/* ============================================================================
   VANGUARD CUSTOMER PORTAL (MVP Prototype 2.0) — STYLES
   Brand tokens + components lifted from outputs/brand-sample.html (the signed-off
   styling foundation). Navy primary · sky-teal secondary · red = LOGO ONLY ·
   Plus Jakarta Sans · comfortable/airy. The feel, above everything: EASY.
   Why plain CSS variables (not the production token architecture): prototype,
   not production (ADR-0002 / docs/ui-ux.md). Koda rebuilds tokens for real.
   ============================================================================ */

/* ── BRAND TOKENS ─────────────────────────────────────────────────────────── */
:root{
  --navy:#004674; --navy-800:#003A60; --navy-50:#EBF3FA;
  --teal:#6FBED9;            /* brand secondary — sky teal */
  --teal-dark:#1F6F8F;       /* darker sky-teal for text/borders on white */
  --teal-50:#EAF6FB;
  --red:#ED2124;             /* LOGO ONLY — never a UI action */
  --error:#DC2626;
  --ink:#0F172A; --muted:#475569; --faint:#94A3B8;
  --line:#E2E8F0; --chrome:#F1F5F9; --canvas:#FFFFFF; --thead:#F8FAFC;
  --asphalt:#c8c8c8;          /* speed-calmer diagram backdrop (matches the reference configurator) */
  --ok-bg:#F0FDF4; --ok-bd:#BBF7D0; --ok-tx:#15803D;
  --warn-bg:#FFFBEB; --warn-bd:#FDE68A; --warn-tx:#B45309;
  --info-bg:#EFF6FF; --info-bd:#BFDBFE; --info-tx:#1D4ED8;
  --neu-bg:#F8FAFC; --neu-bd:#E2E8F0; --neu-tx:#475569;
  --err-bg:#FEF2F2; --err-bd:#FECACA; --err-tx:#B91C1C;
  /* Radius grammar: interactive · structural · overlay. Bumped for the 2.0
     look-&-feel refresh — softly rounded (not square, not pill), matching Oliver's
     CTA reference screenshots. */
  --ri:3px; --rs:5px; --ro:6px;   /* Option B — slight rounding (matches the documented radius grammar) */
  --shadow-sm:0 1px 3px rgba(0,0,0,.04);
  --shadow-pop:0 8px 28px rgba(15,23,42,.16);
  --shadow-lift:0 10px 24px rgba(31,111,143,.18);   /* teal-tinted "lift" on hover for clickable cards */
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--ink);background:var(--chrome);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.hidden{display:none !important}
.muted{color:var(--muted)}
.tabnum{font-variant-numeric:tabular-nums}
/* Lucide inline icons (ADR-0006): align to text; flex containers centre them via align-items. */
.li{display:inline-block;vertical-align:-.14em;flex-shrink:0}
button .li,a .li{pointer-events:none}
.dot-online{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ok-tx);margin-right:6px;vertical-align:middle}

/* ── DEMO TOOLBAR (testing device — NOT part of the product) ──────────────────
   The "view as role / switch test user" switcher. Dark strip so it reads as a
   scaffold, not portal chrome. Pairs with "no real auth" (ADR-0002). */
.demobar{background:#fff;color:var(--muted);display:flex;align-items:center;gap:12px;padding:8px 16px;font-size:12px;flex-wrap:wrap;border-top:1px solid var(--line);box-shadow:0 -2px 10px rgba(15,23,42,.06);z-index:40}
.demobar .tag{font-weight:700;letter-spacing:.03em;text-transform:uppercase;font-size:10.5px;color:var(--muted);display:flex;align-items:center;gap:6px}
.demobar .tag .blink{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(111,190,217,.3)}
.demobar label{color:var(--muted);font-size:11px;font-weight:600;margin:0}
.demobar select{font:inherit;font-size:12px;font-weight:600;background:#fff;color:var(--navy);border:1px solid var(--teal);border-radius:var(--ri);padding:5px 9px;cursor:pointer;max-width:320px}
/* persona picker becomes a searchable combo (19 users) — style its input to match */
.demobar .combo{display:inline-block;width:auto;position:relative}
.demobar .combo-input{font:inherit;font-size:12px;font-weight:600;background:#fff;color:var(--navy);border:1px solid var(--teal);border-radius:var(--ri);padding:5px 26px 5px 9px;cursor:text;min-width:260px;max-width:320px;margin:0}
.demobar .combo-caret{color:var(--teal)}
.demobar .spacer{flex:1}
.demobar .demo-meta{color:var(--navy);font-weight:600}
.demobar .demo-link{color:var(--navy);border-bottom:1px solid var(--teal);cursor:pointer;font-weight:700}
.demobar .demo-link:hover{border-color:var(--navy)}

/* ── BUTTONS ──────────────────────────────────────────────────────────────── */
.btn{font:inherit;font-weight:600;border-radius:var(--ri);padding:10px 18px;cursor:pointer;border:1.5px solid transparent;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .1s ease}
.btn:disabled{opacity:.5;cursor:not-allowed}
/* Vanguard double-chevron signature — only on the prominent full-width primary
   CTAs (refs: Rounded CTA 1/2.png) so it stays special; not on small card buttons
   or modal confirm buttons. The inline "→" was stripped from these in app.js. */
.btn-primary.btn-block::after{content:"»";font-weight:800;font-size:1.1em;line-height:1}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--navy-800)}
.btn-secondary{background:#fff;color:var(--teal-dark);border-color:var(--teal)}
.btn-secondary:hover:not(:disabled){background:var(--teal-50)}
.btn-ghost{background:#fff;color:var(--muted);border-color:var(--line)}
.btn-ghost:hover:not(:disabled){background:var(--chrome);color:var(--ink)}
.btn-danger{background:#fff;color:var(--error);border-color:var(--err-bd)}
.btn-danger:hover:not(:disabled){background:var(--err-bg)}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-block{width:100%}

/* ── BADGES ───────────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;border-radius:100px;padding:3px 10px;border:1px solid;white-space:nowrap}
.badge.ok{background:var(--ok-bg);border-color:var(--ok-bd);color:var(--ok-tx)}
.badge.info{background:var(--info-bg);border-color:var(--info-bd);color:var(--info-tx)}
.badge.neu{background:var(--neu-bg);border-color:var(--neu-bd);color:var(--neu-tx)}
.badge.warn{background:var(--warn-bg);border-color:var(--warn-bd);color:var(--warn-tx)}
.badge.err{background:var(--err-bg);border-color:var(--err-bd);color:var(--err-tx)}

/* ── LOGO WORDMARK (placeholder until the real Vanguard logo asset is embedded) */
.logo{font-weight:800;font-size:22px;color:var(--navy);letter-spacing:-.01em;cursor:pointer;display:flex;align-items:center}
.logo .dot{color:var(--red)}
.logo-img{height:30px;width:auto;display:block}
.auth-card .logo-img{height:42px;margin-bottom:2px}

/* ── AUTH ZONE (centred card; login / sign-up / onboarding) ──────────────────*/
.auth-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:40px}
.auth-card{background:var(--canvas);border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);width:100%;max-width:420px;padding:40px 36px}
.auth-card h1{font-size:20px;font-weight:700;margin:26px 0 6px;letter-spacing:-.02em}
.auth-card p.sub{color:var(--muted);font-size:14px;margin-bottom:24px}
.auth-foot{margin-top:20px;text-align:center;font-size:13px;color:var(--muted)}
.tlink{color:var(--teal-dark);font-weight:600;border-bottom:2px solid var(--teal);cursor:pointer}

/* ── FORMS ────────────────────────────────────────────────────────────────── */
label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field{width:100%;font:inherit;font-size:14px;padding:11px 13px;border:1px solid var(--line);border-radius:var(--ri);margin-bottom:18px;outline:none;background:#fff;color:var(--ink)}
.field:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,70,116,.12)}

/* ── SEARCHABLE COMBO BOXES (every dropdown is type-to-search; Oliver) ─────────
   The native <select> is hidden (keeps value + onchange); a search input + a
   body-mounted floating popup overlay it. Wrapper inherits the select's class/
   style for layout; the field "look" lives on the input. */
.combo{position:relative;display:block}
.combo > select{display:none !important}
.combo.field{border:0;padding:0;background:none;box-shadow:none}   /* keep .field margin/width; drop its border (it's on the input) */
.combo-input{width:100%;padding-right:30px;cursor:text}
.combo-input.field{margin:0}
.combo-caret{position:absolute;right:11px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--faint);cursor:pointer}
.combo-pop{position:fixed;z-index:200;background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-pop);max-height:240px;overflow:auto;padding:4px}
.combo-opt{padding:8px 11px;font-size:13px;border-radius:var(--ri);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.combo-opt:hover,.combo-opt.active{background:var(--navy-50)}
.combo-opt.sel{font-weight:700;color:var(--navy)}
.combo-grp{padding:8px 11px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--faint)}
.combo-empty{padding:9px 11px;font-size:12px;color:var(--muted)}

/* ── APP SHELL (top bar + left menu + main) ──────────────────────────────────*/
.shell{display:grid;grid-template-columns:248px 1fr;grid-template-rows:60px 1fr;min-height:100%;height:100%}
.topbar{grid-column:1/3;background:var(--canvas);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 22px;height:60px;gap:16px}
.topbar .spacer{flex:1}

/* basket */
.basket{position:relative;color:var(--navy);font-size:13px;font-weight:600;border:1px solid var(--line);border-radius:var(--ri);padding:8px 14px;background:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.basket:hover{border-color:var(--teal);background:var(--teal-50)}
.basket svg{width:19px;height:19px;flex-shrink:0}
.basket .count{position:absolute;top:-8px;right:-8px;background:var(--teal-dark);color:#fff;border-radius:100px;font-size:10px;font-weight:700;padding:1px 6px;min-width:18px;text-align:center}
.basket .count.zero{display:none}

/* ── MESSAGES & ALERTS (top-bar bell + dropdown) ──────────────────────────── */
.alertbell{position:relative}
.bell{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--ri);width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;color:var(--navy);cursor:pointer}
.bell:hover{border-color:var(--teal);background:var(--teal-50)}
.bell svg{width:19px;height:19px}
.bell-count{position:absolute;top:-7px;right:-7px;background:var(--teal-dark);color:#fff;border-radius:100px;font-size:10px;font-weight:700;padding:1px 5px;min-width:17px;text-align:center;line-height:1.4}
.alerts-menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--line);border-radius:var(--ro);box-shadow:var(--shadow-pop);width:370px;max-width:calc(100vw - 36px);z-index:60;overflow:hidden}
.alerts-head{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px}
.alerts-readall{font-size:12px;font-weight:600;color:var(--teal-dark);cursor:pointer}
.alerts-readall:hover{text-decoration:underline}
.alerts-list{max-height:440px;overflow:auto}
.alert-item{display:flex;gap:12px;align-items:flex-start;padding:12px 16px;border-bottom:1px solid var(--line);cursor:pointer}
.alert-item:last-child{border-bottom:none}
.alert-item:hover{background:var(--chrome)}
.alert-item.unread{background:var(--navy-50)}
.alert-ic{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--neu-bg);color:var(--muted)}
.alert-ic svg{width:16px;height:16px}
.alert-ic.order{background:var(--info-bg);color:var(--info-tx)}
.alert-ic.quote{background:var(--teal-50);color:var(--teal-dark)}
.alert-ic.approval{background:var(--warn-bg);color:var(--warn-tx)}
.alert-body{flex:1;min-width:0}
.alert-title{font-size:13px;font-weight:700;line-height:1.3;color:var(--ink)}
.alert-sub{font-size:12px;color:var(--muted);line-height:1.45;margin-top:2px}
.alert-time{font-size:11px;color:var(--faint);margin-top:5px}
.alert-dot{width:8px;height:8px;border-radius:50%;background:var(--teal-dark);flex-shrink:0;margin-top:6px}
.alerts-empty{padding:34px 16px;text-align:center;color:var(--muted);font-size:13px}
.alerts-empty .big{font-size:28px;opacity:.4;margin-bottom:8px}

/* account chip + dropdown */
.acct{position:relative}
.chip{display:flex;align-items:center;gap:9px;background:var(--navy-50);border-radius:100px;padding:5px 12px 5px 14px;font-size:13px;font-weight:600;color:var(--navy);cursor:pointer;border:1px solid transparent}
.chip:hover{border-color:var(--teal)}
.chip .caret{font-size:10px;opacity:.7}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--line);border-radius:var(--ro);box-shadow:var(--shadow-pop);min-width:230px;padding:6px;z-index:60}
.menu .mhead{padding:10px 12px 8px;border-bottom:1px solid var(--line);margin-bottom:6px}
.menu .mhead .nm{font-weight:700;color:var(--ink)}
.menu .mhead .sub{font-size:12px;color:var(--muted);margin-top:2px}
.menu .mitem{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--ri);font-size:13px;font-weight:500;color:#334155;cursor:pointer}
.menu .mitem:hover{background:var(--chrome)}
.menu .mitem .ic{width:16px;text-align:center;color:var(--muted)}
.menu .mitem.danger{color:var(--error)}
.menu .msep{height:1px;background:var(--line);margin:6px 0}

/* sidebar / left menu */
.sidebar{background:var(--chrome);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:3px;overflow:auto}
.navitem{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--ri);color:#334155;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .12s ease}
.navitem:hover{background:#fff}
.navitem.active{color:var(--navy);font-weight:700;background:#fff}
/* bigger, "designed" line icons — reserved for the left nav (Oliver: icons live here only) */
.navitem .ic{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;color:var(--teal-dark);flex-shrink:0}
.navitem .ic svg{width:21px;height:21px}
.navitem.active .ic{color:var(--navy)}
.navitem .pill{margin-left:auto;background:var(--navy-50);color:var(--navy);font-size:10px;font-weight:700;border-radius:100px;padding:1px 7px}
/* Expandable Quotes/Orders groups: parent keeps the nav look; the active section
   shows a chevron rotated open + indented sub-items beneath it (Oliver). */
.navparent .navchev{margin-left:auto;color:var(--faint);transition:transform .15s ease;flex-shrink:0}
.navparent.open{color:var(--navy);font-weight:700}
.navparent.open .ic,.navparent.open .navchev{color:var(--navy)}
.navparent.open .navchev{transform:rotate(90deg)}
.navsub{display:flex;flex-direction:column;gap:2px;margin:2px 0 6px}
.navsubitem{display:flex;align-items:center;gap:8px;padding:8px 12px 8px 48px;border-radius:var(--ri);color:#475569;font-size:12.5px;font-weight:600;cursor:pointer;transition:background .12s ease}
.navsubitem:hover{background:#fff}
.navsubitem.active{color:var(--navy);background:#fff}
.navsubitem .pill{margin-left:auto;background:var(--navy-50);color:var(--navy);font-size:10px;font-weight:700;border-radius:100px;padding:1px 7px}
.nav-sectn{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:14px 12px 6px}
.nav-spacer{flex:1}
/* sidebar profile summary (top of nav) — a Portal 1.0 element, re-skinned navy/teal */
.side-profile{background:var(--navy);color:#fff;border-radius:var(--rs);padding:18px 14px;margin-bottom:14px;text-align:center}
.side-profile .spav{width:50px;height:50px;border-radius:50%;background:var(--teal);color:var(--navy-800);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.side-profile .spnm{font-weight:700;font-size:14px;line-height:1.3}
.side-profile .spco{font-size:12px;color:rgba(255,255,255,.82);margin-top:3px}
.side-profile .spac{font-size:11px;color:rgba(255,255,255,.6);margin-top:2px}
/* sidebar help card (bottom of nav) — live chat (primary) + account manager (secondary) */
.side-help{background:#fff;border:1px solid var(--line);border-radius:var(--rs);padding:14px;margin-top:8px;box-shadow:var(--shadow-sm)}
.side-help .eyebrow{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--teal-dark);margin-bottom:6px}
.side-help p{font-size:12px;color:var(--muted);line-height:1.45;margin-bottom:10px}
.side-help .btn{width:100%;font-size:12.5px;padding:10px;white-space:normal;line-height:1.3;height:auto;text-align:center}
.side-help .am{font-size:11.5px;color:var(--muted);margin-top:11px;line-height:1.55;border-top:1px solid var(--line);padding-top:10px}
.side-help .am b{color:var(--ink)}
.side-help .am a{color:var(--teal-dark);font-weight:700;word-break:break-word}

/* main content */
.main{background:var(--canvas);padding:30px 36px;overflow:auto}
.main h1{font-size:21px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}
.main .lede{color:var(--muted);font-size:14px;margin-bottom:26px}
.section-h{font-size:15px;font-weight:700;margin:30px 0 14px;display:flex;align-items:center;justify-content:space-between}
.section-h a.more{font-size:13px;font-weight:600;color:var(--teal-dark);cursor:pointer}

/* ── CARDS / METRICS ──────────────────────────────────────────────────────── */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--canvas);border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);padding:18px 20px}
.card.click{cursor:pointer;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}
.card.click:hover{border-color:var(--teal);box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.card .k{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:8px}
.card .v{font-size:26px;font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums}
.card .meta{font-size:12px;color:var(--muted);margin-top:4px}

/* ── DASHBOARD (Pass 2 refresh) — metric cards · order cards · favourite minis ──
   Modelled on Portal 1.0 (Reference files/Portal 1.0 dashboard .png), re-skinned to
   2.0 navy/teal: big count + caps label + a link cue, with a teal left-accent. */
.card.metric{border-left:4px solid var(--teal);display:flex;flex-direction:column}
.card.metric .m-v{font-size:30px;font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums;line-height:1}
.card.metric .m-k{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:7px}
.card.metric .m-link{font-size:12.5px;font-weight:700;color:var(--teal-dark);margin-top:12px}
.card.metric:hover .m-link{text-decoration:underline}

/* recent-order cards (replaces the dashboard table — Oliver: cards, not listing lines) */
.order-cards{display:flex;flex-direction:column;gap:12px}
.order-card{background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);padding:16px 18px;cursor:pointer;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}
.order-card:hover{border-color:var(--teal);box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.order-card .oc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.order-card .oc-title{font-size:15px;font-weight:700;color:var(--navy);line-height:1.3}
.order-card .oc-meta{font-size:12px;color:var(--muted);margin-top:5px}
.order-card .oc-bot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.order-card .oc-price{font-size:18px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums}
.order-card .oc-price small{font-size:11px;font-weight:600;color:var(--muted)}
.order-card .oc-actions{display:flex;gap:8px;flex-shrink:0}

/* favourite "mini" cards (dashboard preview — click through to the product) */
.fav-minis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.fav-mini{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);padding:12px 14px;cursor:pointer;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}
.fav-mini:hover{border-color:var(--teal);box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.fav-mini .fm-thumb{width:48px;height:48px;border-radius:var(--ri);background:var(--chrome);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.fav-mini .fm-thumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.fav-mini .fm-thumb .ph{color:var(--faint)}
.fav-mini .fm-info{flex:1;min-width:0}
.fav-mini .fm-nm{font-size:13px;font-weight:700;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fav-mini .fm-code{font-size:11px;color:var(--muted);font-weight:600;margin-top:2px}

/* ── TABLES ───────────────────────────────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--rs);overflow:hidden;font-size:13px;background:#fff}
.tbl th{background:var(--thead);text-align:left;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:11px 14px}
.tbl th.num{text-align:right}   /* numeric headers (Qty/Unit/Line) line up over their right-aligned values */
.tbl td{padding:12px 14px;border-top:1px solid var(--line);vertical-align:middle}
.tbl tr.click{cursor:pointer}
.tbl tr.click:hover td{background:var(--navy-50)}
.tbl td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.tbl .code{color:var(--muted);font-size:12px}
.tbl td.cimg,.tbl th.cimg{width:46px;padding-right:4px}   /* image column: no header, tight */
.tbl td.iname{font-weight:600;color:var(--ink)}           /* product name = primary column */

/* ── EMPTY STATE ──────────────────────────────────────────────────────────── */
.empty{border:1px dashed var(--line);border-radius:var(--rs);background:var(--neu-bg);padding:42px 28px;text-align:center;color:var(--muted)}
.empty .big{font-size:30px;margin-bottom:10px;opacity:.5}
.empty h3{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px}
.empty p{font-size:13px;margin-bottom:16px}

/* ── STUB (placeholder for screens built in later milestones) ─────────────── */
.stub{border:1px dashed var(--teal);background:var(--teal-50);border-radius:var(--rs);padding:34px 28px;color:var(--teal-dark)}
.stub h3{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:8px}
.stub p{font-size:13px;color:var(--muted);max-width:560px}
.stub .ms{display:inline-block;margin-top:14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:#fff;border:1px solid var(--teal);color:var(--teal-dark);border-radius:100px;padding:4px 11px}

/* ── ASK A QUESTION — navy icon-only chat launcher (HubSpot style) ──────────── */
.chat{position:fixed;right:26px;bottom:54px;width:58px;height:58px;background:var(--navy);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.22);cursor:pointer;z-index:50;border:none}
.chat:hover{background:var(--navy-800)}
.chat svg{width:27px;height:27px}

/* ── "Ask a question" LIVE CHAT widget (HubSpot-style) ────────────────────── */
.chatpanel{position:fixed;right:26px;bottom:124px;width:362px;max-width:calc(100vw - 36px);height:478px;max-height:calc(100vh - 130px);background:#fff;border-radius:14px;box-shadow:0 14px 44px rgba(15,23,42,.30);display:flex;flex-direction:column;overflow:hidden;z-index:56;animation:chatin .18s ease-out}
@keyframes chatin{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.chat-head{background:var(--navy);color:#fff;padding:14px 16px;display:flex;align-items:center;gap:11px}
.chat-avs{display:flex}
.chat-avs .cav{width:30px;height:30px;border-radius:50%;background:var(--teal);color:var(--navy-800);font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center;border:2px solid var(--navy);margin-left:-9px}
.chat-avs .cav:first-child{margin-left:0}
.chat-meta{flex:1;min-width:0}
.chat-names{font-weight:700;font-size:14px}
.chat-status{font-size:11px;color:rgba(255,255,255,.78)}
.chat-x{background:none;border:none;color:#fff;font-size:17px;cursor:pointer;opacity:.85;line-height:1}
.chat-x:hover{opacity:1}
.chat-body{flex:1;overflow:auto;padding:16px;background:var(--chrome);display:flex;flex-direction:column;gap:10px}
.cmsg{display:flex;gap:8px;align-items:flex-end;max-width:86%}
.cmsg.agent{align-self:flex-start}
.cmsg.user{align-self:flex-end;flex-direction:row-reverse}
.cmsg .cav{width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cbub{padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.45;white-space:pre-line}
.cmsg.agent .cbub{background:#fff;border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}
.cmsg.user .cbub{background:var(--navy);color:#fff;border-bottom-right-radius:4px}
.chat-input{display:flex;align-items:center;gap:8px;padding:12px;border-top:1px solid var(--line);background:#fff}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:100px;padding:10px 16px;font:inherit;font-size:13px;outline:none}
.chat-input input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,70,116,.1)}
.chat-send{width:38px;height:38px;border-radius:50%;background:var(--navy);color:#fff;border:none;cursor:pointer;font-size:14px;flex-shrink:0}
.chat-send:hover{background:var(--navy-800)}

/* ── PRODUCT ENQUIRY modal (centred; message + attachments) ───────────────── */
.enq-prod{display:flex;align-items:center;gap:12px;background:var(--neu-bg);border:1px solid var(--line);border-radius:var(--rs);padding:10px 12px;margin-bottom:14px}
.enq-prod .qthumb{width:46px;height:46px;border-radius:var(--ri);background:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.enq-prod .qthumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.enq-prod .qthumb .ph{color:var(--faint)}
.enq-prod .qnm{font-size:13px;font-weight:700}
.enq-prod .qcode{font-size:11px;color:var(--muted);font-weight:600}
.enq-from{font-size:12px;color:var(--muted);margin-bottom:14px}
.enq-drop{display:flex;align-items:center;justify-content:center;gap:8px;border:1.5px dashed var(--teal);border-radius:var(--rs);padding:16px;color:var(--teal-dark);font-weight:600;font-size:13px;cursor:pointer;background:var(--teal-50)}
.enq-drop:hover{background:#fff}
.enq-drop input{display:none}
.enq-files{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.enq-file{font-size:12px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:4px 10px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.enq-file b{cursor:pointer;color:var(--faint);font-weight:700}
.enq-file b:hover{color:var(--error)}

/* ── TOAST + SPINNER (feels-real feedback) ───────────────────────────────────*/
#toast-host{position:fixed;left:50%;bottom:58px;transform:translateX(-50%);display:flex;flex-direction:column;gap:8px;z-index:90;align-items:center}
.toast{background:var(--navy-800);color:#fff;font-size:13px;font-weight:600;padding:11px 18px;border-radius:var(--ro);box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:9px;animation:toastin .18s ease-out}
.toast.err{background:var(--error)}
@keyframes toastin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.spinner{width:34px;height:34px;border:3px solid var(--navy-50);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.spinner{animation-duration:1.6s}.toast{animation:none}}

/* ── APP ROOT LAYOUT ──────────────────────────────────────────────────────── */
#app{height:100%}
.appframe{display:flex;flex-direction:column;height:100vh}
.appframe .demobar{flex-shrink:0}
.appframe .view{flex:1;min-height:0}

/* ============================================================================
   MILESTONE 2 — BUY-FLOW (Browse list · product detail · fixings · Quote panel)
   Browse is a LISTING of rows (not a content page) per Oliver: small thumbnail
   "enough to see what it is", code · name · price · stock · qty · Add. Rich
   content pages are the future unified website, not the MVP.
   ============================================================================ */

/* layout: category rail + results */
.browse{display:grid;grid-template-columns:220px 1fr;gap:28px;align-items:start}
.catnav{font-size:13px;position:sticky;top:0}
.catnav .cat{padding:9px 11px;border-radius:var(--ri);cursor:pointer;color:#334155;font-weight:500}
.catnav .cat:hover{background:#fff}
.catnav .cat.active{background:var(--navy-50);color:var(--navy);font-weight:700}
.catnav .cat .n{float:right;color:var(--faint);font-weight:600}
.catnav .cat.active .n{color:var(--navy)}
.catnav .cat .allflag{font-weight:600;font-size:12px;color:var(--muted)}
/* child subcategories under the active parent (parent → child) */
.catnav .subnav{margin:1px 0 6px 0;display:flex;flex-direction:column;gap:1px}
.catnav .subcat{padding:6px 11px;border-radius:var(--ri);cursor:pointer;color:var(--muted);font-size:12px;font-weight:500}
.catnav .subcat:hover{background:#fff;color:var(--ink)}
.catnav .subcat.active{background:var(--navy-50);color:var(--navy);font-weight:700}
.catnav .subcat .n{float:right;color:var(--faint);font-weight:600}
/* subcategory group headings in the product list */
.subhead{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:20px 0 8px;display:flex;align-items:center;justify-content:space-between}
.subhead:first-child{margin-top:8px}
.subhead span{color:var(--faint);font-weight:600}
.searchwrap{position:relative;margin-bottom:8px}
.search{width:100%;font:inherit;font-size:14px;padding:11px 14px 11px 38px;border:1px solid var(--line);border-radius:var(--ri);outline:none;background:#fff}
.search:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,70,116,.12)}
.searchwrap .si{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--faint)}
.resmeta{font-size:12px;color:var(--muted);margin:4px 2px 14px}

/* product rows */
.plist{display:flex;flex-direction:column;gap:10px}
.prow{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--rs);padding:12px 16px;box-shadow:var(--shadow-sm)}
.prow:hover{border-color:var(--teal)}
.prow .thumb{width:60px;height:60px;border-radius:var(--ri);background:var(--chrome);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}
.prow .thumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.prow .thumb .ph{color:var(--faint);font-size:20px}
.prow .pinfo{flex:1;min-width:0;cursor:pointer}
.prow .pinfo .code{font-size:11px;color:var(--muted);font-weight:600}
.prow .pinfo .nm{font-size:14px;font-weight:700;line-height:1.3;margin:1px 0 2px}
.prow .pinfo .nm:hover{color:var(--navy)}
.prow .pinfo .ds{font-size:12px;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.prow .pmid{width:128px;flex-shrink:0;text-align:right}
.prow .price{font-size:15px;font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums;white-space:nowrap}
.prow .price small{font-weight:600;color:var(--muted);font-size:11px}
.prow .price.enq{color:var(--teal-dark);font-size:13px;font-weight:700}
.prow .price.locked{color:var(--faint);font-size:12px;font-weight:600}
.prow .pstock{margin-top:5px}
.prow .pact{width:184px;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:8px}

/* favourite star */
.fav{background:none;border:none;cursor:pointer;color:var(--faint);font-size:18px;line-height:1;padding:4px;flex-shrink:0}
.fav:hover{color:var(--teal-dark)}
.fav.on{color:var(--teal-dark)}

/* quantity stepper */
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--ri);overflow:hidden;background:#fff}
.qty button{width:30px;height:34px;border:none;background:#fff;color:var(--navy);font-size:16px;font-weight:700;cursor:pointer}
.qty button:hover{background:var(--navy-50)}
.qty input{width:46px;height:34px;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font:inherit;font-weight:700;font-size:13px;color:var(--ink);outline:none;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.qty.lg input{width:64px;height:42px}
.qty.lg button{height:42px;width:38px}
.unitnote{font-size:11px;color:var(--faint);text-align:right}

/* PRODUCT DETAIL (lightweight, functional — not a content page) */
.crumbs{font-size:12px;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--teal-dark);font-weight:600;cursor:pointer}
.pdetail{display:grid;grid-template-columns:340px 1fr;gap:36px;align-items:start}
.pdetail .pimg{background:var(--chrome);border:1px solid var(--line);border-radius:var(--rs);height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pdetail .pimg img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.pdetail .pimg .ph{color:var(--faint);font-size:40px}
.pdetail h1{font-size:22px;margin-bottom:6px}
.pdetail .dcode{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:14px}
.pdetail .ddesc{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:20px;max-width:620px}
.pdetail .dprice{font-size:26px;font-weight:800;color:var(--navy);margin-bottom:4px;font-variant-numeric:tabular-nums}
.pdetail .dprice small{font-size:13px;color:var(--muted);font-weight:600}
.pdetail .dbuy{display:flex;align-items:center;gap:14px;margin:22px 0;flex-wrap:wrap}
.specs{border-top:1px solid var(--line);margin-top:8px;padding-top:18px;font-size:13px;max-width:520px}
.specs .srow{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line)}
.specs .srow .k{color:var(--muted)}
.specs .srow .v{font-weight:600}

/* ── RIGHT SLIDE-OUT QUOTE PANEL (the cart) ───────────────────────────────── */
.qbackdrop{position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:95;opacity:0;visibility:hidden;transition:opacity .2s}
.qbackdrop.open{opacity:1;visibility:visible}
.qpanel{position:fixed;top:0;right:0;bottom:0;width:430px;max-width:92vw;background:#fff;z-index:100;box-shadow:-8px 0 28px rgba(15,23,42,.18);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .22s ease-out}
.qpanel.open{transform:translateX(0)}
@media (prefers-reduced-motion:reduce){.qpanel,.qbackdrop{transition:none}}
.qhead{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid var(--line)}
.qhead h2{font-size:16px;font-weight:700}
.qhead .qcount{background:var(--navy-50);color:var(--navy);font-size:12px;font-weight:700;border-radius:100px;padding:2px 9px}
.qhead .x{margin-left:auto;background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer;line-height:1}
.qhead .x:hover{color:var(--ink)}
.qlines{flex:1;overflow:auto;padding:8px 20px}
.qline{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.qline .qthumb{width:46px;height:46px;border-radius:var(--ri);background:var(--chrome);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.qline .qthumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.qline .qthumb .ph{color:var(--faint);font-size:14px}
.qline .qmid{flex:1;min-width:0}
.qline .qnm{font-size:13px;font-weight:700;line-height:1.3}
.qline .qcode{font-size:11px;color:var(--muted);font-weight:600}
.qline .qctl{display:flex;align-items:center;gap:10px;margin-top:8px}
.qline .qremove{background:none;border:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;text-decoration:underline}
.qline .qremove:hover{color:var(--error)}
.qline .qlt{font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums;white-space:nowrap}
/* configured set in the cart (heading + parts + edit/remove) */
.qgroup{border:1px solid var(--teal);border-radius:var(--rs);background:var(--teal-50);padding:6px 10px 10px;margin:10px 0}
.qgroup-head{padding:6px 4px 4px}
.qg-label{font-size:13px;font-weight:800;color:var(--navy)}
.qg-sub{font-size:11px;color:var(--muted);font-weight:600}
.qg-actions{display:flex;gap:8px;padding:0 4px 6px}
.qg-btn{background:#fff;border:1px solid var(--teal);color:var(--teal-dark);border-radius:var(--ri);font:inherit;font-size:11px;font-weight:700;padding:5px 9px;cursor:pointer}
.qg-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.qg-btn.rm{border-color:var(--line);color:var(--muted)}
.qg-btn.rm:hover{background:var(--error);border-color:var(--error);color:#fff}
.qline.qgl{background:#fff;border:1px solid var(--line);border-radius:var(--ri);padding:8px 10px;margin:6px 0 0;border-bottom:1px solid var(--line)}
.qline.qgl .qthumb{width:38px;height:38px}
.qline.fix{padding:10px 0 10px 58px;border-bottom:1px dashed var(--line)}
.qline.fix .qnm{font-weight:600;font-size:12px;color:var(--muted)}
.qline.fix .ficon{color:var(--teal-dark);font-weight:700;margin-right:4px}
.qline .qfix-for{font-size:11px;color:var(--faint);margin-top:3px}   /* "↳ Fixings for X" caption on the (now full-line) fixing row */
.qsum{padding:16px 20px;border-top:1px solid var(--line);background:var(--neu-bg)}
.qsum .row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--muted)}
.qsum .row.tot{font-size:16px;font-weight:800;color:var(--ink);border-top:1px solid var(--line);margin-top:8px;padding-top:12px}
.qsum .row .v{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink)}
.qsum .row.tot .v{color:var(--navy)}
.qsum .frnote{font-size:11px;color:var(--faint);margin-top:6px;text-align:right}
.qfoot{padding:16px 20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.qempty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);padding:30px}
.qempty .big{font-size:34px;opacity:.4;margin-bottom:12px}
.qempty h3{font-size:15px;color:var(--ink);margin-bottom:6px}
.qempty p{font-size:13px;margin-bottom:18px}

/* ── MODAL (fixings prompt, etc.) ─────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:110;display:flex;align-items:center;justify-content:center;padding:24px}
.modal{position:relative;background:#fff;border-radius:var(--ro);box-shadow:var(--shadow-pop);width:100%;max-width:480px;overflow:hidden;animation:popin .16s ease-out}
.modal-x{position:absolute;top:10px;right:10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:0;background:transparent;color:var(--muted);cursor:pointer;border-radius:var(--ri);z-index:3}
.modal-x:hover{background:var(--neu-bg);color:var(--ink)}
@keyframes popin{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.modal .mtop{padding:22px 24px 6px}
.modal .mtop .meyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--teal-dark);margin-bottom:6px}
.modal h2{font-size:18px;font-weight:700;letter-spacing:-.01em}
.modal .msub{font-size:13px;color:var(--muted);margin-top:6px}
.modal .mbody{padding:14px 24px}
.modal .mfoot{padding:16px 24px;background:var(--neu-bg);border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.fixopt{display:flex;align-items:center;gap:13px;border:1px solid var(--line);border-radius:var(--rs);padding:12px 14px;margin-bottom:10px;cursor:pointer}
.fixopt:hover{border-color:var(--teal);background:var(--teal-50)}
.fixopt.sel{border-color:var(--navy);background:var(--navy-50)}
.fixopt .fcheck{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff}
.fixopt.sel .fcheck{background:var(--navy);border-color:var(--navy)}
.fixopt .fnm{font-size:13px;font-weight:700}
.fixopt .fds{font-size:12px;color:var(--muted)}
.fixopt .fpr{margin-left:auto;font-weight:800;color:var(--navy);font-variant-numeric:tabular-nums;white-space:nowrap}
.readonly-note{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--muted);background:var(--neu-bg);border:1px solid var(--line);border-radius:var(--ri);padding:6px 10px}

/* ============================================================================
   MILESTONE 3 — CHECKOUT, FREIGHT & ORDERS
   ============================================================================ */
.checkout-grid{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}

/* ── CHECKOUT ACCORDION (Pass 4) — progressive disclosure, one step open at a time ──
   Land with Step 1 open; "Continue →" validates the step, collapses it and opens the
   next; any step re-opens via its header. Same fields & order logic as before. */
.co-step{background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);margin-bottom:14px;overflow:hidden}
.co-step.open{border-color:var(--teal)}
.co-step-head{width:100%;display:flex;align-items:center;gap:12px;padding:15px 18px;background:none;border:none;cursor:pointer;font:inherit;text-align:left}
.co-step-head:hover{background:var(--neu-bg)}
.co-num{width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.co-num.done{background:var(--ok-tx)}
.co-step-title{font-size:14px;font-weight:700;color:var(--ink)}
.co-step-sum{font-size:12.5px;color:var(--muted);margin-left:6px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.co-step-chev{margin-left:auto;color:var(--faint);font-size:12px;flex-shrink:0}
.co-step-body{padding:6px 18px 18px}
.co-step-body .chint{font-size:12px;color:var(--muted);margin-bottom:14px}
.co-continue{margin-top:16px}

/* delivery vs pickup — rounded selectable cards (no emoji), per Oliver */
.co-method-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.co-method-card{display:flex;align-items:flex-start;gap:11px;border:1.5px solid var(--line);border-radius:var(--rs);padding:14px;cursor:pointer;background:#fff;transition:border-color .12s ease,background .12s ease}
.co-method-card:hover{border-color:var(--teal)}
.co-method-card.sel{border-color:var(--navy);background:var(--navy-50)}
.co-method-card .cmc-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;margin-top:1px;position:relative}
.co-method-card.sel .cmc-radio{border-color:var(--navy)}
.co-method-card.sel .cmc-radio:after{content:'';position:absolute;inset:3px;border-radius:50%;background:var(--navy)}
.co-method-card .cmc-t{display:block;font-size:13px;font-weight:700}
.co-method-card .cmc-d{display:block;font-size:12px;color:var(--muted);margin-top:2px;line-height:1.4}

/* inline "add new delivery address" form in checkout Step 1 */
.new-addr{border:1px solid var(--line);border-radius:var(--rs);background:var(--neu-bg);padding:14px 16px;margin-top:10px}
.new-addr .na-h{font-size:13px;font-weight:700;margin-bottom:10px}
.new-addr .na-save{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--ink);margin:6px 0 0;text-transform:none}
.new-addr .na-save input{width:auto;margin:0;accent-color:var(--navy)}
.new-addr .na-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}

.co-card{background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px}
.co-card h3{font-size:14px;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:9px}
.co-card .chint{font-size:12px;color:var(--muted);margin-bottom:16px}
.co-card .num-badge{width:22px;height:22px;border-radius:50%;background:var(--navy);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.formrow{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.formrow .full{grid-column:1/3}
textarea.field{resize:vertical;min-height:64px;line-height:1.5}
/* native (non-combo) dropdowns — used for short lists (≤5 options); custom chevron
   so they match the app instead of the OS default. */
select.field{cursor:pointer;background-color:#fff;appearance:none;-webkit-appearance:none;padding-right:34px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center}
.field.short{margin-bottom:0}
.fiellabel-row{display:flex;justify-content:space-between;align-items:baseline}
.opt-tag{font-size:11px;color:var(--faint);font-weight:600}

/* segmented control (delivery/pickup, card/bank) */
.segment{display:inline-flex;border:1px solid var(--line);border-radius:var(--ri);overflow:hidden;background:#fff;margin-bottom:18px}
.segment button{font:inherit;font-size:13px;font-weight:600;padding:9px 18px;border:none;background:#fff;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:7px}
.segment button+button{border-left:1px solid var(--line)}
.segment button.on{background:var(--navy);color:#fff}

/* payment method option */
.payopt{display:flex;align-items:center;gap:13px;border:1px solid var(--line);border-radius:var(--rs);padding:13px 15px;margin-bottom:10px;cursor:pointer}
.payopt:hover{border-color:var(--teal)}
.payopt.sel{border-color:var(--navy);background:var(--navy-50)}
.payopt .pradio{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;position:relative}
.payopt.sel .pradio{border-color:var(--navy)}
.payopt.sel .pradio:after{content:'';position:absolute;inset:3px;border-radius:50%;background:var(--navy)}
.payopt .pnm{font-size:13px;font-weight:700}
.payopt .pds{font-size:12px;color:var(--muted)}
.po-note{background:var(--info-bg);border:1px solid var(--info-bd);color:var(--info-tx);border-radius:var(--ri);padding:11px 14px;font-size:12.5px;font-weight:500;margin-top:6px}
.pickup-note{background:var(--neu-bg);border:1px solid var(--line);border-radius:var(--ri);padding:14px 16px;font-size:13px;color:var(--muted)}
.pickup-note b{color:var(--ink)}

/* order summary (checkout right rail) — reuses quote summary vibe */
.co-summary{position:sticky;top:0;border:1px solid var(--line);border-radius:var(--rs);background:#fff;box-shadow:var(--shadow-sm);overflow:hidden}
.co-summary .csh{padding:16px 18px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px}
.co-sumlines{padding:8px 18px;max-height:260px;overflow:auto}
.cosl{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12.5px;padding:7px 0;border-bottom:1px solid var(--line)}
.cosl:last-child{border-bottom:none}
.cosl .cn{color:var(--ink);flex:1;min-width:0}.cosl .cq{color:var(--muted)}
.cosl .cv{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}
.co-sum{padding:14px 18px;background:var(--neu-bg);border-top:1px solid var(--line)}
.co-sum .row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--muted)}
.co-sum .row .v{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink)}
.co-sum .row.tot{font-size:17px;font-weight:800;color:var(--ink);border-top:1px solid var(--line);margin-top:8px;padding-top:12px}
.co-sum .row.tot .v{color:var(--navy)}
.co-act{padding:16px 18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}

/* ORDER CONFIRMATION */
.conf{max-width:680px;margin:0 auto;text-align:center;padding:24px 0 40px}
.conf .tick{width:74px;height:74px;border-radius:50%;background:var(--ok-bg);border:2px solid var(--ok-bd);color:var(--ok-tx);font-size:38px;display:flex;align-items:center;justify-content:center;margin:8px auto 18px}
.conf h1{font-size:24px;margin-bottom:8px}
.conf .csub{color:var(--muted);font-size:14px;margin-bottom:26px}
.conf .cbox{text-align:left;border:1px solid var(--line);border-radius:var(--rs);background:#fff;box-shadow:var(--shadow-sm);padding:0;overflow:hidden;margin-bottom:22px}
.conf .cbox .cbh{background:var(--navy);color:#fff;padding:14px 20px;display:flex;justify-content:space-between;align-items:center}
.conf .cbox .cbh .so{font-weight:800;font-size:16px}
.conf .cbox .cbh .amt{font-weight:800;font-size:16px;font-variant-numeric:tabular-nums}
.conf .cbox .cbody{padding:16px 20px;font-size:13px}
.conf .cbox .crow{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--line)}
.conf .cbox .crow:last-child{border:none}
.conf .cbox .crow .k{color:var(--muted)}
.conf .cbox .crow .v{font-weight:600;text-align:right}
.conf .next{background:var(--info-bg);border:1px solid var(--info-bd);color:var(--info-tx);border-radius:var(--rs);padding:14px 18px;font-size:13px;text-align:left;margin-bottom:24px;line-height:1.55}
.conf .cbtns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* PAST ORDER detail */
.od-grid{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
.od-meta{border:1px solid var(--line);border-radius:var(--rs);background:#fff;box-shadow:var(--shadow-sm);padding:18px 20px}
.od-meta .mr{display:flex;justify-content:space-between;font-size:13px;padding:7px 0;border-bottom:1px solid var(--line)}
.od-meta .mr:last-child{border:none}
.od-meta .mr .k{color:var(--muted)} .od-meta .mr .v{font-weight:600;text-align:right}

/* detail right-rail (quote detail): meta + totals + CTAs grouped in one card, CTAs
   stacked under the totals (Oliver + "Example of CTA under totals area" reference). */
.dr-table .tbl{margin:0}
.detail-rail{border:1px solid var(--line);border-radius:var(--rs);background:#fff;box-shadow:var(--shadow-sm);overflow:hidden;position:sticky;top:0}
.detail-rail .dr-head{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px;display:flex;justify-content:space-between;align-items:center;gap:8px}
.detail-rail .dr-meta{padding:6px 18px}
.detail-rail .dr-row{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;padding:7px 0;border-bottom:1px solid var(--line)}
.detail-rail .dr-meta .dr-row:last-child{border-bottom:none}
.detail-rail .dr-row .k{color:var(--muted)} .detail-rail .dr-row .v{font-weight:600;text-align:right;color:var(--ink)}
.detail-rail .dr-tot{padding:10px 18px;background:var(--neu-bg);border-top:1px solid var(--line)}
.detail-rail .dr-tot .dr-row{border-bottom:none;padding:4px 0;color:var(--muted)}
.detail-rail .dr-tot .dr-row.tot{font-size:16px;font-weight:800;color:var(--ink);border-top:1px solid var(--line);margin-top:6px;padding-top:10px}
.detail-rail .dr-tot .dr-row.tot .v{color:var(--navy)}
.detail-rail .dr-act{padding:14px 18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
/* 6-column detail table: tighter columns; stack the rail below the table on narrower
   viewports so the table gets full width and never overflows. */
.dr-table .tbl th,.dr-table .tbl td{padding-left:10px;padding-right:10px}
@media (max-width:1100px){.od-grid{grid-template-columns:1fr}}

/* ── "SYSTEM WORKING" OVERLAY (the feels-real spinner) ────────────────────── */
.processing{position:fixed;inset:0;background:rgba(255,255,255,.82);z-index:130;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;backdrop-filter:blur(1.5px)}
.processing .spinner{width:46px;height:46px;border-width:4px}
.processing .pmsg{font-size:15px;font-weight:700;color:var(--navy)}
.processing .psub{font-size:12.5px;color:var(--muted);margin-top:-8px}

/* ============================================================================
   MILESTONE 4 — ENTRY JOURNEYS (login paths · welcome · onboarding)
   ============================================================================ */
.auth-choice{display:flex;align-items:center;gap:14px;border:1px solid var(--line);border-radius:var(--rs);padding:15px 16px;margin-bottom:12px;cursor:pointer;text-align:left}
.auth-choice:hover{border-color:var(--navy);background:var(--navy-50)}
.auth-choice .ach-ic{font-size:24px;flex-shrink:0;line-height:1}
.auth-choice .ach-t{font-size:14px;font-weight:700}
.auth-choice .ach-d{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.4}
.auth-choice .ach-go{margin-left:auto;color:var(--navy);font-weight:800;font-size:18px}
.auth-card .formrow{gap:0 14px}
.auth-card .badge{align-self:flex-start}

/* pending-account explainer banner (shown above every screen for pending users) */
.pending-banner{display:flex;gap:12px;align-items:flex-start;background:var(--warn-bg);border:1px solid var(--warn-bd);color:var(--warn-tx);border-radius:var(--rs);padding:13px 16px;margin-bottom:22px;font-size:13px;line-height:1.5}
.pending-banner .pb-ic{font-size:18px;line-height:1.2;flex-shrink:0}
.pending-banner b{font-weight:700}

/* ============================================================================
   MILESTONE 5 — SAVED QUOTES · SEND COMPOSER · FAVOURITES
   ============================================================================ */
.qcards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.qcard{background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);padding:18px 20px;cursor:pointer;display:flex;flex-direction:column;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}
.qcard:hover{border-color:var(--teal);box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.qcard .qc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.qcard .qc-name{font-size:15px;font-weight:700;color:var(--navy);line-height:1.3}
.qcard .qc-meta{font-size:12px;color:var(--muted);margin-top:3px}
.qcard .qc-total{font-size:19px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;margin-top:8px}
.qcard .qc-actions{display:flex;gap:8px;margin-top:14px}

/* branded quote preview inside the Send composer */
.email-preview{border:1px solid var(--line);border-radius:var(--rs);overflow:hidden;margin-top:4px;font-size:13px}
.email-preview .ep-head{background:var(--navy);color:#fff;padding:10px 14px;font-weight:800;font-size:16px}
.email-preview .ep-head .dot{color:var(--red)}
.email-preview .ep-body{padding:14px;color:var(--muted);line-height:1.55}
.email-preview .ep-quote{background:var(--neu-bg);border:1px solid var(--line);border-radius:var(--ri);padding:10px 12px;margin:10px 0;color:var(--ink)}
.email-preview .ep-total{font-weight:800;color:var(--navy)}
.email-preview .ep-link{color:var(--teal-dark);font-weight:700}
.modal .mbody.scroll{max-height:62vh;overflow:auto}
.sent-ok{text-align:center;padding:14px 0 4px}
.sent-ok .tick{width:60px;height:60px;border-radius:50%;background:var(--ok-bg);border:2px solid var(--ok-bd);color:var(--ok-tx);font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}

/* inline "add to favourites" search results (Favourites tab) */
.favadd-results{border:1px solid var(--line);border-radius:var(--rs);overflow:hidden;margin-bottom:6px;background:#fff}
.favadd-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line)}
.favadd-row:last-child{border-bottom:none}
.favadd-row .favadd-info{flex:1;min-width:0}
.favadd-row .code{font-size:11px;color:var(--muted);font-weight:600}
.favadd-row .nm{font-size:13px;font-weight:700;line-height:1.3}

/* shared-quote (recipient link view) */
.shared-banner{display:flex;gap:10px;align-items:center;background:var(--info-bg);border:1px solid var(--info-bd);color:var(--info-tx);border-radius:var(--rs);padding:12px 16px;margin-bottom:18px;font-size:13px;font-weight:600}
.share-msg{background:var(--neu-bg);border:1px solid var(--line);border-left:3px solid var(--teal);border-radius:var(--ri);padding:12px 16px;margin-bottom:20px;font-size:14px;color:var(--ink);line-height:1.5}

/* small line-item thumbnail (quote/order/checkout — product visible at every stage) */
.cellitem{display:flex;align-items:center;gap:11px}
.linethumb{width:36px;height:36px;border-radius:4px;background:var(--chrome);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.linethumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.linethumb .ph{color:var(--faint);font-size:13px}

/* ============================================================================
   MILESTONE 6 — ACCOUNT HUB
   ============================================================================ */
.acct-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.acct-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font:inherit;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;margin-bottom:-1px}
.acct-tab:hover{color:var(--ink)}
.acct-tab.on{color:var(--navy);border-bottom-color:var(--navy)}
.ns-note{display:flex;gap:8px;align-items:center;background:var(--info-bg);border:1px solid var(--info-bd);color:var(--info-tx);border-radius:var(--ri);padding:11px 14px;font-size:12.5px;font-weight:500;margin-bottom:16px}
.addr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.addr-card{background:#fff;border:1px solid var(--line);border-radius:var(--rs);box-shadow:var(--shadow-sm);padding:16px 18px}
.addr-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}
.addr-label{font-weight:700;font-size:14px}
.addr-node{font-size:12px;color:var(--muted)}
.addr-lines{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:14px}
.addr-actions{display:flex;gap:8px;flex-wrap:wrap}
.co-card label{margin-top:6px}
.co-card .field[disabled]{background:var(--neu-bg);color:var(--muted);cursor:not-allowed}
.co-branch{margin-bottom:18px;max-width:460px}
.co-branch label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}

/* ============================================================================
   MILESTONE 7 — CONFIGURATORS
   ============================================================================ */
.cfg-grid{display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:start}
.cfg-controls label{display:block;margin:14px 0 6px}
.cfg-controls label:first-child{margin-top:0}
.cfg-controls .qty{width:100%}
.cfg-controls .qty input{flex:1;width:auto}
/* realistic speed-calmer render container — fixed 4:1 box (matches the reference's
   font-scaling assumption); the SVG fills it and centres via preserveAspectRatio. */
.sc-diagram{width:100%;aspect-ratio:4/1;background:var(--asphalt);border:1px solid var(--line);border-radius:var(--rs);overflow:hidden;margin-bottom:20px}
.sc-diagram svg{width:100%;height:100%;display:block}
.sec-h2{font-size:15px;font-weight:700;margin:18px 0 12px}
@media (max-width:900px){.cfg-grid{grid-template-columns:1fr}}

/* ============================================================================
   SHARED DATA TABLE — transaction lists (Projects · Quotes · Orders)
   Sortable headers, filter toolbar (search + chips + branch dropdown), pager.
   ============================================================================ */
.tbl-wrap{display:flex;flex-direction:column;gap:14px}
.tbl-actions{margin-bottom:16px}
.tbl-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.tbl-toolbar .tbl-tb-sp{flex:1 1 auto}
.tbl-search{height:38px;min-width:230px;padding:0 14px;border:1px solid var(--line);border-radius:var(--rs);font-size:13px;background:#fff;color:var(--ink)}
.tbl-search:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--navy-50)}
.tbl-filter{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);font-weight:600}
/* compact the branded control for the toolbar — applies to both the native <select>
   (≤5 branches) and the searchable combo (>5 branches) so they look identical. */
.tbl-filter select.field{margin:0;width:auto;min-width:170px;padding-top:9px;padding-bottom:9px;font-size:13px;font-weight:600;color:var(--ink);border-radius:var(--rs)}
.tbl-filter .combo.field{margin:0;width:auto;min-width:190px}
.tbl-filter .combo-input.field{font-size:13px;font-weight:600;border-radius:var(--rs)}
.tbl-chips{display:inline-flex;gap:6px;flex-wrap:wrap}
.tbl-chips .chip{height:32px;padding:0 13px;border:1px solid var(--line);border-radius:100px;background:#fff;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s ease}
.tbl-chips .chip:hover{border-color:var(--teal);color:var(--ink)}
.tbl-chips .chip.on{background:var(--navy);border-color:var(--navy);color:#fff}

/* list-table skin (extends .tbl) — sortable headers + clickable rows */
.tbl.list th.srt{cursor:pointer;user-select:none;white-space:nowrap}
.tbl.list th.srt:hover{color:var(--ink)}
.tbl.list th.active{color:var(--navy)}
.tbl.list th .srt-c{font-size:9px;margin-left:4px;vertical-align:middle}
.tbl.list td.iname{color:var(--navy);font-weight:700}
.tbl.list .tbl-link{color:var(--teal-dark);font-weight:600;cursor:pointer}
.tbl.list .tbl-link:hover{text-decoration:underline}
.tbl.list .muted{color:var(--muted)}
.tbl.list td .neg{color:var(--err-tx,#b42318);font-weight:600}

.tbl-empty{padding:34px 16px;text-align:center;color:var(--muted);font-size:14px;border:1px dashed var(--line);border-top:0;border-radius:0 0 var(--rs) var(--rs)}
.tbl-count{font-size:12px;color:var(--muted)}
.tbl-pager{display:flex;align-items:center;justify-content:space-between;gap:12px}
.tbl-pg-btns{display:flex;gap:8px}
.tbl-pg-btns .btn[disabled]{opacity:.45;pointer-events:none}

.proj-meta{font-size:13px;color:var(--muted);margin:-10px 0 8px}
.proj-meta .code{color:var(--muted)}
.main .muted{color:var(--muted)}
@media (max-width:720px){.tbl-toolbar{gap:8px}.tbl-search{min-width:0;flex:1 1 100%}}
