/* ============================================================
   बालेन्दु द्विवेदी — stylesheet
   Edit palettes in the "COLOR PALETTES" block. Default palette
   is set via data-palette on <html> in index.html.
   ============================================================ */

:root{
  --bg:#F4EDDD; --bg-2:#EDE4D0; --surface:#FBF6EC;
  --text:#211C17; --text-soft:#4E463B; --text-faint:#6E6354;
  --accent:#9B2D20; --accent-2:#876618; --on-accent:#fff;
  --line:rgba(33,28,23,.15); --line-soft:rgba(33,28,23,.07);
  --maxw:1180px;
  --display:'Rozha One','Tiro Devanagari Hindi',serif;
  --serif:'Tiro Devanagari Hindi',Georgia,serif;
  --sans:'Mukta',system-ui,sans-serif;
}

/* ====================== COLOR PALETTES (light) — tuned for WCAG AA ====================== */
[data-palette="oxblood"]{--bg:#F4EDDD;--bg-2:#EDE4D0;--surface:#FBF6EC;--text:#211C17;--text-soft:#4E463B;--text-faint:#6E6354;--accent:#9B2D20;--accent-2:#876618;--line:rgba(33,28,23,.15);--line-soft:rgba(33,28,23,.07)}
[data-palette="indigo"]{--bg:#EEEFF4;--bg-2:#E3E5EF;--surface:#F8F9FC;--text:#1A1C24;--text-soft:#3F4459;--text-faint:#666B7D;--accent:#343F80;--accent-2:#8A5A1E;--line:rgba(26,28,36,.15);--line-soft:rgba(26,28,36,.07)}
[data-palette="forest"]{--bg:#EDF1EA;--bg-2:#E1E8DA;--surface:#F7FAF2;--text:#1B201A;--text-soft:#3E4639;--text-faint:#66705E;--accent:#2C5C45;--accent-2:#876618;--line:rgba(27,32,26,.15);--line-soft:rgba(27,32,26,.07)}
[data-palette="terracotta"]{--bg:#F5ECE3;--bg-2:#EEE1D2;--surface:#FCF6EC;--text:#241C15;--text-soft:#4C4236;--text-faint:#6F6453;--accent:#A0431F;--accent-2:#6B5A30;--line:rgba(36,28,21,.15);--line-soft:rgba(36,28,21,.07)}
[data-palette="plum"]{--bg:#F2ECF0;--bg-2:#E8DDE5;--surface:#FBF6F9;--text:#221A20;--text-soft:#473C43;--text-faint:#6E6168;--accent:#6B2858;--accent-2:#876618;--line:rgba(34,26,32,.15);--line-soft:rgba(34,26,32,.07)}
[data-palette="teal"]{--bg:#E9F0EF;--bg-2:#DBE7E4;--surface:#F4FAF8;--text:#15201E;--text-soft:#3A4744;--text-faint:#5E6E6A;--accent:#1C6460;--accent-2:#8C6018;--line:rgba(21,32,30,.15);--line-soft:rgba(21,32,30,.07)}
[data-palette="royal"]{--bg:#ECEEF5;--bg-2:#E0E4F0;--surface:#F6F8FD;--text:#191C26;--text-soft:#3E4356;--text-faint:#666B80;--accent:#243C80;--accent-2:#8A6018;--line:rgba(25,28,38,.15);--line-soft:rgba(25,28,38,.07)}
[data-palette="charcoal"]{--bg:#EFEDE8;--bg-2:#E3E0D9;--surface:#F9F7F2;--text:#1E1C18;--text-soft:#45403A;--text-faint:#6B6458;--accent:#3C3A36;--accent-2:#7A6018;--line:rgba(30,28,24,.15);--line-soft:rgba(30,28,24,.07)}

/* ====================== DARK base + per-palette accents ====================== */
:root[data-theme="dark"]{
  --bg:#15120E; --bg-2:#1C1813; --surface:#211B14;
  --text:#ECE3D1; --text-soft:#B8AF9D; --text-faint:#948975;
  --accent:#E0644F; --accent-2:#E0A53C; --on-accent:#181310;
  --line:rgba(236,227,209,.14); --line-soft:rgba(236,227,209,.07);
}
:root[data-theme="dark"][data-palette="oxblood"]{--accent:#E0644F;--accent-2:#E0A53C}
:root[data-theme="dark"][data-palette="indigo"]{--accent:#8AA0E8;--accent-2:#E0A53C}
:root[data-theme="dark"][data-palette="forest"]{--accent:#6FC09A;--accent-2:#E0A53C}
:root[data-theme="dark"][data-palette="terracotta"]{--accent:#E58A5E;--accent-2:#D9B25E}
:root[data-theme="dark"][data-palette="plum"]{--accent:#D588C0;--accent-2:#E0A53C}
:root[data-theme="dark"][data-palette="teal"]{--accent:#5FC9C0;--accent-2:#E6B24C}
:root[data-theme="dark"][data-palette="royal"]{--accent:#8AA2F0;--accent-2:#E0A53C}
:root[data-theme="dark"][data-palette="charcoal"]{--accent:#D6CFC2;--accent-2:#E0A53C}

/* ====================== BASE ====================== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:70px;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--serif);font-size:clamp(1.02rem,.4vw + .95rem,1.15rem);line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;transition:background .4s ease,color .4s ease}
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
:root[data-theme="dark"] body::before{mix-blend-mode:overlay;opacity:.06}
::selection{background:var(--accent);color:var(--on-accent)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,64px);position:relative;z-index:2}
.it{font-style:italic}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.kick{font-family:var(--sans);font-size:.78rem;font-weight:600;color:var(--accent)}
.lat{letter-spacing:.04em}
.skip{position:absolute;left:-9999px;top:0;z-index:400;background:var(--accent);color:var(--on-accent);font-family:var(--sans);font-size:.9rem;padding:10px 16px;border-radius:0 0 8px 0}
.skip:focus{left:0}
main{display:block}

/* ====================== NAV ====================== */
nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(12px) saturate(1.2);border-bottom:1px solid var(--line-soft);transition:box-shadow .35s}
nav.scrolled{box-shadow:0 10px 30px rgba(0,0,0,.12)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:11px clamp(18px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-brand{font-family:var(--display);font-size:1.5rem}
.nav-brand b{color:var(--accent)}
.nav-links{display:flex;gap:18px;align-items:center}
.nav-links a{font-family:var(--sans);font-size:.84rem;font-weight:500;color:var(--text-soft);position:relative;padding:4px 0;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1.5px;background:var(--accent);transition:width .35s cubic-bezier(.2,.7,.2,1)}
.nav-links a:hover{color:var(--text)}.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:10px}
.theme-tog,.menu-tog{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--text-soft);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.25s;flex:0 0 auto}
.theme-tog:hover,.menu-tog:hover{color:var(--accent);border-color:var(--accent)}
.lang-tog{height:36px;min-width:42px;padding:0 12px;border-radius:100px;border:1px solid var(--line);background:transparent;color:var(--text-soft);font-family:var(--sans);font-size:.78rem;font-weight:600;cursor:pointer;transition:.25s;flex:0 0 auto}
.lang-tog:hover{color:var(--accent);border-color:var(--accent)}
.theme-tog svg,.menu-tog svg{width:16px;height:16px}
.ic-moon{display:none}:root[data-theme="dark"] .ic-sun{display:none}:root[data-theme="dark"] .ic-moon{display:block}
.menu-tog{display:none}
.mobile-menu{display:none;flex-direction:column;background:var(--surface);border-bottom:1px solid var(--line)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--sans);font-size:1rem;padding:13px clamp(18px,5vw,64px);border-top:1px solid var(--line-soft);color:var(--text)}
.mm-controls{display:flex;gap:10px;padding:14px clamp(18px,5vw,64px);border-top:1px solid var(--line-soft)}
.mm-controls button{flex:1;font-family:var(--sans);font-size:.84rem;font-weight:500;padding:11px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--text);cursor:pointer}
.mm-controls button:active{background:var(--accent);color:var(--on-accent)}
@media(max-width:900px){.nav-links{display:none}.menu-tog{display:inline-flex}}

/* ====================== HERO ====================== */
.hero{padding:clamp(40px,7vw,92px) 0 clamp(30px,4vw,52px);position:relative;overflow:hidden}
.hero .topline{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:clamp(26px,4vw,48px);font-family:var(--sans);font-size:.76rem;color:var(--text-faint)}
.hero-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(28px,5vw,60px);align-items:center}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr}}
.masthead{font-family:var(--display);line-height:1.04;font-size:clamp(2.8rem,11vw,7rem);word-break:break-word}
.masthead .l{display:block;opacity:0;transform:translateY(.18em);animation:rise .9s cubic-bezier(.16,1,.3,1) forwards}
.masthead .l2{color:var(--accent);animation-delay:.14s}
@keyframes rise{to{opacity:1;transform:none}}
.standfirst{font-family:var(--serif);font-style:italic;font-size:clamp(1.25rem,2.6vw,1.95rem);line-height:1.4;max-width:24ch;margin:clamp(20px,3vw,30px) 0 14px;opacity:0;animation:fade .9s ease .5s forwards}
.standfirst b{color:var(--accent);font-style:italic}
.lead{color:var(--text-soft);max-width:42ch;font-size:1.05rem;opacity:0;animation:fade .9s ease .66s forwards}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:clamp(22px,3vw,32px);opacity:0;animation:fade .9s ease .8s forwards}
.btn{font-family:var(--sans);font-size:.86rem;font-weight:600;padding:13px 24px;border-radius:100px;border:1px solid var(--text);display:inline-flex;align-items:center;gap:8px;transition:.3s;color:var(--text);cursor:pointer;background:transparent}
.btn .a{transition:transform .3s}.btn:hover .a{transform:translateX(4px)}
.btn-fill{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.btn-fill:hover{filter:brightness(1.08)}
.btn-ghost:hover{background:var(--text);color:var(--bg)}
.hero-portrait{position:relative}
.hero-portrait img{width:100%;height:auto;border-radius:8px;filter:grayscale(.16) contrast(1.03);box-shadow:0 30px 70px rgba(0,0,0,.22)}
.hero-portrait .cap{font-family:var(--sans);font-size:.7rem;color:var(--text-faint);margin-top:10px;text-align:right}
@media(max-width:880px){.hero-portrait{max-width:340px;margin:0 auto}}
.specs{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);margin-top:clamp(34px,5vw,56px)}
@media(max-width:620px){.specs{grid-template-columns:repeat(2,1fr)}}
.spec{padding:18px 16px;border-right:1px solid var(--line)}
.spec:last-child{border-right:0}
@media(max-width:620px){.spec:nth-child(2){border-right:0}.spec:nth-child(-n+2){border-bottom:1px solid var(--line)}}
.spec .n{font-family:var(--display);font-size:clamp(1.8rem,3.4vw,2.5rem);color:var(--accent);line-height:1}
.spec .l{font-family:var(--sans);font-size:.72rem;color:var(--text-faint);margin-top:6px}

/* ====================== SECTION SHELL ====================== */
section{padding:clamp(48px,7vw,96px) 0}
.shead{position:relative;margin-bottom:clamp(30px,4vw,48px)}
.shead .top{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.shead .side{font-family:var(--sans);font-size:.76rem;color:var(--text-faint)}
.shead h2{font-family:var(--display);font-size:clamp(1.9rem,5vw,3.3rem);line-height:1.12}
.shead::after{content:"";display:block;height:1.5px;background:var(--text);transform:scaleX(0);transform-origin:left;transition:transform 1s cubic-bezier(.16,1,.3,1)}
.shead.in::after{transform:scaleX(1)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.band{background:var(--bg-2)}

/* ====================== ABOUT ====================== */
.about{display:grid;grid-template-columns:.85fr 1.4fr;gap:clamp(28px,5vw,60px);align-items:start}
@media(max-width:840px){.about{grid-template-columns:1fr}}
.about-portrait img{width:100%;height:auto;border-radius:8px;filter:grayscale(.2) contrast(1.03)}
.about-meta{margin-top:16px}
.about-meta .row{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:.95rem}
.about-meta .k{font-family:var(--sans);font-size:.78rem;color:var(--accent);min-width:84px;padding-top:3px}
.about-meta .v{color:var(--text-soft)}
.abody p{font-size:clamp(1.06rem,1.5vw,1.22rem);line-height:1.78;margin-bottom:1em}
.abody p:first-child::first-letter{font-family:var(--display);float:left;font-size:3.2em;line-height:.7;padding:.06em .12em 0 0;color:var(--accent)}
.abody .pq{font-style:italic;font-size:clamp(1.25rem,2.2vw,1.6rem);line-height:1.4;color:var(--accent);border-left:2px solid var(--accent);padding-left:20px;margin:1.1em 0}

/* ====================== BOOKS ====================== */
.books{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:clamp(18px,2.5vw,32px)}
.book{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:pointer;transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}
.book .cov{cursor:pointer}
.book:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(0,0,0,.16)}
.book .cov{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bg-2);cursor:zoom-in}
.book .cov img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.book:hover .cov img{transform:scale(1.04)}
.book .cov.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;background:linear-gradient(150deg,var(--accent),var(--accent-2));cursor:default}
.book .cov.placeholder .pt{font-family:var(--display);color:var(--on-accent);font-size:1.6rem;line-height:1.2}
.book .cov.placeholder .pg{font-family:var(--sans);color:var(--on-accent);opacity:.8;font-size:.72rem;margin-top:12px}
.book .bd{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.book .gen{font-family:var(--sans);font-size:.72rem;font-weight:600;color:var(--accent)}
.book .t{font-family:var(--serif);font-size:1.32rem;line-height:1.2;overflow-wrap:anywhere}
.book .meta{font-family:var(--sans);font-size:.76rem;color:var(--text-faint)}
.book .bl{font-size:.96rem;line-height:1.6;color:var(--text-soft)}
.book .actions{margin-top:auto;padding-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.bbtn{font-family:var(--sans);font-size:.74rem;font-weight:600;padding:7px 14px;border-radius:100px;border:1px solid var(--accent);color:var(--accent);transition:.25s}
.bbtn:hover{background:var(--accent);color:var(--on-accent)}
.bbtn.listen{border-color:var(--accent-2);color:var(--accent-2)}
.bbtn.listen:hover{background:var(--accent-2);color:var(--on-accent)}

/* ====================== FORTHCOMING ====================== */
.glabel{display:flex;align-items:center;gap:14px;margin:clamp(26px,4vw,42px) 0 16px}
.glabel:first-of-type{margin-top:0}
.glabel .gt{font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--accent)}
.glabel .gl{flex:1;height:1px;background:var(--line)}
.fbooks{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr));gap:clamp(12px,1.8vw,20px)}
.fbook{background:var(--surface);border:1px solid var(--line);border-radius:9px;overflow:hidden;transition:transform .4s,box-shadow .4s}
.fbook:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.14)}
.fbook .cov{aspect-ratio:3/4;overflow:hidden;background:var(--bg-2);cursor:zoom-in}
.fbook .cov img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.fbook:hover .cov img{transform:scale(1.04)}
.fbook .cov.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:16px;background:linear-gradient(150deg,var(--accent),var(--accent-2));cursor:default}
.fbook .cov.placeholder .pt{font-family:var(--display);color:var(--on-accent);font-size:1.1rem;line-height:1.2}
.fbook .cov.placeholder .pg{font-family:var(--sans);color:var(--on-accent);opacity:.8;font-size:.62rem;margin-top:8px}
.fbook .bd{padding:13px 14px 15px}
.fbook .t{font-family:var(--serif);font-size:1.06rem;line-height:1.22;overflow-wrap:anywhere}
.fbook .s{font-family:var(--sans);font-size:.74rem;color:var(--text-faint);margin-top:5px;line-height:1.4}
.coming{font-family:var(--sans);font-size:.66rem;font-weight:600;color:var(--on-accent);background:var(--accent);border-radius:100px;padding:3px 11px;display:inline-block;margin-bottom:8px}

/* ====================== FILMOGRAPHY ====================== */
.films{display:grid;gap:clamp(16px,2vw,24px)}
.film{background:var(--surface);border:1px solid var(--line);border-radius:11px;overflow:hidden}
.film-head{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:baseline;padding:clamp(16px,2vw,24px);border-bottom:1px solid var(--line-soft)}
.film-head>div{min-width:0}
.film-head .no{font-family:var(--sans);font-size:.84rem;color:var(--text-faint)}
.film-head .nm{font-family:var(--serif);font-size:clamp(1.25rem,2.6vw,1.95rem);line-height:1.12;overflow-wrap:anywhere}
.film-head .ds{font-family:var(--sans);font-size:.84rem;color:var(--text-soft);margin-top:4px}
.film-head .aw{font-family:var(--sans);font-size:.78rem;font-weight:600;color:var(--accent-2);text-align:right}
@media(max-width:680px){.film-head{grid-template-columns:auto 1fr}.film-head .aw{grid-column:2;text-align:left;margin-top:4px}}
.film-certs{display:flex;gap:12px;padding:clamp(14px,1.8vw,20px);overflow-x:auto;scrollbar-width:thin;position:relative}
.film-certs img{height:clamp(150px,18vw,170px);width:auto;border-radius:6px;border:1px solid var(--line);cursor:zoom-in;transition:transform .35s;flex:0 0 auto}
.film-certs img:hover{transform:scale(1.03)}
.film-feature{margin-bottom:clamp(24px,3vw,38px);display:grid;grid-template-columns:280px 1fr;gap:clamp(20px,3vw,38px);align-items:center;border:1px solid var(--line);padding:clamp(18px,2.5vw,28px);border-radius:11px;background:var(--surface)}
@media(max-width:680px){.film-feature{grid-template-columns:1fr}}
.film-feature img{border-radius:7px;width:100%;height:auto;cursor:zoom-in}
.film-feature .ft{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2rem)}
.film-feature .fd{color:var(--text-soft);margin-top:8px}
.film-credit{font-family:var(--sans);font-size:.9rem;color:var(--text-soft);margin-top:clamp(20px,2.5vw,30px);text-align:center}
.film-credit b{color:var(--accent)}

/* ====================== AWARDS ====================== */
.aw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:clamp(14px,2vw,22px)}
.awc{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:clamp(18px,2.2vw,24px);display:flex;flex-direction:column;gap:8px;transition:transform .4s,box-shadow .4s;border-top:3px solid var(--accent)}
.awc:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.13)}
.awc .yr{font-family:var(--display);font-size:1.5rem;color:var(--accent)}
.awc .nm{font-family:var(--serif);font-size:1.18rem;line-height:1.3;overflow-wrap:anywhere}
.awc .by{font-family:var(--sans);font-size:.82rem;color:var(--text-soft)}
.awc .sub{font-family:var(--sans);font-size:.78rem;color:var(--text-faint);font-style:italic}
.gallery-cap{font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--accent);margin:clamp(40px,5vw,60px) 0 18px;display:flex;align-items:center;gap:12px}
.gallery-cap::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(190px,100%),1fr));gap:clamp(12px,1.6vw,18px)}
.gal .gi{position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--bg-2);cursor:zoom-in;aspect-ratio:4/3}
.gal .gi img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gal .gi:hover img{transform:scale(1.05)}
.gal.tall .gi{aspect-ratio:3/4}
/* progressive disclosure */
.gal.collapsed .gi:nth-child(n+7){display:none}
.showmore{display:flex;justify-content:center;margin-top:18px}
.showmore button{font-family:var(--sans);font-size:.8rem;font-weight:600;color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:100px;padding:9px 22px;cursor:pointer;transition:.25s}
.showmore button:hover{background:var(--accent);color:var(--on-accent)}

/* ====================== PRESS ====================== */
.press{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:720px){.press{grid-template-columns:1fr}}
.press .pq{background:var(--surface);padding:clamp(22px,3vw,34px);display:flex;flex-direction:column}
.press .pq q{font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2.2vw,1.55rem);line-height:1.35;quotes:none}
.press .pq .by{font-family:var(--sans);font-size:.78rem;font-weight:600;color:var(--accent);margin-top:14px}
.press .pq .src{font-family:var(--sans);font-size:.72rem;color:var(--text-faint);margin-top:4px}
.videos{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:clamp(16px,2vw,22px)}
.vid{background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.vid .frame{position:relative;aspect-ratio:16/9;background:#000;cursor:pointer}
.vid .frame img{width:100%;height:100%;object-fit:cover;opacity:.85;transition:opacity .3s}
.vid .frame:hover img{opacity:1}
.vid .frame .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.vid .frame .play span{width:58px;height:58px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;font-size:1.4rem;padding-left:4px;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.vid .vbd{padding:14px 15px 16px}
.vid .vt{font-family:var(--serif);font-size:1.1rem;line-height:1.25}
.vid .vs{font-family:var(--sans);font-size:.74rem;color:var(--text-faint);margin-top:5px}

/* ====================== CONTACT ====================== */
.contact{background:var(--bg-2);border-top:1px solid var(--line)}
.contact .big{font-family:var(--display);font-size:clamp(2.2rem,6vw,4rem);line-height:1.1;margin-bottom:8px}
.contact .big em{font-style:normal;color:var(--accent)}
.contact .sub{font-style:italic;color:var(--text-soft);max-width:40ch;font-size:clamp(1.1rem,2vw,1.35rem)}
.csocial{display:flex;flex-wrap:wrap;gap:12px;margin-top:clamp(28px,4vw,40px)}
.cs{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:100px;padding:11px 18px 11px 13px;transition:.25s}
.cs:hover{border-color:var(--accent);transform:translateY(-2px)}
.cs .ico{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:var(--accent)}
.cs .ico svg{width:20px;height:20px;fill:currentColor}
.cs .lbl{font-family:var(--sans);font-size:.86rem;font-weight:500}
.cs.only-mobile{display:none}
@media(max-width:680px){.cs.only-mobile{display:inline-flex}}
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,48px);margin-top:clamp(28px,4vw,40px);align-items:start}
@media(max-width:860px){.cgrid{grid-template-columns:1fr}}
.cform{display:flex;flex-direction:column;gap:12px}
.cform label{font-family:var(--sans);font-size:.78rem;color:var(--text-faint);display:block;margin-bottom:5px}
.cform input,.cform textarea{font-family:var(--serif);font-size:1rem;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text);width:100%}
.cform input:focus,.cform textarea:focus{outline:2px solid var(--accent);border-color:transparent}
.form-msg{font-family:var(--sans);font-size:.9rem;margin-top:4px}
.form-msg.ok{color:var(--accent-2)}.form-msg.err{color:var(--accent)}
.fbembed{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--surface);min-height:200px}
.fbembed iframe{display:block;width:100%;border:0}

/* ====================== FOOTER ====================== */
footer{background:var(--bg);border-top:1px solid var(--line)}
.foot-in{max-width:var(--maxw);margin:0 auto;padding:24px clamp(18px,5vw,64px);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-family:var(--sans);font-size:.74rem;color:var(--text-faint)}
.foot-in .g{color:var(--accent)}
.foot-dot{cursor:default;user-select:none}

/* ====================== LIGHTBOX ====================== */
.lb{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:clamp(14px,4vw,48px);background:rgba(10,8,6,.93);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity .3s}
.lb.show{opacity:1;visibility:visible}
.lb img,.lb .lbvid{max-width:90vw;max-height:84vh;border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,.6);transform:scale(.98);transition:transform .3s}
.lb.show img,.lb.show .lbvid{transform:none}
.lb .lbvid{width:min(90vw,960px);aspect-ratio:16/9}
.lb-x{position:absolute;top:18px;right:18px;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.4);color:#fff;font-size:1.3rem;cursor:pointer}

/* ====================== STUDIO (hidden theme switcher) ====================== */
.studio{position:fixed;right:16px;bottom:16px;z-index:300;width:min(300px,calc(100vw - 32px));background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.3);padding:16px;transform:translateY(20px) scale(.96);opacity:0;visibility:hidden;transition:.3s cubic-bezier(.16,1,.3,1)}
.studio.open{transform:none;opacity:1;visibility:visible}
.studio h4{font-family:var(--sans);font-size:.82rem;font-weight:700;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}
.studio .hint{font-family:var(--sans);font-size:.68rem;color:var(--text-faint);margin-bottom:12px}
.studio .sx{cursor:pointer;border:0;background:none;color:var(--text-faint);font-size:1.1rem}
.swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.sw{aspect-ratio:1;border-radius:8px;border:2px solid transparent;cursor:pointer;position:relative;overflow:hidden}
.sw[aria-pressed="true"]{border-color:var(--text)}
.sw .dot{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-family:var(--sans);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.studio .modes{display:flex;gap:8px}
.studio .modes button{flex:1;font-family:var(--sans);font-size:.78rem;padding:8px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--text);cursor:pointer}
.studio .modes button.on{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}

/* ====================== QUICK-JUMP CHIPS (sticky) ====================== */
.chips{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:8px clamp(18px,5vw,64px) 10px;border-top:1px solid var(--line-soft)}
.chips::-webkit-scrollbar{display:none}
.chips a{flex:0 0 auto;font-family:var(--sans);font-size:.8rem;font-weight:500;color:var(--text-soft);border:1px solid var(--line);border-radius:100px;padding:6px 15px;transition:.25s;white-space:nowrap}
.chips a:hover,.chips a.active{color:var(--on-accent);background:var(--accent);border-color:var(--accent)}

/* ====================== MARQUEE (reviews ticker) ====================== */
.marquee{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee .mtrack{display:flex;gap:clamp(14px,2vw,22px);width:max-content;animation:scrollx 46s linear infinite}
.marquee:hover .mtrack{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.qcard{flex:0 0 auto;width:clamp(280px,34vw,400px);background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:clamp(20px,2.4vw,28px);display:flex;flex-direction:column;border-top:3px solid var(--accent)}
.qcard q{font-family:var(--serif);font-style:italic;font-size:clamp(1.05rem,1.7vw,1.28rem);line-height:1.45;quotes:none;flex:1}
.qcard .qfoot{display:flex;align-items:center;gap:11px;margin-top:16px}
.qcard .qav{flex:none;width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}
.qcard .qav-ph{display:grid;place-items:center;background:var(--accent);color:var(--on-accent);font-family:var(--display);font-size:1.15rem;line-height:1}
.qcard .qmeta{display:flex;flex-direction:column;gap:1px;min-width:0}
.qcard .qname{font-family:var(--sans);font-size:.86rem;font-weight:700;color:var(--text)}
.qcard .qrole{font-family:var(--sans);font-size:.72rem;color:var(--text-faint)}
.qcard .qtags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.qcard .qtag{font-family:var(--sans);font-size:.68rem;font-weight:600;padding:3px 9px;border-radius:100px;letter-spacing:.01em}
.qcard .qbook{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.qcard .qplat{background:var(--bg-2);color:var(--text-soft);border:1px solid var(--line)}
.qcard .qbook::before{content:"📖 ";font-size:.78em}

/* ====================== 2-D PHOTO WALL (gallery) ====================== */
.wall{display:flex;flex-direction:column;gap:clamp(10px,1.4vw,14px);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.wrow{display:flex;gap:clamp(10px,1.4vw,14px);width:max-content}
.wrow.lft{animation:scrollx 60s linear infinite}
.wrow.rgt{animation:scrollxr 60s linear infinite}
@keyframes scrollxr{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.wall:hover .wrow{animation-play-state:paused}
.wimg{flex:0 0 auto;height:clamp(120px,15vw,180px);border-radius:10px;overflow:hidden;cursor:zoom-in;border:1px solid var(--line);background:var(--bg-2)}
.wimg img{height:100%;width:auto;display:block;transition:transform .5s}
.wimg:hover img{transform:scale(1.05)}

/* ====================== CAROUSEL (forthcoming / videos / press / ceremony) ====================== */
.carousel{position:relative}
.ctrack{display:flex;gap:clamp(12px,1.8vw,20px);overflow-x:auto;scroll-snap-type:x proximity;scroll-behavior:smooth;scrollbar-width:none;padding:4px 2px 12px}
.ctrack::-webkit-scrollbar{display:none}
.ctrack>*{scroll-snap-align:start;flex:0 0 auto}
.carr-btn{position:absolute;top:38%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:1.3rem;line-height:1;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(0,0,0,.14);transition:.2s}
.carr-btn:hover{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.carr-prev{left:-6px}.carr-next{right:-6px}
.carr-btn[disabled]{opacity:0;pointer-events:none}
@media(max-width:680px){.carr-btn{display:none}}
.carousel .fbook{width:clamp(150px,42vw,180px)}
.carousel .vid{width:clamp(260px,72vw,320px)}
.carousel .ctile{width:clamp(200px,60vw,280px);border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--bg-2);cursor:zoom-in}
.carousel .ctile img{width:100%;height:200px;object-fit:cover;display:block;transition:transform .5s}
.carousel .ctile:hover img{transform:scale(1.04)}
.carousel .ctile.cer img{height:170px}

/* ====================== TABS (media) ====================== */
.tabs{display:flex;gap:8px;margin-bottom:clamp(24px,3vw,34px);flex-wrap:wrap}
.tab{font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--text-soft);background:transparent;border:1px solid var(--line);border-radius:100px;padding:8px 18px;cursor:pointer;transition:.25s}
.tab:hover{border-color:var(--accent);color:var(--accent)}
.tab.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.tabpanel{display:none}
.tabpanel.active{display:block;animation:fadein .4s ease}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ====================== FILM CARDS + LAUREL ====================== */
.fcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:clamp(16px,2.2vw,26px)}
.fcard{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface);cursor:pointer;transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;display:flex;flex-direction:column;text-align:left;font:inherit;color:inherit;padding:0}
.fcard:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(0,0,0,.18)}
.fposter{aspect-ratio:3/4;position:relative;overflow:hidden;background:linear-gradient(155deg,var(--accent),#1c140e)}
.fposter>img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.fcard:hover .fposter>img{transform:scale(1.04)}
.fposter .grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,8,6,.86),rgba(10,8,6,.05) 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:16px}
.fposter .fno{position:absolute;top:12px;left:14px;font-family:var(--sans);font-size:.7rem;color:rgba(255,255,255,.7)}
.fposter .ft{font-family:var(--display);color:#fff;font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.08}
.fposter .fg{font-family:var(--sans);color:rgba(255,255,255,.82);font-size:.72rem;margin-top:5px}
.fcard .fbd{padding:13px 15px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid var(--line-soft)}
.fcard .open{font-family:var(--sans);font-size:.74rem;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:5px}
.laurel{display:inline-flex;align-items:center;gap:3px}
.laurel .lsp{width:15px;height:32px;color:var(--accent-2);flex:0 0 auto}
.laurel .lsp.flip{transform:scaleX(-1)}
.laurel .lc{display:flex;flex-direction:column;align-items:center;line-height:1}
.laurel .lc b{font-family:var(--display);font-size:1.15rem;color:var(--accent-2)}
.laurel .lc i{font-family:var(--sans);font-style:normal;font-size:.52rem;color:var(--text-faint)}
.fcard .gtag{font-family:var(--sans);font-size:.7rem;color:var(--text-faint)}

/* ====================== MODAL (film / book detail) ====================== */
.modal{position:fixed;inset:0;z-index:210;display:flex;align-items:center;justify-content:center;padding:clamp(12px,4vw,44px);background:rgba(10,8,6,.62);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity .3s}
.modal.show{opacity:1;visibility:visible}
.modal-box{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:14px;max-width:780px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:0 30px 90px rgba(0,0,0,.45);transform:translateY(14px) scale(.985);transition:.3s cubic-bezier(.16,1,.3,1)}
.modal.show .modal-box{transform:none}
.modal-x{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:1.2rem;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center}
.modal-x:hover{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.mb-grid{display:grid;grid-template-columns:230px 1fr;gap:clamp(18px,3vw,32px);padding:clamp(20px,3vw,32px)}
@media(max-width:620px){.mb-grid{grid-template-columns:1fr}}
.mb-cover img{width:100%;border-radius:9px;border:1px solid var(--line)}
.mb-cover.placeholder{aspect-ratio:3/4;border-radius:9px;background:linear-gradient(150deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;font-family:var(--display);color:var(--on-accent);font-size:1.4rem}
.mb-gen{font-family:var(--sans);font-size:.74rem;font-weight:600;color:var(--accent)}
.mb-title{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.3rem);line-height:1.1;margin:6px 0}
.mb-meta{font-family:var(--sans);font-size:.82rem;color:var(--text-faint);margin-bottom:14px}
.mb-body{font-size:clamp(1.02rem,1.4vw,1.14rem);line-height:1.7;color:var(--text)}
.mb-body p{margin-bottom:.8em}
.mb-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.mb-fests{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.mb-fest{font-family:var(--sans);font-size:.74rem;color:var(--text-soft);border:1px solid var(--line);border-radius:100px;padding:5px 12px}
.mb-certs{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.mb-certs .gi{width:120px;height:160px;border:1px solid var(--line);border-radius:8px;overflow:hidden;cursor:zoom-in;background:var(--bg-2)}
.mb-certs .gi img{width:100%;height:100%;object-fit:cover}
.mb-laurelrow{margin:4px 0 12px}

/* ====================== FEATURED-IN STRIP ====================== */
.featured{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.featured .flab{font-family:var(--sans);font-size:.72rem;font-weight:600;color:var(--text-faint);text-align:center;padding:16px 0 0}
.featured .ftrack{display:flex;gap:clamp(28px,5vw,64px);width:max-content;align-items:center;animation:scrollx 38s linear infinite;padding:14px 0 18px}
.featured:hover .ftrack{animation-play-state:paused}
.featured .fitem{font-family:var(--display);font-size:clamp(1.1rem,1.8vw,1.5rem);color:var(--text-soft);white-space:nowrap}

/* ====================== UTIL ====================== */
.sprog{position:fixed;top:0;left:0;right:0;height:2px;z-index:60;background:var(--accent);transform:scaleX(0);transform-origin:left;pointer-events:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
  .masthead .l,.standfirst,.lead,.cta,.reveal{opacity:1!important;transform:none!important}
}

/* ===== extended biography (About) ===== */
.bio-toggle{margin-top:18px;background:none;border:0;padding:0;font-family:var(--sans);font-weight:700;font-size:.92rem;color:var(--accent);cursor:pointer;letter-spacing:.01em}
.bio-toggle:hover{text-decoration:underline;text-underline-offset:4px}
.bio-extended{margin-top:22px;border-top:1px solid var(--line-soft);padding-top:8px;animation:bioIn .35s ease}
@keyframes bioIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.bio-extended h3{font-family:var(--sans);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:22px 0 8px}
.bio-extended h3:first-child{margin-top:6px}
.bio-extended p{font-family:var(--serif);font-size:1.02rem;line-height:1.85;color:var(--text-soft);margin:0 0 4px}

/* ===== Facebook connect card (contact) ===== */
.fbcard{display:flex;align-items:center;gap:14px;padding:18px;border:1px solid var(--line);border-radius:14px;background:var(--surface);text-decoration:none;color:var(--text);transition:border-color .2s,transform .2s,box-shadow .2s}
.fbcard:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.fbcard-ic{flex:none;width:44px;height:44px;border-radius:11px;display:grid;place-items:center;background:var(--accent);color:var(--on-accent)}
.fbcard-ic svg{width:24px;height:24px}
.fbcard-tx{flex:1;display:flex;flex-direction:column;gap:3px}
.fbcard-tx b{font-family:var(--sans);font-weight:700;font-size:.98rem}
.fbcard-tx span{font-family:var(--sans);font-size:.84rem;color:var(--text-faint);line-height:1.4}
.fbcard-go{flex:none;color:var(--accent);font-size:1.3rem;font-weight:700}
