/* ============================================================
   DULVANI TALENT — Cinematic after-dark design system
   Shared across: index.html · stories.html · apply.html
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=Inter:wght@400;500;600&display=swap');

:root{
  /* palette — after dark */
  --bg:#0E0B0A;
  --bg2:#15110D;
  --bg3:#1D1812;
  --cream:#F1E6D4;
  --cream2:#A99C86;
  --cream3:#766B5A;
  --amber:#E0A85C;
  --amber-bright:#F6DCA8;
  --amber-deep:#B97D32;
  --line:rgba(241,230,212,.12);
  --line2:rgba(241,230,212,.22);
  --glass:rgba(20,16,12,.55);

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --gut:clamp(20px,5vw,80px);
  --maxw:1320px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--cream);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--amber);color:#241702}

/* atmospheric amber glow — fixed, drifting */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 82% -8%, rgba(224,168,92,.20), transparent 60%),
    radial-gradient(48vw 48vw at -10% 108%, rgba(185,125,50,.14), transparent 62%);
  animation:glowDrift 22s ease-in-out infinite;
}
@keyframes glowDrift{50%{transform:translate3d(2%,2.5%,0) scale(1.06)}}

/* film grain */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* keep real content above the glow */
.announce,.nav,.drawer,main,section,footer,.strip{position:relative;z-index:1}

/* ── layout ────────────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.rule{height:1px;background:var(--line);width:100%}

.kicker{
  font-family:var(--sans);font-size:11px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--amber);
  display:inline-flex;align-items:center;gap:10px;
}
.kicker::before{content:"";width:24px;height:1px;background:var(--amber-deep);display:inline-block}
.kicker.center::after{content:"";width:24px;height:1px;background:var(--amber-deep);display:inline-block}

.eyebrow-num{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--cream3)}

h1,h2,h3{font-family:var(--serif);font-weight:330;line-height:1.02;letter-spacing:-.012em}
h1 em,h2 em,h3 em,.italic{font-style:italic;font-weight:330}
.serif{font-family:var(--serif)}

/* gold-foil gradient on the big display italics */
.hero h1 em,.cta-h em,.stmt-q em,.htitle em{
  font-style:italic;
  background:linear-gradient(172deg,var(--amber-bright) 0%,var(--amber) 45%,var(--amber-deep) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* ── buttons ───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.03em;
  padding:16px 30px;border-radius:100px;transition:.45s var(--ease);
  position:relative;overflow:hidden;
}
.btn .arr{width:16px;height:10px;position:relative;transition:.4s var(--ease)}
.btn .arr::after{content:"→";position:absolute;right:0;top:50%;transform:translateY(-50%)}
.btn:hover .arr{transform:translateX(5px)}
/* primary = gold foil */
.btn-dark{background:linear-gradient(180deg,#EAC279,#C0883A);color:#241702;
  box-shadow:0 12px 34px rgba(192,136,58,.30)}
.btn-dark:hover{box-shadow:0 16px 44px rgba(224,168,92,.45);transform:translateY(-2px)}
/* ghost */
.btn-ghost{background:transparent;color:var(--cream);box-shadow:inset 0 0 0 1px var(--line2)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1px var(--cream);background:rgba(241,230,212,.06)}

/* ── announce bar ──────────────────────────────────────────── */
.announce{background:var(--bg2);color:var(--cream2);overflow:hidden;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;font-weight:500;border-bottom:1px solid var(--line)}
.announce-track{display:flex;gap:0;white-space:nowrap;width:max-content;
  animation:ticker 38s linear infinite}
.announce-item{padding:9px 0;display:inline-flex;align-items:center}
.announce-item::after{content:"";width:4px;height:4px;border-radius:50%;
  background:var(--amber);margin:0 28px}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ── nav ───────────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:200;background:rgba(14,11,10,.55);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:.4s var(--ease)}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(14,11,10,.86)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:18px var(--gut);
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{font-family:var(--serif);font-size:23px;letter-spacing:.01em;line-height:1;
  display:flex;align-items:baseline;gap:7px;color:var(--cream)}
.logo b{font-weight:400}
.logo .dot{color:var(--amber)}
.logo .sub{font-family:var(--sans);font-size:8.5px;font-weight:600;letter-spacing:.28em;
  text-transform:uppercase;color:var(--cream3);align-self:center}

.nav-mid{display:flex;align-items:center;gap:38px}
.nav-link{font-size:13px;font-weight:500;letter-spacing:.02em;position:relative;padding:4px 0;
  color:var(--cream2);transition:color .3s}
.nav-link::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--amber);transition:width .35s var(--ease)}
.nav-link:hover,.nav-link.active{color:var(--cream)}
.nav-link:hover::after,.nav-link.active::after{width:100%}

.nav-right{display:flex;align-items:center;gap:18px}

.lang{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;
  letter-spacing:.1em;padding:7px 12px;border-radius:100px;color:var(--cream);
  box-shadow:inset 0 0 0 1px var(--line2);transition:.3s}
.lang:hover{box-shadow:inset 0 0 0 1px var(--amber)}
.lang .flag{font-size:13px;line-height:1}
.lang .code{color:var(--cream2)}

.nav-cta{font-size:13px;font-weight:600;letter-spacing:.03em;padding:11px 22px;
  border-radius:100px;background:linear-gradient(180deg,#EAC279,#C0883A);color:#241702;transition:.4s var(--ease)}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(224,168,92,.4)}

.burger{display:none;width:30px;height:18px;position:relative}
.burger span{position:absolute;left:0;width:100%;height:1.5px;background:var(--cream);
  transition:.35s var(--ease)}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:50%;transform:translateY(-50%)}
.burger span:nth-child(3){bottom:0}
body.menu-open .burger span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

.drawer{position:fixed;inset:0;z-index:190;background:var(--bg);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:var(--gut);
  transform:translateY(-100%);transition:transform .6s var(--ease);visibility:hidden}
body.menu-open .drawer{transform:translateY(0);visibility:visible}
.drawer a{font-family:var(--serif);font-size:clamp(36px,11vw,64px);font-weight:330;
  padding:8px 0;display:flex;align-items:baseline;gap:14px;color:var(--cream)}
.drawer a .n{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--amber);
  letter-spacing:.1em}

/* ── hero ──────────────────────────────────────────────────── */
.hero{padding:clamp(54px,9vw,124px) 0 clamp(48px,8vw,88px);position:relative;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(50vw 46vw at 50% 38%,rgba(224,168,92,.18),transparent 62%)}
.hero > .wrap > .kicker{display:inline-flex;margin-bottom:clamp(26px,4.5vw,46px)}
.hero-tag-row{display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:14px;margin-bottom:clamp(26px,5vw,52px)}
.hero h1{font-size:clamp(50px,10vw,158px);font-weight:300;letter-spacing:-.03em}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln > span{display:block;transform:translateY(110%);
  animation:rise 1.05s var(--ease) forwards}
.hero h1 .ln:nth-child(2) > span{animation-delay:.12s}
.hero h1 .ln:nth-child(3) > span{animation-delay:.24s}
@keyframes rise{to{transform:translateY(0)}}

/* signature: spotlit-portrait stage */
.hero-stage{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(30px,5vw,64px);align-items:center}
.hero-copy{min-width:0}
.hero-sub{font-size:clamp(16px,2vw,19px);max-width:52ch;color:var(--cream2);line-height:1.55;margin:clamp(26px,4vw,36px) auto 0}
.hero-sub strong{color:var(--cream);font-weight:500}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:clamp(28px,4vw,40px)}
.hero-proof{display:inline-flex;align-items:center;gap:18px;margin-top:clamp(36px,5vw,56px);
  padding:12px 30px 12px 12px;border-radius:16px;background:var(--glass);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 0 0 1px var(--line2)}
.hero-proof img{width:76px;height:94px;object-fit:cover;border-radius:11px;filter:saturate(.92) contrast(1.04)}
.hero-proof .hp-txt{text-align:left}
.hero-proof .hp-txt b{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--cream);display:block;line-height:1.2}
.hero-proof .hp-txt span{font-size:12.5px;color:var(--cream2);display:block;margin-top:3px}

.portrait-frame{position:relative;aspect-ratio:3/4.05;border-radius:14px;overflow:hidden;
  box-shadow:0 44px 100px rgba(0,0,0,.6), inset 0 0 0 1px var(--line2);
  opacity:0;transform:translateY(34px);animation:up 1.1s .4s forwards}
.portrait-frame img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.05)}
.portrait-frame::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 38%,rgba(14,11,10,.86))}
.glass-quote{position:absolute;left:14px;right:14px;bottom:14px;z-index:2;padding:16px 18px;border-radius:12px;
  background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:inset 0 0 0 1px rgba(241,230,212,.18)}
.glass-quote .gq{font-family:var(--serif);font-style:italic;font-size:21px;color:var(--cream)}
.glass-quote .gn{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-top:6px}

@keyframes up{to{opacity:1;transform:none}}

/* ── marquee strip ─────────────────────────────────────────── */
.strip{border-block:1px solid var(--line);overflow:hidden;background:var(--bg2)}
.strip-track{display:flex;width:max-content;animation:ticker 44s linear infinite}
.strip-item{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3.4vw,40px);
  font-weight:330;color:var(--cream);padding:18px 0;display:inline-flex;align-items:center}
.strip-item::after{content:"✦";font-style:normal;color:var(--amber);font-size:14px;margin:0 38px}

/* ── section scaffold ──────────────────────────────────────── */
.sec{padding:clamp(64px,10vw,140px) 0}
.sec-head{display:grid;grid-template-columns:1fr;gap:22px;margin-bottom:clamp(40px,6vw,72px)}
.sec-head .h{font-size:clamp(32px,5.2vw,68px);font-weight:300;max-width:16ch}
.sec-head .lead{font-size:clamp(16px,1.8vw,19px);color:var(--cream2);max-width:52ch}
.two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:start}
@media(min-width:900px){.sec-head.split{grid-template-columns:.9fr 1.1fr;align-items:end}}

/* ── services ──────────────────────────────────────────────── */
.svc{border-top:1px solid var(--line)}
.svc-item{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,60px);
  padding:clamp(28px,4vw,46px) 0;border-bottom:1px solid var(--line);
  transition:padding-left .5s var(--ease),background .5s var(--ease)}
.svc-item:hover{padding-left:18px;background:linear-gradient(90deg,rgba(224,168,92,.06),transparent)}
.svc-n{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,30px);
  color:var(--amber);line-height:1}
.svc-body{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:760px){.svc-body{grid-template-columns:.85fr 1.15fr;gap:clamp(24px,4vw,60px)}}
.svc-t{font-family:var(--serif);font-size:clamp(24px,3vw,38px);font-weight:330;letter-spacing:-.01em;color:var(--cream)}
.svc-d{font-size:15.5px;color:var(--cream2);line-height:1.6;max-width:46ch}

/* ── statement ─────────────────────────────────────────────── */
.stmt{padding:clamp(90px,13vw,180px) 0;text-align:center;position:relative;overflow:hidden}
.stmt::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(50vw 50vw at 50% 50%,rgba(224,168,92,.14),transparent 60%)}
.stmt-q{font-family:var(--serif);font-weight:300;font-size:clamp(30px,5.6vw,78px);
  line-height:1.08;letter-spacing:-.02em;max-width:18ch;margin:34px auto 0;color:var(--cream)}

/* ── numbers ───────────────────────────────────────────────── */
.nums{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line)}
@media(min-width:760px){.nums{grid-template-columns:repeat(4,1fr)}}
.num{background:var(--bg2);padding:clamp(30px,4vw,52px) clamp(22px,3vw,34px);transition:background .4s}
.num:hover{background:var(--bg3)}
.num-v{font-family:var(--serif);font-size:clamp(40px,5.5vw,72px);font-weight:300;
  line-height:1;letter-spacing:-.02em;color:var(--cream)}
.num-v em{font-style:italic;color:var(--amber)}
.num-l{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream2);
  margin-top:16px;font-weight:500}

/* ── trust / safety ────────────────────────────────────────── */
.trust{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:760px){.trust{grid-template-columns:repeat(3,1fr)}}
.trust-c{background:var(--bg2);padding:clamp(28px,3.5vw,42px);transition:background .4s}
.trust-c:hover{background:var(--bg3)}
.trust-c .ti{font-family:var(--serif);font-size:22px;font-style:italic;margin-bottom:12px;color:var(--amber)}
.trust-c .td{font-size:14.5px;color:var(--cream2);line-height:1.6}

/* ── portrait plate (placeholder-friendly) ─────────────────── */
.plate{position:relative;background:var(--bg3);overflow:hidden;border:1px solid var(--line)}
.plate.tall{aspect-ratio:3/4}
.plate.wide{aspect-ratio:4/3}
.plate img{width:100%;height:100%;object-fit:cover}
.plate-cap{position:absolute;left:16px;bottom:14px;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--cream);font-weight:500;z-index:2}
.plate-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:8px;color:var(--cream3);
  background:radial-gradient(40vw 40vw at 60% 30%,rgba(224,168,92,.08),transparent 60%)}
.plate-ph .pm{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--amber)}
.plate-ph .ps{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase}

/* ── testimonial / video ───────────────────────────────────── */
.video-outer{position:relative;border:1px solid var(--line2);overflow:hidden;background:#000;
  box-shadow:0 44px 100px rgba(0,0,0,.55)}
.video-inner{position:relative;width:100%;aspect-ratio:9/13;max-height:78vh;margin:0 auto}
.video-iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-poster{position:absolute;inset:0;cursor:pointer}
.video-poster img{width:100%;height:100%;object-fit:cover}
.video-poster::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.4))}
.play-btn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:74px;height:74px;border-radius:50%;background:rgba(224,168,92,.18);
  backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;
  z-index:2;transition:.4s var(--ease)}
.play-btn svg{width:30px;height:30px;margin-left:3px}
.video-poster:hover .play-btn{background:rgba(224,168,92,.32);transform:translate(-50%,-50%) scale(1.06)}
.poster-badge{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream);font-weight:600}

/* quotes */
.quotes{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:820px){.quotes{grid-template-columns:repeat(2,1fr)}}
.quote{background:var(--bg2);padding:clamp(30px,4vw,48px);display:flex;flex-direction:column;gap:20px;transition:background .4s}
.quote:hover{background:var(--bg3)}
.quote-mk{font-family:var(--serif);font-style:italic;font-size:48px;color:var(--amber);line-height:.5}
.quote-t{font-family:var(--serif);font-size:clamp(20px,2.4vw,27px);font-weight:330;line-height:1.32;color:var(--cream)}
.quote-t em{font-style:italic;color:var(--amber)}
.quote-by{margin-top:auto;display:flex;align-items:center;gap:12px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--cream2)}
.quote-by b{font-weight:600;color:var(--cream)}
.quote-by .av{width:34px;height:34px;border-radius:50%;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);
  font-style:italic;color:var(--amber);font-size:15px;box-shadow:inset 0 0 0 1px var(--line2)}

/* ── CTA band ──────────────────────────────────────────────── */
.cta{padding:clamp(80px,11vw,160px) 0;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(46vw 46vw at 50% 40%,rgba(224,168,92,.16),transparent 62%)}
.cta-h{font-family:var(--serif);font-weight:300;font-size:clamp(36px,6.5vw,92px);
  line-height:1.02;letter-spacing:-.02em;color:var(--cream)}
.cta-p{font-size:clamp(16px,1.8vw,19px);color:var(--cream2);max-width:50ch;margin:26px auto 38px}

/* ── apply page ────────────────────────────────────────────── */
.apply-wrap{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px);
  padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(64px,9vw,120px)}
@media(min-width:980px){.apply-wrap{grid-template-columns:.82fr 1.18fr;align-items:start}}
.apply-aside{position:sticky;top:110px}
.apply-h{font-size:clamp(38px,6vw,76px);font-weight:300;letter-spacing:-.02em;line-height:1.02;color:var(--cream)}
.apply-h em{font-style:italic;color:var(--amber)}
.apply-lead{font-size:17px;color:var(--cream2);max-width:42ch;margin-top:24px;line-height:1.6}
.apply-assur{margin-top:36px;display:flex;flex-direction:column;gap:14px}
.apply-assur li{display:flex;gap:13px;font-size:14.5px;color:var(--cream2);list-style:none;line-height:1.5}
.apply-assur .ck{color:var(--amber);flex:none;font-weight:600}

/* form */
.form{display:flex;flex-direction:column;gap:26px}
.field{display:flex;flex-direction:column;gap:9px}
.field-row{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:560px){.field-row{grid-template-columns:1fr 1fr}}
.field label,.q-label{font-family:var(--serif);font-size:18px;font-weight:400;letter-spacing:-.01em;line-height:1.3;color:var(--cream)}
.field .hint{font-size:12.5px;color:var(--cream3);margin-top:-2px}
input[type=text],input[type=tel],input[type=date],select{
  width:100%;font-family:var(--sans);font-size:15px;color:var(--cream);
  background:var(--bg2);border:1px solid var(--line2);border-radius:8px;
  padding:14px 16px;transition:.25s}
input::placeholder{color:var(--cream3)}
input:focus,select:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(224,168,92,.16);background:var(--bg3)}
input[type=date]{color-scheme:dark}
select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A99C86' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
select option{background:var(--bg2);color:var(--cream)}

.file-drop{border:1px dashed var(--line2);border-radius:10px;padding:30px 20px;
  text-align:center;background:var(--bg2);transition:.3s;cursor:pointer}
.file-drop:hover{border-color:var(--amber);background:var(--bg3)}
.file-inner{display:flex;flex-direction:column;align-items:center;gap:8px}
.file-icon{width:42px;height:42px;border-radius:50%;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--amber)}
.file-label{font-size:14.5px;font-weight:500;color:var(--cream)}
.file-hint{font-size:12px;color:var(--cream3)}

.opt-group{display:flex;flex-direction:column;gap:10px}
@media(min-width:560px){.opt-group.grid2{display:grid;grid-template-columns:1fr 1fr}}
.opt{display:flex;align-items:center;gap:12px;padding:13px 16px;border:1px solid var(--line2);
  border-radius:8px;background:var(--bg2);cursor:pointer;transition:.2s;font-size:14.5px;color:var(--cream)}
.opt:hover{border-color:var(--cream3)}
.opt input{appearance:none;width:18px;height:18px;border:1.5px solid var(--line2);
  flex:none;transition:.2s;position:relative;background:transparent}
.opt input[type=radio]{border-radius:50%}
.opt input[type=checkbox]{border-radius:4px}
.opt input:checked{border-color:var(--amber);background:var(--amber)}
.opt input:checked::after{content:"";position:absolute;inset:0;display:flex}
.opt input[type=radio]:checked::after{inset:4px;border-radius:50%;background:#241702}
.opt input[type=checkbox]:checked::after{left:5px;top:1px;width:5px;height:10px;
  border:solid #241702;border-width:0 2px 2px 0;transform:rotate(45deg)}
.opt:has(input:checked){border-color:var(--amber);background:rgba(224,168,92,.08)}

.submit{margin-top:8px;width:100%;justify-content:center;font-size:14px;padding:18px 30px}
.form-note{font-size:12.5px;color:var(--cream3);text-align:center;line-height:1.5}

/* ── footer ────────────────────────────────────────────────── */
.footer{background:#0A0807;color:var(--cream);padding:clamp(56px,8vw,100px) 0 40px;border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1fr;gap:40px;align-items:start}
@media(min-width:760px){.footer-top{grid-template-columns:1.4fr 1fr 1fr}}
.footer .logo{color:var(--cream);font-size:30px}
.footer .logo .sub{color:var(--cream3)}
.footer-tag{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--amber);
  max-width:24ch;margin-top:20px;line-height:1.4}
.foot-col h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream3);
  font-weight:600;margin-bottom:18px}
.foot-col a{display:block;font-size:15px;color:var(--cream);opacity:.82;padding:6px 0;transition:.25s}
.foot-col a:hover{opacity:1;color:var(--amber);padding-left:5px}
.footer-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  margin-top:clamp(48px,7vw,80px);padding-top:28px;border-top:1px solid var(--line);
  font-size:12px;letter-spacing:.04em;color:var(--cream3)}
.footer-bot a{color:var(--cream3);transition:.25s}
.footer-bot a:hover{color:var(--amber)}

/* ── reveal animation ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}
.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}

/* ── responsive ────────────────────────────────────────────── */
@media(max-width:880px){
  .nav-mid{display:none}
  .nav-cta{display:none}
  .burger{display:block}
  .hero-stage{grid-template-columns:1fr}
  .portrait-frame{max-width:380px;margin-top:8px}
  .two{grid-template-columns:1fr}
  .apply-aside{position:static}
}
@media(max-width:560px){
  .lang .code{display:none}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .hero h1 .ln > span{transform:none}
  .portrait-frame{opacity:1;transform:none}
  .reveal{opacity:1;transform:none}
  body::before{animation:none}
}
