/* ELEVATED COLLECTIVE — Shared Stylesheet v2
   Fixes: mobile menu solid bg, light mode visibility, hero cutoff,
   colored social icons, red V, smaller cards, lightbox, button centering */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Manrope:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}ul{list-style:none}button{cursor:pointer;font-family:inherit}

:root{
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Manrope',system-ui,sans-serif;
  --bg-primary:#080808;--bg-secondary:#111111;--bg-card:#161616;--bg-elevated:#1c1c1c;--bg-input:#1a1a1a;
  --text-primary:#f2efe8;--text-secondary:#a09a90;--text-muted:#6b665e;
  --accent:#c8a45e;--accent-hover:#dbb86e;--accent-dim:rgba(200,164,94,.12);
  --red:#b83232;--red-hover:#d43c3c;--red-dim:rgba(184,50,50,.1);
  --border:#252320;--border-hover:#3a3630;--shadow:rgba(0,0,0,.4);
  --overlay:rgba(8,8,8,.94);--gradient-fade:linear-gradient(180deg,transparent 0%,var(--bg-primary) 100%);
}
[data-theme="light"]{
  --bg-primary:#f5f2ed;--bg-secondary:#eae6df;--bg-card:#ffffff;--bg-elevated:#f0ece5;--bg-input:#ffffff;
  --text-primary:#1a1714;--text-secondary:#5c574f;--text-muted:#8a857d;
  --accent:#a07830;--accent-hover:#b8892a;--accent-dim:rgba(160,120,48,.1);
  --red:#a02828;--red-hover:#c03030;--red-dim:rgba(160,40,40,.08);
  --border:#d8d3ca;--border-hover:#c0bab0;--shadow:rgba(0,0,0,.08);
  --overlay:rgba(245,242,237,.96);--gradient-fade:linear-gradient(180deg,transparent 0%,var(--bg-primary) 100%);
}

body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}

/* TYPOGRAPHY */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5vw,4.5rem)}h2{font-size:clamp(1.8rem,3.5vw,3rem)}h3{font-size:clamp(1.3rem,2.5vw,1.8rem)}h4{font-size:1.2rem}
.label{font-family:var(--font-body);font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:block}
.red-v{color:var(--red)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 2rem;background:var(--overlay);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:64px}
.nav-logo{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--text-primary)}
.nav-logo span,.nav-logo .text-accent{color:var(--accent)}
.nav-logo .red-v,.red-v{color:var(--red)!important}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.82rem;font-weight:500;color:var(--text-secondary);transition:color .3s;letter-spacing:.02em}
.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}
/* CTA — ALWAYS white text on red, both modes */
.nav-cta{background:var(--red);color:#fff!important;padding:.55rem 1.3rem;font-size:.78rem;font-weight:600;letter-spacing:.04em;border:none;transition:background .3s}
.nav-cta:hover{background:var(--red-hover);color:#fff!important}
/* Theme toggle — visible in BOTH modes */
.theme-toggle{background:none;border:1px solid var(--border);color:var(--text-primary);width:34px;height:34px;display:flex;align-items:center;justify-content:center;transition:all .3s;border-radius:2px;flex-shrink:0}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
.theme-toggle svg{width:16px;height:16px;stroke:currentColor;fill:none}
[data-theme="light"] .icon-moon{display:none}[data-theme="light"] .icon-sun{display:block}
:not([data-theme="light"]) .icon-sun{display:none}:not([data-theme="light"]) .icon-moon{display:block}

/* Mobile nav hamburger */
.nav-hamburger{display:none;background:none;border:none;color:var(--text-primary);padding:.5rem}
.nav-hamburger svg{width:24px;height:24px}
@media(max-width:768px){
  .nav{padding:0 1.2rem}
  .nav-hamburger{display:flex;align-items:center}
  .nav-links{
    display:none;
    position:fixed;
    top:64px;
    left:0;
    right:0;
    height:calc(100vh - 64px);
    height:calc(100dvh - 64px);
    flex-direction:column;
    justify-content:flex-start;
    align-items:center;
    padding:2.5rem 2rem;
    gap:1.8rem;
    z-index:99999;
    border-top:1px solid var(--border);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch
  }
  .nav-links{background:#080808}
  [data-theme="light"] .nav-links{background:#f5f2ed}
  .nav-links.open{display:flex!important}
  .nav-links a,.nav-links button,.nav-links .theme-toggle{opacity:1!important;visibility:visible!important;position:relative!important;transform:none!important}
  .nav-links a{font-size:1.2rem;color:#f2efe8}
  [data-theme="light"] .nav-links a{color:#1a1714}
  .nav-links a.active{color:var(--accent)}
  .nav-cta{width:100%;text-align:center;padding:.9rem 1.5rem;display:block;margin-top:.5rem}
  .theme-toggle{margin-top:.5rem}
}

/* BUTTONS — .btn-primary always white text */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 2rem;font-family:var(--font-body);font-size:.82rem;font-weight:600;letter-spacing:.05em;border:none;transition:all .3s;text-transform:uppercase;text-align:center}
.btn-primary{background:var(--red);color:#fff!important}
.btn-primary:hover{background:var(--red-hover);transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:#080808!important}
.btn-accent:hover{background:var(--accent-hover);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{background:transparent;color:var(--accent);padding:.5rem 0;text-transform:none;letter-spacing:0;font-size:.88rem;border:none;display:inline-flex;align-items:center;gap:.4rem}
.btn-ghost:hover{color:var(--accent-hover)}
.btn-ghost svg{width:16px;height:16px;transition:transform .3s}
.btn-ghost:hover svg{transform:translateX(4px)}

/* SECTIONS */
.section{padding:5rem 0}
.section-dark{background:var(--bg-secondary);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-header{margin-bottom:2.5rem}
.section-header .label{margin-bottom:.75rem}
.section-header p{color:var(--text-secondary);font-size:1rem;line-height:1.7;max-width:560px;margin-top:.75rem}

/* ARTIST CARDS — smaller, 4 across on desktop */
.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.artist-card{position:relative;overflow:hidden;background:var(--bg-card);border:1px solid var(--border);transition:all .4s}
.artist-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 40px var(--shadow)}
.artist-card-img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .6s ease}
.artist-card:hover .artist-card-img{transform:scale(1.04)}
.placeholder-portrait{width:100%;aspect-ratio:3/4;background:linear-gradient(145deg,#1a1510 0%,#2a2018 40%,#1e1a15 70%,#121010 100%);position:relative}
.placeholder-portrait::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 40% 30%,rgba(200,164,94,.06) 0%,transparent 60%)}
.placeholder-portrait.alt-1{background:linear-gradient(145deg,#10141a,#182028 40%,#151a20 70%,#0e1014)}
.placeholder-portrait.alt-2{background:linear-gradient(145deg,#1a1210,#28201a 40%,#201815 70%,#141010)}
.artist-card-body{padding:.9rem 1rem 1rem}
.artist-card-name{font-family:var(--font-display);font-size:1.05rem;font-weight:600}
.artist-card-role{font-size:.68rem;font-weight:600;color:var(--accent);margin-top:.1rem;text-transform:uppercase;letter-spacing:.06em}
.artist-card-location{font-size:.68rem;color:var(--text-muted);margin-top:.2rem}
.artist-card-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.5rem}
.tag{font-size:.58rem;font-weight:600;padding:.18rem .4rem;border:1px solid var(--border);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}
.tag-accent{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}

/* FILTERS */
.filter-bar{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.5rem}
.filter-btn{padding:.4rem .8rem;font-family:var(--font-body);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:transparent;border:1px solid var(--border);color:var(--text-muted);transition:all .3s}
.filter-btn:hover,.filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}

/* FORMS */
.form-group{margin-bottom:1.5rem}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:.02em}
.form-label .required{color:var(--red);margin-left:2px}
.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:.3rem}
.form-input,.form-textarea,.form-select{width:100%;padding:.75rem 1rem;font-family:var(--font-body);font-size:.9rem;background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);transition:border-color .3s;appearance:none;border-radius:0}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--accent)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-textarea{resize:vertical;min-height:120px}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b665e' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.6rem}
.checkbox-item{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text-secondary);cursor:pointer}
.checkbox-item input[type="checkbox"]{width:18px;height:18px;accent-color:var(--red);cursor:pointer;flex-shrink:0}
.form-dynamic{display:none}.form-dynamic.visible{display:block}

/* PROCESS GRID */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.process-step{padding:2rem 1.5rem;background:var(--bg-primary)}
.process-step-num{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--accent);opacity:.25;line-height:1;margin-bottom:1rem}
.process-step h4{font-family:var(--font-body);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}
.process-step p{font-size:.85rem;color:var(--text-secondary);line-height:1.6}
@media(max-width:900px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:550px){.process-grid{grid-template-columns:1fr}}

/* FAQ */
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.3rem 0;background:none;border:none;text-align:left;font-family:var(--font-body);font-size:.95rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:color .3s;gap:1rem}
.faq-question:hover{color:var(--accent)}
.faq-question svg{width:18px;height:18px;flex-shrink:0;color:var(--text-muted);transition:transform .3s}
.faq-item.open .faq-question svg{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-answer{max-height:500px;padding-bottom:1.3rem}
.faq-answer p{font-size:.9rem;color:var(--text-secondary);line-height:1.7}

/* FOOTER with colored social icons */
.footer{background:var(--bg-secondary);border-top:1px solid var(--border);padding:3.5rem 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--border)}
.footer-brand p{font-size:.85rem;color:var(--text-secondary);line-height:1.7;margin-top:1rem;max-width:320px}
.footer-heading{font-family:var(--font-body);font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem}
.footer-links a{display:block;font-size:.85rem;color:var(--text-secondary);padding:.25rem 0;transition:color .3s}
.footer-links a:hover{color:var(--accent)}
.footer-socials{display:flex;gap:.7rem;margin-top:1.2rem}
.footer-social{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .3s,box-shadow .3s}
.footer-social:hover{transform:scale(1.1)}
.footer-social svg{width:18px;height:18px;fill:#fff;stroke:none}
.footer-social--ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.footer-social--ig:hover{box-shadow:0 4px 20px rgba(225,48,108,.5)}
.footer-social--fb{background:#1877F2}
.footer-social--fb:hover{box-shadow:0 4px 20px rgba(24,119,242,.5)}
.footer-social--yt{background:#FF0000}
.footer-social--yt:hover{box-shadow:0 4px 20px rgba(255,0,0,.5)}
.footer-bottom{padding:1.2rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem}
.footer-copy{font-size:.75rem;color:var(--text-muted)}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{font-size:.75rem;color:var(--text-muted);transition:color .3s}
.footer-legal a:hover{color:var(--accent)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.footer-bottom{flex-direction:column;align-items:flex-start}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}}

/* HERO */
.hero{min-height:85vh;display:flex;align-items:flex-end;padding:0 0 4rem;position:relative}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 65% 25%,rgba(184,50,50,.05) 0%,transparent 70%),radial-gradient(ellipse 50% 70% at 25% 75%,rgba(200,164,94,.04) 0%,transparent 60%)}
.hero-bg::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:var(--gradient-fade)}
.hero .container{position:relative;z-index:2}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-sub{font-size:1.05rem;font-weight:400;color:var(--text-secondary);max-width:520px;margin-top:1.2rem;line-height:1.7}
.hero-actions{display:flex;gap:.8rem;margin-top:2rem;flex-wrap:wrap}
@media(max-width:768px){.hero{min-height:70vh;padding:6rem 0 3rem;align-items:flex-end}.hero h1{font-size:clamp(1.8rem,8vw,3rem)}}

/* PAGE HERO (inner pages) */
.page-hero{padding:8rem 0 3rem;position:relative;border-bottom:1px solid var(--border)}
.page-hero .hero-bg{position:absolute;inset:0;z-index:0}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{font-size:clamp(1.8rem,4vw,3rem)}
.page-hero p{color:var(--text-secondary);font-size:1rem;max-width:550px;margin-top:.8rem;line-height:1.7}

/* ARTIST PROFILE */
.profile-hero{padding:6rem 0 0}
.profile-layout{display:grid;grid-template-columns:380px 1fr;gap:3.5rem;align-items:start}
.profile-photo-main{width:100%;aspect-ratio:3/4;object-fit:cover;border:1px solid var(--border);cursor:pointer}
.profile-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;margin-top:.4rem}
.profile-photo-thumb{width:100%;aspect-ratio:1;object-fit:cover;border:1px solid var(--border);opacity:.7;transition:opacity .3s;cursor:pointer}
.profile-photo-thumb:hover{opacity:1}
.profile-info{padding-top:.5rem}
.profile-name{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,3rem);font-weight:700;line-height:1.1}
.profile-role{font-size:.82rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-top:.4rem}
.profile-location{font-size:.88rem;color:var(--text-muted);margin-top:.25rem}
.profile-bio{color:var(--text-secondary);font-size:.95rem;line-height:1.8;margin-top:1.2rem;max-width:600px}
.profile-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.profile-detail-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.3rem}
.profile-detail-value{font-size:.9rem;color:var(--text-primary)}
.interview-section{padding:3rem 0}
.qa-block{padding:1.5rem 0;border-bottom:1px solid var(--border)}.qa-block:last-child{border-bottom:none}
.qa-question{font-family:var(--font-display);font-size:1.2rem;font-weight:600;font-style:italic;color:var(--accent);margin-bottom:.6rem}
.qa-answer{font-size:.95rem;color:var(--text-secondary);line-height:1.8}
.video-embed{width:100%;aspect-ratio:16/9;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin:1.2rem 0;overflow:hidden}
.video-embed iframe{width:100%;height:100%;border:none}
.video-embed-placeholder{text-align:center;color:var(--text-muted);font-size:.85rem}
.video-embed-placeholder svg{width:40px;height:40px;margin-bottom:.5rem;opacity:.3}
@media(max-width:900px){.profile-layout{grid-template-columns:1fr;gap:2rem}.profile-layout>div:first-child{max-width:360px}}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.active{display:flex}
.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain}
.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;opacity:.7;transition:opacity .3s;line-height:1}
.lightbox-close:hover{opacity:1}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.7;transition:opacity .3s,background .3s}
.lightbox-nav:hover{opacity:1;background:rgba(255,255,255,.2)}
.lightbox-prev{left:1.5rem}.lightbox-next{right:1.5rem}
.lightbox-nav svg{width:20px;height:20px}

/* CONTACT CARDS */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.contact-card{padding:2rem;border:1px solid var(--border);background:var(--bg-card);transition:border-color .3s}
.contact-card:hover{border-color:var(--accent)}
.contact-card svg{width:24px;height:24px;color:var(--accent);margin-bottom:1rem}
.contact-card h4{font-family:var(--font-body);font-size:.9rem;font-weight:700;margin-bottom:.5rem}
.contact-card p{font-size:.85rem;color:var(--text-secondary);line-height:1.6}
.contact-card a{color:var(--accent);transition:color .3s}
.contact-card a:hover{color:var(--accent-hover)}

/* TWO-COL SPLIT */
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
@media(max-width:768px){.split-grid{grid-template-columns:1fr;gap:3rem}}

/* UTILITY */
.text-accent{color:var(--accent)}.text-red{color:var(--red)}.text-muted{color:var(--text-muted)}
.divider{width:60px;height:2px;background:var(--accent);margin:1rem 0}.divider-red{background:var(--red)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:480px){.container{padding:0 1.2rem}.section{padding:3.5rem 0}.roster-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.profile-details-grid{grid-template-columns:1fr}}
