/* ---------- CUSTOM FONTS ---------- */

/* Adelphi PE — variable font, single file covers all weights */
@font-face {
  font-family: 'Adelphi';
  src: url('../fonts/Adelphi/AdelphiPEVariableWeb/AdelphiPEVFWeb-All.woff2') format('woff2-variations');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* Begum — serif body font (non-title text) */
@font-face {
  font-family: 'Begum';
  src: url('../fonts/Begum/Begum-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Begum';
  src: url('../fonts/Begum/Begum-MediumItalic.woff2') format('woff2');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

:root{
  /* tokens — overridden live by Tweaks */
  --bg: #0A0C0D;
  --bg-2: #0E1112;
  --bg-panel: #10191B;
  --soft: #E7E2D8;
  --soft-ink: #172120;
  --soft-dim: #68706D;
  --soft-faint: #8F948F;
  --ink: #E8E8E6;
  --ink-dim: #9AA0A0;
  --ink-faint: #5A6165;
  --rule: rgba(232,232,230,0.09);
  --rule-strong: rgba(232,232,230,0.18);
  --accent: oklch(0.66 0.075 182);
  --accent-deep: oklch(0.42 0.055 185);
  --accent-glow: oklch(0.72 0.09 180 / 0.25);
  --dark-copy: rgba(232, 232, 230, 0.72);

  --serif: 'Newsreader', 'Times New Roman', serif;        /* display / title headings */
  --serif-body: 'Begum', 'Newsreader', Georgia, serif;    /* body serif text */
  --sans: 'Adelphi', ui-sans-serif, system-ui, sans-serif;
  --mono: 'Adelphi', ui-sans-serif, system-ui, sans-serif;

  --gutter: clamp(24px, 5vw, 88px);
  --pad-y: clamp(80px, 12vw, 180px);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-size:16px;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}

.wrap{padding-left:var(--gutter);padding-right:var(--gutter)}
.rule{height:1px;background:var(--rule);width:100%}
.rule-strong{height:1px;background:var(--rule-strong);width:100%}

/* typography */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);font-weight:400;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent-glow)}
.display{font-family:var(--serif);font-weight:300;letter-spacing:-0.02em;line-height:0.98;font-optical-sizing:auto}
.display em{font-style:italic;font-weight:300;color:var(--ink-dim)}
.lead{font-family:var(--serif-body);font-weight:500;font-size:clamp(18px,1.4vw,22px);line-height:1.5;color:var(--ink)}
.small{font-size:13px;color:var(--ink-dim);line-height:1.6}
.kicker{font-family:var(--mono);font-size:10px;letter-spacing:0.24em;text-transform:uppercase;color:var(--ink-faint)}

/* arrow link */
.arrow-link{display:inline-flex;align-items:baseline;gap:14px;padding:14px 0;border-bottom:1px solid var(--rule);color:var(--ink);font-size:15px;font-weight:400;letter-spacing:-0.005em;transition:padding .5s ease, color .3s ease}
.arrow-link .arr{font-family:var(--mono);opacity:.7;transition:transform .5s ease, opacity .3s ease}
.arrow-link:hover{color:var(--ink);padding-left:6px}
.arrow-link:hover .arr{transform:translateX(6px);opacity:1;color:var(--accent)}
.who-dropdown{border-bottom:1px solid var(--rule)}
.who-dropdown summary{list-style:none;cursor:pointer}
.who-dropdown summary::-webkit-details-marker{display:none}
.who-dropdown .arrow-link{width:100%;justify-content:space-between;border-bottom:0}
.who-dropdown[open] .arrow-link{color:var(--accent)}
.who-dropdown[open] .arrow-link .arr{transform:rotate(90deg);opacity:1;color:var(--accent)}
.who-dropdown-panel{padding:2px 0 24px;color:var(--ink-dim);font-size:14px;line-height:1.7;max-width:none}
.who-dropdown-panel p{margin:0 0 14px}
.who-dropdown-panel p:last-child{margin-bottom:0}
.who-dropdown-panel ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.who-dropdown-panel li{position:relative;padding-left:18px}
.who-dropdown-panel li::before{content:"";position:absolute;left:0;top:.78em;width:5px;height:5px;border-radius:50%;background:var(--accent)}

/* cta button */
.btn{display:inline-flex;align-items:center;gap:18px;padding:20px 28px 20px 32px;border:1px solid var(--rule-strong);border-radius:999px;font-size:14px;letter-spacing:0.02em;color:var(--ink);transition:border-color .4s, background .4s, padding .4s}
.btn .arr{font-family:var(--mono);opacity:.8;transition:transform .4s}
.btn:hover{border-color:var(--accent);background:rgba(255,255,255,0.02)}
.btn:hover .arr{transform:translateX(4px);color:var(--accent)}
.btn-solid{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-solid:hover{background:var(--accent);border-color:var(--accent);color:#06191C}

/* section vertical rhythm */
section{padding-top:var(--pad-y);padding-bottom:var(--pad-y);position:relative}
.section-soft{background:var(--soft);color:var(--soft-ink);--ink:var(--soft-ink);--ink-dim:var(--soft-dim);--ink-faint:var(--soft-faint);--rule:rgba(16,25,27,0.11);--rule-strong:rgba(16,25,27,0.2);--accent:oklch(0.48 0.06 182);--accent-glow:oklch(0.55 0.07 182 / 0.22)}
.section-soft .arrow-link:hover,
.section-soft .news-item:hover{background:rgba(16,25,27,0.035)}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:26px var(--gutter);display:flex;justify-content:space-between;align-items:center;mix-blend-mode:normal;transition:background .5s, backdrop-filter .5s}
.nav.scrolled{background:rgba(32,73,79,0.86);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(232,232,230,0.16)}
.logo{display:inline-flex;align-items:center;line-height:0}
.logo img{display:block;width:clamp(132px, 13vw, 172px);height:auto;filter:invert(1) brightness(1.1)}
.logo-footer img{width:clamp(170px, 18vw, 230px)}
.menu-trigger{display:inline-flex;align-items:center;gap:14px;padding:10px 18px 10px 14px;border:1px solid var(--rule-strong);border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;backdrop-filter:blur(8px);background:rgba(32,73,79,0.44);transition:border-color .3s}
.menu-trigger:hover{border-color:var(--accent)}
.menu-trigger .dots{display:inline-flex;flex-direction:column;gap:3px}
.menu-trigger .dots span{width:14px;height:1px;background:var(--ink);display:block;transition:transform .4s}
.menu-trigger[data-open="true"] .dots span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.menu-trigger[data-open="true"] .dots span:nth-child(2){transform:translateY(-4px) rotate(-45deg);width:14px}

/* floating menu panel */
.menu-panel{position:fixed;top:0;right:0;bottom:0;width:min(520px, 92vw);background:linear-gradient(180deg, #244F55, #1F464C);border-left:1px solid var(--rule);z-index:60;transform:translateX(100%);transition:transform .6s cubic-bezier(.7,0,.2,1);padding:120px 64px 64px;display:flex;flex-direction:column;gap:32px}
.menu-panel.open{transform:translateX(0)}
.menu-scrim{position:fixed;inset:0;background:rgba(32,73,79,0.48);backdrop-filter:blur(4px);z-index:55;opacity:0;pointer-events:none;transition:opacity .5s}
.menu-scrim.open{opacity:1;pointer-events:auto}
.menu-panel .kicker{color:rgba(232,232,230,0.54)}
.menu-panel a{color:rgba(232,232,230,0.64)}
.menu-panel a.m-link{font-family:var(--serif);font-size:42px;font-weight:300;letter-spacing:-0.02em;color:var(--ink);display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px solid rgba(232,232,230,0.18);transition:color .3s, padding .4s}
.menu-panel a.m-link .n{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;color:rgba(232,232,230,0.58)}
.menu-panel a.m-link:hover{color:var(--accent);padding-left:8px}

/* ---------- HERO ---------- */
.hero{min-height:100vh;padding-top:140px;padding-bottom:80px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(0.86) contrast(1.04)}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 0%, transparent 40%, rgba(0,0,0,0.55) 75%, rgba(0,0,0,0.80) 100%)}
.hero-inner{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:space-between;flex:1;min-height:calc(100vh - 220px)}
.hero h1{font-size:clamp(52px, 8.2vw, 148px);max-width:16ch;margin:0}
.hero h1 .em{font-style:italic;color:rgba(232,232,230,0.78)}
.hero-tagline{margin:0;color:#fff;font-size:24px;line-height:1;letter-spacing:0;white-space:normal}
.hero-tagline-sans{font-family:var(--sans);font-weight:500}
.hero-tagline-serif{font-family:var(--serif-body);font-weight:500}
.hero-top-row{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-top:180px}
.hero-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim)}
.hero-subtext{max-width:44ch}
.hero-subtext,
.strat-row p,
.final-right p{font-family:var(--sans);font-weight:300;font-size:15px;line-height:1.55;color:var(--dark-copy)}
.people-head .supp,
.foot-about{font-family:var(--sans);font-weight:300;font-size:15px;line-height:1.55}
/* abstract teal svg panel used in hero + keyfigures + finalcta */
.abstract-panel{position:absolute;inset:0;overflow:hidden}
.abstract-panel svg{width:100%;height:100%}

/* ---------- WHO WE ARE ---------- */
.who{display:grid;grid-template-columns:minmax(120px,1fr) minmax(0,7fr) minmax(320px,3fr);gap:64px;align-items:start}
.who .col-label{padding-top:8px}
.who h2{font-family:var(--serif);font-size:clamp(34px, 4.4vw, 72px);font-weight:300;line-height:1.05;letter-spacing:-0.02em;max-width:17ch;margin:0}
.who h2 .dim{color:var(--ink-dim)}
.who .side{display:flex;flex-direction:column;gap:0}
.who .side .supp{margin-top:32px;max-width:none;color:var(--ink-dim);font-size:14px;line-height:1.7}

/* ---------- KEY FIGURES ---------- */
.figures{position:relative;overflow:hidden;padding-top:calc(var(--pad-y) * 0.7);padding-bottom:calc(var(--pad-y) * 0.7)}
.figures-bg{position:absolute;inset:0;z-index:0}
.figures-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(40,90,96,0.08), rgba(25,60,66,0.20))}
.figures-inner{position:relative;z-index:2}
.figures-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:40px;margin-top:72px;border-top:1px solid var(--rule-strong);padding-top:56px}
.figure{display:flex;flex-direction:column}
.figure .num{font-family:var(--serif);font-weight:300;font-size:clamp(44px, 5.2vw, 88px);letter-spacing:-0.025em;line-height:0.95}
.figure .num .unit{font-size:0.55em;color:var(--ink-dim);letter-spacing:-0.01em;margin-left:4px}
.figure .figure-value{min-height:126px}
.figure .lbl{margin-top:0;font-family:var(--mono);font-size:10.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-dim)}

/* ---------- PEOPLE ---------- */
.people-head{display:grid;grid-template-columns:minmax(120px,1fr) minmax(0,7fr) minmax(0,4fr);gap:64px;align-items:start;margin-bottom:96px}
.people-head h2{font-family:var(--serif);font-size:clamp(34px, 4.4vw, 72px);font-weight:300;line-height:1.05;letter-spacing:-0.02em;margin:0;max-width:14ch}
.people-head h2 em{font-style:italic;color:var(--ink-dim);font-weight:300}
.people-head .supp{color:var(--ink-dim);max-width:36ch;padding-top:10px}
.roster{border-top:1px solid var(--rule-strong)}
.roster .row{display:grid;grid-template-columns:60px minmax(0,4fr) minmax(0,3fr) minmax(0,2fr);gap:32px;align-items:center;padding:22px 0;border-bottom:1px solid var(--rule);transition:padding .4s, background .4s}
.roster .row:hover{padding-left:14px;background:linear-gradient(90deg, rgba(255,255,255,0.02), transparent 60%)}
.roster .row .idx{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;color:var(--ink-faint)}
.roster .row .nm{font-family:var(--serif);font-size:clamp(22px,2vw,30px);font-weight:300;letter-spacing:-0.01em}
.roster .row .rl{font-size:13px;color:var(--ink-dim);font-family:var(--mono);letter-spacing:0.08em;text-transform:uppercase}
.roster .row .loc{font-size:12px;color:var(--ink-faint);font-family:var(--mono);letter-spacing:0.12em;text-transform:uppercase;text-align:right}

/* ---------- STRATEGIC BLOCK ---------- */
.strat{background:linear-gradient(180deg, #244F55 0%, #1F464C 100%);position:relative;overflow:hidden}
.strat::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 85% 20%, rgba(40,90,96,0.32), transparent 58%);opacity:.42;pointer-events:none}
.strat-inner{position:relative;z-index:1}
.strat-head{display:grid;grid-template-columns:minmax(120px,1fr) minmax(0,8fr) minmax(0,4fr);gap:64px;align-items:start;margin-bottom:96px}
.strat-head h2{font-family:var(--serif);font-size:clamp(40px, 5.2vw, 84px);font-weight:300;line-height:1.02;letter-spacing:-0.02em;margin:0;max-width:13ch}
.strat-head h2 em{font-style:italic;color:var(--accent);font-weight:300}
.strat-rows{display:flex;flex-direction:column}
.strat-row{display:grid;grid-template-columns:minmax(120px,1fr) minmax(0,5fr) minmax(0,5fr);gap:64px;padding:56px 0;border-top:1px solid rgba(232,232,230,0.12);align-items:start;transition:background .4s}
.strat-row:last-child{border-bottom:1px solid rgba(232,232,230,0.12)}
.strat-row--re{align-items:center}
.strat-row:hover{background:linear-gradient(90deg, rgba(255,255,255,0.015), transparent)}
.strat-row .big-num{font-family:var(--serif);font-weight:300;font-size:clamp(48px, 6vw, 96px);letter-spacing:-0.025em;line-height:0.95;color:var(--ink);opacity:.92}
.strat-row h3{font-family:var(--serif);font-size:clamp(22px,2.2vw,34px);font-weight:300;letter-spacing:-0.01em;line-height:1.15;margin:0;max-width:18ch}
.strat-row p{max-width:42ch;margin:18px 0 0}

/* ---------- TRANSACTIONS ---------- */
.tx-head{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-bottom:72px}
.tx-head h2{font-family:var(--serif);font-size:clamp(32px,3.6vw,56px);font-weight:300;letter-spacing:-0.02em;line-height:1.05;margin:0;max-width:14ch}
.tx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule-strong);border-top:1px solid var(--rule-strong);border-bottom:1px solid var(--rule-strong)}
.tx{background:var(--bg);padding:40px 36px 36px;display:flex;flex-direction:column;gap:20px;transition:background .4s;min-height:340px}
.tx:hover{background:var(--bg-2)}
.tx .tx-amt{font-family:var(--serif);font-weight:300;font-size:clamp(44px,4.8vw,72px);letter-spacing:-0.025em;line-height:1}
.tx .tx-type{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
.tx p{color:var(--ink-dim);font-size:14px;line-height:1.65;margin:0;font-family:var(--serif-body);font-weight:500}
.tx .tx-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--rule)}
.tx .tx-foot span{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim)}

/* ---------- NEWS ---------- */
.news-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px}
.news-list{border-top:1px solid var(--rule-strong)}
.news-item{display:grid;grid-template-columns:140px minmax(0,1fr) 180px 40px;gap:48px;align-items:start;width:100%;text-align:left;padding:40px 0;border-bottom:1px solid var(--rule);transition:padding .4s, background .4s}
.news-item:hover{padding-left:14px;background:linear-gradient(90deg, rgba(255,255,255,0.015), transparent 50%)}
.news-item:focus-visible{outline:1px solid var(--accent);outline-offset:8px}
.news-item .date{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);padding-top:8px}
.news-item h3{font-family:var(--serif);font-size:clamp(20px,1.8vw,26px);font-weight:300;line-height:1.3;letter-spacing:-0.01em;margin:0;max-width:36ch}
.news-item .cat{font-family:var(--mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-faint);padding-top:8px}
.news-item .arr{font-family:var(--mono);text-align:right;color:var(--ink-faint);padding-top:8px;transition:color .3s, transform .4s}
.news-item:hover .arr{color:var(--accent);transform:translateX(6px)}
.news-scrim{position:fixed;inset:0;background:rgba(32,73,79,0.44);backdrop-filter:blur(6px);z-index:70;opacity:0;pointer-events:none;transition:opacity .5s}
.news-scrim.open{opacity:1;pointer-events:auto}
.news-drawer{position:fixed;top:0;right:0;bottom:0;width:min(75vw, 1080px);max-width:calc(100vw - 28px);background:#e7e2d8;color:#10191B;z-index:75;transform:translateX(100%);transition:transform .65s cubic-bezier(.7,0,.2,1);overflow:auto;border-left:1px solid rgba(32,73,79,0.18);box-shadow:-32px 0 80px rgba(32,73,79,.24)}
.news-drawer.open{transform:translateX(0)}
.news-drawer-inner{padding:clamp(32px,5vw,72px);min-height:100%;display:grid;grid-template-columns:minmax(0,4.8fr) minmax(260px,2.7fr);grid-template-rows:auto 1fr;grid-template-areas:"header side" "main side";gap:clamp(32px,5vw,72px)}
.article-header{grid-area:header}
.article-main{grid-area:main}
.news-drawer-close{position:sticky;top:24px;margin-left:auto;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid rgba(32,73,79,0.22);border-radius:50%;font-family:var(--mono);font-size:18px;color:#10191B;background:rgba(244,241,234,0.72);backdrop-filter:blur(12px);transition:background .3s,border-color .3s}
.news-drawer-close:hover{background:#244F55;color:#e7e2d8;border-color:#244F55}
.article-kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(16,25,27,.55);display:flex;gap:16px;flex-wrap:wrap;margin-top:20px}
.article-title{font-family:var(--serif);font-weight:300;font-size:clamp(42px,5vw,88px);line-height:.98;letter-spacing:-.025em;margin:28px 0 28px;max-width:11ch}
.article-dek{font-family:var(--serif-body);font-weight:500;font-size:clamp(18px,1.5vw,24px);line-height:1.45;color:rgba(16,25,27,.78);max-width:46ch;margin:0 0 44px}
.article-body{font-family:var(--serif-body);font-weight:500;font-size:18px;line-height:1.72;color:rgba(16,25,27,.82);max-width:62ch}
.article-body p{margin:0 0 24px}
.article-side{grid-area:side;padding-top:96px}
.article-media{aspect-ratio:4/5;border:1px solid rgba(16,25,27,.14);overflow:hidden;background:#dde4df;margin:0 0 28px}
.article-media svg{width:100%;height:100%;display:block}
.article-meta{display:grid;grid-template-columns:1fr 1fr;gap:1px;border-top:1px solid rgba(16,25,27,.14);border-bottom:1px solid rgba(16,25,27,.14);background:rgba(16,25,27,.14)}
.article-meta div{background:#e7e2d8;padding:18px 0}
.article-meta span{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(16,25,27,.45);margin-bottom:8px}
.article-meta strong{font-weight:400;font-size:14px;color:#10191B}

/* ---------- FINAL CTA ---------- */
.final{position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center}
.final-bg{position:absolute;inset:0;z-index:0}
.final-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(40,90,96,0.08), rgba(25,60,66,0.24))}
.final-inner{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:minmax(170px,1fr) minmax(0,8fr) minmax(320px,4fr);gap:64px;align-items:start}
.final .eyebrow{white-space:nowrap}
.final h2{font-family:var(--serif);font-size:clamp(56px,6.6vw,140px);font-weight:300;letter-spacing:-0.025em;line-height:0.95;margin:0;white-space:nowrap}
.final h2 em{font-style:italic;color:var(--ink-dim);font-weight:300}
.final-right{padding-top:.08em}
.final-right p{max-width:46ch;margin:0 0 40px}

/* ---------- FOOTER ---------- */
footer{padding-top:96px;padding-bottom:48px;border-top:1px solid var(--rule-strong)}
.foot-grid{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2fr) minmax(0,2fr) minmax(0,2fr);gap:48px;margin-bottom:88px}
.foot-grid h4{font-family:var(--mono);font-size:10.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-faint);font-weight:400;margin:0 0 28px}
.foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.foot-grid ul a{font-size:14px;color:var(--ink-dim);transition:color .3s}
.foot-grid ul a:hover{color:var(--accent)}
.foot-about{color:var(--dark-copy);max-width:46ch;margin-top:20px}
.foot-legal{padding:32px 0 0;border-top:1px solid var(--rule);color:var(--ink-faint);font-size:11.5px;line-height:1.7;max-width:80ch;font-family:var(--sans)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:40px;padding-top:24px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:10.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-faint)}
.foot-bottom .links{display:flex;gap:32px}

/* back to top */
.back-top{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);padding:12px 0}
.back-top:hover{color:var(--accent)}

/* ---------- TWEAKS PANEL ---------- */
#tweaks{position:fixed;bottom:20px;right:20px;z-index:200;background:rgba(14,17,18,0.92);backdrop-filter:blur(16px);border:1px solid var(--rule-strong);border-radius:14px;width:300px;padding:18px;font-family:var(--sans);font-size:13px;display:none;box-shadow:0 20px 50px rgba(0,0,0,0.5)}
#tweaks.on{display:block}
#tweaks h4{margin:0 0 12px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim);font-weight:400}
#tweaks .row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 0;border-top:1px solid var(--rule)}
#tweaks label{color:var(--ink-dim);font-size:12px}
#tweaks input[type=range]{width:130px;accent-color:var(--accent)}
#tweaks .swatches{display:flex;gap:6px}
#tweaks .sw{width:20px;height:20px;border-radius:50%;border:1px solid var(--rule-strong);cursor:pointer;transition:transform .2s}
#tweaks .sw.active{border-color:var(--ink);transform:scale(1.15)}
#tweaks select{background:transparent;color:var(--ink);border:1px solid var(--rule-strong);border-radius:6px;padding:4px 8px;font-family:var(--mono);font-size:11px}

/* responsive */
@media (max-width: 900px){
  :root{
    --gutter: clamp(18px, 5vw, 34px);
    --pad-y: clamp(64px, 14vw, 104px);
  }
  section{padding-top:var(--pad-y);padding-bottom:var(--pad-y)}
  .nav{padding:18px var(--gutter)}
  .logo img{width:clamp(128px, 34vw, 158px)}
  .menu-trigger{gap:10px;padding:9px 14px 9px 12px;font-size:10px;letter-spacing:0.12em}
  .menu-panel{width:min(440px, 92vw);padding:104px 34px 42px;gap:22px}
  .menu-panel a.m-link{font-size:clamp(30px, 9vw, 42px)}
  .hero{min-height:100svh;padding-top:112px;padding-bottom:48px}
  .hero-inner{min-height:calc(100svh - 160px)}
  .hero h1{font-size:clamp(52px, 13vw, 96px);max-width:12ch}
  .hero-tagline{font-size:24px}
  .hero-top-row{margin-top:72px;gap:28px}
  .hero-subtext{max-width:36ch}
  .who, .people-head, .strat-head, .strat-row, .final-inner{grid-template-columns:1fr !important}
  .who{gap:34px}
  .who .col-label{padding-top:0}
  .who h2{font-size:clamp(40px, 10vw, 64px);max-width:13ch}
  .who .side{margin-top:8px}
  .people-head{gap:28px;margin-bottom:56px}
  .people-head h2{font-size:clamp(42px, 10vw, 64px);max-width:12ch}
  .people-head .supp{padding-top:0}
  .roster .row{grid-template-columns:42px minmax(0,1fr);gap:8px 18px;padding:20px 0}
  .roster .row:hover{padding-left:0;background:transparent}
  .roster .row .idx{grid-row:1 / span 3;padding-top:6px}
  .roster .row .nm{grid-column:2;font-size:clamp(24px, 7vw, 32px);line-height:1.08}
  .roster .row .rl{grid-column:2;font-size:11px;line-height:1.45}
  .roster .row .loc{grid-column:2;text-align:left;font-size:10.5px}
  .final h2{white-space:normal}
  .final-right{padding-top:0}
  .figures{padding-top:84px;padding-bottom:84px}
  .figures-grid{grid-template-columns:1fr 1fr;gap:34px 24px;margin-top:48px;padding-top:40px}
  .figure .figure-value{min-height:96px}
  .figure .num{font-size:clamp(44px, 12vw, 70px)}
  .tx-grid{grid-template-columns:1fr}
  .news-head{align-items:flex-start;gap:28px}
  .news-item{grid-template-columns:minmax(0,1fr) 30px;gap:12px 18px;padding:30px 0}
  .news-item:hover{padding-left:0}
  .news-item .date{grid-column:1 / -1;padding-top:0}
  .news-item h3{grid-column:1;font-size:clamp(22px, 6vw, 30px);max-width:none}
  .news-item .arr{grid-column:2;grid-row:2;padding-top:4px}
  .news-item .cat{display:none}
  .news-drawer{width:100vw;max-width:100vw;border-left:none}
  .news-drawer-inner{display:flex;flex-direction:column;padding:28px;gap:24px}
  .article-kicker{margin-top:0}
  .article-title{font-size:clamp(42px, 11vw, 64px);max-width:none}
  .article-dek{font-size:18px}
  .article-body{font-size:16px}
  .article-side{padding-top:0}
  .article-media{aspect-ratio:16/10}
  .article-meta{grid-template-columns:1fr 1fr}
  .strat-head{gap:30px;margin-bottom:48px}
  .strat-head h2{font-size:clamp(42px, 11vw, 68px)}
  .strat-row{gap:18px;padding:36px 0}
  .strat-row .big-num{font-size:clamp(42px, 12vw, 72px)}
  .final{min-height:auto}
  .final-inner{gap:30px}
  .final h2{font-size:clamp(58px, 15vw, 96px)}
  .foot-grid{grid-template-columns:1fr 1fr}
  footer > div:first-child{flex-direction:column !important;gap:28px !important;margin-bottom:52px !important}
  .foot-bottom{align-items:flex-start;gap:20px;flex-direction:column}
  .foot-bottom .links{gap:18px;flex-wrap:wrap}
  .hero-top-row{flex-direction:column;align-items:flex-start}
}

@media (max-width: 560px){
  .nav{padding-top:16px;padding-bottom:16px}
  .menu-trigger > span:last-child{font-size:0;letter-spacing:0}
  .menu-trigger > span:last-child::after{content:"Menu";font-size:10px;letter-spacing:0.14em}
  .menu-panel{width:100vw;padding:92px 28px 36px}
  .hero{padding-top:96px}
  .hero h1{font-size:clamp(48px, 15vw, 72px)}
  .who h2,.people-head h2{font-size:clamp(38px, 11vw, 54px)}
  .figures-grid{grid-template-columns:1fr;gap:38px}
  .figure .figure-value{min-height:auto;margin-bottom:22px}
  .news-head{flex-direction:column;margin-bottom:42px}
  .news-head .arrow-link{padding-top:0}

  .foot-grid{grid-template-columns:1fr;gap:34px;margin-bottom:58px}
  .foot-about{max-width:34ch}
}

/* ---------- WIDE SCREEN (>1600px) ---------- */
@media (min-width: 1600px) {
  /* Font scale-up — clamp maxes hit their ceiling on wide screens, so raise them */
  body { font-size: 18px }
  .hero h1 { font-size: clamp(148px, 9vw, 192px) }
  .who h2, .people-head h2 { font-size: clamp(72px, 5vw, 96px) }
  .strat-head h2 { font-size: clamp(84px, 5.5vw, 114px) }
  .final h2 { font-size: clamp(140px, 8vw, 192px) }
  .figure .num { font-size: clamp(88px, 5.8vw, 112px) }
  .roster .row .nm { font-size: clamp(30px, 2.2vw, 42px) }
  .strat-row h3 { font-size: clamp(34px, 2.4vw, 44px) }
  .news-item h3 { font-size: clamp(26px, 1.9vw, 34px) }
  .tx .tx-amt { font-size: clamp(72px, 5vw, 92px) }
  .lead { font-size: clamp(22px, 1.5vw, 28px) }
  .hero-subtext, .strat-row p, .final-right p, .people-head .supp, .foot-about { font-size: 17px }
}

/* ---------- EXTRA WIDE (>2560px) — center content ---------- */
@media (min-width: 2560px) {
  :root { --gutter: max((100vw - 1600px) / 2, 88px) }
}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1.2s ease, transform 1.2s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
