/* Trueleveler · Marketing site · shared styles.
 * Pairs with design_handoff_trueleveler/dev_kit/tokens.css.
 * Self-contained — every marketing page imports just this file.
 */
@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700;800&family=Newsreader:ital,wght@1,400;1,500&family=JetBrains+Mono:wght@500;600;700&display=swap');

:root {
  --navy:#081522; --navy-mid:#0c1c2c; --navy-card:#0f2236; --navy-lift:#16304a;
  --line:rgba(255,255,255,0.09); --line2:rgba(255,255,255,0.18);
  --ink:#e9eef5; --ink-2:rgba(233,238,245,0.78); --ink-3:rgba(233,238,245,0.55); --ink-4:rgba(233,238,245,0.4);
  --amber:#e8871e; --amber-bright:#f7a340; --amber-soft:rgba(232,135,30,0.12); --amber-border:rgba(232,135,30,0.35);
  --ok:#5fb380; --risk:#ef6b6b; --info:#5b9bd5;
  --sans:'Inter Tight',-apple-system,sans-serif;
  --serif:'Newsreader',Georgia,serif;
  --mono:'JetBrains Mono',monospace;
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--navy); color:var(--ink); font-family:var(--sans); font-size:15px; line-height:1.55; }

img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
a:hover { color:var(--amber); }

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ── NAV ─────────────────────────────────────────────── */
.nav {
  position:sticky; top:0; z-index:50; background:rgba(8,21,34,0.92); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line); padding:14px 0;
}
.nav-inner { display:flex; align-items:center; gap:32px; max-width:1280px; margin:0 auto; padding:0 24px; }
.brand { font-weight:700; font-size:17px; letter-spacing:0.01em; color:var(--ink); display:flex; align-items:center; gap:8px; }
.brand-dot { width:9px; height:9px; border-radius:9px; background:var(--amber); }
.nav-links { display:flex; gap:2px; flex:1; }
.nav-link { padding:8px 12px; font-size:13px; color:var(--ink-2); border-radius:3px; transition:background 120ms, color 120ms; position:relative; }
.nav-link:hover { background:rgba(255,255,255,0.04); color:var(--ink); }
.nav-link.has-sub:after { content:'▾'; font-size:9px; color:var(--ink-4); margin-left:5px; }
.nav-link.active { color:var(--amber); }
.nav-link.dropdown-wrap { position:relative; }
.nav-link.dropdown-wrap:hover .dropdown { display:block; }
.dropdown {
  display:none; position:absolute; top:100%; left:0; min-width:260px;
  background:var(--navy-card); border:1px solid var(--line2); border-radius:4px; padding:6px;
  box-shadow:0 12px 36px rgba(0,0,0,0.45); margin-top:4px;
}
.dropdown-group { padding:8px 10px; font-family:var(--mono); font-size:9.5px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--ink-4); }
.dropdown-link { display:block; padding:7px 10px; font-size:13px; color:var(--ink-2); border-radius:3px; }
.dropdown-link:hover { background:rgba(255,255,255,0.04); color:var(--ink); }
.dropdown-link.featured { color:var(--amber); }
.dropdown-link .pill-mini { font-family:var(--mono); font-size:8px; letter-spacing:0.14em;
  text-transform:uppercase; padding:1px 5px; border-radius:2px; margin-left:8px; vertical-align:middle;
  background:var(--amber-soft); border:1px solid var(--amber-border); color:var(--amber); }
.dropdown-link .pill-mini.beta { background:rgba(95,179,128,0.1); border-color:rgba(95,179,128,0.3); color:var(--ok); }
.dropdown-link .pill-mini.soon { background:rgba(91,155,213,0.12); border-color:rgba(91,155,213,0.3); color:var(--info); }
.nav-cta { background:var(--amber); color:var(--navy); padding:8px 14px; border-radius:3px; font-weight:600;
  font-size:13px; transition:background 120ms; }
.nav-cta:hover { background:var(--amber-bright); color:var(--navy); }

/* ── HERO ────────────────────────────────────────────── */
.hero { padding:88px 0 64px; border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.hero:before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 800px 600px at 30% 100%, rgba(232,135,30,0.08), transparent 65%);
  pointer-events:none;
}
.kicker { font-family:var(--mono); font-size:11.5px; font-weight:600; letter-spacing:0.22em;
  color:var(--amber); text-transform:uppercase; margin-bottom:22px; }
.hero h1 { font-size:clamp(40px, 5.5vw, 72px); font-weight:600; line-height:1.02; letter-spacing:-0.025em;
  margin-bottom:24px; max-width:900px; }
.hero h1 em { font-family:var(--serif); font-style:italic; color:var(--amber); font-weight:500; display:block; }
.hero .lede { font-size:clamp(17px, 1.7vw, 21px); color:var(--ink-2); line-height:1.5; max-width:720px;
  margin-bottom:36px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.btn {
  display:inline-flex; align-items:center; gap:8px; padding:11px 18px; border-radius:3px;
  font-size:14px; font-weight:500; border:1px solid; transition:all 150ms;
}
.btn-primary { background:var(--amber); color:var(--navy); border-color:var(--amber); }
.btn-primary:hover { background:var(--amber-bright); border-color:var(--amber-bright); color:var(--navy); }
.btn-ghost { background:transparent; color:var(--ink); border-color:var(--line2); }
.btn-ghost:hover { background:rgba(255,255,255,0.04); color:var(--ink); }
.btn-icon { font-family:var(--mono); font-size:12px; }

/* ── STATS STRIP ─────────────────────────────────────── */
.stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:3px; overflow:hidden;
  max-width:800px; margin-top:48px; }
.stat { background:var(--navy-card); padding:22px 24px; }
.stat-num { font-family:var(--serif); font-style:italic; font-weight:500; font-size:38px;
  color:var(--amber); line-height:1; letter-spacing:-0.02em; }
.stat-lbl { font-family:var(--mono); font-size:10.5px; font-weight:600; letter-spacing:0.14em;
  color:var(--ink-3); text-transform:uppercase; margin-top:10px; }

/* ── SECTION ─────────────────────────────────────────── */
.section { padding:80px 0; border-bottom:1px solid var(--line); }
.section-tinted { background:rgba(232,135,30,0.025); }
.section-head { margin-bottom:48px; max-width:820px; }
.section-num { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.section-num-tag { font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:0.18em;
  color:var(--amber); text-transform:uppercase; }
.section-num-line { flex:1; height:1px; background:var(--line); max-width:200px; }
.section h2 { font-size:clamp(28px,3.5vw,42px); font-weight:600; line-height:1.1; letter-spacing:-0.02em;
  margin-bottom:18px; max-width:780px; }
.section h2 em { font-family:var(--serif); font-style:italic; color:var(--amber); font-weight:500; }
.section h3 { font-size:21px; font-weight:600; letter-spacing:-0.01em; margin-bottom:10px; }
.section p { color:var(--ink-2); font-size:16px; line-height:1.6; max-width:760px; margin-bottom:14px; }
.section p em { color:var(--amber); font-family:var(--serif); font-style:italic; }
.section ul { color:var(--ink-2); font-size:15.5px; line-height:1.65; max-width:720px; padding-left:0; list-style:none; }
.section ul li { padding:8px 0; padding-left:20px; position:relative; border-bottom:1px solid var(--line); }
.section ul li:last-child { border-bottom:none; }
.section ul li:before { content:'·'; position:absolute; left:6px; color:var(--amber); font-weight:800; }
.section ul li strong { color:var(--ink); font-weight:600; }

/* Grid blocks */
.grid-2 { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:18px; }
.grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; }
.grid-4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; }

.card { background:var(--navy-card); border:1px solid var(--line); border-radius:4px; padding:24px 26px; }
.card h3 { margin-bottom:8px; font-size:18px; }
.card p { font-size:14.5px; line-height:1.55; margin:0; color:var(--ink-2); }
.card .card-kicker { font-family:var(--mono); font-size:10px; letter-spacing:0.16em;
  color:var(--amber); text-transform:uppercase; margin-bottom:10px; }
.card-amber { background:var(--amber-soft); border-color:var(--amber-border); }
.card-amber h3 { color:var(--ink); }

/* Pairs-with sidebar */
.pairs-with {
  background:var(--navy-card); border:1px solid var(--line); border-radius:4px;
  padding:18px 20px; margin-top:32px;
}
.pairs-with .label { font-family:var(--mono); font-size:10px; letter-spacing:0.18em;
  color:var(--ink-3); text-transform:uppercase; margin-bottom:10px; }
.pairs-with a {
  display:inline-flex; align-items:center; gap:5px; padding:4px 10px; margin:3px 4px 3px 0;
  background:rgba(255,255,255,0.03); border:1px solid var(--line2); border-radius:2px;
  font-family:var(--mono); font-size:11px; color:var(--ink-2); transition:all 120ms;
}
.pairs-with a:hover { background:var(--amber-soft); border-color:var(--amber-border); color:var(--amber); }

/* Block quote / callout */
.callout {
  border-left:3px solid var(--amber); background:var(--amber-soft);
  padding:18px 22px; border-radius:3px; margin:18px 0;
}
.callout .callout-label { font-family:var(--mono); font-size:10px; letter-spacing:0.18em;
  color:var(--amber); text-transform:uppercase; margin-bottom:8px; }
.callout p { color:var(--ink); margin:0; font-size:15px; }

/* News card */
.news-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:16px; }
.news-card { background:var(--navy-card); border:1px solid var(--line); border-radius:6px; padding:22px; transition:all 150ms; }
.news-card:hover { border-color:var(--amber-border); transform:translateY(-2px); }
.news-tag { display:inline-block; font-family:var(--mono); font-size:9.5px; letter-spacing:0.18em;
  padding:3px 8px; border-radius:2px; margin-bottom:12px; text-transform:uppercase; font-weight:600; }
.news-tag.live { background:var(--amber-soft); color:var(--amber); border:1px solid var(--amber-border); }
.news-tag.beta { background:rgba(95,179,128,0.1); color:var(--ok); border:1px solid rgba(95,179,128,0.3); }
.news-tag.soon { background:rgba(91,155,213,0.12); color:var(--info); border:1px solid rgba(91,155,213,0.3); }
.news-tag.milestone { background:rgba(184,147,214,0.12); color:#b893d6; border:1px solid rgba(184,147,214,0.3); }
.news-date { font-family:var(--mono); font-size:11px; letter-spacing:0.14em; color:var(--ink-3); margin-bottom:10px; }
.news-card h3 { font-size:18px; margin-bottom:8px; letter-spacing:-0.01em; }
.news-card p { font-size:14px; color:var(--ink-2); line-height:1.55; margin:0; }
.news-link { display:inline-block; margin-top:14px; font-family:var(--mono); font-size:11px;
  letter-spacing:0.14em; color:var(--amber); text-transform:uppercase; font-weight:600; }

/* Phase strip — used on homepage + how-it-works */
.phase-strip { display:grid; grid-template-columns:repeat(5,1fr); gap:0; margin-top:32px;
  border:1px solid var(--line); border-radius:4px; overflow:hidden; }
.phase-cell { padding:20px 18px; background:var(--navy-card); border-right:1px solid var(--line); position:relative; }
.phase-cell:last-child { border-right:none; }
.phase-cell .phase-dot { width:9px; height:9px; border-radius:9px; display:inline-block; vertical-align:middle; margin-right:8px; }
.phase-cell .phase-name { font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-2); }
.phase-cell .phase-count { display:block; font-family:var(--serif); font-style:italic; font-size:28px;
  color:var(--amber); line-height:1; letter-spacing:-0.02em; margin-top:14px; }
.phase-cell .phase-engines { font-size:11.5px; color:var(--ink-3); line-height:1.55; margin-top:10px; }

/* Engine tile (homepage) */
.engine-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:10px; }
.engine-tile {
  background:var(--navy-card); border:1px solid var(--line); border-radius:4px;
  padding:16px 18px; transition:all 150ms; display:flex; gap:14px; align-items:flex-start;
}
.engine-tile:hover { border-color:var(--amber-border); }
.engine-tile .e-icon { width:30px; height:30px; border-radius:4px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.05); border:1px solid var(--line2); flex-shrink:0;
  font-family:var(--mono); font-size:13px; color:var(--amber); font-weight:700; }
.engine-tile .e-body { flex:1; min-width:0; }
.engine-tile .e-name { font-size:14px; font-weight:600; margin-bottom:3px; }
.engine-tile .e-status { display:inline-block; font-family:var(--mono); font-size:8.5px; letter-spacing:0.14em;
  text-transform:uppercase; padding:1px 5px; border-radius:2px; margin-left:6px; vertical-align:middle; }
.engine-tile .e-status.shipped { background:rgba(95,179,128,0.1); color:var(--ok); border:1px solid rgba(95,179,128,0.3); }
.engine-tile .e-status.beta { background:var(--amber-soft); color:var(--amber); border:1px solid var(--amber-border); }
.engine-tile .e-status.soon { background:rgba(91,155,213,0.12); color:var(--info); border:1px solid rgba(91,155,213,0.3); }
.engine-tile .e-desc { font-size:12.5px; color:var(--ink-3); line-height:1.5; }

/* Mini-mock (used inline in feature pages) */
.mini-mock {
  background:var(--navy-card); border:1px solid var(--line2); border-radius:4px; padding:18px 20px;
  font-family:var(--mono); font-size:12px; color:var(--ink-2); line-height:1.7; margin:18px 0;
}
.mini-mock .m-row { display:flex; gap:10px; align-items:baseline; padding:6px 0; border-bottom:1px solid var(--line); }
.mini-mock .m-row:last-child { border-bottom:none; }
.mini-mock .m-ts { color:var(--ink-4); font-size:10px; letter-spacing:0.14em; min-width:48px; }
.mini-mock .m-who { color:var(--amber); font-weight:600; min-width:90px; font-size:10px; letter-spacing:0.14em; text-transform:uppercase; }
.mini-mock .m-text { color:var(--ink); font-family:var(--sans); font-size:13px; line-height:1.5; }
.mini-mock .m-chip {
  display:inline-flex; align-items:center; gap:4px; font-size:9.5px; padding:2px 6px; border-radius:2px;
  background:var(--amber-soft); border:1px solid var(--amber-border); color:var(--amber);
  margin-left:6px; vertical-align:middle; letter-spacing:0.08em; font-weight:600;
}

/* FAQ */
.faq details { border-bottom:1px solid var(--line); padding:18px 0; }
.faq summary { font-size:17px; font-weight:500; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary:after { content:'+'; font-family:var(--mono); color:var(--amber); font-size:18px; }
.faq details[open] summary:after { content:'−'; }
.faq details p { font-size:15px; color:var(--ink-2); margin-top:12px; line-height:1.6; }

/* Final CTA */
.final-cta { padding:100px 0; border-top:1px solid var(--line); text-align:center; background:radial-gradient(ellipse at center, rgba(232,135,30,0.06), transparent 60%); }
.final-cta h2 { font-size:clamp(36px,4.5vw,56px); font-weight:600; line-height:1.05; letter-spacing:-0.02em; margin-bottom:18px; }
.final-cta h2 em { font-family:var(--serif); font-style:italic; color:var(--amber); font-weight:500; }
.final-cta p { font-size:18px; color:var(--ink-2); max-width:620px; margin:0 auto 32px; line-height:1.5; }

/* Footer */
.footer { padding:60px 0 40px; border-top:1px solid var(--line); background:#06101a; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr 1fr; gap:36px; margin-bottom:40px; }
.footer-brand { font-size:20px; font-weight:700; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.footer-tagline { font-size:13px; color:var(--ink-3); line-height:1.5; max-width:280px; }
.footer-col h4 { font-family:var(--mono); font-size:10px; letter-spacing:0.18em; color:var(--ink-3); text-transform:uppercase; margin-bottom:14px; font-weight:600; }
.footer-col a { display:block; font-size:13px; color:var(--ink-2); padding:4px 0; }
.footer-col a:hover { color:var(--amber); }
.footer-bottom { padding-top:30px; border-top:1px solid var(--line); display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.14em; color:var(--ink-4); text-transform:uppercase; }

@media (max-width:900px) {
  .nav-links { display:none; }
  .phase-strip { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:repeat(2,1fr); gap:24px; }
}
