/* ===== Tokens ===== */
:root{
  --bg:#000000;
  --bg-soft:#0b0b0b;
  --bg-card:#121212;
  --line:rgba(255,255,255,0.14);
  --ink:#f5f4f1;
  --ink-soft:#a8a49d;
  --ink-mute:#6b6862;
  /* warm greige accent */
  --gold:#D8D0C2;
  --gold-soft:#E7E1D6;
  --green:#141414;
  --green-soft:#D8D0C2;
  --radius:8px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --sans:'Helvetica Neue',Helvetica,Arial,sans-serif;
  --head:'Helvetica Neue',Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}

/* ===== Light theme — warm paper sections to break up the black =====
   Re-scopes the design tokens, so every child (titles, cards, tags,
   stat figures, hairlines, logo-marquee fades) adapts automatically. */
.light{
  --bg:#f4f2ec;
  --bg-soft:#edeae2;
  --bg-card:#ffffff;
  --line:rgba(23,21,18,.14);
  --ink:#171512;
  --ink-soft:#57534b;
  --ink-mute:#8a857c;
  --gold:#8a8270;        /* greige darkened for readability on paper */
  --gold-soft:#6f6757;
  background:var(--bg);
  color:var(--ink);      /* reset color inherited from the dark body */
}
/* fix-ups for values hard-coded outside the token system */
.light .card:hover{border-color:rgba(23,21,18,.32)}
.light .card__tag{border-color:rgba(23,21,18,.28)}
.light .card--feature{background:linear-gradient(160deg,rgba(138,130,112,.10),var(--bg-card) 55%)}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:16px;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
h1,h2,h3,h4{text-wrap:balance}
.num,.proof__num,.proof__suffix,.achv__num,.achv__static,.achv__suffix,.statcol__static{font-variant-numeric:tabular-nums}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--gold-soft)}

/* ===== Brand ===== */
.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--head)}
.brand__mark{display:none}
.brand__text{font-size:1.45rem;font-weight:700;letter-spacing:-.5px;color:var(--ink)}
.brand__accent{color:inherit}
.brand__logo{height:26px;width:auto;display:block}
.brand:hover{opacity:.82}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:500;font-size:.92rem;border-radius:3px;padding:13px 26px;letter-spacing:.01em;
  cursor:pointer;border:1px solid transparent;transition:.25s var(--ease);white-space:nowrap}
.btn--solid{background:var(--gold);color:#171512}
.btn--solid:hover{background:var(--gold-soft)}
.btn--ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn--ghost:hover{border-color:rgba(255,255,255,.4)}
.btn--text{color:var(--ink-soft);padding:13px 6px}
.btn--text:hover{color:var(--ink)}
.btn--full{width:100%}

/* ===== Nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:.3s var(--ease);
  backdrop-filter:blur(0);border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(12,12,14,.82);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:28px}
.nav__links{display:flex;gap:26px}
.nav__links a{font-size:.85rem;color:var(--ink-soft);transition:.2s;position:relative;white-space:nowrap;letter-spacing:.01em}
.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:.25s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:18px;flex:none}
.nav__sep{width:1px;height:18px;background:var(--line)}
.nav__cta{padding:9px 20px;font-size:.88rem}
.nav__login{font-size:.85rem;color:var(--ink-soft);transition:.2s;white-space:nowrap}
.nav__login:hover{color:var(--ink)}
.nav__login-menu{display:none}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:.3s var(--ease)}

/* socials */
.socials{display:flex;align-items:center;gap:10px}
.social{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:9px;color:var(--ink-soft);transition:.22s var(--ease)}
.social[hidden]{display:none}
.social svg{width:18px;height:18px}
.social:hover{color:var(--gold-soft);border-color:var(--gold);transform:translateY(-2px)}
.socials--footer{margin-top:16px}

/* language switch — quiet text style, no box */
.langswitch{display:inline-flex;align-items:center;gap:2px}
.langswitch button{background:none;border:0;color:var(--ink-mute);font-family:inherit;font-size:.78rem;
  font-weight:600;letter-spacing:.08em;padding:4px 5px;cursor:pointer;transition:color .2s}
.langswitch button:hover{color:var(--ink-soft)}
.langswitch button.active{color:var(--gold)}
.langswitch--menu{display:none}   /* shown only inside the mobile menu */

/* ===== Hero (contained video — Citadel-style) ===== */
.hero{position:relative;padding:118px 0 64px;background:var(--bg)}
.hero__media{position:relative;aspect-ratio:16/9;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#000}
.hero__video{position:absolute;inset:0}
.hero__video iframe,.hero__video video{width:100%;height:100%;border:0;display:block;object-fit:cover;background:#000;pointer-events:none}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.5) 32%,rgba(0,0,0,.12) 58%,rgba(0,0,0,.34) 100%)}
.hero__content{position:absolute;z-index:2;left:0;top:0;right:0;padding:clamp(26px,4vw,56px)}
.hero__band{position:absolute;z-index:2;left:0;right:0;bottom:0;
  border-top:1px solid rgba(255,255,255,.16);background:rgba(8,8,8,.6);backdrop-filter:blur(8px)}
.hero__band-inner{display:flex;align-items:center;justify-content:space-between;gap:22px 40px;flex-wrap:wrap;
  padding:22px clamp(26px,4vw,56px)}
.hero__toggle{position:absolute;z-index:3;top:18px;right:18px;width:42px;height:42px;display:inline-flex;
  align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.42);border-radius:50%;
  background:rgba(0,0,0,.3);color:#fff;cursor:pointer;transition:.2s var(--ease)}
.hero__toggle:hover{background:rgba(0,0,0,.55);border-color:#fff}
.hero__toggle svg{width:15px;height:15px}
.hero__toggle .ic-play{display:none}
.hero__toggle.is-paused .ic-pause{display:none}
.hero__toggle.is-paused .ic-play{display:block}

/* ===== Stats band (Citadel-style) ===== */
.statband{border-bottom:1px solid var(--line);background:var(--bg-soft)}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr)}
.statcol{padding:64px 34px;border-left:1px solid var(--line)}
.statband .statcol{text-align:left}   /* beat the old .proof__item centering */
.statcol:first-child{border-left:0;padding-left:0}
.statcol__fig{display:flex;align-items:baseline;gap:6px;margin-bottom:22px}
.statcol__fig .proof__num,.statcol__fig .statcol__static{font-family:var(--head);font-size:clamp(2.6rem,4.4vw,3.4rem);font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.statcol__fig .proof__suffix{font-family:var(--head);font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:700;color:var(--gold)}
.statcol__label{color:var(--ink);font-size:1rem;font-weight:600;letter-spacing:-.005em;margin-bottom:12px}
.statcol__desc{color:var(--ink-mute);font-size:.88rem;line-height:1.6;max-width:34ch}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__grid{position:absolute;inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 80%);opacity:.14}
.hero__glow{position:absolute;top:-12%;left:50%;transform:translateX(-50%);
  width:900px;height:560px;background:radial-gradient(ellipse at center,rgba(216,208,194,.08),transparent 62%);filter:blur(26px)}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;display:block;opacity:1}

/* social proof */
.proof{display:flex;align-items:center;justify-content:center;gap:46px;margin-top:56px;flex-wrap:wrap}
.proof__item{text-align:center}
.proof__figure{display:flex;align-items:baseline;justify-content:center;gap:2px}
.proof__num{font-family:var(--head);font-size:clamp(2.3rem,4.4vw,3.4rem);font-weight:700;letter-spacing:-1.6px;color:var(--ink)}
.proof__suffix{font-family:var(--head);font-size:clamp(1.4rem,2.6vw,2rem);font-weight:700;color:var(--gold)}
.proof__label{display:block;margin-top:6px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.proof__divider{width:1px;height:50px;background:var(--line)}
.hero__inner{position:relative;z-index:1;text-align:center;max-width:880px;margin:0 auto;padding-bottom:80px}
.hero__eyebrow{letter-spacing:.28em;text-transform:uppercase;font-size:.78rem;color:var(--gold);font-weight:600;margin-bottom:26px}
.hero__title{font-family:var(--head);font-weight:700;line-height:1.08;
  font-size:clamp(1.9rem,4vw,3.5rem);letter-spacing:-.022em;max-width:16ch;color:var(--ink);margin:0}
.hero__sub{font-size:1rem;line-height:1.65;color:var(--ink-soft);max-width:560px;margin:0}
.hero__actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap}

/* stats */
.stats{position:relative;z-index:1;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.015)}
.stats__inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:34px 20px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat__num{font-family:var(--head);font-size:2.4rem;font-weight:700;letter-spacing:-1px;color:var(--ink)}
.stat__plus{font-family:var(--head);font-size:1.6rem;font-weight:700;color:var(--gold)}
.stat__label{display:block;font-size:.82rem;color:var(--ink-mute);margin-top:6px;letter-spacing:.02em}

/* ===== Section base ===== */
.section{padding:110px 0;position:relative}
.section__head{max-width:640px;margin:0 auto 60px;text-align:center}
.section__kicker{display:inline-block;letter-spacing:.22em;text-transform:uppercase;font-size:.74rem;font-weight:600;color:var(--gold);margin-bottom:16px}
.section__title{font-family:var(--head);font-weight:700;font-size:clamp(1.9rem,3.4vw,2.6rem);line-height:1.14;letter-spacing:-.02em;margin-bottom:16px}
.section__lead{color:var(--ink-soft);font-size:1.02rem;line-height:1.7;max-width:58ch;margin-left:auto;margin-right:auto}

/* ===== Markets ===== */
.markets{background:var(--bg-soft)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:.3s var(--ease);position:relative;overflow:hidden}
.card:hover{transform:translateY(-4px);border-color:rgba(216,208,194,.45)}
.card__icon{width:46px;height:46px;color:var(--gold);margin-bottom:20px}
.card__icon svg{width:100%;height:100%}
.card h3{font-family:var(--head);font-size:1.12rem;font-weight:600;letter-spacing:-.01em;margin-bottom:10px}
.card p{font-size:.92rem;line-height:1.65;color:var(--ink-soft)}
.card--feature{background:linear-gradient(160deg,rgba(216,208,194,.09),var(--bg-card) 55%);border-color:rgba(216,208,194,.32)}
.card__tag{display:inline-block;margin-top:16px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);border:1px solid rgba(216,208,194,.45);border-radius:3px;padding:4px 12px}

/* ===== Approach ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{padding-top:24px;border-top:2px solid var(--line);transition:.3s var(--ease)}
.step:hover{border-top-color:var(--gold)}
.step__no{font-family:var(--head);font-size:1rem;color:var(--gold);font-weight:600}
.step h3{font-family:var(--head);font-size:1.12rem;font-weight:600;letter-spacing:-.01em;margin:14px 0 10px}
.step p{font-size:.92rem;line-height:1.65;color:var(--ink-soft)}

/* ===== Edge ===== */
.edge{background:var(--bg-soft)}
.edge__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.edge__copy p{color:var(--ink-soft);margin-bottom:18px;max-width:480px}
.edge__copy .section__title{margin-top:14px}
.edge__list{list-style:none;margin-top:26px;display:grid;gap:14px}
.edge__list li{position:relative;padding-left:28px;color:var(--ink);font-size:.96rem}
.edge__list li::before{content:"";position:absolute;left:0;top:9px;width:10px;height:10px;border-radius:50% 50% 50% 0;transform:rotate(45deg);background:var(--gold)}
.edge__visual{display:flex;justify-content:center}
.chart{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:relative}
.chart svg{width:100%;height:200px;display:block}
.chart__line{stroke-dasharray:900;stroke-dashoffset:900;animation:draw 2.4s var(--ease) forwards}
.chart.in .chart__line{stroke-dashoffset:0}
.chart__caption{margin-top:14px;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);text-align:center}
@keyframes draw{to{stroke-dashoffset:0}}

/* ===== Coverage ===== */
.coverage__panel{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;background:var(--bg-card);border:1px solid var(--line);border-radius:24px;padding:36px;align-items:center}
.coverage__map{position:relative;aspect-ratio:16/9;border-radius:var(--radius);
  background:
    radial-gradient(circle at 30% 40%,rgba(255,255,255,.05),transparent 42%),
    radial-gradient(circle at 75% 60%,rgba(216,208,194,.14),transparent 46%),
    var(--bg-soft);
  border:1px solid var(--line);overflow:hidden}
.coverage__map::before{content:"";position:absolute;inset:0;opacity:.4;
  background-image:radial-gradient(rgba(255,255,255,.12) 1px,transparent 1px);background-size:18px 18px}
.dot{position:absolute;width:9px;height:9px;background:var(--gold);border-radius:50%;box-shadow:0 0 12px rgba(216,208,194,.8);transform:translate(-50%,-50%)}
.dot--pulse::after{content:"";position:absolute;inset:-6px;border:2px solid var(--gold);border-radius:50%;animation:pulse 2s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.9}100%{transform:scale(2.4);opacity:0}}
.coverage__regions{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.region h4{font-family:var(--head);font-size:1.05rem;font-weight:600;margin-bottom:4px}
.region p{font-size:.86rem;color:var(--ink-soft)}

/* ===== About ===== */
.about{background:var(--bg-soft)}
.about__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.about__copy p{color:var(--ink-soft);margin-bottom:18px;max-width:520px}
.about__values{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.value{display:flex;gap:14px}
.value__dot{flex:none;width:12px;height:12px;margin-top:7px;border-radius:50% 50% 50% 0;transform:rotate(45deg);background:linear-gradient(135deg,var(--gold),var(--green-soft))}
.value h4{font-family:var(--head);font-size:1.08rem;font-weight:600;margin-bottom:4px}
.value p{font-size:.88rem;color:var(--ink-soft)}

/* ===== Contact ===== */
.contact__inner{max-width:860px;margin:0 auto}
.contact__head{text-align:center;margin-bottom:48px}
.contact__form{display:grid;grid-template-columns:1fr 1fr;gap:20px;background:var(--bg-card);border:1px solid var(--line);border-radius:24px;padding:38px}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1/-1}
.field label{font-size:.82rem;color:var(--ink-soft);letter-spacing:.02em}
.field input,.field select,.field textarea{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;
  padding:13px 15px;color:var(--ink);font-family:inherit;font-size:.95rem;transition:.2s;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(216,208,194,.14)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-mute)}
.form__note{color:var(--gold-soft);font-size:.9rem;margin-top:14px;text-align:center}
.form__note--err{color:#e08a7a}
.contact__details{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-top:30px;color:var(--ink-soft);font-size:.92rem}
.contact__details a:hover{color:var(--gold-soft)}

/* ===== Footer ===== */
.footer{border-top:1px solid var(--line);padding:60px 0 30px;background:var(--bg)}
.footer__inner{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid var(--line)}
.footer__brand p{color:var(--ink-mute);font-size:.9rem;margin-top:12px}
.footer__links{display:flex;gap:26px;flex-wrap:wrap;align-items:center}
.footer__links a{color:var(--ink-soft);font-size:.92rem}
.footer__links a:hover{color:var(--gold-soft)}
.footer__bottom{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-top:24px}
.footer__bottom p{font-size:.8rem;color:var(--ink-mute)}
.footer__disclaimer{max-width:560px;text-align:right}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(26px);transition:.8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ===== Firm / Commodities card numbers ===== */
.card__no{font-family:var(--head);font-weight:700;font-size:.95rem;color:var(--gold);margin-bottom:14px}
.card--muted{opacity:.6}
.cards--3{grid-template-columns:repeat(3,1fr)}

/* Firm — "Who we are" (Citadel-style intro) */
.whoweare{display:grid;grid-template-columns:200px 1fr;gap:48px;align-items:start;max-width:1000px;margin:0 auto 56px}
.whoweare__kicker{padding-top:10px}
.whoweare__body{border-left:1px solid var(--line);padding-left:48px}
.whoweare__statement{font-family:var(--head);font-weight:600;font-size:clamp(1.55rem,2.9vw,2.4rem);line-height:1.26;letter-spacing:-.016em;color:var(--ink)}
.whoweare__cta{margin-top:38px}

/* Firm video embed (16:9, responsive) */
.firm__media{max-width:900px;margin:54px auto 64px}
.firm__cap{display:block;text-align:center;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.firm__video{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#000;aspect-ratio:16/9}
.firm__video iframe{display:block;width:100%;height:100%;border:0}

/* ===== Media coverage tags ===== */
.tags__label{display:block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.tags{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:0 0 8px}
.tags li{font-size:.86rem;color:var(--ink);border:1px solid var(--line);border-radius:3px;padding:7px 14px;transition:.2s var(--ease)}
.tags li:hover{border-color:var(--gold);color:var(--gold-soft)}
.media__formats{margin-top:36px}

/* ===== Production House & Agency ===== */
.studio__services{grid-template-columns:repeat(3,1fr);margin-top:40px}

/* client logo marquee — seamless horizontal loop */
.work{margin-bottom:46px}
.work__kicker{display:block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.logowall{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0}
.logowall::before,.logowall::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.logowall::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.logowall::after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.logotrack{display:flex;width:max-content}
.logowall.is-marquee .logotrack{animation:logoscroll 30s linear infinite}
.logowall.is-marquee:hover .logotrack{animation-play-state:paused}
@keyframes logoscroll{to{transform:translateX(-25%)}}
@media (prefers-reduced-motion: reduce){.logowall.is-marquee .logotrack{animation:none}}
.logoset{display:flex;align-items:center;gap:110px;padding-right:110px}
.clogo{flex:none;display:flex;align-items:center;justify-content:center;min-height:84px;
  opacity:.72;transition:opacity .3s var(--ease)}
.clogo:hover{opacity:1}
/* logo files are pre-baked knockouts (dark set for light sections) — no CSS filter */
.clogo img{height:58px;width:auto;object-fit:contain}
.clogo--sq img{height:74px}     /* square mark (SPR) needs more height to feel equal */
.clogo--lock img{height:72px}   /* stacked lockup (Kartika) — keeps its small type legible */

/* ===== News (publication) band ===== */
.newsband{display:grid;grid-template-columns:1.4fr .9fr;gap:40px;align-items:center;
  border:1px solid var(--line);border-radius:var(--radius);padding:48px;background:rgba(255,255,255,.02)}
.newsband .section__kicker{margin-bottom:14px}
.newsband .section__title{margin-bottom:14px}
.newsband .section__lead{margin:0}
.newsband__right{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.news__url{font-size:1.15rem;color:var(--gold-soft);letter-spacing:.01em;transition:.2s var(--ease)}
.news__url:hover{color:var(--ink)}

/* ===== Research & Activities (home feed) ===== */
.rfeed{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.rfeed__empty{grid-column:1/-1;color:var(--ink-mute);font-size:.92rem;padding:30px 0}
.rfeed a.rfc{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;
  transition:.3s var(--ease);opacity:0;transform:translateY(20px)}
.rfeed a.rfc.in{opacity:1;transform:none}
.rfeed a.rfc:hover{transform:translateY(-5px);border-color:rgba(216,208,194,.45)}
.rfc__top{height:120px;background:linear-gradient(135deg,#15140f,#0c0c0c);position:relative;overflow:hidden}
.rfc__top::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 120% at 100% 0,rgba(216,208,194,.16),transparent 55%),
  repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 2px,transparent 2px 9px)}
.rfc__mono{position:absolute;left:18px;bottom:14px;font-family:var(--head);font-weight:700;font-size:1.4rem;color:rgba(231,225,214,.5);z-index:1}
.rfc__b{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.rfc__cat{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:9px}
.rfc__t{font-family:var(--head);font-size:1.05rem;font-weight:600;line-height:1.3;letter-spacing:-.01em;margin-bottom:8px;color:var(--ink)}
.rfc__d{font-size:.76rem;color:var(--ink-mute);margin-bottom:11px}
.rfc__s{font-size:.86rem;line-height:1.55;color:var(--ink-soft);margin-bottom:16px;flex:1}
.rfc__m{font-size:.82rem;font-weight:600;color:var(--gold-soft);transition:.2s var(--ease)}
.research__cta{margin-top:34px;text-align:center}
@media(max-width:820px){.rfeed{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rfeed{grid-template-columns:1fr}}

/* ============================================================
   Responsive — PC/laptop → tablet/iPad → phone (Android/iOS)
   ============================================================ */

/* Small laptops (1280×800 MacBook, scaled Windows) — tighten the bar */
@media(max-width:1240px){
  .nav__inner{gap:20px}
  .nav__links{gap:18px}
  .nav__links a{font-size:.82rem}
  .nav__right{gap:13px}
  .nav__cta{padding:8px 16px;font-size:.85rem}
  .nav__login{font-size:.82rem}
}

/* Tablet / iPad & below — collapse nav into a menu, 2-up grids */
@media(max-width:1024px){
  /* nav → slide-down menu (language switch moves inside it) */
  .nav__links,.nav__cta,.nav .socials,.nav__right .langswitch,.nav__login,.nav__sep{display:none}
  .nav__burger{display:flex}
  .nav__links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(12,12,14,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:10px 28px 22px}
  .nav__links.open a{padding:14px 0;border-bottom:1px solid var(--line)}
  .nav__links.open .nav__login-menu{display:block}
  .nav__links.open .langswitch--menu{display:inline-flex;align-self:flex-start;margin-top:18px}
  .nav__links.open .langswitch--menu button{padding:9px 18px;font-size:.85rem}

  .section{padding:88px 0}
  .hero{padding:104px 0 48px}

  /* two-up content grids */
  .cards,.cards--3,.steps,.studio__services{grid-template-columns:repeat(2,1fr)}
  .newsband{grid-template-columns:1fr;padding:34px}

  /* stats → 2 × 2 with rules */
  .statgrid{grid-template-columns:repeat(2,1fr)}
  .statcol{padding:48px 30px}
  .statcol:nth-child(odd){border-left:0;padding-left:0}
  .statcol:nth-child(n+3){border-top:1px solid var(--line)}

  /* logo marquee: tighter spacing on tablets */
  .logoset{gap:64px;padding-right:64px}

  /* who-we-are stays two-column but tighter */
  .whoweare{grid-template-columns:140px 1fr;gap:28px}
  .whoweare__body{padding-left:30px}
}

/* iPad portrait & phones (landscape) — hero stacks; who-we-are stacks */
@media(max-width:768px){
  .section{padding:76px 0}
  .hero{padding:96px 0 40px}
  /* hero: headline above, contained video (full, uncropped), text + CTAs below */
  .hero__media{aspect-ratio:auto;border:0;border-radius:0;overflow:visible;background:transparent;display:flex;flex-direction:column;gap:20px}
  .hero__video{position:relative;aspect-ratio:16/9;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;order:0}
  .hero__scrim{display:none}
  .hero__content{position:static;order:-1;padding:0}
  .hero__title{font-size:clamp(1.9rem,6vw,2.8rem);max-width:none}
  .hero__band{position:static;order:1;background:transparent;backdrop-filter:none;border-top:0}
  .hero__band-inner{padding:0;flex-direction:column;align-items:flex-start;gap:16px}
  .hero__toggle{top:12px;right:12px;width:38px;height:38px}
  .whoweare{grid-template-columns:1fr;gap:14px}
  .whoweare__body{border-left:0;padding-left:0}
}

/* Phones — single column everywhere */
@media(max-width:560px){
  .section{padding:64px 0}
  .cards,.cards--3,.steps,.studio__services,.contact__form{grid-template-columns:1fr}
  .statgrid{grid-template-columns:1fr}
  .statcol{padding:34px 0;border-left:0;border-top:1px solid var(--line)}
  .statcol:nth-child(odd){padding-left:0}
  .statcol:first-child{border-top:0;padding-top:2px}
  .logoset{gap:48px;padding-right:48px}
  .clogo img{height:42px}
  .clogo--sq img{height:54px}
  .clogo--lock img{height:52px}
  .logowall::before,.logowall::after{width:50px}
  .proof__divider{display:none}
  .footer__inner{gap:28px}
  .footer__bottom{flex-direction:column;gap:12px}
  .footer__disclaimer{text-align:left}
}

/* Small phones — tighten type & spacing */
@media(max-width:430px){
  .container{padding:0 20px}
  .section{padding:54px 0}
  .section__head{margin-bottom:40px}
  .hero__title{font-size:clamp(1.7rem,8.5vw,2.2rem)}
  .section__title{font-size:clamp(1.55rem,7.5vw,1.95rem)}
  .whoweare__statement{font-size:clamp(1.3rem,6.8vw,1.75rem)}
  .statcol__fig .proof__num,.statcol__fig .statcol__static{font-size:clamp(2.2rem,12vw,2.9rem)}
  .proof__suffix{font-size:1.4rem}
  .btn{padding:12px 22px;font-size:.9rem}
  .tags li{font-size:.8rem;padding:6px 11px}
  .brand__text{font-size:1.25rem}
}

/* ===== Cursor-adaptive FX ===== */
@media (pointer:fine){
  body.has-cursor-fx, body.has-cursor-fx a, body.has-cursor-fx button,
  body.has-cursor-fx .card, body.has-cursor-fx label{cursor:none}
  body.has-cursor-fx input, body.has-cursor-fx textarea, body.has-cursor-fx select{cursor:auto}
}
.cursor-dot,.cursor-ring,.cursor-pulse{mix-blend-mode:difference}  /* stays visible on light sections */
.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;background:#E7E1D6;
  border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);
  transition:opacity .2s,width .2s var(--ease),height .2s var(--ease);will-change:transform}
.cursor-ring{position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid rgba(231,225,214,.5);
  border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);
  transition:width .28s var(--ease),height .28s var(--ease),border-color .28s,background-color .28s,opacity .2s;will-change:transform}
.cursor-ring.is-hover{width:58px;height:58px;border-color:var(--gold);background:rgba(216,208,194,.07)}
.cursor-dot.is-hover{width:4px;height:4px}
.cursor-ring.is-down{width:26px;height:26px;border-color:var(--gold-soft)}
.cursor-dot.is-hidden,.cursor-ring.is-hidden{opacity:0}
.cursor-pulse{position:fixed;top:0;left:0;width:10px;height:10px;border:1px solid var(--gold);
  border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);
  animation:cursorPulse .55s var(--ease) forwards}
@keyframes cursorPulse{from{opacity:.8;scale:1}to{opacity:0;scale:6}}

/* hero spotlight that follows the cursor */
.hero__spot{position:absolute;top:0;left:0;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(216,208,194,.13),transparent 60%);
  filter:blur(36px);pointer-events:none;mix-blend-mode:screen;opacity:0;
  transition:opacity .4s var(--ease);will-change:transform}

/* hero content eases with the pointer (parallax) */
.hero__inner{will-change:transform}

/* pointer-tracked glow on cards / panels */
.card,.step,.newsband{position:relative}
.card::after,.step::after,.newsband::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;
  transition:opacity .35s var(--ease);
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(216,208,194,.09),transparent 62%)}
.card:hover::after,.step:hover::after,.newsband:hover::after{opacity:1}

/* Floating WhatsApp button (number set in admin) */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;box-shadow:0 8px 24px rgba(0,0,0,.28);
  transition:transform .2s ease, box-shadow .2s ease}
.wa-float:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 12px 30px rgba(0,0,0,.34)}
.wa-float[hidden]{display:none}
@media(max-width:520px){.wa-float{right:16px;bottom:16px;width:52px;height:52px}}
@media(prefers-reduced-motion:reduce){.wa-float{transition:none}}

/* print: a clean printed page (hide the intro overlay, nav and floating button) */
@media print{
  #intro,.nav,.wa-float,.hero__toggle{display:none!important}
  body{background:#fff;color:#000}
  .container{max-width:100%}
}
