/* =====================================================
   ThreatBlock — Shared design system
   ===================================================== */

:root{
  --ink:#0E100D;
  --ink-2:#1A1D18;
  --ink-3:#2A2E27;
  --cream:#F2EDE2;
  --cream-2:#E8E1D2;
  --paper:#FAF6EC;
  --moss:#2DD4A6;
  --moss-deep:#0E6F58;
  --amber:#E9A85C;
  --rust:#D96A4A;
  --line:rgba(242,237,226,.14);
  --line-ink:rgba(14,16,13,.12);
  --serif:'Instrument Serif', ui-serif, Georgia, serif;
  --sans:'Geist', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  font-size:17px;
  line-height:1.55;
  color:var(--cream);
  background:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--moss);color:var(--ink)}

/* ===== Layout ===== */
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
@media (max-width:640px){.wrap{padding:0 20px}}

/* ===== Typography ===== */
.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--moss);
  font-weight:500;
}
.eyebrow .dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--moss);margin-right:10px;vertical-align:middle;
  box-shadow:0 0 0 4px rgba(45,212,166,.18);
  animation:pulse 2.2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(45,212,166,.18)}
  50%{box-shadow:0 0 0 8px rgba(45,212,166,0)}
}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.02;margin:0}
h1{font-size:clamp(48px,7.2vw,108px)}
h2{font-size:clamp(36px,4.6vw,68px);line-height:1.05}
h3{font-size:clamp(24px,2.4vw,32px);line-height:1.15}
h4{font-size:22px;line-height:1.2}
.ital{font-style:italic;color:var(--amber)}

p{margin:0 0 1em}
.lede{font-size:clamp(18px,1.4vw,21px);line-height:1.55;color:var(--cream-2);max-width:58ch}

/* ===== Nav ===== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(14,16,13,.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 0;
}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:24px;letter-spacing:-.01em;color:var(--cream)}
.brand-mark{
  width:30px;height:30px;border-radius:7px;
  background:linear-gradient(135deg,var(--moss) 0%, var(--moss-deep) 100%);
  display:grid;place-items:center;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18), 0 6px 18px rgba(45,212,166,.25);
  flex-shrink:0;
}
.brand-mark svg{display:block}
.nav-links{display:flex;gap:34px;align-items:center;font-size:14.5px;color:var(--cream-2)}
.nav-links a{position:relative;transition:color .2s;padding:6px 0}
.nav-links a:hover{color:var(--cream)}
.nav-links a.current{color:var(--cream)}
.nav-links a.current::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;
  height:1px;background:var(--moss);
}
.nav-cta{
  font-family:var(--sans);font-weight:500;font-size:14px;
  padding:10px 18px;border-radius:999px;
  background:var(--cream);color:var(--ink) !important;
  transition:transform .2s, background .2s;
}
.nav-cta::after{display:none}
.nav-cta:hover{background:#fff;transform:translateY(-1px)}

/* Hamburger (mobile) */
.hamburger{
  display:none;flex-direction:column;cursor:pointer;
  background:none;border:none;padding:8px;gap:5px;
}
.hamburger span{
  display:block;width:24px;height:2px;background:var(--cream);
  transition:transform .3s, opacity .3s;
}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(-45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(45deg)}

@media (max-width:880px){
  .hamburger{display:flex}
  .nav-links{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;
    background:rgba(14,16,13,.96);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
    padding:20px 32px 28px;
    gap:18px;
    align-items:stretch;
  }
  .nav-links.show{display:flex}
  .nav-links a{font-size:16px;padding:8px 0}
  .nav-cta{text-align:center;margin-top:8px}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:500;font-size:15px;
  padding:15px 24px;border-radius:999px;
  transition:transform .2s, background .2s, border-color .2s;
  border:1px solid transparent;cursor:pointer;
  text-align:center;
}
.btn-primary{background:var(--moss);color:var(--ink)}
.btn-primary:hover{background:#3FE6B8;transform:translateY(-1px)}
.btn-ghost{border-color:var(--line);color:var(--cream)}
.btn-ghost:hover{border-color:var(--cream-2);background:rgba(242,237,226,.04)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translate(3px,-3px)}

/* ===== Section structure ===== */
section{padding:120px 0;position:relative}
@media (max-width:640px){section{padding:84px 0}}
.section-head{margin-bottom:64px;max-width:780px}
.section-head h2{margin-top:18px}
.section-head .lede{margin-top:24px}

/* ===== HOME HERO ===== */
.hero{
  position:relative;
  padding:90px 0 110px;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 70% 30%, #000 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 70% 30%, #000 0%, transparent 75%);
  opacity:.7;pointer-events:none;
}
.hero::after{
  content:"";position:absolute;
  top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(45,212,166,.16) 0%, transparent 65%);
  pointer-events:none;
}
.hero-grid{
  position:relative;
  display:grid;grid-template-columns:1.35fr .9fr;gap:64px;align-items:end;
}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:48px}}

.hero h1 .stroke{
  -webkit-text-stroke:1.2px var(--cream);
  color:transparent;font-style:italic;
}
.hero h1 .underlined{
  background-image:linear-gradient(transparent 75%, rgba(45,212,166,.55) 75%);
  background-size:100% 100%;background-repeat:no-repeat;
  padding:0 .04em;
}
.hero-eyebrow{margin-bottom:28px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.badge-501{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:6px 10px;border:1px solid var(--line);border-radius:999px;color:var(--cream-2);
}
.hero-sub{margin:36px 0 38px;font-size:clamp(18px,1.45vw,22px);line-height:1.5;color:var(--cream-2);max-width:54ch}
.hero-sub b{color:var(--cream);font-weight:500}

.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.trust-row{
  margin-top:44px;display:flex;gap:28px;flex-wrap:wrap;
  color:var(--cream-2);font-size:13.5px;
}
.trust-row span{display:inline-flex;align-items:center;gap:8px}
.trust-row .tick{color:var(--moss);font-weight:600}

/* Hero status card */
.status-card{
  position:relative;
  background:linear-gradient(180deg, rgba(242,237,226,.06) 0%, rgba(242,237,226,.02) 100%);
  border:1px solid var(--line);border-radius:18px;
  padding:26px;backdrop-filter:blur(8px);
}
.status-card::before{
  content:"";position:absolute;top:0;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg, transparent, var(--moss), transparent);
  opacity:.5;
}
.status-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.status-head .eyebrow{font-size:10.5px}
.status-time{font-family:var(--mono);font-size:11px;color:var(--cream-2);opacity:.7}
.status-rows{display:flex;flex-direction:column;gap:14px}
.status-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border:1px solid var(--line);border-radius:12px;
  background:rgba(14,16,13,.4);
}
.status-row .label{font-size:13.5px;color:var(--cream-2)}
.status-row .label small{display:block;font-family:var(--mono);font-size:10.5px;color:var(--cream-2);opacity:.6;margin-top:3px;letter-spacing:.06em}
.status-row .val{font-family:var(--serif);font-size:28px;color:var(--cream)}
.status-row .val .unit{font-family:var(--mono);font-size:11px;color:var(--moss);margin-left:4px;letter-spacing:.06em}
.status-row.blocked .val{color:var(--moss)}
.status-row.flagged .val{color:var(--amber)}
.scanline{margin-top:18px;height:2px;border-radius:2px;overflow:hidden;background:rgba(242,237,226,.08);position:relative}
.scanline::after{
  content:"";position:absolute;top:0;left:-30%;height:100%;width:30%;
  background:linear-gradient(90deg, transparent, var(--moss), transparent);
  animation:scan 2.4s linear infinite;
}
@keyframes scan{to{left:100%}}

/* "What's included" card list (consultancy variant) */
.included-list{
  list-style:none;padding:0;margin:0 0 22px;
  display:flex;flex-direction:column;gap:14px;
}
.included-list li{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 16px;border:1px solid var(--line);border-radius:12px;
  background:rgba(14,16,13,.4);
  font-size:14.5px;line-height:1.45;
}
.included-list li::before{
  content:"";flex-shrink:0;width:16px;height:16px;margin-top:2px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M2 7.5l3 3 7-7' stroke='%232DD4A6' stroke-width='1.7' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat center/contain;
}
.included-list li strong{color:var(--cream);font-weight:500;display:block;margin-bottom:2px;font-family:var(--serif);font-size:17px}
.included-list li span{color:var(--cream-2);font-size:13.5px}
.included-total{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:16px;border-top:1px solid var(--line);
  font-size:14px;color:var(--cream-2);
}
.included-total strong{font-family:var(--serif);font-size:24px;color:var(--moss);font-weight:400}

/* ===== PAGE HERO (sub-pages) ===== */
.page-hero{
  position:relative;
  padding:90px 0 80px;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 60% 70% at 80% 50%, #000 0%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 60% 70% at 80% 50%, #000 0%, transparent 80%);
  opacity:.6;pointer-events:none;
}
.page-hero .wrap{position:relative}
.page-hero .eyebrow{margin-bottom:24px;display:inline-flex;align-items:center}
.page-hero h1{font-size:clamp(44px,6vw,84px)}
.page-hero .lede{margin-top:28px;max-width:62ch}

/* ===== Ticker ===== */
.ticker{
  background:var(--ink-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;padding:14px 0;
}
.ticker-track{
  display:flex;gap:48px;
  animation:ticker 50s linear infinite;
  white-space:nowrap;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--cream-2);
}
.ticker span{display:inline-flex;align-items:center;gap:10px}
.ticker .tag{color:var(--moss);font-weight:600}
.ticker .tag.flag{color:var(--rust)}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ===== Reality / dark stat cards ===== */
.reality{background:var(--ink)}
.reality-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:24px}
@media (max-width:880px){.reality-grid{grid-template-columns:1fr}}
.stat-card{
  position:relative;padding:40px 32px 36px;
  border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg, rgba(242,237,226,.04), rgba(242,237,226,.01));
  transition:transform .3s ease, border-color .3s ease;
}
.stat-card:hover{transform:translateY(-4px);border-color:rgba(242,237,226,.28)}
.stat-card .num{
  font-family:var(--serif);font-size:clamp(76px,9vw,128px);line-height:1;
  color:var(--cream);display:flex;align-items:baseline;
}
.stat-card .num .pct{font-size:.5em;margin-left:6px;color:var(--moss)}
.stat-card .head{margin:14px 0 12px;font-family:var(--serif);font-size:22px;line-height:1.25;color:var(--cream)}
.stat-card p{color:var(--cream-2);font-size:14.5px;line-height:1.5;margin:0}
.stat-card .source{margin-top:18px;display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--cream-2);opacity:.55}
.stat-card.alt .num,.stat-card.alt .num .pct{color:var(--rust)}
.stat-card.warn .num,.stat-card.warn .num .pct{color:var(--amber)}

.reality-coda{
  margin-top:56px;padding:32px 36px;
  border-left:2px solid var(--moss);
  background:linear-gradient(90deg, rgba(45,212,166,.06), transparent);
  border-radius:0 14px 14px 0;
  font-family:var(--serif);font-size:clamp(22px,2.2vw,30px);line-height:1.35;color:var(--cream);
  max-width:920px;
}
.reality-coda em{color:var(--amber);font-style:italic}

/* ===== Offer (cream section) ===== */
.offer{background:var(--paper);color:var(--ink)}
.offer .eyebrow{color:var(--moss-deep)}
.offer .eyebrow .dot{background:var(--moss-deep);box-shadow:0 0 0 4px rgba(14,111,88,.15)}
.offer-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line-ink);
  border:1px solid var(--line-ink);border-radius:20px;overflow:hidden;
  margin-top:48px;
}
@media (max-width:980px){.offer-grid{grid-template-columns:1fr}}
.offer-card{
  background:var(--paper);padding:44px 36px 40px;
  display:flex;flex-direction:column;gap:18px;
  transition:background .3s;position:relative;
}
.offer-card:hover{background:#FFFCF4}
.offer-num{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--moss-deep);font-weight:500}
.offer-icon{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg, rgba(45,212,166,.18), rgba(14,111,88,.12));
  border:1px solid rgba(14,111,88,.22);
  display:grid;place-items:center;color:var(--moss-deep);
}
.offer-card h3{font-family:var(--serif);color:var(--ink)}
.offer-card ul{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:10px}
.offer-card li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:#2A2E27}
.offer-card li::before{
  content:"";flex-shrink:0;width:14px;height:14px;margin-top:4px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M2 7.5l3 3 7-7' stroke='%230E6F58' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat center/contain;
}

/* ===== Proof ===== */
.proof{background:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
@media (max-width:880px){.proof-grid{grid-template-columns:1fr;gap:48px}}
.proof-item{padding:24px 32px;border-right:1px solid var(--line);text-align:center}
.proof-item:last-child{border-right:none}
@media (max-width:880px){
  .proof-item{border-right:none;border-bottom:1px solid var(--line);padding-bottom:48px}
  .proof-item:last-child{border-bottom:none;padding-bottom:0}
}
.proof-num{font-family:var(--serif);font-size:clamp(72px,10vw,140px);line-height:1;color:var(--cream)}
.proof-num .accent{color:var(--moss)}
.proof-label{margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-2)}
.proof-desc{margin-top:8px;color:var(--cream-2);font-size:14px}

/* ===== Voices ===== */
.voices{background:var(--ink)}
.voices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media (max-width:980px){.voices-grid{grid-template-columns:1fr}}
.quote{
  position:relative;padding:38px 32px 32px;
  border:1px solid var(--line);border-radius:18px;
  background:linear-gradient(180deg, rgba(242,237,226,.035), rgba(242,237,226,.01));
  display:flex;flex-direction:column;gap:24px;
}
.quote::before{
  content:"\201C";
  position:absolute;top:-14px;left:24px;
  font-family:var(--serif);font-size:90px;line-height:1;color:var(--moss);
}
.quote p{font-family:var(--serif);font-size:22px;line-height:1.35;color:var(--cream);margin:0}
.quote-by{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line)}
.quote-by .avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg, var(--moss-deep), var(--moss));
  display:grid;place-items:center;
  font-family:var(--serif);font-size:18px;color:var(--ink);font-weight:600;
}
.quote-by .who{font-size:14px;color:var(--cream)}
.quote-by .who small{display:block;font-size:12.5px;color:var(--cream-2);opacity:.75;margin-top:2px}

/* ===== Eligibility checks (cream section) ===== */
.eligible{background:var(--paper);color:var(--ink)}
.eligible .eyebrow{color:var(--moss-deep)}
.eligible .eyebrow .dot{background:var(--moss-deep);box-shadow:0 0 0 4px rgba(14,111,88,.15)}
.check-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
@media (max-width:880px){.check-grid{grid-template-columns:1fr}}
.check{
  background:#fff;border:1px solid rgba(14,16,13,.08);border-radius:18px;
  padding:32px 28px;display:flex;flex-direction:column;gap:14px;
  position:relative;transition:transform .25s, box-shadow .25s;
}
.check:hover{transform:translateY(-3px);box-shadow:0 18px 40px -20px rgba(14,16,13,.15)}
.check .num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--moss-deep)}
.check h4{font-family:var(--serif);font-size:24px;color:var(--ink)}
.check p{font-size:14.5px;color:#3A3D34;margin:0}
.check .tag{
  position:absolute;top:24px;right:24px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(45,212,166,.14);color:var(--moss-deep);
  display:grid;place-items:center;
}

/* ===== Process / steps ===== */
.process{background:var(--ink)}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);
  border:1px solid var(--line);border-radius:18px;overflow:hidden;
  margin-top:48px;
}
@media (max-width:880px){.steps{grid-template-columns:1fr}}
.step{background:var(--ink);padding:36px 28px 32px;display:flex;flex-direction:column;gap:14px;position:relative}
.step-num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--moss)}
.step h4{font-family:var(--serif);color:var(--cream);font-size:24px;line-height:1.2}
.step p{color:var(--cream-2);font-size:14px;line-height:1.55;margin:0}
.step-week{
  position:absolute;top:24px;right:24px;
  font-family:var(--serif);font-size:46px;color:rgba(242,237,226,.12);line-height:1;
}

/* ===== Sectors (impact page) ===== */
.sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
@media (max-width:980px){.sector-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.sector-grid{grid-template-columns:1fr}}
.sector{
  padding:32px 28px;border:1px solid var(--line);border-radius:16px;
  background:linear-gradient(180deg, rgba(242,237,226,.04), rgba(242,237,226,.01));
  display:flex;flex-direction:column;gap:12px;
  transition:transform .25s, border-color .25s;
}
.sector:hover{transform:translateY(-3px);border-color:rgba(242,237,226,.24)}
.sector .num{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--moss)}
.sector h3{font-family:var(--serif);font-size:24px;color:var(--cream)}
.sector p{color:var(--cream-2);font-size:14px;margin:0}

/* ===== Team (about page) ===== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media (max-width:880px){.team-grid{grid-template-columns:1fr}}
.team-card{
  padding:32px 28px;border:1px solid var(--line);border-radius:18px;
  background:linear-gradient(180deg, rgba(242,237,226,.04), rgba(242,237,226,.01));
  display:flex;flex-direction:column;gap:16px;align-items:flex-start;
}
.team-photo{
  width:88px;height:88px;border-radius:50%;
  overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(135deg, var(--moss-deep), var(--ink-2));
  flex-shrink:0;
}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-role{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--moss)}
.team-card h3{font-family:var(--serif);font-size:24px;color:var(--cream)}
.team-card p{color:var(--cream-2);font-size:14.5px;margin:0}

/* ===== Mission/values grids ===== */
.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media (max-width:880px){.three-grid{grid-template-columns:1fr}}
.tile{
  padding:36px 30px;border:1px solid var(--line);border-radius:18px;
  background:linear-gradient(180deg, rgba(242,237,226,.04), rgba(242,237,226,.01));
  display:flex;flex-direction:column;gap:14px;
}
.tile .num{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--moss)}
.tile h3{font-family:var(--serif);font-size:26px;color:var(--cream);line-height:1.15}
.tile p{color:var(--cream-2);font-size:15px;line-height:1.55;margin:0}

/* ===== Contact page ===== */
.contact-section{background:var(--ink)}
.contact-grid{
  display:grid;grid-template-columns:1.6fr 1fr;gap:48px;
  margin-top:48px;
}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:32px}}

.contact-form{
  padding:36px 32px;
  border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg, rgba(242,237,226,.04), rgba(242,237,226,.01));
}
.contact-form h2{font-size:36px;margin-bottom:8px}
.contact-form .lede{font-size:15.5px;margin:0 0 28px;max-width:none}

.form-group{margin-bottom:20px}
.form-label{
  display:block;margin-bottom:8px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--cream-2);font-weight:500;
}
.form-input,.form-select,.form-textarea{
  width:100%;
  padding:14px 16px;
  font-family:var(--sans);font-size:15px;
  color:var(--cream);
  background:rgba(14,16,13,.5);
  border:1px solid var(--line);
  border-radius:10px;
  transition:border-color .2s, background .2s;
}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(242,237,226,.4)}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;border-color:var(--moss);
  background:rgba(14,16,13,.7);
}
.form-select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><path d='M3 5l4 4 4-4' stroke='%23E8E1D2' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;
  background-position:right 16px center;
  padding-right:42px;
}
.form-select option{background:var(--ink-2);color:var(--cream)}
.form-textarea{min-height:140px;resize:vertical;font-family:var(--sans)}
.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--rust)}
.form-error{display:block;margin-top:6px;font-size:12.5px;color:var(--rust)}

.g-recaptcha{margin:8px 0 4px}

.btn-send{
  width:100%;
  padding:16px 24px;border:none;border-radius:999px;
  font-family:var(--sans);font-weight:500;font-size:15px;
  background:var(--moss);color:var(--ink);
  cursor:pointer;transition:transform .2s, background .2s;
  margin-top:8px;
}
.btn-send:hover{background:#3FE6B8;transform:translateY(-1px)}

.contact-info{
  padding:36px 32px;
  border:1px solid var(--line);border-radius:20px;
  background:linear-gradient(180deg, rgba(242,237,226,.04), rgba(242,237,226,.01));
  display:flex;flex-direction:column;gap:32px;
  align-self:start;
}
.contact-method .label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--moss);margin-bottom:12px;
}
.contact-method h3{font-family:var(--serif);font-size:22px;color:var(--cream);margin-bottom:8px}
.contact-method p,.contact-method a{font-size:14.5px;color:var(--cream-2);line-height:1.6;margin:0}
.contact-method a{display:block;transition:color .2s}
.contact-method a:hover{color:var(--cream)}

/* ===== Final CTA ===== */
.final{background:linear-gradient(180deg, var(--ink) 0%, #0A0C09 100%);border-top:1px solid var(--line);text-align:center}
.final h2{margin:24px 0 28px;max-width:18ch;margin-left:auto;margin-right:auto}
.final .lede{margin:0 auto 40px;text-align:center}
.final-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final-meta{
  margin-top:48px;display:flex;gap:32px;justify-content:center;flex-wrap:wrap;
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--cream-2);opacity:.7;
}

/* ===== Success page ===== */
.success{
  min-height:60vh;
  display:flex;align-items:center;
  text-align:center;
}
.success-icon{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg, var(--moss), var(--moss-deep));
  display:grid;place-items:center;
  margin:0 auto 32px;
  box-shadow:0 12px 40px -10px rgba(45,212,166,.4);
}
.success h1{font-size:clamp(40px,5vw,72px)}
.success .lede{margin:24px auto 40px;text-align:center}
.success-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===== Footer ===== */
footer{background:#0A0C09;border-top:1px solid var(--line);padding:64px 0 40px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-col h5{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cream-2);opacity:.6;margin:0 0 16px;font-weight:500;
}
.foot-col p,.foot-col a{font-size:14.5px;color:var(--cream-2);line-height:1.6}
.foot-col a{display:block;transition:color .2s}
.foot-col a:hover{color:var(--cream)}
.foot-brand .brand{margin-bottom:18px}
.foot-brand p{font-size:14px;color:var(--cream-2);opacity:.75;max-width:34ch}
.foot-bottom{
  margin-top:56px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--cream-2);opacity:.6;
}
