/* ═══════════════ Page layout — 2-col with sticky summary ═══════════════ */
.dply{padding:44px 0 72px;position:relative}
.dply::before{content:"";position:absolute;inset:0 0 auto 0;height:260px;pointer-events:none;z-index:0;background:
  radial-gradient(620px 340px at 80% -10%,rgba(34,211,238,.07),transparent 60%),
  radial-gradient(520px 280px at 12% 30%,rgba(16,185,129,.05),transparent 60%)}
.dply-wrap{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:28px;align-items:start}

.dply-head{margin-bottom:22px}
.crumb{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-3);margin-bottom:14px;font-weight:500;letter-spacing:.2px;flex-wrap:wrap}
.crumb a{color:var(--text-3);transition:.15s}
.crumb a:hover{color:var(--accent)}
.crumb i{font-size:13px}
.crumb [aria-current]{color:#67e8f9;font-weight:600}
.dply-head h1{font-size:36px;font-weight:800;letter-spacing:-.9px;line-height:1.1;margin:0 0 10px}
.dply-head h1 .grad{background:linear-gradient(90deg,#22d3ee,#10b981);-webkit-background-clip:text;background-clip:text;color:transparent}
.dply-head p{font-size:14.5px;color:#cbd5e1;line-height:1.6;margin:0;max-width:740px}

/* Step cards — progressive disclosure: each reveals when the previous completes. */
.step{position:relative;padding:24px 26px 22px;border:1px solid var(--border);border-radius:14px;
  background:linear-gradient(180deg,rgba(19,26,43,.82),rgba(11,15,25,.94));margin-bottom:16px;
  scroll-margin-top:84px}
.step::before{content:"";position:absolute;inset:0;border-radius:14px;padding:1px;pointer-events:none;
  background:linear-gradient(135deg,rgba(34,211,238,.12),transparent 50%,rgba(16,185,129,.1));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;opacity:.8}

/* Hidden state — no animate-out, just disappears. The reveal animation comes
   with .animate-in when JS lifts the hidden class. */
.step-hidden,.final-bar.step-hidden{display:none!important}
.step.animate-in,.final-bar.animate-in{animation:stepReveal .42s cubic-bezier(.22,.61,.36,1) both}
@keyframes stepReveal{
  0%   {opacity:0;transform:translateY(-10px) scale(.99)}
  70%  {opacity:1}
  100% {opacity:1;transform:none}
}

/* Locked state — steps that exist but not yet unlocked (not used while hidden,
   but here in case we want to preview them greyed-out later). */
.step-locked{opacity:.5;filter:saturate(.5);pointer-events:none}

.step-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}

/* Step number badge: pending (cyan ring) → complete (filled emerald + check). */
.step-num{position:relative;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:800;flex-shrink:0;
  background:linear-gradient(135deg,rgba(34,211,238,.18),rgba(16,185,129,.12));
  border:1px solid rgba(34,211,238,.36);color:#a5f3fc;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 0 0 3px rgba(34,211,238,.05);
  transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease)}
.step-num .n{transition:opacity .2s}
.step-num .chk{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:15px;opacity:0;transition:opacity .2s}
.step-num .chk i{font-size:15px}
.step.step-complete .step-num{background:linear-gradient(135deg,#22d3ee,#10b981);border-color:transparent;color:#06080f;box-shadow:0 0 0 3px rgba(16,185,129,.16),inset 0 1px 0 rgba(255,255,255,.25)}
.step.step-complete .step-num .n{opacity:0}
.step.step-complete .step-num .chk{opacity:1}

.step-title{flex:1;min-width:0;display:flex;align-items:center;gap:10px}
.step-title h2{font-size:16px;font-weight:800;color:#f5f9ff;margin:0;letter-spacing:-.2px;line-height:1.2}
.step-title small{font-size:11.5px;color:#94a3b8;font-weight:500}
.step-pill{font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#67e8f9;
  background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.22);padding:3px 9px;border-radius:5px;white-space:nowrap;transition:.25s}
.step.step-complete .step-pill{color:#6ee7b7;background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.28)}

/* ─── Step 1: Account (sign in / register prompt) — deliberately compact. ─── */
.auth-step{display:flex;align-items:center;gap:14px;padding:12px 14px;border:1px solid rgba(34,211,238,.2);border-radius:10px;
  background:linear-gradient(160deg,rgba(34,211,238,.055),rgba(11,15,25,.5))}
.auth-step.authed{border-color:rgba(16,185,129,.28);background:linear-gradient(160deg,rgba(16,185,129,.07),rgba(11,15,25,.5))}
.auth-step-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;font-weight:800;color:#06080f;font-family:'JetBrains Mono',monospace;font-size:12px;
  display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22d3ee,#10b981);
  box-shadow:0 0 0 2px rgba(16,185,129,.14),inset 0 1px 0 rgba(255,255,255,.3)}
.auth-step-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;line-height:1.3}
.auth-step-body strong{font-size:12.5px;font-weight:700;color:#f5f9ff;letter-spacing:-.1px;word-break:break-all;font-family:'JetBrains Mono',monospace}
.auth-step.authed .auth-step-body strong{color:#a7f3d0}
.auth-step:not(.authed) .auth-step-body strong{font-family:inherit;font-size:13px}
.auth-step-body span{font-size:11.5px;color:#94a3b8}
.auth-step-body a{color:#6ee7b7;text-decoration:none}
.auth-step-body a:hover{text-decoration:underline}
.auth-step-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.auth-signout-inline{display:inline-flex;margin:0}
.auth-step-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:7px;font-size:12px;font-weight:600;font-family:inherit;
  color:#cbd5e1;background:rgba(11,15,25,.6);border:1px solid var(--border);cursor:pointer;transition:.15s;text-decoration:none;white-space:nowrap;line-height:1}
.auth-step-btn i{font-size:14px}
.auth-step-btn:hover{color:#f5f9ff;border-color:rgba(34,211,238,.4);background:rgba(34,211,238,.08)}
.auth-step-btn.primary{color:#06080f;background:linear-gradient(135deg,#22d3ee,#10b981);border-color:transparent;font-weight:700;
  box-shadow:0 2px 10px rgba(16,185,129,.22),inset 0 1px 0 rgba(255,255,255,.25)}
.auth-step-btn.primary:hover{filter:brightness(1.08);color:#06080f;background:linear-gradient(135deg,#22d3ee,#10b981)}
.auth-step-btn.ghost{background:transparent;border:none;color:#94a3b8;padding:7px 9px;border-radius:50%}
.auth-step-btn.ghost:hover{color:#fca5a5;background:rgba(239,68,68,.08)}
@media (max-width:560px){
  .auth-step{flex-wrap:wrap;padding:12px}
  .auth-step-body{flex-basis:100%}
  .auth-step-actions{flex-basis:100%;justify-content:flex-end}
}

/* ─── Plan selector ─── */
.plan-switcher{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.plan-pick{position:relative;display:flex;flex-direction:column;gap:4px;padding:14px 16px;
  border:1px solid var(--border);border-radius:11px;background:rgba(255,255,255,.015);cursor:pointer;transition:.18s var(--ease);color:var(--text)}
.plan-pick input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.plan-pick:hover{border-color:var(--border-hover);background:rgba(255,255,255,.025);transform:translateY(-1px)}
.plan-pick-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.plan-pick-name{font-size:14px;font-weight:800;color:#f1f5f9;letter-spacing:-.1px}
.plan-pick-price{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:#67e8f9;white-space:nowrap}
.plan-pick-price small{font-size:10.5px;color:var(--text-3);font-weight:500;margin-left:2px}
.plan-pick-sku{font-size:11px;color:#a5b3c7;font-family:'JetBrains Mono',monospace;line-height:1.3}
.plan-pick-meta{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:5px;font-size:11px;color:#b0bac9}
.plan-pick-meta span{display:inline-flex;align-items:center;gap:4px;letter-spacing:.1px}
.plan-pick-meta i{font-size:12px;color:#67e8f9}
/* DDR generation badge — tight, mono, clearly separates from the GB number. */
.plan-pick-meta em.ddr{font-style:normal;font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:800;letter-spacing:.4px;
  padding:2px 6px;border-radius:4px;margin-left:2px;
  background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.22);color:#67e8f9}
.plan-pick.selected .plan-pick-meta em.ddr{background:rgba(34,211,238,.14);border-color:rgba(34,211,238,.36);color:#a5f3fc}
.plan-pick input:checked ~ .plan-pick-marker{opacity:1}
.plan-pick-marker{position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:12px;padding:1px;pointer-events:none;
  background:linear-gradient(135deg,#22d3ee,#10b981);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;opacity:0;transition:.18s}
.plan-pick.selected{background:linear-gradient(180deg,rgba(34,211,238,.05),rgba(16,185,129,.03));box-shadow:0 0 0 1px rgba(34,211,238,.3),0 12px 26px -14px rgba(34,211,238,.3)}
.plan-pick.selected .plan-pick-name{color:#f5f9ff}
.plan-pick.selected .plan-pick-marker{opacity:1}
.plan-pick.featured::after{content:"Popular";position:absolute;top:-8px;right:10px;font-size:9.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#06080f;
  background:linear-gradient(90deg,#22d3ee,#10b981);padding:3px 8px;border-radius:100px}
.plan-switcher-tabs{display:inline-flex;padding:3px;border:1px solid var(--border);border-radius:100px;background:rgba(255,255,255,.02);margin-bottom:14px}
.plan-switcher-tabs button{padding:7px 14px;border-radius:100px;font-size:11.5px;font-weight:700;letter-spacing:.2px;color:#cbd5e1;background:transparent;transition:.18s;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.plan-switcher-tabs button i{font-size:13px}
.plan-switcher-tabs button.active{background:linear-gradient(90deg,rgba(34,211,238,.2),rgba(16,185,129,.16));color:#f5f9ff;box-shadow:inset 0 0 0 1px rgba(34,211,238,.35)}

/* ─── Billing period picker (inside step 2, below plan grid) ─── */
.period-wrap{margin-top:20px;padding-top:20px;border-top:1px dashed rgba(148,163,184,.2)}
.period-label{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.period-label .t{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#cbd5e1}
.period-label .t i{color:#67e8f9;font-size:14px}
.period-label .hint{font-size:11.5px;color:#94a3b8;font-weight:500}
.period-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}
.period{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:14px 12px 12px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.015);cursor:pointer;transition:.18s var(--ease)}
.period input{position:absolute;opacity:0;pointer-events:none}
.period-title{font-size:12.5px;font-weight:800;color:#f5f9ff;line-height:1.1}
.period-sub{font-size:10.5px;color:#94a3b8;font-weight:600;font-family:'JetBrains Mono',monospace}
.period-save{margin-top:6px;font-size:11px;font-weight:800;letter-spacing:.3px;color:#6ee7b7;background:rgba(16,185,129,.1);padding:3px 9px;border-radius:100px;border:1px solid rgba(16,185,129,.3)}
.period-save.zero{color:#94a3b8;background:transparent;border-color:rgba(148,163,184,.2);font-weight:600}
.period-flag{position:absolute;top:-7px;left:50%;transform:translateX(-50%);font-size:9.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:#06080f;
  background:linear-gradient(90deg,#22d3ee,#10b981);padding:3px 9px;border-radius:100px;box-shadow:0 2px 8px rgba(16,185,129,.28);white-space:nowrap}
.period:hover{border-color:rgba(34,211,238,.35);background:rgba(34,211,238,.04)}
.period.selected{border-color:rgba(34,211,238,.55);background:linear-gradient(180deg,rgba(34,211,238,.06),rgba(16,185,129,.03));
  box-shadow:0 0 0 1px rgba(34,211,238,.3),0 8px 20px -10px rgba(34,211,238,.3)}
.period.selected .period-title{background:linear-gradient(90deg,#22d3ee,#10b981);-webkit-background-clip:text;background-clip:text;color:transparent}
.period.featured{border-color:rgba(16,185,129,.42)}
@media (max-width:520px){
  .period-grid{grid-template-columns:repeat(2,1fr)}
  .period{padding:12px 10px 10px}
}

/* Collapse/expand — both plans and OS. Hidden cards animate in from a short
   translate/opacity state; collapsed state shows a soft gradient mask at the
   bottom of the visible block so users know there's more. */
.collapse-wrap{position:relative}
.plan-pick.hidden-overflow,
.os-row.hidden-overflow{display:none}
.collapse-wrap.expanded .plan-pick.hidden-overflow,
.collapse-wrap.expanded .os-row.hidden-overflow{display:flex;animation:cardReveal .32s cubic-bezier(.22,.61,.36,1) both}
.plan-pick.hidden-filter{display:none!important}
@keyframes cardReveal{0%{opacity:0;transform:translateY(-6px) scale(.985)}100%{opacity:1;transform:none}}

.collapse-fade{position:absolute;left:0;right:0;bottom:0;height:70px;pointer-events:none;
  background:linear-gradient(180deg,transparent 0%,rgba(11,15,25,.85) 85%,rgba(11,15,25,.95) 100%);
  transition:opacity .28s;opacity:1}
.collapse-wrap.expanded .collapse-fade,
.collapse-wrap.no-overflow .collapse-fade{opacity:0}

.collapse-btn-wrap{display:flex;justify-content:center;margin-top:14px}
.collapse-wrap.no-overflow + .collapse-btn-wrap{display:none}
.collapse-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:100px;
  background:rgba(255,255,255,.03);border:1px solid var(--border);color:#cbd5e1;font-size:12.5px;font-weight:700;letter-spacing:.2px;cursor:pointer;transition:.2s var(--ease)}
.collapse-btn:hover{color:#67e8f9;border-color:rgba(34,211,238,.4);background:rgba(34,211,238,.06);transform:translateY(-1px)}
.collapse-btn i{font-size:15px;transition:transform .28s var(--ease)}
.collapse-btn .count{font-family:'JetBrains Mono',monospace;font-size:11px;padding:2px 7px;border-radius:4px;background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.22);color:#67e8f9;font-weight:800}
.collapse-wrap.expanded + .collapse-btn-wrap .collapse-btn i{transform:rotate(180deg)}

/* ─── Location selector ─── */
.loc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.loc{position:relative;padding:14px 16px;border:1px solid var(--border);border-radius:11px;background:rgba(255,255,255,.015);cursor:pointer;transition:.18s var(--ease);color:var(--text)}
.loc input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.loc:hover{border-color:var(--border-hover);background:rgba(255,255,255,.025);transform:translateY(-1px)}
.loc.selected{background:linear-gradient(180deg,rgba(34,211,238,.06),rgba(16,185,129,.03));box-shadow:0 0 0 1px rgba(34,211,238,.3),0 12px 26px -14px rgba(34,211,238,.3)}
.loc-top{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.loc-flag{width:28px;height:21px;border-radius:3px;flex-shrink:0;object-fit:cover;display:block;
  box-shadow:0 1px 3px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08)}
.loc-names h4{font-size:14px;font-weight:800;color:#f1f5f9;margin:0;letter-spacing:-.1px;line-height:1.15}
.loc-names span{font-size:11.5px;color:#cbd5e1;font-family:'JetBrains Mono',monospace;letter-spacing:.2px}
.loc-ping{margin-left:auto;display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:100px;
  font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:800;letter-spacing:.3px;white-space:nowrap;
  background:rgba(255,255,255,.02);border:1px solid var(--border);color:var(--text-3);transition:.28s}
.loc-ping.probing{color:var(--text-3)}
.loc-ping.fast{background:rgba(16,185,129,.09);border-color:rgba(16,185,129,.28);color:#6ee7b7}
.loc-ping.mid{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.28);color:#fbbf24}
.loc-ping.slow{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.28);color:#fca5a5}
.loc-ping .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.75}
.loc-ping.probing .dot{animation:pingpulse 1s infinite}
@keyframes pingpulse{0%,100%{opacity:.35}50%{opacity:1}}
.loc-meta{display:flex;flex-wrap:wrap;gap:6px 12px;font-size:11.5px;color:#b0bac9;margin-top:4px}
.loc-meta span{display:inline-flex;align-items:center;gap:4px}
.loc-meta i{font-size:12px;color:#67e8f9}
.loc-legend{display:flex;gap:14px;margin-top:10px;font-size:10.5px;color:#94a3b8;font-weight:600;letter-spacing:.2px}
.loc-legend span{display:inline-flex;align-items:center;gap:5px}
.loc-legend b{width:7px;height:7px;border-radius:50%}
.loc-legend b.fast{background:#10b981}
.loc-legend b.mid{background:#f59e0b}
.loc-legend b.slow{background:#ef4444}

/* ─── OS selector ─── */
.os-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px}
.os-row{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.015);cursor:pointer;transition:.18s;color:var(--text);position:relative}
.os-row input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.os-row:hover{border-color:var(--border-hover);background:rgba(255,255,255,.03)}
.os-row.selected{background:linear-gradient(90deg,rgba(34,211,238,.07),rgba(16,185,129,.04));box-shadow:inset 0 0 0 1px rgba(34,211,238,.42)}
.os-icon{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:rgba(255,255,255,.04);border:1px solid var(--border)}
.os-icon img{width:18px;height:18px;object-fit:contain;filter:brightness(1.05)}
.os-icon i{font-size:16px;color:#67e8f9}
.os-name{min-width:0;flex:1}
.os-name h5{font-size:12.5px;font-weight:700;color:#f1f5f9;margin:0;letter-spacing:-.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.os-name span{font-size:10.5px;color:#a5b3c7;font-family:'JetBrains Mono',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.os-row.popular::after{content:"★";font-size:10px;color:#fbbf24;margin-left:2px}

/* ─── Credentials ─── */
.cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field-full{grid-column:1 / -1}
.field label{font-size:10.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text-2);display:flex;align-items:center;gap:6px;justify-content:space-between}
.field label i{font-size:12px;color:#67e8f9}
.field label .opt{font-weight:600;letter-spacing:.2px;text-transform:none;color:#94a3b8;font-size:10.5px}
.field input[type=text],.field input[type=password],.field textarea{width:100%;padding:11px 13px;border-radius:10px;
  border:1px solid var(--border-hover);background:rgba(10,14,24,.65);color:var(--text);
  font-family:'Inter',sans-serif;font-size:13.5px;line-height:1.5;outline:none;transition:.18s var(--ease);
  box-shadow:0 1px 0 rgba(255,255,255,.02) inset}
.field input:focus,.field textarea:focus{border-color:rgba(34,211,238,.55);box-shadow:0 0 0 3px rgba(34,211,238,.16),0 1px 0 rgba(255,255,255,.02) inset;background:rgba(10,14,24,.9)}
.field.mono input,.field.mono textarea{font-family:'JetBrains Mono',monospace;letter-spacing:.2px}
.field input[readonly]{background:rgba(10,14,24,.35);color:#94a3b8;cursor:not-allowed;border-color:var(--border)}
.field input[readonly]:focus{border-color:var(--border);box-shadow:none;background:rgba(10,14,24,.35)}

.pwd-wrap{position:relative;display:flex;gap:6px;align-items:stretch}
.pwd-wrap input{flex:1;padding-right:84px}
.pwd-tools{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px}
.pwd-tool{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:7px;background:transparent;color:var(--text-2);font-size:15px;transition:.15s;cursor:pointer;border:none}
.pwd-tool:hover{background:rgba(34,211,238,.08);color:#67e8f9}
.pwd-strength{display:flex;gap:3px;margin-top:4px;height:5px}
.pwd-strength span{flex:1;background:rgba(255,255,255,.06);border-radius:2px;transition:.22s}
.pwd-strength[data-score="1"] span:nth-child(-n+1){background:#ef4444}
.pwd-strength[data-score="2"] span:nth-child(-n+2){background:#f59e0b}
.pwd-strength[data-score="3"] span:nth-child(-n+3){background:#22d3ee}
.pwd-strength[data-score="4"] span{background:linear-gradient(90deg,#22d3ee,#10b981)}
.pwd-hint{font-size:11px;color:#a5b3c7;margin-top:4px;display:flex;justify-content:space-between;gap:10px}
.pwd-hint b{font-weight:700;color:#cbd5e1}
.pwd-hint b.weak{color:#fca5a5}
.pwd-hint b.ok{color:#fbbf24}
.pwd-hint b.good{color:#67e8f9}
.pwd-hint b.strong{color:#6ee7b7}

.ssh-block{margin-top:12px;border:1px dashed var(--border-hover);border-radius:10px;padding:12px 14px 14px;background:rgba(255,255,255,.012)}
.ssh-block label{margin-bottom:10px}
.ssh-block textarea{font-family:'JetBrains Mono',monospace;font-size:11.5px;line-height:1.55;min-height:84px;resize:vertical}
.ssh-hint{font-size:11.5px;color:#a5b3c7;margin-top:8px;line-height:1.55}
.ssh-hint code{font-family:'JetBrains Mono',monospace;color:#67e8f9;background:rgba(34,211,238,.07);padding:1px 5px;border-radius:4px}

/* ─── Add-ons ─── */
.addon-list{display:flex;flex-direction:column;gap:8px}
.addon{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;padding:14px 16px;border:1px solid var(--border);border-radius:11px;background:rgba(255,255,255,.015);transition:.18s}
.addon:hover{border-color:var(--border-hover);background:rgba(255,255,255,.025)}
.addon.selected{background:linear-gradient(90deg,rgba(34,211,238,.06),rgba(16,185,129,.03));box-shadow:inset 0 0 0 1px rgba(34,211,238,.32)}
.addon-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.22);color:#67e8f9;font-size:16px}
.addon-body{min-width:0}
.addon-body h5{font-size:13px;font-weight:800;color:#f1f5f9;margin:0 0 2px;letter-spacing:-.1px}
.addon-body p{font-size:12px;color:#b0bac9;margin:0;line-height:1.5}
.addon-price{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:#67e8f9;font-weight:700;white-space:nowrap;text-align:right}
.addon-price small{display:block;font-size:10.5px;color:#94a3b8;margin-top:2px}

/* Switch (add-ons that are on/off) */
.sw{position:relative;width:42px;height:24px;cursor:pointer;flex-shrink:0}
.sw input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.sw-ui{position:absolute;inset:0;background:rgba(255,255,255,.06);border:1px solid var(--border-hover);border-radius:100px;transition:.22s var(--ease)}
.sw-ui::before{content:"";position:absolute;top:50%;left:2px;width:18px;height:18px;border-radius:50%;background:#94a3b8;transform:translateY(-50%);transition:.22s var(--ease);box-shadow:0 1px 3px rgba(0,0,0,.4)}
.sw input:checked + .sw-ui{background:linear-gradient(90deg,#22d3ee,#10b981);border-color:transparent}
.sw input:checked + .sw-ui::before{left:22px;background:#fff}

/* Qty spinner (IPv4 count) */
.qty{display:inline-flex;align-items:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;overflow:hidden;flex-shrink:0}
.qty button{width:32px;height:34px;background:transparent;color:var(--text-2);font-size:14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:.15s}
.qty button:hover{background:rgba(34,211,238,.08);color:#67e8f9}
.qty button:disabled{opacity:.35;cursor:default}
.qty button:disabled:hover{background:transparent;color:var(--text-2)}
.qty input{width:44px;height:34px;text-align:center;background:transparent;border:none;color:#f5f9ff;font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;outline:none;padding:0}

/* ─── Quantity + hostname row ─── */
/* Both columns share .field's label-above-control flow, so the qty widget and the
   hostname input line up pixel-perfect on the first baseline. */
.qty-row{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.qty-row .qty{width:fit-content;align-self:start}
.qty-row .qty button{width:42px;height:44px;font-size:16px;line-height:1}
.qty-row .qty input{width:62px;height:44px;font-size:15px;font-weight:800}
.qty-row .field input{height:44px;padding:0 14px}
.hostname-preview{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:#cbd5e1;margin-top:8px;line-height:1.5}
.hostname-preview code{color:#67e8f9;background:rgba(34,211,238,.06);padding:1px 6px;border-radius:4px;border:1px solid rgba(34,211,238,.14);font-size:11.5px}

/* ─── Terms + submit bar ─── */
.final-bar{display:flex;gap:18px;align-items:center;padding:20px 24px;border:1px solid var(--border);border-radius:14px;
  background:linear-gradient(135deg,rgba(34,211,238,.06),rgba(16,185,129,.04) 50%,rgba(11,15,25,.95));margin-top:14px;flex-wrap:wrap}
.terms{display:flex;align-items:flex-start;gap:10px;flex:1 1 260px;min-width:0;font-size:12.5px;color:#cbd5e1;line-height:1.55;cursor:pointer;user-select:none}
.terms input{position:absolute;opacity:0;pointer-events:none}
.terms-box{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border-hover);background:rgba(255,255,255,.02);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;transition:.18s}
.terms-box i{font-size:14px;color:#06080f;opacity:0;transition:.18s}
.terms input:checked + .terms-box{background:linear-gradient(135deg,#22d3ee,#10b981);border-color:transparent}
.terms input:checked + .terms-box i{opacity:1}
.terms a{color:#67e8f9;text-decoration:none;border-bottom:1px solid rgba(34,211,238,.3)}
.terms-text strong{color:#f1f5f9;font-weight:700}

/* Deploy button — two-part: action label on the left, price pill on the right.
   Deeper cyan→emerald gradient (tailwind -600 stops) + white text reads much
   cleaner than the lighter -400/500 combo with dark type. */
.btn-deploy{display:inline-flex;align-items:center;gap:12px;padding:14px 18px 14px 22px;border-radius:11px;font-size:14px;font-weight:800;color:#fff;border:none;cursor:pointer;letter-spacing:.2px;
  background:linear-gradient(90deg,#0891b2 0%,#059669 100%);
  text-shadow:0 1px 1px rgba(0,0,0,.22);
  box-shadow:0 0 0 1px rgba(6,182,212,.45),0 14px 32px -10px rgba(5,150,105,.55),inset 0 1px 0 rgba(255,255,255,.14);
  transition:.18s var(--ease);white-space:nowrap;flex-shrink:0}
.btn-deploy:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(6,182,212,.6),0 18px 36px -8px rgba(5,150,105,.62),inset 0 1px 0 rgba(255,255,255,.18);filter:brightness(1.08)}
.btn-deploy:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;filter:none}
.btn-deploy-left{display:inline-flex;align-items:center;gap:8px}
.btn-deploy-left i{font-size:17px}
.btn-deploy-price{display:inline-flex;align-items:baseline;gap:1px;padding:5px 11px;border-radius:100px;background:rgba(0,12,16,.3);font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:800;letter-spacing:-.2px;box-shadow:inset 0 1px 0 rgba(0,0,0,.14)}
.btn-deploy-price .per{font-size:10.5px;opacity:.82;font-weight:700;margin-left:1px}

/* Honeypot */
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}

/* ═══════════════ Sticky summary sidebar ═══════════════ */
.dply-sum-wrap{position:sticky;top:76px}
.sum{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:linear-gradient(180deg,rgba(19,26,43,.9),rgba(11,15,25,.96));box-shadow:0 30px 60px -24px rgba(0,0,0,.55),0 0 0 1px rgba(34,211,238,.05)}
.sum::before{content:"";position:absolute;inset:-1px;border-radius:15px;padding:1px;pointer-events:none;
  background:linear-gradient(135deg,rgba(34,211,238,.28),transparent 45%,transparent 55%,rgba(16,185,129,.22));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude}
.sum{position:relative}
.sum-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.015)}
.sum-head h3{font-size:12px;font-weight:800;color:#f1f5f9;margin:0;letter-spacing:.5px;text-transform:uppercase}
.sum-head h3 i{color:#67e8f9;font-size:14px;margin-right:6px;vertical-align:-2px}
.sum-head .sum-tag{font-size:10.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#6ee7b7;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.28);padding:3px 8px;border-radius:5px}

.sum-plan{display:flex;flex-direction:column;gap:2px;padding:18px 18px 16px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(34,211,238,.05),transparent)}
/* Empty state: centered hint with icon + copy. Not italic grey-on-black anymore. */
.sum-plan.empty{padding:28px 22px;text-align:center;background:transparent;font-style:normal}
.sum-plan.empty .ring{width:52px;height:52px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(34,211,238,.1),rgba(16,185,129,.06));border:1px dashed rgba(34,211,238,.32);color:#67e8f9;font-size:24px}
.sum-plan.empty h5{font-size:14px;font-weight:800;color:#f1f5f9;margin:0 0 6px;letter-spacing:-.2px}
.sum-plan.empty p{font-size:12.5px;color:#cbd5e1;margin:0;line-height:1.5}
.sum-plan-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:2px}
.sum-plan h4{font-size:16px;font-weight:800;color:#f5f9ff;margin:0;letter-spacing:-.25px;display:inline-flex;align-items:center;gap:8px;min-width:0}
.sum-plan h4 .type{font-family:'JetBrains Mono',monospace;font-size:9px;padding:2px 6px;background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.26);color:#67e8f9;border-radius:4px;font-weight:800;letter-spacing:.6px;flex-shrink:0}
.sum-plan .price{font-family:'JetBrains Mono',monospace;font-size:15px;font-weight:800;color:#f5f9ff;white-space:nowrap;flex-shrink:0}
.sum-plan .price small{font-size:10.5px;color:#94a3b8;margin-left:2px;font-weight:600}
.sum-plan .sku{font-size:11.5px;color:#a5b3c7;font-family:'JetBrains Mono',monospace;margin-top:1px}
.sum-plan .specs{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:10px;font-size:11px;color:#b0bac9;padding-top:10px;border-top:1px dashed rgba(148,163,184,.2)}
.sum-plan .specs span{display:inline-flex;align-items:center;gap:4px}
.sum-plan .specs i{font-size:12px;color:#67e8f9}
.sum-plan .specs em{font-style:normal;font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:800;letter-spacing:.4px;
  padding:1px 5px;border-radius:3px;margin-left:2px;
  background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.22);color:#67e8f9}
.sum-plan .deploy{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:11px;font-weight:700;letter-spacing:.2px;color:#6ee7b7;
  padding:4px 10px;border-radius:100px;background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.25);align-self:flex-start}
.sum-plan .deploy i{font-size:12px}

.sum-section{padding:12px 18px;border-bottom:1px solid var(--border);font-size:12.5px;color:var(--text-2);display:flex;justify-content:space-between;align-items:center;gap:10px}
.sum-section:last-of-type{border-bottom:none}
.sum-section .lbl{font-size:10.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#94a3b8}
.sum-section .val{color:#f1f5f9;font-weight:700;font-size:12.5px;text-align:right}
.sum-section .val b{display:block;font-family:'JetBrains Mono',monospace;color:#f5f9ff;font-weight:800}
.sum-section .val span{display:block;font-size:11px;color:#a5b3c7;font-family:'JetBrains Mono',monospace;margin-top:1px}
.sum-section.empty .val{color:#94a3b8;font-style:italic;font-weight:500}
.sum-section .ping{display:inline-flex;align-items:center;gap:5px;font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;color:#6ee7b7;margin-top:3px}
.sum-section .ping .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

.sum-addons{padding:12px 18px;border-bottom:1px solid var(--border);font-size:12px;color:#cbd5e1}
.sum-addons .lbl{font-size:10.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#94a3b8;margin-bottom:6px}
.sum-addons ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}
.sum-addons li{display:flex;justify-content:space-between;gap:10px;font-size:12px}
.sum-addons li span{color:#e2e8f0}
.sum-addons li b{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:#67e8f9;font-weight:700}
.sum-addons .none{color:#94a3b8;font-style:italic;font-size:12px}

.sum-totals{padding:16px 18px 18px;background:linear-gradient(180deg,rgba(16,185,129,.06),rgba(11,15,25,.96));display:flex;flex-direction:column;gap:7px}
.sum-totals .line{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;color:#cbd5e1}
.sum-totals .line b{font-family:'JetBrains Mono',monospace;color:#f1f5f9;font-weight:800}
.sum-totals .line .muted{color:#94a3b8;font-weight:500}
.sum-totals .grand{padding-top:10px;margin-top:4px;border-top:1px dashed rgba(148,163,184,.28);display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-size:14px;color:#f5f9ff}
.sum-totals .grand span{color:#cbd5e1;font-weight:700}
.sum-totals .grand strong{font-family:'JetBrains Mono',monospace;font-size:24px;letter-spacing:-.5px;background:linear-gradient(90deg,#22d3ee,#10b981);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800}
.sum-totals .grand small{font-size:11px;color:#94a3b8;font-family:'JetBrains Mono',monospace;font-weight:600}
.sum-totals .save-line b{color:#6ee7b7}
.sum-totals .grand-eff{font-size:11px;color:#94a3b8;text-align:right;margin-top:-2px;font-family:'JetBrains Mono',monospace;font-weight:600}
.sum-totals .grand-eff span{color:#6ee7b7}
.sum-coins{display:flex;gap:10px;align-items:center;padding:12px 18px;border-top:1px solid var(--border);background:rgba(255,255,255,.012)}
.sum-coins-lbl{font-size:10.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#94a3b8}
.sum-coins-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1}
.sum-coins-row img{height:16px;opacity:.65;transition:.18s}
.sum-coins-row img:hover{opacity:1}

/* ═══════════════ Success banner ═══════════════ */
.ok-banner{display:flex;gap:16px;align-items:flex-start;padding:22px 26px;border-radius:14px;
  border:1px solid rgba(16,185,129,.35);background:linear-gradient(180deg,rgba(16,185,129,.1),rgba(16,185,129,.02));margin-bottom:24px}
.ok-banner i{font-size:28px;color:#6ee7b7;margin-top:3px;flex-shrink:0}
.ok-banner h2{font-size:20px;font-weight:800;color:#f5f9ff;margin:0 0 8px;letter-spacing:-.3px}
.ok-banner p{font-size:13.5px;color:#d1fae5;line-height:1.65;margin:0 0 6px;max-width:720px}
.ok-banner code{font-family:'JetBrains Mono',monospace;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.28);color:#6ee7b7;padding:1px 7px;border-radius:4px;font-size:12.5px;font-weight:700}

.err-banner{display:flex;gap:14px;align-items:flex-start;padding:14px 18px;border-radius:12px;
  border:1px solid rgba(239,68,68,.35);background:linear-gradient(180deg,rgba(239,68,68,.09),rgba(239,68,68,.02));margin-bottom:18px}
.err-banner i{font-size:20px;color:#fca5a5;margin-top:2px;flex-shrink:0}
.err-banner strong{color:#f5f9ff;display:block;margin-bottom:4px;font-size:13px}
.err-banner ul{margin:0;padding-left:18px;font-size:12.5px;color:#fecaca;line-height:1.55}

/* ═══════════════ Responsive ═══════════════ */
/* Tablet & below: summary drops under the form (natural source order → bottom). */
@media (max-width:1100px){
  .dply-wrap{grid-template-columns:1fr;gap:16px}
  .dply-sum-wrap{position:static}
  .sum{position:relative}
}

/* Mobile — every surface reflowed for a single tight column. */
@media (max-width:760px){
  .dply{padding:22px 0 120px}                           /* extra bottom padding because of the sticky deploy CTA */
  .container{padding:0 16px}
  .dply-head{margin-bottom:16px}
  .dply-head h1{font-size:clamp(22px,5.8vw,28px);letter-spacing:-.6px;line-height:1.15}
  .dply-head p{font-size:13.5px}

  /* Step cards: tighter, readable headers that don't truncate. */
  .step{padding:18px 16px 16px;margin-bottom:12px;border-radius:12px;scroll-margin-top:72px}
  .step-head{gap:10px;margin-bottom:12px;flex-wrap:wrap}
  .step-num{width:26px;height:26px;font-size:11.5px}
  .step-title{flex:1 1 auto;min-width:0}
  .step-title h2{font-size:14.5px;line-height:1.2}
  .step-title small{display:none}                        /* subtitle dropped — the title is enough on mobile */
  .step-pill{font-size:9.5px;padding:2px 7px}            /* kept, but tiny */

  /* Plan filter tabs — full-width so they're easy to tap. */
  .plan-switcher-tabs{display:flex;width:100%;padding:3px}
  .plan-switcher-tabs button{flex:1;padding:9px 8px;justify-content:center}

  /* Plan / location / OS grids: single column with large touch targets. */
  .plan-switcher{grid-template-columns:1fr;gap:8px}
  .plan-pick{padding:14px 14px}
  .plan-pick-name{font-size:15px}
  .plan-pick-price{font-size:14px}
  .loc-grid{grid-template-columns:1fr;gap:8px}
  .loc{padding:13px 14px}
  .os-grid{grid-template-columns:repeat(2,1fr);gap:7px}
  .os-row{padding:11px 12px}
  .os-name h5{font-size:12px}
  .os-name span{font-size:10px}

  /* Expand/collapse button spans full width for easier thumb reach. */
  .collapse-btn{width:100%;padding:12px 18px;font-size:12.5px}
  .collapse-btn-wrap{margin-top:10px}
  .collapse-fade{height:56px}

  /* Credentials: single column, roomier inputs. */
  .cred-grid{grid-template-columns:1fr;gap:14px}
  /* 16px min keeps iOS from zooming the viewport on focus. Padding kept roomy. */
  .field input[type=text],.field input[type=password],.field textarea{font-size:16px;padding:13px 14px}
  .pwd-wrap input{padding-right:104px}
  .pwd-tool{width:40px;height:40px}
  .pwd-hint{flex-direction:column;gap:2px;align-items:flex-start}
  .ssh-block{padding:12px 14px 14px}
  .ssh-block textarea{font-size:13px;min-height:72px}
  /* Standalone qty spinner (outside .qty-row) stays too small on touch otherwise */
  .qty button{width:40px;height:44px;font-size:15px}
  .qty input{width:52px;height:44px;font-size:15px}

  /* Add-ons: icon + text on top, price + control below on the right. */
  .addon{grid-template-columns:38px 1fr auto;grid-template-rows:auto auto;row-gap:6px;column-gap:12px;padding:12px 14px}
  .addon-icon{grid-row:1 / 3}
  .addon-body{grid-column:2;grid-row:1}
  .addon-price{grid-column:3;grid-row:1;text-align:right}
  .addon > .sw,.addon > .qty{grid-column:2 / -1;grid-row:2;justify-self:end}
  .addon-body h5{font-size:12.5px}
  .addon-body p{font-size:11.5px}

  /* Quantity + hostname: stacked on mobile, inputs keep their 44 px touch height. */
  .qty-row{grid-template-columns:1fr;gap:14px}
  .qty-row .qty{width:fit-content}
  .hostname-preview{font-size:11px}

  /* Final bar — the user's explicit ask. Terms on top (readable), button
     full-width, split into "Deploy server" + a right-aligned price pill so
     nothing wraps awkwardly. */
  .final-bar{flex-direction:column;align-items:stretch;gap:14px;padding:16px 16px;margin-top:12px}
  .terms{flex:0 1 auto;width:100%;font-size:12.5px;gap:12px}
  .terms-box{width:24px;height:24px}
  .btn-deploy{width:100%;justify-content:space-between;padding:15px 18px;font-size:15px;border-radius:12px}
  .btn-deploy-left{font-size:15px}
  .btn-deploy-left i{font-size:18px}
  .btn-deploy-price{font-size:14.5px;padding:6px 13px}

  /* Summary sidebar on mobile: compact padding and smaller text, still readable. */
  .sum-head{padding:12px 14px}
  .sum-plan{padding:14px 14px 12px}
  .sum-plan.empty{padding:22px 16px}
  .sum-plan.empty .ring{width:44px;height:44px;font-size:20px}
  .sum-section,.sum-addons{padding:11px 14px}
  .sum-totals{padding:14px 14px 16px}
  .sum-totals .grand strong{font-size:22px}
  .sum-coins{padding:10px 14px}

  /* Success banner — recap grid collapses to 1 column for readability. */
  .ok-banner{padding:18px 18px;gap:12px}
  .ok-banner i{font-size:24px}
  .ok-banner h2{font-size:17px}
  .ok-banner p{font-size:12.5px}
}

/* Extra-small — phones narrower than ~400 px. */
@media (max-width:400px){
  .dply-head h1{font-size:22px}
  .os-grid{grid-template-columns:1fr}
  .step-pill{display:none}                              /* reclaim the width at the top of each step */
  .addon{grid-template-columns:auto 1fr;grid-template-rows:auto auto auto}
  .addon-icon{grid-row:1}
  .addon-body{grid-column:2;grid-row:1}
  .addon-price{grid-column:1 / -1;grid-row:2;text-align:left}
  .addon > .sw,.addon > .qty{grid-column:1 / -1;grid-row:3;justify-self:start}
}
