/* ============================================================
   XENON CAPITAL MARKETS — Design System
   Modern institutional · Archivo + IBM Plex Mono · Ink / Paper / Voltage amber
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  /* color */
  --ink:        #0d0e11;
  --ink-soft:   #16181c;
  --ink-700:    #2a2d33;
  --paper:      #f4f2ec;
  --paper-2:    #faf9f5;
  --white:      #ffffff;
  --muted:      #5b5f66;
  --muted-2:    #84888f;
  --line:       rgba(13,14,17,.13);
  --line-soft:  rgba(13,14,17,.08);
  --line-on-ink:rgba(255,255,255,.14);
  --accent:     #d99518;          /* voltage amber */
  --accent-deep:#a86f0d;
  --accent-glow:rgba(217,149,24,.16);
  --up:         #1f9d55;
  --down:       #c5413b;

  /* type */
  --sans: 'Archivo', system-ui, -apple-system, sans-serif;
  --mono: 'IBM Plex Mono', ui-monospace, 'SFMono-Regular', monospace;

  /* layout */
  --container: 1280px;
  --gutter: clamp(20px, 5vw, 56px);
  --section-y: clamp(72px, 9vw, 150px);
  --radius: 2px;

  /* motion */
  --ease: cubic-bezier(.4,.01,.2,1);
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
::selection{ background:var(--ink); color:var(--paper); }

/* ---------- layout helpers ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.section{ padding-block:var(--section-y); }
.section--tight{ padding-block:clamp(56px,6vw,96px); }
.on-ink{ background:var(--ink); color:var(--paper); }
.on-ink .muted{ color:rgba(255,255,255,.6); }
.bg-2{ background:var(--paper-2); }

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent-deep);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.on-ink .eyebrow{ color:var(--accent); }
.eyebrow::before{
  content:"";
  width:1.6em; height:1px;
  background:currentColor;
  opacity:.65;
}
.eyebrow--plain::before{ display:none; }

h1,h2,h3,h4{ font-weight:700; line-height:1.04; letter-spacing:-.02em; }
.display{
  font-size:clamp(2.7rem, 6.4vw, 5.6rem);
  font-weight:800;
  line-height:.98;
  letter-spacing:-.035em;
}
.h1{ font-size:clamp(2.3rem, 4.6vw, 3.9rem); letter-spacing:-.03em; }
.h2{ font-size:clamp(1.9rem, 3.4vw, 3rem); }
.h3{ font-size:clamp(1.35rem, 2vw, 1.8rem); letter-spacing:-.018em; }
.lead{
  font-size:clamp(1.12rem, 1.5vw, 1.42rem);
  line-height:1.5;
  font-weight:400;
  color:var(--ink-700);
  letter-spacing:-.01em;
  max-width:46ch;
  text-wrap:pretty;
}
.on-ink .lead{ color:rgba(255,255,255,.78); }
.muted{ color:var(--muted); }
p{ text-wrap:pretty; }
.measure{ max-width:62ch; }
.measure-sm{ max-width:46ch; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--mono);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.13em;
  text-transform:uppercase;
  padding:1.05em 1.7em;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--paper);
  border-radius:var(--radius);
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
}
.btn .arrow{ transition:transform .35s var(--ease); }
.btn:hover{ background:transparent; color:var(--ink); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); }
.btn--accent{ background:var(--accent); border-color:var(--accent); color:var(--ink); }
.btn--accent:hover{ background:transparent; color:var(--ink); }
.on-ink .btn{ background:var(--paper); border-color:var(--paper); color:var(--ink); }
.on-ink .btn:hover{ background:transparent; color:var(--paper); }
.on-ink .btn--ghost{ background:transparent; color:var(--paper); border-color:var(--line-on-ink); }
.on-ink .btn--ghost:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

.link-arrow{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--mono); font-size:.78rem; font-weight:500;
  letter-spacing:.1em; text-transform:uppercase;
  padding-bottom:.35em;
  border-bottom:1px solid var(--line);
  transition:border-color .3s var(--ease), gap .3s var(--ease);
}
.link-arrow:hover{ border-color:var(--ink); gap:.85em; }
.on-ink .link-arrow{ border-color:var(--line-on-ink); }
.on-ink .link-arrow:hover{ border-color:var(--paper); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  background:rgba(244,242,236,.82);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease), background .4s var(--ease);
}
.site-header.scrolled{ border-bottom-color:var(--line); }
.site-header.on-dark{ background:rgba(13,14,17,.0); }
.site-header.on-dark.scrolled{ background:rgba(13,14,17,.86); border-bottom-color:var(--line-on-ink); }
.nav{
  height:78px;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand-mark{
  width:26px; height:26px; flex:none;
  background:var(--accent);
  position:relative;
  border-radius:1px;
}
.brand-mark::after{
  content:""; position:absolute; inset:7px;
  background:var(--ink);
  clip-path:polygon(0 0,100% 0,0 100%);
}
.brand-text{ line-height:1; }
.brand-name{
  font-weight:800; font-size:1.32rem; letter-spacing:.06em;
  display:block;
}
.brand-sub{
  font-family:var(--mono); font-size:.56rem; font-weight:500;
  letter-spacing:.26em; text-transform:uppercase;
  color:var(--muted); margin-top:3px;
}
.on-dark .brand-name{ color:var(--paper); }
.on-dark .brand-sub{ color:rgba(255,255,255,.55); }

.nav-links{ display:flex; align-items:center; gap:clamp(20px,2.4vw,40px); list-style:none; }
.nav-links a{
  font-family:var(--mono); font-size:.74rem; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted);
  position:relative; padding-block:6px;
  transition:color .3s var(--ease);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{
  content:""; position:absolute; left:0; bottom:-2px;
  width:100%; height:1.5px; background:var(--accent);
}
.on-dark .nav-links a{ color:rgba(255,255,255,.62); }
.on-dark .nav-links a:hover,.on-dark .nav-links a.active{ color:var(--paper); }

.nav-cta{ display:flex; align-items:center; gap:18px; }
.nav-cta .btn{ padding:.78em 1.25em; }

.nav-toggle{
  display:none; width:42px; height:42px;
  border:1px solid var(--line); background:transparent;
  border-radius:var(--radius); position:relative;
}
.nav-toggle span{
  position:absolute; left:11px; right:11px; height:1.5px; background:var(--ink);
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.nav-toggle span:nth-child(1){ top:15px; }
.nav-toggle span:nth-child(2){ top:21px; }
.nav-toggle span:nth-child(3){ top:27px; }
.on-dark .nav-toggle{ border-color:var(--line-on-ink); }
.on-dark .nav-toggle span{ background:var(--paper); }
body.nav-open .nav-toggle span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
body.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* ---------- ticker ---------- */
.ticker{
  border-top:1px solid var(--line-on-ink);
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
  height:42px; display:flex; align-items:center;
  position:relative;
}
.ticker::before,.ticker::after{
  content:""; position:absolute; top:0; bottom:0; width:60px; z-index:2; pointer-events:none;
}
.ticker::before{ left:0; background:linear-gradient(90deg,var(--ink),transparent); }
.ticker::after{ right:0; background:linear-gradient(270deg,var(--ink),transparent); }
.ticker-track{ display:flex; align-items:center; gap:0; white-space:nowrap; animation:ticker 48s linear infinite; }
.ticker:hover .ticker-track{ animation-play-state:paused; }
.tick{
  display:inline-flex; align-items:baseline; gap:.6em;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.04em;
  padding-inline:26px;
  border-right:1px solid var(--line-on-ink);
}
.tick .sym{ color:rgba(255,255,255,.92); font-weight:500; }
.tick .px{ color:rgba(255,255,255,.6); }
.tick .chg{ font-weight:500; }
.tick .chg.up{ color:#46c281; }
.tick .chg.down{ color:#e0726c; }
@keyframes ticker{ to{ transform:translateX(-50%); } }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:flex-end;
  background:var(--ink); color:var(--paper);
  overflow:hidden;
  padding-top:120px;
}
.hero-grid-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.9; }
.hero::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 90% at 80% 10%, rgba(217,149,24,.10), transparent 55%),
             linear-gradient(180deg, rgba(13,14,17,.4) 0%, transparent 30%, rgba(13,14,17,.78) 100%);
  pointer-events:none;
}
.hero .container{ position:relative; z-index:2; }
.hero-inner{ padding-bottom:clamp(48px,7vw,96px); }
.hero h1{ max-width:16ch; margin-top:.5rem; }
.hero-meta{
  display:flex; flex-wrap:wrap; gap:clamp(28px,5vw,72px);
  margin-top:clamp(36px,5vw,60px);
  padding-top:32px; border-top:1px solid var(--line-on-ink);
}
.hero-meta .item{ }
.hero-meta .k{ font-family:var(--mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.5); }
.hero-meta .v{ font-size:clamp(1.6rem,2.6vw,2.4rem); font-weight:700; letter-spacing:-.02em; margin-top:6px; }
.hero-meta .v small{ font-size:.5em; font-weight:500; color:var(--accent); margin-left:.2em; }
.hero-scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.5); display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll .bar{ width:1px; height:38px; background:linear-gradient(var(--accent),transparent); animation:scrollpulse 2.2s var(--ease) infinite; }
@keyframes scrollpulse{ 0%,100%{ opacity:.3; transform:scaleY(.6); } 50%{ opacity:1; transform:scaleY(1); } }

/* ---------- page hero (interior) ---------- */
.page-hero{
  background:var(--ink); color:var(--paper);
  position:relative; overflow:hidden;
  padding-top:clamp(150px,18vh,210px);
  padding-bottom:clamp(60px,8vw,110px);
}
.page-hero-canvas{ position:absolute; inset:0; opacity:.55; z-index:0; }
.page-hero::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(13,14,17,.2), rgba(13,14,17,.6));
}
.page-hero .container{ position:relative; z-index:2; }
.page-hero h1{ max-width:18ch; }
.page-hero .lead{ margin-top:26px; }
.breadcrumb{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin-bottom:22px; display:flex; gap:.6em;
}
.breadcrumb .sep{ color:var(--accent); }

/* ============================================================
   GENERIC SECTION BLOCKS
   ============================================================ */
.section-head{ max-width:680px; margin-bottom:clamp(40px,5vw,70px); }
.section-head .eyebrow{ margin-bottom:22px; }
.section-head h2{ margin-bottom:0; }

/* split: text + media */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,96px);
  align-items:center;
}
.split--reverse .split-media{ order:-1; }
.split-body .eyebrow{ margin-bottom:20px; }
.split-body h2{ margin-bottom:24px; }
.split-body .lead{ margin-bottom:28px; max-width:46ch; }
.split-body p + p{ margin-top:1.1em; }

/* media frame / placeholder */
.media{
  position:relative; border-radius:var(--radius); overflow:hidden;
  background:var(--ink-soft);
  aspect-ratio:4/3;
}
.media img{ width:100%; height:100%; object-fit:cover; }
.media--tall{ aspect-ratio:3/4; }
.media--wide{ aspect-ratio:16/10; }
.placeholder{
  position:relative; width:100%; height:100%;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 12px, transparent 12px 24px),
    var(--ink-soft);
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line-on-ink);
}
.placeholder span{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.45);
  border:1px solid var(--line-on-ink); padding:.6em 1em; border-radius:2px;
  background:rgba(13,14,17,.4);
}
.media .tag{
  position:absolute; left:14px; bottom:14px; z-index:2;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--paper); background:rgba(13,14,17,.6); padding:.45em .8em; border-radius:2px;
  backdrop-filter:blur(4px);
}

/* ---------- stats band ---------- */
.stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line-on-ink);
  border:1px solid var(--line-on-ink);
}
.stat{ background:var(--ink); padding:clamp(28px,3.5vw,46px) clamp(22px,2.5vw,34px); }
.stat .num{ font-size:clamp(2.4rem,4.2vw,3.6rem); font-weight:800; letter-spacing:-.04em; line-height:1; }
.stat .num small{ font-size:.4em; font-weight:600; color:var(--accent); margin-left:.15em; letter-spacing:0; }
.stat .label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.55); margin-top:16px; line-height:1.4; }
.stats.on-paper{ background:var(--line); border-color:var(--line); }
.stats.on-paper .stat{ background:var(--paper); }
.stats.on-paper .num{ color:var(--ink); }
.stats.on-paper .label{ color:var(--muted); }

/* ---------- feature trio ---------- */
.features{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.feature{ background:var(--paper); padding:clamp(30px,3vw,46px); display:flex; flex-direction:column; gap:18px; transition:background .35s var(--ease); }
.feature:hover{ background:var(--paper-2); }
.feature .idx{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; color:var(--accent-deep); }
.feature .ico{ width:34px; height:34px; color:var(--ink); }
.feature h3{ font-size:1.3rem; }
.feature p{ color:var(--muted); font-size:.97rem; line-height:1.6; }
.on-ink .features{ background:var(--line-on-ink); border-color:var(--line-on-ink); }
.on-ink .feature{ background:var(--ink); }
.on-ink .feature:hover{ background:var(--ink-soft); }
.on-ink .feature .ico{ color:var(--paper); }
.on-ink .feature p{ color:rgba(255,255,255,.62); }

/* ---------- markets grid ---------- */
.markets{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.market{ background:var(--paper-2); padding:clamp(26px,2.6vw,36px); display:flex; flex-direction:column; gap:14px; min-height:200px; transition:background .35s var(--ease),color .35s var(--ease); }
.market:hover{ background:var(--ink); color:var(--paper); }
.market .m-head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; }
.market .m-code{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; color:var(--accent-deep); }
.market:hover .m-code{ color:var(--accent); }
.market h3{ font-size:1.25rem; margin-top:auto; }
.market p{ font-size:.92rem; color:var(--muted); line-height:1.55; }
.market:hover p{ color:rgba(255,255,255,.66); }
.market .m-tags{ display:flex; flex-wrap:wrap; gap:6px; }
.market .m-tags span{ font-family:var(--mono); font-size:.62rem; letter-spacing:.08em; text-transform:uppercase; border:1px solid var(--line); padding:.35em .6em; border-radius:2px; color:var(--muted); }
.market:hover .m-tags span{ border-color:var(--line-on-ink); color:rgba(255,255,255,.7); }

/* ---------- team ---------- */
.team{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,2vw,30px); }
.member .portrait{ aspect-ratio:3/4; border-radius:var(--radius); overflow:hidden; margin-bottom:18px; }
.member .ph{
  width:100%; height:100%;
  background:repeating-linear-gradient(135deg, rgba(13,14,17,.05) 0 10px, transparent 10px 20px), var(--ink-soft);
  display:flex; align-items:flex-end; padding:14px;
}
.member .ph span{ font-family:var(--mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.member h3{ font-size:1.12rem; letter-spacing:-.01em; }
.member .role{ font-family:var(--mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--accent-deep); margin-top:6px; }

/* ---------- list rows (responsibilities etc) ---------- */
.rows{ border-top:1px solid var(--line); }
.row-item{
  display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start;
  padding:22px 0; border-bottom:1px solid var(--line);
}
.row-item .marker{ font-family:var(--mono); font-size:.72rem; color:var(--accent-deep); letter-spacing:.1em; padding-top:.3em; }
.row-item p{ font-size:1.02rem; color:var(--ink-700); }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; }
.cta-band .container{ position:relative; z-index:2; }
.cta-inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:36px; }
.cta-inner h2{ max-width:18ch; }
.cta-canvas{ position:absolute; inset:0; opacity:.4; z-index:0; }

/* ============================================================
   FORMS
   ============================================================ */
.form-card{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(28px,3.4vw,48px); }
.form-card h3{ font-size:1.5rem; margin-bottom:6px; }
.form-card .form-sub{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:30px; }
.field{ margin-bottom:22px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
label.flabel{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-700); margin-bottom:9px; }
label.flabel .req{ color:var(--accent-deep); }
.input,.textarea,select.input{
  width:100%; font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:.95em 1em; transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.input:focus,.textarea:focus,select.input:focus{ outline:none; border-color:var(--ink); box-shadow:0 0 0 3px var(--accent-glow); }
.textarea{ resize:vertical; min-height:130px; }
.hint{ font-size:.82rem; color:var(--muted-2); margin-top:8px; }
.filebox{ display:flex; align-items:center; gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--white); }
.filebox label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; padding:.95em 1.2em; background:var(--ink); color:var(--paper); cursor:pointer; white-space:nowrap; }
.filebox .fname{ padding:.95em 1.1em; color:var(--muted); font-size:.92rem; }
.form-success{ display:none; padding:1em 1.2em; background:var(--ink); color:var(--paper); font-family:var(--mono); font-size:.8rem; letter-spacing:.06em; border-radius:var(--radius); margin-top:8px; }

/* contact info list */
.contact-list{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); }
.contact-row{ padding:26px 0; border-bottom:1px solid var(--line); display:grid; grid-template-columns:140px 1fr; gap:24px; align-items:baseline; }
.contact-row .ck{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-deep); }
.contact-row .cv{ font-size:1.18rem; letter-spacing:-.01em; }
.contact-row .cv a:hover{ color:var(--accent-deep); }
.contact-row .cv .sub{ display:block; color:var(--muted); font-size:1rem; margin-top:2px; }

/* job list cards */
.jobs{ display:flex; flex-direction:column; }
.job{
  display:grid; grid-template-columns:auto 1fr auto; gap:clamp(20px,4vw,60px); align-items:center;
  padding:clamp(26px,3vw,40px) 0; border-top:1px solid var(--line);
  transition:padding-left .4s var(--ease);
}
.job:last-child{ border-bottom:1px solid var(--line); }
.job:hover{ padding-left:14px; }
.job .j-code{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; color:var(--accent-deep); }
.job .j-main h3{ font-size:clamp(1.5rem,2.4vw,2.1rem); margin-bottom:8px; }
.job .j-main p{ color:var(--muted); max-width:60ch; font-size:.98rem; }
.job .j-meta{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.job .j-meta span{ font-family:var(--mono); font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; border:1px solid var(--line); padding:.4em .7em; border-radius:2px; color:var(--muted); }
.job .j-go{ width:54px; height:54px; border:1px solid var(--ink); border-radius:50%; display:flex; align-items:center; justify-content:center; flex:none; transition:background .35s var(--ease),color .35s var(--ease); }
.job:hover .j-go{ background:var(--ink); color:var(--paper); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--ink); color:var(--paper); padding-top:clamp(64px,7vw,100px); }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:clamp(28px,4vw,56px); padding-bottom:clamp(48px,6vw,80px); }
.footer-brand .brand-name{ color:var(--paper); }
.footer-brand p{ color:rgba(255,255,255,.55); max-width:34ch; margin-top:20px; font-size:.95rem; }
.footer-col h4{ font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.45); font-weight:500; margin-bottom:22px; }
.footer-col ul{ list-style:none; display:flex; flex-direction:column; gap:13px; }
.footer-col a{ color:rgba(255,255,255,.78); font-size:.95rem; transition:color .25s var(--ease); }
.footer-col a:hover{ color:var(--accent); }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between; align-items:center; padding-block:28px; border-top:1px solid var(--line-on-ink); }
.footer-bottom p{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; color:rgba(255,255,255,.45); }
.footer-bottom .legal{ display:flex; gap:24px; }
.footer-disc{ font-size:.74rem; color:rgba(255,255,255,.3); line-height:1.6; max-width:none; padding-bottom:30px; border-top:1px solid var(--line-on-ink); padding-top:24px; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  *{ animation:none !important; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .stats{ grid-template-columns:repeat(2,1fr); }
  .team{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; row-gap:40px; }
}
@media (max-width:860px){
  body{ font-size:16px; }
  .nav-links, .nav-cta .btn{ display:none; }
  .nav-toggle{ display:block; }
  .split{ grid-template-columns:1fr; gap:36px; }
  .split--reverse .split-media{ order:0; }
  .features,.markets{ grid-template-columns:1fr; }
  .job{ grid-template-columns:auto 1fr; }
  .job .j-go{ display:none; }
  .field-row{ grid-template-columns:1fr; }
  .contact-row{ grid-template-columns:1fr; gap:6px; }

  /* mobile menu */
  .nav-links{
    position:fixed; inset:78px 0 auto 0;
    background:var(--ink); flex-direction:column; align-items:flex-start;
    gap:0; padding:12px var(--gutter) 30px;
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:opacity .3s var(--ease), transform .3s var(--ease);
    border-bottom:1px solid var(--line-on-ink);
  }
  body.nav-open .nav-links{ display:flex; transform:none; opacity:1; pointer-events:auto; }
  .nav-links a{ color:rgba(255,255,255,.8); font-size:.95rem; padding:16px 0; width:100%; border-bottom:1px solid var(--line-on-ink); }
  .nav-links a.active::after{ display:none; }
  body.nav-open .nav-cta .btn{ display:inline-flex; }
}
@media (max-width:560px){
  .stats{ grid-template-columns:1fr; }
  .team{ grid-template-columns:1fr 1fr; }
  .footer-top{ grid-template-columns:1fr; }
  .hero-meta{ gap:24px; }
  .cta-inner{ flex-direction:column; align-items:flex-start; }
}
