/* ===== Endless Room — shared site styles ===== */
:root{
  --red:#E2231A;
  --obsidian:#060504;
  --obsidian-2:#0d0b0a;
  --obsidian-3:#16110f;
  --canvas:#F0EBE0;
  --graphite:#8a8782;
  --graphite-2:#5a5754;
  --line:rgba(240,235,224,0.14);
  --line-strong:rgba(240,235,224,0.26);
  --lime:#B8E62B; --coral:#FF6B5A; --violet:#8B5CF6; --sky:#38BDF8;
  --display:"Oswald","Archivo Narrow",system-ui,sans-serif;
  --display-alt:"Archivo",system-ui,sans-serif;
  --serif:"Fraunces",Georgia,serif;
  --body:"Epilogue","Inter",system-ui,sans-serif;
  --maxw:1180px;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{ background:var(--obsidian); color:var(--canvas); font-family:var(--body);
  font-weight:400; -webkit-font-smoothing:antialiased; line-height:1.6; overflow-x:hidden; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
section{ position:relative; }

/* type */
.kicker{ font-family:var(--display); font-weight:600; text-transform:uppercase;
  letter-spacing:.34em; font-size:11px; color:var(--red); display:inline-flex; align-items:center; gap:11px; }
.kicker .sq{ width:9px; height:9px; background:var(--red); display:inline-block; }
.kicker.muted{ color:var(--graphite); }
h1,h2,h3{ font-family:var(--display); font-weight:700; text-transform:uppercase; line-height:.95; letter-spacing:-.01em; }
h1{ font-size:clamp(44px,7.5vw,86px); line-height:.9; }
h2{ font-size:clamp(30px,4.6vw,52px); }
h3{ font-size:21px; font-weight:600; letter-spacing:.01em; }
.red{ color:var(--red); }
.grey{ color:var(--graphite); }
.lead{ font-size:clamp(16px,2.1vw,20px); line-height:1.55; color:rgba(240,235,224,0.9); max-width:62ch; }
.body{ font-size:15px; line-height:1.7; color:rgba(240,235,224,0.78); }
.body p+p{ margin-top:16px; }
.pull{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(22px,3.2vw,34px); line-height:1.3; }
.redrule{ width:64px; height:5px; background:var(--red); border:0; }
.center{ text-align:center; }

/* nav */
.topbar{ position:fixed; top:0; left:0; right:0; height:4px; background:var(--red); z-index:60; }
header.nav{ position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(6,5,4,0.72); backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent; transition:border-color .3s, background .3s; }
header.nav.scrolled{ border-bottom:1px solid var(--line); background:rgba(6,5,4,0.94); }
.nav .bar{ display:flex; align-items:center; justify-content:space-between; height:70px; }
.brand{ display:flex; align-items:baseline; gap:10px; }
.brand .inf{ color:var(--red); font-size:21px; font-weight:900; font-family:var(--display-alt); }
.brand .mark{ font-family:var(--display-alt); font-weight:800; font-size:19px; letter-spacing:.02em; }
.navlinks{ display:flex; align-items:center; gap:30px; }
.navlinks a{ font-family:var(--display); text-transform:uppercase; letter-spacing:.16em;
  font-size:12px; color:var(--graphite); transition:color .2s; position:relative; }
.navlinks a:hover{ color:var(--canvas); }
.navlinks a.active{ color:var(--canvas); }
.navlinks a.active:after{ content:""; position:absolute; left:0; right:0; bottom:-7px; height:2px; background:var(--red); }
.btn{ font-family:var(--display); text-transform:uppercase; letter-spacing:.14em; font-size:12px; font-weight:600;
  padding:12px 22px; border:1px solid var(--red); color:#fff; background:var(--red); transition:.2s; display:inline-block; cursor:pointer; }
.btn:hover{ background:transparent; color:var(--red); }
.btn.ghost{ background:transparent; color:var(--canvas); border-color:var(--line-strong); }
.btn.ghost:hover{ border-color:var(--canvas); }
.btn.lg{ padding:15px 30px; font-size:13px; }
.btn.dark{ color:var(--obsidian); border-color:rgba(6,5,4,.25); }
.btn.dark:hover{ background:var(--obsidian); color:#fff; border-color:var(--obsidian); }
.menutoggle{ display:none; background:none; border:0; color:var(--canvas); font-size:26px; cursor:pointer; }

/* page header (subpages) */
.pagehead{ padding:140px 0 56px;
  background:radial-gradient(110% 90% at 82% 0%, rgba(226,35,26,0.10), transparent 55%), var(--obsidian); }
.pagehead .crumb{ font-family:var(--display); text-transform:uppercase; letter-spacing:.2em; font-size:11px; color:var(--graphite); margin-bottom:18px; }
.pagehead .crumb a:hover{ color:var(--canvas); }
.pagehead h1{ font-size:clamp(40px,6vw,72px); margin:14px 0 22px; }

/* sections */
.sec{ padding:clamp(64px,9vw,118px) 0; }
.sec.tight{ padding:clamp(48px,6vw,80px) 0; }
.sec.light{ background:var(--canvas); color:var(--obsidian); }
.sec.light .lead{ color:#2b2724; }
.sec.light .body{ color:#3a3530; }
.sec.light .grey{ color:var(--graphite-2); }
.sec.light .kicker.muted{ color:var(--graphite-2); }
.sec.alt{ background:var(--obsidian-2); }
.sechead{ max-width:780px; margin-bottom:50px; }
.sechead.center{ margin-left:auto; margin-right:auto; }
.sechead h2{ margin:16px 0 18px; }

/* hero (home) */
.hero{ min-height:100vh; display:flex; align-items:center; padding:120px 0 70px;
  background:radial-gradient(120% 90% at 80% 10%, rgba(226,35,26,0.10), transparent 55%), var(--obsidian); }
.hero .ghost{ position:absolute; right:-4vw; top:8%; font-family:var(--display-alt); font-weight:900;
  font-size:48vw; line-height:.8; color:rgba(226,35,26,0.06); user-select:none; z-index:0; pointer-events:none; }
.hero .wrap{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.hero h1{ margin:18px 0 24px; }
.hero .cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-fig{ position:relative; }
.hero-fig img{ border:1px solid var(--line); box-shadow:0 40px 120px rgba(0,0,0,.6); }
.hero-fig .tag{ position:absolute; left:-14px; bottom:24px; background:var(--red); color:#fff;
  font-family:var(--display); text-transform:uppercase; letter-spacing:.2em; font-size:10px; padding:9px 14px; }

/* splits */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.split.rev .txt{ order:2; }
.split img{ border:1px solid var(--line); }
.sec.light .split img{ border-color:rgba(6,5,4,.12); }

.statline{ display:flex; gap:30px; margin-top:30px; flex-wrap:wrap; }
.stat .n{ font-family:var(--display-alt); font-weight:800; font-size:34px; color:var(--red); line-height:1; }
.stat .l{ font-size:12px; color:var(--graphite); text-transform:uppercase; letter-spacing:.14em; margin-top:6px; }

/* grids / cards */
.grid{ display:grid; gap:18px; }
.g2{ grid-template-columns:1fr 1fr; }
.g3{ grid-template-columns:repeat(3,1fr); }
.card{ background:var(--obsidian-2); border:1px solid var(--line); padding:26px 24px; position:relative; transition:.25s; }
.sec.alt .card{ background:var(--obsidian-3); }
.sec.light .card{ background:#fff; border-color:rgba(6,5,4,.1); }
.card:hover{ border-color:var(--red); transform:translateY(-3px); }
.card .num{ font-family:var(--display-alt); font-weight:800; font-size:15px; color:var(--red); letter-spacing:.1em; }
.card h3{ margin:14px 0 9px; }
.card p{ font-size:13.5px; color:rgba(240,235,224,0.7); line-height:1.6; }
.sec.light .card p{ color:#5a5754; }

.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.step{ border-top:3px solid var(--red); padding-top:18px; }
.step .s{ font-family:var(--display-alt); font-weight:800; font-size:13px; color:var(--graphite); letter-spacing:.18em; }
.step h3{ margin:10px 0 8px; }
.step p{ font-size:14px; color:rgba(240,235,224,0.74); }
.sec.light .step p{ color:#4a453f; }

/* phases bar */
.phases{ display:flex; gap:0; margin-top:26px; border:1px solid var(--line); }
.phase{ flex:1; padding:16px 14px; border-right:1px solid var(--line); }
.phase:last-child{ border-right:0; }
.phase .p{ font-family:var(--display-alt); font-weight:800; color:var(--red); font-size:13px; }
.phase .t{ font-family:var(--display); text-transform:uppercase; letter-spacing:.12em; font-size:12px; margin:8px 0 5px; }
.phase .d{ font-size:11.5px; color:var(--graphite); line-height:1.45; }

/* pricing */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:start; }
.tier{ background:#fff; border:1px solid rgba(6,5,4,0.12); padding:30px 26px; position:relative; }
.tier.feat{ border:2px solid var(--red); box-shadow:0 30px 80px rgba(0,0,0,.18); }
.tier .badge{ position:absolute; top:-12px; left:26px; background:var(--red); color:#fff;
  font-family:var(--display); text-transform:uppercase; letter-spacing:.16em; font-size:10px; padding:5px 12px; }
.tier .name{ font-family:var(--display); text-transform:uppercase; letter-spacing:.2em; font-size:14px; color:var(--graphite-2); }
.tier .price{ font-family:var(--display-alt); font-weight:800; font-size:46px; margin:10px 0 2px; color:var(--obsidian); }
.tier .price span{ font-size:15px; font-weight:600; color:var(--graphite-2); }
.tier .desc{ font-size:13px; color:#5a5754; margin:10px 0 20px; min-height:42px; }
.tier ul{ list-style:none; }
.tier li{ font-size:13.5px; padding:9px 0 9px 26px; position:relative; border-top:1px solid rgba(6,5,4,0.07); color:#2b2724; }
.tier li:before{ content:"●"; color:var(--red); position:absolute; left:0; font-size:10px; top:11px; }
.tier li.off{ color:#b6b2ab; }
.tier li.off:before{ content:"—"; color:#cfcabf; }
.tier .btn{ width:100%; text-align:center; margin-top:22px; }
.pricenote{ text-align:center; margin-top:26px; font-size:13px; color:var(--graphite-2); }

/* feature matrix */
.matrix{ width:100%; border-collapse:collapse; font-size:13.5px; margin-top:10px; }
.matrix th,.matrix td{ text-align:left; padding:13px 16px; border-bottom:1px solid rgba(6,5,4,.1); }
.matrix thead th{ font-family:var(--display); text-transform:uppercase; letter-spacing:.12em; font-size:12px; color:var(--graphite-2); }
.matrix td.c,.matrix th.c{ text-align:center; }
.matrix .yes{ color:var(--red); font-weight:700; }
.matrix .no{ color:#c9c4ba; }
.matrix tbody tr:hover{ background:rgba(6,5,4,.025); }

/* revenue list */
.revlist{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.rev{ border-left:4px solid var(--red); padding:16px 20px; background:var(--obsidian-2); }
.rev .n{ font-family:var(--display-alt); font-weight:800; color:var(--graphite); font-size:13px; letter-spacing:.1em; }
.rev h3{ margin:8px 0 6px; font-size:18px; }
.rev p{ font-size:13px; color:rgba(240,235,224,0.7); }

/* timeline */
.timeline{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.tl{ border-top:3px solid var(--red); padding-top:16px; }
.tl .s{ font-family:var(--display-alt); font-weight:800; color:var(--graphite); font-size:12px; letter-spacing:.16em; }
.tl h3{ font-size:16px; margin:9px 0 7px; }
.tl p{ font-size:12.5px; color:rgba(240,235,224,0.7); }

/* cta band */
.ctaband{ padding:clamp(70px,9vw,120px) 0; text-align:center;
  background:radial-gradient(100% 120% at 50% 0%, rgba(226,35,26,0.16), transparent 60%), var(--obsidian-2); }
.ctaband h2{ margin:18px auto 22px; max-width:18ch; }
.ctaband .lead{ margin:0 auto 34px; }

/* footer */
footer{ background:var(--obsidian); border-top:1px solid var(--line); padding:56px 0 36px; }
.foot{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:34px; }
.foot .col h4{ font-family:var(--display); text-transform:uppercase; letter-spacing:.2em; font-size:11px; color:var(--graphite); margin-bottom:14px; }
.foot .col a, .foot .col p{ display:block; font-size:13px; color:rgba(240,235,224,0.7); margin-bottom:9px; }
.foot .col a:hover{ color:var(--canvas); }
.foot .col a.ext:after{ content:" ↗"; color:var(--red); font-size:11px; }
.foot .blurb{ max-width:280px; }
.legal{ margin-top:42px; padding-top:22px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-family:var(--display); text-transform:uppercase; letter-spacing:.18em; font-size:10px; color:var(--graphite); }
.legal a:hover{ color:var(--canvas); }

/* reveal */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

@media(max-width:900px){
  .navlinks{ position:fixed; inset:70px 0 auto 0; background:var(--obsidian-2); flex-direction:column;
    gap:0; padding:0; border-bottom:1px solid var(--line); display:none; }
  .navlinks.open{ display:flex; }
  .navlinks a{ width:100%; padding:18px 24px; border-top:1px solid var(--line); font-size:14px; }
  .navlinks a.active:after{ display:none; }
  .navlinks .btn{ margin:16px 24px; width:calc(100% - 48px); text-align:center; }
  .menutoggle{ display:block; }
  .hero .wrap, .split, .split.rev .txt{ grid-template-columns:1fr; order:0; }
  .split{ grid-template-columns:1fr; }
  .hero-fig{ order:-1; }
  .steps, .tiers, .g3, .timeline, .revlist{ grid-template-columns:1fr; }
  .g2{ grid-template-columns:1fr; }
  .phases{ flex-wrap:wrap; }
  .phase{ flex:1 1 40%; border-right:0; border-bottom:1px solid var(--line); }
  .foot{ grid-template-columns:1fr 1fr; }
  .matrix{ font-size:12px; }
  .matrix th,.matrix td{ padding:10px 8px; }
}
@media(max-width:560px){ .foot{ grid-template-columns:1fr; } }
