/* ============================================================
   ExistemAI - site MVP (LeadTruffle structure replica)
   Dark, premium. Emerald accent (ExistemAI brand). Fully tokenized.
   To match LeadTruffle's exact palette later: change the
   --accent / --bg tokens in :root only.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ---- base (near-black, faint warm) ---- */
  --bg:        #0b0c0e;
  --bg-2:      #0e0f12;
  --surface:   #131418;
  --surface-2: #181a1f;
  --surface-3: #1e2127;
  --border:    #24262b;
  --border-hi: #32343b;

  /* ---- ink ---- */
  --text:   #e7e8ea;
  --text-2: #b4b7bd;
  --text-3: #9499a1;
  --field-border: #6a6e77;

  /* ---- truffle gold accent ---- */
  --accent:      #3fcf8e;
  --accent-2:    #5fe3a6;
  --accent-deep: #2a9e6b;
  --accent-soft: rgba(63, 207, 142, 0.10);
  --accent-line: rgba(63, 207, 142, 0.32);
  --gold-grad:   linear-gradient(135deg, #5fe3a6 0%, #3fcf8e 50%, #2a9e6b 100%);

  /* ---- signal ---- */
  --star:  #f5b740;
  --green: #46c98a;
  --red:   #e2685f;

  /* ---- shadows ---- */
  --shadow-sm: 0 2px 10px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 18px 40px -12px rgba(0, 0, 0, 0.7);
  --shadow-lg: 0 40px 90px -28px rgba(0, 0, 0, 0.85);
  --glow:      0 0 0 1px var(--accent-line), 0 18px 50px -18px rgba(63,207,142,0.35);

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --wrap: 1200px;
  --nav-h: 72px;
  --radius: 14px;
}

/* ---------- fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=JetBrains+Mono:wght@400;500&display=swap');

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 90px; }

body {
  font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: 1rem;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* faint engineered grid behind everything */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.016) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.016) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 90% 55% at 50% 0%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 90% 55% at 50% 0%, #000 30%, transparent 80%);
}

main, nav, footer { position: relative; z-index: 1; }

h1, h2, h3, h4, h5 {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600; line-height: 1.1; letter-spacing: -0.02em;
  color: var(--text);
}

a { color: inherit; text-decoration: none; }
img, svg { max-width: 100%; display: block; }
ul { list-style: none; }

::selection { background: var(--accent); color: #06130c; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 3px; }

/* ---------- layout primitives ---------- */
.wrap { width: 100%; max-width: var(--wrap); margin: 0 auto; padding: 0 28px; }
.section { padding: 96px 0; position: relative; }
.section--tight { padding: 64px 0; }
.center { text-align: center; }
.mono { font-family: 'JetBrains Mono', monospace; }

.eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent); display: inline-flex; align-items: center; gap: 9px;
}
.eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--accent-line); }
.eyebrow--center { justify-content: center; }

.section-head { max-width: 720px; margin: 0 auto; }
.section-head.left { margin: 0; }
.section-head h2 { font-size: clamp(2rem, 4vw, 3rem); margin: 16px 0 0; }
.section-head p { color: var(--text-2); font-size: 1.18rem; margin: 18px auto 0; line-height: 1.6; max-width: 620px; }

/* corner-tick decoration */
.ticked { position: relative; }
.ticked::before, .ticked::after {
  content: ''; position: absolute; width: 10px; height: 10px;
  border: 1px solid var(--accent-line); pointer-events: none;
}
.ticked::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.ticked::after  { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 0.95rem;
  padding: 13px 24px; border-radius: 10px; border: 1px solid transparent;
  cursor: pointer; white-space: nowrap;
  transition: transform .4s var(--ease), background .3s var(--ease), border-color .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease);
}
.btn svg { width: 16px; height: 16px; transition: transform .4s var(--ease); }
.btn:hover svg { transform: translateX(3px); }
.btn--primary { background: var(--gold-grad); color: #06130c; box-shadow: 0 10px 30px -12px rgba(63,207,142,0.5); }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -12px rgba(63,207,142,0.65); }
.btn--primary:active { transform: translateY(0) scale(.985); }
.btn--ghost { background: transparent; color: var(--text); border-color: var(--border-hi); }
.btn--ghost:hover { transform: translateY(-2px); border-color: var(--accent-line); color: var(--accent); }
.btn--dark { background: var(--surface-2); color: var(--text); border-color: var(--border); }
.btn--dark:hover { transform: translateY(-2px); border-color: var(--border-hi); }
.btn--lg { padding: 16px 30px; font-size: 1.02rem; }
.btn--block { width: 100%; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100; height: var(--nav-h);
  display: flex; align-items: center; border-bottom: 1px solid transparent;
  transition: background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s var(--ease);
}
.nav.is-stuck { background: rgba(11,12,14,0.82); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom-color: var(--border); }
.nav__inner { width: 100%; max-width: var(--wrap); margin: 0 auto; padding: 0 28px; display: flex; align-items: center; gap: 18px; }

.brand { display: flex; align-items: center; gap: 11px; font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.18rem; letter-spacing: -0.02em; margin-right: 8px; }
.brand__mark { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; background: var(--gold-grad); color: #06130c; box-shadow: 0 6px 18px -6px rgba(63,207,142,0.6); }
.brand__mark svg { width: 17px; height: 17px; }
.brand b { font-weight: 700; }

.nav__links { display: flex; align-items: center; gap: 4px; margin-left: auto; }
.nav__item { position: relative; }
.nav__link {
  display: inline-flex; align-items: center; gap: 6px; padding: 9px 14px; border-radius: 8px;
  font-size: 0.93rem; font-weight: 500; color: var(--text-2);
  transition: color .25s var(--ease), background .25s var(--ease); cursor: pointer; background: none; border: none; font-family: inherit;
}
.nav__link:hover, .nav__item:hover .nav__link, .nav__item.open .nav__link { color: var(--text); background: var(--surface); }
.nav__link .chev { width: 13px; height: 13px; transition: transform .25s var(--ease); }
.nav__item.open .nav__link .chev { transform: rotate(180deg); }

/* dropdown / mega menu */
.dropdown {
  position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%) translateY(8px);
  background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 14px;
  box-shadow: var(--shadow-lg); opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .28s var(--ease), transform .28s var(--ease); min-width: 280px; z-index: 120;
}
.dropdown::before { content: ''; position: absolute; top: -10px; left: 0; right: 0; height: 10px; }
.nav__item:hover .dropdown, .nav__item.open .dropdown { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown--wide { min-width: 600px; }
.dropdown__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.dropdown a { display: flex; gap: 12px; padding: 11px 13px; border-radius: 10px; transition: background .2s var(--ease); align-items: flex-start; }
.dropdown a:hover { background: var(--surface-2); }
.dropdown a .di { width: 30px; height: 30px; flex: 0 0 30px; display: grid; place-items: center; border-radius: 8px; background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-line); }
.dropdown a .di svg { width: 15px; height: 15px; }
.dropdown a b { font-size: 0.9rem; font-weight: 600; color: var(--text); display: block; font-family: 'Space Grotesk', sans-serif; }
.dropdown a span { font-size: 0.78rem; color: var(--text-3); line-height: 1.4; }
.dropdown__head { font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-3); padding: 8px 13px 6px; }

.nav__cta { display: flex; align-items: center; gap: 10px; margin-left: 8px; }
.nav__login { display: inline-flex; align-items: center; gap: 7px; font-size: 0.9rem; color: var(--text-2); padding: 9px 12px; border-radius: 8px; transition: color .2s, background .2s; }
.nav__login:hover { color: var(--text); background: var(--surface); }

.nav__burger { display: none; width: 42px; height: 42px; border: 1px solid var(--border); border-radius: 10px; background: var(--surface); cursor: pointer; align-items: center; justify-content: center; flex-direction: column; gap: 4px; }
.nav__burger span { width: 18px; height: 2px; background: var(--text); border-radius: 2px; transition: transform .3s var(--ease), opacity .3s var(--ease); }
.nav.menu-open .nav__burger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav.menu-open .nav__burger span:nth-child(2) { opacity: 0; }
.nav.menu-open .nav__burger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* mobile drawer */
.mobile-menu { position: fixed; inset: var(--nav-h) 0 0; background: var(--bg-2); z-index: 95; padding: 24px 28px 40px; overflow-y: auto; transform: translateX(100%); transition: transform .4s var(--ease); display: flex; flex-direction: column; gap: 4px; }
.nav.menu-open + .mobile-menu, .mobile-menu.open { transform: translateX(0); }
.mobile-menu a, .mobile-menu .mm-toggle { padding: 15px 8px; border-bottom: 1px solid var(--border); font-size: 1.05rem; font-weight: 500; color: var(--text); display: flex; justify-content: space-between; align-items: center; background: none; border-left: 0; border-right: 0; border-top: 0; width: 100%; font-family: inherit; cursor: pointer; }
.mobile-menu .mm-sub { display: none; padding-left: 14px; }
.mobile-menu .mm-sub.open { display: block; }
.mobile-menu .mm-sub a { font-size: 0.95rem; color: var(--text-2); border-bottom: 1px solid var(--border); }
.mobile-menu .mm-cta { margin-top: 22px; display: flex; flex-direction: column; gap: 12px; }
.mobile-menu .mm-toggle .chev { width: 16px; height: 16px; transition: transform .25s; }
.mobile-menu .mm-toggle.open .chev { transform: rotate(180deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero { padding: calc(var(--nav-h) + 60px) 0 70px; position: relative; overflow: hidden; }
.hero::after { content: ''; position: absolute; top: -10%; left: 50%; transform: translateX(-50%); width: 900px; height: 600px; background: radial-gradient(ellipse at center, rgba(63,207,142,0.13), transparent 65%); pointer-events: none; z-index: 0; }
.hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 50px; align-items: center; position: relative; z-index: 1; }
.hero__badge { display: inline-flex; align-items: center; gap: 9px; padding: 7px 14px; border: 1px solid var(--accent-line); border-radius: 100px; background: var(--accent-soft); font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-bottom: 26px; }
.hero__badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); animation: pulse 2.4s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
.hero h1 { font-size: clamp(2.4rem, 5vw, 3.85rem); line-height: 1.05; }
.hero h1 .hl { background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero__sub { font-size: 1.15rem; color: var(--text-2); margin: 24px 0 32px; max-width: 540px; line-height: 1.6; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero__cta .note { font-size: 0.82rem; color: var(--text-3); }

.hero__logos { margin-top: 44px; display: flex; flex-direction: column; gap: 18px; }
.logo-row { }
.logo-row__label { font-family: 'JetBrains Mono', monospace; font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); margin-bottom: 12px; }
.logo-row__set { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.logo-chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border: 1px solid var(--border); border-radius: 10px; background: var(--surface); font-size: 0.84rem; font-weight: 600; color: var(--text-2); }
.logo-chip .lc-mark { width: 16px; height: 16px; border-radius: 4px; display: grid; place-items: center; font-size: 0.7rem; font-weight: 800; }

/* phone mockup */
.phone-wrap { display: flex; justify-content: center; position: relative; }
.phone { width: 308px; max-width: 80vw; background: #0c0b0e; border: 9px solid #1d1a22; border-radius: 42px; padding: 14px 12px 18px; box-shadow: var(--shadow-lg), 0 0 0 1px var(--border); position: relative; }
.phone::before { content: ''; position: absolute; top: 14px; left: 50%; transform: translateX(-50%); width: 110px; height: 22px; background: #1d1a22; border-radius: 0 0 14px 14px; }
.phone__top { display: flex; align-items: center; gap: 10px; padding: 28px 10px 14px; border-bottom: 1px solid var(--border); margin-bottom: 12px; }
.phone__av { width: 34px; height: 34px; border-radius: 50%; background: var(--gold-grad); display: grid; place-items: center; color: #06130c; font-weight: 800; font-size: 0.85rem; }
.phone__name { font-weight: 600; font-size: 0.9rem; }
.phone__status { font-size: 0.7rem; color: var(--green); display: flex; align-items: center; gap: 5px; }
.phone__status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
.phone__chat { display: flex; flex-direction: column; gap: 9px; padding: 4px 6px 6px; }
.bubble { max-width: 80%; padding: 9px 13px; border-radius: 15px; font-size: 0.83rem; line-height: 1.4; }
.bubble--in { background: var(--surface-2); color: var(--text); border-bottom-left-radius: 5px; align-self: flex-start; }
.bubble--out { background: var(--gold-grad); color: #06130c; border-bottom-right-radius: 5px; align-self: flex-end; font-weight: 500; }
.bubble__time { font-size: 0.62rem; color: var(--text-3); margin: 2px 4px 0; }
.phone__tag { position: absolute; right: -14px; top: 96px; background: var(--surface); border: 1px solid var(--accent-line); border-radius: 10px; padding: 7px 11px; font-size: 0.7rem; font-family: 'JetBrains Mono', monospace; color: var(--accent); box-shadow: var(--shadow-md); }

/* ============================================================
   MARQUEE (trusted-by logos)
   ============================================================ */
.marquee-band { padding: 40px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: var(--bg-2); }
.marquee-head { text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); margin-bottom: 26px; }
.marquee-head .star { color: var(--star); }
.marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee__track { display: flex; gap: 18px; width: max-content; animation: scroll-x 38s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes scroll-x { to { transform: translateX(-50%); } }
.client-logo { display: flex; align-items: center; gap: 9px; padding: 13px 22px; border: 1px solid var(--border); border-radius: 12px; background: var(--surface); color: var(--text-2); font-weight: 700; font-size: 0.92rem; white-space: nowrap; font-family: 'Space Grotesk', sans-serif; }
.client-logo .cl-dot { width: 22px; height: 22px; border-radius: 6px; background: var(--surface-3); display: grid; place-items: center; color: var(--accent); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tcards { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 20px; margin-top: 48px; }
.tcard { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 26px; display: flex; flex-direction: column; gap: 14px; transition: transform .35s var(--ease), border-color .35s var(--ease); }
.tcard:hover { transform: translateY(-4px); border-color: var(--border-hi); }
.tcard__stars { color: var(--star); letter-spacing: 2px; font-size: 0.95rem; }
.tcard__quote { color: var(--text); font-size: 0.98rem; line-height: 1.6; flex: 1; }
.tcard__who { display: flex; align-items: center; gap: 12px; padding-top: 6px; border-top: 1px solid var(--border); }
.tcard__av { width: 44px; height: 44px; border-radius: 50%; background: var(--surface-3); display: grid; place-items: center; font-weight: 700; color: var(--accent); border: 1px solid var(--border-hi); font-family: 'Space Grotesk', sans-serif; }
.tcard__name { font-weight: 600; font-size: 0.92rem; }
.tcard__role { font-size: 0.8rem; color: var(--text-3); }
.placeholder-tag { display: inline-block; font-family: 'JetBrains Mono', monospace; font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); background: var(--accent-soft); border: 1px dashed var(--accent-line); border-radius: 6px; padding: 3px 8px; }

/* press strip */
.press { display: flex; align-items: center; justify-content: center; gap: 30px; flex-wrap: wrap; margin-top: 14px; }
.press__item { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.05rem; color: var(--text-3); filter: grayscale(1); opacity: 0.7; transition: opacity .3s, color .3s; }
.press__item:hover { opacity: 1; color: var(--text-2); }
.press-frame { display: flex; align-items: center; justify-content: center; gap: 22px; }
.press-frame .bar { width: 1px; height: 40px; background: var(--border); }

/* ============================================================
   HOW IT WORKS / FLOW DIAGRAM
   ============================================================ */
.flow { display: grid; grid-template-columns: 1fr auto 1fr; gap: 26px; align-items: center; margin-top: 54px; }
.flow__col { display: flex; flex-direction: column; gap: 12px; }
.flow__src { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid var(--border); border-radius: 12px; background: var(--surface); transition: border-color .3s, transform .3s; }
.flow__src:hover { border-color: var(--accent-line); transform: translateX(4px); }
.flow__src .fi { width: 34px; height: 34px; flex: 0 0 34px; border-radius: 8px; background: var(--surface-2); display: grid; place-items: center; color: var(--accent); }
.flow__src b { font-size: 0.9rem; font-weight: 600; display: block; }
.flow__src span { font-size: 0.76rem; color: var(--text-3); }
.flow__hub { display: grid; place-items: center; gap: 14px; }
.flow__core { width: 150px; height: 150px; border-radius: 28px; background: var(--gold-grad); display: grid; place-items: center; text-align: center; color: #06130c; box-shadow: var(--glow); position: relative; }
.flow__core b { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.05rem; line-height: 1.15; }
.flow__core span { font-size: 0.72rem; font-family: 'JetBrains Mono', monospace; }
.flow__out { display: flex; flex-direction: column; gap: 12px; }
.flow__arrow { color: var(--accent); display: grid; place-items: center; }

/* ============================================================
   VIDEO
   ============================================================ */
.video-frame { max-width: 880px; margin: 44px auto 0; aspect-ratio: 16/9; border-radius: 18px; border: 1px solid var(--border); background: var(--surface); position: relative; overflow: hidden; display: grid; place-items: center; box-shadow: var(--shadow-lg); }
.video-frame::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 50%, rgba(63,207,142,0.12), transparent 60%); }
.video-play { width: 78px; height: 78px; border-radius: 50%; background: var(--gold-grad); display: grid; place-items: center; cursor: pointer; box-shadow: 0 12px 40px -8px rgba(63,207,142,0.6); transition: transform .3s var(--ease); position: relative; z-index: 1; }
.video-play:hover { transform: scale(1.08); }
.video-play svg { width: 30px; height: 30px; color: #06130c; margin-left: 4px; }
.video-cap { position: absolute; bottom: 20px; left: 22px; font-family: 'JetBrains Mono', monospace; font-size: 0.74rem; color: var(--text-2); z-index: 1; }

/* ============================================================
   FEATURE TOOLBOX GRID
   ============================================================ */
.fgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 18px; margin-top: 50px; }
.fcard { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 26px; display: flex; flex-direction: column; gap: 13px; transition: transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease); position: relative; overflow: hidden; }
.fcard:hover { transform: translateY(-5px); border-color: var(--accent-line); background: var(--surface-2); }
.fcard__icon { width: 50px; height: 50px; border-radius: 13px; background: var(--accent-soft); border: 1px solid var(--accent-line); display: grid; place-items: center; color: var(--accent); font-size: 1.4rem; }
.fcard__icon svg { width: 24px; height: 24px; }
.fcard h3 { font-size: 1.18rem; }
.fcard p { color: var(--text-2); font-size: 0.94rem; line-height: 1.55; flex: 1; }
.fcard__link { display: inline-flex; align-items: center; gap: 7px; color: var(--accent); font-weight: 600; font-size: 0.9rem; font-family: 'Space Grotesk', sans-serif; }
.fcard__link svg { width: 15px; height: 15px; transition: transform .3s var(--ease); }
.fcard:hover .fcard__link svg { transform: translateX(4px); }
.fcard--new::after { content: 'New'; position: absolute; top: 16px; right: 16px; font-family: 'JetBrains Mono', monospace; font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green); background: rgba(70,201,138,0.1); border: 1px solid rgba(70,201,138,0.3); border-radius: 6px; padding: 3px 8px; }

/* ============================================================
   INTEGRATIONS CLOUD
   ============================================================ */
.intg { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 44px; max-width: 920px; margin-left: auto; margin-right: auto; }
.intg__pill { padding: 11px 20px; border: 1px solid var(--border); border-radius: 100px; background: var(--surface); color: var(--text-2); font-weight: 600; font-size: 0.9rem; transition: border-color .3s, color .3s, transform .3s; }
.intg__pill:hover { border-color: var(--accent-line); color: var(--text); transform: translateY(-2px); }
.intg-note { text-align: center; max-width: 640px; margin: 30px auto 0; color: var(--text-2); }
.intg-explore { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; align-items: center; margin-top: 22px; font-size: 0.9rem; }
.intg-explore .lbl { color: var(--text-3); font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; }
.intg-explore a { color: var(--accent); font-weight: 600; }

/* ============================================================
   USE CASES
   ============================================================ */
.ucards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 18px; margin-top: 50px; }
.ucard { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 26px; transition: transform .35s var(--ease), border-color .35s var(--ease); }
.ucard:hover { transform: translateY(-4px); border-color: var(--border-hi); }
.ucard__emoji { font-size: 1.8rem; margin-bottom: 14px; display: block; }
.ucard h3 { font-size: 1.12rem; margin-bottom: 9px; }
.ucard p { color: var(--text-2); font-size: 0.92rem; line-height: 1.55; margin-bottom: 14px; }
.ucard a { color: var(--accent); font-weight: 600; font-size: 0.88rem; display: inline-flex; gap: 6px; align-items: center; }

/* ============================================================
   DEMO / FOUNDER BAND
   ============================================================ */
.demo-band { background: linear-gradient(135deg, var(--surface) 0%, var(--bg-2) 100%); border: 1px solid var(--border); border-radius: 24px; padding: 50px; display: grid; grid-template-columns: 1fr auto; gap: 36px; align-items: center; }
.demo-band h2 { font-size: clamp(1.7rem, 3vw, 2.4rem); }
.demo-band p { color: var(--text-2); margin: 14px 0 26px; font-size: 1.05rem; }
.founder { display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center; }
.founder__pic { width: 120px; height: 120px; border-radius: 50%; background: var(--surface-3); border: 2px solid var(--accent-line); display: grid; place-items: center; color: var(--text-3); font-size: 0.7rem; font-family: 'JetBrains Mono', monospace; text-align: center; }
.founder b { font-size: 0.95rem; }
.founder span { font-size: 0.8rem; color: var(--text-3); }

/* ============================================================
   FAQ
   ============================================================ */
.faq-tabs { display: inline-flex; gap: 4px; padding: 4px; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; margin: 0 auto 32px; }
.faq-tab { padding: 9px 22px; border-radius: 9px; font-weight: 600; font-size: 0.9rem; color: var(--text-2); cursor: pointer; border: none; background: none; font-family: 'Space Grotesk', sans-serif; transition: background .25s, color .25s; }
.faq-tab.active { background: var(--gold-grad); color: #06130c; }
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-panel { display: none; }
.faq-panel.active { display: block; }
.faq-item { border: 1px solid var(--border); border-radius: 12px; margin-bottom: 12px; background: var(--surface); overflow: hidden; transition: border-color .3s; }
.faq-item.open { border-color: var(--accent-line); }
.faq-q { width: 100%; text-align: left; padding: 20px 24px; background: none; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 1.02rem; color: var(--text); }
.faq-q .icon { width: 24px; height: 24px; flex: 0 0 24px; border-radius: 50%; border: 1px solid var(--border-hi); display: grid; place-items: center; transition: transform .3s var(--ease), background .3s, border-color .3s; position: relative; }
.faq-q .icon::before, .faq-q .icon::after { content: ''; position: absolute; background: var(--text-2); transition: background .3s; }
.faq-q .icon::before { width: 11px; height: 2px; }
.faq-q .icon::after { width: 2px; height: 11px; }
.faq-item.open .faq-q .icon { background: var(--accent); border-color: var(--accent); transform: rotate(135deg); }
.faq-item.open .faq-q .icon::before, .faq-item.open .faq-q .icon::after { background: #06130c; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .4s var(--ease); }
.faq-a__inner { padding: 0 24px 22px; color: var(--text-2); line-height: 1.65; font-size: 0.96rem; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band { text-align: center; padding: 90px 0; position: relative; overflow: hidden; }
.cta-band::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 800px; height: 500px; background: radial-gradient(ellipse, rgba(63,207,142,0.14), transparent 65%); pointer-events: none; }
.cta-band__inner { position: relative; z-index: 1; }
.cta-band h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
.cta-band p { color: var(--text-2); font-size: 1.12rem; margin: 18px 0 32px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--bg-2); border-top: 1px solid var(--border); padding: 64px 0 34px; }
.footer__top { display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 36px; padding-bottom: 44px; border-bottom: 1px solid var(--border); }
.footer__brand .brand { margin-bottom: 16px; }
.footer__brand p { color: var(--text-2); font-size: 0.92rem; line-height: 1.6; max-width: 280px; margin-bottom: 18px; }
.footer__contact { font-size: 0.88rem; color: var(--text-3); display: flex; flex-direction: column; gap: 7px; }
.footer__contact a { color: var(--text-2); }
.footer__contact a:hover { color: var(--accent); }
.footer__col h4 { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); margin-bottom: 16px; font-weight: 500; }
.footer__col a { display: block; color: var(--text-2); font-size: 0.9rem; padding: 6px 0; transition: color .2s; }
.footer__col a:hover { color: var(--accent); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding-top: 26px; flex-wrap: wrap; }
.footer__bottom .copy { font-size: 0.85rem; color: var(--text-3); }
.footer__legal { display: flex; gap: 20px; flex-wrap: wrap; }
.footer__legal a { font-size: 0.85rem; color: var(--text-3); }
.footer__legal a:hover { color: var(--text-2); }
.made-usa { display: inline-flex; align-items: center; gap: 7px; font-size: 0.82rem; color: var(--text-3); margin-top: 10px; }

/* reveal on scroll */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .phone-wrap { order: -1; }
  .demo-band { grid-template-columns: 1fr; text-align: center; }
  .founder { order: -1; }
  .footer__top { grid-template-columns: 1fr 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
  .flow { grid-template-columns: 1fr; gap: 18px; }
  .flow__arrow { transform: rotate(90deg); }
  .flow__hub { margin: 8px 0; }
}
@media (max-width: 860px) {
  .nav__links, .nav__login { display: none; }
  .nav__burger { display: flex; }
  .nav__cta .btn--ghost { display: none; }
  .section { padding: 68px 0; }
  .hero { padding-top: calc(var(--nav-h) + 36px); }
}
@media (max-width: 600px) {
  .wrap { padding: 0 20px; }
  .nav__inner { padding: 0 20px; }
  .footer__top { grid-template-columns: 1fr 1fr; }
  .demo-band { padding: 32px 24px; }
  .tcards, .fgrid, .ucards { grid-template-columns: 1fr; }
  .faq-q { font-size: 0.94rem; padding: 17px 18px; }
  .press-frame { gap: 12px; }
}

/* ============================================================
   PHONE TAG - fix overlap (override; anchors to phone bottom)
   ============================================================ */
.phone__tag {
  top: auto; right: auto; bottom: -16px; left: 50%;
  transform: translateX(-50%);
  background: var(--surface-2);
  border: 1px solid var(--accent-line);
  border-radius: 100px;
  padding: 8px 16px;
  font-size: 0.72rem;
  box-shadow: var(--shadow-md);
  white-space: nowrap; z-index: 4;
  display: inline-flex; align-items: center; gap: 7px;
}
.phone__tag::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(70,201,138,0.18); }

/* ============================================================
   PRICING
   ============================================================ */
.pricing-hero { padding: calc(var(--nav-h) + 64px) 0 36px; text-align: center; position: relative; }
.pricing-hero::after { content:''; position:absolute; top:-4%; left:50%; transform:translateX(-50%); width:820px; height:480px; background:radial-gradient(ellipse at center, rgba(63,207,142,0.10), transparent 65%); pointer-events:none; }
.pricing-hero .eyebrow { justify-content: center; position: relative; z-index: 1; }
.pricing-hero h1 { font-size: clamp(2.2rem, 4.6vw, 3.4rem); max-width: 900px; margin: 16px auto 0; position: relative; z-index: 1; }
.pricing-hero p { color: var(--text-2); font-size: 1.12rem; max-width: 700px; margin: 20px auto 30px; position: relative; z-index: 1; }
.pricing-hero .btn { position: relative; z-index: 1; }

.pgroup-labels { display: grid; grid-template-columns: 1fr 3fr; gap: 18px; margin-bottom: 14px; }
.pgroup-labels span { font-family: 'JetBrains Mono', monospace; font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-3); padding-left: 8px; display: flex; align-items: center; gap: 9px; }
.pgroup-labels span::before { content:''; width: 18px; height: 1px; background: var(--accent-line); }

.pgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; align-items: stretch; }
.ptier { background: var(--surface); border: 1px solid var(--border); border-radius: 18px; padding: 28px 24px; display: flex; flex-direction: column; position: relative; transition: transform .35s var(--ease), border-color .35s var(--ease); }
.ptier:hover { transform: translateY(-4px); border-color: var(--border-hi); }
.ptier--starter { background: var(--bg-2); }
.ptier--featured { border-color: var(--accent); box-shadow: var(--glow); }
.ptier--featured:hover { transform: translateY(-6px); }
.ptier__badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--gold-grad); color: #06130c; font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 0.68rem; letter-spacing: 0.06em; text-transform: uppercase; padding: 5px 14px; border-radius: 100px; white-space: nowrap; box-shadow: 0 8px 20px -8px rgba(63,207,142,0.6); }
.ptier__name { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.32rem; }
.ptier__for { color: var(--text-3); font-size: 0.85rem; line-height: 1.45; min-height: 54px; margin-top: 6px; }
.ptier__price { display: flex; align-items: baseline; gap: 5px; margin: 14px 0 2px; flex-wrap: wrap; }
.ptier__price .amt { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 2.1rem; letter-spacing: -0.02em; color: var(--text); }
.ptier__price .per { color: var(--text-3); font-size: 0.9rem; }
.ptier__setup { color: var(--text-3); font-size: 0.82rem; margin-bottom: 14px; min-height: 18px; }
.ptier__cta { margin-bottom: 18px; }
.ptier__list { display: flex; flex-direction: column; gap: 10px; border-top: 1px solid var(--border); padding-top: 16px; margin-top: auto; }
.ptier__list .pl-head { font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-bottom: 3px; }
.ptier__list li { display: flex; gap: 9px; font-size: 0.86rem; color: var(--text-2); line-height: 1.42; align-items: flex-start; }
.ptier__list li svg { width: 15px; height: 15px; flex: 0 0 15px; color: var(--accent); margin-top: 3px; }

/* money / transparency */
.money-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; margin-top: 44px; }
.money-card { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 24px; }
.money-card .mi { width: 42px; height: 42px; border-radius: 11px; background: var(--accent-soft); border: 1px solid var(--accent-line); display: grid; place-items: center; color: var(--accent); margin-bottom: 14px; }
.money-card .mi svg { width: 20px; height: 20px; }
.money-card h3 { font-size: 1.02rem; margin-bottom: 8px; }
.money-card p { color: var(--text-2); font-size: 0.89rem; line-height: 1.55; }

/* comparison table */
.compare-wrap { margin-top: 46px; overflow-x: auto; border: 1px solid var(--border); border-radius: 16px; background: var(--surface); }
.compare { width: 100%; border-collapse: collapse; min-width: 760px; }
.compare th, .compare td { padding: 15px 18px; text-align: center; border-bottom: 1px solid var(--border); font-size: 0.9rem; }
.compare tbody tr:last-child td { border-bottom: 0; }
.compare thead th { background: var(--surface-2); font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 0.98rem; color: var(--text); }
.compare thead th.feat-col, .compare td.feat-col { text-align: left; }
.compare td.feat-col { color: var(--text-2); font-weight: 500; }
.compare thead th.col-featured { color: var(--accent); }
.compare tbody td.col-featured { background: rgba(63,207,142,0.04); }
.compare tbody tr:hover td { background: var(--surface-2); }
.compare tbody tr:hover td.col-featured { background: rgba(63,207,142,0.07); }
.compare .chk svg { width: 18px; height: 18px; color: var(--accent); display: inline-block; }
.compare .dash { color: var(--text-3); }
.compare .val { color: var(--text-2); font-size: 0.82rem; font-weight: 600; }
.compare tr.grp td { background: var(--bg-2); font-family: 'JetBrains Mono', monospace; font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-3); text-align: left; }

/* risk reversal */
.risk { margin-top: 46px; background: linear-gradient(135deg, var(--surface), var(--bg-2)); border: 1px solid var(--border); border-radius: 20px; padding: 40px; display: flex; gap: 24px; align-items: flex-start; }
.risk .ri { width: 54px; height: 54px; flex: 0 0 54px; border-radius: 14px; background: var(--accent-soft); border: 1px solid var(--accent-line); display: grid; place-items: center; color: var(--accent); }
.risk h3 { font-size: 1.4rem; margin-bottom: 10px; }
.risk p { color: var(--text-2); font-size: 1rem; line-height: 1.62; }

/* discovery sprint */
.sprint__tracks { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-top: 30px; }
.sprint__track { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 24px 32px; min-width: 190px; transition: transform .3s var(--ease), border-color .3s var(--ease); }
.sprint__track:hover { transform: translateY(-3px); border-color: var(--accent-line); }
.sprint__track .tname { font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-3); margin-bottom: 8px; }
.sprint__track b { font-family: 'Space Grotesk', sans-serif; font-size: 1.7rem; display: block; }

@media (max-width: 1024px) { .pgrid { grid-template-columns: repeat(2, 1fr); } .ptier--featured { transform: none; } .pgroup-labels { display: none; } }
@media (max-width: 560px) { .pgrid { grid-template-columns: 1fr; } .risk { flex-direction: column; padding: 28px; } .ptier__for { min-height: 0; } }

/* ============================================================
   FEATURE / SOLUTION PAGE COMPONENTS
   ============================================================ */
.crumb { padding: calc(var(--nav-h) + 28px) 0 0; }
.crumb .wrap { font-size: 0.8rem; font-family: 'JetBrains Mono', monospace; color: var(--text-3); display: flex; gap: 8px; align-items: center; }
.crumb a { color: var(--text-3); } .crumb a:hover { color: var(--accent); }
.crumb .sep { opacity: 0.5; } .crumb .here { color: var(--text-2); }

/* feature hero: agent stack visual */
.fhero { padding: 34px 0 60px; position: relative; overflow: hidden; }
.fhero::after { content:''; position:absolute; top:-20%; right:-5%; width:680px; height:560px; background:radial-gradient(ellipse at center, rgba(63,207,142,0.12), transparent 65%); pointer-events:none; }
.fhero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 50px; align-items: center; position: relative; z-index: 1; }
.fhero h1 { font-size: clamp(2.2rem, 4.6vw, 3.4rem); margin-top: 18px; }
.fhero h1 .hl { background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.fhero__sub { color: var(--text-2); font-size: 1.12rem; line-height: 1.6; margin: 22px 0 30px; max-width: 540px; }

.agentstack { display: flex; flex-direction: column; gap: 12px; }
.agentcard { display: flex; align-items: center; gap: 14px; padding: 15px 18px; background: var(--surface); border: 1px solid var(--border); border-radius: 14px; box-shadow: var(--shadow-sm); transition: transform .35s var(--ease), border-color .35s var(--ease); }
.agentcard:hover { transform: translateX(5px); border-color: var(--accent-line); }
.agentcard .ac-i { width: 40px; height: 40px; flex: 0 0 40px; border-radius: 11px; background: var(--accent-soft); border: 1px solid var(--accent-line); display: grid; place-items: center; color: var(--accent); }
.agentcard .ac-i svg { width: 19px; height: 19px; }
.agentcard b { font-family: 'Space Grotesk', sans-serif; font-size: 0.95rem; display: block; }
.agentcard span { font-size: 0.77rem; color: var(--text-3); }
.agentcard .ac-stat { margin-left: auto; font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; color: var(--accent); display: inline-flex; align-items: center; gap: 6px; }
.agentcard .ac-stat::before { content:''; width:6px; height:6px; border-radius:50%; background: var(--green); box-shadow:0 0 0 3px rgba(70,201,138,0.16); }

/* versus block */
.versus { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 46px; }
.versus__col { border: 1px solid var(--border); border-radius: 18px; padding: 32px; }
.versus__col--them { background: var(--bg-2); }
.versus__col--us { background: linear-gradient(135deg, var(--surface), var(--bg-2)); border-color: var(--accent-line); box-shadow: var(--glow); }
.versus__tag { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-3); margin-bottom: 14px; }
.versus__col--us .versus__tag { color: var(--accent); }
.versus__col h3 { font-size: 1.3rem; margin-bottom: 16px; }
.versus__list li { display: flex; gap: 11px; padding: 11px 0; color: var(--text-2); font-size: 0.94rem; line-height: 1.5; border-bottom: 1px solid var(--border); align-items: flex-start; }
.versus__list li:last-child { border-bottom: 0; }
.versus__list li .vi { flex: 0 0 18px; margin-top: 2px; }
.versus__col--them .vi { color: var(--text-3); } .versus__col--us .vi { color: var(--accent); }

/* numbered steps */
.steps { display: flex; flex-direction: column; margin-top: 46px; max-width: 860px; }
.step { display: grid; grid-template-columns: auto 1fr; gap: 22px; padding: 26px 0; border-bottom: 1px solid var(--border); }
.step:last-child { border-bottom: 0; }
.step__n { font-family: 'JetBrains Mono', monospace; font-size: 0.85rem; color: var(--accent); border: 1px solid var(--accent-line); background: var(--accent-soft); width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; }
.step h3 { font-size: 1.2rem; margin-bottom: 7px; }
.step p { color: var(--text-2); font-size: 0.96rem; line-height: 1.6; }
.step__tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.step__tags span { font-family: 'JetBrains Mono', monospace; font-size: 0.66rem; color: var(--text-3); border: 1px solid var(--border); border-radius: 6px; padding: 3px 9px; }

@media (max-width: 900px) { .fhero__grid { grid-template-columns: 1fr; gap: 38px; } .agentstack { order: -1; } }
@media (max-width: 768px) { .versus { grid-template-columns: 1fr; } }

/* ============================================================
   DATA ORGANIZATION PAGE COMPONENTS
   ============================================================ */
/* knowledge-base visual panel */
.datapanel { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow-lg); overflow: hidden; }
.datapanel__bar { display: flex; align-items: center; gap: 7px; padding: 13px 16px; border-bottom: 1px solid var(--border); background: var(--surface-2); }
.datapanel__bar .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--border-hi); }
.datapanel__bar .nm { margin-left: 10px; font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; color: var(--text-3); }
.datapanel__body { padding: 18px; display: flex; flex-direction: column; gap: 10px; font-family: 'JetBrains Mono', monospace; font-size: 0.78rem; }
.datarow { display: flex; gap: 12px; align-items: baseline; }
.datarow .k { color: var(--text-3); min-width: 112px; flex: 0 0 112px; }
.datarow .v { color: var(--text); }
.datarow .v em { color: var(--accent); font-style: normal; }
.datapanel__foot { padding: 12px 18px; border-top: 1px solid var(--border); font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; color: var(--accent); display: flex; align-items: center; gap: 8px; }
.datapanel__foot::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(70,201,138,0.16); }

/* two-layer cards */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 46px; }
.duo__card { background: var(--surface); border: 1px solid var(--border); border-radius: 18px; padding: 32px; }
.duo__card .badge { display: inline-flex; align-items: center; gap: 8px; font-family: 'JetBrains Mono', monospace; font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); border: 1px solid var(--accent-line); background: var(--accent-soft); border-radius: 100px; padding: 5px 13px; margin-bottom: 16px; }
.duo__card h3 { font-size: 1.32rem; margin-bottom: 10px; }
.duo__card > p { color: var(--text-2); font-size: 0.95rem; line-height: 1.6; margin-bottom: 18px; }
.duo__list li { display: flex; gap: 10px; padding: 10px 0; color: var(--text-2); font-size: 0.9rem; border-top: 1px solid var(--border); align-items: flex-start; line-height: 1.45; }
.duo__list li svg { width: 15px; height: 15px; flex: 0 0 15px; color: var(--accent); margin-top: 3px; }

/* reporting mock */
.report-card { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 28px; box-shadow: var(--shadow-md); max-width: 560px; }
.report-row { display: flex; justify-content: space-between; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--border); }
.report-row:last-child { border-bottom: 0; }
.report-row .rl { color: var(--text-2); font-size: 0.92rem; }
.report-row .rv { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.3rem; color: var(--text); }
.report-row .rv.up { color: var(--green); }

@media (max-width: 768px) { .duo { grid-template-columns: 1fr; } }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-hero { padding: calc(var(--nav-h) + 44px) 0 70px; position: relative; overflow: hidden; }
.contact-hero::after { content:''; position:absolute; top:-10%; right:-5%; width:640px; height:520px; background:radial-gradient(ellipse at center, rgba(63,207,142,0.10), transparent 65%); pointer-events:none; }
.contact-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 48px; align-items: start; position: relative; z-index: 1; }
.contact-info h1 { font-size: clamp(2.1rem, 4.4vw, 3.1rem); margin-top: 16px; }
.contact-info h1 .hl { background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.contact-info > p { color: var(--text-2); font-size: 1.1rem; line-height: 1.6; margin: 20px 0 0; max-width: 480px; }
.covers { margin-top: 30px; display: flex; flex-direction: column; gap: 14px; }
.covers li { display: flex; gap: 13px; align-items: flex-start; color: var(--text-2); font-size: 0.96rem; line-height: 1.45; }
.covers li svg { width: 21px; height: 21px; flex: 0 0 21px; color: var(--accent); margin-top: 1px; }
.covers li b { color: var(--text); font-family: 'Space Grotesk', sans-serif; }
.contact-meta { margin-top: 30px; display: flex; flex-direction: column; gap: 12px; padding-top: 26px; border-top: 1px solid var(--border); }
.contact-meta .row { display: flex; align-items: center; gap: 12px; font-size: 0.95rem; color: var(--text-2); }
.contact-meta .row svg { width: 18px; height: 18px; flex: 0 0 18px; color: var(--accent); }
.contact-meta .row a { color: var(--text-2); } .contact-meta .row a:hover { color: var(--accent); }

.contact-card { background: var(--surface); border: 1px solid var(--border); border-radius: 20px; padding: 32px; box-shadow: var(--shadow-lg); }
.contact-card h2 { font-size: 1.3rem; }
.contact-card .cc-sub { color: var(--text-3); font-size: 0.9rem; margin: 6px 0 22px; }
.contact-divider { display: flex; align-items: center; gap: 14px; margin: 22px 0; color: var(--text-3); font-size: 0.78rem; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.1em; }
.contact-divider::before, .contact-divider::after { content: ''; height: 1px; background: var(--border); flex: 1; }
.field { margin-bottom: 15px; }
.field label { display: block; font-size: 0.8rem; color: var(--text-2); margin-bottom: 7px; font-family: 'Space Grotesk', sans-serif; font-weight: 500; }
.field input, .field select, .field textarea { width: 100%; background: var(--surface-2); border: 1px solid var(--border-hi); border-radius: 10px; padding: 12px 14px; color: var(--text); font-family: inherit; font-size: 0.95rem; transition: border-color .2s var(--ease); }
.field input::placeholder, .field textarea::placeholder { color: var(--text-3); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); }
.field textarea { resize: vertical; min-height: 100px; }
.field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-note { font-size: 0.78rem; color: var(--text-3); margin-top: 14px; text-align: center; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; gap: 38px; } }
@media (max-width: 480px) { .field--row { grid-template-columns: 1fr; } }

/* ============================================================
   HOW IT WORKS - stat band + pillars
   ============================================================ */
.statband { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 46px; }
.stat { text-align: center; padding: 26px 18px; border: 1px solid var(--border); border-radius: 14px; background: var(--surface); transition: transform .35s var(--ease), border-color .35s var(--ease); }
.stat:hover { transform: translateY(-3px); border-color: var(--accent-line); }
.stat b { display: block; font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 2.1rem; line-height: 1; background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; margin-bottom: 8px; }
.stat span { color: var(--text-3); font-size: 0.86rem; }
@media (max-width: 680px) { .statband { grid-template-columns: 1fr 1fr; } }

.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 48px; }
.pillar { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 30px; transition: transform .35s var(--ease), border-color .35s var(--ease); }
.pillar:hover { transform: translateY(-5px); border-color: var(--accent-line); }
.pillar__n { font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; }
.pillar h3 { font-size: 1.28rem; margin-bottom: 10px; }
.pillar p { color: var(--text-2); font-size: 0.94rem; line-height: 1.55; margin-bottom: 16px; }
.pillar a { color: var(--accent); font-weight: 600; font-size: 0.9rem; font-family: 'Space Grotesk', sans-serif; display: inline-flex; gap: 7px; align-items: center; }
@media (max-width: 820px) { .pillars { grid-template-columns: 1fr; } }

/* ============================================================
   Reduced motion (a11y)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
  .marquee__track { animation: none !important; }
}

/* ============================================================
   PRICING PATH TABS (Run my marketing / Respond to my leads)
   ============================================================ */
.ptabs { display: inline-flex; gap: 4px; padding: 4px; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; }
.ptab { padding: 11px 24px; border-radius: 9px; font-weight: 600; font-size: 0.95rem; color: var(--text-2); cursor: pointer; border: none; background: none; font-family: 'Space Grotesk', sans-serif; transition: background .25s var(--ease), color .25s var(--ease); white-space: nowrap; }
.ptab.active { background: var(--gold-grad); color: #06130c; }
.ptab-panel { display: none; }
.ptab-panel.active { display: block; animation: ptabFade .4s var(--ease); }
@keyframes ptabFade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.ptab-intro { text-align: center; color: var(--text-2); max-width: 620px; margin: 22px auto 36px; font-size: 1rem; }
.pgrid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.pgrid.cols-2 { grid-template-columns: repeat(2, 1fr); max-width: 760px; margin-left: auto; margin-right: auto; }
@media (max-width: 1024px) { .pgrid.cols-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 820px) { .pgrid.cols-3, .pgrid.cols-2 { grid-template-columns: 1fr; max-width: 430px; } }

/* ============================================================
   BILLING CADENCE TOGGLE
   ============================================================ */
.bill-toggle { display: inline-flex; gap: 4px; padding: 4px; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; flex-wrap: wrap; justify-content: center; }
.bill-opt { padding: 9px 18px; border-radius: 9px; font-weight: 600; font-size: 0.9rem; color: var(--text-2); cursor: pointer; border: none; background: none; font-family: 'Space Grotesk', sans-serif; transition: background .25s var(--ease), color .25s var(--ease); display: inline-flex; align-items: center; gap: 8px; }
.bill-opt.active { background: var(--surface-3); color: var(--text); }
.bill-save { font-family: 'JetBrains Mono', monospace; font-size: 0.6rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--accent); background: var(--accent-soft); border: 1px solid var(--accent-line); border-radius: 6px; padding: 2px 6px; }
.bill-note { margin-top: 14px; font-size: 0.82rem; color: var(--text-3); display: flex; gap: 8px; align-items: center; justify-content: center; flex-wrap: wrap; }
.ptier__bill { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; color: var(--text-3); margin: -4px 0 16px; }

/* ============================================================
   LEGAL PAGES + 404
   ============================================================ */
.legal { max-width: 760px; margin: 0 auto; }
.legal h2 { font-size: 1.4rem; margin: 34px 0 12px; }
.legal p, .legal li { color: var(--text-2); line-height: 1.7; margin-bottom: 12px; font-size: 0.98rem; }
.legal a { color: var(--accent); }
.legal__updated { color: var(--text-3); font-size: 0.85rem; font-family: 'JetBrains Mono', monospace; }
.draft-banner { background: var(--accent-soft); border: 1px dashed var(--accent-line); border-radius: 12px; padding: 16px 20px; margin-bottom: 28px; color: var(--text-2); font-size: 0.92rem; }
.draft-banner b { color: var(--accent); }
.notfound { text-align: center; padding: calc(var(--nav-h) + 80px) 0 100px; }
.notfound .code { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(4rem, 14vw, 9rem); background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; line-height: 1; }

/* ===== GUIDES: handoff content styles, scoped under .guide (re-merged) ===== */
.guide *, .guide *::before, .guide *::after { box-sizing: border-box; margin: 0; padding: 0; }
.guide {
  
  --bg:        #0b0c0e;
  --bg-2:      #0e0f12;
  --surface:   #131418;
  --surface-2: #181a1f;
  --border:    #24262b;
  --border-hi: #32343b;

  
  --text:   #e7e8ea;
  --text-2: #b4b7bd;
  --text-3: #9499a1;
  --field-border: #6a6e77;

  
  --accent:      #3fcf8e;
  --accent-deep: #2a9e6b;
  --accent-soft: rgba(63, 207, 142, 0.10);
  --accent-line: rgba(63, 207, 142, 0.30);

  
  --amber: #d7a64a;

  
  --shadow-sm: 0 2px 10px rgba(0, 0, 0, 0.35);
  --shadow-md: 0 18px 40px -12px rgba(4, 8, 6, 0.7);
  --shadow-lg: 0 40px 80px -24px rgba(4, 8, 6, 0.85);

  --ease: cubic-bezier(0.16, 1, 0.3, 1);

  --wrap: 1180px;
  --nav-h: 68px;
}
.guide { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
.guide {
  font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  font-size: 1rem;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.guide body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 90% 60% at 50% 0%, #000 30%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse 90% 60% at 50% 0%, #000 30%, transparent 78%);
}
.guide main, .guide nav, .guide footer { position: relative; z-index: 1; }
.guide h1, .guide h2, .guide h3, .guide h4 {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.02em;
}
.guide a { color: inherit; text-decoration: none; }
.guide img { max-width: 100%; display: block; }
.guide ::selection { background: var(--accent); color: #06130c; }
.guide :focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 3px;
}
.guide .wrap { width: 100%; max-width: var(--wrap); margin: 0 auto; padding: 0 28px; }
.guide .section { padding: 104px 0; }
.guide .section--tight { padding: 72px 0; }
.guide .eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.guide .eyebrow::before {
  content: '';
  width: 22px;
  height: 1px;
  background: var(--accent-line);
}
.guide .mono { font-family: 'JetBrains Mono', monospace; }
.guide .section-head { max-width: 680px; }
.guide .section-head h2 {
  font-size: clamp(1.9rem, 3.6vw, 2.85rem);
  margin: 18px 0 0;
}
.guide .section-head p {
  color: var(--text-2);
  font-size: 1.06rem;
  margin-top: 16px;
}
.guide .ticked { position: relative; }
.guide .ticked::before, .guide .ticked::after {
  content: '';
  position: absolute;
  width: 9px; height: 9px;
  border: 1px solid var(--accent-line);
  pointer-events: none;
}
.guide .ticked::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.guide .ticked::after { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }
.guide .btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  padding: 13px 22px;
  border-radius: 9px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 0.45s var(--ease), background 0.3s var(--ease),
              border-color 0.3s var(--ease), color 0.3s var(--ease);
  white-space: nowrap;
}
.guide .btn svg { width: 16px; height: 16px; transition: transform 0.45s var(--ease); }
.guide .btn:hover svg { transform: translateX(3px); }
.guide .btn--primary { background: var(--accent); color: #06130c; }
.guide .btn--primary:hover { transform: translateY(-2px); background: #4ede9c; }
.guide .btn--primary:active { transform: translateY(0) scale(0.985); }
.guide .btn--ghost {
  background: transparent;
  color: var(--text);
  border-color: var(--border-hi);
}
.guide .btn--ghost:hover { transform: translateY(-2px); border-color: var(--accent-line); color: var(--accent); }
.guide .btn--ghost:active { transform: translateY(0) scale(0.985); }
.guide .btn--block { width: 100%; justify-content: center; }
.guide .btn--lg { padding: 16px 28px; font-size: 1.02rem; }
.guide .nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 80;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  border-bottom: 1px solid transparent;
  transition: background 0.4s var(--ease), border-color 0.4s var(--ease),
              backdrop-filter 0.4s var(--ease);
}
.guide .nav.is-stuck {
  background: rgba(11, 12, 14, 0.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom-color: var(--border);
}
.guide .nav__inner {
  width: 100%; max-width: var(--wrap);
  margin: 0 auto; padding: 0 28px;
  display: flex; align-items: center; justify-content: space-between;
}
.guide .brand {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700; font-size: 1.16rem;
  letter-spacing: -0.02em;
}
.guide .brand__mark {
  width: 26px; height: 26px;
  display: grid; place-items: center;
  border: 1px solid var(--accent-line);
  border-radius: 7px;
  background: var(--accent-soft);
}
.guide .brand__mark span {
  width: 9px; height: 9px; border-radius: 2px;
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(63,207,142,0.14);
}
.guide .brand em { color: var(--accent); font-style: normal; }
.guide .brand__name { white-space: nowrap; }
.guide .nav__links { display: flex; align-items: center; gap: 4px; }
.guide .nav__links a:not(.btn) {
  font-size: 0.92rem;
  color: var(--text-2);
  padding: 8px 13px;
  border-radius: 7px;
  transition: color 0.25s var(--ease), background 0.25s var(--ease);
}
.guide .nav__links a:not(.btn):hover { color: var(--text); background: var(--surface-2); }
.guide .nav__links a.is-active { color: var(--accent); }
.guide .nav__links .btn { margin-left: 8px; }
.guide .nav__toggle {
  display: none;
  width: 42px; height: 42px;
  border: 1px solid var(--border-hi);
  border-radius: 8px;
  background: var(--surface);
  cursor: pointer;
  position: relative;
}
.guide .nav__toggle span, .guide .nav__toggle span::before, .guide .nav__toggle span::after {
  content: '';
  position: absolute;
  width: 17px; height: 1.5px;
  background: var(--text);
  left: 50%; transform: translateX(-50%);
  transition: transform 0.35s var(--ease), opacity 0.2s var(--ease);
}
.guide .nav__toggle span { top: 50%; margin-top: -0.75px; }
.guide .nav__toggle span::before { top: -6px; }
.guide .nav__toggle span::after { top: 6px; }
.guide .nav__toggle.is-open span { background: transparent; }
.guide .nav__toggle.is-open span::before { transform: translateY(6px) rotate(45deg); }
.guide .nav__toggle.is-open span::after { transform: translateY(-6px) rotate(-45deg); }
.guide .drawer {
  position: fixed;
  top: var(--nav-h); left: 0; right: 0;
  z-index: 79;
  background: rgba(11,12,14,0.97);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  padding: 14px 28px 26px;
  display: none;
  flex-direction: column;
  gap: 4px;
}
.guide .drawer.is-open { display: flex; }
.guide .drawer a:not(.btn) {
  padding: 13px 6px;
  color: var(--text-2);
  border-bottom: 1px solid var(--border);
  font-size: 1rem;
  opacity: 0;
  transform: translateY(-6px);
  animation: drawerIn 0.4s var(--ease) forwards;
}
.guide .drawer.is-open a:not(.btn):nth-child(1) { animation-delay: 0.04s; }
.guide .drawer.is-open a:not(.btn):nth-child(2) { animation-delay: 0.08s; }
.guide .drawer.is-open a:not(.btn):nth-child(3) { animation-delay: 0.12s; }
.guide .drawer.is-open a:not(.btn):nth-child(4) { animation-delay: 0.16s; }
.guide .drawer.is-open a:not(.btn):nth-child(5) { animation-delay: 0.20s; }
.guide .drawer .btn { margin-top: 16px; }
@keyframes drawerIn { to { opacity: 1; transform: translateY(0); } }
.guide .hero {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  padding: calc(var(--nav-h) + 56px) 0 80px;
  position: relative;
}
.guide .hero::after {
  content: '';
  position: absolute;
  top: -10%; right: -6%;
  width: 620px; height: 620px;
  background: radial-gradient(circle, rgba(63,207,142,0.10) 0%, transparent 66%);
  pointer-events: none;
  z-index: 0;
}
.guide .hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.guide .hero__copy { max-width: 560px; }
.guide .hero h1 {
  font-size: clamp(2.5rem, 5.4vw, 4rem);
  margin: 22px 0 0;
}
.guide .hero h1 .hl { color: var(--accent); }
.guide .hero__lead {
  color: var(--text-2);
  font-size: 1.14rem;
  margin: 22px 0 32px;
  max-width: 480px;
}
.guide .hero__ctas { display: flex; gap: 13px; flex-wrap: wrap; }
.guide .statuspill {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-2);
  padding: 7px 13px;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: var(--surface);
}
.guide .statuspill i {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent);
  animation: blink 2.4s var(--ease) infinite;
}
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0.25;} }
.guide .term {
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg-2) 100%);
  border: 1px solid var(--border);
  border-radius: 13px;
  box-shadow: var(--shadow-md);
  overflow: hidden;
  font-family: 'JetBrains Mono', monospace;
}
.guide .term__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 15px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-2);
}
.guide .term__dot { width: 9px; height: 9px; border-radius: 50%; background: var(--border-hi); }
.guide .term__dot--live { background: var(--accent); }
.guide .term__title {
  margin-left: 6px;
  font-size: 0.72rem;
  color: var(--text-3);
  letter-spacing: 0.06em;
}
.guide .term__body {
  padding: 18px 18px 22px;
  font-size: 0.82rem;
  line-height: 1.85;
  min-height: 338px;
}
.guide .term__line { white-space: pre-wrap; word-break: break-word; }
.guide .term__prompt { color: var(--accent); }
.guide .term__cmd { color: var(--text); }
.guide .term__out { color: var(--text-2); }
.guide .term__ok { color: var(--accent); }
.guide .term__dim { color: var(--text-3); }
.guide .term__cursor {
  display: inline-block;
  width: 8px; height: 1.05em;
  background: var(--accent);
  vertical-align: -2px;
  animation: blink 1.1s steps(1) infinite;
}
.guide .steps { margin-top: 52px; display: grid; gap: 0; }
.guide .step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 26px;
  padding: 34px 0;
  border-top: 1px solid var(--border);
}
.guide .step:last-child { border-bottom: 1px solid var(--border); }
.guide .step__idx {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.78rem;
  color: var(--accent);
  padding-top: 5px;
}
.guide .step__idx b {
  display: block;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.5rem; font-weight: 600;
  color: var(--text);
}
.guide .step__body { max-width: 620px; }
.guide .step__body h3 { font-size: 1.32rem; }
.guide .step__body p { color: var(--text-2); margin-top: 9px; }
.guide .step__tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 14px; }
.guide .tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem;
  color: var(--text-3);
  border: 1px solid var(--border);
  padding: 4px 9px; border-radius: 5px;
}
.guide .srow {
  display: grid;
  grid-template-columns: 0.42fr 0.58fr;
  gap: 48px;
  align-items: center;
  padding: 56px 0;
  border-top: 1px solid var(--border);
}
.guide .srow:last-of-type { border-bottom: 1px solid var(--border); }
.guide .srow--flip .srow__head { order: 2; }
.guide .srow__head { }
.guide .srow__num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.74rem; color: var(--accent);
  letter-spacing: 0.1em;
}
.guide .srow__head h3 { font-size: 1.6rem; margin: 14px 0 12px; }
.guide .srow__head p { color: var(--text-2); }
.guide .srow__list { margin-top: 18px; display: grid; gap: 9px; }
.guide .srow__list li {
  list-style: none;
  display: flex; gap: 11px;
  font-size: 0.95rem; color: var(--text-2);
}
.guide .srow__list svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 4px; color: var(--accent); }
.guide .srow__visual { }
.guide .srow-duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  padding: 56px 0;
  border-top: 1px solid var(--border);
  align-items: start;
}
.guide .srow-duo .srow-mini h3 { font-size: 1.6rem; margin: 14px 0 12px; }
.guide .srow-duo .srow-mini > p { color: var(--text-2); }
.guide .srow-duo .srow-mini .panel { margin-top: 24px; }
.guide .panel {
  border: 1px solid var(--border);
  border-radius: 13px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg-2) 100%);
  padding: 26px;
}
.guide .panel__bar {
  display: flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem; color: var(--text-3);
  letter-spacing: 0.08em;
  padding-bottom: 16px; margin-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.guide .panel__bar .ico {
  width: 26px; height: 26px; border-radius: 7px;
  display: grid; place-items: center;
  background: var(--accent-soft); border: 1px solid var(--accent-line);
  color: var(--accent);
}
.guide .panel__bar .ico svg { width: 15px; height: 15px; }
.guide .kv { display: grid; gap: 12px; }
.guide .kv__row {
  display: flex; align-items: center; justify-content: space-between;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.8rem;
}
.guide .kv__row .k { color: var(--text-3); }
.guide .kv__row .v { color: var(--text); }
.guide .kv__row .v.ok { color: var(--accent); }
.guide .fcards {
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.guide .fcard {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
  padding: 26px 24px;
  transition: border-color 0.4s var(--ease), background 0.4s var(--ease),
              transform 0.5s var(--ease);
}
.guide .fcard:hover {
  border-color: var(--accent-line);
  background: var(--surface-2);
  transform: translateY(-3px);
}
.guide .fcard__ico {
  width: 42px; height: 42px; border-radius: 10px;
  display: grid; place-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--accent-line);
  color: var(--accent);
  margin-bottom: 16px;
}
.guide .fcard__ico svg { width: 20px; height: 20px; }
.guide .fcard h3 { font-size: 1.12rem; }
.guide .fcard p { color: var(--text-2); font-size: 0.93rem; margin-top: 8px; }
.guide .fcard__tag {
  margin-top: 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.68rem; color: var(--text-3);
  letter-spacing: 0.06em;
}
.guide .fcard--wide { grid-column: span 2; }
.guide .fcard--tint {
  background: linear-gradient(135deg, rgba(63,207,142,0.06) 0%, var(--surface) 55%);
  border-color: var(--accent-line);
}
.guide .fcard--wide p { max-width: 62ch; }
.guide .tiers {
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  align-items: start;
}
.guide .tier {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  padding: 30px 26px;
  display: flex; flex-direction: column;
  transition: border-color 0.4s var(--ease), transform 0.5s var(--ease);
}
.guide .tier:hover { border-color: var(--border-hi); transform: translateY(-3px); }
.guide .tier--featured {
  border-color: var(--accent-line);
  background: linear-gradient(180deg, rgba(63,207,142,0.05) 0%, var(--surface) 36%);
  transform: translateY(-10px);
}
.guide .tier--featured:hover { transform: translateY(-13px); }
.guide .tier__flag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.guide .tier__name { font-size: 1.45rem; }
.guide .tier__for {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.74rem; color: var(--text-3);
  margin-top: 8px;
}
.guide .tier__price {
  margin: 20px 0;
  padding: 16px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.guide .tier__price b {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.32rem; font-weight: 600;
  display: block;
}
.guide .tier__price span { font-size: 0.86rem; color: var(--text-3); }
.guide .tier__list { display: grid; gap: 11px; margin-bottom: 26px; }
.guide .tier__list li {
  list-style: none;
  display: flex; gap: 10px;
  font-size: 0.92rem; color: var(--text-2);
}
.guide .tier__list svg { width: 15px; height: 15px; flex-shrink: 0; margin-top: 4px; color: var(--accent); }
.guide .tier .btn { margin-top: auto; }
.guide .duo {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 56px;
  align-items: center;
}
.guide .stat-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--border);
  border-radius: 13px;
  overflow: hidden;
  background: var(--surface);
}
.guide .stat-strip > div {
  padding: 26px 22px;
  border-right: 1px solid var(--border);
}
.guide .stat-strip > div:last-child { border-right: 0; }
.guide .stat-strip--4 { grid-template-columns: repeat(4, 1fr); }
.guide .stat-strip .n {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600; font-size: 2rem; color: var(--accent);
  letter-spacing: -0.02em;
}
.guide .stat-strip .l {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-3);
  margin-top: 7px;
}
.guide .values { display: grid; gap: 2px; margin-top: 40px; }
.guide .value {
  display: grid; grid-template-columns: auto 1fr; gap: 18px;
  padding: 22px 0;
  border-top: 1px solid var(--border);
}
.guide .value:last-child { border-bottom: 1px solid var(--border); }
.guide .value__ico {
  width: 38px; height: 38px; border-radius: 9px;
  display: grid; place-items: center;
  border: 1px solid var(--accent-line);
  background: var(--accent-soft);
  color: var(--accent);
}
.guide .value__ico svg { width: 18px; height: 18px; }
.guide .value h3 { font-size: 1.1rem; }
.guide .value p { color: var(--text-2); font-size: 0.95rem; margin-top: 5px; }
.guide .slab {
  border: 1px solid var(--border);
  border-radius: 18px;
  background:
    radial-gradient(ellipse 70% 100% at 50% 0%, rgba(63,207,142,0.07), transparent 70%),
    var(--surface);
  padding: 64px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.guide .slab::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.guide .slab h2 { font-size: clamp(1.8rem, 3.6vw, 2.7rem); }
.guide .slab p {
  color: var(--text-2);
  max-width: 580px; margin: 16px auto 30px;
  font-size: 1.06rem;
}
.guide .slab .btn { }
.guide .slab__cluster { display: flex; gap: 13px; justify-content: center; flex-wrap: wrap; }
.guide .formwrap {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 48px;
  align-items: start;
}
.guide .field { margin-bottom: 18px; }
.guide .field label {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-2);
  margin-bottom: 8px;
}
.guide .field label .opt { color: var(--text-3); text-transform: none; letter-spacing: 0; }
.guide .field input, .guide .field select, .guide .field textarea {
  width: 100%;
  background: var(--bg-2);
  border: 1px solid var(--field-border);
  border-radius: 9px;
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.96rem;
  padding: 12px 14px;
  transition: border-color 0.3s var(--ease), background 0.3s var(--ease);
}
.guide .field textarea { resize: vertical; min-height: 118px; }
.guide .field input:focus, .guide .field select:focus, .guide .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--surface);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.guide .field input::placeholder, .guide .field textarea::placeholder { color: var(--text-3); }
.guide .field select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239499a1' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
}
.guide .field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.guide .hp { position: absolute; left: -9999px; opacity: 0; height: 0; overflow: hidden; }
.guide .form-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  padding: 30px;
}
.guide .form-note {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.74rem; color: var(--text-3);
  margin-top: 14px; text-align: center;
}
.guide .form-ok {
  display: none;
  text-align: center;
  padding: 44px 24px;
}
.guide .form-ok.is-shown { display: block; }
.guide .form-ok__mark {
  width: 56px; height: 56px; margin: 0 auto 18px;
  border-radius: 50%;
  display: grid; place-items: center;
  border: 1px solid var(--accent-line);
  background: var(--accent-soft);
  color: var(--accent);
}
.guide .form-ok__mark svg { width: 26px; height: 26px; }
.guide .form-ok h3 { font-size: 1.3rem; }
.guide .form-ok p { color: var(--text-2); margin-top: 8px; }
.guide .is-submitting { opacity: 0.55; pointer-events: none; }
.guide .contact-aside { display: grid; gap: 14px; }
.guide .contact-item {
  border: 1px solid var(--border);
  border-radius: 11px;
  background: var(--surface);
  padding: 20px;
  display: flex; gap: 15px; align-items: flex-start;
  transition: border-color 0.35s var(--ease);
}
.guide .contact-item:hover { border-color: var(--accent-line); }
.guide .contact-item__ico {
  width: 38px; height: 38px; border-radius: 9px; flex-shrink: 0;
  display: grid; place-items: center;
  border: 1px solid var(--accent-line);
  background: var(--accent-soft); color: var(--accent);
}
.guide .contact-item__ico svg { width: 17px; height: 17px; }
.guide .contact-item .k {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-3);
}
.guide .contact-item .v { color: var(--text); margin-top: 3px; font-size: 0.98rem; }
.guide .phead {
  padding: calc(var(--nav-h) + 72px) 0 18px;
  position: relative;
}
.guide .phead::after {
  content: '';
  position: absolute; top: 0; right: 0;
  width: 460px; height: 460px;
  background: radial-gradient(circle, rgba(63,207,142,0.08), transparent 68%);
  pointer-events: none;
}
.guide .phead h1 {
  font-size: clamp(2.3rem, 4.6vw, 3.4rem);
  margin-top: 18px;
  max-width: 720px;
}
.guide .phead p {
  color: var(--text-2);
  font-size: 1.1rem;
  margin-top: 16px;
  max-width: 600px;
}
.guide .crumb {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem; color: var(--text-3);
  letter-spacing: 0.06em;
}
.guide .crumb a:hover { color: var(--accent); }
.guide .crumb .sep { color: var(--border-hi); margin: 0 7px; }
.guide .footer {
  border-top: 1px solid var(--border);
  padding: 56px 0 34px;
  margin-top: 40px;
}
.guide .footer__top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--border);
}
.guide .footer__brand { max-width: 320px; }
.guide .footer__brand p {
  color: var(--text-3); font-size: 0.9rem; margin-top: 14px;
}
.guide .footer__col h4 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-3);
  font-weight: 400;
  margin-bottom: 14px;
}
.guide .footer__col a {
  display: block;
  color: var(--text-2);
  font-size: 0.93rem;
  padding: 5px 0;
  transition: color 0.25s var(--ease);
}
.guide .footer__col a:hover { color: var(--accent); }
.guide .footer__bottom {
  display: flex; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
  padding-top: 24px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.74rem;
  color: var(--text-3);
}
.guide .faq { margin-top: 8px; display: grid; max-width: 820px; }
.guide .faq details { border-top: 1px solid var(--border); }
.guide .faq details:last-of-type { border-bottom: 1px solid var(--border); }
.guide .faq summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 4px;
  display: flex; align-items: center; gap: 20px;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600; font-size: 1.05rem;
  transition: color 0.25s var(--ease);
}
.guide .faq summary::-webkit-details-marker { display: none; }
.guide .faq summary:hover { color: var(--accent); }
.guide .faq summary span { flex: 1; }
.guide .faq__pm {
  width: 20px; height: 20px; flex-shrink: 0; position: relative;
}
.guide .faq__pm::before, .guide .faq__pm::after {
  content: ''; position: absolute; background: var(--accent);
  transition: transform 0.4s var(--ease), opacity 0.3s var(--ease);
}
.guide .faq__pm::before { top: 50%; left: 0; right: 0; height: 1.6px; margin-top: -0.8px; }
.guide .faq__pm::after { left: 50%; top: 0; bottom: 0; width: 1.6px; margin-left: -0.8px; }
.guide .faq details[open] .faq__pm::after { transform: rotate(90deg); opacity: 0; }
.guide .faq__a { padding: 0 4px 24px; color: var(--text-2); max-width: 660px; font-size: 0.97rem; }
.guide .js .reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}
.guide .js .reveal.is-in { opacity: 1; transform: translateY(0); }
.guide .reveal[data-delay="1"] { transition-delay: 0.08s; }
.guide .reveal[data-delay="2"] { transition-delay: 0.16s; }
.guide .reveal[data-delay="3"] { transition-delay: 0.24s; }
.guide .reveal[data-delay="4"] { transition-delay: 0.32s; }
@media (prefers-reduced-motion: reduce) {
.guide * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
.guide .reveal { opacity: 1 !important; transform: none !important; }
.guide { scroll-behavior: auto; }
}
@media (max-width: 980px) {
.guide .hero__grid { grid-template-columns: 1fr; gap: 40px; }
.guide .hero { min-height: auto; padding-top: calc(var(--nav-h) + 48px); }
.guide .srow { grid-template-columns: 1fr; gap: 28px; padding: 44px 0; }
.guide .srow--flip .srow__head { order: 0; }
.guide .srow-duo { grid-template-columns: 1fr; gap: 44px; padding: 44px 0; }
.guide .duo { grid-template-columns: 1fr; gap: 36px; }
.guide .tiers { grid-template-columns: 1fr; }
.guide .tier--featured { transform: none; }
.guide .tier--featured:hover { transform: translateY(-3px); }
.guide .formwrap { grid-template-columns: 1fr; gap: 32px; }
.guide .footer__top { grid-template-columns: 1fr 1fr; gap: 28px; }
.guide .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 760px) {
.guide .nav__links { display: none; }
.guide .nav__toggle { display: block; }
.guide .section { padding: 72px 0; }
.guide .wrap { padding: 0 20px; }
.guide .nav__inner { padding: 0 20px; }
.guide .fcards { grid-template-columns: 1fr; }
.guide .fcard--wide { grid-column: span 1; }
.guide .tiers { grid-template-columns: 1fr; }
.guide .tier--featured { transform: none; }
.guide .tier--featured:hover { transform: translateY(-3px); }
.guide .slab { padding: 44px 24px; }
.guide .stat-strip, .guide .stat-strip--4 { grid-template-columns: 1fr; }
.guide .stat-strip > div { border-right: 0; border-bottom: 1px solid var(--border); }
.guide .stat-strip > div:last-child { border-bottom: 0; }
.guide .field--row { grid-template-columns: 1fr; }
.guide .step { grid-template-columns: 1fr; gap: 10px; }
.guide .footer__top { grid-template-columns: 1fr; }
}
@media (max-width: 460px) {
.guide .hero h1 { font-size: 2.4rem; }
}
.guide .nav__dd { position: relative; display: flex; align-items: center; }
.guide .nav__dd-btn { font-family: inherit; font-size: 0.92rem; color: var(--text-2); background: none; border: 0; cursor: pointer; padding: 8px 13px; border-radius: 8px; display: inline-flex; align-items: center; gap: 5px; }
.guide .nav__dd-btn:hover, .guide .nav__dd:focus-within .nav__dd-btn { color: var(--text); background: var(--surface-2); }
.guide .nav__dd-caret { width: 12px; height: 12px; transition: transform .2s ease; }
.guide .nav__dd:hover .nav__dd-caret, .guide .nav__dd:focus-within .nav__dd-caret { transform: rotate(180deg); }
.guide .nav__dd-menu { position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%) translateY(6px); background: rgba(17,19,24,0.98); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); border: 1px solid var(--border-hi); border-radius: 16px; padding: 16px; min-width: 540px; box-shadow: 0 24px 64px rgba(0,0,0,.55); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .18s ease, transform .18s ease; z-index: 90; }
.guide .nav__dd:hover .nav__dd-menu, .guide .nav__dd:focus-within .nav__dd-menu { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.guide .nav__dd-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 4px 20px; }
.guide .nav__dd-col { display: flex; flex-direction: column; }
.guide .nav__dd-menu a { padding: 7px 10px; border-radius: 8px; color: var(--text-2); font-size: 0.875rem; text-decoration: none; white-space: nowrap; }
.guide .nav__dd-menu a:hover { color: var(--text); background: var(--surface-2); }
.guide .nav__dd-head { color: var(--text); font-weight: 600; font-size: 0.7rem; text-transform: uppercase; letter-spacing: .07em; opacity: .5; margin-bottom: 3px; }
.guide .nav__dd-head:hover { opacity: 1; background: none; color: var(--accent); }
.guide .drawer__group { border-bottom: 1px solid var(--border); }
.guide .drawer__group > summary { list-style: none; cursor: pointer; padding: 13px 6px; color: var(--text-2); display: flex; align-items: center; justify-content: space-between; }
.guide .drawer__group > summary::-webkit-details-marker { display: none; }
.guide .drawer__group > summary::after { content: "+"; color: var(--text-3, var(--text-2)); font-size: 1.1rem; }
.guide .drawer__group[open] > summary::after { content: "\2212"; }
.guide .drawer__group a { display: block; padding: 10px 6px 10px 18px; color: var(--text-2); font-size: 0.92rem; text-decoration: none; border: 0; }
.guide .drawer__group a:hover { color: var(--text); }
.guide .pf-wrap {max-width:760px;margin:0 auto;padding:0 22px}
.guide .pf section {margin:46px auto}
.guide .pf h2 {font-family:'Space Grotesk',sans-serif;font-size:1.55rem;line-height:1.2;margin:0 0 14px}
.guide .pf h3 {font-family:'Space Grotesk',sans-serif;font-size:1.18rem;line-height:1.25;margin:22px 0 8px;color:#eef1f5}
.guide .pf p {font-family:'DM Sans',sans-serif;color:#c3c7cf;line-height:1.7;margin:0 0 14px;font-size:1.12rem}
.guide .pf ul {font-family:'DM Sans',sans-serif;color:#c3c7cf;line-height:1.7;margin:0 0 14px;padding-left:22px}
.guide .pf li {margin:0 0 8px}
.guide .pf strong {color:#eef1f5}
.guide .pf a {color:#3fcf8e}
.guide .pf .lead {font-size:1.22rem;color:#dfe3e9;line-height:1.55}
.guide .pf-card {background:#121419;border:1px solid #232733;border-radius:16px;padding:26px 26px 8px}
.guide .pf-stat {display:flex;flex-wrap:wrap;gap:26px;margin:6px 0 18px}
.guide .pf-stat div {min-width:120px}
.guide .pf-stat b {font-family:'JetBrains Mono',monospace;font-size:1.7rem;color:#3fcf8e;display:block;line-height:1.1}
.guide .pf-stat span {font-family:'DM Sans',sans-serif;font-size:.86rem;color:#9aa0ab}
.guide .pf-check {font-family:'DM Sans',sans-serif;color:#c3c7cf;line-height:1.6;margin:0 0 12px;padding-left:26px;position:relative}
.guide .pf-check:before {content:"";position:absolute;left:0;top:8px;width:11px;height:11px;border-radius:3px;background:#3fcf8e}
.guide .pf-faq {border-top:1px solid #232733;padding:18px 0}
.guide .pf-faq h3 {font-family:'Space Grotesk',sans-serif;font-size:1.06rem;margin:0 0 8px;color:#eef1f5}
.guide .pf-note {font-size:.85rem;color:#7b818c;font-style:italic}
.guide .pf-table {width:100%;border-collapse:collapse;font-family:'DM Sans',sans-serif;color:#c3c7cf;font-size:.95rem;margin:6px 0 18px}
.guide .pf-table th, .guide .pf-table td {border:1px solid #232733;padding:10px 12px;text-align:left;vertical-align:top;line-height:1.5}
.guide .pf-table th {color:#eef1f5;font-family:'Space Grotesk',sans-serif;font-weight:600;background:#121419}
.guide .pf-table thead th:first-child {background:transparent;border-color:transparent}
.guide .pf-cta {text-align:center;background:#121419;border:1px solid #232733;border-radius:18px;padding:38px 22px}


/* ===== guide table of contents ===== */
.guide .guide-toc{max-width:760px;margin:10px auto 30px;padding:18px 22px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,0.025)}
.guide .guide-toc__label{font-family:'JetBrains Mono',monospace;font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin:0 0 12px}
.guide .guide-toc ol{margin:0;padding:0;list-style:none;counter-reset:toc;display:grid;grid-template-columns:1fr 1fr;gap:4px 26px}
.guide .guide-toc li{margin:0}
.guide .guide-toc a{counter-increment:toc;display:flex;gap:9px;align-items:baseline;color:var(--text-2);text-decoration:none;font-size:1rem;line-height:1.45;padding:4px 0}
.guide .guide-toc a::before{content:counter(toc);color:var(--text-3);font-family:'JetBrains Mono',monospace;font-size:0.8rem;min-width:18px}
.guide .guide-toc a:hover{color:var(--accent)}
html{scroll-behavior:smooth}
@media(max-width:640px){.guide .guide-toc ol{grid-template-columns:1fr}}

/* ===== HOMEPAGE: funnel reposition ===== */
.funnel-wrap{display:flex;justify-content:center;align-items:flex-start;position:relative}
.funnel{position:relative;width:100%;max-width:360px;padding-right:20px}
.funnel__cap{font-family:'JetBrains Mono',monospace;font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);text-align:center;margin-bottom:14px}
.funnel__stages{display:flex;flex-direction:column;align-items:center;gap:9px;position:relative}
.funnel__stages::before{content:'';position:absolute;top:6px;bottom:-6px;left:50%;width:2px;transform:translateX(-50%);background:linear-gradient(var(--accent),rgba(63,207,142,0.05));opacity:.35}
.fstage{width:var(--w);max-width:100%;background:var(--surface);border:1px solid var(--accent-line);border-radius:11px;padding:11px 14px;display:flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:0.9rem;color:var(--text);position:relative;z-index:1;box-shadow:0 6px 18px rgba(0,0,0,0.25)}
.fstage__dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex:none;box-shadow:0 0 0 3px rgba(63,207,142,0.18)}
.funnel__out{width:34%;min-width:120px;margin:10px auto 0;background:var(--gold-grad);color:#06130c;font-weight:700;text-align:center;border-radius:11px;padding:11px 8px;font-size:0.85rem;position:relative;z-index:1}
.funnel__base{margin-top:16px;border:1px dashed var(--accent-line);border-radius:12px;padding:14px;text-align:center;background:rgba(63,207,142,0.05)}
.funnel__base span{font-family:'JetBrains Mono',monospace;font-size:0.72rem;letter-spacing:0.06em;text-transform:uppercase;color:var(--accent)}
.funnel__loop{position:absolute;right:-12px;top:54px;display:flex;flex-direction:column;align-items:center;color:var(--accent);opacity:.7;pointer-events:none}
.funnel__loop svg{width:30px;height:108px}
.funnel__loop span{writing-mode:vertical-rl;font-size:0.58rem;font-family:'JetBrains Mono',monospace;letter-spacing:0.12em;text-transform:uppercase;margin-top:4px}

/* foundation */
.found{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:680px;margin:46px auto 0}
.found__layer{width:100%;border:1px solid var(--border);border-radius:16px;padding:22px 26px;background:var(--surface);text-align:center}
.found__layer b{display:block;font-size:1.08rem;margin-bottom:7px}
.found__layer span{color:var(--text-2);font-size:0.96rem;line-height:1.55}
.found__layer--team{background:rgba(63,207,142,0.06);border-color:var(--accent-line)}
.found__arrow{color:var(--accent)}.found__arrow svg{width:24px;height:34px}

/* team roles */
.roles{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;margin-top:46px}
.role{display:flex;gap:15px;align-items:flex-start;border:1px solid var(--border);border-radius:16px;padding:22px;background:var(--surface)}
.role__n{flex:none;width:34px;height:34px;border-radius:10px;background:var(--gold-grad);color:#06130c;font-weight:800;display:grid;place-items:center;font-family:'JetBrains Mono',monospace;font-size:0.95rem}
.role__b h3{font-size:1.06rem;margin-bottom:6px}
.role__b p{color:var(--text-2);font-size:0.95rem;line-height:1.55}

/* improve */
.improve{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:46px;max-width:980px;margin-left:auto;margin-right:auto}
.imp{border-top:2px solid var(--accent);padding:18px 2px 0}
.imp b{display:block;font-size:1.06rem;margin-bottom:7px}
.imp span{color:var(--text-2);font-size:0.95rem;line-height:1.55}

/* outcome */
.outcome{display:grid;grid-template-columns:1.1fr 0.9fr;gap:54px;align-items:center}
.outcome__lead .eyebrow{margin-bottom:14px}
.outcome__lead h2{font-size:clamp(1.9rem,3.4vw,2.7rem)}
.outcome__lead p{color:var(--text-2);font-size:1.08rem;line-height:1.65;margin:18px 0 26px;max-width:540px}
.outcome__list{display:grid;gap:0;list-style:none;margin:0;padding:0}
.outcome__list li{display:flex;flex-direction:column;gap:4px;padding:18px 0;border-top:1px solid var(--border)}
.outcome__list li:last-child{border-bottom:1px solid var(--border)}
.outcome__list b{font-size:1.05rem}
.outcome__list span{color:var(--text-2);font-size:0.94rem}

@media (max-width:900px){
  .outcome{grid-template-columns:1fr;gap:30px}
  .improve{grid-template-columns:1fr;gap:22px;max-width:520px}
  .funnel__loop{display:none}
  .funnel{max-width:340px;padding-right:0;margin-top:30px}
}
@media (max-width:600px){ .roles{grid-template-columns:1fr} }
