:root{
  /* KDS tokens */
  --action-primary:#009b1a; --action-primary-press:#007a14;
  --green:#009b1a; --green-tint:#e9f7ec; --green-text:#0b7a23;
  --amber:#b26a00; --amber-strong:#dc8a05; --amber-tint:#fdf3e1;
  --red:#d93838; --red-tint:#fdecec;
  --blue:#2b5fb3; --blue-tint:#eaf1fc;
  --violet:#6b4fb3; --violet-tint:#f1ecfc;
  --ink:#16181d; --text-secondary:#5b616b; --text-tertiary:#8a9099;
  --surface:#ffffff; --surface-tertiary:#f3f6f4; --bg:#eef0f3;
  --line:#eceef1; --line-strong:#e2e5e9;
  --r8:8px; --r10:10px; --r12:12px; --r14:14px; --r999:999px;
  --shadow-card:0 2px 10px -4px rgba(15,23,42,.10);
  --shadow-float:0 18px 50px -12px rgba(15,23,42,.35);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased}
html,body{height:100%}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--ink);
  background:
    radial-gradient(900px 600px at 12% 8%, #e8f5e9 0%, rgba(232,245,233,0) 55%),
    radial-gradient(900px 600px at 88% 92%, #eaf1fc 0%, rgba(234,241,252,0) 55%),
    #e9ecf1;
  min-height:100%;
  display:flex;align-items:center;justify-content:center;
  padding:40px 16px;
}
.stage{display:flex;flex-direction:column;align-items:center;gap:18px}
.stage__title{font-weight:800;font-size:15px;color:#3a3f47;letter-spacing:.2px;opacity:.8}

/* phone */
.phone{
  width:390px;height:844px;background:var(--surface);border-radius:42px;
  box-shadow:var(--shadow-float);position:relative;overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
}
.phone__notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:140px;height:26px;background:#0c0d10;border-radius:0 0 16px 16px;z-index:60}
.screen{position:absolute;inset:0;display:flex;flex-direction:column;background:var(--surface)}
.screen__scroll{flex:1;overflow-y:auto;overflow-x:hidden}
.screen__scroll::-webkit-scrollbar{width:0}

/* type ramp (KDS) */
.t-xl{font-size:24px;font-weight:800;line-height:1.18;letter-spacing:-.4px}
.t-lg{font-size:20px;font-weight:800;line-height:1.2}
.t-md{font-size:16px;font-weight:700;line-height:1.3}
.t-sm{font-size:14px;font-weight:600;line-height:1.35}
.t-xs{font-size:13px;font-weight:600}
.b-md{font-size:14px;font-weight:400;line-height:1.5;color:var(--text-secondary)}
.b-sm{font-size:12.5px;font-weight:400;line-height:1.5;color:var(--text-secondary)}
.b-xs{font-size:11px;font-weight:500;color:var(--text-tertiary)}
.kicker{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-tertiary)}
.muted{color:var(--text-secondary)} .tert{color:var(--text-tertiary)}
.green{color:var(--green)} .amber{color:var(--amber-strong)} .red{color:var(--red)}

/* header (KDS) */
.hdr{height:56px;display:flex;align-items:center;gap:10px;padding:0 14px;border-bottom:1px solid var(--line);flex:0 0 auto;background:var(--surface);z-index:5}
.hdr__back{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.hdr__back:active{background:var(--surface-tertiary)}
.hdr__title{font-size:14px;font-weight:600;color:var(--ink)}
.hdr__logo{font-size:20px;font-weight:800;color:var(--green);letter-spacing:-.5px}

.pad{padding:18px 20px}
.stack{display:flex;flex-direction:column}
.row{display:flex;align-items:center}
.between{justify-content:space-between}
.gap6{gap:6px}.gap8{gap:8px}.gap10{gap:10px}.gap12{gap:12px}.gap14{gap:14px}.gap16{gap:16px}
.grow{flex:1}

/* buttons */
.btn{border:none;border-radius:var(--r12);font-family:inherit;font-weight:700;font-size:15px;cursor:pointer;width:100%;padding:15px;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .08s}
.btn:active{transform:scale(.985)}
.btn--primary{background:var(--action-primary);color:#fff}
.btn--primary:active{background:var(--action-primary-press)}
.btn--secondary{background:#fff;color:var(--ink);border:1.5px solid var(--line-strong)}
.btn--ghost{background:var(--surface-tertiary);color:var(--ink)}
.btn[disabled]{opacity:.45;pointer-events:none}
.link{color:var(--green);font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}

/* tag / pill */
.tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:var(--r999);font-size:10.5px;font-weight:700}
.tag--green{background:var(--green-tint);color:var(--green-text)}
.tag--amber{background:var(--amber-tint);color:var(--amber)}
.tag--red{background:var(--red-tint);color:var(--red)}

/* card */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r14);box-shadow:var(--shadow-card)}
.tile{border-radius:var(--r14);padding:16px}

/* input */
.field{display:flex;flex-direction:column;gap:7px}
.field__label{font-size:12px;font-weight:600;color:var(--ink)}
.input{border:1px solid var(--line-strong);border-radius:var(--r12);padding:13px 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;width:100%}
.input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(0,155,26,.12)}
.radio{display:flex;align-items:center;gap:10px;border:1px solid var(--line-strong);border-radius:var(--r12);padding:13px 14px;cursor:pointer}
.radio--on{border-color:var(--green);background:linear-gradient(0deg,rgba(0,155,26,.05),rgba(0,155,26,.05)),#fff}
.radio__dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--line-strong);flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.radio--on .radio__dot{border-color:var(--green)}
.radio--on .radio__dot::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--green)}
.radio__t{font-size:14px;font-weight:600}

/* tedi */
.tedi{display:flex;gap:10px;align-items:center}
.tedi img{width:48px;height:52px;object-fit:contain;flex:0 0 auto}
.tedi--bubble{background:var(--green-tint);border-radius:var(--r14);padding:11px 14px}
.tedi__txt{font-size:12.5px;font-weight:500;line-height:1.45;color:var(--ink)}

/* tabs */
.tabs{display:flex;gap:6px;background:#f1f3f5;border-radius:var(--r12);padding:4px}
.tab{flex:1;text-align:center;font-size:12.5px;font-weight:600;color:var(--text-secondary);padding:9px 6px;border-radius:9px;cursor:pointer;position:relative;z-index:1}
.tab--on{color:#fff}
.tabs__ind{position:absolute;border-radius:9px;background:var(--ink);z-index:0;top:4px;bottom:4px}

/* gauge */
.gaugewrap{display:flex;justify-content:center;align-items:center;position:relative}
.gauge__num{position:absolute;display:flex;flex-direction:column;align-items:center}
.gauge__val{font-size:46px;font-weight:800;letter-spacing:-1px;line-height:1}
.gauge__sub{font-size:11px;font-weight:600;color:var(--text-tertiary);margin-top:2px}

/* bar */
.track{height:7px;border-radius:5px;background:#eceef1;overflow:hidden}
.fill{height:100%;border-radius:5px}

/* list rows */
.lrow{display:flex;align-items:center;gap:12px;padding:13px 14px}
.lrow + .lrow{border-top:1px solid var(--line)}
.dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.ic svg,.statusic svg{width:18px;height:18px;fill:none;stroke-width:2}

/* impact glyph */
.impact{display:flex;align-items:flex-end;gap:3px;height:16px}
.impact i{width:4px;border-radius:2px;background:#dfe3e7}
.impact i.on{background:var(--green)}

/* feature table */
.frow{display:flex;align-items:center;gap:8px;padding:13px 14px}
.frow + .frow{border-top:1px solid var(--line)}
.statusic{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 auto}

/* footer dock */
.dock{flex:0 0 auto;padding:14px 20px 22px;background:linear-gradient(0deg,#fff 70%,rgba(255,255,255,0));border-top:1px solid var(--line)}

/* misc */
.divider{height:1px;background:var(--line)}
.center{display:flex;flex-direction:column;align-items:center;text-align:center}
.restart{margin-top:14px;font-size:12px;color:#3a3f47;opacity:.7;cursor:pointer;text-decoration:underline}
.seg{display:flex;height:24px;border-radius:8px;overflow:hidden}
.pillrow{display:flex;align-items:center;gap:8px}
.pillv{padding:5px 10px;border-radius:var(--r999);font-size:12px;font-weight:700}

/* stepper */
.steps{display:flex;gap:5px;padding:12px 20px 4px}
.steps i{flex:1;height:4px;border-radius:3px;background:#e6e9ed;overflow:hidden}
.steps i b{display:block;height:100%;background:var(--green);border-radius:3px}
.steplabel{font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--text-tertiary);padding:0 20px 2px}

/* checkbox */
.cbx{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line-strong);display:flex;align-items:center;justify-content:center;flex:0 0 auto;cursor:pointer;transition:background .12s}
.cbx--on{background:var(--green);border-color:var(--green)}
.cbx svg{width:13px;height:13px;stroke:#fff;stroke-width:3;fill:none}

/* alert (KDS) */
.alert{display:flex;gap:10px;border-radius:var(--r12);padding:13px 14px}
.alert--error{background:var(--red-tint)}
.alert__ic{width:22px;height:22px;flex:0 0 auto}

/* plan card */
.plan{padding:16px;border-radius:var(--r14)}
.plan__spec{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-secondary);padding:5px 0}
.plan__spec b{color:var(--ink);font-weight:600}
.chiprow{display:flex;flex-wrap:wrap;gap:6px}
.chip2{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:var(--r999);background:var(--green-tint);color:var(--green-text)}
.editlink{font-size:12px;font-weight:700;color:var(--green);cursor:pointer}

/* segmented 2-way toggle (who's covered) */
.seg2toggle{display:flex;background:#e9ecef;border-radius:var(--r12);padding:4px}
.seg2tab{flex:1;text-align:center;font-size:14px;font-weight:600;color:var(--text-secondary);padding:11px 8px;border-radius:9px;cursor:pointer;position:relative}
.seg2tab.on{color:var(--ink)}
.seg2pill{position:absolute;inset:0;background:#fff;border-radius:9px;box-shadow:0 1px 4px rgba(15,23,42,.12);z-index:0}
