*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#020617;
  --bg-card:rgba(15,23,42,0.65);
  --bg-card-solid:#0f172a;
  --border:rgba(255,255,255,0.07);
  --border-cyan:rgba(6,182,212,0.22);
  --text:#e2e8f0;
  --text-muted:#94a3b8;
  --text-dim:#64748b;
  --cyan:#06b6d4;
  --cyan-dim:rgba(6,182,212,0.1);
  --cyan-glow:rgba(6,182,212,0.15);
  --green:#10b981;
  --violet:#8b5cf6;
}
html{color-scheme:dark;scroll-behavior:smooth}
body{
  font-family:ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}
a{color:var(--cyan);text-decoration:none}
a:hover{text-decoration:underline}

/* Background blobs */
.bg-blobs{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.35;animation:blob-drift 18s ease-in-out infinite}
.blob-1{width:500px;height:500px;background:radial-gradient(circle,rgba(6,182,212,0.4) 0%,transparent 70%);top:-120px;left:-100px;animation-delay:0s}
.blob-2{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,0.3) 0%,transparent 70%);bottom:-80px;right:-60px;animation-delay:-7s}
.blob-3{width:320px;height:320px;background:radial-gradient(circle,rgba(16,185,129,0.2) 0%,transparent 70%);top:40%;left:55%;animation-delay:-13s}
@keyframes blob-drift{
  0%,100%{transform:translate(0,0) scale(1)}
  30%{transform:translate(40px,-30px) scale(1.06)}
  60%{transform:translate(-25px,20px) scale(0.94)}
}

/* Page wrapper above blobs */
.page-wrap{position:relative;z-index:1}

/* Nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(2,6,23,0.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 1.5rem}
.nav-inner{max-width:72rem;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:3.75rem}
.nav-brand{display:flex;align-items:center;gap:0.6rem;font-weight:700;font-size:0.95rem;color:#fff;text-decoration:none;letter-spacing:-0.01em}
.nav-brand img{width:30px;height:30px;border-radius:9px;box-shadow:0 0 12px rgba(6,182,212,0.3)}
.nav-links{display:flex;gap:1.5rem;font-size:0.82rem}
.nav-links a{color:var(--text-muted);text-decoration:none;transition:color 0.15s}
.nav-links a:hover,.nav-links a.active{color:#fff}

/* Layout */
.container{max-width:54rem;margin:0 auto;padding:3rem 1.5rem 6rem;position:relative;z-index:1}
.container-wide{max-width:72rem;margin:0 auto;padding:0 1.5rem 6rem;position:relative;z-index:1}

/* Hero */
.hero{text-align:center;padding:5rem 0 2.5rem;position:relative}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.35rem 0.9rem;
  border-radius:999px;
  border:1px solid var(--border-cyan);
  background:var(--cyan-dim);
  color:var(--cyan);
  font-size:0.72rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  margin-bottom:1.5rem;
}
.hero h1{
  font-size:3rem;font-weight:800;
  letter-spacing:-0.03em;line-height:1.1;
  background:linear-gradient(160deg,#fff 0%,#94a3b8 80%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:1.25rem;
}
.hero .subtitle{font-size:1.1rem;color:var(--text-muted);max-width:38rem;margin:0 auto 2rem;line-height:1.7}
.hero-logo{
  display:flex;align-items:center;justify-content:center;margin-bottom:1.75rem;
}
.hero-logo img{
  width:88px;height:88px;border-radius:22px;
  box-shadow:0 0 0 1px rgba(6,182,212,0.2), 0 0 40px rgba(6,182,212,0.18), 0 16px 48px rgba(0,0,0,0.6);
}

/* Badges */
.badges{display:flex;flex-wrap:wrap;justify-content:center;gap:0.5rem;margin-bottom:2.5rem}
.badge{
  display:inline-flex;align-items:center;gap:0.35rem;
  padding:0.32rem 0.8rem;
  border-radius:999px;
  border:1px solid rgba(100,116,139,0.2);
  background:rgba(15,23,42,0.7);
  backdrop-filter:blur(8px);
  color:var(--text-muted);font-size:0.72rem;font-weight:500;
  transition:border-color 0.2s,color 0.2s;
}
.badge svg{width:12px;height:12px;opacity:0.6;flex-shrink:0}
.badge:hover{border-color:rgba(6,182,212,0.3);color:#cbd5e1}

/* Screenshot */
.screenshot-wrap{
  position:relative;
  max-width:720px;
  margin:0 auto 1rem;
}
.screenshot-glow{
  position:absolute;inset:-20px;
  background:radial-gradient(ellipse at center,rgba(6,182,212,0.12) 0%,transparent 70%);
  pointer-events:none;
  border-radius:24px;
}
.screenshot-frame{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.1);
  box-shadow:0 0 0 1px rgba(6,182,212,0.08),0 40px 100px rgba(0,0,0,0.7),0 0 60px rgba(6,182,212,0.06);
}
.screenshot-frame img{width:100%;height:auto;display:block}
.screenshot-bar{
  height:28px;
  background:rgba(15,23,42,0.95);
  border-bottom:1px solid rgba(255,255,255,0.06);
  display:flex;align-items:center;padding:0 12px;gap:6px;
}
.screenshot-dot{width:10px;height:10px;border-radius:50%}
.dot-red{background:#ff5f57}
.dot-yellow{background:#ffbd2e}
.dot-green{background:#28c840}

/* CTA row */
.cta-row{display:flex;justify-content:center;gap:0.75rem;margin-top:2rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:0.4rem;padding:0.6rem 1.4rem;border-radius:10px;font-size:0.84rem;font-weight:500;text-decoration:none;transition:all 0.2s;letter-spacing:-0.005em}
.btn-primary{
  border:1px solid rgba(6,182,212,0.35);
  background:linear-gradient(135deg,rgba(6,182,212,0.18),rgba(6,182,212,0.06));
  color:var(--cyan);
  box-shadow:0 0 20px rgba(6,182,212,0.1);
}
.btn-primary:hover{background:linear-gradient(135deg,rgba(6,182,212,0.28),rgba(6,182,212,0.12));box-shadow:0 0 30px rgba(6,182,212,0.18);text-decoration:none;transform:translateY(-1px)}
.btn-secondary{border:1px solid rgba(255,255,255,0.08);background:rgba(15,23,42,0.7);backdrop-filter:blur(8px);color:var(--text-muted)}
.btn-secondary:hover{border-color:rgba(255,255,255,0.16);color:#fff;text-decoration:none;transform:translateY(-1px)}

/* Section title */
.section-title{font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-0.02em;margin-bottom:0.4rem;text-align:center}
.section-sub{font-size:0.85rem;color:var(--text-muted);text-align:center;margin-bottom:2rem}

/* Cards / Feature grid */
.features{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}
@media(max-width:640px){.features{grid-template-columns:1fr}}
.card{
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--bg-card);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:1.4rem 1.5rem;
  transition:border-color 0.2s,box-shadow 0.2s;
}
.card:hover{
  border-color:rgba(6,182,212,0.18);
  box-shadow:0 0 28px rgba(6,182,212,0.06),0 4px 24px rgba(0,0,0,0.3);
}
.card-icon{
  width:32px;height:32px;border-radius:8px;
  background:rgba(6,182,212,0.1);
  border:1px solid rgba(6,182,212,0.15);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:0.75rem;
  color:var(--cyan);
}
.card-icon svg{width:16px;height:16px}
.card h3{font-size:0.875rem;font-weight:600;color:#fff;margin-bottom:0.4rem;letter-spacing:-0.01em}
.card p{font-size:0.8rem;color:var(--text-muted);line-height:1.6}

/* Buy button */
.btn-buy{
  border:1px solid rgba(16,185,129,0.5);
  background:linear-gradient(135deg,rgba(16,185,129,0.2),rgba(6,182,212,0.1));
  color:#6ee7b7;
  font-weight:600;
  box-shadow:0 0 20px rgba(16,185,129,0.15);
}
.btn-buy:hover{
  background:linear-gradient(135deg,rgba(16,185,129,0.3),rgba(6,182,212,0.18));
  box-shadow:0 0 28px rgba(16,185,129,0.25);
  text-decoration:none;transform:translateY(-1px);
}

/* ═══ PRICING ═══ */
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:1.5rem}
@media(max-width:700px){.pricing-grid{grid-template-columns:1fr}}
.pricing-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--bg-card);
  backdrop-filter:blur(12px);
  padding:2rem 1.75rem;
  display:flex;flex-direction:column;
  position:relative;
}
.pricing-card--pro{
  border-color:rgba(16,185,129,0.35);
  background:linear-gradient(160deg,rgba(16,185,129,0.08) 0%,rgba(6,182,212,0.04) 40%,var(--bg-card) 70%);
  box-shadow:0 0 40px rgba(16,185,129,0.08),0 12px 40px rgba(0,0,0,0.3);
}
.pricing-popular{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  padding:0.25rem 0.9rem;border-radius:999px;
  background:linear-gradient(135deg,#10b981,#06b6d4);
  color:#020617;font-size:0.68rem;font-weight:700;
  letter-spacing:0.06em;text-transform:uppercase;
  box-shadow:0 4px 14px rgba(16,185,129,0.4);
}
.pricing-badge{
  display:inline-block;padding:0.2rem 0.7rem;border-radius:6px;
  border:1px solid rgba(100,116,139,0.3);
  background:rgba(15,23,42,0.8);
  color:var(--text-muted);font-size:0.72rem;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;
  margin-bottom:1rem;width:fit-content;
}
.pricing-badge--pro{border-color:rgba(16,185,129,0.4);color:#6ee7b7;background:rgba(16,185,129,0.1)}
.pricing-price{font-size:2.8rem;font-weight:800;color:#fff;letter-spacing:-0.04em;line-height:1}
.pricing-period{font-size:0.78rem;color:var(--text-dim);margin-top:0.35rem;margin-bottom:1.25rem}
.pricing-features{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:0.55rem}
.pricing-features li{font-size:0.82rem;color:var(--text-muted);display:flex;align-items:flex-start;gap:0.5rem;line-height:1.5}
.pricing-features li::before{content:'';width:16px;height:16px;flex-shrink:0;margin-top:0.12em;border-radius:50%;display:inline-block}
.pricing-features li.included::before{background:rgba(16,185,129,0.2);border:1px solid rgba(16,185,129,0.5);box-shadow:0 0 4px rgba(16,185,129,0.3)}
.pricing-features li.excluded::before{background:rgba(100,116,139,0.15);border:1px solid rgba(100,116,139,0.3)}
.pricing-features li.included{color:#cbd5e1}
.pricing-features li.excluded{color:var(--text-dim);text-decoration:line-through;opacity:0.65}
.pricing-features strong{color:#fff;font-weight:500}
/* Button wrapper ensures both cards' buttons align at the same vertical position
   regardless of the guarantee text or different feature list lengths */
.pricing-btn-wrap{margin-top:auto;padding-top:1rem}
.pricing-btn{width:100%;justify-content:center;padding:0.75rem 1.5rem}
.pricing-guarantee{
  display:flex;align-items:center;justify-content:center;gap:0.4rem;
  margin-top:0.75rem;font-size:0.7rem;color:var(--text-dim);
  min-height:1.4rem; /* reserve space so button position stays fixed */
}

/* Pricing FAQ */
.pricing-faq{margin-top:2rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:700px){.pricing-faq{grid-template-columns:1fr}}
.pricing-faq-item{
  border:1px solid var(--border);border-radius:12px;
  background:var(--bg-card);padding:1rem 1.25rem;
}
.pricing-faq-item strong{font-size:0.82rem;color:#fff;display:block;margin-bottom:0.35rem}
.pricing-faq-item p{font-size:0.78rem;color:var(--text-muted);margin:0;line-height:1.6}

/* CTA card */
.cta-card{
  border:1px solid var(--border-cyan);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(6,182,212,0.06) 0%,rgba(15,23,42,0.8) 60%);
  backdrop-filter:blur(12px);
  padding:2.5rem 2rem;
  text-align:center;
  margin-top:3rem;
}
.cta-card h2{font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:0.5rem;letter-spacing:-0.02em}
.cta-card p{font-size:0.88rem;color:var(--text-muted);max-width:34rem;margin:0 auto 1.5rem}

/* ═══ CONSENT BANNER ═══ */
.consent-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:100;
  display:flex;justify-content:center;
  padding:0.75rem 1rem;
  background:rgba(2,6,23,0.92);
  backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
}
.consent-inner{
  max-width:54rem;width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  flex-wrap:wrap;
}
.consent-inner p{font-size:0.75rem;color:var(--text-muted);margin:0}
.consent-actions{display:flex;gap:0.5rem}
.consent-accept{
  padding:0.35rem 0.9rem;border-radius:6px;border:1px solid rgba(16,185,129,0.5);
  background:rgba(16,185,129,0.15);color:#6ee7b7;font-size:0.72rem;font-weight:600;cursor:pointer;
}
.consent-accept:hover{background:rgba(16,185,129,0.25)}
.consent-decline{
  padding:0.35rem 0.9rem;border-radius:6px;border:1px solid var(--border);
  background:transparent;color:var(--text-dim);font-size:0.72rem;cursor:pointer;
}
.consent-decline:hover{color:var(--text-muted)}

/* Content pages */
.page-title{font-size:1.85rem;font-weight:700;color:#fff;margin-bottom:0.5rem;letter-spacing:-0.02em}
.page-date{font-size:0.75rem;color:var(--text-dim);margin-bottom:2rem}
.content h2{font-size:1.05rem;font-weight:600;color:#fff;margin-top:2rem;margin-bottom:0.75rem}
.content p{color:var(--text-muted);font-size:0.88rem;margin-bottom:1rem;line-height:1.75}
.content ul,.content ol{color:var(--text-muted);font-size:0.88rem;padding-left:1.5rem;margin-bottom:1rem}
.content li{margin-bottom:0.4rem;line-height:1.7}
.content strong{color:var(--text)}
.content a{color:var(--cyan)}
.content a:hover{text-decoration:underline}

/* Footer */
.footer{
  border-top:1px solid var(--border);
  padding:2rem 1.5rem;
  text-align:center;
  font-size:0.75rem;
  color:var(--text-dim);
  position:relative;z-index:1;
}
.footer a{color:var(--text-muted);transition:color 0.15s}
.footer a:hover{color:#fff}
.footer-brand{display:flex;align-items:center;justify-content:center;gap:0.5rem;margin-bottom:0.75rem;font-weight:600;font-size:0.82rem;color:var(--text-muted)}
.footer-brand img{width:20px;height:20px;border-radius:5px}

/* ─── MOBILE ────────────────────────────────────────── */
@media(max-width:680px){
  /* Prevent horizontal overflow */
  body{overflow-x:hidden}

  /* Nav: compact, hide low-priority links */
  .nav{padding:0 1rem}
  .nav-links{gap:0.6rem;font-size:0.74rem}
  .nav-hide-mobile{display:none}

  /* Hero */
  .hero{padding:2.75rem 0 1.75rem}
  .hero-eyebrow{font-size:0.65rem;padding:0.28rem 0.7rem}
  .hero h1{font-size:1.9rem;letter-spacing:-0.025em}
  .hero .subtitle{font-size:0.88rem;margin-bottom:1.5rem}
  .hero-logo img{width:70px;height:70px;border-radius:17px}

  /* Badges */
  .badge{font-size:0.68rem;padding:0.28rem 0.65rem}

  /* CTA row */
  .cta-row{gap:0.5rem}
  .btn{padding:0.5rem 1rem;font-size:0.8rem}

  /* Screenshot */
  .screenshot-wrap{margin-top:1.75rem}
  .screenshot-bar{height:24px}
  .screenshot-dot{width:8px;height:8px}

  /* Spotlight: single column, compact */
  .spotlight{
    grid-template-columns:1fr;
    padding:1.25rem;
    gap:1.25rem;
  }
  .spotlight-text h2{font-size:1.1rem}
  .spotlight-text p{font-size:0.82rem}
  .terminal-caps li{font-size:0.78rem}

  /* Terminal window: wrap text on mobile */
  .term-window{max-width:100%;overflow:hidden}
  .term-body{
    font-size:0.66rem;
    padding:0.75rem 0.85rem;
    white-space:normal;
    word-break:break-all;
    overflow-x:hidden;
  }
  .term-body div{margin-bottom:0.1rem}
  .term-titlebar .title-text{font-size:0.62rem}

  /* Section titles */
  .section-title{font-size:1.1rem}
  .section-sub{font-size:0.82rem}

  /* Features grid: single column already handled at 640px */
  .features{gap:0.75rem}
  .card{padding:1.1rem 1.2rem}
  .card h3{font-size:0.83rem}
  .card p{font-size:0.78rem}
  .card-icon{width:28px;height:28px;border-radius:7px}
  .card-icon svg{width:14px;height:14px}

  /* CTA card */
  .cta-card{padding:1.75rem 1.25rem;margin-top:2rem}
  .cta-card h2{font-size:1.1rem}
  .cta-card p{font-size:0.83rem}

  /* Content pages */
  .page-title{font-size:1.4rem}
  .content h2{font-size:1rem}
  .content p,.content li{font-size:0.85rem}

  /* Footer */
  .footer{padding:1.5rem 1rem}
}

/* ─── TABLET ─────────────────────────────────────────── */
@media(min-width:681px) and (max-width:900px){
  .hero h1{font-size:2.3rem}
  .spotlight{padding:1.5rem;gap:1.5rem}
  .term-body{font-size:0.72rem}
}

/* Divider */
.divider{border:none;border-top:1px solid var(--border);margin:3rem 0}

/* SSH Terminal spotlight */
.spotlight{
  border:1px solid rgba(6,182,212,0.18);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(6,182,212,0.05) 0%,rgba(15,23,42,0.7) 50%,rgba(139,92,246,0.04) 100%);
  backdrop-filter:blur(12px);
  padding:2rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  align-items:center;
  margin-bottom:2rem;
}
@media(max-width:680px){.spotlight{grid-template-columns:1fr}}
.spotlight-text h2{
  font-size:1.3rem;font-weight:700;color:#fff;
  letter-spacing:-0.02em;margin-bottom:0.75rem;
}
.spotlight-text .label{
  display:inline-flex;align-items:center;gap:0.4rem;
  padding:0.25rem 0.65rem;border-radius:999px;
  background:rgba(6,182,212,0.12);border:1px solid rgba(6,182,212,0.25);
  color:var(--cyan);font-size:0.68rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;margin-bottom:0.9rem;
}
.spotlight-text p{font-size:0.84rem;color:var(--text-muted);margin-bottom:1.1rem;line-height:1.7}
.terminal-caps{list-style:none;padding:0;display:flex;flex-direction:column;gap:0.45rem}
.terminal-caps li{
  display:flex;align-items:flex-start;gap:0.55rem;
  font-size:0.8rem;color:var(--text-muted);line-height:1.5;
}
.terminal-caps li::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--cyan);flex-shrink:0;margin-top:0.42em;
  box-shadow:0 0 6px rgba(6,182,212,0.6);
}
.terminal-caps strong{color:#cbd5e1;font-weight:500}

/* Fake terminal window */
.term-window{
  border-radius:12px;overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:0 8px 40px rgba(0,0,0,0.5),0 0 20px rgba(6,182,212,0.05);
}
.term-titlebar{
  background:#1e293b;padding:8px 12px;
  display:flex;align-items:center;gap:6px;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.term-titlebar .t-dot{width:10px;height:10px;border-radius:50%}
.term-titlebar .title-text{
  margin-left:auto;margin-right:auto;
  font-size:0.68rem;color:var(--text-dim);font-family:ui-monospace,monospace;
}
.term-body{
  background:#0a0f1a;
  padding:1rem 1.1rem;
  font-family:ui-monospace,'Cascadia Code','Fira Code',Menlo,Monaco,monospace;
  font-size:0.75rem;line-height:1.65;
}
.t-prompt{color:#22d3ee}
.t-cmd{color:#e2e8f0}
.t-out{color:#64748b}
.t-green{color:#4ade80}
.t-yellow{color:#fbbf24}
.t-blue{color:#60a5fa}
.t-dim{color:#334155}
.t-cursor{
  display:inline-block;width:8px;height:0.95em;
  background:#22d3ee;vertical-align:text-bottom;
  animation:blink 1.1s step-end infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
