/* ═══════════════════════════════════════════════════════════
   ServerCrate — Production CSS v3.3
   Syne (display) + DM Sans (body) + Geist Mono (code)
   ═══════════════════════════════════════════════════════════ */

:root {
  --ink:    #0d1117;
  --ink2:   #21262d;
  --ink3:   #484f58;
  --ink4:   #8b949e;
  --ink5:   #b1bac4;
  --bg:     #ffffff;
  --bg2:    #f6f8fa;
  --bg3:    #eef1f5;
  --border: #d0d7de;
  --border2:#e0e6ed;

  --blue:   #58a6ff;
  --blue-d: #1f6feb;
  --blue-l: #a5d6ff;
  --teal:   #3fb950;
  --amber:  #d29922;
  --red:    #f85149;

  --dark:        #0d1117;
  --dark2:       #161b22;
  --dark3:       #21262d;
  --dark4:       #30363d;
  --dark5:       #484f58;
  --dark-border: #30363d;

  --font:    'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --display: 'Syne', var(--font);
  --mono:    'Geist Mono', 'SF Mono', 'Fira Code', monospace;

  --nav-h:  60px;
  --max:    1140px;
  --px:     clamp(20px, 5vw, 72px);
  --ease:   cubic-bezier(.16,1,.3,1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:var(--font);cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ── Nav ── */
#site-header{position:fixed;top:0;left:0;right:0;z-index:9000;height:var(--nav-h)}

.nav-shell{
  height:var(--nav-h);display:flex;align-items:center;
  border-bottom:1px solid transparent;
  transition:background .25s var(--ease),border-color .25s,backdrop-filter .25s}

.nav-shell.scrolled{
  background:rgba(13,17,23,.9);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--dark-border)}

.nav-shell.light-nav{
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--border);box-shadow:0 1px 0 var(--border2)}
.nav-shell.light-nav.scrolled{
  background:rgba(255,255,255,.98)}

.nav-bar{
  width:100%;max-width:var(--max);margin:0 auto;
  padding:0 var(--px);display:flex;align-items:center}

/* Logo */
.site-logo{display:flex;align-items:center;margin-right:auto;flex-shrink:0}
.site-logo img{height:24px;width:auto;display:block}
.logo-wordmark{
  font-family:var(--display);font-weight:800;font-size:1.05rem;
  letter-spacing:-.03em;color:#fff}
.nav-shell.light-nav .logo-wordmark{color:var(--ink)}

/* Nav links */
.nav-links{display:flex;align-items:center;gap:2px;margin-left:28px}
.nav-links a{
  padding:6px 11px;border-radius:6px;font-size:.875rem;font-weight:500;
  color:rgba(255,255,255,.72);transition:color .15s,background .15s}
.nav-links a:hover,.nav-links a.nav-active{color:#fff;background:rgba(255,255,255,.09)}
.nav-shell.light-nav .nav-links a{color:var(--ink3)}
.nav-shell.light-nav .nav-links a:hover,
.nav-shell.light-nav .nav-links a.nav-active{color:var(--ink);background:var(--bg2)}

.nav-signin{
  margin-left:16px;padding:6px 13px;border-radius:6px;
  font-size:.875rem;font-weight:500;color:rgba(255,255,255,.5);
  white-space:nowrap;transition:color .15s}
.nav-signin:hover{color:#fff}
.nav-shell.light-nav .nav-signin{color:var(--ink4)}
.nav-shell.light-nav .nav-signin:hover{color:var(--ink)}

.nav-cta{
  margin-left:8px;padding:7px 16px;border-radius:8px;
  font-size:.875rem;font-weight:600;white-space:nowrap;
  background:var(--blue-d);color:#fff;
  box-shadow:0 0 0 1px rgba(88,166,255,.28);
  transition:background .15s,transform .1s,box-shadow .15s}
.nav-cta:hover{
  background:#1659c5;transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(31,111,235,.45)}

.nav-burger{
  display:none;flex-direction:column;gap:5px;padding:8px;margin-left:8px;
  color:#fff}
.nav-shell.light-nav .nav-burger{color:var(--ink)}
.nav-burger span{
  display:block;width:20px;height:2px;background:currentColor;
  border-radius:2px;transition:transform .25s,opacity .25s}

.nav-mob{
  display:none;position:fixed;inset:0;z-index:8999;
  background:var(--dark);padding:calc(var(--nav-h) + 20px) 20px 24px;
  flex-direction:column;gap:6px;overflow-y:auto}
.nav-mob.open{display:flex}
.nav-mob a{
  padding:13px 16px;border-radius:10px;font-size:.9375rem;font-weight:500;
  color:rgba(255,255,255,.8);border:1px solid var(--dark-border);
  transition:background .15s,color .15s}
.nav-mob a:hover{background:var(--dark3);color:#fff}
.nav-mob-cta{
  background:var(--blue-d) !important;color:#fff !important;
  border-color:var(--blue-d) !important;text-align:center;margin-top:8px}

@media(max-width:860px){
  .nav-links,.nav-signin,.nav-cta{display:none}
  .nav-burger{display:flex}}

/* ── Hero ── */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:center;
  background:var(--dark);overflow:hidden;
  padding-top:var(--nav-h)}

.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(88,166,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(88,166,255,.05) 1px,transparent 1px);
  background-size:60px 60px;pointer-events:none}

.hero::after{
  content:'';position:absolute;
  top:-20%;left:50%;transform:translateX(-50%);
  width:900px;height:600px;
  background:radial-gradient(ellipse at 50% 40%,
    rgba(31,111,235,.2) 0%,rgba(88,166,255,.06) 42%,transparent 70%);
  pointer-events:none;z-index:0}

.hero-inner{
  position:relative;z-index:1;width:100%;max-width:var(--max);
  margin:0 auto;padding:80px var(--px);
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:44px;padding:60px var(--px) 52px}}

/* Hero badge */
.h-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 13px 5px 9px;border-radius:100px;
  background:rgba(88,166,255,.1);border:1px solid rgba(88,166,255,.22);
  font-size:.75rem;font-weight:600;color:var(--blue-l);
  letter-spacing:.05em;margin-bottom:24px;text-transform:uppercase}
.h-badge-dot{
  width:6px;height:6px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 7px var(--blue);flex-shrink:0;
  animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.8)}}

.h-title{
  font-family:var(--display);
  font-size:clamp(2.3rem,5.2vw,3.8rem);
  font-weight:800;line-height:1.08;letter-spacing:-.04em;
  color:#fff;margin-bottom:20px}
.h-title .hi{
  background:linear-gradient(130deg,var(--blue) 0%,#a5d6ff 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text}

.h-sub{
  font-size:1.0625rem;line-height:1.72;
  color:rgba(255,255,255,.58);margin-bottom:36px;max-width:510px}
.h-sub strong{color:rgba(255,255,255,.9);font-weight:500}

.h-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.btn-hero-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 24px;border-radius:10px;font-size:.9375rem;font-weight:600;
  background:var(--blue);color:#fff;
  box-shadow:0 0 0 1px rgba(88,166,255,.38),0 4px 20px rgba(31,111,235,.28);
  transition:all .2s var(--ease)}
.btn-hero-primary:hover{
  background:var(--blue-d);transform:translateY(-2px);
  box-shadow:0 0 0 1px rgba(88,166,255,.5),0 8px 28px rgba(31,111,235,.4)}
.btn-hero-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;border-radius:10px;font-size:.9375rem;font-weight:500;
  background:rgba(255,255,255,.06);color:rgba(255,255,255,.8);
  border:1px solid rgba(255,255,255,.12);transition:all .2s var(--ease)}
.btn-hero-ghost:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.2)}

.h-note{font-size:.8rem;color:rgba(255,255,255,.32)}
.h-trust{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}
.h-ti{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.42)}
.h-ti i{color:var(--blue);font-size:.72rem}

/* Hero card */
.h-card-wrap{perspective:1200px}
@media(max-width:900px){.h-card-wrap{perspective:none}}
.h-card{
  background:var(--dark2);border:1px solid var(--dark-border);
  border-radius:16px;overflow:hidden;
  box-shadow:0 28px 72px rgba(0,0,0,.55),0 0 0 1px rgba(88,166,255,.09);
  transform:rotateY(-5deg) rotateX(2deg);
  transition:transform .4s var(--ease)}
.h-card:hover{transform:rotateY(-1deg) rotateX(1deg)}
@media(max-width:900px){.h-card{transform:none}.h-card:hover{transform:none}}

.hc-bar{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;background:var(--dark3);
  border-bottom:1px solid var(--dark-border)}
.hc-dots{display:flex;gap:6px}
.hc-dot{width:10px;height:10px;border-radius:50%}
.hc-dot.r{background:#f85149}.hc-dot.y{background:#d29922}.hc-dot.g{background:#3fb950}
.hc-title-bar{flex:1;font-size:.75rem;color:var(--ink4);font-family:var(--mono)}
.hc-badge{
  padding:2px 8px;border-radius:100px;font-size:.67rem;font-weight:600;
  background:rgba(63,185,80,.14);color:var(--teal);border:1px solid rgba(63,185,80,.28)}

.hc-body{padding:18px}
.hc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.hc-stat{background:var(--dark3);border:1px solid var(--dark-border);border-radius:9px;padding:11px}
.hcs-l{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--dark5);margin-bottom:5px}
.hcs-v{font-size:.88rem;font-weight:700;color:var(--ink5);font-family:var(--mono)}
.hcs-v.accent{color:var(--blue)}
.hcs-v.alive{color:var(--teal)}

.hc-bar2{display:flex;justify-content:space-between;font-size:.7rem;color:var(--dark5);margin-bottom:7px}
.hc-prog{height:5px;background:var(--dark3);border-radius:100px;overflow:hidden;margin-bottom:14px}
.hc-prog-fill{
  height:100%;width:33%;
  background:linear-gradient(90deg,var(--blue-d),var(--blue));
  border-radius:100px;animation:progfill 2s var(--ease) forwards}
@keyframes progfill{from{width:0}to{width:33%}}

.hc-snaps{display:flex;flex-direction:column;gap:5px}
.hc-snap{
  display:flex;align-items:center;gap:9px;
  padding:8px 11px;background:var(--dark3);
  border:1px solid var(--dark-border);border-radius:7px}
.hc-snap-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 5px var(--teal);flex-shrink:0}
.hc-snap-name{flex:1;font-size:.76rem;color:var(--ink5);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hc-snap-date{font-size:.7rem;color:var(--dark5);font-family:var(--mono);white-space:nowrap}
.hc-snap-ok{font-size:.66rem;font-weight:600;color:var(--teal);padding:2px 6px;background:rgba(63,185,80,.1);border-radius:4px;white-space:nowrap}

.hc-foot{
  padding:9px 16px;background:var(--dark3);
  border-top:1px solid var(--dark-border);
  font-size:.71rem;color:var(--dark5);display:flex;align-items:center;gap:6px}
.hc-foot i{color:var(--blue)}

/* ── Marquee strip ── */
.vstrip{
  background:var(--dark2);
  border-top:1px solid var(--dark-border);
  border-bottom:1px solid var(--dark-border);
  overflow:hidden}
.vstrip-inner{
  display:flex;align-items:center;
  width:max-content;white-space:nowrap;
  animation:marquee 32s linear infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.vsi{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;font-size:.8rem;font-weight:500;color:var(--ink5);flex-shrink:0}
.vsi i{color:var(--blue);font-size:.78rem}
.vsep{display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--dark-border);margin:0 4px;flex-shrink:0}

/* ── Sections ── */
.sec{padding:96px 0}
.sec-dark{background:var(--dark);color:#fff}
.sec-tint{background:var(--bg2)}
/* Dark section with proper dark table styles */
.sec-dark2{
  background:var(--dark2);color:#fff;
  border-top:1px solid var(--dark-border);
  border-bottom:1px solid var(--dark-border)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--px)}

/* Eyebrow / headings */
.eyebrow{
  display:inline-block;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--blue-d);margin-bottom:12px}
.eyebrow-light{color:var(--blue-l)}
.h2{
  font-family:var(--display);font-size:clamp(1.85rem,4vw,2.85rem);
  font-weight:800;line-height:1.1;letter-spacing:-.035em;
  color:var(--ink);margin-bottom:16px}
.h2-light{color:#fff}
.lead{font-size:1.0625rem;line-height:1.72;color:var(--ink3);max-width:600px}
.lead-light{color:rgba(255,255,255,.58)}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ── How it works ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:76px;align-items:start}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:44px}}
.step{display:flex;gap:18px;margin-bottom:28px;align-items:flex-start}
.step:last-child{margin-bottom:0}
.step-n{
  font-family:var(--mono);font-size:.72rem;font-weight:700;
  color:var(--blue-d);line-height:1;
  min-width:auto;letter-spacing:.08em;flex-shrink:0;
  padding:6px 10px;border-radius:6px;
  background:rgba(31,111,235,.08);
  border:1px solid rgba(31,111,235,.18);
  align-self:flex-start;
  font-variant-numeric:tabular-nums}
.sec-dark .step-n{
  color:var(--blue);background:rgba(88,166,255,.1);
  border-color:rgba(88,166,255,.22)}
.step-t{font-size:.9375rem;font-weight:700;color:var(--ink);margin-bottom:5px}
.step-p{font-size:.875rem;color:var(--ink3);line-height:1.65}

/* ── Terminal ── */
.term{
  background:var(--dark);border:1px solid var(--dark-border);
  border-radius:12px;overflow:hidden;font-family:var(--mono);font-size:.81rem;
  box-shadow:0 16px 48px rgba(0,0,0,.28)}
.term-bar{
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;background:var(--dark2);
  border-bottom:1px solid var(--dark-border)}
.term-dots{display:flex;gap:6px}
.td.r{width:11px;height:11px;border-radius:50%;background:#f85149;flex-shrink:0}
.td.y{width:11px;height:11px;border-radius:50%;background:#d29922;flex-shrink:0}
.td.g{width:11px;height:11px;border-radius:50%;background:#3fb950;flex-shrink:0}
.term-t{flex:1;text-align:center;font-size:.73rem;color:var(--dark5)}
.term-body{padding:18px 22px;line-height:2;color:var(--ink5)}
.td1{color:var(--dark5)}
.td2{color:var(--blue)}
.td3{color:rgba(255,255,255,.75)}
.td4{color:var(--teal)}
.td5{color:var(--blue);font-weight:600}
.tcur{
  display:inline-block;width:8px;height:14px;
  background:var(--blue);animation:blink 1s step-end infinite;vertical-align:text-bottom}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ── Feature grid ── */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
@media(max-width:860px){.g3{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.g3{grid-template-columns:1fr}}

.feat{
  background:var(--bg);border:1px solid var(--border2);
  border-radius:14px;padding:26px;
  transition:border-color .2s,box-shadow .2s,transform .2s}
.feat:hover{
  border-color:var(--blue);
  box-shadow:0 0 0 1px rgba(88,166,255,.18),0 8px 22px rgba(0,0,0,.06);
  transform:translateY(-2px)}
.feat-icon{
  width:42px;height:42px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;margin-bottom:15px}
.fi-b{background:rgba(31,111,235,.1);color:var(--blue-d)}
.fi-t{background:rgba(63,185,80,.1);color:var(--teal)}
.fi-a{background:rgba(210,153,34,.1);color:var(--amber)}
.fi-v{background:rgba(88,166,255,.1);color:var(--blue)}
.fi-n{background:rgba(248,81,73,.08);color:var(--red)}
.fi-r{background:rgba(63,185,80,.08);color:var(--teal)}
.feat-title{font-size:.9375rem;font-weight:700;color:var(--ink);margin-bottom:7px;font-family:var(--display)}
.feat-body{font-size:.875rem;color:var(--ink3);line-height:1.65}

.sec-dark .feat{background:var(--dark2);border-color:var(--dark-border)}
.sec-dark .feat:hover{border-color:var(--blue);box-shadow:0 0 0 1px rgba(88,166,255,.2),0 8px 28px rgba(0,0,0,.35)}
.sec-dark .feat-title{color:#fff}
.sec-dark .feat-body{color:var(--ink4)}

/* ── Privacy block ── */
.priv{
  background:var(--dark);border-radius:18px;overflow:hidden;
  border:1px solid var(--dark-border);
  box-shadow:0 20px 56px rgba(0,0,0,.14)}
.priv-inner{display:grid;grid-template-columns:1fr 1fr}
@media(max-width:760px){.priv-inner{grid-template-columns:1fr}}
.priv-left{padding:44px;border-right:1px solid var(--dark-border)}
@media(max-width:760px){.priv-left{border-right:none;border-bottom:1px solid var(--dark-border);padding:32px}}
.priv-right{padding:44px}
@media(max-width:760px){.priv-right{padding:32px}}
.priv-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:var(--blue);display:block;margin-bottom:13px}
.priv-title{font-family:var(--display);font-size:1.65rem;font-weight:800;line-height:1.2;letter-spacing:-.03em;color:#fff;margin-bottom:15px}
.priv-body{font-size:.875rem;color:rgba(255,255,255,.48);line-height:1.72}
.priv-checks{display:flex;flex-direction:column;gap:13px}
.priv-check{display:flex;align-items:center;gap:11px;font-size:.875rem;color:rgba(255,255,255,.7)}
.priv-check i{
  color:var(--teal);font-size:.75rem;flex-shrink:0;
  width:20px;height:20px;border-radius:50%;
  background:rgba(63,185,80,.12);
  display:inline-flex;align-items:center;justify-content:center}

/* ── Compare table — LIGHT version (default) ── */
.compare-wrap{
  overflow-x:auto;border-radius:12px;
  border:1px solid var(--border2);
  box-shadow:0 2px 16px rgba(0,0,0,.05)}
.ctable{width:100%;border-collapse:collapse;font-size:.875rem;min-width:480px}
.ctable thead th{
  padding:13px 18px;text-align:center;font-weight:700;
  background:var(--bg2);border-bottom:1px solid var(--border2);
  font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink3)}
.ctable thead th:first-child{text-align:left}
.ctable thead th.ours{background:var(--blue-d);color:#fff}
.ctable tbody tr{background:var(--bg)}
.ctable tbody tr:nth-child(even){background:var(--bg2)}
.ctable tbody tr:hover{background:#edf2fb}
.ctable td{padding:12px 18px;border-bottom:1px solid var(--border2);text-align:center;color:var(--ink3)}
.ctable td:first-child{text-align:left;color:var(--ink2);font-weight:500}
.ctable tbody tr:last-child td{border-bottom:none}
.oc{background:rgba(31,111,235,.05) !important}
.ci{color:var(--teal);font-size:.92rem}
.cx{color:var(--red);font-size:.88rem;opacity:.5}

/* ── Compare table — DARK version (inside sec-dark2) ── */
.sec-dark2 .compare-wrap{
  border-color:var(--dark-border);
  box-shadow:0 4px 24px rgba(0,0,0,.3)}
.sec-dark2 .ctable thead th{
  background:var(--dark3);border-bottom-color:var(--dark-border);color:var(--ink4)}
.sec-dark2 .ctable thead th.ours{background:var(--blue-d);color:#fff}
.sec-dark2 .ctable tbody tr{background:var(--dark2)}
.sec-dark2 .ctable tbody tr:nth-child(even){background:var(--dark3)}
.sec-dark2 .ctable tbody tr:hover{background:var(--dark4)}
.sec-dark2 .ctable td{border-bottom-color:var(--dark-border);color:var(--ink4)}
.sec-dark2 .ctable td:first-child{color:var(--ink5)}
.sec-dark2 .oc{background:rgba(31,111,235,.08) !important}

/* ── Pricing ── */
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
@media(max-width:1000px){.plan-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.plan-grid{grid-template-columns:1fr}}

.plan{
  background:var(--bg);border:1px solid var(--border2);
  border-radius:15px;padding:26px;position:relative;
  transition:border-color .2s,box-shadow .2s,transform .2s}
.plan:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(0,0,0,.07)}
.plan.hot{
  border-color:var(--blue);
  box-shadow:0 0 0 1px rgba(88,166,255,.28),0 8px 28px rgba(31,111,235,.1)}
.plan-pop{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  padding:3px 12px;border-radius:100px;font-size:.67rem;font-weight:700;
  background:var(--blue-d);color:#fff;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.plan-tier{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink4);margin-bottom:9px}
.plan-price{font-family:var(--display);margin-bottom:6px;line-height:1}
.plan-price sup{font-size:1.15rem;font-weight:700;vertical-align:top;margin-top:7px;color:var(--ink2)}
.plan-price span.amt{font-size:2.7rem;font-weight:800;color:var(--ink);letter-spacing:-.04em}
.plan-price sub{font-size:.82rem;color:var(--ink4);font-weight:400}
.plan-desc{font-size:.8rem;color:var(--ink4);margin-bottom:18px}
.plan-hr{height:1px;background:var(--border2);margin-bottom:18px}
.plan-feats{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.plan-feats li{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--ink3)}
.plan-feats li i{font-size:.68rem;color:var(--teal);flex-shrink:0}
.plan-feats li.na{color:var(--ink4);opacity:.55}
.plan-feats li.na i{color:var(--ink4);opacity:.55}
.plan-btn{
  display:block;text-align:center;padding:11px;border-radius:9px;
  font-size:.875rem;font-weight:600;transition:all .15s}
.pbtn-o{background:var(--bg2);color:var(--ink2);border:1px solid var(--border2)}
.pbtn-o:hover{background:var(--bg3);border-color:var(--border)}
.pbtn-b{background:var(--blue-d);color:#fff;box-shadow:0 2px 8px rgba(31,111,235,.28)}
.pbtn-b:hover{background:var(--blue);box-shadow:0 4px 14px rgba(31,111,235,.4)}

/* ── FAQ ── */
.faq-item{border-bottom:1px solid var(--border2)}
.faq-item:first-child{border-top:1px solid var(--border2)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;width:100%;
  padding:19px 0;text-align:left;font-size:.9375rem;font-weight:600;
  color:var(--ink);cursor:pointer;gap:16px;background:none;border:none}
.faq-q:hover{color:var(--blue-d)}
.faq-icon{
  flex-shrink:0;width:22px;height:22px;border-radius:50%;
  background:var(--bg2);display:flex;align-items:center;justify-content:center;
  font-size:.68rem;color:var(--ink3);transition:background .15s,transform .25s}
.faq-item.open .faq-icon{background:var(--blue-d);color:#fff;transform:rotate(45deg)}
.faq-body{overflow:hidden;max-height:0;transition:max-height .35s var(--ease)}
.faq-body-inner{padding:0 0 18px;font-size:.9rem;color:var(--ink3);line-height:1.72}

/* ── CTA ── */
.cta-sec{
  background:var(--dark);padding:96px var(--px);
  text-align:center;position:relative;overflow:hidden}
.cta-sec::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:400px;
  background:radial-gradient(ellipse,rgba(31,111,235,.18) 0%,transparent 70%);
  pointer-events:none}
.cta-inner{position:relative;z-index:1;max-width:560px;margin:0 auto}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:9px;font-size:.9rem;font-weight:600;
  transition:all .15s var(--ease);cursor:pointer;border:none}
.btn-blue{background:var(--blue-d);color:#fff;box-shadow:0 2px 8px rgba(31,111,235,.28)}
.btn-blue:hover{background:#1659c5;box-shadow:0 4px 14px rgba(31,111,235,.4);transform:translateY(-1px)}
.btn-dark{background:var(--dark3);color:rgba(255,255,255,.85);border:1px solid var(--dark-border)}
.btn-dark:hover{background:var(--dark4);color:#fff}
.btn-ghost-w{background:rgba(255,255,255,.07);color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.13)}
.btn-ghost-w:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-ghost{background:var(--bg2);color:var(--ink2);border:1px solid var(--border2)}
.btn-ghost:hover{background:var(--bg3)}
.btn-xl{padding:14px 28px;font-size:1rem;border-radius:10px}
.btn-lg{padding:12px 22px;border-radius:9px}

/* ── Footer ── */
.site-footer{
  background:var(--dark);border-top:1px solid var(--dark-border);
  padding:60px var(--px) 28px}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:44px;margin-bottom:44px}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr}}

.footer-brand{
  display:flex;align-items:center;gap:9px;margin-bottom:12px}
.footer-brand img{height:22px;width:auto}
.footer-brand .logo-wordmark{
  font-family:var(--display);font-weight:800;font-size:1rem;
  letter-spacing:-.03em;color:#fff}
.footer-desc{font-size:.84rem;color:var(--dark5);line-height:1.65;max-width:280px;margin-bottom:16px}
.footer-trust{display:flex;flex-wrap:wrap;gap:7px}
.ft-badge{
  padding:3px 9px;border-radius:6px;font-size:.7rem;font-weight:600;
  background:var(--dark3);color:var(--ink4);border:1px solid var(--dark-border)}
.footer-col-title{
  font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--dark5);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:.875rem;color:var(--dark5);transition:color .15s}
.footer-links a:hover{color:rgba(255,255,255,.8)}
.footer-bottom{
  padding-top:24px;border-top:1px solid var(--dark-border);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-copy{font-size:.78rem;color:var(--dark5)}
.footer-legal{display:flex;gap:18px}
.footer-legal a{font-size:.78rem;color:var(--dark5);transition:color .15s}
.footer-legal a:hover{color:rgba(255,255,255,.6)}

/* ── Use case cards ── */
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
@media(max-width:860px){.uc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.uc-grid{grid-template-columns:1fr}}
.uc-card{
  display:block;background:var(--bg);border:1px solid var(--border2);
  border-radius:13px;padding:24px;text-decoration:none;
  transition:all .2s var(--ease)}
.uc-card:hover{
  border-color:var(--blue);
  box-shadow:0 8px 22px rgba(0,0,0,.06);transform:translateY(-2px)}
.uc-icon{
  width:40px;height:40px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;margin-bottom:13px}
.uc-title{font-size:.9375rem;font-weight:700;color:var(--ink);margin-bottom:6px;font-family:var(--display)}
.uc-body{font-size:.84rem;color:var(--ink3);line-height:1.6}
.uc-arrow{font-size:.78rem;color:var(--blue-d);margin-top:13px;display:flex;align-items:center;gap:4px;font-weight:600}

/* ── Landing pages ── */
.page-hero{
  background:var(--bg2);
  padding:calc(var(--nav-h) + 56px) 0 56px;
  border-bottom:1px solid var(--border2)}
.page-hero.dark-hero{background:var(--dark);border-bottom-color:var(--dark-border)}
.page-hero h1{
  font-family:var(--display);font-size:clamp(1.75rem,4vw,2.7rem);
  font-weight:800;letter-spacing:-.035em;line-height:1.1;
  color:var(--ink);margin-bottom:16px}
.page-hero.dark-hero h1{color:#fff}
.page-hero .lead{max-width:600px}
.page-hero.dark-hero .lead{color:rgba(255,255,255,.58)}

.breadcrumb{display:flex;align-items:center;gap:7px;font-size:.77rem;color:var(--ink4);margin-bottom:18px}
.breadcrumb a{color:var(--ink4);transition:color .15s}
.breadcrumb a:hover{color:var(--blue-d)}
.breadcrumb-sep{color:var(--border)}

/* ── Content blocks ── */
.content-block{max-width:780px;margin:0 auto}

.content-block h2{
  font-family:var(--display);font-size:1.6rem;font-weight:800;
  letter-spacing:-.035em;line-height:1.15;
  color:var(--ink);margin:52px 0 14px}
.content-block h2:first-child{margin-top:0}

.content-block h3{
  font-family:var(--display);font-size:1.1rem;font-weight:700;
  letter-spacing:-.02em;color:var(--ink);margin:32px 0 10px}

.content-block p{
  font-size:.9375rem;color:var(--ink3);line-height:1.78;margin-bottom:16px}

/* Standard bullet list */
.content-block ul{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.content-block ul li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.9375rem;color:var(--ink3);line-height:1.65}
.content-block ul li::before{
  content:'→';color:var(--blue-d);flex-shrink:0;font-weight:700;margin-top:2px}

/* Definition list style — for li with <strong> label + description */
/* When a li has a <strong> as first child, render as a clean definition row */
.content-block ul.def-list{gap:0;border:1px solid var(--border2);border-radius:12px;overflow:hidden;margin-bottom:24px}
.content-block ul.def-list li{
  display:grid;grid-template-columns:240px 1fr;gap:0;align-items:stretch;
  border-bottom:1px solid var(--border2);padding:0}
.content-block ul.def-list li:last-child{border-bottom:none}
.content-block ul.def-list li::before{display:none}
.content-block ul.def-list li strong{
  display:flex;align-items:center;
  padding:14px 18px;font-size:.875rem;font-weight:600;color:var(--ink2);
  background:var(--bg2);border-right:1px solid var(--border2);
  min-width:0}
.content-block ul.def-list li span{
  display:flex;align-items:center;
  padding:14px 18px;font-size:.875rem;color:var(--ink3);line-height:1.6}
@media(max-width:640px){
  .content-block ul.def-list li{grid-template-columns:1fr}
  .content-block ul.def-list li strong{border-right:none;border-bottom:1px solid var(--border2);background:var(--bg2)}
}

/* Inline code */
.content-block code{
  font-family:var(--mono);font-size:.85em;
  background:var(--bg2);border:1px solid var(--border2);
  padding:2px 6px;border-radius:5px;color:var(--blue-d)}

/* ── 404 ── */
.not-found{
  min-height:80vh;display:flex;align-items:center;
  justify-content:center;text-align:center;padding:var(--px)}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--ink4)}

@media(max-width:540px){.sec{padding:64px 0}}

/* ── Testi cards (homelab + restic-sftp pages) ── */
.testi{
  background:var(--bg);border:1px solid var(--border2);
  border-radius:14px;padding:26px;
  transition:border-color .2s,transform .2s}
.testi:hover{border-color:var(--blue);transform:translateY(-2px)}
.testi-stars{font-size:1.4rem;color:var(--blue-d);margin-bottom:14px}
.testi-text{font-size:.9rem;color:var(--ink3);line-height:1.7;margin-bottom:18px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-av{
  width:38px;height:38px;border-radius:8px;flex-shrink:0;
  background:var(--blue-d);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.78rem;letter-spacing:.02em}
.testi-name{font-size:.875rem;font-weight:700;color:var(--ink2)}
.testi-role{font-size:.78rem;color:var(--ink4);margin-top:2px}

/* ── Hero-bg / h-eyebrow / h-dot (custom landing page hero style) ── */
.hero-bg,.hero-lines{display:none}
.h-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;font-weight:600;color:rgba(255,255,255,.6);
  letter-spacing:.04em;margin-bottom:18px;text-transform:uppercase}
.h-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--blue);box-shadow:0 0 7px var(--blue);flex-shrink:0;
  animation:pulse 2s ease-in-out infinite}

/* ── Step-body (used inside .step) ── */
.step-body{flex:1}

/* ── hc-alive / hc-label (custom card variants) ── */
.hc-alive{
  width:8px;height:8px;border-radius:50%;
  background:var(--teal);box-shadow:0 0 6px var(--teal);
  flex-shrink:0;animation:pulse 2s infinite}
.hc-label{flex:1;font-size:.75rem;color:var(--ink4);font-family:var(--mono)}

/* ── blue-m alias ── */
:root{--blue-m:var(--blue-d)}

/* ── eyebrow-dark (for dark CTA sections) ── */
.eyebrow-dark{color:var(--blue-l)}

/* ═══════════════════════════════════════════════════════════
   v3.3 ADDITIONS — guide page consistency
   ═══════════════════════════════════════════════════════════ */

/* ── Code blocks (pre) — dark terminal style ── */
.content-block pre{
  position:relative;
  background:var(--dark);border:1px solid var(--dark-border);
  border-radius:10px;overflow:hidden;
  margin:18px 0 24px;
  box-shadow:0 4px 14px rgba(0,0,0,.08)}
.content-block pre code{
  display:block;
  font-family:var(--mono);font-size:.82rem;line-height:1.7;
  color:var(--ink5);background:transparent;border:none;padding:18px 22px;
  overflow-x:auto;
  -webkit-text-size-adjust:100%;
  white-space:pre;
  tab-size:2}
@media(max-width:540px){
  .content-block pre code{font-size:.78rem;padding:14px 16px}
}

/* Copy button on code blocks */
.pre-copy{
  position:absolute;top:9px;right:9px;
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;border-radius:6px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);
  font-family:var(--font);font-size:.72rem;font-weight:500;
  cursor:pointer;opacity:0;
  transition:opacity .15s,background .15s,color .15s,border-color .15s}
.pre-copy i{font-size:.72rem}
.content-block pre:hover .pre-copy,
.pre-copy:focus{opacity:1}
.pre-copy:hover{
  background:rgba(255,255,255,.1);
  color:#fff;border-color:rgba(255,255,255,.2)}
.pre-copy.copied{
  opacity:1;
  background:rgba(63,185,80,.15);
  color:var(--teal);
  border-color:rgba(63,185,80,.35)}
@media(max-width:640px){
  .pre-copy{opacity:1}
}

/* ── Inline links inside content (replaces inline style="color:var(--blue-d)") ── */
.content-block a:not(.btn):not(.related-link){
  color:var(--blue-d);text-decoration:underline;
  text-decoration-color:rgba(31,111,235,.3);
  text-underline-offset:2px;
  transition:color .15s,text-decoration-color .15s}
.content-block a:not(.btn):not(.related-link):hover{
  color:var(--blue);text-decoration-color:var(--blue)}

/* ── Sub-step h3 (for things like "Network dependency" inside a step) ── */
.content-block h3.sub{
  font-family:var(--display);font-size:1rem;font-weight:700;
  letter-spacing:-.015em;color:var(--ink2);
  margin:24px 0 8px}

/* ── Page-hero refinements (used on every guide) ── */
.page-hero .hero-actions{
  display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.page-hero .lead{margin:18px 0 28px}
.page-hero h1 .accent{color:var(--blue)}
.page-hero.dark-hero h1 .accent{color:var(--blue)}

/* ── Related links section ── */
.related-sec{padding:64px 0 88px;background:var(--bg2);border-top:1px solid var(--border2)}
.related-head{margin-bottom:22px}
.related-head .h2{margin-bottom:0}
.related-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:10px}
.related-link{
  display:flex;align-items:center;gap:10px;
  padding:13px 15px;background:var(--bg);
  border:1px solid var(--border2);border-radius:10px;
  font-size:.875rem;font-weight:500;color:var(--ink2);
  text-decoration:none;
  transition:border-color .15s,background .15s,transform .15s,color .15s}
.related-link:hover{
  border-color:var(--blue);background:#fff;
  color:var(--blue-d);transform:translateY(-1px)}
.related-link i{
  color:var(--blue-d);font-size:.78rem;flex-shrink:0;
  width:14px;text-align:center}

/* ── Standardized FAQ wrapper for guide pages ── */
.faq-sec{padding:80px 0;background:var(--bg)}
.faq-sec .wrap{max-width:780px}
.faq-head{text-align:center;margin-bottom:44px}

/* ── Standardized CTA on guide pages ── */
.cta-sec .eyebrow{display:block;margin-bottom:14px}
.cta-sec .h2{margin-bottom:14px}
.cta-sec .lead{margin:0 auto 28px;color:rgba(255,255,255,.6)}
.cta-sec .h-actions{justify-content:center}

/* ── Notes / callouts (info / tip / warn) ── */
.callout{
  display:flex;gap:14px;
  padding:16px 18px;border-radius:10px;
  margin:18px 0 24px;
  font-size:.9rem;line-height:1.65}
.callout i{flex-shrink:0;margin-top:2px;font-size:.95rem}
.callout-info{
  background:rgba(31,111,235,.06);
  border:1px solid rgba(31,111,235,.18);
  color:var(--ink2)}
.callout-info i{color:var(--blue-d)}
.callout-tip{
  background:rgba(63,185,80,.06);
  border:1px solid rgba(63,185,80,.22);
  color:var(--ink2)}
.callout-tip i{color:var(--teal)}
.callout-warn{
  background:rgba(210,153,34,.07);
  border:1px solid rgba(210,153,34,.25);
  color:var(--ink2)}
.callout-warn i{color:var(--amber)}
.callout p{margin:0;color:inherit}
.callout strong{color:var(--ink);font-weight:600}

/* ── Ordered list inside content block ── */
.content-block ol{
  margin:0 0 18px 0;padding-left:1.4em;
  display:flex;flex-direction:column;gap:6px}
.content-block ol li{
  font-size:.9375rem;color:var(--ink3);line-height:1.7;
  padding-left:4px}
.content-block ol li::marker{color:var(--blue-d);font-weight:700}

/* ── Section dividers between content-blocks ── */
.content-block + .content-block{margin-top:64px}

/* ── Selection styling ── */
::selection{background:rgba(31,111,235,.22);color:var(--ink)}

/* ═══════════════════════════════════════════════════════════
   v3.4 — Portal showcase section (homepage)
   ═══════════════════════════════════════════════════════════ */

/* Full-width showcase section */
.showcase{
  background:var(--dark);
  padding:96px 0;
  border-top:1px solid var(--dark-border);
  border-bottom:1px solid var(--dark-border);
  position:relative;
  overflow:hidden;
}
.showcase::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 50% 0%, rgba(31,111,235,.12) 0%, transparent 60%),
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size:auto, 60px 60px, 60px 60px;
  background-position:center top, 0 0, 0 0;
  mask-image:linear-gradient(to bottom, black 0%, black 70%, transparent 100%);
}
.showcase .wrap{position:relative;z-index:1}

.showcase-head{
  text-align:center;
  max-width:640px;
  margin:0 auto 56px;
}
.showcase-head .h2{color:#fff}
.showcase-head .lead{color:rgba(255,255,255,.58);margin:16px auto 0}

/* Main hero image - the landscape dashboard */
.showcase-hero{
  position:relative;
  max-width:1100px;
  margin:0 auto;
  border-radius:18px;
  overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(88,166,255,.12),
    0 24px 72px rgba(0,0,0,.55),
    0 0 90px rgba(31,111,235,.08);
}
.showcase-hero img,
.showcase-hero picture{
  display:block;width:100%;height:auto;
  border-radius:18px;
}
.showcase-hero::after{
  content:"";position:absolute;inset:0;
  border-radius:18px;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}

/* Split pair - two portrait images side by side */
.showcase-pair{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  max-width:1100px;
  margin:56px auto 0;
}
@media(max-width:860px){
  .showcase-pair{grid-template-columns:1fr;gap:20px}
}

.showcase-card{
  background:var(--dark2);
  border:1px solid var(--dark-border);
  border-radius:16px;
  overflow:hidden;
  transition:border-color .25s, transform .25s;
}
.showcase-card:hover{
  border-color:rgba(88,166,255,.3);
  transform:translateY(-3px);
}
.showcase-card picture,
.showcase-card img{
  display:block;width:100%;height:auto;
}
.showcase-card-body{
  padding:20px 22px 22px;
}
.showcase-card-title{
  font-family:var(--display);
  font-size:1.05rem;font-weight:700;
  color:#fff;margin-bottom:6px;
  letter-spacing:-.02em;
}
.showcase-card-body p{
  font-size:.875rem;
  color:rgba(255,255,255,.55);
  line-height:1.65;
  margin:0;
}

/* Showcase CTA under the pair */
.showcase-cta{
  text-align:center;
  margin-top:48px;
}
.showcase-cta .btn{margin:0 4px}

@media(max-width:540px){
  .showcase{padding:64px 0}
  .showcase-head{margin-bottom:36px}
  .showcase-pair{margin-top:36px}
}

.cta-fineprint{text-align:center;margin-top:18px;font-size:.75rem;color:rgba(255,255,255,.22)}
