/* ── VELANTIS LIGHT THEME ─────────────────────────────────── */
:root {
  --bg:     #F5F2EC;
  --bg2:    #EDEAE3;
  --bg3:    #E4E0D8;
  --white:  #FFFFFF;
  --ink:    #111820;
  --ink2:   #2C3A44;
  --muted:  #6B7A82;
  --rule:   #D8D3CA;
  --gold:   #9E7545;
  --dk:     #14303E;
  --dk2:    #1C3A4A;
  --ch:     #F5F2EC;
  --dim:    rgba(245,242,236,.52);
  --dim2:   rgba(245,242,236,.22);
  --fd: 'Cormorant Garamond', Georgia, serif;
  --fb: 'Jost', system-ui, sans-serif;
  --fm: 'DM Mono', 'Courier New', monospace;
  --f0: 10px;  --f1: 13px;  --f2: 16px;  --f3: 20px;
  --f4: 28px;  --f5: 40px;  --f6: clamp(44px,6vw,78px);
  --s2: 16px;  --s3: 24px;  --s4: 32px;  --s5: 48px;
  --s6: 64px;  --s7: 88px;  --s8: 120px;
  --pad: 52px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
img { display: block; max-width: 100%; }
a { text-decoration: none; }
button { cursor: pointer; border: none; background: none; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--fb);
  font-size: var(--f2);
  font-weight: 400;
  line-height: 1.75;
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* NAV — light */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 58px; display: flex; align-items: center;
  justify-content: space-between; padding: 0 var(--pad);
  background: rgba(245,242,236,.96);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--rule);
}
.nav-logo {
  font-family: var(--fm); font-size: var(--f0);
  letter-spacing: .24em; text-transform: uppercase;
  color: var(--ink); display: flex; align-items: center; gap: 18px;
}
.nav-coord {
  font-size: 9px; color: var(--muted);
  padding-left: 18px; border-left: 1px solid var(--rule);
}
.nav-links { display: flex; gap: 32px; }
.nav-links a {
  font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em;
  text-transform: uppercase; color: var(--muted); transition: color .2s;
}
.nav-links a:hover, .nav-links a.cur { color: var(--ink); }
.nav-r { display: flex; align-items: center; gap: 18px; }
.nav-ghost {
  font-family: var(--fm); font-size: 9px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--rule); transition: color .2s;
}
.nav-ghost:hover { color: var(--muted); }
.nav-cta {
  font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em;
  text-transform: uppercase; color: var(--white);
  background: var(--ink); padding: 8px 20px; transition: background .2s;
}
.nav-cta:hover { background: var(--gold); }

/* HERO — always dark with image */
.hero {
  height: 100vh; min-height: 580px;
  position: relative; display: flex; flex-direction: column;
}
.hero-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center 38%;
  filter: brightness(.28) saturate(.5);
}
.hero-body {
  position: relative; z-index: 1; flex: 1;
  display: flex; align-items: flex-end;
  padding: 0 var(--pad) var(--s7);
  padding-top: 58px;
}
.hero-text { max-width: 560px; }
.hero-pre {
  font-family: var(--fm); font-size: var(--f0);
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: var(--s4);
}
.hero-h1 {
  font-family: var(--fd); font-size: var(--f6);
  font-weight: 300; line-height: 1.06; letter-spacing: -.02em;
  color: var(--ch); margin-bottom: var(--s4);
}
.hero-h1 em { font-style: italic; color: var(--dim); }
.hero-p {
  font-size: var(--f2); line-height: 1.7; color: var(--dim);
  max-width: 400px; margin-bottom: var(--s5);
}
.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }
.btn-hero {
  font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em;
  text-transform: uppercase; background: var(--ch); color: var(--ink);
  padding: 13px 28px; transition: background .2s; display: inline-block;
}
.btn-hero:hover { background: var(--gold); color: var(--white); }
.btn-ghost {
  font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em;
  text-transform: uppercase; background: transparent; color: var(--dim);
  padding: 13px 28px; border: 1px solid rgba(245,242,236,.25);
  transition: all .2s; display: inline-block;
}
.btn-ghost:hover { color: var(--ch); border-color: rgba(245,242,236,.6); }

/* HERO STAT BAR */
.hbar {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: repeat(4,1fr);
  border-top: 1px solid rgba(245,242,236,.1);
}
.hb {
  padding: 18px var(--s4); border-right: 1px solid rgba(245,242,236,.1);
}
.hb:last-child { border-right: none; }
.hb-v {
  font-family: var(--fd); font-size: var(--f5);
  font-weight: 300; line-height: 1; color: var(--ch); margin-bottom: 4px;
}
.hb-l {
  font-family: var(--fm); font-size: var(--f0);
  letter-spacing: .14em; text-transform: uppercase; color: var(--dim2);
}

/* PAGE HEADER — image version */
.ph {
  padding: calc(58px + var(--s6)) var(--pad) var(--s6);
  background: var(--dk); color: var(--ch);
  position: relative; overflow: hidden; min-height: 280px;
}
.ph img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; filter: brightness(.2) saturate(.4);
}
.ph-c { position: relative; z-index: 1; max-width: 640px; }

/* PAGE HEADER — no image */
.ph-bare {
  padding: calc(58px + var(--s7)) var(--pad) var(--s7);
  background: var(--dk);
  border-bottom: 1px solid rgba(255,255,255,.07);
  min-height: 260px;
  display: flex;
  align-items: flex-end;
}

.ph-pre {
  font-family: var(--fm); font-size: var(--f0);
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: var(--s3);
}
.ph-h1 {
  font-family: var(--fd); font-size: clamp(40px,5vw,68px);
  font-weight: 300; letter-spacing: -.02em; line-height: 1.06;
  margin-bottom: var(--s3);
}
.ph-h1 em { font-style: italic; }
.ph-p { font-size: var(--f2); line-height: 1.7; max-width: 500px; }
.ph .ph-p { color: var(--dim); }
.ph-bare .ph-h1 { color: var(--ch); }
.ph-bare .ph-p { color: var(--dim); }

/* SECTIONS */
.sec  { padding: var(--s8) 0; }
.sec-sm { padding: var(--s7) 0; }
.s-white { background: var(--white); }
.s-bg    { background: var(--bg); }
.s-bg2   { background: var(--bg2); }
.s-bg3   { background: var(--bg3); }
.s-dk    { background: var(--dk);  color: var(--ch); }
.s-dk2   { background: var(--dk2); color: var(--ch); }
.s-gold  { background: var(--gold); color: var(--white); }

/* WRAP */
.wrap {
  width: 100%; max-width: 1140px;
  margin: 0 auto; padding: 0 var(--pad);
}

/* TYPOGRAPHY */
.eyebrow {
  font-family: var(--fm); font-size: var(--f0);
  letter-spacing: .18em; text-transform: uppercase; color: var(--gold);
  display: flex; align-items: center; gap: 14px; margin-bottom: var(--s3);
}
.eyebrow::before {
  content: ''; display: inline-block; width: 14px; height: 1px;
  background: currentColor; flex-shrink: 0;
}
.h2 {
  font-family: var(--fd); font-size: var(--f5);
  font-weight: 300; letter-spacing: -.02em; line-height: 1.1;
}
.h2 em { font-style: italic; }
.h3 {
  font-family: var(--fd); font-size: var(--f4);
  font-weight: 400; letter-spacing: -.01em; line-height: 1.2;
}
.body  { font-size: var(--f2); line-height: 1.75; color: var(--ink2); }
.small { font-size: var(--f1); line-height: 1.65; color: var(--muted); }
.lbl   { font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em; text-transform: uppercase; color: var(--muted); }
.dim-t { color: var(--dim); }

/* GRID */
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s7); align-items: start; }
.g3 { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s4); }
.g4 { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--s4); }

/* SPLIT PANELS */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--rule); }
.panel { padding: var(--s7) var(--s6); background: var(--white); }
.panel-bg  { background: var(--bg2); }
.panel-bg3 { background: var(--bg3); }
.panel-dk  { background: var(--dk);  color: var(--ch); padding: var(--s7) var(--s6); }

/* STAT QUAD */
.squat { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--rule); }
.sq { padding: var(--s5) var(--s4); background: var(--bg2); }
.sq-v { font-family: var(--fd); font-size: var(--f5); font-weight: 300; line-height: 1; margin-bottom: 4px; }
.sq-l { font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em; text-transform: uppercase; color: var(--muted); }

/* STEPS */
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--rule); }
.step {
  padding: var(--s6) var(--s4); background: var(--white);
  border-top: 2px solid transparent; transition: border-color .2s;
}
.step:hover { border-top-color: var(--gold); }
.step-n { font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em; color: var(--gold); margin-bottom: var(--s3); }
.step-t { font-family: var(--fd); font-size: var(--f4); font-weight: 400; letter-spacing: -.01em; line-height: 1.2; margin-bottom: var(--s2); }
.step-b { font-size: var(--f1); line-height: 1.7; color: var(--muted); }

/* TABLE */
.tbl { width: 100%; border-collapse: collapse; }
.tbl thead tr { border-bottom: 2px solid var(--rule); }
.tbl th {
  font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em;
  text-transform: uppercase; color: var(--muted); padding: 0 0 var(--s3);
  text-align: left; font-weight: 400;
}
.tbl tbody tr { border-bottom: 1px solid var(--rule); transition: background .12s; cursor: pointer; }
.tbl tbody tr:hover { background: var(--bg2); }
.tbl td { padding: var(--s3) 0; vertical-align: middle; }

/* TIERS */
.tiers { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--rule); }
.tier { background: var(--white); padding: var(--s6) var(--s4); border-top: 2px solid transparent; transition: border-color .2s; }
.tier:hover { border-top-color: var(--rule); }
.tier-f { background: var(--dk); color: var(--ch); border-top-color: var(--gold); }
.t-n { font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em; color: var(--gold); margin-bottom: var(--s3); }
.t-nm { font-family: var(--fd); font-size: var(--f5); font-weight: 300; letter-spacing: -.02em; line-height: 1; margin-bottom: 4px; color: var(--ink); }
.tier-f .t-nm { color: var(--ch); }
.t-tg { font-family: var(--fm); font-size: var(--f0); letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: var(--s4); }
.tier-f .t-tg { color: var(--dim2); }
.t-fe { font-family: var(--fd); font-size: var(--f3); font-weight: 300; margin-bottom: var(--s4); padding-bottom: var(--s4); border-bottom: 1px solid var(--rule); color: var(--ink2); }
.tier-f .t-fe { border-color: rgba(245,242,236,.1); color: var(--dim); }
.t-b { font-size: var(--f1); line-height: 1.6; margin-bottom: 9px; padding-left: 13px; position: relative; color: var(--ink2); }
.tier-f .t-b { color: var(--dim); }
.t-b::before { content: ''; position: absolute; left: 0; top: 8px; width: 4px; height: 1px; background: var(--gold); }
.t-cta {
  display: block; margin-top: var(--s5); font-family: var(--fm);
  font-size: var(--f0); letter-spacing: .15em; text-transform: uppercase;
  text-align: center; padding: 12px; border: 1px solid var(--rule);
  color: var(--ink); transition: all .2s;
}
.tier-f .t-cta { background: var(--gold); color: var(--white); border-color: var(--gold); }
.tier-f .t-cta:hover { background: #8A6438; }
.t-cta:hover { border-color: var(--gold); color: var(--gold); }

/* CONTACT ROWS */
.crow { display: flex; align-items: flex-start; gap: var(--s4); padding: 14px 0; border-bottom: 1px solid var(--rule); }
.crow:last-child { border-bottom: none; }
.c-l { font-family: var(--fm); font-size: var(--f0); letter-spacing: .14em; text-transform: uppercase; color: var(--gold); min-width: 88px; padding-top: 2px; }
.c-v { font-size: var(--f1); color: var(--muted); line-height: 1.6; }
.c-v a { color: inherit; transition: color .15s; }
.c-v a:hover { color: var(--ink); }
/* Dark variant */
.crow-dk { border-color: rgba(245,242,236,.1); }
.crow-dk .c-v { color: var(--dim); }
.crow-dk .c-v a:hover { color: var(--ch); }

/* FORM */
.fg2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
.fg1 { display: flex; flex-direction: column; gap: 6px; }
.fg1.full { grid-column: 1 / -1; }
.f-lbl { font-family: var(--fm); font-size: var(--f0); letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.f-i, .f-s, .f-t {
  width: 100%; background: var(--white); border: 1px solid var(--rule);
  color: var(--ink); padding: 11px 14px; font-family: var(--fb);
  font-size: var(--f2); font-weight: 400; outline: none;
  transition: border-color .2s; appearance: none;
}
.f-i:focus, .f-s:focus, .f-t:focus { border-color: var(--gold); }
.f-i::placeholder { color: var(--muted); }
.f-t { resize: vertical; min-height: 88px; }
.f-sub {
  width: 100%; background: var(--ink); color: var(--white); border: none;
  padding: 13px; font-family: var(--fm); font-size: var(--f0);
  letter-spacing: .18em; text-transform: uppercase;
  cursor: pointer; margin-top: var(--s3); transition: background .2s;
}
.f-sub:hover { background: var(--gold); }

/* BUTTONS */
.btn {
  font-family: var(--fm); font-size: var(--f0); letter-spacing: .15em;
  text-transform: uppercase; display: inline-block;
  padding: 13px 28px; transition: all .2s;
}
.btn-dk  { background: var(--ink);  color: var(--white); }
.btn-dk:hover  { background: var(--gold); }
.btn-gd  { background: var(--gold); color: var(--white); }
.btn-gd:hover  { background: #8A6438; }
.btn-out { background: transparent; color: var(--muted); border: 1px solid var(--rule); }
.btn-out:hover { border-color: var(--gold); color: var(--gold); }
.btn-chalk { background: var(--ch); color: var(--ink); }
.btn-chalk:hover { background: var(--gold); color: var(--white); }

/* FOOTER */
footer {
  background: var(--ink); color: var(--ch);
  padding: var(--s7) var(--pad) var(--s4);
}
.foot-g {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--s6);
  padding-bottom: var(--s5); border-bottom: 1px solid rgba(245,242,236,.08);
  margin-bottom: var(--s3);
}
.f-br { font-family: var(--fm); font-size: var(--f0); letter-spacing: .22em; text-transform: uppercase; margin-bottom: 5px; }
.f-tg { font-family: var(--fd); font-size: var(--f3); font-weight: 300; font-style: italic; color: rgba(245,242,236,.28); margin-bottom: var(--s3); }
.f-co { font-family: var(--fm); font-size: 9px; letter-spacing: .1em; color: rgba(245,242,236,.16); line-height: 1.8; }
.f-ct { font-family: var(--fm); font-size: var(--f0); letter-spacing: .18em; text-transform: uppercase; color: rgba(245,242,236,.22); margin-bottom: var(--s3); }
.f-lk { display: block; font-size: var(--f1); color: rgba(245,242,236,.38); margin-bottom: 8px; transition: color .15s; }
.f-lk:hover { color: var(--ch); }
.f-bt { display: flex; justify-content: space-between; align-items: center; font-family: var(--fm); font-size: 9px; letter-spacing: .08em; color: rgba(245,242,236,.18); }
.f-si { color: rgba(245,242,236,.18); transition: color .15s; }
.f-si:hover { color: rgba(245,242,236,.45); }
.f-dc { font-size: 9px; color: rgba(245,242,236,.13); margin-top: var(--s3); line-height: 1.7; max-width: 620px; letter-spacing: .03em; }

/* REVEAL */
.rv { opacity: 0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease; }
.rv.on { opacity: 1; transform: none; }
.d1 { transition-delay: .1s; } .d2 { transition-delay: .2s; } .d3 { transition-delay: .3s; }

/* TICKER */
.tick-wrap { height: 38px; background: var(--bg3); border-bottom: 1px solid var(--rule); overflow: hidden; display: flex; align-items: center; }
.tick-track { display: flex; animation: ticker 36s linear infinite; white-space: nowrap; }
.tick-item { font-family: var(--fm); font-size: var(--f0); letter-spacing: .14em; text-transform: uppercase; color: var(--muted); padding: 0 40px; display: flex; align-items: center; gap: 40px; }
.tick-item::after { content: ''; width: 3px; height: 3px; border-radius: 50%; background: var(--gold); opacity: .5; flex-shrink: 0; }
@keyframes ticker { to { transform: translateX(-50%); } }

/* RESPONSIVE */
@media (max-width: 1024px) { :root { --pad: 36px; } }
@media (max-width: 768px) {
  :root { --pad: 22px; --f6: clamp(38px,9vw,60px); --s8: 88px; }
  .nav-links { display: none; }
  .g2, .split { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr 1fr; }
  .tiers { grid-template-columns: 1fr; }
  .g3 { grid-template-columns: 1fr; }
  .hbar, .hbar.hbar { grid-template-columns: 1fr 1fr; }
  .foot-g { grid-template-columns: 1fr 1fr; gap: var(--s4); }
  footer { padding: var(--s6) var(--pad) var(--s3); }
  .panel, .panel-bg, .panel-dk, .panel-bg3 { padding: var(--s6) var(--s4); }
  .squat { grid-template-columns: 1fr 1fr; }
  .fg2 { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .steps { grid-template-columns: 1fr; }
  .foot-g { grid-template-columns: 1fr; }
  .hero-btns { flex-direction: column; }
  .btn-hero, .btn-ghost { text-align: center; display: block; }
}
.ph-bare .ph-pre { color: var(--gold); }
