/* ============================================================================
   ByondVoice — public marketing site + self-service number-ordering flow.
   Shares the Byond type family + structural DNA of web/marketing (byondcx) and
   web/byondvoice (operator console), but carries the ByondVoice "SIGNAL"
   identity: cool slate paper + a cyan -> indigo gradient (vs byondcx's warm
   cream + magenta -> orange), tuned for a trustworthy telecom/voice product.
   No build step — plain CSS.
   ============================================================================ */
:root{
  /* cool paper — slate-leaning, matches the byondvoice console */
  --paper:#F4F6FA; --paper-2:#EAEEF6; --paper-3:#DFE5F0;
  --ink:#0E1726; --ink-soft:#36435A; --muted:#74829A;
  --line:rgba(14,23,38,.12); --line-2:rgba(14,23,38,.07);
  /* SIGNAL gradient — the ByondVoice brand mark */
  --s1:#06B6D4; --s2:#3B6FF6; --s3:#6D5BF8;
  --grad:linear-gradient(118deg,#06B6D4 0%,#3B6FF6 54%,#6D5BF8 100%);
  --grad-soft:linear-gradient(118deg,rgba(6,182,212,.16),rgba(109,91,248,.10));
  /* dark "switch" chrome */
  --console:#0A1120; --console-2:#111B30; --console-line:rgba(255,255,255,.09);
  --console-text:#EAF0FB; --console-muted:#8294B4;
  --ok:#16B981; --warn:#E0911C; --bad:#E2445C; --hold:#06B6D4;
  --r:16px; --maxw:1180px;
  --serif:"Bricolage Grotesque",sans-serif; --sans:"Hanken Grotesk",sans-serif; --mono:"JetBrains Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  -webkit-font-smoothing:antialiased; line-height:1.55; overflow-x:hidden;
  background-image:
    radial-gradient(130% 120% at 100% 0%, rgba(59,111,246,.08), transparent 46%),
    radial-gradient(120% 120% at 0% 0%, rgba(6,182,212,.06), transparent 42%);
}
/* faint signal-grid backdrop */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:56px 56px; mask-image:radial-gradient(130% 100% at 56% 0%,#000,transparent 80%);
}
body.locked{overflow:hidden}
a{color:inherit; text-decoration:none}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px; position:relative; z-index:1}
.mono{font-family:var(--mono); font-weight:500; letter-spacing:.03em}
.grad-text{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(14,23,38,.18);border-radius:8px;border:2px solid var(--paper)}

.kicker{font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--s2); display:inline-flex; align-items:center; gap:9px}
.kicker::before{content:""; width:7px; height:7px; border-radius:50%; background:var(--grad); box-shadow:0 0 0 4px rgba(59,111,246,.12); animation:pulse 2s infinite}
.micro{font-family:var(--mono); font-size:10.5px; letter-spacing:.13em; text-transform:uppercase; color:var(--muted)}
.opt{text-transform:none; letter-spacing:0; opacity:.75; font-size:.92em}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(59,111,246,.18)}50%{box-shadow:0 0 0 7px rgba(59,111,246,0)}}

/* ---------- logo lockup (inline SVG waveform mark) ---------- */
.bv-logo{display:flex; align-items:center; gap:10px}
.bv-mark{width:30px;height:30px;border-radius:9px;background:var(--grad);display:grid;place-items:center;flex:none;box-shadow:0 6px 16px -8px rgba(59,111,246,.7)}
.bv-mark svg{width:18px;height:18px}
.bv-mark svg rect{fill:#fff}
.bv-word{font-family:var(--serif); font-weight:800; font-size:18px; letter-spacing:-.02em; color:var(--ink); line-height:1}
.bv-word .v{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:14.5px; border-radius:11px; padding:11px 18px; transition:transform .18s ease, box-shadow .2s ease, background .2s, border-color .2s; cursor:pointer; border:1px solid transparent; white-space:nowrap; font-family:var(--sans)}
.btn-grad{background:var(--grad); color:#fff; box-shadow:0 8px 22px -8px rgba(59,111,246,.6)}
.btn-grad:hover{transform:translateY(-2px); box-shadow:0 14px 30px -10px rgba(59,111,246,.72)}
.btn-ghost{border-color:var(--line); color:var(--ink); background:rgba(255,255,255,.55)}
.btn-ghost:hover{border-color:var(--ink); transform:translateY(-2px)}
.btn-arrow::after{content:"→"; font-family:var(--mono)}
.btn[disabled]{opacity:.5; pointer-events:none}
.linkbtn{background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:13px;color:var(--s2);padding:0}
.linkbtn:hover{color:var(--s3);text-decoration:underline}
.signin{font-size:14.5px; font-weight:600; color:var(--ink-soft)}
.signin:hover{color:var(--s2)}

/* ---------- nav ---------- */
header.nav{position:sticky; top:0; z-index:50; backdrop-filter:saturate(140%) blur(12px); background:rgba(244,246,250,.78); border-bottom:1px solid var(--line-2)}
.nav-in{display:flex; align-items:center; justify-content:space-between; height:70px; gap:18px}
.nav-links{display:flex; gap:28px; font-size:14.5px; font-weight:500}
.nav-links a{color:var(--ink-soft); transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex; align-items:center; gap:16px}
.menu-btn{display:none; width:40px;height:40px; border:1px solid var(--line); border-radius:11px; background:rgba(255,255,255,.5); cursor:pointer; align-items:center; justify-content:center}
.menu-btn svg{width:18px;height:18px;stroke:var(--ink);stroke-width:1.8;fill:none}
.nav-scrim{position:fixed; inset:0; background:rgba(10,17,32,.45); backdrop-filter:blur(3px); opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s; z-index:48}
.nav-scrim.open{opacity:1; visibility:visible}

/* ---------- hero ---------- */
.hero{padding:72px 0 44px; display:grid; grid-template-columns:1.04fr .96fr; gap:54px; align-items:center}
h1{font-family:var(--serif); font-weight:700; font-size:clamp(40px,5.4vw,66px); line-height:1.0; letter-spacing:-.022em}
.hero-copy .lead{margin-top:22px; font-size:clamp(16.5px,1.4vw,19px); color:var(--ink-soft); max-width:38ch}
.hero-cta{margin-top:30px; display:flex; gap:14px; flex-wrap:wrap}
.trust{margin-top:30px; display:flex; flex-wrap:wrap; gap:8px}
.trust span{font-family:var(--mono); font-size:11px; letter-spacing:.05em; color:var(--ink-soft); border:1px solid var(--line); border-radius:7px; padding:6px 10px; background:rgba(255,255,255,.5)}

/* hero art — phone + floating cards */
.hero-art{position:relative; display:flex; justify-content:center; align-items:center; min-height:440px}
.phone{width:min(330px,100%); background:var(--console); border-radius:30px; padding:14px; box-shadow:0 50px 90px -38px rgba(10,17,32,.65), 0 0 0 1px rgba(0,0,0,.05); position:relative; overflow:hidden; z-index:2}
.phone::after{content:""; position:absolute; inset:0; background:radial-gradient(90% 60% at 80% -10%, rgba(59,111,246,.22), transparent 55%); pointer-events:none}
.phone-bar{display:flex; align-items:center; justify-content:space-between; padding:6px 8px 12px; position:relative; z-index:1}
.phone-bar .ttl{font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; color:var(--console-muted); text-transform:uppercase}
.live-dot{display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:10.5px; color:#7CF2C8}
.live-dot i{width:7px;height:7px;border-radius:50%;background:#27E2A0;box-shadow:0 0 9px #27E2A0;animation:pulse 1.6s infinite}
.phone-screen{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02)); border:1px solid var(--console-line); border-radius:18px; padding:16px; position:relative; z-index:1}
.callcard{display:flex; align-items:center; gap:12px}
.callcard .ava{width:46px;height:46px;border-radius:13px;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:16px;flex:none}
.cc-meta{min-width:0;flex:1}
.cc-meta b{color:#fff;font-size:15px;display:block;font-weight:600}
.cc-meta span{color:var(--console-muted);font-size:11px}
.cc-timer{color:#7CF2C8;font-size:14px;font-weight:600}
.wave{display:flex; align-items:flex-end; gap:3px; height:40px; margin:16px 0 4px}
.wave i{flex:1; background:var(--grad); border-radius:3px; opacity:.85; animation:wv 1.1s ease-in-out infinite}
@keyframes wv{0%,100%{height:16%}50%{height:100%}}
.flow{display:flex; flex-direction:column; gap:7px; margin-top:14px; padding-top:14px; border-top:1px solid var(--console-line)}
.flow .frow{display:flex; align-items:center; gap:10px; font-family:var(--mono); font-size:11px; color:var(--console-muted)}
.flow .frow .fi{width:20px;height:20px;border-radius:6px;background:rgba(59,111,246,.18);color:#9FC0FF;display:grid;place-items:center;flex:none;font-size:10px}
.flow .frow.in{animation:rowIn .5s both}
@keyframes rowIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:none}}
.phone-keys{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; padding:14px 8px 6px; position:relative; z-index:1}
.key{height:46px;border-radius:13px;border:1px solid var(--console-line);background:rgba(255,255,255,.05);display:grid;place-items:center;cursor:default}
.key svg{width:19px;height:19px;stroke:var(--console-text);stroke-width:1.7;fill:none}
.key-end{background:linear-gradient(180deg,#E2445C,#c4374c);border-color:transparent}
.key-end svg{stroke:#fff}
.float-card{position:absolute; background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,255,255,.82)); border:1px solid var(--line); border-radius:14px; padding:13px 15px; box-shadow:0 24px 50px -28px rgba(10,17,32,.4); z-index:3; display:flex; flex-direction:column; gap:3px; backdrop-filter:blur(6px); animation:floaty 5s ease-in-out infinite}
.float-card b{font-size:13.5px; color:var(--ink); font-weight:600}
.float-card .fc-sub{font-size:10.5px; color:var(--muted)}
.fc-1{top:18px; left:-6px; animation-delay:.2s}
.fc-2{bottom:30px; right:-10px; animation-delay:1.4s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ---------- value props ---------- */
.props-sec{padding-top:18px}
.props{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.prop{border:1px solid var(--line); border-radius:var(--r); padding:24px 22px; background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(255,255,255,.4)); transition:transform .25s, border-color .25s, box-shadow .25s}
.prop:hover{transform:translateY(-4px); border-color:rgba(59,111,246,.35); box-shadow:0 22px 44px -26px rgba(59,111,246,.4)}
.prop .p-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--grad-soft);color:var(--s2);margin-bottom:14px}
.prop .p-ic svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.7;fill:none}
.prop h3{font-family:var(--serif); font-weight:600; font-size:18px; letter-spacing:-.01em; margin-bottom:8px}
.prop p{color:var(--ink-soft); font-size:14px}

/* ---------- sections ---------- */
section{padding:78px 0; position:relative}
.sec-head{max-width:680px; margin-bottom:44px}
.sec-head h2{font-family:var(--serif); font-weight:700; font-size:clamp(28px,3.4vw,42px); letter-spacing:-.02em; line-height:1.05; margin-top:14px}
.sec-head p{margin-top:14px; color:var(--ink-soft); font-size:17px; max-width:60ch}

/* feature grid */
.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.card{border:1px solid var(--line); border-radius:var(--r); padding:26px 24px 28px; background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.35)); transition:transform .25s, border-color .25s, box-shadow .25s}
.card:hover{transform:translateY(-4px); border-color:rgba(59,111,246,.4); box-shadow:0 22px 44px -26px rgba(59,111,246,.4)}
.card h3{font-family:var(--serif); font-weight:600; font-size:20px; margin:16px 0 9px; letter-spacing:-.01em}
.card p{color:var(--ink-soft); font-size:14.7px}
.card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--grad);color:#fff}
.card .ic svg{width:23px;height:23px;stroke:#fff;stroke-width:1.7;fill:none}

/* steps */
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line)}
.step{padding:26px 22px 30px; border-right:1px solid var(--line); position:relative}
.step:last-child{border-right:none}
.step .no{font-family:var(--mono); font-size:13px; color:var(--s2); font-weight:700}
.step h4{font-family:var(--serif); font-size:19px; font-weight:600; margin:18px 0 8px}
.step p{font-size:14px; color:var(--ink-soft)}
.step::before{content:""; position:absolute; top:-1px; left:0; width:38%; height:2px; background:var(--grad)}

/* ============================================================================
   ORDER FLOW (the self-service funnel)
   ============================================================================ */
.order-sec{padding-top:40px}
.order-shell{border:1px solid var(--line); border-radius:24px; background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(255,255,255,.5)); overflow:hidden; box-shadow:0 40px 90px -50px rgba(10,17,32,.4)}
.order-head{display:flex; align-items:flex-end; justify-content:space-between; gap:24px; padding:30px 32px 26px; background:var(--console); color:var(--console-text); position:relative; overflow:hidden; flex-wrap:wrap}
.order-head::after{content:""; position:absolute; inset:0; background:radial-gradient(70% 130% at 100% 0%, rgba(59,111,246,.24), transparent 58%); pointer-events:none}
.order-head>div{position:relative; z-index:1; max-width:46ch}
.order-head .kicker{color:#7FD8E8}
.order-head h2{font-family:var(--serif); font-weight:700; font-size:clamp(24px,3vw,34px); letter-spacing:-.02em; margin-top:12px; color:#fff}
.oh-sub{color:var(--console-muted); font-size:15px; margin-top:10px}

/* stepper */
.stepper{display:flex; align-items:center; gap:0; list-style:none; position:relative; z-index:1; flex-wrap:wrap}
.stepper li{display:flex; align-items:center; gap:9px; padding-right:20px; position:relative; opacity:.55; transition:opacity .25s}
.stepper li:not(:last-child)::after{content:""; width:24px; height:1px; background:var(--console-line); margin-left:8px}
.stepper li .dot{width:28px;height:28px;border-radius:50%;border:1px solid var(--console-line);display:grid;place-items:center;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--console-muted);transition:.25s;flex:none}
.stepper li .lab{font-size:13px;font-weight:600;color:var(--console-muted)}
.stepper li.active{opacity:1}
.stepper li.active .dot{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 6px 16px -6px rgba(59,111,246,.7)}
.stepper li.active .lab{color:#fff}
.stepper li.done .dot{background:rgba(22,185,129,.2);border-color:rgba(22,185,129,.5);color:#7CF2C8}
.stepper li.done{opacity:.9}

.order-body{padding:28px 32px 30px}
.ostep{display:none; animation:viewIn .35s cubic-bezier(.2,.7,.2,1) both}
.ostep.active{display:block}
@keyframes viewIn{from{opacity:0; transform:translateY(10px)}to{opacity:1; transform:none}}
.ostep-foot{display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:24px; padding-top:20px; border-top:1px solid var(--line-2); flex-wrap:wrap}
.selnote{color:var(--muted); font-size:12px}

/* search bar */
.search-bar{display:grid; grid-template-columns:repeat(2,1fr) 1.4fr auto; gap:14px; align-items:end}
.sf{display:flex; flex-direction:column; gap:6px; min-width:0}
.sf.grow{min-width:0}
.sf label{font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted)}
.sf select, .sf input{height:46px; border:1px solid var(--line); border-radius:11px; background:rgba(255,255,255,.8); padding:0 14px; font-family:var(--sans); font-size:14.5px; color:var(--ink); width:100%}
.sf select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2374829A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 13px center;padding-right:38px}
.sf select:focus, .sf input:focus{outline:none; border-color:var(--s2); box-shadow:0 0 0 3px rgba(59,111,246,.1)}
.search-btn{height:46px}
.sb-ico{width:16px;height:16px;stroke:#fff;stroke-width:2;fill:none}

/* results */
.results{margin-top:22px; min-height:120px}
.results-hint{font-family:var(--mono); font-size:12.5px; color:var(--muted); text-align:center; padding:34px 12px; border:1px dashed var(--line); border-radius:14px; line-height:1.6}
.results-hint.err{color:var(--bad); border-color:rgba(226,68,92,.4); background:rgba(226,68,92,.05)}
.results-hint.loading{color:var(--s2); border-color:rgba(59,111,246,.4)}
.results-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.numcard{border:1px solid var(--line); border-radius:13px; padding:15px 16px; background:rgba(255,255,255,.7); cursor:pointer; transition:transform .18s, border-color .18s, box-shadow .18s; text-align:left; position:relative; font-family:var(--sans)}
.numcard:hover{transform:translateY(-3px); border-color:rgba(59,111,246,.45); box-shadow:0 16px 34px -22px rgba(59,111,246,.45)}
.numcard.sel{border-color:var(--s2); background:var(--grad-soft); box-shadow:0 0 0 1px var(--s2)}
.numcard .nc-num{font-family:var(--mono); font-weight:600; font-size:16px; color:var(--ink); letter-spacing:.01em}
.numcard .nc-meta{display:flex; gap:7px; margin-top:9px; flex-wrap:wrap}
.numcard .nc-chip{font-family:var(--mono); font-size:10px; letter-spacing:.03em; padding:3px 8px; border-radius:7px; background:rgba(14,23,38,.05); color:var(--ink-soft)}
.numcard .nc-chip.type{background:rgba(109,91,248,.12); color:#4a3bb8}
.numcard .nc-price{position:absolute; top:14px; right:14px; font-family:var(--mono); font-size:12px; color:var(--ink-soft)}
.numcard .nc-check{position:absolute; top:12px; right:12px; width:22px;height:22px;border-radius:50%;background:var(--grad);display:none;place-items:center}
.numcard.sel .nc-check{display:grid}
.numcard.sel .nc-price{display:none}
.numcard .nc-check svg{width:13px;height:13px;stroke:#fff;stroke-width:3;fill:none}

/* skeleton loading cards */
.skel{border:1px solid var(--line-2); border-radius:13px; padding:15px 16px; background:rgba(255,255,255,.5); overflow:hidden; position:relative}
.skel::after{content:""; position:absolute; inset:0; transform:translateX(-100%); background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent); animation:shimmer 1.4s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.skel .sk-line{height:13px; border-radius:5px; background:rgba(14,23,38,.08); margin-bottom:10px}
.skel .sk-line.w1{width:60%; height:17px}
.skel .sk-line.w2{width:38%}

/* picked banner */
.picked-banner{display:flex; align-items:center; gap:14px; border:1px solid rgba(59,111,246,.3); background:var(--grad-soft); border-radius:13px; padding:14px 16px; margin-bottom:22px}
.picked-banner .pb-ic{width:34px;height:34px;border-radius:9px;background:var(--grad);display:grid;place-items:center;flex:none}
.picked-banner .pb-ic svg{width:18px;height:18px;stroke:#fff;stroke-width:2.4;fill:none}
.pb-meta{flex:1;min-width:0}
.pb-meta b{font-family:var(--mono);font-size:16px;display:block;color:var(--ink)}

/* plans */
.plans{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.plan{border:1px solid var(--line); border-radius:14px; padding:20px 18px; background:rgba(255,255,255,.66); cursor:pointer; transition:transform .18s, border-color .18s, box-shadow .18s; position:relative; text-align:left; font-family:var(--sans)}
.plan:hover{transform:translateY(-3px); border-color:rgba(59,111,246,.4)}
.plan.sel{border-color:var(--s2); box-shadow:0 0 0 1px var(--s2), 0 18px 38px -24px rgba(59,111,246,.5); background:rgba(255,255,255,.92)}
.plan .pl-badge{position:absolute; top:-9px; left:18px; font-family:var(--mono); font-size:9.5px; letter-spacing:.08em; padding:3px 9px; border-radius:6px; background:var(--grad); color:#fff}
.plan .pl-name{font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--s2)}
.plan .pl-amt{font-family:var(--serif); font-weight:700; font-size:30px; letter-spacing:-.02em; margin:10px 0 1px}
.plan .pl-per{font-family:var(--mono); font-size:10.5px; color:var(--muted)}
.plan ul{list-style:none; margin:14px 0 0; display:flex; flex-direction:column; gap:7px; font-size:13px; color:var(--ink-soft)}
.plan li{display:flex; gap:8px; align-items:flex-start}
.plan li svg{width:14px;height:14px;stroke:var(--s2);stroke-width:2.4;fill:none;flex:none;margin-top:3px}
.plan .pl-radio{position:absolute; top:16px; right:16px; width:20px;height:20px;border-radius:50%;border:2px solid var(--line);transition:.18s}
.plan.sel .pl-radio{border-color:var(--s2);background:var(--s2);box-shadow:inset 0 0 0 3px #fff}

/* seats */
.seats-row{display:flex; align-items:center; justify-content:space-between; gap:18px; margin-top:22px; padding:18px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.5); flex-wrap:wrap}
.seats-l .sr-sub{font-size:13px; color:var(--muted); margin-top:4px}
.stepper-num{display:flex; align-items:center; gap:0; border:1px solid var(--line); border-radius:11px; overflow:hidden; background:#fff}
.sn-btn{width:44px;height:46px;border:none;background:rgba(14,23,38,.03);font-size:20px;color:var(--ink);cursor:pointer;font-family:var(--sans);transition:background .15s}
.sn-btn:hover{background:var(--grad-soft);color:var(--s2)}
.sn-in{width:64px;height:46px;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font-family:var(--mono);font-size:16px;font-weight:600;color:var(--ink)}
.sn-in:focus{outline:none;background:var(--grad-soft)}

/* order summary */
.order-summary{margin-top:22px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.55); padding:18px}
.os-line{display:flex; align-items:center; justify-content:space-between; gap:12px; font-size:14.5px; color:var(--ink-soft); padding:7px 0}
.os-line.os-total{border-top:1px solid var(--line-2); margin-top:6px; padding-top:14px; font-family:var(--serif); font-size:19px; font-weight:700; color:var(--ink)}
.os-line.os-total .mono{font-size:19px}
.os-fine{font-size:12px; color:var(--muted); margin-top:12px; line-height:1.5}

/* details form */
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted)}
.field input{height:46px; border:1px solid var(--line); border-radius:11px; background:rgba(255,255,255,.8); padding:0 14px; font-family:var(--sans); font-size:14.5px; color:var(--ink)}
.field input:focus{outline:none; border-color:var(--s2); box-shadow:0 0 0 3px rgba(59,111,246,.1)}
.field input.bad{border-color:var(--bad); box-shadow:0 0 0 3px rgba(226,68,92,.1)}
.hp{position:absolute!important;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.consent{display:flex; gap:11px; align-items:flex-start; margin-top:18px; font-size:13.5px; color:var(--ink-soft); line-height:1.5}
.consent input{margin-top:3px; width:17px; height:17px; accent-color:var(--s2); flex:none}
.consent a{color:var(--s2); text-decoration:underline}

/* review */
.review{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}
.rv-block{border:1px solid var(--line); border-radius:13px; padding:16px 18px; background:rgba(255,255,255,.6)}
.rv-block b{font-family:var(--mono); font-size:17px; display:block; margin-top:7px; color:var(--ink); word-break:break-word}
.rv-block .rv-sub{font-size:11.5px; color:var(--muted); display:block; margin-top:5px}
.rv-block.rv-total{background:var(--console); border-color:transparent}
.rv-block.rv-total .micro{color:var(--console-muted)}
.rv-block.rv-total b{font-size:26px; font-family:var(--serif); font-weight:700}
.rv-block.rv-total .rv-sub{color:var(--console-muted)}
.checkout-btn{position:relative}
.lock-ico{width:16px;height:16px;stroke:#fff;stroke-width:2;fill:none}
.checkout-fine{font-size:12px; color:var(--muted); margin-top:14px; text-align:center; line-height:1.5}

/* inline message line (order errors / status) */
.msg-line{font-family:var(--mono); font-size:12px; padding:11px 14px; border-radius:11px; display:none; line-height:1.5; margin-top:18px}
.msg-line.show{display:block}
.msg-line.ok{background:rgba(22,185,129,.1); color:#0c7a55; border:1px solid rgba(22,185,129,.25)}
.msg-line.err{background:rgba(226,68,92,.08); color:#b02239; border:1px solid rgba(226,68,92,.25)}
.msg-line.loading{background:rgba(59,111,246,.08); color:#234fc4; border:1px solid rgba(59,111,246,.25)}

/* ============================================================================
   PRICING
   ============================================================================ */
.prices{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; align-items:stretch}
.price{border:1px solid var(--line); border-radius:var(--r); padding:26px 22px; background:rgba(255,255,255,.55); display:flex; flex-direction:column}
.price.feat{border-color:transparent; background:var(--console); color:var(--console-text); box-shadow:0 30px 60px -30px rgba(10,17,32,.5); transform:translateY(-8px)}
.price .pl{font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--s2)}
.price.feat .pl{color:#7FD8E8}
.price .amt{font-family:var(--serif); font-weight:700; font-size:34px; margin:14px 0 2px; letter-spacing:-.02em}
.price .per{font-family:var(--mono); font-size:11px; color:var(--muted)}
.price.feat .per{color:var(--console-muted)}
.price ul{list-style:none; margin:18px 0 22px; display:flex; flex-direction:column; gap:9px; font-size:13.6px; color:var(--ink-soft)}
.price.feat ul{color:#D8E0EE}
.price li{display:flex; gap:8px; align-items:flex-start}
.price li svg{width:14px;height:14px;stroke:var(--s2);stroke-width:2.4;fill:none;flex:none;margin-top:3px}
.price.feat li svg{stroke:#7FD8E8}
.price .badge{align-self:flex-start; font-family:var(--mono); font-size:10px; letter-spacing:.1em; padding:4px 9px; border-radius:6px; background:var(--grad); color:#fff; margin-bottom:12px}
.price .btn{margin-top:auto; justify-content:center}
.price.feat .btn-ghost{border-color:rgba(255,255,255,.25); color:#fff; background:rgba(255,255,255,.06)}
.price-notes{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:24px}
.pn{border:1px solid var(--line); border-radius:13px; padding:18px; background:rgba(255,255,255,.5)}
.pn .pn-h{font-size:11px; color:var(--s2); letter-spacing:.1em; display:block; margin-bottom:8px}
.pn p{font-size:13.5px; color:var(--ink-soft)}
.pn b{color:var(--ink)}

/* ============================================================================
   RESELLER
   ============================================================================ */
.reseller{background:var(--console); color:var(--console-text); border-radius:26px; padding:54px; display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:center; position:relative; overflow:hidden}
.reseller::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 100% 0%,rgba(59,111,246,.24),transparent 55%);pointer-events:none}
.reseller>div{position:relative; z-index:1}
.reseller .kicker{color:#7FD8E8}
.reseller h2{font-family:var(--serif); font-weight:700; font-size:clamp(28px,3.2vw,40px); letter-spacing:-.02em; line-height:1.04; margin:14px 0 16px; color:#fff}
.reseller p.r-lead{color:#C2CEE2; font-size:16.5px; max-width:46ch}
.r-list{margin-top:22px; display:flex; flex-direction:column; gap:13px}
.r-list li{list-style:none; display:flex; gap:12px; font-size:15px; color:#DBE3F0}
.r-list .tick{color:#fff; background:var(--grad); width:22px;height:22px;border-radius:6px;display:grid;place-items:center;flex:none;font-size:12px;font-family:var(--mono)}
.r-cta{margin-top:30px}
.diagram{display:flex; flex-direction:column; gap:14px}
.node{border:1px solid var(--console-line); border-radius:14px; padding:16px 18px; background:rgba(255,255,255,.03)}
.node .lbl{font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--console-muted)}
.node .nm{font-family:var(--serif); font-size:18px; margin-top:4px; color:var(--console-text)}
.node.brand{border-color:rgba(59,111,246,.5); background:linear-gradient(180deg,rgba(59,111,246,.14),rgba(6,182,212,.05))}
.node.brand .nm{color:#fff}
.conn{height:20px; width:2px; background:linear-gradient(var(--s1),var(--s3)); margin-left:26px}
.tenants{display:flex; gap:8px; flex-wrap:wrap; margin-top:4px}
.tenants span{font-family:var(--mono); font-size:11px; padding:6px 9px; border:1px dashed var(--console-line); border-radius:8px; color:var(--console-muted)}

/* ============================================================================
   SECURITY
   ============================================================================ */
.sec-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.sgi{border:1px solid var(--line); border-radius:12px; padding:18px; background:rgba(255,255,255,.5)}
.sgi .h{font-size:11px; color:var(--s2); letter-spacing:.08em}
.sgi .t{font-weight:600; margin-top:8px; font-size:15px}
.sgi p{font-size:13px; color:var(--ink-soft); margin-top:5px}

/* ============================================================================
   CTA / DEMO
   ============================================================================ */
.ctaband{background:var(--console); color:#fff; border-radius:26px; padding:48px; position:relative; overflow:hidden}
.ctaband::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 130% at 20% 0%,rgba(59,111,246,.26),transparent 60%)}
.cta-grid{display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:center; position:relative; z-index:1}
.cta-left h2{font-family:var(--serif); font-weight:700; font-size:clamp(28px,3.4vw,40px); letter-spacing:-.02em}
.cta-sub{color:rgba(234,240,251,.74); max-width:46ch; margin:14px 0 24px; font-size:16px}
.cta-trust{display:flex; gap:18px; flex-wrap:wrap; margin-top:26px; font-size:11px; color:var(--console-muted); letter-spacing:.04em}
.cta-trust span{display:inline-flex; align-items:center; gap:7px}
.cta-trust i{width:7px;height:7px;border-radius:50%;background:#27E2A0;box-shadow:0 0 8px #27E2A0;animation:pulse 1.8s infinite}

/* demo form */
.demo-form{text-align:left}
.df-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.df-in{width:100%;font-family:var(--sans);font-size:15px;color:#fff;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:13px 14px;outline:none;transition:border-color .15s ease,background .15s ease}
.df-in::placeholder{color:rgba(234,240,251,.5)}
.df-in:focus{border-color:var(--s1);background:rgba(255,255,255,.10)}
.df-sel{margin-top:12px;appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.df-sel option{color:#0E1726}
.df-ta{margin-top:12px;resize:vertical;min-height:64px;font-family:var(--sans)}
.df-hp{position:absolute!important;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.df-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px;align-items:center}
.df-msg{margin-top:14px;font-size:14px;min-height:1.2em;font-family:var(--mono)}
.df-msg.ok{color:#7CF2C8}
.df-msg.err{color:#ffb4a8}

/* ============================================================================
   FOOTER
   ============================================================================ */
footer{border-top:1px solid var(--line); padding:54px 0 34px; margin-top:30px}
.foot-top{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px}
.foot-logo{margin-bottom:14px}
.foot-blurb{color:var(--ink-soft);font-size:14px;max-width:32ch}
.foot-col h5{font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:14px}
.foot-col a{display:block; color:var(--ink-soft); font-size:14px; padding:5px 0}
.foot-col a:hover{color:var(--s2)}
.foot-bot{display:flex; justify-content:space-between; align-items:center; margin-top:40px; padding-top:22px; border-top:1px solid var(--line-2); font-size:13px; color:var(--muted); flex-wrap:wrap; gap:10px}
.status{display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11.5px}
.status i{width:7px;height:7px;border-radius:50%;background:#27E2A0;box-shadow:0 0 8px #27E2A0;animation:pulse 1.8s infinite}

/* ---------- toast ---------- */
.toast{position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(160%); background:var(--console); color:#fff; padding:13px 20px; border-radius:12px; font-size:13.5px; font-weight:500; z-index:130; box-shadow:0 20px 40px -20px rgba(0,0,0,.5); display:flex; align-items:center; gap:10px; transition:transform .35s cubic-bezier(.2,.7,.2,1); border:1px solid rgba(255,255,255,.12); max-width:min(440px,92vw)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast i{width:8px;height:8px;border-radius:50%;background:#27E2A0;box-shadow:0 0 9px #27E2A0;flex:none}
.toast.err i{background:var(--bad);box-shadow:0 0 9px var(--bad)}

/* ---------- reveal ---------- */
.rv{opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.rv.show{opacity:1; transform:none}

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
@media (max-width:980px){
  .hero{grid-template-columns:1fr; gap:36px; padding-top:40px}
  .hero-art{min-height:auto; margin-top:8px}
  .grid,.props{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .prices,.sec-grid{grid-template-columns:1fr 1fr}
  .reseller{grid-template-columns:1fr; padding:34px}
  .cta-grid{grid-template-columns:1fr; gap:30px}
  .results-grid,.plans{grid-template-columns:1fr 1fr}
  .price.feat{transform:none}
  .nav-links{display:none}
  .menu-btn{display:flex}
  .demo-only{display:none}
  /* mobile nav drawer */
  .nav-links.open{display:flex; position:fixed; top:70px; left:0; right:0; flex-direction:column; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:8px 28px 20px; z-index:49}
  .nav-links.open a{padding:14px 0; border-bottom:1px solid var(--line-2); font-size:16px}
  .search-bar{grid-template-columns:1fr 1fr}
  .search-bar .sf.grow{grid-column:1/-1}
  .search-btn{grid-column:1/-1}
  .price-notes{grid-template-columns:1fr}
}
@media (max-width:620px){
  .wrap{padding:0 18px}
  .props,.grid,.prices,.sec-grid,.steps,.foot-top{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .reseller,.ctaband{padding:26px}
  .order-head,.order-body{padding-left:20px;padding-right:20px}
  .results-grid,.plans,.review,.form-grid,.df-grid{grid-template-columns:1fr}
  .stepper li .lab{display:none}
  .stepper li{padding-right:14px}
  .nav-cta .signin{display:none}
  .seats-row{flex-direction:column; align-items:stretch}
  .ostep-foot{flex-direction:column-reverse; align-items:stretch}
  .ostep-foot .btn{justify-content:center}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important; transition:none!important}}
