/* ============================================================
   KHELIFI CONSULTING. Premium one-page site.
   Marcellus display (Trajan-class, matches the KH logo) + Inter body
   Self-hosted: no CDN dependency, always loads.
   ============================================================ */

@font-face{font-family:"Inter";src:url("assets/fonts/Inter-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/Inter-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/Inter-SemiBold.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/Inter-Italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/Inter-SemiBoldItalic.woff2") format("woff2");font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:"Marcellus";src:url("assets/fonts/Marcellus-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter Display";src:url("assets/fonts/InterDisplay-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter Display";src:url("assets/fonts/InterDisplay-SemiBold.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter Display";src:url("assets/fonts/InterDisplay-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Inter Display";src:url("assets/fonts/InterDisplay-SemiBoldItalic.woff2") format("woff2");font-weight:600;font-style:italic;font-display:swap}

:root{
  --gold:#DAA750;
  --gold-bright:#EBBE6E;
  --gold-deep:#B8863B;
  --ease:cubic-bezier(.22,1,.36,1);
  --font-display:"Marcellus","Inter Display",serif;
  --font-body:"Inter",system-ui,sans-serif;
}

[data-theme="dark"]{
  --stroke-gold:rgba(235,190,110,.28);
  --bg:#120D0A;
  --bg-alt:#171110;
  --surface:rgba(255,255,255,.04);
  --surface-strong:rgba(255,255,255,.07);
  --border:rgba(218,167,80,.16);
  --border-soft:rgba(255,255,255,.08);
  --text:#F5EDE2;
  --text-soft:rgba(245,237,226,.62);
  --text-faint:rgba(245,237,226,.38);
  --accent:var(--gold);
  --glow:rgba(218,167,80,.20);
  --header-bg:rgba(18,13,10,.72);
  --shadow:0 24px 60px rgba(0,0,0,.45);
}

[data-theme="light"]{
  --stroke-gold:rgba(168,118,42,.34);
  --bg:#FAF9F6;
  --bg-alt:#F1EEE7;
  --surface:rgba(26,18,10,.035);
  --surface-strong:rgba(26,18,10,.06);
  --border:rgba(160,116,42,.22);
  --border-soft:rgba(26,18,10,.10);
  --text:#1D150D;
  --text-soft:rgba(29,21,13,.66);
  --text-faint:rgba(29,21,13,.42);
  --accent:#A8762B;
  --glow:rgba(218,167,80,.28);
  --header-bg:rgba(250,249,246,.82);
  --shadow:0 24px 60px rgba(105,75,30,.14);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-feature-settings:"cv05","cv11";
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  transition:background .5s var(--ease),color .5s var(--ease);
  overflow-x:hidden;
}
::selection{background:var(--gold);color:#1A120A}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3{font-family:var(--font-display)}
em{font-style:normal;font-weight:400;color:var(--accent)}

.container{width:min(1240px,92%);margin-inline:auto}
.top-sentinel{position:absolute;top:0;height:24px;width:1px}

/* ---------- progress bar (CSS scroll-driven) ---------- */
.progress-bar{
  position:fixed;top:0;left:0;height:2px;width:100%;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));
  z-index:1001;transform:scaleX(0);transform-origin:left;
}
@supports (animation-timeline: scroll()){
  .progress-bar{animation:pageProgress linear;animation-timeline:scroll(root)}
  @keyframes pageProgress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
}

/* ---------- header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:1000;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),backdrop-filter .4s;
}
.site-header.scrolled{
  background:var(--header-bg);
  backdrop-filter:blur(18px) saturate(1.4);
  -webkit-backdrop-filter:blur(18px) saturate(1.4);
  box-shadow:0 1px 0 var(--border-soft);
}
.header-inner{
  width:min(1320px,94%);margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{height:38px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:"Marcellus",serif;font-weight:400;font-size:1.02rem;letter-spacing:.10em}
.brand-sub{font-family:"Marcellus",serif;font-weight:400;font-size:.58rem;letter-spacing:.42em;color:var(--text-soft)}

/* hero is always dark: force light header text while over hero */
.site-header:not(.scrolled).over-hero{color:#F5EDE2}
.site-header:not(.scrolled).over-hero .main-nav a,
.site-header:not(.scrolled).over-hero .brand-sub{color:rgba(245,237,226,.72)}
.site-header:not(.scrolled).over-hero .theme-toggle{color:#F5EDE2;border-color:rgba(245,237,226,.25);background:rgba(255,255,255,.06)}
.site-header:not(.scrolled).over-hero .nav-burger span{background:#F5EDE2}

.main-nav{display:flex;gap:32px}
.main-nav a{
  font-size:.88rem;font-weight:500;letter-spacing:.02em;color:var(--text-soft);
  position:relative;padding:4px 0;transition:color .3s;
}
.main-nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--accent);transition:width .35s var(--ease);
}
.main-nav a:hover{color:inherit}
.main-nav a:hover::after{width:100%}

.header-actions{display:flex;align-items:center;gap:14px}

.theme-toggle{
  width:40px;height:40px;border-radius:999px;
  border:1px solid var(--border);background:var(--surface);
  color:var(--text);cursor:pointer;display:grid;place-items:center;
  transition:border-color .3s,transform .3s var(--ease),background .3s,color .3s;
  font-size:18px;
}
.theme-toggle:hover{border-color:var(--accent);transform:rotate(15deg)}
.theme-toggle:active{transform:scale(.94)}
[data-theme="dark"] .icon-moon{display:none}
[data-theme="light"] .icon-sun{display:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:500;font-size:.92rem;letter-spacing:.01em;
  padding:13px 26px;border-radius:999px;
  transition:transform .25s var(--ease),box-shadow .3s var(--ease),background .3s,border-color .3s;
  white-space:nowrap;will-change:transform;
}
.btn-lg{padding:17px 34px;font-size:.97rem}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));
  color:#1A120A;box-shadow:0 8px 28px rgba(218,167,80,.28);
}
.btn-gold:hover{box-shadow:0 14px 38px rgba(218,167,80,.4)}
.btn-gold:active{transform:scale(.97)}
.btn-ghost{border:1px solid rgba(245,237,226,.3);color:#F5EDE2;background:rgba(255,255,255,.05);backdrop-filter:blur(8px)}
.btn-ghost:hover{border-color:var(--gold)}
.btn-ghost:active{transform:scale(.97)}

/* ---------- burger ---------- */
.nav-burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:8px}
.nav-burger span{width:24px;height:2px;background:var(--text);transition:.35s var(--ease)}
.nav-burger[aria-expanded="true"] span:first-child{transform:translateY(4px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:last-child{transform:translateY(-4px) rotate(-45deg)}

/* ============ HERO: full-bleed photo, always dark ============ */
.hero{
  position:relative;min-height:100dvh;
  display:flex;align-items:flex-end;
  padding:120px 0 64px;overflow:hidden;
  color:#F5EDE2;
}
.hero-media{position:absolute;inset:0;pointer-events:none}
.hero-photo{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  animation:kenburns 18s var(--ease) forwards;
  transform-origin:60% 40%;
}
@keyframes kenburns{from{transform:scale(1.12)}to{transform:scale(1)}}
.hero-scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(to top,rgba(14,9,6,.92) 0%,rgba(14,9,6,.45) 38%,rgba(14,9,6,.25) 60%,rgba(14,9,6,.55) 100%),
    linear-gradient(100deg,rgba(14,9,6,.82) 0%,rgba(14,9,6,.25) 55%,transparent 80%);
}
.hero-glow{
  position:absolute;width:1000px;height:1000px;border-radius:50%;
  left:60%;top:35%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(218,167,80,.16) 0%,transparent 62%);
  transition:transform 1.2s var(--ease);
}

.hero-inner{position:relative;display:grid;grid-template-columns:1.45fr .85fr;gap:56px;align-items:end}

.eyebrow{
  display:flex;align-items:center;gap:14px;
  font-size:.78rem;font-weight:700;letter-spacing:.30em;text-transform:uppercase;
  color:var(--gold);margin-bottom:26px;
}
.eyebrow-line{width:42px;height:1px;background:var(--gold);display:inline-block}

.hero-title{
  font-size:clamp(2.5rem,4.1vw,3.9rem);
  font-weight:400;line-height:1.12;letter-spacing:.005em;
  margin-bottom:26px;color:#FAF4E8;
}
.hero-title .line{display:block;overflow:hidden;padding-bottom:.12em;margin-bottom:-.12em}
.hero-title .w{
  display:inline-block;transform:translateY(120%);
  animation:riseUp .9s var(--ease) forwards;
  animation-delay:calc(var(--hero-delay,0s) + var(--i,0)*.09s);
}
@keyframes riseUp{to{transform:translateY(0)}}
.hero-title em{color:var(--gold-bright)}

.hero-lede{max-width:42ch;font-size:1.1rem;color:rgba(245,237,226,.78);margin-bottom:34px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}

/* hero glass stat cards over photo */
.hero-cards{display:grid;gap:14px}
.glass-card{
  background:rgba(20,13,8,.55);
  border:1px solid rgba(218,167,80,.28);
  border-radius:20px;
  backdrop-filter:blur(16px) saturate(1.3);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 18px 44px rgba(0,0,0,.35);
  transition:transform .45s var(--ease),border-color .35s;
  will-change:transform;
}
.glass-card:hover{border-color:var(--gold)}
.stat-card{padding:24px 26px}
.stat-number{font-family:var(--font-display);font-size:2.7rem;font-weight:400;letter-spacing:.01em;color:var(--gold-bright);line-height:1.05}
.stat-label{font-size:.86rem;color:rgba(245,237,226,.7);margin-top:4px}

/* ---------- marquee ---------- */
.marquee{
  border-block:1px solid var(--border-soft);
  padding:20px 0;overflow:hidden;
  background:var(--bg-alt);
  transition:background .5s var(--ease);
}
.marquee-track{display:flex;gap:52px;width:max-content;animation:marquee 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{
  font-family:var(--font-display);font-size:1.3rem;font-weight:400;
  letter-spacing:.01em;color:var(--text-soft);white-space:nowrap;
}
.marquee-track i{color:var(--accent);font-style:normal;font-size:.85rem;align-self:center}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
.section{padding:130px 0;position:relative}
.section-alt{background:var(--bg-alt);transition:background .5s var(--ease)}
.section-head{margin-bottom:64px}
.section-head h2,
.contact-copy h2{
  font-size:clamp(2.2rem,4.4vw,3.5rem);
  font-weight:400;line-height:1.14;letter-spacing:.005em;
}

/* about: text + boardroom image */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;margin-bottom:96px}
.about-lede{font-size:1.35rem;font-weight:400;line-height:1.5;letter-spacing:-.01em;margin-bottom:24px}
.about-body{color:var(--text-soft)}
.about-figure{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.about-figure img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform 1.2s var(--ease)}
.about-figure:hover img{transform:scale(1.04)}
.about-figure::after{
  content:"";position:absolute;inset:0;border-radius:24px;
  border:1px solid rgba(218,167,80,.25);pointer-events:none;
}

/* pillars: hairline columns */
.pillars{display:grid;grid-template-columns:repeat(3,1fr)}
.pillar{padding:8px 36px;border-left:1px solid var(--border-soft)}
.pillar:first-child{padding-left:0;border-left:0}
.pillar h3{font-size:1.35rem;font-weight:400;margin-bottom:14px;color:var(--accent)}
.pillar p{font-size:.96rem;color:var(--text-soft)}

/* ============ SERVICES: interactive large-type accordion ============ */
.services-list{border-top:1px solid var(--border-soft)}
.service-row{border-bottom:1px solid var(--border-soft)}
.service-toggle{
  width:100%;display:flex;align-items:center;gap:28px;
  background:none;border:0;cursor:pointer;color:inherit;
  padding:30px 8px;text-align:left;
  transition:padding .35s var(--ease);
}
.service-toggle:hover{padding-left:20px}
.service-toggle .ph{font-size:30px;color:var(--accent);flex-shrink:0;transition:transform .4s var(--ease)}
.service-title{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,3.2vw,2.4rem);
  font-weight:400;letter-spacing:.005em;line-height:1.15;
  color:var(--text-faint);
  transition:color .35s var(--ease);
  flex:1;
}
.service-toggle:hover .service-title,
.service-row.open .service-title{color:var(--text)}
.service-chevron{
  width:44px;height:44px;border:1px solid var(--border);border-radius:999px;
  display:grid;place-items:center;flex-shrink:0;
  color:var(--accent);font-size:18px;
  transition:transform .45s var(--ease),background .3s,color .3s;
}
.service-row.open .service-chevron{transform:rotate(45deg);background:var(--accent);color:var(--bg)}
.service-body{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .5s var(--ease);
}
.service-body>div{overflow:hidden}
.service-row.open .service-body{grid-template-rows:1fr}
.service-items{
  display:flex;flex-wrap:wrap;gap:10px;
  padding:0 8px 34px 66px;
}
.service-items li{
  list-style:none;font-size:.92rem;font-weight:500;color:var(--text-soft);
  border:1px solid var(--border);border-radius:999px;padding:9px 18px;
  background:var(--surface);
  transition:border-color .3s,color .3s;
}
.service-items li:hover{border-color:var(--accent);color:var(--text)}

/* why */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border-soft);border-radius:20px;overflow:hidden}
.why-card{padding:40px 32px;border-right:1px solid var(--border-soft);background:var(--surface);transition:background .35s}
.why-card:last-child{border-right:0}
.why-card:hover{background:var(--surface-strong)}
.why-card h3{font-size:1.2rem;font-weight:400;margin-bottom:12px;color:var(--accent)}
.why-card p{font-size:.9rem;color:var(--text-soft)}

/* methodology */
.method-list{list-style:none;max-width:880px}
.method-step{
  display:flex;gap:32px;align-items:flex-start;
  padding:34px 0;border-bottom:1px solid var(--border-soft);
}
.method-step:last-child{border-bottom:0}
.method-num{
  font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--accent);
  width:46px;height:46px;border:1px solid var(--border);border-radius:999px;
  display:grid;place-items:center;flex-shrink:0;margin-top:4px;
  transition:background .3s,color .3s;
}
.method-step:hover .method-num{background:var(--accent);color:var(--bg)}
.method-step h3{font-size:1.4rem;font-weight:400;margin-bottom:6px}
.method-step p{color:var(--text-soft);max-width:60ch}

/* values / ethics */
.values-band{text-align:center;margin-bottom:70px}
.values-row{
  display:flex;justify-content:center;align-items:center;gap:30px;flex-wrap:wrap;
  font-family:var(--font-display);
  font-size:clamp(1.5rem,3vw,2.4rem);font-weight:400;letter-spacing:.01em;
}
.values-row i{color:var(--accent);font-style:normal;font-size:1rem}
.ethics{max-width:780px;margin-inline:auto;text-align:center}
.ethics blockquote{
  font-size:clamp(1.2rem,2.2vw,1.55rem);font-weight:500;
  font-style:italic;line-height:1.55;color:var(--text-soft);
}
.ethics figcaption{margin-top:22px;font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}

/* contact */
.section-contact{
  background:
    radial-gradient(ellipse 60% 80% at 80% 20%,var(--glow),transparent 60%),
    var(--bg-alt);
  transition:background .5s var(--ease);
}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
.contact-lede{color:var(--text-soft);margin:24px 0 36px;max-width:44ch}
.section-contact .btn-gold{box-shadow:0 8px 28px rgba(218,167,80,.28)}
.contact-details{display:flex;flex-direction:column;gap:34px}
.contact-item p{color:var(--text-soft);font-size:.95rem}
.contact-item a:hover{color:var(--accent)}
.contact-label{
  font-size:.72rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);margin-bottom:8px;
}

/* footer */
.site-footer{border-top:1px solid var(--border-soft);padding:56px 0}
.footer-inner{display:flex;align-items:center;gap:28px;flex-wrap:wrap;justify-content:space-between}
.footer-tag{color:var(--text-soft);font-size:.9rem}
.footer-copy{color:var(--text-faint);font-size:.82rem}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:1080px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-cards{grid-template-columns:1fr 1fr;max-width:560px}
  .pillars{grid-template-columns:1fr}
  .pillar{border-left:0;border-top:1px solid var(--border-soft);padding:28px 0}
  .pillar:first-child{border-top:0;padding-top:0}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .why-card:nth-child(2){border-right:0}
  .why-card:nth-child(-n+2){border-bottom:1px solid var(--border-soft)}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .header-cta{display:none}
}
@media (max-width:720px){
  .main-nav{
    position:fixed;inset:0;z-index:-1;
    flex-direction:column;justify-content:center;align-items:center;gap:30px;
    background:var(--bg);opacity:0;pointer-events:none;
    transition:opacity .4s var(--ease);
  }
  .main-nav.open{opacity:1;pointer-events:auto;z-index:999;color:var(--text)}
  .main-nav a{font-size:1.5rem;color:var(--text-soft)}
  .nav-burger{display:flex}
  .why-grid{grid-template-columns:1fr}
  .why-card{border-right:0;border-bottom:1px solid var(--border-soft)}
  .why-card:last-child{border-bottom:0}
  .section{padding:90px 0}
  .hero{padding-top:110px}
  .hero-cards{grid-template-columns:1fr 1fr}
  .service-items{padding-left:8px}
  .service-toggle{gap:16px}
  .method-step{gap:20px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .hero-title .w{transform:none;animation:none}
  .rise{opacity:1;transform:none;animation:none}
  .intro{display:none}
  .hero-title .endure{animation:none;background-position:0 0}
  .hero-photo{animation:none}
  .reveal{opacity:1;transform:none}
}

/* ============ HERO CINEMA PACKAGE ============ */

/* staged entrance for eyebrow, lede, CTAs */
.rise{
  opacity:0;transform:translateY(26px);
  animation:riseFade .9s var(--ease) forwards;
  animation-delay:calc(var(--hero-delay,0s) + var(--d,0s));
}
@keyframes riseFade{to{opacity:1;transform:none}}

/* gold shimmer sweep + drawn underline on "endure" */
.hero-title .endure{
  position:relative;font-style:normal;
  background:linear-gradient(110deg,var(--gold) 20%,#FFF3D6 50%,var(--gold) 80%);
  background-size:220% 100%;background-position:120% 0;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--gold);
  animation:goldSweep 1.8s var(--ease) forwards;
  animation-delay:calc(var(--hero-delay,0s) + 1s);
}
@keyframes goldSweep{to{background-position:-120% 0}}
.hero-title .endure::after{
  content:"";position:absolute;left:0;bottom:-.08em;height:2px;width:100%;
  background:linear-gradient(90deg,var(--gold-bright),var(--gold-deep));
  transform:scaleX(0);transform-origin:left;
  animation:drawLine .8s var(--ease) forwards;
  animation-delay:calc(var(--hero-delay,0s) + 1.15s);
}
@keyframes drawLine{to{transform:scaleX(1)}}

/* cinematic film grain (fixed, pointer-events none, GPU-cheap) */
.grain{
  position:fixed;inset:0;z-index:900;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='0.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
}
[data-theme="light"] .grain{opacity:.035}

/* slow breathing of the hero glow */
.hero-glow{animation:glowBreathe 9s ease-in-out infinite alternate}
@keyframes glowBreathe{from{opacity:.75}to{opacity:1.15}}

/* scroll cinema: photo zooms in and content recedes as you scroll (Chromium/modern) */
@supports (animation-timeline: scroll()){
  .hero-media{
    animation:heroParallax linear forwards;
    animation-timeline:scroll(root);
    animation-range:0 120vh;
    will-change:transform;
  }
  @keyframes heroParallax{to{transform:scale(1.14) translateY(7%)}}
  .hero-inner{
    animation:heroRecede linear forwards;
    animation-timeline:scroll(root);
    animation-range:0 95vh;
  }
  @keyframes heroRecede{to{opacity:.04;transform:translateY(-80px)}}
  .hero-scrim{
    animation:scrimDarken linear forwards;
    animation-timeline:scroll(root);
    animation-range:0 110vh;
  }
  @keyframes scrimDarken{to{opacity:1.0;background-color:rgba(14,9,6,.55)}}
}

/* brand intro: gold monogram reveal, then curtain lifts */
.intro{
  position:fixed;inset:0;z-index:2000;
  background:#0E0906;
  display:grid;place-items:center;
  visibility:hidden;
}
.intro.play{visibility:visible;animation:curtainUp 1s var(--ease) forwards;animation-delay:1.7s}
@keyframes curtainUp{to{transform:translateY(-100%)}}
.intro-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.intro-mark{
  height:74px;width:auto;opacity:0;transform:scale(.86);filter:blur(8px);
}
.intro.play .intro-mark{animation:markIn 1s var(--ease) forwards .1s}
@keyframes markIn{to{opacity:1;transform:scale(1);filter:blur(0)}}
.intro-rule{
  width:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.intro.play .intro-rule{animation:ruleGrow .8s var(--ease) forwards .5s}
@keyframes ruleGrow{to{width:210px}}
.intro-word{
  font-family:"Marcellus",serif;font-size:.8rem;letter-spacing:.5em;color:#F5EDE2;
  opacity:0;transform:translateY(10px);
}
.intro.play .intro-word{animation:riseFade .8s var(--ease) forwards .65s}

/* ============================================================
   UPGRADE LAYER — 3D emblem, services grid, bento, cine, mad-libs
   ============================================================ */


/* ---------- services: numbered editorial grid ---------- */
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border-soft);border-left:1px solid var(--border-soft);
}
.svc{
  border-right:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);
  padding:30px 28px 36px;min-height:210px;display:flex;flex-direction:column;
  position:relative;transition:background .4s var(--ease);
}
.svc:hover{background:var(--surface)}
.svc::after{content:"";position:absolute;left:0;top:0;width:100%;height:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.svc:hover::after{transform:scaleX(1)}
.svc-n{font-family:var(--font-display);font-size:.95rem;color:var(--accent)}
.svc h3{font-size:1.25rem;font-weight:400;margin:auto 0 10px;padding-top:26px}
.svc-items{font-size:.85rem;color:var(--text-faint);line-height:1.7}
@media (max-width:1020px){.svc-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.svc-grid{grid-template-columns:1fr}.svc{min-height:0}.svc h3{padding-top:14px}}

/* ---------- why: bento with image cells ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bento .why-card{margin:0}
.b-img{border-radius:20px;overflow:hidden;min-height:220px}
.b-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 1s var(--ease)}
.b-img:hover img{transform:scale(1.0)}
@media (max-width:1020px){.bento{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.bento{grid-template-columns:1fr}}

/* ---------- cinematic band ---------- */
.cine-band{height:clamp(280px,42vw,500px);overflow:hidden;position:relative}
.cine-band img{position:absolute;inset:-12% 0;width:100%;height:124%;object-fit:cover}

/* ---------- mad-libs form ---------- */
.mad{margin-top:8px}
.mad-row{font-family:var(--font-display);font-size:clamp(1.05rem,1.6vw,1.3rem);line-height:2.4;margin-bottom:6px}
.mad input{
  border:none;border-bottom:1px solid var(--border);background:transparent;outline:none;
  font-family:var(--font-display);font-style:italic;font-size:.95em;color:var(--text);
  padding:2px 8px;min-width:190px;transition:border-color .3s;
}
.mad input::placeholder{color:var(--text-faint);font-style:italic}
.mad input:focus{border-color:var(--accent)}
.mad-pills{display:inline-flex;gap:8px;flex-wrap:wrap;vertical-align:middle}
.mad-pills label{cursor:pointer}
.mad-pills input{display:none}
.mad-pills span{
  display:inline-block;border:1px solid var(--border);border-radius:999px;padding:6px 16px;
  font-family:var(--font-body);font-size:.8rem;transition:all .3s var(--ease);
}
.mad-pills input:checked+span{background:var(--accent);color:#1A120A;border-color:var(--accent)}
.mad .btn{margin-top:22px}
.mad-ok{display:none;margin-top:14px;font-size:.9rem;color:var(--accent)}
.mad-ok.show{display:block}
.mad-ok a{text-decoration:underline}
@media (max-width:640px){.mad input{min-width:100%;margin:4px 0}.mad-row{line-height:2}}
