/* =====================================================
   BobRay · global.css — Design System
   Privacy-first analytics. Minimal. Light + Dark.
   ===================================================== */

/* ── Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;450;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ── Tokens ── */
:root{
  --bg:#ffffff;
  --bg-alt:#f6f7f6;
  --bg-deep:#eef0ee;
  --surface:#ffffff;
  --surface-2:#fafbfa;
  --ink:#0d1310;
  --ink-2:#3d453f;
  --muted:#6b736d;
  --faint:#9aa39c;
  --line:rgba(13,19,16,0.09);
  --line-2:rgba(13,19,16,0.05);
  --accent:#00b364;
  --accent-2:#00c26e;
  --accent-soft:rgba(0,194,110,0.10);
  --accent-line:rgba(0,194,110,0.22);
  --on-accent:#04140c;
  --danger:#d8472b;
  --warn:#c98a00;

  --font-display:'Space Grotesk',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  --maxw:1140px;
  --maxw-wide:1280px;
  --radius-sm:8px;
  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;

  --pad-section:104px;
  --header-h:64px;

  --shadow-sm:0 1px 2px rgba(13,19,16,0.05), 0 1px 3px rgba(13,19,16,0.04);
  --shadow:0 4px 16px rgba(13,19,16,0.07);
  --shadow-lg:0 18px 48px rgba(13,19,16,0.12);

  --ease:cubic-bezier(0.22,1,0.36,1);
  --dur:0.32s;
  --dur-slow:0.7s;
}

[data-theme="dark"]{
  --bg:#080a09;
  --bg-alt:#0e120f;
  --bg-deep:#141815;
  --surface:#10140f;
  --surface-2:#0c0f0d;
  --ink:#f1f4f1;
  --ink-2:#c3c9c4;
  --muted:#8a938c;
  --faint:#5c655e;
  --line:rgba(255,255,255,0.10);
  --line-2:rgba(255,255,255,0.05);
  --accent:#1edb83;
  --accent-2:#2ee892;
  --accent-soft:rgba(46,232,146,0.10);
  --accent-line:rgba(46,232,146,0.22);
  --on-accent:#04140c;
  --shadow-sm:0 1px 2px rgba(0,0,0,0.4);
  --shadow:0 4px 18px rgba(0,0,0,0.5);
  --shadow-lg:0 20px 50px rgba(0,0,0,0.6);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .4s var(--ease), color .4s var(--ease);
}

::selection{background:var(--accent-soft);color:var(--ink)}

/* scrollbar */
*{scrollbar-width:thin;scrollbar-color:var(--line) transparent}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--faint)}

/* =========================================
   Typography
   ========================================= */
.b-display{font-family:var(--font-display)}
.b-mono{font-family:var(--font-mono)}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.08;letter-spacing:-0.02em;font-weight:600}

.b-h1{font-size:clamp(2.4rem,5.6vw,4rem);font-weight:600;letter-spacing:-0.035em;line-height:1.04}
.b-h2{font-size:clamp(1.8rem,3.6vw,2.7rem);letter-spacing:-0.03em;line-height:1.08;margin-bottom:14px}
.b-h3{font-size:clamp(1.1rem,1.8vw,1.3rem);font-weight:600;letter-spacing:-0.02em;margin-bottom:8px}
.b-h4{font-size:1.02rem;font-weight:600}

.b-p{font-size:clamp(0.96rem,1.2vw,1.06rem);color:var(--muted);line-height:1.7}
.b-p-lg{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--ink-2);line-height:1.65}
.b-p-sm{font-size:0.9rem;color:var(--muted);line-height:1.6}

.b-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);
  font-size:0.72rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--accent);margin-bottom:18px;
}
.b-eyebrow::before{content:'';width:8px;height:8px;border-radius:2px;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}

.b-accent{color:var(--accent)}
.b-muted{color:var(--muted)}

/* =========================================
   Layout
   ========================================= */
.b-section{padding:var(--pad-section) 24px}
.b-section-sm{padding:64px 24px}
.b-divided{border-top:1px solid var(--line)}
.b-alt{background:var(--bg-alt)}
.b-container{max-width:var(--maxw);margin:0 auto;width:100%}
.b-container-wide{max-width:var(--maxw-wide);margin:0 auto;width:100%}

.b-head{max-width:640px;margin:0 auto 56px;text-align:center}
.b-head.left{margin-left:0;text-align:left}
.b-head .b-eyebrow{margin-bottom:16px}

/* =========================================
   Buttons
   ========================================= */
.b-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-body);font-size:0.94rem;font-weight:500;
  padding:12px 22px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--on-accent);
  transition:transform var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  white-space:nowrap;
}
.b-btn i{font-size:1.05em;transition:transform var(--dur) var(--ease)}
.b-btn:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 8px 24px var(--accent-soft)}
.b-btn:hover i.arrow{transform:translateX(3px)}
.b-btn:active{transform:translateY(0)}

.b-btn-outline{background:transparent;color:var(--ink);border:1px solid var(--line)}
.b-btn-outline:hover{background:var(--bg-alt);border-color:var(--faint);box-shadow:none}

.b-btn-ghost{background:transparent;color:var(--ink);border:1px solid transparent}
.b-btn-ghost:hover{background:var(--bg-alt);box-shadow:none}

.b-btn-sm{padding:9px 16px;font-size:0.86rem}
.b-btn-lg{padding:15px 30px;font-size:1rem}
.b-btn-full{width:100%}

.b-link{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-weight:500;font-size:0.94rem;transition:gap var(--dur) var(--ease)}
.b-link:hover{gap:10px}

/* =========================================
   Header
   ========================================= */
#b-header{
  position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid transparent;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
#b-header.scrolled{border-bottom-color:var(--line)}
.b-logo{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:1.12rem;letter-spacing:-0.02em;color:var(--ink)}
.b-logo-mark{
  width:26px;height:26px;border-radius:7px;
  background:var(--accent);position:relative;flex-shrink:0;
  display:grid;place-items:center;
}
.b-logo-mark::before{content:'';width:11px;height:11px;border:2px solid var(--on-accent);border-radius:50%;}
.b-logo-mark::after{content:'';position:absolute;width:5px;height:5px;border-radius:50%;background:var(--on-accent)}
.b-logo b{font-weight:600}
.b-logo span{color:var(--accent)}

.b-nav{display:flex;align-items:center;gap:4px}
.b-nav a{
  font-size:0.9rem;font-weight:450;color:var(--ink-2);
  padding:8px 13px;border-radius:var(--radius-sm);
  transition:color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.b-nav a:hover{color:var(--ink);background:var(--bg-alt)}
.b-nav a.active{color:var(--accent)}

.b-header-actions{display:flex;align-items:center;gap:8px}
.b-theme-btn{
  width:38px;height:38px;border-radius:var(--radius-sm);
  display:grid;place-items:center;color:var(--ink-2);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.b-theme-btn:hover{background:var(--bg-alt);color:var(--ink)}
.b-theme-btn i{font-size:1.15rem}
.b-menu-btn{display:none;width:38px;height:38px;border-radius:var(--radius-sm);place-items:center;color:var(--ink);font-size:1.4rem}

/* mobile nav */
.b-mobile-nav{
  position:fixed;inset:0;z-index:899;background:var(--bg);
  transform:translateX(100%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;padding-top:var(--header-h);
}
.b-mobile-nav.open{transform:translateX(0)}
.b-mobile-body{flex:1;overflow-y:auto;padding:18px 24px}
.b-mobile-body a{
  display:flex;align-items:center;justify-content:space-between;
  padding:17px 4px;font-family:var(--font-display);font-size:1.25rem;font-weight:500;
  color:var(--ink);border-bottom:1px solid var(--line);
}
.b-mobile-body a i{color:var(--faint);font-size:1rem}
.b-mobile-footer{padding:24px;border-top:1px solid var(--line)}

/* scroll progress */
#b-progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:901;width:0;transition:width .1s linear}

/* =========================================
   Reveal animation
   ========================================= */
.b-reveal{opacity:0;transform:translateY(22px);transition:opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease)}
.b-reveal.visible{opacity:1;transform:none}
.b-d1{transition-delay:.08s}.b-d2{transition-delay:.16s}.b-d3{transition-delay:.24s}.b-d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .b-reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto!important}
}

/* =========================================
   Hero
   ========================================= */
.hero{position:relative;padding:calc(var(--header-h) + 90px) 24px 96px;overflow:hidden}
.hero-inner{max-width:var(--maxw);margin:0 auto}
.hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center}
.hero-tag{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:0.76rem;letter-spacing:0.02em;
  color:var(--ink-2);background:var(--surface);border:1px solid var(--line);
  padding:7px 14px;border-radius:var(--radius-pill);margin-bottom:26px;
}
.hero-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent-soft);animation:pulse 2.2s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--accent-line)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
.hero h1{margin-bottom:22px}
.hero-sub{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--muted);line-height:1.6;max-width:480px;margin-bottom:32px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.hero-trust{display:flex;align-items:center;gap:18px;font-size:0.82rem;color:var(--faint);flex-wrap:wrap}
.hero-trust span{display:inline-flex;align-items:center;gap:6px}
.hero-trust i{color:var(--accent)}

/* hero panel - fake live dashboard */
.hero-panel{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);overflow:hidden;
}
.hero-panel-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.hp-dot{width:10px;height:10px;border-radius:50%;background:var(--line)}
.hero-panel-url{margin-left:8px;font-family:var(--font-mono);font-size:0.74rem;color:var(--faint)}
.hero-panel-body{padding:22px}
.hp-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:20px}
.hp-metric-label{font-size:0.78rem;color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.08em}
.hp-metric-val{font-family:var(--font-display);font-size:2.3rem;font-weight:600;letter-spacing:-0.03em;color:var(--ink);line-height:1}
.hp-delta{font-family:var(--font-mono);font-size:0.78rem;color:var(--accent);background:var(--accent-soft);padding:3px 8px;border-radius:6px}
.hp-chart{display:flex;align-items:flex-end;gap:5px;height:96px;margin-bottom:18px}
.hp-bar{flex:1;background:var(--accent-soft);border-radius:4px 4px 2px 2px;position:relative;transition:height .5s var(--ease)}
.hp-bar::after{content:'';position:absolute;inset:0 0 auto;height:3px;background:var(--accent);border-radius:4px 4px 0 0;opacity:.9}
.hp-foot{display:flex;gap:10px}
.hp-mini{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 12px}
.hp-mini-l{font-size:0.68rem;color:var(--faint);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:3px}
.hp-mini-v{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink)}

/* =========================================
   Stat strip
   ========================================= */
.stat-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-alt)}
.stat-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{padding:38px 24px;text-align:center;border-right:1px solid var(--line)}
.stat-cell:last-child{border-right:none}
.stat-val{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:600;letter-spacing:-0.03em;color:var(--ink);line-height:1}
.stat-val .u{color:var(--accent)}
.stat-label{font-family:var(--font-mono);font-size:0.74rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-top:10px}

/* =========================================
   Feature cards / bento
   ========================================= */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.b-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:30px;transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.b-card:hover{border-color:var(--accent-line);transform:translateY(-3px);box-shadow:var(--shadow)}
.span2{grid-column:span 2}.span3{grid-column:span 3}.span4{grid-column:span 4}.span6{grid-column:span 6}
.b-card-icon{
  width:44px;height:44px;border-radius:11px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent);font-size:1.3rem;margin-bottom:18px;
}
.b-card .b-h3{margin-bottom:8px}
.b-card .b-p{font-size:0.94rem}

/* feature row */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* =========================================
   Numbered steps
   ========================================= */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step}
.step{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;position:relative;
}
.step-num{font-family:var(--font-mono);font-size:0.8rem;color:var(--accent);margin-bottom:16px;letter-spacing:0.05em}
.step h3{margin-bottom:8px}

/* =========================================
   Pricing
   ========================================= */
.pricing-toggle{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:48px;font-size:0.92rem;color:var(--muted)}
.toggle-switch{width:48px;height:27px;border-radius:999px;background:var(--bg-deep);border:1px solid var(--line);position:relative;cursor:pointer;transition:background var(--dur) var(--ease)}
.toggle-switch.on{background:var(--accent)}
.toggle-knob{position:absolute;top:2px;left:2px;width:21px;height:21px;border-radius:50%;background:#fff;transition:transform var(--dur) var(--ease);box-shadow:var(--shadow-sm)}
.toggle-switch.on .toggle-knob{transform:translateX(21px)}
.toggle-save{font-family:var(--font-mono);font-size:0.72rem;color:var(--accent);background:var(--accent-soft);padding:3px 9px;border-radius:6px}

.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.price-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px 28px;display:flex;flex-direction:column;position:relative;
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.price-card:hover{border-color:var(--accent-line);transform:translateY(-3px);box-shadow:var(--shadow)}
.price-card.featured{border-color:var(--accent);box-shadow:var(--shadow);background:var(--surface)}
.price-card.featured::before{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);padding:1px;background:linear-gradient(160deg,var(--accent),transparent 55%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.price-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--on-accent);font-family:var(--font-mono);font-size:0.68rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;padding:5px 13px;border-radius:999px}
.price-name{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--ink);margin-bottom:5px}
.price-tag{font-size:0.88rem;color:var(--muted);margin-bottom:22px;min-height:40px}
.price-amount{display:flex;align-items:flex-start;gap:2px;margin-bottom:4px}
.price-cur{font-family:var(--font-display);font-size:1.3rem;font-weight:500;color:var(--ink);margin-top:6px}
.price-num{font-family:var(--font-display);font-size:3rem;font-weight:600;letter-spacing:-0.04em;color:var(--ink);line-height:1}
.price-per{font-size:0.86rem;color:var(--muted);margin-bottom:24px}
.price-feats{display:flex;flex-direction:column;gap:13px;margin-bottom:28px;flex:1}
.price-feats li{display:flex;gap:11px;align-items:flex-start;font-size:0.9rem;color:var(--ink-2);line-height:1.45}
.price-check{flex-shrink:0;width:18px;height:18px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:0.6rem;margin-top:2px}

/* =========================================
   Logos / marquee
   ========================================= */
.marquee{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:56px;width:max-content;animation:scroll 32s linear infinite}
@keyframes scroll{to{transform:translateX(-50%)}}
.marquee-item{font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--faint);white-space:nowrap;display:flex;align-items:center;gap:9px;opacity:.75}
.marquee-item i{font-size:1.3rem}

/* =========================================
   Testimonials
   ========================================= */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column}
.quote-stars{color:var(--accent);font-size:0.82rem;margin-bottom:14px;display:flex;gap:3px}
.quote-text{font-size:0.98rem;color:var(--ink-2);line-height:1.6;flex:1;margin-bottom:20px}
.quote-author{display:flex;align-items:center;gap:12px}
.quote-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-family:var(--font-display);font-weight:600}
.quote-name{font-weight:600;font-size:0.9rem;color:var(--ink)}
.quote-role{font-size:0.8rem;color:var(--muted)}

/* =========================================
   CTA banner
   ========================================= */
.cta{background:var(--ink);color:var(--bg);text-align:center;padding:96px 24px;position:relative;overflow:hidden}
[data-theme="dark"] .cta{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta::before{content:'';position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:600px;height:600px;background:radial-gradient(circle,var(--accent-soft),transparent 65%);pointer-events:none}
.cta-inner{position:relative;max-width:640px;margin:0 auto}
.cta h2{color:var(--bg);margin-bottom:16px}
[data-theme="dark"] .cta h2{color:var(--ink)}
.cta p{color:rgba(255,255,255,0.6);font-size:1.08rem;margin-bottom:32px}
[data-theme="dark"] .cta p{color:var(--muted)}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta .b-btn-outline{color:#fff;border-color:rgba(255,255,255,0.2)}
.cta .b-btn-outline:hover{background:rgba(255,255,255,0.08)}
[data-theme="dark"] .cta .b-btn-outline{color:var(--ink);border-color:var(--line)}
[data-theme="dark"] .cta .b-btn-outline:hover{background:var(--bg-alt)}

/* =========================================
   Footer
   ========================================= */
#b-footer{background:var(--bg-alt);border-top:1px solid var(--line);padding:64px 24px 32px}
.footer-main{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer-brand .b-logo{margin-bottom:16px}
.footer-brand p{font-size:0.9rem;color:var(--muted);max-width:300px;line-height:1.6}
.footer-social{display:flex;gap:10px;margin-top:20px}
.footer-social a{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:all var(--dur) var(--ease)}
.footer-social a:hover{color:var(--accent);border-color:var(--accent-line);background:var(--accent-soft)}
.footer-col-title{font-family:var(--font-mono);font-size:0.72rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--faint);margin-bottom:16px}
.footer-col a{display:block;font-size:0.9rem;color:var(--ink-2);padding:6px 0;transition:color var(--dur) var(--ease)}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{max-width:var(--maxw);margin:48px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:0.82rem;color:var(--faint)}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap}
.footer-legal a{font-size:0.82rem;color:var(--muted);transition:color var(--dur) var(--ease)}
.footer-legal a:hover{color:var(--accent)}

/* =========================================
   Page hero (interior pages)
   ========================================= */
.page-hero{padding:calc(var(--header-h) + 72px) 24px 64px;text-align:center;border-bottom:1px solid var(--line)}
.page-hero .b-eyebrow{justify-content:center}
.page-hero h1{font-size:clamp(2.2rem,4.5vw,3.4rem);margin-bottom:18px}
.page-hero p{max-width:580px;margin:0 auto;font-size:clamp(1rem,1.4vw,1.15rem);color:var(--muted)}

/* =========================================
   Accordion (FAQ)
   ========================================= */
.acc{max-width:760px;margin:0 auto}
.acc-item{border-bottom:1px solid var(--line)}
.acc-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 4px;text-align:left;font-family:var(--font-display);font-size:1.05rem;font-weight:500;color:var(--ink)}
.acc-trigger i{color:var(--faint);transition:transform var(--dur) var(--ease);flex-shrink:0}
.acc-item.open .acc-trigger i{transform:rotate(45deg);color:var(--accent)}
.acc-body{max-height:0;overflow:hidden;transition:max-height var(--dur) var(--ease)}
.acc-body-inner{padding:0 4px 22px;color:var(--muted);font-size:0.96rem;line-height:1.7}

/* =========================================
   Tabs
   ========================================= */
.b-tabs{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:44px;padding:6px;background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius-pill);width:max-content;margin-left:auto;margin-right:auto;max-width:100%}
.b-tab{padding:9px 18px;border-radius:var(--radius-pill);font-size:0.88rem;font-weight:500;color:var(--muted);transition:all var(--dur) var(--ease)}
.b-tab.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.b-panel{display:none}
.b-panel.active{display:block;animation:fade .4s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* =========================================
   Forms
   ========================================= */
.field{margin-bottom:18px}
.field label{display:block;font-size:0.86rem;font-weight:500;color:var(--ink-2);margin-bottom:7px}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--font-body);font-size:0.94rem;color:var(--ink);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:12px 14px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* =========================================
   Notice / callout
   ========================================= */
.callout{display:flex;gap:14px;background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:var(--radius);padding:18px 20px;align-items:flex-start}
.callout i{color:var(--accent);font-size:1.3rem;flex-shrink:0;margin-top:1px}
.callout-text{font-size:0.92rem;color:var(--ink-2);line-height:1.6}
.callout-text strong{color:var(--ink)}

/* =========================================
   Legal pages
   ========================================= */
.legal-wrap{max-width:780px;margin:0 auto;padding:calc(var(--header-h) + 56px) 24px 80px}
.legal-wrap h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:10px}
.legal-meta{font-family:var(--font-mono);font-size:0.8rem;color:var(--faint);margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.legal-wrap h2{font-size:1.35rem;margin:38px 0 12px}
.legal-wrap h3{font-size:1.05rem;margin:24px 0 8px}
.legal-wrap p{color:var(--ink-2);margin-bottom:14px;font-size:0.96rem;line-height:1.75}
.legal-wrap ul{margin:0 0 16px 0;padding-left:0}
.legal-wrap li{position:relative;padding-left:22px;margin-bottom:9px;color:var(--ink-2);font-size:0.96rem;line-height:1.7}
.legal-wrap li::before{content:'';position:absolute;left:4px;top:11px;width:6px;height:6px;border-radius:2px;background:var(--accent)}
.legal-wrap a{color:var(--accent)}
.legal-toc{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;margin-bottom:36px}
.legal-toc-title{font-family:var(--font-mono);font-size:0.74rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--faint);margin-bottom:12px}
.legal-toc a{display:block;padding:5px 0;font-size:0.9rem;color:var(--ink-2)}
.legal-toc a:hover{color:var(--accent)}

/* =========================================
   Utility
   ========================================= */
.b-hidden{display:none!important}
.text-center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:28px}.mt-l{margin-top:48px}
.b-divider{height:1px;background:var(--line);border:none;margin:0}

/* =========================================
   Responsive
   ========================================= */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-panel{max-width:520px}
  .bento{grid-template-columns:repeat(2,1fr)}
  .span2,.span3,.span4{grid-column:span 1}
  .span6{grid-column:span 2}
  .feat-grid,.steps,.price-grid,.quote-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:768px){
  :root{--pad-section:72px;--header-h:60px}
  .b-nav,.b-header-cta{display:none}
  .b-menu-btn{display:grid}
  .stat-inner{grid-template-columns:1fr 1fr}
  .stat-cell:nth-child(2){border-right:none}
  .stat-cell:nth-child(1),.stat-cell:nth-child(2){border-bottom:1px solid var(--line)}
}
@media (max-width:520px){
  .footer-main{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .b-section{padding:var(--pad-section) 18px}
}
