/* RoamLuna customer portal. Flat, white, editorial. Teal + warm amber.
   Hairline borders and accent rules, NOT shadowed cards. Mirrors the main site. */
:root{
  --bg:#ffffff;
  --band:#F4F6F5;
  --ink:#15181A;
  --muted:#5B6360;
  --soft:#7C8682;
  --teal:#0E7C66;
  --teal-d:#0B6353;
  --teal-tint:#E7F1EE;
  --amber:#E0892F;
  --amber-d:#B96E1F;
  --amber-tint:#FBF1E4;
  --line:#E4E8E6;
  --line-strong:#CDD4D1;
  --warn:#9A3328;
  --warn-tint:#F6E9E7;
  --r:8px;
  --r-lg:14px;
  --font:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --banner-h:38px;
  --topbar-h:64px;
  --header-h:102px;
  --sidebar-w:236px;
  --gut:clamp(20px,3.4vw,44px);
  --shadow-pop:0 12px 30px rgba(21,24,26,.12);
  --shadow-modal:0 24px 60px rgba(21,24,26,.24);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-family:var(--font)}
h1,h2,h3,.display{font-weight:800;letter-spacing:-.032em;line-height:1.08}
h1{letter-spacing:-.04em}
.num{font-variant-numeric:tabular-nums}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal-d);text-decoration:underline}
svg{display:block}
[hidden]{display:none!important}

.eyebrow{display:block;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--teal)}
.eyebrow--amber{color:var(--amber-d)}
.eyebrow--muted{color:var(--soft)}

/* buttons (mirror the main site exactly) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-weight:700;cursor:pointer;
  border:1px solid transparent;border-radius:var(--r);padding:12px 22px;font-size:1rem;line-height:1.1;transition:background .15s,color .15s,border-color .15s}
.btn--primary{background:var(--teal);color:#fff}
.btn--primary:hover{background:var(--teal-d);color:#fff;text-decoration:none}
.btn--amber{background:var(--amber);color:#fff}
.btn--amber:hover{background:var(--amber-d);color:#fff;text-decoration:none}
.btn--ghost{background:#fff;color:var(--teal);border-color:var(--line-strong)}
.btn--ghost:hover{border-color:var(--teal);color:var(--teal-d);text-decoration:none}
.btn--danger{background:#fff;color:var(--warn);border-color:var(--line-strong)}
.btn--danger:hover{border-color:var(--warn);color:var(--warn);text-decoration:none}
.btn--sm{padding:9px 15px;font-size:.9rem}
.btn--block{width:100%}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.45;cursor:default}

/* link-style action (no box) for tertiary actions */
.linkbtn{font:inherit;font-size:.95rem;font-weight:700;color:var(--teal);background:none;border:0;padding:0;cursor:pointer;border-bottom:1px solid transparent}
.linkbtn:hover{border-bottom-color:var(--teal)}
.linkbtn--danger{color:var(--warn)}
.linkbtn--danger:hover{border-bottom-color:var(--warn)}

:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.btn:focus-visible{outline-offset:3px}

/* ---------- header: demo banner + topbar ---------- */
.appheader{position:sticky;top:0;z-index:60;background:#fff}
.demo-banner{position:relative;display:flex;align-items:center;gap:10px;height:var(--banner-h);
  background:var(--amber-tint);border-bottom:1px solid var(--line);color:var(--amber-d);
  font-size:.82rem;font-weight:700;padding:0 var(--gut)}
.demo-banner__dot{width:7px;height:7px;border-radius:50%;background:var(--amber);flex:none}
.demo-banner strong{font-weight:800}
.demo-banner__msg{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.demo-banner__text{color:var(--ink);font-weight:600}
.demo-banner__actions{margin-left:auto;display:flex;align-items:center;gap:18px;flex:none}
.demo-banner__btn,.demo-banner__reset{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:.78rem;font-weight:800;
  color:var(--amber-d);background:transparent;border:0;border-bottom:1px solid transparent;padding:0 0 1px;cursor:pointer}
.demo-banner__btn:hover,.demo-banner__reset:hover{color:var(--ink);border-bottom-color:var(--ink)}
.demo-banner__btn svg{width:14px;height:14px}
.demo-banner__btn[aria-expanded="true"]{color:var(--ink);border-bottom-color:var(--ink)}

/* global demo controls popover (replaces the per-page demo boxes) */
.demo-panel{position:absolute;top:calc(100% + 8px);right:var(--gut);width:310px;max-width:calc(100vw - 24px);
  background:#fff;border:1px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);padding:16px 18px;z-index:70}
.demo-panel__title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.13em;color:var(--soft);margin-bottom:14px}
.demo-group{margin-bottom:14px}
.demo-group:last-child{margin-bottom:0}
.demo-group__label{font-size:.82rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.demo-group__row{display:flex;flex-wrap:wrap;gap:7px}

/* dashboard stat links (make each KPI navigable) */
.stat__link{display:inline-block;margin-top:10px;font-size:.85rem;font-weight:700;color:var(--teal);background:none;border:0;border-bottom:1px solid transparent;padding:0;cursor:pointer}
.stat__link:hover{border-bottom-color:var(--teal);text-decoration:none}

/* destructive action, isolated from primary actions by a hairline */
.danger-row{margin-top:6px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px 24px;flex-wrap:wrap}
.danger-row__txt{color:var(--muted);font-size:.9rem;max-width:48ch}

/* plan comparison table */
.tbl .is-current{background:var(--teal-tint)}
.tbl th.is-current{color:var(--teal-d)}
.tbl .feat-yes{color:var(--teal);font-weight:800}
.compare-tag{display:inline-block;margin-left:8px;font-size:.58rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-d);background:#fff;border:1px solid var(--teal);border-radius:4px;padding:2px 6px;vertical-align:middle}

.topbar{display:flex;align-items:center;gap:16px;height:var(--topbar-h);padding:0 var(--gut);border-bottom:1px solid var(--line)}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.32rem;color:var(--ink);letter-spacing:-.02em}
.logo:hover{text-decoration:none;color:var(--ink)}
.logo-icon{width:28px;height:28px;color:var(--teal);flex:none}
.topbar__spacer{flex:1}
.account-menu{position:relative}
.account-btn{display:inline-flex;align-items:center;gap:10px;font:inherit;font-weight:700;font-size:.92rem;color:var(--ink);
  background:#fff;border:1px solid var(--line-strong);border-radius:var(--r);padding:6px 12px 6px 7px;cursor:pointer;transition:border-color .15s}
.account-btn:hover{border-color:var(--teal)}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--teal);color:#fff;font-weight:800;font-size:.85rem;
  display:grid;place-items:center;flex:none}
.account-btn__name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-btn__chev{width:16px;height:16px;color:var(--soft)}
.account-pop{position:absolute;top:calc(100% + 8px);right:0;min-width:208px;background:#fff;border:1px solid var(--line-strong);
  border-radius:var(--r-lg);box-shadow:var(--shadow-pop);padding:6px;z-index:20}
.account-pop button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;font:inherit;font-size:.94rem;font-weight:600;
  color:var(--ink);background:transparent;border:0;border-radius:6px;padding:9px 10px;cursor:pointer}
.account-pop button:hover{background:var(--band)}
.account-pop svg{color:var(--soft)}
.account-pop hr{border:0;border-top:1px solid var(--line);margin:5px 4px}

/* ---------- layout: sidebar + content ---------- */
.layout{display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr);max-width:1340px;margin:0 auto;align-items:start}
.sidebar{position:sticky;top:calc(var(--header-h) + 14px);align-self:start;padding:22px 16px;display:flex;flex-direction:column;gap:4px}
.navbtn{display:flex;align-items:center;gap:12px;width:100%;text-align:left;font:inherit;font-size:.95rem;font-weight:600;
  color:var(--muted);background:transparent;border:0;border-radius:var(--r);padding:11px 12px;cursor:pointer;transition:background .15s,color .15s}
.navbtn:hover{background:var(--band);color:var(--ink)}
.navbtn svg{width:19px;height:19px;flex:none;color:currentColor}
.navbtn[aria-current="page"]{background:var(--teal-tint);color:var(--teal-d);font-weight:700}
.navbtn[aria-current="page"] svg{color:var(--teal)}

.content{min-width:0;border-left:1px solid var(--line);min-height:calc(100vh - var(--header-h));padding:34px var(--gut) 80px}

/* ---------- panel + headings ---------- */
.panel{animation:fade .22s ease both;max-width:1060px}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.panel__head{margin-bottom:34px}
.panel__head h1{font-size:clamp(1.85rem,3vw,2.4rem)}
.panel__head h1:focus{outline:none}
.panel__lead{color:var(--muted);font-size:1.06rem;margin-top:8px;max-width:64ch}
.block{margin-top:46px}
.block__head{margin-bottom:18px}
.section-title{font-size:1.18rem;letter-spacing:-.02em}
.section-sub{color:var(--muted);font-size:.96rem;margin-top:4px}

/* ---------- KPI stat row (border-top accent, no boxes) ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,34px)}
.stat{border-top:2px solid var(--teal);padding-top:15px}
.stat--amber{border-top-color:var(--amber)}
.stat__value{font-weight:800;font-size:1.6rem;letter-spacing:-.025em;margin-top:11px;line-height:1.08;font-variant-numeric:tabular-nums}
.stat__sub{color:var(--muted);font-size:.92rem;margin-top:7px;max-width:24ch}

/* ---------- bordered panels (border only, NO shadow) ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px}
.card--pad-lg{padding:26px 28px}
.grid{display:grid;gap:18px;align-items:start}
.grid--2{grid-template-columns:1fr 1fr}
.grid--3{grid-template-columns:repeat(3,1fr)}

/* editorial 2-up split, divided by a hairline (like the site's contrast grid) */
.split{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff;align-items:stretch}
.split > div{padding:26px 28px}
.split > div + div{border-left:1px solid var(--line)}
.card__label{display:block;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--teal)}
.card__big{font-weight:800;font-size:1.55rem;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.card__sub{color:var(--muted);font-size:.94rem;margin-top:4px}
.card__row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.card__actions--links{gap:22px;align-items:center}

/* ---------- status tags (flat, square-ish) ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.07em;padding:4px 9px;border-radius:4px;white-space:nowrap}
.tag__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.tag--ok{background:var(--teal-tint);color:var(--teal-d)}
.tag--warn{background:var(--amber-tint);color:var(--amber-d)}
.tag--danger{background:var(--warn-tint);color:var(--warn)}
.tag--muted{background:var(--band);color:var(--muted)}

/* ---------- progress bar ---------- */
.progress{position:relative;height:10px;background:var(--line);border-radius:6px;overflow:hidden;margin:16px 0 10px}
.progress__fill{height:100%;background:var(--teal);border-radius:6px;width:0;transition:width .5s cubic-bezier(.4,0,.2,1)}
.progress__fill.is-warn{background:var(--amber)}
.progress__fill.is-danger{background:var(--warn)}
.progress__meta{display:flex;justify-content:space-between;gap:12px;font-size:.96rem;color:var(--muted)}
.progress__meta b{color:var(--ink);font-weight:700}

/* circular usage ring (SVG, no gradient) */
.ring-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.ring{position:relative;width:140px;height:140px;flex:none}
.ring svg{transform:rotate(-90deg)}
.ring__track{fill:none;stroke:var(--line);stroke-width:12}
.ring__fill{fill:none;stroke:var(--teal);stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.4,0,.2,1),stroke .3s}
.ring__fill.is-warn{stroke:var(--amber)}
.ring__fill.is-danger{stroke:var(--warn)}
.ring__center{position:absolute;inset:0;display:grid;place-content:center;text-align:center}
.ring__center b{font-size:1.5rem;font-weight:800;font-variant-numeric:tabular-nums}
.ring__center span{font-size:.76rem;color:var(--soft);font-weight:600}

/* two-pool allowance view (monthly + Travel Boost) */
.alloc-head{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.alloc-bar{display:flex;height:16px;border-radius:8px;overflow:hidden;background:var(--line);margin:16px 0}
.alloc-seg{position:relative;height:100%;min-width:3px;background:var(--teal-tint)}
.alloc-seg--boost{background:var(--amber-tint);box-shadow:inset 2px 0 0 #fff}
.alloc-seg__used{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--teal);transition:width .5s cubic-bezier(.4,0,.2,1)}
.alloc-seg__used--amber{background:var(--amber)}
.pool-legend{list-style:none;display:grid;gap:11px;margin-top:4px}
.pool-legend li{display:flex;align-items:center;gap:10px;font-size:.95rem}
.pool-dot{width:10px;height:10px;border-radius:3px;flex:none}
.pool-dot--teal{background:var(--teal)}
.pool-dot--amber{background:var(--amber)}
.pool-legend__name{font-weight:700}
.pool-legend__val{margin-left:auto;color:var(--muted);font-variant-numeric:tabular-nums}
.pool-note{color:var(--soft);font-size:.86rem;margin-top:14px;max-width:48ch}

/* ---------- key/value rows (hairline) ---------- */
.kv{list-style:none}
.kv li{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:13px 0;border-bottom:1px solid var(--line)}
.kv li:last-child{border-bottom:0;padding-bottom:0}
.kv li:first-child{padding-top:0}
.kv__k{color:var(--muted);font-size:.96rem}
.kv__v{font-weight:700;text-align:right}

/* ---------- notices: flat icon + text under a hairline. No tinted box, no accent bar. ---------- */
.alert{display:flex;gap:11px;align-items:flex-start;font-size:.96rem;border-top:1px solid var(--line);padding-top:16px}
.alert__ic{flex:none;width:19px;height:19px;margin-top:2px;color:var(--muted)}
.alert--warn .alert__ic{color:var(--amber-d)}
.alert--danger .alert__ic{color:var(--warn)}
.alert--ok .alert__ic{color:var(--teal-d)}
.alert b{font-weight:800}
.alert p{color:var(--muted);margin-top:2px}

/* ---------- tables (bordered, no shadow) ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff}
table.tbl{width:100%;border-collapse:collapse;font-size:.94rem;min-width:420px}
table.tbl th,table.tbl td{text-align:left;padding:14px 18px;border-bottom:1px solid var(--line)}
table.tbl th{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--soft);font-weight:800}
table.tbl tbody tr:last-child td{border-bottom:0}
table.tbl td.num,table.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}
table.tbl td{color:var(--ink)}

/* ---------- plan cards ---------- */
.plan-current{border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;padding:28px;max-width:560px}
.plan-current__top{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap}
.plan-current__price{font-weight:800;font-size:2.4rem;letter-spacing:-.03em;margin:14px 0 18px}
.plan-current__price small{font-size:.95rem;color:var(--muted);font-weight:600;letter-spacing:0}
.plan-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:680px;align-items:start}
.plan-card{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;padding:24px;display:flex;flex-direction:column;
  transition:border-color .18s ease}
.plan-card--current{border-color:var(--teal);border-width:2px;padding:23px}
.plan-card__price{font-weight:800;font-size:2.1rem;letter-spacing:-.03em;margin:6px 0 12px}
.plan-card__price small{font-size:.92rem;color:var(--muted);font-weight:600;letter-spacing:0}
.plan-card__desc{color:var(--muted);font-size:.95rem;margin-bottom:14px;min-height:2.9em}
.feat-list{list-style:none;margin:6px 0 20px;flex:1}
.feat-list li{position:relative;padding:7px 0 7px 26px;font-size:.95rem}
.feat-list li::before{content:"";position:absolute;left:3px;top:13px;width:9px;height:5px;border-left:2px solid var(--teal);border-bottom:2px solid var(--teal);transform:rotate(-45deg)}

/* ---------- boost cards (match the site's .boost — border, no shadow) ---------- */
.boost-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.boost-card{border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;padding:22px 16px;display:flex;flex-direction:column;
  align-items:center;text-align:center;gap:3px;transition:border-color .18s ease,transform .18s ease}
.boost-card:hover{border-color:var(--teal);transform:translateY(-3px)}
.boost-card--feat{border-color:var(--teal);border-width:2px;padding:21px 15px}
.boost-card__data{font-weight:800;font-size:1.5rem;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.boost-card__name{font-size:.82rem;color:var(--soft);font-weight:700}
.boost-card__val{font-size:.84rem;color:var(--muted)}
.boost-card__price{font-weight:800;color:var(--teal);font-size:1.25rem;margin:10px 0 14px;font-variant-numeric:tabular-nums}
.boost-card .btn{margin-top:auto;width:100%}

/* active boost: flat bordered strip (white, hairline border — no tint fill, no accent bar) */
.active-boost{display:flex;align-items:center;gap:15px;flex-wrap:wrap;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;background:#fff}
.active-boost__ic{width:38px;height:38px;border-radius:var(--r);background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;flex:none}
.active-boost__ic svg{width:22px;height:22px}
.active-boost b{font-size:1.05rem}
.active-boost__meta{color:var(--muted);font-size:.92rem;margin-top:2px}

/* ---------- coverage (hairline list, not a card grid) ---------- */
.cov-search{position:relative;max-width:440px;margin-bottom:22px}
.cov-search input{width:100%;font:inherit;font-size:1rem;padding:13px 15px 13px 42px;border:1px solid var(--line-strong);border-radius:var(--r);background:#fff;color:var(--ink)}
.cov-search input:focus{outline:2px solid var(--teal);outline-offset:1px;border-color:var(--teal)}
.cov-search__ic{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--soft);width:18px;height:18px}
.cov-list{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff}
.cov-row{display:flex;align-items:center;gap:14px;padding:15px 20px;border-top:1px solid var(--line)}
.cov-row:first-child{border-top:0}
.fl{width:28px;height:21px;border-radius:3px;object-fit:cover;flex:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);vertical-align:middle;background:var(--band)}
.cov-row__name{font-weight:700;font-size:1rem}
.cov-row--off{opacity:.6}
.cov-row__spacer{flex:1}
.cov-row__net{color:var(--muted);font-size:.9rem;white-space:nowrap}
.cov-empty{color:var(--muted);padding:18px 4px}
.cov-hint{color:var(--muted);font-size:.96rem}
@media (max-width:560px){.cov-row__net{display:none}}

/* ---------- FAQ (native details) ---------- */
.faq{max-width:780px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:17px 0;font-weight:700;font-size:1.04rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:focus-visible{outline-offset:4px}
.faq summary::after{content:"+";color:var(--teal);font-weight:800;font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"\2212"}
.faq p{color:var(--muted);padding:0 0 18px;max-width:70ch}

/* ---------- preference toggles ---------- */
.pref{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--line)}
.pref:last-child{border-bottom:0;padding-bottom:0}
.pref:first-child{padding-top:0}
.pref__txt b{display:block;font-weight:700}
.pref__txt span{font-size:.88rem;color:var(--muted)}
.switch{position:relative;width:46px;height:26px;border-radius:999px;background:var(--line-strong);border:0;cursor:pointer;flex:none;transition:background .2s}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(21,24,26,.25);transition:transform .2s}
.switch[aria-checked="true"]{background:var(--teal)}
.switch[aria-checked="true"]::after{transform:translateX(20px)}

/* ---------- demo controls (clearly a demo affordance, not product UI) ---------- */
.demo-controls{border:1px dashed var(--line-strong);border-radius:var(--r-lg);padding:18px 20px}
.demo-controls__label{display:flex;align-items:center;gap:8px;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.13em;color:var(--soft);margin-bottom:12px}
.demo-controls__row{display:flex;flex-wrap:wrap;gap:8px}
.chip-btn{font:inherit;font-size:.88rem;font-weight:700;color:var(--muted);background:#fff;border:1px solid var(--line-strong);
  border-radius:var(--r);padding:8px 14px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}
.chip-btn:hover{border-color:var(--teal);color:var(--teal-d)}
.chip-btn[aria-pressed="true"]{background:var(--teal);border-color:var(--teal);color:#fff}

/* ---------- QR + manual install ---------- */
.qr{width:168px;height:168px;flex:none;border:1px solid var(--line-strong);border-radius:var(--r);background:#fff;padding:12px}
.qr svg{width:100%;height:100%}
.manual{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.84rem}
.manual div{padding:11px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--line)}
.manual div:last-child{border-bottom:0;padding-bottom:0}
.manual div:first-child{padding-top:0}
.manual span{color:var(--soft)}
.manual b{color:var(--ink);word-break:break-all}

/* ---------- usage breakdown rows ---------- */
.bd-list{list-style:none}
.bd-list li{padding:13px 0;border-bottom:1px solid var(--line)}
.bd-list li:last-child{border-bottom:0;padding-bottom:0}
.bd-list li:first-child{padding-top:0}
.bd-list__top{display:flex;justify-content:space-between;gap:12px;font-size:.95rem;margin-bottom:8px}
.bd-list__top b{font-weight:700;font-variant-numeric:tabular-nums}
.bd-bar{height:6px;background:var(--line);border-radius:6px;overflow:hidden}
.bd-bar__fill{height:100%;background:var(--teal);border-radius:6px}

/* ---------- ordered steps (install guide) ---------- */
.steps-list{list-style:none;counter-reset:s;display:grid;gap:14px}
.steps-list li{counter-increment:s;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;color:var(--ink)}
.steps-list li::before{content:counter(s);width:28px;height:28px;border-radius:50%;background:var(--teal-tint);color:var(--teal-d);
  font-weight:800;font-size:.9rem;display:grid;place-items:center}

/* ---------- forms ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:.88rem;font-weight:700;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:1rem;padding:12px 14px;border:1px solid var(--line-strong);
  border-radius:var(--r);background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--teal);outline-offset:1px;border-color:var(--teal)}
.field textarea{min-height:108px;resize:vertical}
.field-row{display:flex;gap:12px}
.field-row .field{flex:1}

/* ---------- modals ---------- */
#modal-root{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px}
.modal-overlay{position:absolute;inset:0;background:rgba(21,24,26,.5)}
.modal{position:relative;z-index:1;width:100%;max-width:460px;max-height:calc(100vh - 40px);overflow-y:auto;
  background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-modal);animation:modalIn .2s cubic-bezier(.22,.7,.2,1) both}
.modal--wide{max-width:540px}
@keyframes modalIn{from{opacity:0;transform:translateY(12px) scale(.99)}to{opacity:1;transform:none}}
.modal__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:24px 24px 0}
.modal__head h2{font-size:1.28rem}
.modal__close{flex:none;width:34px;height:34px;border-radius:var(--r);border:1px solid var(--line);background:#fff;color:var(--muted);
  cursor:pointer;display:grid;place-items:center;transition:border-color .15s,color .15s}
.modal__close:hover{border-color:var(--line-strong);color:var(--ink)}
.modal__close svg{width:18px;height:18px}
.modal__body{padding:14px 24px 4px;color:var(--muted)}
.modal__body p{margin-bottom:10px}
.modal__body p:last-child{margin-bottom:0}
.modal__detail{list-style:none;border:1px solid var(--line);border-radius:var(--r);margin:16px 0}
.modal__detail li{display:flex;justify-content:space-between;gap:14px;padding:12px 14px;border-bottom:1px solid var(--line)}
.modal__detail li:last-child{border-bottom:0}
.modal__detail .k{color:var(--soft);font-size:.9rem}
.modal__detail .v{font-weight:800;color:var(--ink)}
.modal__note{font-size:.85rem;color:var(--soft);background:var(--band);border-radius:var(--r);padding:10px 12px;margin-top:6px}
.modal__foot{display:flex;gap:10px;padding:20px 24px 24px;flex-wrap:wrap}
.modal__foot .btn{flex:1;min-width:130px}
body.modal-open{overflow:hidden}

/* ---------- toasts ---------- */
#toast-region{position:fixed;left:0;right:0;bottom:24px;z-index:120;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none;padding:0 16px}
.toast{pointer-events:auto;display:flex;align-items:center;gap:10px;max-width:380px;width:100%;
  background:var(--ink);color:#fff;border-radius:var(--r);padding:12px 16px;font-size:.94rem;font-weight:600;box-shadow:var(--shadow-modal);
  animation:toastIn .25s cubic-bezier(.22,.7,.2,1) both}
.toast.is-out{animation:toastOut .25s ease forwards}
.toast--success{background:var(--teal-d)}
.toast--warning{background:var(--amber-d)}
.toast--danger{background:var(--warn)}
@keyframes toastIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(14px)}}

/* ---------- mobile bottom nav ---------- */
.bottomnav{display:none}
.bottomnav__more{position:fixed;inset:0;z-index:90;display:none}
.bottomnav__more.is-open{display:block}
.bottomnav__more .modal-overlay{background:rgba(21,24,26,.4)}
.bottomnav__sheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-top-left-radius:var(--r-lg);border-top-right-radius:var(--r-lg);
  padding:12px;padding-bottom:calc(72px + 12px);box-shadow:var(--shadow-modal)}
.bottomnav__sheet .navbtn{font-size:1rem;padding:13px 12px}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .stats{grid-template-columns:repeat(2,1fr);gap:24px 26px}
  .boost-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  .layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .content{border-left:0;padding:24px var(--gut) calc(72px + 28px)}
  /* mobile dashboard: lead with the data-usage ring, push the KPI strip below it */
  #panel-dashboard{display:flex;flex-direction:column}
  #panel-dashboard .panel__head{order:1;margin-bottom:22px}
  #panel-dashboard #dash-usage-block{order:2;margin-top:0}
  #panel-dashboard .stats{order:3;margin-top:38px}
  #panel-dashboard .block:not(#dash-usage-block){order:4}
  .grid--2,.grid--3,.split{grid-template-columns:1fr}
  .split > div + div{border-left:0;border-top:1px solid var(--line)}
  .plan-cards{grid-template-columns:1fr}
  .boost-grid{grid-template-columns:repeat(2,1fr)}
  .demo-banner__text{display:none}
  .bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top:1px solid var(--line);padding:6px 4px;justify-content:space-around}
  .tabbtn{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;min-width:0;font:inherit;font-size:.68rem;font-weight:700;
    color:var(--muted);background:transparent;border:0;padding:7px 2px;cursor:pointer;border-radius:var(--r)}
  .tabbtn svg{width:22px;height:22px}
  .tabbtn[aria-current="page"]{color:var(--teal-d)}
  .modal__foot{flex-direction:column}
  .modal__foot .btn{width:100%}
}
@media (max-width:430px){
  .boost-grid{grid-template-columns:1fr}
  .field-row{flex-direction:column;gap:0}
}
