/* ===== Nodegate — landing styles =====
   Brand tokens from Nodefleet brand guidelines:
   Rocket Purple #2A274B · Aurora Blur #99DFAF · Indigo Fuzz #584EC7 · Blue Sky #02A7E8
   Type: Urbanist (display + body), JetBrains Mono (console / mono accents)
*/

:root{
  --rocket:   #2A274B;
  --rocket-2: #1a1830;
  --rocket-3: #0e0c1d;
  --aurora:   #99DFAF;
  --aurora-2: #5bc48a;
  --indigo:   #584EC7;
  --sky:      #02A7E8;
  --ink:      #eef0ff;
  --ink-dim:  #a9adca;
  --ink-mute: #6d7396;
  --line:     rgba(153,223,175,.18);
  --line-2:   rgba(255,255,255,.08);

  --shadow-1: 0 1px 0 rgba(255,255,255,.06) inset, 0 10px 40px -20px rgba(2,167,232,.35);
  --shadow-2: 0 40px 120px -40px rgba(88,78,199,.55);

  --radius: 18px;
  --radius-sm: 10px;

  --f-display: "Urbanist", system-ui, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, monospace;

  --max: 1240px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-display);
  font-weight:400;
  color:var(--ink);
  background:var(--rocket-3);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
code, .mono{font-family:var(--f-mono);font-size:.92em}
em{font-style:italic;color:var(--aurora);font-weight:600}
::selection{background:var(--aurora);color:var(--rocket-3)}

/* ===== Aurora atmosphere ===== */
.aurora{
  position:fixed;inset:0;z-index:-1;
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(88,78,199,.45), transparent 60%),
    radial-gradient(900px 600px at -10% 20%, rgba(2,167,232,.25), transparent 60%),
    radial-gradient(800px 500px at 50% 110%, rgba(153,223,175,.18), transparent 60%),
    linear-gradient(180deg, #0a0818 0%, #0e0c1d 40%, #0a0818 100%);
  overflow:hidden;
}
.aurora-band{
  position:absolute;left:-10%;right:-10%;height:260px;filter:blur(60px);opacity:.55;
  mix-blend-mode:screen;transform-origin:center;
}
.band-1{
  top:18%;
  background:linear-gradient(90deg, transparent 0%, rgba(153,223,175,.6) 30%, rgba(2,167,232,.5) 60%, transparent 100%);
  transform:rotate(-6deg);
  animation:drift 22s ease-in-out infinite alternate;
}
.band-2{
  top:38%;height:180px;opacity:.35;
  background:linear-gradient(90deg, transparent, rgba(88,78,199,.7), transparent);
  transform:rotate(3deg);
  animation:drift 28s ease-in-out infinite alternate-reverse;
}
.band-3{
  top:72%;height:220px;opacity:.3;
  background:linear-gradient(90deg, transparent, rgba(153,223,175,.5), rgba(2,167,232,.35), transparent);
  transform:rotate(-2deg);
  animation:drift 34s ease-in-out infinite alternate;
}
@keyframes drift{
  0%{transform:translateX(-4%) rotate(-6deg)}
  100%{transform:translateX(6%) rotate(-4deg)}
}
.stars{
  position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 20% 10%, #fff, transparent 50%),
    radial-gradient(1px 1px at 80% 20%, #dfe8ff, transparent 50%),
    radial-gradient(1.5px 1.5px at 30% 60%, #fff, transparent 50%),
    radial-gradient(1px 1px at 60% 80%, #bcd1ff, transparent 50%),
    radial-gradient(1px 1px at 90% 40%, #fff, transparent 50%),
    radial-gradient(1px 1px at 10% 85%, #fff, transparent 50%),
    radial-gradient(1.2px 1.2px at 45% 30%, #b1f0c9, transparent 50%);
  background-size: 1000px 1000px;
  opacity:.7;
  animation:twinkle 6s ease-in-out infinite;
}
@keyframes twinkle{50%{opacity:.45}}
.grain{
  position:absolute;inset:0;pointer-events:none;opacity:.08;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ===== Brand word — homage to Nodefleet logotype ===== */
.brand{
  display:inline-flex;align-items:center;gap:0;position:relative;
  font-family:var(--f-display);font-weight:800;font-size:22px;letter-spacing:-.02em;
}
.brand-mark{
  color:var(--aurora);
  background:linear-gradient(180deg,var(--aurora) 0%, var(--aurora-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.brand-word{color:#fff}
.brand-underline{
  position:absolute;left:10px;right:10px;bottom:-7px;height:3px;
  background:linear-gradient(90deg, var(--aurora) 0%, var(--aurora) 20%, transparent 22%, var(--aurora) 26%, transparent 30%, var(--aurora) 34%, var(--aurora) 100%);
  border-radius:2px;
}

/* ===== Nav ===== */
.nav{
  max-width:var(--max);margin:0 auto;padding:28px 32px;
  display:flex;align-items:center;gap:32px;
  position:relative;z-index:10;
}
.nav-links{display:flex;gap:28px;margin-left:24px;font-size:15px;color:var(--ink-dim)}
.nav-links a{position:relative;padding:6px 0}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;
  background:linear-gradient(90deg,var(--aurora),transparent);
}
.nav-cta{margin-left:auto;display:flex;gap:12px;align-items:center}

.ghost, .solid{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:999px;font-weight:600;font-size:14.5px;
  transition:transform .2s ease, box-shadow .3s ease, background .3s ease;
  white-space:nowrap;
}
.ghost{
  color:#fff;border:1px solid var(--line);background:rgba(255,255,255,.02);
}
.ghost:hover{border-color:var(--aurora);color:var(--aurora)}
.solid{
  color:var(--rocket-3);
  background:linear-gradient(180deg,#c7f5d6 0%, var(--aurora) 55%, var(--aurora-2) 100%);
  box-shadow: 0 0 0 1px rgba(153,223,175,.4), 0 10px 30px -10px rgba(153,223,175,.55);
}
.solid:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(153,223,175,.6), 0 18px 40px -14px rgba(153,223,175,.7)}
.solid span{transition:transform .2s ease}
.solid:hover span{transform:translateX(3px)}
.big{padding:15px 24px;font-size:16px}

/* ===== Hero ===== */
.hero{
  max-width:var(--max);margin:40px auto 0;padding:40px 32px 80px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;color:var(--ink-dim);letter-spacing:.02em;
  padding:8px 14px;border:1px solid var(--line);border-radius:999px;
  background:rgba(153,223,175,.04);
  backdrop-filter:blur(6px);
}
.eyebrow b{color:var(--aurora);font-weight:700}
.eyebrow .dot{
  width:8px;height:8px;border-radius:50%;background:var(--aurora);
  box-shadow:0 0 0 3px rgba(153,223,175,.25), 0 0 14px var(--aurora);
}
h1{
  font-size:clamp(44px, 6.8vw, 88px);
  line-height:.96;letter-spacing:-.035em;font-weight:800;
  margin:22px 0 24px;
}
h1 em{display:inline-block;font-family:var(--f-display);font-style:italic}
.lede{
  font-size:19px;color:var(--ink-dim);max-width:58ch;margin:0 0 32px;
}
.lede code{
  color:var(--aurora);background:rgba(153,223,175,.08);
  padding:2px 7px;border-radius:6px;border:1px solid var(--line);
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-meta{
  list-style:none;padding:0;margin:0;display:flex;gap:36px;flex-wrap:wrap;
  border-top:1px dashed var(--line);padding-top:24px;
}
.hero-meta li{font-size:14px;color:var(--ink-mute)}
.hero-meta strong{display:block;color:#fff;font-size:26px;font-weight:700;letter-spacing:-.02em}

/* animated hero word stagger */
.hero h1, .lede, .hero-cta, .hero-meta{animation:rise .9s ease both}
.lede{animation-delay:.08s}
.hero-cta{animation-delay:.16s}
.hero-meta{animation-delay:.24s}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ===== Console ===== */
.console{
  position:relative;border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(26,24,48,.95), rgba(14,12,29,.95));
  border:1px solid var(--line);
  box-shadow:var(--shadow-2), var(--shadow-1);
  overflow:hidden;
  animation:rise 1s .2s ease both;
}
.console::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 200px at 100% 0%, rgba(2,167,232,.18), transparent 60%);
  pointer-events:none;
}
.console-chrome{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;border-bottom:1px solid var(--line-2);
  background:rgba(255,255,255,.02);
}
.console-chrome .dot{width:11px;height:11px;border-radius:50%}
.console-chrome .red{background:#ff5f56}
.console-chrome .amber{background:#ffbd2e}
.console-chrome .lime{background:var(--aurora)}
.console-title{
  margin-left:auto;font-family:var(--f-mono);font-size:12px;color:var(--ink-mute);
}
.console-body{
  margin:0;padding:26px 24px;font-family:var(--f-mono);font-size:13.5px;
  color:#e4e8ff;line-height:1.7;white-space:pre-wrap;
}
.c-prompt{color:var(--aurora);font-weight:700}
.c-caret{color:var(--sky)}
.c-cmd{color:#fff;font-weight:700}
.c-str{color:#ffd18f}
.c-flag{color:var(--indigo);filter:brightness(1.6)}
.c-ok{color:var(--aurora);font-weight:700}
.c-step{color:var(--sky)}
.c-kw{color:#c7b6ff;font-weight:600}
.c-dim{color:var(--ink-mute)}
.c-link{color:var(--sky);text-decoration:underline;text-decoration-color:rgba(2,167,232,.4)}
.blink{animation:blink 1.6s steps(2) infinite}
@keyframes blink{50%{opacity:.35}}

.console-beam{
  position:absolute;top:0;bottom:0;left:-20%;width:40%;
  background:linear-gradient(90deg, transparent, rgba(153,223,175,.1), transparent);
  transform:skewX(-20deg);
  animation:sweep 6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes sweep{0%,100%{left:-40%}50%{left:110%}}

/* ===== Logos strip ===== */
.logos{
  max-width:var(--max);margin:0 auto;padding:40px 32px;
  display:flex;align-items:center;gap:40px;flex-wrap:wrap;
  border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);
}
.logos-label{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute)}
.logos ul{list-style:none;margin:0;padding:0;display:flex;gap:38px;flex-wrap:wrap;font-family:var(--f-mono);font-size:13px;color:var(--ink-dim)}

/* ===== Section heads ===== */
.section-head{max-width:720px;margin:0 auto 56px}
.section-head.center{text-align:center}
.kicker{
  display:inline-block;font-family:var(--f-mono);font-size:12px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--aurora);
  padding:6px 12px;border:1px solid var(--line);border-radius:999px;
  margin-bottom:18px;
}
.section-head h2{
  font-size:clamp(34px, 4.2vw, 56px);line-height:1.04;letter-spacing:-.025em;
  font-weight:800;margin:0 0 16px;
}
.section-head p{color:var(--ink-dim);font-size:17px;margin:0}

/* ===== Services ===== */
.services{max-width:var(--max);margin:0 auto;padding:120px 32px 60px}
.service-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.svc{
  position:relative;padding:28px 26px 26px;
  border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(26,24,48,.7), rgba(14,12,29,.75));
  backdrop-filter:blur(8px);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
  overflow:hidden;
}
.svc::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  background:linear-gradient(135deg, transparent 30%, rgba(153,223,175,.35) 50%, transparent 70%);
  opacity:0;transition:opacity .4s;pointer-events:none;
  mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  -webkit-mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  padding:1px;
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}
.svc:hover{
  transform:translateY(-4px);
  border-color:rgba(153,223,175,.35);
  box-shadow:0 30px 80px -30px rgba(2,167,232,.35);
}
.svc:hover::before{opacity:1}
.svc-icon{
  width:54px;height:54px;border-radius:14px;
  display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%, rgba(153,223,175,.25), rgba(88,78,199,.15));
  border:1px solid var(--line);
  color:var(--aurora);
  margin-bottom:22px;
}
.svc-icon svg{width:28px;height:28px}
.svc h3{font-size:22px;margin:0 0 8px;letter-spacing:-.01em;font-weight:700}
.svc p{color:var(--ink-dim);font-size:15px;margin:0 0 18px}
.svc-tags{list-style:none;padding:0;margin:0;display:flex;gap:8px;flex-wrap:wrap}
.svc-tags li{
  font-family:var(--f-mono);font-size:11px;
  color:var(--aurora);padding:4px 10px;
  border:1px solid var(--line);border-radius:999px;
  background:rgba(153,223,175,.05);
}

.svc-faucet .svc-icon   {color:var(--aurora)}
.svc-explorer .svc-icon {color:var(--sky)}
.svc-snapshot .svc-icon {color:#c7b6ff}
.svc-rpc .svc-icon      {color:var(--aurora)}
.svc-seeds .svc-icon    {color:var(--sky)}
.svc-panel .svc-icon    {color:#ffd18f}

/* ===== How it works ===== */
.how{max-width:var(--max);margin:0 auto;padding:120px 32px 60px}
.steps{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step;
  position:relative;
}
.steps::before{
  content:"";position:absolute;left:8%;right:8%;top:68px;height:1px;
  background:linear-gradient(90deg, transparent, var(--line), var(--aurora), var(--line), transparent);
  opacity:.6;
}
.steps li{
  position:relative;padding:26px 24px;border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(26,24,48,.7), rgba(14,12,29,.75));
  backdrop-filter:blur(8px);
}
.step-num{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;
  color:var(--rocket-3);background:var(--aurora);
  display:inline-block;padding:4px 10px;border-radius:6px;margin-bottom:14px;
  box-shadow:0 0 24px rgba(153,223,175,.35);
}
.steps h3{font-size:22px;margin:0 0 8px;font-weight:700}
.steps p{color:var(--ink-dim);font-size:15px;margin:0 0 18px}
.steps p code{color:var(--aurora)}
.step-code{
  margin:0;padding:12px 14px;border-radius:var(--radius-sm);
  background:rgba(10,8,24,.7);border:1px solid var(--line-2);
  font-family:var(--f-mono);font-size:12.5px;color:#e4e8ff;
  overflow:auto;
}

/* ===== Pricing ===== */
.pricing{max-width:var(--max);margin:0 auto;padding:120px 32px 60px}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.plan{
  position:relative;padding:32px 28px;border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(26,24,48,.75), rgba(14,12,29,.8));
  backdrop-filter:blur(8px);display:flex;flex-direction:column;
}
.plan header h3{font-size:24px;margin:0;letter-spacing:-.01em;font-weight:800}
.plan-tag{color:var(--ink-mute);font-size:13px;margin:4px 0 18px}
.price{display:flex;align-items:baseline;gap:6px;margin:10px 0 22px}
.amt{font-size:58px;font-weight:800;letter-spacing:-.03em;
  background:linear-gradient(180deg,#fff 0%, #c9d4ff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.per{color:var(--ink-mute);font-size:15px}
.plan ul{list-style:none;padding:0;margin:0 0 28px;flex:1}
.plan ul li{
  font-size:14.5px;color:var(--ink-dim);padding:10px 0;
  border-top:1px dashed var(--line-2);
}
.plan ul li:first-child{border-top:0}
.plan ul li b{color:#fff;font-weight:700}
.plan a{align-self:stretch;justify-content:center}
.plan-featured{
  border-color:rgba(153,223,175,.45);
  background:
    radial-gradient(600px 300px at 50% -10%, rgba(153,223,175,.18), transparent 60%),
    linear-gradient(180deg, rgba(26,24,48,.9), rgba(14,12,29,.95));
  transform:translateY(-8px);
  box-shadow:0 40px 100px -40px rgba(153,223,175,.35);
}
.ribbon{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;color:var(--rocket-3);font-weight:700;
  background:linear-gradient(90deg,var(--aurora),#c7f5d6);
  box-shadow:0 10px 26px -10px rgba(153,223,175,.6);
}
.pricing-foot{text-align:center;color:var(--ink-mute);font-size:14px;margin-top:36px}

/* ===== CTA ===== */
.cta{max-width:var(--max);margin:60px auto 80px;padding:0 32px}
.cta-inner{
  position:relative;overflow:hidden;
  border:1px solid var(--line);border-radius:28px;
  padding:64px 56px;text-align:center;
  background:
    radial-gradient(600px 300px at 20% 0%, rgba(2,167,232,.35), transparent 60%),
    radial-gradient(600px 300px at 80% 100%, rgba(153,223,175,.35), transparent 60%),
    linear-gradient(180deg, rgba(26,24,48,.9), rgba(14,12,29,.95));
}
.cta-inner h2{font-size:clamp(32px, 4vw, 52px);line-height:1.05;letter-spacing:-.025em;font-weight:800;margin:0 0 14px}
.cta-inner > p{color:var(--ink-dim);font-size:18px;max-width:58ch;margin:0 auto 30px}
.cta-inner code{color:var(--aurora);background:rgba(153,223,175,.08);padding:2px 7px;border-radius:6px;border:1px solid var(--line)}
.deploy-form{
  display:flex;gap:12px;max-width:640px;margin:0 auto;
  background:rgba(10,8,24,.6);
  border:1px solid var(--line);border-radius:999px;padding:8px 8px 8px 24px;
  align-items:center;
}
.deploy-form label{flex:1;display:flex;flex-direction:column;text-align:left}
.deploy-form span{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.deploy-form input{
  background:transparent;border:0;color:#fff;font-size:16px;
  font-family:var(--f-mono);padding:4px 0;outline:none;width:100%;
}
.deploy-form input::placeholder{color:var(--ink-mute)}
.cta-foot{color:var(--ink-mute);font-size:14px;margin-top:22px}
.cta-foot a{color:var(--aurora);text-decoration:underline;text-decoration-color:rgba(153,223,175,.35)}

/* ===== Footer ===== */
.foot{
  max-width:var(--max);margin:0 auto;padding:60px 32px 40px;
  border-top:1px dashed var(--line);
}
.foot-top{display:grid;grid-template-columns:1.2fr 2fr;gap:40px;margin-bottom:40px}
.foot-brand p{color:var(--ink-mute);font-size:14px;max-width:44ch;margin-top:14px}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.foot-cols h4{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 14px;font-weight:600}
.foot-cols a{display:block;color:var(--ink-dim);font-size:14px;padding:4px 0}
.foot-cols a:hover{color:var(--aurora)}
.foot-bot{
  display:flex;justify-content:space-between;gap:20px;
  padding-top:24px;border-top:1px dashed var(--line);
  font-size:12px;color:var(--ink-mute);
}
.foot-mono{font-family:var(--f-mono)}

/* ===== Responsive ===== */
@media (max-width: 1040px){
  .hero{grid-template-columns:1fr;gap:40px;padding-bottom:60px}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr;gap:16px}
  .steps::before{display:none}
  .plans{grid-template-columns:1fr;gap:16px}
  .plan-featured{transform:none}
  .foot-top{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .nav{padding:20px;gap:14px;flex-wrap:wrap}
  .nav-links{display:none}
  .hero{padding:20px 20px 40px}
  .services,.how,.pricing{padding:80px 20px 40px}
  .service-grid{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr 1fr}
  .cta-inner{padding:40px 24px}
  .deploy-form{flex-direction:column;border-radius:18px;padding:14px}
  .deploy-form label{width:100%}
}
