/* =========================================================================
   NEWay Productions / America's Sweetheart is a Secret MONSTER
   Cinematic single-page site
   ========================================================================= */

/* ----- Design tokens ----- */
:root{
  --bg:        #0a0708;
  --bg-2:      #100b0d;
  --bg-3:      #16101300;
  --panel:     rgba(24,17,20,.66);
  --panel-2:   rgba(31,22,26,.92);
  --ink:       #f6efe7;
  --muted:     #b7a89b;
  --muted-2:   #8b7d72;
  --gold:      #c9a35c;
  --gold-2:    #ecd08a;
  --gold-deep: #8a6d34;
  --blood:     #c01f2d;
  --blood-2:   #e8392b;
  --line:      rgba(201,163,92,.16);
  --line-2:    rgba(246,239,231,.08);

  --font-display:'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-impact: 'Anton', 'Arial Narrow', Impact, sans-serif;
  --font-sans:   'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

  --maxw: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--gold-2);outline-offset:3px;border-radius:2px}

/* Film grain + vignette overlays (whole page) */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(192,31,45,.10), transparent 55%),
    radial-gradient(140% 120% at 50% 120%, rgba(0,0,0,.66), transparent 60%);
  mix-blend-mode:normal;
}
body::after{
  content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ----- Layout helpers ----- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px);position:relative;z-index:2}
section{position:relative;z-index:2}
.eyebrow{
  font-family:var(--font-sans);
  font-size:.72rem;font-weight:600;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:.8em;
}
.eyebrow::before{content:"";width:30px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,60px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .eyebrow::after{content:"";width:30px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
h2.title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2rem,5.2vw,3.6rem);line-height:1.04;letter-spacing:-.01em;
  margin:.35em 0 .3em;
}
h2.title em{font-style:italic;color:var(--gold-2)}
.lede{color:var(--muted);font-size:clamp(1rem,1.5vw,1.18rem);max-width:62ch}
.pad{padding-block:clamp(72px,10vw,140px)}
.hair{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);border:0}

/* ============================ NAV ============================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,48px);
  transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,7,8,.82);backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  padding-block:12px;border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:baseline;gap:.55rem;font-family:var(--font-display);font-weight:800;font-size:1.32rem;letter-spacing:.02em}
.brand .ne{color:var(--ink)}
.brand .way{color:var(--gold);font-style:italic}
.brand .sub{font-family:var(--font-sans);font-size:.56rem;font-weight:600;letter-spacing:.34em;color:var(--muted-2);text-transform:uppercase;transform:translateY(-2px)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.82rem;font-weight:500;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;transition:color .25s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease)}
.nav-links a:hover::after{width:100%}
/* Keep nav CTA buttons legible: beat the .nav-links a text-color rules */
.nav-links a.btn::after{display:none}
.nav-links a.btn-gold,.nav-links a.btn-gold:hover{color:#1a1208}
.nav-links a.btn-blood,.nav-links a.btn-blood:hover{color:#fff}
.nav-links a.btn-ghost,.nav-links a.btn-ghost:hover{color:var(--ink)}
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:.85em 1.6em;border-radius:2px;transition:all .3s var(--ease);white-space:nowrap;
}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#1a1208;box-shadow:0 6px 22px -8px rgba(201,163,92,.7)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(236,208,138,.8);filter:brightness(1.06)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(201,163,92,.07)}
.btn-blood{background:linear-gradient(180deg,var(--blood-2),var(--blood));color:#fff;box-shadow:0 6px 24px -8px rgba(192,31,45,.75)}
.btn-blood:hover{transform:translateY(-2px);filter:brightness(1.08)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:51}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s var(--ease)}

/* ============================ HERO ============================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  padding-top:96px;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg::before{content:"";position:absolute;inset:0;background:url(../img/hero-bg.jpg) center 30%/cover;opacity:.32;filter:saturate(.9)}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg, var(--bg) 8%, rgba(10,7,8,.55) 50%, rgba(10,7,8,.85) 100%),
    linear-gradient(180deg, rgba(10,7,8,.7), transparent 30%, var(--bg) 96%);
}
.hero-inner{
  position:relative;z-index:3;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(20px,5vw,48px);
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,5vw,72px);align-items:center;
}
.hero-copy{max-width:660px}
.hero-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.6rem}
.tag{
  font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--line);border-radius:100px;padding:.45em 1em;background:rgba(201,163,92,.05)
}
.hero h1{font-family:var(--font-display);font-weight:400;line-height:.98;margin-bottom:.4rem}
.hero h1 .pre{
  display:block;font-size:clamp(1.5rem,4vw,2.7rem);font-weight:500;
  letter-spacing:.04em;color:var(--ink);text-transform:uppercase;
}
.hero h1 .pre em{font-style:italic;color:var(--gold-2);font-weight:600}
.hero h1 .monster{
  display:block;font-family:var(--font-impact);
  font-size:clamp(4.4rem,16vw,11rem);line-height:.84;letter-spacing:.01em;
  color:var(--blood-2);text-transform:uppercase;margin-top:.04em;
  text-shadow:0 0 40px rgba(192,31,45,.45),0 6px 30px rgba(0,0,0,.6);
  background:linear-gradient(180deg,#f0463a,#a3121e);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-logline{
  font-family:var(--font-display);font-style:italic;font-size:clamp(1.05rem,1.9vw,1.4rem);
  color:var(--ink);margin:1.5rem 0 1rem;max-width:48ch;line-height:1.5
}
.hero-sub{color:var(--muted);max-width:52ch;margin-bottom:2rem;font-size:1.02rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-meta{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:1.8rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.hero-meta .m{display:flex;flex-direction:column}
.hero-meta .m b{font-family:var(--font-impact);font-size:1.7rem;color:var(--gold-2);line-height:1;letter-spacing:.02em}
.hero-meta .m span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-top:.4em}

/* Poster */
.hero-poster{position:relative;justify-self:center;perspective:1200px}
.hero-poster .frame{
  position:relative;width:min(360px,80vw);border-radius:6px;overflow:hidden;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.9),0 0 0 1px rgba(201,163,92,.25),0 0 60px -20px rgba(192,31,45,.4);
  transform:rotateY(-7deg) rotateX(2deg);transition:transform .6s var(--ease);
}
.hero-poster .frame:hover{transform:rotateY(0) rotateX(0) scale(1.02)}
.hero-poster .frame img{width:100%}
.hero-poster .badge{
  position:absolute;top:14px;left:-8px;z-index:4;
  background:linear-gradient(180deg,var(--blood-2),var(--blood));color:#fff;
  font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  padding:.5em 1em;box-shadow:0 8px 20px -6px rgba(192,31,45,.7)
}
.hero-poster .badge::before{content:"";position:absolute;left:0;bottom:-6px;border:4px solid transparent;border-top-color:var(--gold-deep);border-right-color:var(--gold-deep)}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:.6em;color:var(--muted-2);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase}
.scroll-cue .line{width:1px;height:38px;background:linear-gradient(180deg,var(--gold),transparent);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ============================ MARQUEE ============================ */
.marquee{
  border-block:1px solid var(--line);background:linear-gradient(90deg,rgba(192,31,45,.06),rgba(201,163,92,.05));
  overflow:hidden;padding:18px 0;position:relative;z-index:2
}
.marquee-track{display:flex;gap:0;width:max-content;animation:scroll 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{
  font-family:var(--font-display);font-style:italic;font-size:1.15rem;color:var(--ink);
  padding:0 2rem;display:inline-flex;align-items:center;gap:2rem;white-space:nowrap;opacity:.92
}
.marquee-track span::after{content:"✦";color:var(--gold);font-style:normal;font-size:.8rem}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================ STORY ============================ */
.story{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.story-copy p{color:var(--muted);margin-bottom:1.2rem;font-size:1.06rem}
.story-copy p strong{color:var(--ink);font-weight:600}
.story-copy .drop::first-letter{
  font-family:var(--font-display);float:left;font-size:3.6rem;line-height:.8;
  padding:.08em .12em 0 0;color:var(--gold-2);font-weight:800
}
.story-figs{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.story-figs figure{position:relative;border-radius:5px;overflow:hidden;border:1px solid var(--line-2)}
.story-figs figure img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);filter:saturate(.95) contrast(1.03)}
.story-figs figure:hover img{transform:scale(1.06)}
.story-figs .tall{grid-row:span 2}
.story-figs figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:18px 14px 12px;
  font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);
  background:linear-gradient(transparent,rgba(0,0,0,.78))
}

/* ============================ PILLARS ============================ */
.pillars-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.pillar{
  background:var(--bg);padding:clamp(26px,3vw,38px);position:relative;
  transition:background .4s var(--ease);overflow:hidden
}
.pillar:hover{background:var(--bg-2)}
.pillar .num{font-family:var(--font-impact);font-size:2.2rem;color:transparent;-webkit-text-stroke:1px var(--gold-deep);line-height:1;margin-bottom:.6rem;transition:.4s}
.pillar:hover .num{color:var(--gold);-webkit-text-stroke:1px var(--gold)}
.pillar h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:.5rem}
.pillar p{color:var(--muted);font-size:.95rem}
.pillar::after{content:"";position:absolute;left:0;top:0;width:2px;height:0;background:linear-gradient(var(--gold),var(--blood));transition:height .5s var(--ease)}
.pillar:hover::after{height:100%}

/* ============================ ACTS / arc ============================ */
.arc{background:var(--bg-2);position:relative}
.arc::before{content:"";position:absolute;inset:0;background:url('../img/section-bg.jpg') center/cover;opacity:.10;z-index:0}
.acts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:act}
.act{
  position:relative;border:1px solid var(--line);border-radius:6px;padding:clamp(24px,2.6vw,34px);
  background:linear-gradient(180deg,var(--panel),rgba(16,11,13,.9));backdrop-filter:blur(6px);
  transition:transform .4s var(--ease),border-color .4s
}
.act:hover{transform:translateY(-6px);border-color:rgba(201,163,92,.4)}
.act .roman{font-family:var(--font-display);font-size:.8rem;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem;display:block}
.act h3{font-family:var(--font-display);font-size:1.5rem;font-weight:700;line-height:1.15;margin-bottom:.8rem}
.act p{color:var(--muted);font-size:.95rem}
.act .dot{position:absolute;top:34px;right:28px;width:8px;height:8px;border-radius:50%;background:var(--blood-2);box-shadow:0 0 14px var(--blood-2)}
.hook-line{
  margin-top:28px;text-align:center;font-family:var(--font-display);font-style:italic;
  font-size:clamp(1.1rem,2vw,1.5rem);color:var(--ink)
}
.hook-line b{color:var(--gold-2);font-style:normal;font-weight:700}

/* ============================ CAST ============================ */
.cast{background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.cast-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cast-card{
  position:relative;border-radius:7px;overflow:hidden;border:1px solid var(--line);
  background:var(--bg-2);transition:transform .45s var(--ease),box-shadow .45s,border-color .45s
}
.cast-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -30px rgba(0,0,0,.9);border-color:rgba(201,163,92,.45)}
.cast-photo{position:relative;aspect-ratio:4/4.6;overflow:hidden}
.cast-photo img{width:100%;height:100%;object-fit:cover;object-position:center 28%;filter:grayscale(.25) contrast(1.04);transition:.6s var(--ease)}
.cast-card:hover .cast-photo img{filter:grayscale(0) contrast(1.06);transform:scale(1.05)}
.cast-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,7,8,.9))}
.cast-role{position:absolute;left:18px;bottom:16px;z-index:2}
.cast-role .char{font-family:var(--font-display);font-size:1.5rem;font-weight:700;line-height:1}
.cast-role .tagline{font-size:.78rem;color:var(--gold-2);margin-top:.3rem;font-style:italic;font-family:var(--font-display)}
.cast-body{padding:18px 20px 22px}
.cast-body .actor{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:.9rem}
.cast-body .actor .name{font-weight:600;font-size:1.02rem}
.cast-body .actor .handle{font-size:.74rem;color:var(--gold);letter-spacing:.04em}
.cast-stat{display:flex;gap:.6em;font-size:.86rem;color:var(--muted);padding:.5em 0;border-top:1px solid var(--line-2)}
.cast-stat:first-of-type{border-top:none}
.cast-stat b{color:var(--ink);font-weight:600;white-space:nowrap}
.cast-stat .k{color:var(--gold);flex-shrink:0;width:1.4em}

.support{margin-top:48px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.support .sc{border:1px solid var(--line);border-radius:6px;padding:22px 24px;background:var(--panel);transition:.4s}
.support .sc:hover{border-color:rgba(201,163,92,.4);background:var(--panel-2)}
.support .sc h4{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:.3rem}
.support .sc .ko{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.support .sc p{color:var(--muted);font-size:.9rem}

/* ============================ DEMAND / stats ============================ */
.demand{background:var(--bg);position:relative;overflow:hidden}
.demand-head{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,64px);align-items:end;margin-bottom:48px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.stat{background:var(--bg-2);padding:30px 24px;text-align:center;transition:background .4s}
.stat:hover{background:var(--bg)}
.stat .big{font-family:var(--font-impact);font-size:clamp(2.2rem,4vw,3.1rem);line-height:1;letter-spacing:.01em;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .lab{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.7rem}
.demand-note{display:flex;align-items:center;gap:1rem;margin-top:30px;padding:20px 26px;border:1px solid var(--line);border-radius:6px;background:linear-gradient(90deg,rgba(192,31,45,.08),transparent)}
.demand-note .spark{font-family:var(--font-impact);font-size:2.4rem;color:var(--blood-2);line-height:1}
.demand-note p{color:var(--muted);font-size:.98rem}
.demand-note p b{color:var(--ink)}

/* ============================ GALLERY ============================ */
.gallery{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.gal-grid{column-count:3;column-gap:12px}
.gal-item{position:relative;display:block;break-inside:avoid;margin:0 0 12px;overflow:hidden;border-radius:5px;cursor:pointer;border:1px solid var(--line-2);background:var(--bg-2)}
.gal-item img{width:100%;height:auto;display:block;transition:transform .7s var(--ease),filter .5s;filter:brightness(1.08) saturate(1.04)}
.gal-item:hover img{transform:scale(1.08);filter:brightness(1.14) saturate(1.1)}
.gal-item::after{content:"⌕";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:var(--ink);background:rgba(10,7,8,.3);opacity:0;transition:.4s}
.gal-item:hover::after{opacity:1}
.gal-cap{position:absolute;left:12px;bottom:10px;z-index:2;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);text-shadow:0 1px 6px #000;opacity:0;transition:.4s}
.gal-item:hover .gal-cap{opacity:1}
.trailer-note{margin-top:22px;text-align:center;color:var(--muted-2);font-size:.84rem;letter-spacing:.08em}
.trailer-note b{color:var(--gold)}

/* ============================ PRODUCTION / package ============================ */
.prod{background:var(--bg-2)}
.prod-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:start}
.budget{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel)}
.budget-head{display:flex;justify-content:space-between;align-items:baseline;padding:22px 26px;border-bottom:1px solid var(--line);background:linear-gradient(90deg,rgba(201,163,92,.08),transparent)}
.budget-head .t{font-family:var(--font-display);font-size:1.25rem;font-weight:700}
.budget-head .tot{font-family:var(--font-impact);font-size:1.7rem;color:var(--gold-2)}
.budget-row{display:flex;justify-content:space-between;align-items:center;padding:13px 26px;font-size:.92rem;border-top:1px solid var(--line-2);transition:background .3s}
.budget-row:hover{background:rgba(201,163,92,.04)}
.budget-row .cat{color:var(--muted)}
.budget-row .amt{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.budget-row .bar{flex:1;height:1px;margin:0 16px;background:repeating-linear-gradient(90deg,var(--line-2) 0 4px,transparent 4px 8px)}
.budget-foot{display:flex;justify-content:space-between;align-items:center;padding:18px 26px;border-top:2px solid var(--line);background:rgba(192,31,45,.06)}
.budget-foot .l{font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}
.budget-foot .v{font-family:var(--font-impact);font-size:2rem;color:#fff}

.spec-stack{display:flex;flex-direction:column;gap:18px}
.spec{border:1px solid var(--line);border-radius:8px;padding:24px 26px;background:var(--panel);transition:.4s}
.spec:hover{border-color:rgba(201,163,92,.4)}
.spec h4{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:.9rem;display:flex;align-items:center;gap:.6rem}
.spec h4 .ic{color:var(--gold)}
.spec ul li{display:flex;gap:.9rem;align-items:flex-start;color:var(--muted);font-size:.93rem;line-height:1.5;padding:.72em 0;border-top:1px solid var(--line-2)}
.spec ul li:first-child{border-top:none;padding-top:.2em}
.spec ul li:last-child{padding-bottom:.2em}
.spec ul li::before{content:"";flex:0 0 7px;width:7px;height:7px;margin-top:.55em;border-radius:50%;background:linear-gradient(180deg,var(--gold-2),var(--gold-deep));box-shadow:0 0 9px rgba(201,163,92,.45)}
.spec .pills{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:.2em}
.spec .pill{font-size:.72rem;letter-spacing:.08em;border:1px solid var(--line);border-radius:100px;padding:.5em 1em;color:var(--ink)}

/* ============================ SLATE ============================ */
.slate{background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.slate-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.poster-card{position:relative;border-radius:6px;overflow:hidden;border:1px solid var(--line-2);cursor:default;aspect-ratio:2/3;background:var(--bg-2)}
.poster-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s;filter:saturate(.9) brightness(.92)}
.poster-card:hover img{transform:scale(1.06);filter:saturate(1.05) brightness(1)}
.poster-card .meta{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:16px 16px 18px;background:linear-gradient(transparent 45%,rgba(8,6,7,.92));opacity:0;transition:.4s;transform:translateY(8px)}
.poster-card:hover .meta{opacity:1;transform:translateY(0)}
.poster-card .meta .g{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.25rem}
.poster-card .meta .nm{font-family:var(--font-display);font-weight:700;font-size:1.02rem;line-height:1.1}
.poster-card .corner{position:absolute;top:10px;right:10px;font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);background:rgba(10,7,8,.7);border:1px solid var(--line);padding:.35em .7em;border-radius:100px}
.slate-foot{margin-top:34px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.slate-foot .sf{background:var(--bg-2);padding:26px 24px}
.slate-foot .sf b{font-family:var(--font-impact);font-size:1.8rem;color:var(--gold-2);display:block;line-height:1}
.slate-foot .sf span{color:var(--muted);font-size:.88rem;display:block;margin-top:.5rem}

/* ============================ ABOUT / difference ============================ */
.about{background:var(--bg)}
.diff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:8px}
.diff{border:1px solid var(--line);border-radius:8px;padding:clamp(26px,3vw,38px);background:var(--panel);position:relative;overflow:hidden;transition:.45s var(--ease)}
.diff:hover{transform:translateY(-5px);border-color:rgba(201,163,92,.4)}
.diff .ix{font-family:var(--font-impact);font-size:1rem;color:var(--bg);background:var(--gold);width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-bottom:1rem}
.diff h3{font-family:var(--font-display);font-size:1.35rem;font-weight:700;margin-bottom:.6rem}
.diff p{color:var(--muted);font-size:.96rem}
.model{margin-top:42px;border:1px solid var(--line);border-radius:8px;padding:clamp(28px,3.4vw,44px);background:linear-gradient(120deg,rgba(201,163,92,.06),transparent)}
.model h3{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-bottom:1.4rem}
.model-paths{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.path{text-align:center;padding:18px}
.path .n{font-family:var(--font-impact);color:transparent;-webkit-text-stroke:1px var(--gold);font-size:1.6rem;display:block;margin-bottom:.6rem}
.path h4{font-size:1.02rem;font-weight:600;margin-bottom:.4rem}
.path p{color:var(--muted);font-size:.88rem}

/* ============================ CONTACT ============================ */
.contact{position:relative;background:var(--bg-2);overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;background:url('../img/still-h4.jpg') center/cover;opacity:.14;z-index:0}
.contact::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--bg-2),rgba(16,11,13,.6),var(--bg-2));z-index:0}
.contact .wrap{text-align:center;max-width:820px}
.contact h2{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,6vw,4rem);line-height:1.02;margin:.4rem 0 1rem}
.contact h2 em{font-style:italic;color:var(--gold-2)}
.contact .lede{margin:0 auto 2.4rem;text-align:center}
.contact-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2.6rem}
.contact-card{display:inline-grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden;width:100%;max-width:760px;margin:0 auto}
.cc{background:var(--bg-2);padding:24px 22px}
.cc .k{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.cc .v{font-size:.98rem;color:var(--ink);word-break:break-word}
.cc a:hover{color:var(--gold-2)}
.founder{margin-top:2.4rem;font-family:var(--font-display);font-style:italic;color:var(--muted)}
.founder b{color:var(--ink);font-style:normal}

/* ============================ FOOTER ============================ */
.footer{padding:clamp(56px,7vw,80px) 0 28px;border-top:1px solid var(--line);background:var(--bg)}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:42px}
.footer-brand .brand{font-size:1.22rem;margin-bottom:1rem}
.footer-brand p{color:var(--muted);font-size:.9rem;line-height:1.6;max-width:32ch;margin-bottom:1.5rem}
.footer-social{display:flex;gap:.7rem}
.footer-social a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .3s var(--ease)}
.footer-social a:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,163,92,.08);transform:translateY(-2px)}
.footer-col h4{font-family:var(--font-sans);font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.footer-col a{display:block;color:var(--muted);font-size:.9rem;padding:.42em 0;transition:color .25s}
.footer-col a:hover{color:var(--ink)}
.footer-bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;border-top:1px solid var(--line-2);padding-top:24px;color:var(--muted-2);font-size:.8rem;letter-spacing:.02em}
.footer-bottom a{color:var(--muted-2)}
.footer-bottom a:hover{color:var(--gold)}
/* Lottie sizing */
.scroll-cue lottie-player{width:34px;height:34px}
.btn-lottie{width:20px;height:20px;flex:0 0 auto}
.trailer-note{display:flex;align-items:center;justify-content:center;gap:.55rem}
.trailer-note lottie-player{width:22px;height:22px}
.lottie-spark{width:22px;height:22px;display:inline-block;vertical-align:-5px}

/* ============================ LIGHTBOX ============================ */
.lb{position:fixed;inset:0;z-index:100;background:rgba(6,4,5,.95);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:4vw}
.lb.open{display:flex;animation:fade .3s var(--ease)}
.lb img{max-width:92vw;max-height:88vh;border-radius:4px;box-shadow:0 30px 90px -20px #000,0 0 0 1px rgba(201,163,92,.2)}
.lb .close{position:absolute;top:24px;right:30px;font-size:2rem;color:var(--ink);width:48px;height:48px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
.lb .close:hover{border-color:var(--gold);color:var(--gold);transform:rotate(90deg)}
.lb .nav-arrow{position:absolute;top:50%;transform:translateY(-50%);font-size:2.4rem;color:var(--muted);padding:20px;transition:.3s}
.lb .nav-arrow:hover{color:var(--gold)}
.lb .prev{left:2vw}.lb .next{right:2vw}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ============================ REVEAL anim ============================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================ RESPONSIVE ============================ */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:40px;text-align:left}
  .hero-poster{order:-1;justify-self:start}
  .hero-poster .frame{transform:none;width:min(280px,64vw)}
  .story-grid,.demand-head,.prod-grid{grid-template-columns:1fr}
  .acts{grid-template-columns:1fr}
  .cast-grid{grid-template-columns:repeat(2,1fr)}
  .slate-grid{grid-template-columns:repeat(3,1fr)}
  .gal-grid{grid-template-columns:repeat(3,1fr)}
  .diff-grid,.model-paths{grid-template-columns:1fr 1fr}
  .nav-links{
    position:fixed;inset:0;width:100%;flex-direction:column;
    align-items:center;justify-content:center;gap:1.9rem;padding:84px 32px 48px;
    background:#0a0708;
    transform:translateX(100%);transition:transform .42s var(--ease),visibility .42s var(--ease);z-index:49;
    visibility:hidden;
  }
  .nav-links.open{transform:translateX(0);visibility:visible}
  .nav-links a{font-size:1.4rem;letter-spacing:.14em}
  .nav-links a::after{display:none}
  .nav-links .btn{margin-top:.8rem;font-size:.9rem;padding:1em 2em}
  .nav-toggle{display:flex}
  .nav-toggle.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.x span:nth-child(2){opacity:0}
  .nav-toggle.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media(max-width:620px){
  .cast-grid,.slate-grid,.gal-grid,.diff-grid,.model-paths{grid-template-columns:1fr 1fr}
  .hero-meta{gap:1.2rem}
  .hero-meta .m b{font-size:1.3rem}
  .gal-grid{grid-auto-rows:150px}
  .story-figs{gap:10px}
  .footer-bottom{justify-content:center;text-align:center}
}
@media(max-width:440px){
  .slate-grid,.gal-grid{grid-template-columns:1fr 1fr}
  .cast-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
}

/* ============================ COMPANY-SITE ADDITIONS ============================ */
/* Hero: company headline */
.hero .eyebrow{margin-bottom:1.5rem}
.hero-accent{
  display:block;font-family:var(--font-display);font-style:italic;font-weight:800;
  font-size:clamp(2.8rem,8vw,5.4rem);line-height:.95;letter-spacing:-.015em;margin-top:.06em;
  background:linear-gradient(180deg,var(--gold-2),var(--gold) 70%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 8px 26px rgba(0,0,0,.45));
}

/* Hero: fanned poster stack */
.poster-stack{position:relative;justify-self:center;width:min(290px,72vw);margin-inline:auto}
.poster-stack .pf{border-radius:6px;overflow:hidden;border:1px solid rgba(201,163,92,.22);background:var(--bg-2)}
.poster-stack .pf img{display:block;width:100%}
.poster-stack .p1{position:relative;z-index:3;box-shadow:0 44px 90px -30px #000,0 0 0 1px rgba(201,163,92,.3),0 0 64px -18px rgba(192,31,45,.42);transition:transform .6s var(--ease)}
.poster-stack .p2,.poster-stack .p3{position:absolute;top:7%;width:78%;z-index:1;box-shadow:0 30px 60px -26px rgba(0,0,0,.9);filter:brightness(.6) saturate(.82);transition:transform .6s var(--ease)}
.poster-stack .p2{left:0;transform:translateX(-30%) rotate(-8deg)}
.poster-stack .p3{right:0;transform:translateX(30%) rotate(8deg)}
.poster-stack:hover .p1{transform:translateY(-5px) scale(1.015)}
.poster-stack:hover .p2{transform:translateX(-42%) rotate(-11deg)}
.poster-stack:hover .p3{transform:translateX(42%) rotate(11deg)}
.pf-badge{position:absolute;top:12px;left:12px;z-index:6;background:linear-gradient(180deg,var(--blood-2),var(--blood));color:#fff;font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:.5em .9em;border-radius:3px;box-shadow:0 8px 20px -6px rgba(192,31,45,.7)}

/* Studio: model + includes side by side */
.studio-split{display:grid;grid-template-columns:1.08fr .92fr;gap:22px;margin-top:42px;align-items:stretch}
.studio-split .model{margin-top:0}
.spec.includes{align-self:stretch;display:flex;flex-direction:column;justify-content:center}

/* Talent: section label */
.support-label{text-align:center;margin-top:50px;margin-bottom:20px;font-family:var(--font-display);font-style:italic;color:var(--muted);font-size:1.08rem}

/* Featured: tag rows */
.feat-grid{grid-template-columns:.85fr 1.15fr;align-items:center}
.feat-tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.feat-tags .pill{font-size:.72rem;letter-spacing:.06em;border:1px solid var(--line);border-radius:100px;padding:.5em 1.1em;color:var(--ink);background:rgba(192,31,45,.06)}

/* Company-site responsive */
@media(max-width:980px){
  .studio-split{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .feat-grid .hero-poster{order:-1}
  .hero-accent{font-size:clamp(2.6rem,12vw,4rem)}
  .poster-stack{width:min(260px,62vw);margin-top:8px}
}
@media(max-width:620px){
  .support{grid-template-columns:1fr 1fr}
  .poster-stack .p2{transform:translateX(-24%) rotate(-7deg)}
  .poster-stack .p3{transform:translateX(24%) rotate(7deg)}
}

/* Gallery masonry: responsive column counts */
@media(max-width:760px){.gal-grid{column-count:2}}
@media(max-width:430px){.gal-grid{column-count:1}}

/* Contact eyebrow: add trailing line to match centered eyebrows */
.contact .eyebrow::after{content:"";width:30px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}

/* Footer responsive */
@media(max-width:880px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr;gap:30px}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr 1fr}
}

/* ============================ LEGAL PAGES ============================ */
.nav-solid{background:rgba(10,7,8,.9);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}
.legal-head{padding:128px 0 48px;background:linear-gradient(180deg,var(--bg-2),var(--bg));border-bottom:1px solid var(--line)}
.legal-back{display:inline-flex;align-items:center;gap:.45em;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem;transition:color .25s}
.legal-back:hover{color:var(--gold)}
.legal-head .eyebrow{margin-bottom:.7rem}
.legal-head h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2.1rem,5vw,3.3rem);line-height:1.05;margin:.2rem 0 .6rem}
.legal-updated{color:var(--muted-2);font-size:.84rem;letter-spacing:.03em}
.legal-body{display:grid;grid-template-columns:230px 1fr;gap:clamp(32px,5vw,64px);padding-top:clamp(40px,5vw,60px);padding-bottom:clamp(56px,8vw,96px);align-items:start}
.legal-toc{position:sticky;top:88px;border-left:1px solid var(--line);padding-left:20px}
.legal-toc h4{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.legal-toc a{display:block;color:var(--muted);font-size:.84rem;line-height:1.3;padding:.42em 0;transition:color .2s}
.legal-toc a:hover{color:var(--ink)}
.legal-content{max-width:760px;color:var(--muted);font-size:1rem;line-height:1.75}
.legal-content > p:first-child{font-size:1.08rem;color:var(--ink);line-height:1.7;margin-bottom:2rem}
.legal-section{scroll-margin-top:90px}
.legal-content h2{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:clamp(1.3rem,2.4vw,1.6rem);margin:0 0 1rem;padding-top:.4rem}
.legal-content h3{color:var(--ink);font-size:1.05rem;font-weight:600;margin:1.5rem 0 .55rem}
.legal-content p{margin-bottom:1.05rem}
.legal-content section{margin-bottom:2.2rem}
.legal-content ul,.legal-content ol{margin:0 0 1.15rem 1.3rem}
.legal-content li{margin-bottom:.55rem;padding-left:.35rem}
.legal-content ul li{list-style:disc}
.legal-content ol li{list-style:decimal}
.legal-content a{color:var(--gold);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.legal-content a:hover{color:var(--gold-2)}
.legal-content strong{color:var(--ink);font-weight:600}
.legal-content table{width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;font-size:.9rem}
.legal-content th,.legal-content td{border:1px solid var(--line);padding:.65em .85em;text-align:left;vertical-align:top}
.legal-content th{color:var(--ink);background:rgba(201,163,92,.07);font-weight:600}
.legal-note{border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:5px;padding:18px 20px;background:var(--panel);margin:1.4rem 0;color:var(--ink);font-size:.95rem}
.legal-note p{margin:0}
@media(max-width:860px){
  .legal-body{grid-template-columns:1fr;gap:8px}
  .legal-toc{position:static;border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:22px;margin-bottom:22px}
  .legal-toc a{display:inline-block;margin-right:14px}
}

/* ============================ PROVEN EXPERIENCE ============================ */
.proven{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.proven-bg{position:absolute;inset:0;z-index:0}
.proven-bg::before{content:"";position:absolute;inset:0;background:url(../img/proven-bg.jpg) center 26%/cover;opacity:.34;filter:saturate(.95)}
.proven-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,7,8,.7),rgba(10,7,8,.4) 42%,rgba(10,7,8,.74))}
.proven-points{display:flex;flex-wrap:wrap;justify-content:center;gap:.9rem 2rem;margin:0 auto clamp(36px,5vw,54px);max-width:920px}
.proven-points .pp{display:flex;align-items:center;gap:.6rem;color:var(--muted);font-size:.95rem}
.proven-points .ck{color:var(--gold);font-weight:700;flex:0 0 auto}
.proven-posters{display:flex;justify-content:center;align-items:center;gap:clamp(14px,2.6vw,30px);flex-wrap:wrap}
.proven-posters figure{position:relative;border-radius:7px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.9);transition:transform .45s var(--ease),box-shadow .45s,border-color .45s}
.proven-posters figure:hover{transform:translateY(-8px);border-color:rgba(201,163,92,.4);box-shadow:0 42px 72px -30px rgba(0,0,0,.95)}
.proven-posters img{display:block;height:clamp(300px,36vw,420px);width:auto;max-width:88vw;filter:saturate(1.03)}
/* clickable talent handle */
a.handle:hover{color:var(--gold-2)}
@media(max-width:840px){
  .proven-posters{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;scroll-snap-type:x mandatory;gap:14px;padding-bottom:16px;scrollbar-width:thin}
  .proven-posters figure{flex:0 0 auto;scroll-snap-align:center}
  .proven-posters img{height:min(52vh,380px);max-width:none}
  .proven-points{text-align:left;justify-content:flex-start}
}

/* ============================ CONTACT FORM ============================ */
.contact-form{max-width:560px;margin:2.4rem auto .4rem;text-align:left;display:flex;flex-direction:column;gap:1.05rem}
.contact-form .cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1.05rem}
.contact-form label{display:flex;flex-direction:column;gap:.5rem;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.contact-form label span{color:var(--muted-2);text-transform:none;letter-spacing:.02em;font-weight:400}
.contact-form input,.contact-form textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);background:rgba(246,239,231,.04);
  border:1px solid var(--line);border-radius:5px;padding:.85em 1em;width:100%;
  transition:border-color .25s,background .25s;resize:vertical;letter-spacing:0;text-transform:none}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--muted-2)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold);background:rgba(246,239,231,.06)}
.contact-form button{align-self:flex-start;margin-top:.5rem}
.contact-form button:disabled{opacity:.6;cursor:wait}
.cf-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.cf-status{display:block;font-size:.92rem;min-height:1.1em;margin-top:.2rem;letter-spacing:0;text-transform:none;color:var(--muted)}
.cf-status.ok{color:var(--gold-2)}
.cf-status.err{color:var(--blood-2)}
.contact-alt{margin-top:1.4rem;color:var(--muted-2);font-size:.9rem}
.contact-alt a{color:var(--gold)}
.contact-alt a:hover{color:var(--gold-2)}
@media(max-width:560px){.contact-form .cf-row{grid-template-columns:1fr}}

/* Left-aligned eyebrows (hero, studio) read odd with a single leading line; remove it */
.hero .eyebrow::before,.about .eyebrow::before{display:none}
