/* Human Design with Alvaro Abreu — shared styles (dark default + light theme) */
:root{
  --ink:#100E18;
  --ink-2:#14121C;
  --ink-3:#1C1928;
  --parchment:#F4EDE1;
  --parchment-2:#EAE0CE;
  --gold:#C9A05C;
  --gold-2:#D8BA85;
  --gold-dim:rgba(201,160,92,.22);
  --mist:#8A8496;
  --mist-2:#B9B3C4;
  --ember:#C25A2E;
  --ember-2:#A0451F;
  --white:#FBF8F2;
  --nav-bg:rgba(16,14,24,.86);
  --hero-glow:#241E38;
  --band:#1A1526;
  --card-tint:rgba(30,27,42,.4);
  --legal:#565064;
  --alt-tx:#57503F;
  --alt-tx-2:#5D5749;
  --alt-lead:#2E2A1F;
  --fd:"Fraunces",Georgia,serif;
  --fb:"Outfit",system-ui,sans-serif;
}
html[data-theme="light"]{
  --ink:#F6F0E4;
  --ink-2:#EFE7D6;
  --ink-3:#FFFDF7;
  --parchment:#211C30;
  --parchment-2:#E6DBC4;
  --gold:#A67F3E;
  --gold-2:#8F6C31;
  --gold-dim:rgba(166,127,62,.32);
  --mist:#7C7466;
  --mist-2:#5A5346;
  --white:#14121C;
  --nav-bg:rgba(246,240,228,.9);
  --hero-glow:#ECE2CC;
  --band:#EFE6D2;
  --card-tint:rgba(255,253,247,.65);
  --legal:#8B8374;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--fb);font-weight:300;font-size:17px;line-height:1.65;
  color:var(--parchment);background:var(--ink);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  transition:background .4s,color .4s;
}
h1,h2,h3{font-family:var(--fd);font-weight:400;line-height:1.1}
a{color:inherit}
button{font-family:var(--fb)}
img,svg,canvas{display:block}
::selection{background:var(--gold);color:var(--ink)}

/* ---------- Progress bar ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:90;
  background:linear-gradient(90deg,var(--gold),var(--ember));transition:width .1s linear}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,4vw,60px);
  background:transparent;transition:background .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(14px);
  border-bottom-color:var(--gold-dim);padding:11px clamp(20px,4vw,60px)}
.nav__logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--white)}
.nav__logo svg{height:36px;width:auto;transition:transform .4s}
.nav__logo:hover svg{transform:rotate(6deg)}
.nav__wordmark{display:flex;flex-direction:column;line-height:1}
.nav__wordmark .name{font-family:var(--fd);font-size:15px;letter-spacing:.2em;text-transform:uppercase}
.nav__wordmark .tag{font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-top:4px}
.nav__links{display:flex;gap:clamp(12px,2vw,28px);align-items:center;list-style:none}
.nav__links a{color:var(--mist-2);text-decoration:none;font-size:12.5px;letter-spacing:.14em;
  text-transform:uppercase;font-weight:400;position:relative;padding:4px 0;transition:color .25s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--gold);transition:width .3s cubic-bezier(.4,0,.2,1)}
.nav__links a:hover{color:var(--white)}
.nav__links a:hover::after{width:100%}
.nav__cta{background:var(--gold);color:var(--ink)!important;padding:11px 24px!important;
  border-radius:99px;font-weight:500!important}
.nav__cta::after{display:none}
.nav__cta:hover{background:var(--gold-2)}
.nav__burger{display:none;background:none;border:0;cursor:pointer;padding:6px;z-index:85}
.nav__burger span{display:block;width:24px;height:2px;background:var(--white);margin:5px 0;transition:.3s}

/* Language switcher + theme toggle */
.nav__tools{display:flex;align-items:center;gap:14px}
.lang{display:flex;align-items:center;gap:2px;border:1px solid var(--gold-dim);border-radius:99px;padding:3px}
.lang a{text-decoration:none;font-size:11px;letter-spacing:.12em;font-weight:500;
  color:var(--mist-2);padding:6px 10px;border-radius:99px;transition:color .25s,background .25s}
.lang a:hover{color:var(--white)}
.lang a.on{background:var(--gold);color:var(--ink)}
.theme-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--gold-dim);
  background:transparent;color:var(--gold);cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:border-color .25s,transform .25s,background .25s}
.theme-btn:hover{border-color:var(--gold);transform:rotate(15deg)}
.theme-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8}
html:not([data-theme="light"]) .theme-btn .icon-moon{display:none}
html[data-theme="light"] .theme-btn .icon-sun{display:none}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  padding:120px clamp(20px,4vw,60px) 80px;overflow:hidden;
  background:radial-gradient(1200px 700px at 75% -10%,var(--hero-glow) 0%,var(--ink) 55%)}
#stars{position:absolute;inset:0;pointer-events:none}
html[data-theme="light"] #stars{display:none}
.hero__aurora{position:absolute;width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,160,92,.16) 0%,rgba(194,90,46,.07) 40%,transparent 70%);
  top:-350px;right:-200px;pointer-events:none;animation:aurora 14s ease-in-out infinite alternate}
@keyframes aurora{from{transform:translate(0,0) scale(1)}to{transform:translate(-90px,70px) scale(1.15)}}
.hero__inner{max-width:1280px;margin:0 auto;position:relative;width:100%;
  display:grid;grid-template-columns:7fr 5fr;gap:clamp(36px,5vw,90px);align-items:center}
.hero__eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12px;
  letter-spacing:.36em;text-transform:uppercase;color:var(--gold);margin-bottom:34px}
.hero__eyebrow::before{content:"";width:42px;height:1px;background:var(--gold)}
.hero__eyebrow .pulse{width:7px;height:7px;border-radius:50%;background:var(--gold);
  animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(201,160,92,.5)}50%{box-shadow:0 0 0 9px rgba(201,160,92,0)}}
.hero h1{font-size:clamp(44px,5.8vw,84px);font-weight:340;letter-spacing:-.015em;
  margin-bottom:24px;color:var(--white)}
.hero h1 em{font-style:italic;font-weight:340;
  background:linear-gradient(100deg,var(--gold) 20%,var(--gold-2) 50%,var(--ember) 90%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero__sub{font-size:clamp(17px,1.5vw,20px);color:var(--mist-2);max-width:33em;margin-bottom:40px}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero__stats{display:flex;gap:clamp(20px,3vw,48px);margin-top:56px;flex-wrap:wrap}
.hstat{border-left:1px solid var(--gold-dim);padding-left:16px}
.hstat b{display:block;font-family:var(--fd);font-weight:400;font-size:clamp(22px,2vw,30px);color:var(--gold-2)}
.hstat span{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mist)}

/* chart card — stays paper in both themes */
.chart-card{position:relative;border-radius:6px 6px 34px 6px;padding:clamp(22px,2.2vw,32px);
  background:linear-gradient(165deg,#FBF8F2 0%,#F4EDE1 100%);color:#14121C;
  box-shadow:0 40px 100px -24px rgba(0,0,0,.7),0 0 0 1px rgba(201,160,92,.25);
  transform:perspective(1200px) rotateY(0deg);transition:transform .5s ease}
html[data-theme="light"] .chart-card{box-shadow:0 30px 70px -24px rgba(70,55,20,.35),0 0 0 1px rgba(166,127,62,.3)}
.chart-card:hover{transform:perspective(1200px) rotateY(-2deg) translateY(-4px)}
.chart-card::before{content:"";position:absolute;top:-12px;left:28px;right:28px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.chart-card__badge{position:absolute;top:-14px;right:26px;background:var(--ember);color:#FBF8F2;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  padding:6px 14px;border-radius:99px}
.chart-card__title{font-family:var(--fd);font-size:23px;margin-bottom:6px}
.chart-card__sub{font-size:13.5px;color:#6d6759;margin-bottom:18px}
.chart-card bodygraph-embed{display:block;min-height:400px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-weight:500;
  font-size:13.5px;letter-spacing:.14em;text-transform:uppercase;padding:17px 34px;
  border-radius:99px;cursor:pointer;border:0;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .25s}
.btn:hover svg{transform:translateX(4px)}
.btn--gold{background:var(--gold);color:var(--ink)}
.btn--gold:hover{background:var(--gold-2);transform:translateY(-2px);
  box-shadow:0 14px 34px -10px rgba(201,160,92,.5)}
.btn--ember{background:var(--ember);color:#FBF8F2}
.btn--ember:hover{background:var(--ember-2);transform:translateY(-2px);
  box-shadow:0 14px 34px -10px rgba(194,90,46,.55)}
.btn--ghost{border:1px solid var(--gold-dim);color:var(--gold-2);background:transparent}
.btn--ghost:hover{border-color:var(--gold);background:rgba(201,160,92,.08)}

/* ---------- Marquee ---------- */
.marquee{background:var(--gold);color:var(--ink);overflow:hidden;padding:13px 0;
  transform:rotate(-.6deg) scale(1.02);position:relative;z-index:5}
.marquee__track{display:flex;gap:0;white-space:nowrap;animation:marquee 30s linear infinite;width:max-content}
.marquee span{font-family:var(--fd);font-style:italic;font-size:15px;letter-spacing:.12em;
  text-transform:uppercase;padding:0 22px;position:relative}
.marquee span::after{content:"✦";position:absolute;right:-8px;font-style:normal;opacity:.6}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Section scaffolding ---------- */
.section{padding:clamp(90px,10vw,150px) clamp(20px,4vw,60px);position:relative}
.section__inner{max-width:1280px;margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.eyebrow::before{content:"";width:40px;height:1px;background:var(--gold)}
.h2{font-size:clamp(34px,3.8vw,58px);font-weight:340;color:var(--white)}
.h2 em{font-style:italic;color:var(--gold-2)}

/* ---------- What (parchment section — light in both themes) ---------- */
.what{background:var(--parchment-2);color:#14121C;
  border-radius:clamp(24px,4vw,56px) clamp(24px,4vw,56px) 0 0;margin-top:-20px}
.what .h2{color:#14121C}
.what .h2 em{color:var(--ember)}
.what .eyebrow{color:var(--ember)}
.what .eyebrow::before{background:var(--ember)}
.what__grid{display:grid;grid-template-columns:5fr 7fr;gap:clamp(32px,5vw,100px)}
.what__lead{font-size:clamp(18px,1.6vw,22px);line-height:1.55;margin-bottom:26px;color:var(--alt-lead)}
.what__body{color:var(--alt-tx)}
.what__pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(48px,5vw,80px)}
.pillar{background:#FBF8F2;border:1px solid rgba(20,18,28,.09);border-radius:4px 4px 22px 4px;
  padding:36px 26px;position:relative;overflow:hidden;
  transition:transform .35s,box-shadow .35s}
.pillar::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--ember));transform:scaleX(0);
  transform-origin:left;transition:transform .45s}
.pillar:hover{transform:translateY(-8px);box-shadow:0 26px 50px -20px rgba(20,18,28,.25)}
.pillar:hover::before{transform:scaleX(1)}
.pillar__num{font-family:var(--fd);font-style:italic;font-size:15px;color:#A67F3E;margin-bottom:16px}
.pillar h3{font-size:22px;margin-bottom:10px;color:#14121C}
.pillar p{font-size:14.5px;color:var(--alt-tx-2)}

/* ---------- Explorer ---------- */
.explorer{background:var(--ink-2)}
.explorer__grid{display:grid;grid-template-columns:6fr 6fr;gap:clamp(32px,5vw,90px);align-items:center;
  margin-top:clamp(40px,4vw,64px)}
.bodygraph{position:relative;max-width:430px;margin:0 auto;width:100%}
.bodygraph svg{width:100%;height:auto}
.bg-center{cursor:pointer;transition:filter .3s}
.bg-center .shape{fill:rgba(201,160,92,.07);stroke:var(--gold);stroke-width:1.6;
  transition:fill .3s,stroke .3s,filter .3s}
.bg-center:hover .shape{fill:rgba(201,160,92,.28)}
.bg-center.active .shape{fill:var(--gold);stroke:var(--gold-2);
  filter:drop-shadow(0 0 14px rgba(201,160,92,.65))}
.bg-channel{stroke:var(--gold-dim);stroke-width:1.2;fill:none}
.bg-label{font-family:var(--fb);font-size:8.5px;letter-spacing:.14em;fill:var(--mist);
  text-transform:uppercase;pointer-events:none}
.explorer__panel{background:var(--ink-3);border:1px solid var(--gold-dim);
  border-radius:4px 26px 4px 4px;padding:clamp(28px,3vw,44px);min-height:340px;position:relative}
.explorer__panel::after{content:"";position:absolute;inset:9px;border:1px solid rgba(201,160,92,.12);
  border-radius:2px 20px 2px 2px;pointer-events:none}
.explorer__count{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--mist);margin-bottom:14px}
.explorer__name{font-family:var(--fd);font-size:clamp(26px,2.4vw,36px);color:var(--gold-2);margin-bottom:4px}
.explorer__theme{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--ember);margin-bottom:20px}
.explorer__desc{color:var(--mist-2);font-size:15.5px;margin-bottom:22px}
.explorer__states{display:grid;gap:12px}
.exp-state{border-left:2px solid var(--gold-dim);padding-left:14px}
.exp-state b{display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:2px}
.exp-state span{font-size:14px;color:var(--mist-2)}
.explorer__hint{margin-top:22px;font-size:12.5px;color:var(--mist);display:flex;align-items:center;gap:8px}
.explorer__hint svg{width:14px;height:14px;stroke:var(--gold);fill:none;stroke-width:2;flex-shrink:0}

/* ---------- Types (tabs) ---------- */
.types{background:var(--ink)}
.types__tabs{display:flex;gap:8px;flex-wrap:wrap;margin:clamp(36px,4vw,56px) 0 34px}
.ttab{background:transparent;border:1px solid var(--gold-dim);color:var(--mist-2);
  padding:12px 22px;border-radius:99px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;transition:all .3s;font-weight:400}
.ttab:hover{border-color:var(--gold);color:var(--white)}
.ttab.active{background:var(--gold);border-color:var(--gold);color:var(--ink);font-weight:500}
.tpanel{display:none;background:var(--ink-3);border:1px solid var(--gold-dim);
  border-radius:4px 4px 30px 4px;padding:clamp(28px,3.4vw,52px);
  grid-template-columns:7fr 5fr;gap:clamp(28px,4vw,70px);align-items:center}
.tpanel.active{display:grid;animation:fadeUp .5s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.tpanel__role{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--ember);margin-bottom:10px}
.tpanel__name{font-family:var(--fd);font-size:clamp(30px,3vw,46px);color:var(--white);margin-bottom:16px}
.tpanel__desc{color:var(--mist-2);font-size:16px;margin-bottom:28px;max-width:36em}
.tpanel__facts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tfact{background:rgba(201,160,92,.05);border:1px solid var(--gold-dim);border-radius:3px;padding:16px 14px}
.tfact b{display:block;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  font-weight:500;margin-bottom:5px}
.tfact span{font-family:var(--fd);font-size:16.5px;color:var(--parchment)}
.tpanel__viz{text-align:center}
.tpanel__pct{font-family:var(--fd);font-size:clamp(56px,6vw,92px);font-weight:340;color:var(--gold-2);line-height:1}
.tpanel__pct small{font-size:.38em;color:var(--mist)}
.tpanel__bar{height:5px;background:rgba(201,160,92,.14);border-radius:99px;margin:20px auto 10px;max-width:260px;overflow:hidden}
.tpanel__bar i{display:block;height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--gold),var(--ember));transition:width 1s cubic-bezier(.3,.9,.3,1)}
.tpanel__of{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--mist)}

/* ---------- Steps (parchment section) ---------- */
.steps{background:var(--parchment-2);color:#14121C;border-radius:clamp(24px,4vw,56px)}
.steps .h2{color:#14121C}
.steps .h2 em{color:var(--ember)}
.steps .eyebrow{color:var(--ember)}.steps .eyebrow::before{background:var(--ember)}
.steps__row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px);
  margin-top:clamp(44px,5vw,72px);counter-reset:step}
.step{position:relative;padding-top:26px}
.step::before{counter-increment:step;content:"0" counter(step);
  font-family:var(--fd);font-style:italic;font-size:clamp(58px,6vw,86px);font-weight:340;
  color:transparent;-webkit-text-stroke:1px rgba(20,18,28,.28);
  position:absolute;top:-24px;left:-4px;line-height:1;z-index:0}
.step h3{font-size:22px;margin-bottom:10px;position:relative;z-index:1}
.step p{font-size:15px;color:var(--alt-tx);position:relative;z-index:1}
.step__arrow{margin-top:18px}
.step__arrow a{font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ember);
  text-decoration:none;border-bottom:1px solid transparent;transition:border-color .25s}
.step__arrow a:hover{border-color:var(--ember)}

/* ---------- Reading ---------- */
.reading{background:var(--ink-2)}
.reading__grid{display:grid;grid-template-columns:6fr 6fr;gap:clamp(32px,5vw,90px);align-items:center}
.reading__lead{font-size:18px;color:var(--mist-2);margin:22px 0 34px;max-width:34em}
.reading__list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:13px 26px;margin-bottom:38px}
.reading__list li{font-size:15px;display:flex;gap:10px;align-items:baseline;color:var(--parchment)}
.reading__list li::before{content:"—";color:var(--gold);flex-shrink:0}
.reading__note{font-size:12.5px;color:var(--mist);margin-top:18px}
/* report mock — stays paper in both themes */
.report-mock{position:relative;height:430px;perspective:1400px}
.rpage{position:absolute;inset:0;margin:auto;width:min(300px,80%);height:400px;border-radius:4px;
  background:linear-gradient(170deg,#FBF8F2,#EAE0CE);
  box-shadow:0 30px 70px -18px rgba(0,0,0,.65);padding:30px 26px;color:#14121C;
  transition:transform .6s cubic-bezier(.3,.9,.3,1)}
html[data-theme="light"] .rpage{box-shadow:0 26px 60px -18px rgba(70,55,20,.4)}
.rpage--b{transform:rotate(-7deg) translateX(-42px);opacity:.55}
.rpage--c{transform:rotate(6deg) translateX(46px);opacity:.35}
.report-mock:hover .rpage--a{transform:translateY(-12px)}
.report-mock:hover .rpage--b{transform:rotate(-10deg) translateX(-58px)}
.report-mock:hover .rpage--c{transform:rotate(9deg) translateX(62px)}
.rpage__brand{font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:#A67F3E;margin-bottom:20px}
.rpage__title{font-family:var(--fd);font-size:21px;margin-bottom:6px}
.rpage__sub{font-size:11.5px;color:#6d6759;margin-bottom:22px}
.rline{height:7px;border-radius:99px;background:rgba(20,18,28,.09);margin-bottom:10px}
.rline--gold{background:rgba(201,160,92,.4);width:62%}
.rline--s{width:84%}.rline--m{width:70%}.rline--l{width:92%}
.rpage__chart{margin:22px auto 0;width:110px;opacity:.85}

/* ---------- About ---------- */
.about{background:var(--ink)}
.about__grid{display:grid;grid-template-columns:4fr 7fr;gap:clamp(32px,6vw,110px);align-items:center}
.about__portrait{aspect-ratio:4/5;border-radius:4px 40px 4px 4px;position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--ink-3),var(--ink-2));border:1px solid var(--gold-dim);
  display:flex;align-items:center;justify-content:center}
.about__portrait svg{width:46%;opacity:.9}
.about__portrait-label{position:absolute;bottom:20px;left:0;right:0;text-align:center;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--mist)}
.about p{color:var(--mist-2);margin-bottom:20px;max-width:40em}
.about__sig{font-family:var(--fd);font-style:italic;font-size:22px;color:var(--gold-2);margin-top:8px}

/* ---------- FAQ ---------- */
.faq{background:var(--ink-2)}
.faq__grid{display:grid;grid-template-columns:5fr 7fr;gap:clamp(32px,5vw,90px)}
.faq__item{border-bottom:1px solid rgba(201,160,92,.16)}
.faq__item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;
  align-items:center;gap:20px;padding:24px 0;font-family:var(--fd);font-size:19px;
  color:var(--parchment);transition:color .25s}
.faq__item summary:hover{color:var(--gold-2)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--fb);font-weight:300;font-size:26px;
  color:var(--gold);transition:transform .3s;flex-shrink:0}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{padding:0 0 24px;color:var(--mist-2);font-size:15.5px;max-width:36em}

/* ---------- CTA band ---------- */
.ctaband{background:linear-gradient(120deg,var(--band) 0%,var(--ink) 60%);position:relative;overflow:hidden}
.ctaband::before{content:"";position:absolute;width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,160,92,.14),transparent 65%);
  top:-260px;left:-160px}
.ctaband__inner{max-width:860px;margin:0 auto;text-align:center;position:relative}
.ctaband .h2{margin-bottom:18px}
.ctaband p{color:var(--mist-2);margin-bottom:36px}

/* ---------- Newsletter ---------- */
.news{background:var(--ink-2);border-top:1px solid rgba(201,160,92,.12)}
.news__inner{max-width:720px;margin:0 auto;text-align:center}
.news p{color:var(--mist-2);margin:14px 0 34px}
.news__form{display:flex;gap:10px;max-width:480px;margin:0 auto}
.news__form input{flex:1;background:rgba(127,116,90,.08);border:1px solid var(--gold-dim);
  color:var(--white);padding:16px 20px;font-family:var(--fb);font-size:15px;
  border-radius:99px;outline:none;transition:border-color .25s}
.news__form input::placeholder{color:var(--mist)}
.news__form input:focus{border-color:var(--gold)}
.news__form button{background:var(--gold);border:0;color:var(--ink);font-weight:500;font-size:13px;
  letter-spacing:.12em;text-transform:uppercase;padding:0 28px;border-radius:99px;cursor:pointer;
  transition:background .25s}
.news__form button:hover{background:var(--gold-2)}
.news__hint{font-size:12px;color:var(--mist);margin-top:16px}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:var(--mist);padding:64px clamp(20px,4vw,60px) 40px;
  border-top:1px solid rgba(201,160,92,.12)}
.footer__inner{max-width:1280px;margin:0 auto}
.footer__top{display:flex;justify-content:space-between;align-items:flex-start;gap:36px;
  flex-wrap:wrap;margin-bottom:36px}
.footer__brand{display:flex;align-items:center;gap:12px;color:var(--white)}
.footer__brand svg{height:32px;width:auto}
.footer__brand .name{font-family:var(--fd);font-size:13px;letter-spacing:.22em;text-transform:uppercase}
.footer__nav{display:flex;gap:26px;list-style:none;flex-wrap:wrap}
.footer__nav a{color:var(--mist);text-decoration:none;font-size:13px;letter-spacing:.08em;transition:color .25s}
.footer__nav a:hover{color:var(--gold)}
.footer__legal{font-size:11.5px;line-height:1.7;color:var(--legal);max-width:64em}

/* ---------- Floating CTA / top ---------- */
.fab{position:fixed;bottom:26px;right:26px;z-index:70;display:flex;gap:10px;align-items:center;
  opacity:0;transform:translateY(18px);pointer-events:none;transition:opacity .4s,transform .4s}
.fab.show{opacity:1;transform:none;pointer-events:auto}
.fab__cta{display:flex;align-items:center;gap:10px;background:var(--ember);color:#FBF8F2;
  text-decoration:none;font-size:12.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:14px 24px;border-radius:99px;box-shadow:0 16px 40px -10px rgba(194,90,46,.6);
  transition:transform .25s,background .25s}
.fab__cta:hover{transform:translateY(-3px);background:var(--ember-2)}
.fab__cta .dot{width:7px;height:7px;border-radius:50%;background:#FBF8F2;
  animation:pulse 2.4s ease-in-out infinite}
.fab__top{width:44px;height:44px;border-radius:50%;border:1px solid var(--gold-dim);
  background:var(--nav-bg);backdrop-filter:blur(8px);color:var(--gold);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:border-color .25s,transform .25s}
.fab__top:hover{border-color:var(--gold);transform:translateY(-3px)}
.fab__top svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"]{transition-delay:.36s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  .marquee__track{animation:none}
  .hero__aurora{animation:none}
  #stars{display:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1020px){
  .hero__inner,.what__grid,.explorer__grid,.reading__grid,.about__grid,.faq__grid{grid-template-columns:1fr}
  .tpanel{grid-template-columns:1fr}
  .tpanel__viz{text-align:left}
  .tpanel__bar{margin-left:0}
  .what__pillars,.steps__row{grid-template-columns:1fr;gap:26px}
  .tpanel__facts{grid-template-columns:1fr 1fr}
  .hero{min-height:auto;padding-top:110px}
  .about__portrait{max-width:340px}
  .report-mock{height:460px;margin-top:10px}
  .nav__tools{margin-left:auto;margin-right:14px}
  .lang a{padding:5px 8px}
  .nav__links{position:fixed;inset:0 0 auto 0;padding:86px clamp(20px,4vw,60px) 34px;
    flex-direction:column;align-items:flex-start;gap:0;background:var(--nav-bg);
    backdrop-filter:blur(16px);border-bottom:1px solid var(--gold-dim);
    transform:translateY(-115%);transition:transform .4s ease;z-index:82}
  .nav__links.open{transform:none}
  .nav__links li{width:100%;padding:13px 0;border-bottom:1px solid rgba(201,160,92,.08)}
  .nav__burger{display:block;position:relative;z-index:84}
  .nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__burger.open span:nth-child(2){opacity:0}
  .nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .news__form{flex-direction:column}
  .news__form button{padding:16px}
  .fab__cta span.txt{display:none}
  .fab__cta{padding:14px 16px}
}
@media (max-width:560px){
  .nav__wordmark{display:none}
  .lang{padding:2px}
  .lang a{padding:4px 7px;font-size:10px}
}
