/* =========================================================
   CloudVPS.dk — Design System
   Direction: "Nordic Aurora" — deep night infrastructure
   with a drifting cyan→violet aurora as the single signature.
   Display: Space Grotesk · Body: Manrope · Data: JetBrains Mono
   ========================================================= */

:root {
  /* dark is the default identity */
  --bg:        #070b16;
  --bg-2:      #0a1020;
  --surface:   #0f1827;
  --surface-2: #141f33;
  --border:    rgba(255,255,255,.08);
  --border-2:  rgba(255,255,255,.14);
  --ink:       #eaf0fb;
  --ink-soft:  #c3cde0;
  --muted:     #8a98b8;

  --accent-1:  #39e1ff;   /* cyan  */
  --accent-2:  #7c6bff;   /* violet*/
  --mint:      #1ff5b0;   /* "gratis"/checks */
  --aurora: linear-gradient(115deg, #39e1ff 0%, #6f6bff 48%, #b56bff 100%);

  --glow-1: rgba(57,225,255,.55);
  --glow-2: rgba(124,107,255,.50);

  --radius:   18px;
  --radius-sm:12px;
  --radius-lg:26px;

  --shadow:   0 24px 60px -28px rgba(2,8,23,.85);
  --shadow-card: 0 2px 0 rgba(255,255,255,.03) inset, 0 30px 70px -40px rgba(0,0,0,.9);

  --ff-display: "Space Grotesk", system-ui, sans-serif;
  --ff-body:    "Manrope", system-ui, sans-serif;
  --ff-mono:    "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

[data-theme="light"] {
  /* Light mode er deaktiveret — sitet kører kun i dark mode. */
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; }
}
body{
  font-family:var(--ff-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.62;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .5s var(--ease), color .4s var(--ease);
}
a{ color:inherit; text-decoration:none; }
img,svg{ max-width:100%; display:block; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }

/* ---------- ambient aurora background (signature) ---------- */
.aurora-field{
  position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none;
}
.aurora-field::before,
.aurora-field::after{
  content:""; position:absolute; border-radius:50%;
  filter:blur(90px); opacity:.55; mix-blend-mode:screen;
}
.aurora-field::before{
  width:60vw; height:60vw; top:-22vw; left:-12vw;
  background:radial-gradient(circle at 30% 30%, var(--glow-1), transparent 62%);
  animation:drift1 22s var(--ease) infinite alternate;
}
.aurora-field::after{
  width:55vw; height:55vw; top:-8vw; right:-14vw;
  background:radial-gradient(circle at 60% 40%, var(--glow-2), transparent 62%);
  animation:drift2 26s var(--ease) infinite alternate;
}
[data-theme="light"] .aurora-field::before,
[data-theme="light"] .aurora-field::after{ mix-blend-mode:normal; opacity:.5; }
.grid-veil{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),
                   linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 0%, transparent 72%);
          mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 0%, transparent 72%);
  opacity:.5;
}
@keyframes drift1{ to{ transform:translate3d(8vw,6vh,0) scale(1.15); } }
@keyframes drift2{ to{ transform:translate3d(-7vw,4vh,0) scale(1.1); } }

/* ---------- layout ---------- */
.wrap{ width:min(100% - 40px, var(--maxw)); margin-inline:auto; }
.section{ padding:96px 0; }
.section--tight{ padding:64px 0; }

.eyebrow{
  font-family:var(--ff-mono); font-size:12.5px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--accent-1); font-weight:600;
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--aurora); }

h1,h2,h3,h4{ font-family:var(--ff-display); font-weight:600; line-height:1.05; letter-spacing:-.02em; color:var(--ink); }
h2.display{ font-size:clamp(2rem,4.4vw,3.25rem); margin:18px 0 16px; }
.lead{ color:var(--muted); font-size:1.06rem; max-width:60ch; }

.gradient-text{
  background:var(--aurora); -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px; justify-content:center;
  padding:13px 22px; border-radius:999px; font-weight:700; font-size:.95rem;
  transition:transform .25s var(--ease), box-shadow .3s var(--ease), background .3s;
  white-space:nowrap;
}
.btn:focus-visible{ outline:2px solid var(--accent-1); outline-offset:3px; }
.btn-primary{
  background:var(--aurora); color:#05080f;
  box-shadow:0 8px 26px -8px var(--glow-2), 0 0 0 1px rgba(255,255,255,.08) inset;
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 16px 34px -10px var(--glow-1); }
.btn-ghost{ border:1px solid var(--border-2); color:var(--ink); background:var(--surface); }
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--accent-1); }
.btn-sm{ padding:10px 16px; font-size:.86rem; }
.btn-block{ width:100%; }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  backdrop-filter:saturate(1.4) blur(14px);
  background:color-mix(in srgb, var(--bg) 72%, transparent);
  border-bottom:1px solid var(--border);
}
.nav{ display:flex; align-items:center; gap:22px; height:70px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--ff-display); font-weight:700; font-size:1.12rem; letter-spacing:-.02em; }
.brand .mark{
  width:34px; height:34px; border-radius:10px; display:grid; place-items:center;
  background:var(--aurora); position:relative; box-shadow:0 6px 18px -6px var(--glow-2);
}
.brand .mark svg{ width:20px; height:20px; }
.brand b{ color:var(--ink); }
.brand .tld{ color:var(--accent-1); }
.nav-links{ display:flex; gap:6px; margin-left:8px; }
.nav-links a{
  padding:9px 14px; border-radius:10px; font-size:.93rem; font-weight:600; color:var(--ink-soft);
  transition:background .2s, color .2s;
}
.nav-links a:hover, .nav-links a[aria-current="page"]{ background:var(--surface-2); color:var(--ink); }
.nav-spacer{ flex:1; }
.nav-actions{ display:flex; align-items:center; gap:10px; }

.theme-toggle{
  width:42px; height:42px; border-radius:12px; border:1px solid var(--border-2);
  background:var(--surface); display:grid; place-items:center; transition:transform .3s var(--ease), border-color .2s;
}
.theme-toggle:hover{ transform:translateY(-2px); border-color:var(--accent-1); }
.theme-toggle svg{ width:19px; height:19px; }
.theme-toggle .sun{ display:none; }
[data-theme="light"] .theme-toggle .sun{ display:block; }
[data-theme="light"] .theme-toggle .moon{ display:none; }

.burger{ display:none; width:42px; height:42px; border-radius:12px; border:1px solid var(--border-2); background:var(--surface); place-items:center; }
.burger span{ display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; position:relative; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink); border-radius:2px; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }

/* ---------- hero ---------- */
.hero{ position:relative; padding:74px 0 40px; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.hero h1{ font-size:clamp(2.5rem,6vw,4.4rem); line-height:1.02; }
.hero p.lead{ margin:22px 0 30px; font-size:1.12rem; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.badge-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:26px; }
.chip{
  display:inline-flex; align-items:center; gap:8px; font-size:.82rem; font-weight:600;
  padding:7px 13px; border-radius:999px; border:1px solid var(--border); background:var(--surface);
  color:var(--ink-soft);
}
.chip .dot{ width:7px; height:7px; border-radius:50%; background:var(--mint); box-shadow:0 0 10px var(--mint); }

.parent-tag{
  display:inline-flex; align-items:center; gap:9px; font-family:var(--ff-mono); font-size:12px;
  letter-spacing:.06em; color:var(--muted); margin-bottom:22px;
  padding:6px 12px; border:1px solid var(--border); border-radius:999px; background:var(--surface);
}
.parent-tag b{ color:var(--ink); }

/* hero visual — animated node constellation */
.orbit{ position:relative; aspect-ratio:1/1; }
.orbit svg{ width:100%; height:100%; overflow:visible; }
.node{ transform-box:fill-box; transform-origin:center; }
.node-core{ animation:pulse 3.2s ease-in-out infinite; }
.node:nth-child(2) .node-core{ animation-delay:.4s }
.node:nth-child(3) .node-core{ animation-delay:.9s }
.node:nth-child(4) .node-core{ animation-delay:1.3s }
.node:nth-child(5) .node-core{ animation-delay:1.7s }
@keyframes pulse{ 0%,100%{ opacity:.5; r:4 } 50%{ opacity:1; r:6 } }
.flow{ stroke-dasharray:5 9; animation:flow 2.4s linear infinite; }
@keyframes flow{ to{ stroke-dashoffset:-56; } }
.ring{ transform-origin:50% 50%; animation:spin 36s linear infinite; }
.ring.r2{ animation-duration:52s; animation-direction:reverse; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ---------- ticker ---------- */
.ticker{ border-block:1px solid var(--border); background:var(--bg-2); overflow:hidden; }
.ticker-track{ display:flex; gap:54px; padding:16px 0; white-space:nowrap; animation:ticker 26s linear infinite; }
.ticker-track span{ font-family:var(--ff-mono); font-size:.84rem; color:var(--muted); letter-spacing:.04em; display:inline-flex; align-items:center; gap:10px; }
.ticker-track span b{ color:var(--accent-1); }
@keyframes ticker{ to{ transform:translateX(-50%); } }

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

/* ---------- feature cards ---------- */
.grid{ display:grid; gap:20px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }

.card{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:26px; position:relative; transition:transform .35s var(--ease), border-color .3s, box-shadow .35s;
}
.card:hover{ transform:translateY(-6px); border-color:var(--border-2); box-shadow:var(--shadow-card); }
.card .ico{
  width:46px; height:46px; border-radius:13px; display:grid; place-items:center; margin-bottom:16px;
  background:color-mix(in srgb, var(--accent-2) 16%, transparent);
  border:1px solid var(--border-2);
}
.card .ico svg{ width:22px; height:22px; stroke:var(--accent-1); }
.card h3{ font-size:1.18rem; margin-bottom:8px; }
.card p{ color:var(--muted); font-size:.95rem; }

/* ---------- pricing ---------- */
.plans{ display:grid; gap:20px; grid-template-columns:repeat(auto-fill,minmax(255px,1fr)); }
.plan{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:26px 24px; display:flex; flex-direction:column; position:relative; overflow:hidden;
  transition:transform .35s var(--ease), border-color .3s, box-shadow .35s;
}
.plan:hover{ transform:translateY(-7px); border-color:var(--border-2); box-shadow:var(--shadow-card); }
.plan.featured{ border-color:transparent; }
.plan.featured::before{
  content:""; position:absolute; inset:0; border-radius:var(--radius); padding:1.4px;
  background:var(--aurora);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none;
}
.plan .flag{
  position:absolute; top:16px; right:-34px; transform:rotate(45deg);
  background:var(--aurora); color:#05080f; font-size:.66rem; font-weight:800; letter-spacing:.12em;
  padding:5px 40px; text-transform:uppercase;
}
.plan .tier{ font-family:var(--ff-mono); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent-1); }
.plan .ram{ font-family:var(--ff-display); font-size:1.5rem; font-weight:600; margin-top:4px; }
.price{ display:flex; align-items:baseline; gap:6px; margin:14px 0 4px; }
.price .num{ font-family:var(--ff-display); font-size:2.5rem; font-weight:700; letter-spacing:-.03em; }
.price .cur{ font-family:var(--ff-mono); font-size:.95rem; color:var(--muted); }
.price .per{ font-size:.9rem; color:var(--muted); }
.specs{ display:grid; gap:10px; margin:18px 0 22px; }
.specs li{ display:flex; gap:10px; align-items:flex-start; font-size:.92rem; color:var(--ink-soft); font-family:var(--ff-mono); }
.specs li svg{ width:16px; height:16px; flex:none; margin-top:3px; stroke:var(--mint); }
.plan .btn{ margin-top:auto; }

/* ---------- split / showcase ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.checklist{ display:grid; gap:13px; margin-top:22px; }
.checklist li{ display:flex; gap:12px; align-items:flex-start; color:var(--ink-soft); }
.checklist li svg{ width:20px; height:20px; flex:none; margin-top:2px; stroke:var(--mint); }
.glasspanel{
  border:1px solid var(--border); border-radius:var(--radius-lg); padding:30px;
  background:linear-gradient(160deg, color-mix(in srgb,var(--surface) 92%,transparent), var(--surface-2));
  box-shadow:var(--shadow);
}

/* mock terminal */
.term{ font-family:var(--ff-mono); font-size:.86rem; }
.term .bar{ display:flex; gap:7px; margin-bottom:16px; }
.term .bar i{ width:11px; height:11px; border-radius:50%; background:var(--border-2); display:block; }
.term .bar i:nth-child(1){ background:#ff6b6b } .term .bar i:nth-child(2){ background:#ffd166 } .term .bar i:nth-child(3){ background:var(--mint) }
.term .line{ display:flex; gap:8px; color:var(--ink-soft); }
.term .pr{ color:var(--accent-1); }
.term .ok{ color:var(--mint); }
.term .cmt{ color:var(--muted); }
.cursor{ display:inline-block; width:8px; height:15px; background:var(--accent-1); animation:blink 1.1s steps(2) infinite; vertical-align:-2px; }
@keyframes blink{ 50%{ opacity:0 } }

/* ---------- stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.stat{ text-align:center; padding:26px 14px; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); }
.stat .n{ font-family:var(--ff-display); font-size:2.2rem; font-weight:700; }
.stat .n .gradient-text{ display:inline; }
.stat .l{ color:var(--muted); font-size:.86rem; margin-top:4px; }
.stat b{ display:block; font-family:var(--ff-display); font-weight:700; line-height:1.05; letter-spacing:-.02em;
  font-size:clamp(1.45rem,4.4vw,2.05rem); overflow-wrap:anywhere; }
.stat span{ display:block; color:var(--muted); font-size:.84rem; margin-top:6px; }

/* ---------- OS logos row ---------- */
.os-row{ display:flex; flex-wrap:wrap; gap:12px; }
.os{
  font-family:var(--ff-mono); font-size:.85rem; padding:10px 16px; border-radius:999px;
  border:1px solid var(--border); background:var(--surface); color:var(--ink-soft);
  display:inline-flex; align-items:center; gap:9px; transition:border-color .2s, transform .2s;
}
.os:hover{ border-color:var(--accent-1); transform:translateY(-2px); }
.os .d{ width:7px; height:7px; border-radius:50%; background:var(--accent-2); }

/* ---------- domain search ---------- */
.domain-box{
  display:flex; gap:10px; background:var(--surface); border:1px solid var(--border-2);
  border-radius:999px; padding:8px 8px 8px 22px; max-width:560px; align-items:center;
}
.domain-box input{
  flex:1; background:transparent; border:none; color:var(--ink); font-family:var(--ff-mono);
  font-size:1rem; outline:none;
}
.domain-box input::placeholder{ color:var(--muted); }
.tld-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }
.tld{ font-family:var(--ff-display); font-weight:700; font-size:1.05rem; padding:9px 18px; border-radius:12px; border:1px solid var(--border); background:var(--surface); }
.tld span{ color:var(--accent-1); }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin-inline:auto; }
.faq details{
  border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--surface);
  padding:0 22px; margin-bottom:12px; transition:border-color .25s;
}
.faq details[open]{ border-color:var(--border-2); }
.faq summary{
  list-style:none; cursor:pointer; padding:18px 0; font-family:var(--ff-display); font-weight:600;
  font-size:1.04rem; display:flex; justify-content:space-between; gap:16px; align-items:center;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ flex:none; width:24px; height:24px; border-radius:50%; border:1px solid var(--border-2); display:grid; place-items:center; transition:transform .3s, background .3s; }
.faq details[open] summary .pm{ transform:rotate(45deg); background:var(--aurora); color:#05080f; border-color:transparent; }
.faq p{ color:var(--muted); padding-bottom:20px; font-size:.96rem; }
.faq ul.in{ color:var(--muted); padding:0 0 20px 18px; list-style:disc; display:grid; gap:6px; }

/* ---------- threat grid (ddos) ---------- */
.threats{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.threat{
  border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--surface);
  padding:16px; font-family:var(--ff-mono); font-size:.85rem; display:flex; align-items:center; gap:10px;
  transition:border-color .25s, transform .25s;
}
.threat:hover{ border-color:#ff6b6b55; transform:translateY(-3px); }
.threat .x{ width:18px; height:18px; flex:none; stroke:#ff6b6b; }
.scale-meter{
  border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); padding:26px; margin-top:24px;
}
.scale-meter .row{ display:flex; justify-content:space-between; font-family:var(--ff-mono); font-size:.8rem; color:var(--muted); margin-bottom:10px; }
.scale-bar{ height:14px; border-radius:999px; background:var(--surface-2); overflow:hidden; border:1px solid var(--border); }
.scale-bar i{ display:block; height:100%; width:0; background:var(--aurora); border-radius:999px; transition:width 1.6s var(--ease); }

/* ---------- CTA band ---------- */
.cta-band{
  border:1px solid var(--border); border-radius:var(--radius-lg); padding:52px;
  background:radial-gradient(120% 140% at 0% 0%, color-mix(in srgb,var(--accent-2) 22%,transparent), transparent 55%),
             radial-gradient(120% 140% at 100% 100%, color-mix(in srgb,var(--accent-1) 18%,transparent), transparent 55%),
             var(--surface);
  text-align:center; box-shadow:var(--shadow);
}
.cta-band h2{ font-size:clamp(1.8rem,3.6vw,2.6rem); }
.cta-band .btn-row{ display:flex; gap:14px; justify-content:center; margin-top:24px; flex-wrap:wrap; }

/* ---------- footer ---------- */
.footer{ border-top:1px solid var(--border); background:var(--bg-2); padding:60px 0 34px; margin-top:40px; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:34px; }
.footer h4{ font-family:var(--ff-mono); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.footer a{ display:block; color:var(--ink-soft); font-size:.92rem; padding:5px 0; transition:color .2s; }
.footer a:hover{ color:var(--accent-1); }
.footer .blurb{ color:var(--muted); font-size:.92rem; max-width:38ch; margin-top:14px; }
.footer-bottom{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:42px; padding-top:22px; border-top:1px solid var(--border); color:var(--muted); font-size:.84rem; }

/* page hero (subpages) */
.page-hero{ padding:64px 0 8px; }
.page-hero h1{ font-size:clamp(2.2rem,5vw,3.4rem); }
.page-hero .lead{ margin-top:18px; }

/* ---------- "Skabt af nørder" + svævende dashboard ---------- */
@property --v{ syntax:"<number>"; inherits:false; initial-value:0; }
.nerds .wrap{ display:grid; grid-template-columns:1.04fr 1fr; gap:56px; align-items:center; }
.nerd-head h2{ font-size:clamp(2rem,4vw,3rem); line-height:1.04; }
.nerd-grid{ display:grid; grid-template-columns:1fr 1fr; gap:30px 36px; margin-top:36px; }
.nerd-feat .ico{ width:42px; height:42px; }
.nerd-feat h3{ font-family:var(--ff-display); font-size:1.08rem; font-weight:600; margin:14px 0 7px; }
.nerd-feat p{ color:var(--muted); font-size:.92rem; line-height:1.55; }
.nerd-more{ display:inline-flex; align-items:center; gap:12px; margin-top:34px; font-weight:700;
  color:var(--ink); text-decoration:none; }
.nerd-more .arr{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center;
  border:1.5px solid var(--mint); color:var(--mint); transition:transform .35s var(--ease), background .35s; }
.nerd-more:hover .arr{ transform:translateX(5px); background:color-mix(in srgb,var(--mint) 16%,transparent); }
.nerd-more u{ text-decoration-color:var(--border-2); text-underline-offset:5px; }
.green-badge{ display:inline-flex; align-items:center; gap:9px; margin-top:26px; padding:8px 15px;
  border-radius:999px; border:1px solid color-mix(in srgb,var(--mint) 45%,transparent);
  background:color-mix(in srgb,var(--mint) 10%,transparent); color:var(--mint);
  font-family:var(--ff-mono); font-size:.78rem; letter-spacing:.04em; }
.green-badge .leaf{ width:15px; height:15px; }

/* the floating scene */
.dash-scene{ position:relative; min-height:430px; }
.dash-uptime{ position:absolute; top:-6px; right:6px; text-align:right; z-index:4; }
.dash-uptime b{ display:block; font-family:var(--ff-display); font-weight:700; font-size:2.7rem;
  line-height:1; color:var(--mint); letter-spacing:-.02em; }
.dash-uptime span{ display:block; color:var(--muted); font-size:.82rem; margin-top:8px; max-width:14ch; margin-left:auto; }

.editor{ position:absolute; left:0; top:74px; width:74%; border-radius:14px; overflow:hidden;
  border:1px solid var(--border); background:var(--bg-2); box-shadow:var(--shadow);
  font-family:var(--ff-mono); font-size:.72rem; opacity:.96; animation:drift 9s var(--ease) infinite; }
.editor .top{ display:flex; gap:6px; padding:11px 13px; background:var(--surface); border-bottom:1px solid var(--border); }
.editor .top i{ width:9px; height:9px; border-radius:50%; background:var(--border-2); }
.editor .top i:nth-child(1){ background:#ff6b6b } .editor .top i:nth-child(2){ background:#ffd166 } .editor .top i:nth-child(3){ background:var(--mint) }
.editor .body{ display:flex; }
.editor .rail{ width:38px; flex:none; background:var(--surface); border-right:1px solid var(--border);
  display:flex; flex-direction:column; align-items:center; gap:14px; padding:14px 0; }
.editor .rail svg{ width:15px; height:15px; stroke:var(--muted); fill:none; stroke-width:2; }
.editor .code{ padding:16px 16px 30px; color:var(--ink-soft); line-height:1.85; white-space:nowrap; }
.editor .code .k{ color:var(--accent-2); } .editor .code .f{ color:var(--accent-1); }
.editor .code .s{ color:var(--mint); } .editor .code .c{ color:var(--muted); }

.panel{ position:absolute; right:0; bottom:0; width:62%; min-width:300px; z-index:3;
  border-radius:18px; border:1px solid var(--border-2); padding:14px;
  background:color-mix(in srgb,var(--surface) 88%, transparent); backdrop-filter:blur(14px);
  box-shadow:0 40px 80px -34px rgba(0,0,0,.85); animation:floaty 6.5s var(--ease) infinite; }
.panel .url{ display:flex; align-items:center; gap:8px; padding:8px 12px; border-radius:10px;
  background:var(--surface-2); border:1px solid var(--border); font-family:var(--ff-mono);
  font-size:.74rem; color:var(--muted); margin-bottom:13px; }
.panel .url .dot{ width:6px; height:6px; border-radius:50%; background:var(--mint); box-shadow:0 0 8px var(--mint); }
.panel .url .sp{ margin-left:auto; display:flex; gap:5px; }
.panel .url .sp i{ width:6px; height:6px; border-radius:50%; background:var(--border-2); }
.panel-grid{ display:grid; grid-template-columns:1.25fr 1fr; gap:11px; }
.tile{ border:1px solid var(--border); border-radius:13px; background:var(--surface); padding:14px; }
.gauges{ display:flex; gap:18px; justify-content:space-around; }
.gauge{ text-align:center; }
.gauge .ring{ --v:0; position:relative; width:62px; height:62px; border-radius:50%; margin:0 auto 9px; display:grid; place-items:center;
  background:conic-gradient(var(--gc,var(--accent-1)) calc(var(--v)*3.6deg), var(--surface-2) 0);
  transition:--v 1.4s var(--ease); }
.gauge .ring::after{ content:""; width:46px; height:46px; border-radius:50%; background:var(--surface); }
.gauge .ring b{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--ff-mono); font-size:.8rem; color:var(--ink); }
.gauge small{ display:block; color:var(--muted); font-size:.72rem; letter-spacing:.04em; }
.status .srow{ display:flex; justify-content:space-between; align-items:center; font-size:.76rem;
  padding:4px 0; color:var(--muted); }
.status .srow b{ color:var(--ink-soft); font-family:var(--ff-mono); font-weight:500; }
.status .on{ color:var(--mint); display:inline-flex; align-items:center; gap:6px; }
.status .on::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--mint); box-shadow:0 0 7px var(--mint); }
.req{ display:flex; flex-direction:column; justify-content:center; }
.req .lbl{ font-family:var(--ff-mono); font-size:.64rem; letter-spacing:.18em; color:var(--muted); text-transform:uppercase; }
.req .big{ font-family:var(--ff-display); font-weight:700; font-size:1.7rem; line-height:1.1; margin:3px 0; }
.req .up{ color:var(--mint); font-size:.74rem; display:inline-flex; align-items:center; gap:4px; }
.apps{ display:flex; align-items:center; justify-content:space-around; }
.apps .app{ width:38px; height:38px; border-radius:50%; display:grid; place-items:center;
  border:1px solid var(--border); background:var(--surface-2); }
.apps .app svg{ width:20px; height:20px; }
@keyframes floaty{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-14px) } }
@keyframes drift{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(8px) } }

/* ---------- reviews / trustpilot ---------- */
.tp-badge{ display:inline-flex; align-items:center; gap:12px; padding:12px 20px; border-radius:999px;
  border:1px solid var(--border-2); background:var(--surface); margin-inline:auto; }
.tp-badge .score{ font-family:var(--ff-display); font-weight:700; font-size:1.15rem; }
.tp-badge .stars{ display:inline-flex; gap:3px; }
.tp-badge small{ color:var(--muted); font-size:.84rem; }
.stars svg{ width:17px; height:17px; }
.stars svg path{ fill:#1ff5b0; }
.review{ display:flex; flex-direction:column; gap:14px; }
.review .stars{ display:inline-flex; gap:3px; }
.review p{ font-size:1.02rem; color:var(--ink-soft); line-height:1.6; }
.review .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.review .who .av{ width:40px; height:40px; border-radius:50%; flex:none; display:grid; place-items:center;
  font-family:var(--ff-display); font-weight:700; color:#05080f; background:var(--aurora); }
.review .who b{ display:block; font-size:.95rem; }
.review .who span{ color:var(--muted); font-size:.8rem; }

/* ---------- control panel showcase ---------- */
.browser-frame{ border:1px solid var(--border-2); border-radius:16px; overflow:hidden; background:var(--surface); box-shadow:var(--shadow); max-width:880px; margin:0 auto; }
.browser-frame .bf-bar{ display:flex; align-items:center; gap:12px; padding:11px 14px; background:var(--bg-2); border-bottom:1px solid var(--border); }
.browser-frame .bf-dots{ display:flex; gap:6px; }
.browser-frame .bf-dots i{ width:10px; height:10px; border-radius:50%; background:var(--border-2); }
.browser-frame .bf-dots i:nth-child(1){ background:#ff6b6b } .browser-frame .bf-dots i:nth-child(2){ background:#ffd166 } .browser-frame .bf-dots i:nth-child(3){ background:var(--mint) }
.browser-frame .bf-url{ font-family:var(--ff-mono); font-size:.76rem; color:var(--muted); background:var(--surface); padding:5px 16px; border-radius:8px; border:1px solid var(--border); }
.browser-frame img{ display:block; width:100%; height:auto; }
.ctrl-box{ border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); overflow:hidden;
  display:flex; flex-direction:column; transition:transform .25s var(--ease), border-color .25s; }
.ctrl-box:hover{ transform:translateY(-6px); border-color:var(--border-2); box-shadow:var(--shadow-card); }
.ctrl-box .shot{ aspect-ratio:16/10; overflow:hidden; border-bottom:1px solid var(--border); background:var(--bg-2); }
.ctrl-box .shot img{ width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
.ctrl-box .shot.ph{ display:grid; place-items:center;
  background:radial-gradient(120% 120% at 30% 0%, color-mix(in srgb,var(--accent-1) 18%,transparent), transparent 60%), var(--bg-2); }
.ctrl-box .shot.ph svg{ width:44px; height:44px; stroke:var(--accent-1); fill:none; stroke-width:1.6; opacity:.9; }
.ctrl-box .body{ padding:20px 22px 24px; }
.ctrl-box .ico{ width:38px; height:38px; }
.ctrl-box h3{ margin:12px 0 7px; font-family:var(--ff-display); font-size:1.1rem; font-weight:600; }
.ctrl-box p{ color:var(--muted); font-size:.93rem; line-height:1.55; }

/* ---------- responsive ---------- */
@media (max-width:960px){
  .nerds .wrap{ grid-template-columns:1fr; }
  .dash-scene{ position:static; min-height:auto; margin-top:30px; display:flex; flex-direction:column; gap:18px; }
  .dash-uptime{ position:static; text-align:left; }
  .dash-uptime b{ font-size:2.2rem; }
  .dash-uptime span{ margin-left:0; }
  .editor{ position:static; width:100%; }
  .panel{ position:static; width:100%; min-width:0; }
  .hero-grid, .split, .footer-grid{ grid-template-columns:1fr; }
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
  .stats,.threats{ grid-template-columns:repeat(2,1fr); }
  .orbit{ max-width:420px; margin-inline:auto; }
  .nav-links{ position:fixed; inset:70px 0 auto 0; flex-direction:column; gap:0; background:var(--bg);
    border-bottom:1px solid var(--border); padding:10px 20px 18px; transform:translateY(-130%); transition:transform .4s var(--ease); z-index:55; }
  .nav-links.open{ transform:none; }
  .nav-links a{ padding:14px 8px; border-radius:0; border-bottom:1px solid var(--border); }
  .burger{ display:grid; }
}
@media (max-width:560px){
  .section{ padding:60px 0; }
  .section--tight{ padding:48px 0; }
  .hero{ padding:54px 0 28px; }
  .grid-3,.grid-4,.grid-2,.stats,.threats{ grid-template-columns:1fr; }
  .cta-band{ padding:34px 22px; }
  .nav-actions .btn.hide-sm{ display:none; }
  .hero-cta .btn, .btn-row .btn{ width:100%; justify-content:center; }
  .page-hero .btn-row .btn{ width:100%; }
  .editor{ font-size:.66rem; }
  .panel .panel-grid{ grid-template-columns:1fr; }
  .term{ font-size:.76rem; }
  .stat{ padding:22px 14px; }
  .wrap{ padding-inline:18px; }
}
