/* ============================================================
   TORRES MOLINA CAPITAL — Stylesheet
   Fortaleza para el capital digital.
   Paleta: medianoche + piedra fría + champán/oro (luz de antorcha).
   Tipografía: Cinzel (lapidaria) · Fraunces (editorial) · Inter (texto).
   ============================================================ */

:root{
  --bg:#070A12;
  --bg-2:#0B0F1B;
  --panel:#0F1424;
  --line:rgba(255,255,255,0.08);
  --line-strong:rgba(255,255,255,0.16);
  --ink:#EAECF1;
  --ink-soft:#9AA3B5;
  --ink-faint:#5E6779;
  --gold:#C9A35B;
  --gold-bright:#E2C485;
  --gold-deep:#8C6E37;
  --stone-1:#222a3a;
  --stone-2:#1a212f;
  --stone-3:#141a26;
  --mortar:#0a0e16;
  --radius:2px;
  --ease:cubic-bezier(0.22,0.61,0.36,1);
  --maxw:1240px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:#0B0F1B}
a{color:inherit;text-decoration:none}
img,svg,canvas{display:block;max-width:100%}

/* ---------- Loader ---------- */
.loader{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  transition:opacity .8s var(--ease),visibility .8s var(--ease);
}
.loader.is-done{opacity:0;visibility:hidden}
.loader__mark{
  font-family:'Cinzel',serif;font-weight:500;font-size:42px;letter-spacing:.24em;
  color:var(--gold);padding-left:.24em;
}
.loader__bar{width:160px;height:1px;background:var(--line);overflow:hidden}
.loader__bar span{display:block;height:100%;width:0;background:var(--gold);animation:load 1.4s var(--ease) forwards}
@keyframes load{to{width:100%}}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:background .4s var(--ease),border-color .4s var(--ease);border-bottom:1px solid transparent}
.nav.is-stuck{background:rgba(7,10,18,0.72);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:22px 32px;display:flex;align-items:center;justify-content:space-between}
.nav__brand{display:flex;align-items:baseline;gap:9px}
.nav__mark{font-family:'Cinzel',serif;font-weight:600;font-size:20px;letter-spacing:.14em;color:var(--ink)}
.nav__word{font-size:10px;letter-spacing:.2em;color:var(--gold);font-weight:500;white-space:nowrap}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{font-size:13px;letter-spacing:.04em;color:var(--ink-soft);transition:color .3s}
.nav__links a:hover{color:var(--ink)}
.nav__cta{border:1px solid var(--line-strong);padding:9px 20px;border-radius:var(--radius);color:var(--ink)!important;transition:border-color .3s,background .3s!important}
.nav__cta:hover{border-color:var(--gold);background:rgba(201,163,91,0.08)}
.nav__burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:6px;padding:6px}
.nav__burger span{width:24px;height:1.5px;background:var(--ink);transition:.3s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 32px 80px;overflow:hidden}
.hero__tower{position:absolute;top:0;right:0;height:100%;width:58%;z-index:1;pointer-events:none}
.hero__grain{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.6;
  background:radial-gradient(120% 90% at 78% 0%,rgba(201,163,91,0.10),transparent 60%),
             radial-gradient(100% 80% at 100% 100%,rgba(20,30,60,0.5),transparent 70%)}
.hero__content{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%}
.hero__eyebrow{font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.hero__ref{font-size:11px;letter-spacing:.22em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:30px}
.hero__title{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(44px,7vw,94px);line-height:1.02;letter-spacing:-0.02em;margin-bottom:32px}
.hero__title span{display:block}
.hero__title span:last-child{color:var(--gold);font-style:italic;font-weight:400}
.hero__lead{max-width:560px;font-size:clamp(16px,1.6vw,19px);color:var(--ink-soft);line-height:1.7;margin-bottom:42px}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:12px;font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--ink-faint)}
.hero__scroll-line{width:1px;height:54px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold-bright);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(280%)}}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:15px 30px;font-size:13px;letter-spacing:.08em;border-radius:var(--radius);transition:all .35s var(--ease);font-weight:400;cursor:pointer;border:0;font-family:inherit}
.btn--gold{background:var(--gold);color:#0A0D16;font-weight:500}
.btn--gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 14px 40px -12px rgba(201,163,91,0.55)}
.btn--ghost{border:1px solid var(--line-strong);color:var(--ink);background:transparent}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-bright)}
.btn--lg{padding:18px 40px;font-size:15px;letter-spacing:.05em}

/* ============================================================
   GATE — portones de piedra que se abren al hacer scroll
   ============================================================ */
.gate{position:relative;height:260vh}
.gate__sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg)}

/* contenido revelado tras las puertas */
.gate__reveal{
  position:relative;z-index:1;max-width:980px;width:100%;padding:0 32px;text-align:center;
  opacity:0;transform:scale(.94);transition:opacity .6s var(--ease),transform .6s var(--ease);
}
.gate__reveal.is-open{opacity:1;transform:none}
.gate__kicker{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.gate__title{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(30px,4.4vw,52px);letter-spacing:-0.02em;margin-bottom:42px}

.dash{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:30px}
.dash__cell{padding:26px 22px;text-align:left;border-left:1px solid var(--line);border-top:1px solid var(--line)}
.dash__cell:nth-child(-n+3){border-top:0}
.dash__cell:nth-child(3n+1){border-left:0}
.dash__k{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px}
.dash__v{display:block;font-family:'Fraunces',serif;font-size:22px;color:var(--gold-bright);line-height:1.1}
.dash__v--muted{color:var(--ink-soft);font-style:italic;font-size:18px}

.dash__chart{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.dash__chart-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:18px;font-size:13px;color:var(--ink-soft)}
.dash__note{font-size:11px;font-style:italic;color:var(--ink-faint)}
.chart{width:100%;height:auto}
.chart__grid{stroke:var(--line);stroke-width:1}
.chart__area{opacity:0;transition:opacity 1.2s var(--ease) .8s}
.chart__line{fill:none;stroke:var(--gold);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:2200;stroke-dashoffset:2200}
.gate__reveal.is-open .chart__line{animation:draw 2.4s var(--ease) .3s forwards}
.gate__reveal.is-open .chart__area{opacity:1}
@keyframes draw{to{stroke-dashoffset:0}}

/* muro de ladrillos que estalla */
.gate__wall{position:absolute;inset:0;z-index:5;perspective:1200px;perspective-origin:50% 50%}
.brick{
  position:absolute;will-change:transform,opacity;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 5px),
    linear-gradient(150deg, var(--stone-1), var(--stone-3));
  box-shadow:
    inset 1px 1px 0 rgba(255,255,255,0.07),
    inset -1.5px -2px 0 rgba(0,0,0,0.55),
    0 1px 2px rgba(0,0,0,0.5);
  border-radius:1px;
}
.brick::after{
  content:"";position:absolute;inset:0;filter:url(#stoneNoise);
  opacity:.45;mix-blend-mode:overlay;pointer-events:none;border-radius:1px;
}

/* destello dorado al romperse el muro */
.gate__flash{
  position:absolute;inset:0;z-index:6;pointer-events:none;opacity:0;
  background:radial-gradient(circle at 50% 50%, rgba(226,196,133,0.55), rgba(201,163,91,0.12) 35%, transparent 65%);
}

.gate__hint{position:absolute;bottom:46px;left:50%;transform:translateX(-50%);z-index:7;display:flex;flex-direction:column;align-items:center;gap:12px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);transition:opacity .4s}
.gate__hint-line{width:1px;height:40px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.gate__hint-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold-bright);animation:scrolldot 2.2s var(--ease) infinite}

/* ---------- Sections ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:140px 32px}
.section__head{margin-bottom:72px}
.section__index{display:inline-block;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.section__title{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(32px,4.6vw,58px);line-height:1.08;letter-spacing:-0.02em}

/* ---------- Strategy ---------- */
.strategy__grid{margin-bottom:96px}
.strategy__lead{font-size:clamp(20px,2.4vw,30px);font-weight:300;line-height:1.5;color:var(--ink);max-width:820px;margin-bottom:80px;font-family:'Fraunces',serif}
.strategy__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.strategy__col{border-top:1px solid var(--line-strong);padding-top:28px}
.strategy__num{font-family:'Cinzel',serif;color:var(--gold);font-size:18px;letter-spacing:.1em}
.strategy__col h3{font-size:20px;font-weight:500;margin:18px 0 14px;letter-spacing:-0.01em}
.strategy__col p{color:var(--ink-soft);font-size:15px;line-height:1.7}

/* ---------- Flow diagram ---------- */
.flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;gap:0;border:1px solid var(--line);border-radius:var(--radius);padding:44px 36px;position:relative;background:var(--bg-2)}
.flow__node{text-align:center;padding:22px}
.flow__node--core{border:1px solid var(--gold);border-radius:var(--radius);background:rgba(201,163,91,0.06)}
.flow__role{display:block;font-family:'Cinzel',serif;font-size:16px;letter-spacing:.08em;color:var(--ink);margin-bottom:8px}
.flow__node--core .flow__role{color:var(--gold-bright)}
.flow__desc{display:block;font-size:12px;color:var(--ink-faint);letter-spacing:.04em}
.flow__arrow{width:60px;height:1px;background:linear-gradient(90deg,var(--gold-deep),var(--gold));position:relative}
.flow__arrow::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);border-left:6px solid var(--gold);border-top:4px solid transparent;border-bottom:4px solid transparent}
.flow__return{grid-column:1 / -1;text-align:center;margin-top:30px;padding-top:22px;border-top:1px dashed var(--line);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}

/* ---------- Strategies list ---------- */
.strategies__list{border-top:1px solid var(--line)}
.strat{display:grid;grid-template-columns:90px 1fr 200px;gap:40px;align-items:center;padding:42px 8px;border-bottom:1px solid var(--line);transition:background .4s var(--ease),padding .4s var(--ease);position:relative}
.strat::before{content:"";position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,rgba(201,163,91,0.07),transparent);transition:width .5s var(--ease);z-index:-1}
.strat:hover::before{width:100%}
.strat:hover{padding-left:24px;padding-right:24px}
.strat__no{font-family:'Cinzel',serif;font-size:28px;color:var(--ink-faint);transition:color .4s}
.strat:hover .strat__no{color:var(--gold)}
.strat__body h3{font-size:clamp(22px,2.4vw,30px);font-weight:400;font-family:'Fraunces',serif;margin-bottom:10px}
.strat__body p{color:var(--ink-soft);font-size:15px;max-width:560px;line-height:1.7}
.strat__tag{justify-self:end;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--line);padding:7px 14px;border-radius:var(--radius);white-space:nowrap}

/* ---------- Table ---------- */
.table{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.table__row{display:grid;grid-template-columns:1.4fr 1fr 1.6fr;gap:24px;padding:22px 28px;border-top:1px solid var(--line);align-items:center;transition:background .3s}
.table__row:first-child{border-top:0}
.table__row:not(.table__row--head):hover{background:var(--bg-2)}
.table__row--head{background:var(--panel);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint)}
.table__row span:first-child{color:var(--ink)}
.table__row span:last-child{color:var(--ink-soft);font-size:14px}
.table__num{font-family:'Fraunces',serif;color:var(--gold-bright);font-size:18px}

/* ---------- Reporting ---------- */
.reporting__lead{font-size:clamp(18px,2vw,22px);font-weight:300;line-height:1.6;color:var(--ink-soft);max-width:760px;margin-bottom:54px;font-family:'Fraunces',serif}
.reports{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:96px}
.report{display:grid;gap:8px;padding:30px 32px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2);transition:border-color .35s var(--ease),transform .35s var(--ease),background .35s}
.report:hover{border-color:var(--gold);transform:translateY(-3px);background:rgba(201,163,91,0.04)}
.report__date{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.report__title{font-family:'Fraunces',serif;font-size:22px;color:var(--ink)}
.report__meta{font-size:13px;color:var(--ink-faint)}
.report__arrow{font-size:13px;color:var(--gold-bright);letter-spacing:.04em;margin-top:6px}

/* Composición */
.compo__head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:38px;flex-wrap:wrap;border-top:1px solid var(--line-strong);padding-top:34px}
.compo__head h3{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(24px,3vw,34px);color:var(--ink)}
.compo__asof{font-size:13px;color:var(--ink-faint);letter-spacing:.04em}
.compo__grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:56px;align-items:center}

/* Donut */
.compo__chart{position:relative;display:flex;align-items:center;justify-content:center}
.donut{width:100%;max-width:340px;height:auto;transform:rotate(-90deg)}
.donut circle{fill:none;stroke-width:26;transition:stroke-dasharray 1.3s var(--ease)}
.donut__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.donut__total{font-family:'Fraunces',serif;font-size:30px;color:var(--ink);letter-spacing:-0.01em}
.donut__label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px}

/* Tabla composición */
.ctable{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.ctable__row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 0.7fr;gap:14px;padding:14px 20px;border-top:1px solid var(--line);align-items:center;font-size:14px}
.ctable__row:first-child{border-top:0}
.ctable__row--head{background:var(--panel);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.ctable__row:not(.ctable__row--head):hover{background:var(--bg-2)}
.ctable__num{text-align:right;font-variant-numeric:tabular-nums}
.ctable__asset{display:flex;align-items:center;gap:11px;color:var(--ink)}
.ctable__dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.ctable__sym{font-weight:500}
.ctable__name{color:var(--ink-faint);font-size:12px}
.ctable__val{color:var(--ink)}
.ctable__w{color:var(--ink-soft)}

/* ---------- Terms ---------- */
.terms__grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.terms__block{border:1px solid var(--line);border-radius:var(--radius);padding:38px 34px;background:var(--bg-2)}
.terms__block h3{font-family:'Fraunces',serif;font-weight:400;font-size:22px;color:var(--gold-bright);margin-bottom:24px}
.spec div{display:flex;justify-content:space-between;gap:20px;padding:15px 0;border-top:1px solid var(--line)}
.spec div:first-child{border-top:0}
.spec dt{color:var(--ink-faint);font-size:14px;letter-spacing:.02em}
.spec dd{color:var(--ink);font-size:14px;text-align:right;max-width:60%}

/* ---------- Contact ---------- */
.contact{text-align:center;border-top:1px solid var(--line)}
.contact__inner{max-width:720px;margin:0 auto}
.contact__title{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(32px,5vw,60px);line-height:1.06;letter-spacing:-0.02em;margin:22px 0 24px}
.contact__lead{font-size:18px;color:var(--ink-soft);line-height:1.7;margin-bottom:38px}
.investor{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:34px}
.investor__opt{padding:14px 26px;border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);border-radius:var(--radius);font-family:inherit;font-size:14px;cursor:pointer;transition:all .3s}
.investor__opt:hover{border-color:var(--gold);color:var(--ink)}
.investor__opt.is-active{border-color:var(--gold);background:rgba(201,163,91,0.1);color:var(--gold-bright)}
.cform{display:grid;gap:14px;text-align:left}
.cform__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform input,.cform textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:15px 18px;color:var(--ink);font-family:inherit;font-size:15px;transition:border-color .3s}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--gold)}
.cform textarea{resize:vertical}
.cform .btn{justify-self:start;margin-top:6px}
.cform__status{font-size:13px;color:var(--gold-bright);min-height:18px}

/* ---------- Portal: botón nav ---------- */
.nav__portal{font-family:inherit}

/* ---------- Zona protegida (gated) ---------- */
.gated{position:relative}
.gated__lock{position:absolute;inset:-1px;z-index:20;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(7,10,18,0.82),rgba(7,10,18,0.94));backdrop-filter:blur(7px);
  border:1px solid var(--line);border-radius:var(--radius);text-align:center;padding:40px}
.gated__lock-inner{max-width:440px}
.gated__icon{width:62px;height:62px;margin:0 auto 22px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-bright)}
.gated__lock h3{font-family:'Fraunces',serif;font-weight:400;font-size:26px;margin-bottom:14px;color:var(--ink)}
.gated__lock p{color:var(--ink-soft);font-size:15px;line-height:1.7;margin-bottom:28px}
.gated__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Modal auth ---------- */
.auth{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px}
.auth[hidden]{display:none}
.auth__overlay{position:absolute;inset:0;background:rgba(4,6,11,0.78);backdrop-filter:blur(6px)}
.auth__panel{position:relative;z-index:1;width:100%;max-width:440px;background:var(--bg-2);border:1px solid var(--line-strong);border-radius:4px;padding:42px 40px;box-shadow:0 40px 120px -30px rgba(0,0,0,0.8);animation:authIn .45s var(--ease)}
@keyframes authIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.auth__x{position:absolute;top:16px;right:20px;background:none;border:0;color:var(--ink-faint);font-size:26px;cursor:pointer;line-height:1;transition:color .3s}
.auth__x:hover{color:var(--ink)}
.auth__brand{display:flex;align-items:baseline;gap:9px;justify-content:center;margin-bottom:6px}
.auth__kicker{text-align:center;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:26px}
.auth__tabs{display:flex;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:5px;margin-bottom:24px}
.auth__tab{flex:1;padding:11px;background:none;border:0;color:var(--ink-soft);font-family:inherit;font-size:13px;letter-spacing:.04em;cursor:pointer;border-radius:1px;transition:all .3s}
.auth__tab.is-active{background:rgba(201,163,91,0.12);color:var(--gold-bright)}
.auth__form{display:grid;gap:13px}
.auth__form input,.auth__form select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;color:var(--ink);font-family:inherit;font-size:15px;transition:border-color .3s}
.auth__form input:focus,.auth__form select:focus{outline:none;border-color:var(--gold)}
.auth__form select{color:var(--ink-soft)}
.auth__check{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--ink-faint);line-height:1.5;cursor:pointer}
.auth__check input{width:auto;margin-top:2px;accent-color:var(--gold)}
.auth__form .btn{margin-top:6px;text-align:center}
.auth__status{min-height:18px;margin-top:14px;font-size:13px;color:var(--ink-soft);text-align:center}
.auth__status--ok{color:var(--gold-bright)}
.auth__status--warn{color:#d98a8a}
.auth__note{margin-top:18px;font-size:11.5px;color:var(--ink-faint);line-height:1.6;text-align:center}

/* ---------- Banner vista previa ---------- */
.preview-banner{position:fixed;bottom:0;left:0;width:100%;z-index:1500;background:rgba(201,163,91,0.12);border-top:1px solid var(--gold-deep);color:var(--gold-bright);font-size:12px;letter-spacing:.04em;text-align:center;padding:9px 16px;backdrop-filter:blur(8px)}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);background:var(--bg-2)}
.footer__inner{max-width:var(--maxw);margin:0 auto;padding:64px 32px 48px;display:grid;gap:30px}
.footer__brand{display:flex;align-items:baseline;gap:9px}
.footer__disclaimer{font-size:12.5px;color:var(--ink-faint);line-height:1.7;max-width:880px}
.footer__meta{display:flex;justify-content:space-between;padding-top:26px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-faint);letter-spacing:.06em}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease) var(--d,0s),transform .9s var(--ease) var(--d,0s)}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav__links{position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);background:var(--bg-2);border-left:1px solid var(--line);flex-direction:column;align-items:flex-start;justify-content:center;gap:30px;padding:0 40px;transform:translateX(100%);transition:transform .5s var(--ease)}
  .nav__links.is-open{transform:none}
  .nav__burger{display:flex;z-index:1001}
  .nav.is-open .nav__burger span:first-child{transform:translateY(3.75px) rotate(45deg)}
  .nav.is-open .nav__burger span:last-child{transform:translateY(-3.75px) rotate(-45deg)}
  .hero__tower{width:100%;opacity:.4}
  .gate{height:220vh}
  .dash{grid-template-columns:1fr 1fr}
  .dash__cell:nth-child(3n+1){border-left:1px solid var(--line)}
  .dash__cell:nth-child(odd){border-left:0}
  .dash__cell:nth-child(-n+2){border-top:0}
  .dash__cell:nth-child(3){border-top:1px solid var(--line)}
  .strategy__cols{grid-template-columns:1fr;gap:36px}
  .flow{grid-template-columns:1fr;gap:18px;justify-items:center}
  .flow__arrow{width:1px;height:36px;background:linear-gradient(180deg,var(--gold-deep),var(--gold))}
  .flow__arrow::after{right:50%;top:auto;bottom:0;transform:translateX(50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:6px solid var(--gold);border-bottom:0}
  .strat{grid-template-columns:60px 1fr;gap:20px}
  .strat__tag{display:none}
  .table__row{grid-template-columns:1fr;gap:8px}
  .table__row--head{display:none}
  .terms__grid{grid-template-columns:1fr}
  .reports{grid-template-columns:1fr}
  .compo__grid{grid-template-columns:1fr;gap:40px}
  .donut{max-width:280px}
  .ctable__row{grid-template-columns:1.3fr 1fr 1fr;gap:10px;font-size:13px}
  .ctable__row span:nth-child(3),.ctable__row span:nth-child(5){display:none}
  .section{padding:96px 24px}
  .hero{padding:120px 24px 90px}
}
@media (max-width:480px){
  .dash{grid-template-columns:1fr}
  .dash__cell{border-left:0!important}
  .cform__row{grid-template-columns:1fr}
  .nav__inner{padding:18px 20px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none}
}
