/* Naliwajka Store styling -- the customer-facing sibling of /print. Reuses the same
   burgundy design tokens (web/static/app.css + Site/naliwajka/brand.css) so the brand
   is consistent, with a more "commercial" surface: hero intros + numbered step cards.
   Standalone (this repo deploys to its own LXC), so the tokens are duplicated here. */
:root{
  --bg:#f6f6f7; --bg-soft:#fafafb;
  --surface:#ffffff; --surface-2:#fbfafa; --surface-3:#f2eef0;
  --line:#e4e3e6; --line-soft:#eeedef;
  --text:#1c1b1d; --text-dim:#5b5860; --text-faint:#8c8891;
  --accent:#80213b; --accent-2:#9e2a4a; --accent-deep:#5e1729;
  --accent-ink:#ffffff; --accent-soft:rgba(128,33,59,.09); --accent-glow:rgba(128,33,59,.18);
  --ok:#3f9142; --warn:#b9770a; --danger:#c0392b;
  --radius:10px; --radius-sm:7px;
  --shadow:0 1px 3px rgba(20,15,18,.08),0 8px 24px rgba(20,15,18,.06);
  --shadow-sm:0 1px 2px rgba(20,15,18,.07);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg);color:var(--text);
  font:14px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:var(--accent-soft);color:var(--accent-deep)}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* scrollbars */
*{scrollbar-width:thin;scrollbar-color:#cfcdd1 transparent}
*::-webkit-scrollbar{width:11px;height:11px}
*::-webkit-scrollbar-thumb{background:#cfcdd1;border-radius:8px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:#b6b3b8;background-clip:content-box}

/* header / nav -- tabs live in the header */
header{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:6px;
  padding:0 24px;height:58px;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);
  border-bottom:1px solid var(--line);box-shadow:0 1px 2px rgba(20,15,18,.04)}
header h1{font-size:17px;margin:0;font-weight:700;letter-spacing:-.01em;line-height:1;
  display:inline-flex;align-items:center;gap:8px}
header h1 a{color:var(--text);text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:9px;background:var(--surface-3);border:1px solid var(--line);
  transition:color .15s,background .15s,border-color .15s,box-shadow .15s}
header h1 a::before{content:"";width:9px;height:9px;border-radius:3px;
  background:linear-gradient(140deg,var(--accent-2),var(--accent-deep));
  box-shadow:0 1px 4px var(--accent-glow)}
header h1 a:hover{color:var(--accent);background:var(--accent-soft);border-color:#e0c2cb;
  box-shadow:var(--shadow-sm);text-decoration:none}
header h1 a:active{transform:translateY(1px)}
header h1 .tag{color:var(--text-faint);font-weight:500;font-size:13px;letter-spacing:.01em}
header .sub{margin-left:auto;color:var(--text-faint);font-size:12.5px;letter-spacing:.01em}

/* top tabs (Products / Quoting / Design) -- underline style in the header */
.tabs{display:flex;gap:2px;margin-left:18px;align-self:stretch}
.tabs .tab{background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;
  color:var(--text-dim);padding:0 14px;font:inherit;font-size:13.5px;font-weight:600;cursor:pointer;
  box-shadow:none;letter-spacing:0;display:inline-flex;align-items:center}
.tabs .tab:hover{color:var(--text);background:transparent;transform:none;box-shadow:none;filter:none}
.tabs .tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tabpanel.hidden{display:none}

/* main site nav (Projects / DAG / Store) -- underline links, matches the site */
.mainnav{display:flex;gap:2px;margin-left:10px;align-self:stretch}
.mainnav a{display:inline-flex;align-items:center;padding:0 13px;font-size:13.5px;font-weight:600;
  color:var(--text-dim);text-decoration:none;border-bottom:2px solid transparent}
.mainnav a:hover{color:var(--text);text-decoration:none}
.mainnav a.active{color:var(--accent);border-bottom-color:var(--accent)}

/* subheader: the store's own sections (Products / Quoting / Design) as sub-pages */
.subnav{position:sticky;top:58px;z-index:9;display:flex;gap:2px;align-items:center;
  padding:0 24px;height:44px;background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(10px) saturate(140%);backdrop-filter:blur(10px) saturate(140%);
  border-bottom:1px solid var(--line)}
.subnav a{display:inline-flex;align-items:center;height:100%;padding:0 14px;font-size:13.5px;
  font-weight:600;color:var(--text-dim);text-decoration:none;border-bottom:2px solid transparent}
.subnav a:hover{color:var(--text);text-decoration:none}
.subnav a.active{color:var(--accent);border-bottom-color:var(--accent)}
/* the Orders link is revealed by nav.js for approved users; keep it hidden until then
   (the [hidden] attribute alone loses to the display rule above). */
.subnav a[hidden]{display:none}

/* account control (sign in / avatar) -- shared look with the rest of naliwajka.com */
.acct-nav{display:flex;align-items:center;gap:11px;margin-left:auto}
.acct-btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none;
  font-size:13px;font-weight:600;color:var(--accent-ink);
  background:linear-gradient(140deg,var(--accent-2),var(--accent-deep));
  padding:7px 14px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
  transition:transform .12s ease,box-shadow .15s ease}
.acct-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow);text-decoration:none}
.acct-g{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;
  border-radius:4px;background:#fff;color:var(--accent-deep);font-weight:800;font-size:12px}
.acct-me{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);
  font-size:13px;font-weight:600;padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s}
.acct-me:hover{background:var(--surface-3);text-decoration:none}
.acct-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-av{width:26px;height:26px;border-radius:50%;object-fit:cover;border:1px solid var(--line)}
.acct-av-ph{display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--accent-deep);font-weight:700;font-size:13px}
.acct-out{text-decoration:none;font-size:13px;font-weight:600;color:var(--text-faint);
  border-left:1px solid var(--line);padding-left:11px;transition:color .15s}
.acct-out:hover{color:var(--accent-2)}
.acct-mgmt{display:inline-flex;align-items:center;text-decoration:none;font-size:12px;
  font-weight:700;letter-spacing:.05em;color:var(--accent-ink);
  background:linear-gradient(140deg,var(--accent-2),var(--accent-deep));
  padding:6px 13px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
.acct-mgmt:hover{transform:translateY(-1px);box-shadow:var(--shadow);text-decoration:none}

main{max-width:980px;margin:0 auto;padding:16px 20px 28px}

/* subtabs (FDM, …) inside Quoting -- pill style */
.subtabs{display:flex;gap:8px;margin:2px 0 12px}
.subtabs .subtab{background:var(--surface);color:var(--text-dim);border:1px solid var(--line);
  border-radius:999px;padding:7px 18px;font:inherit;font-size:13px;font-weight:600;cursor:pointer;
  box-shadow:var(--shadow-sm)}
.subtabs .subtab:hover{color:var(--text);background:var(--surface-3);filter:none;transform:none;box-shadow:var(--shadow-sm)}
.subtabs .subtab.active{color:var(--accent-ink);background:linear-gradient(180deg,var(--accent-2),var(--accent));border-color:var(--accent-deep)}
.subtabpanel.hidden{display:none}

/* hero intro blocks -- the "commercial" voice */
.hero{padding:2px 4px 8px}
.hero h2{margin:0 0 3px;font-size:21px;font-weight:750;letter-spacing:-.02em;color:var(--text)}
.hero p{margin:0;color:var(--text-dim);font-size:13.5px;line-height:1.5;max-width:62ch}

h2.sec{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);
  margin:14px 4px 8px;font-weight:700;display:flex;align-items:center;gap:10px}
h2.sec::after{content:"";flex:1;height:1px;background:var(--line)}
.note{color:var(--text-faint);font-size:12.5px;line-height:1.5;margin-top:9px}
.hint{color:var(--text-faint);font-weight:400;font-size:11px}

/* ---- 3D viewers (STL model / sliced gcode) ---- */
.preview .preview-head{display:flex;align-items:center;gap:10px}
.preview .preview-head h2.sec{flex:1;margin:0}
.preview .preview-head .hint{white-space:nowrap}
.preview canvas{display:block;width:100%;height:380px;margin:10px 0 6px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  background:#121013;cursor:grab;touch-action:none}
.preview canvas:active{cursor:grabbing}
.preview .preview-foot{display:block}

/* steps 2 (upload) + 3 (slice) side by side, each above its own preview; stack when narrow.
   Previews shrink in this two-up layout so the page stays compact (canvas auto-fits its column). */
.qcols{display:flex;gap:12px;align-items:flex-start}
.qcols .qcol{flex:1 1 0;min-width:0}
.qcol .preview canvas{height:220px}
@media(max-width:880px){.qcols{flex-direction:column}}

/* quantity + shipping + delivery merged into one card: divide the sub-blocks with a hairline */
#orderDetails .od-block + .od-block{margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft)}
#orderDetails .od-block h2.sec{margin-top:0}

/* add-ons: a checkbox row with title + price + description */
.addon{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.addon input{width:auto;margin-top:2px;flex:0 0 auto}
.addon-body{display:flex;flex-direction:column;gap:2px}
.addon-title{font-size:14px;font-weight:600;color:var(--text)}
.addon-price{color:var(--accent);font-weight:700;margin-left:4px}
.addon-desc{font-size:12.5px}

/* quantity section */
#qtyView .qty-row{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}
#qtyView label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--text-dim);max-width:150px}
#qtyView input{width:90px}
#gcodeInput{margin-left:8px}

/* panels / cards */
.panel,.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm)}
.panel{padding:14px 18px;margin-bottom:10px}

/* numbered step cards (the quote pipeline) */
.step{display:flex;gap:16px;align-items:flex-start}
.step-no{flex:0 0 auto;width:30px;height:30px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;
  color:var(--accent-ink);background:linear-gradient(180deg,var(--accent-2),var(--accent));
  border:1px solid var(--accent-deep);box-shadow:var(--shadow-sm);margin-top:2px}
.step-body{flex:1;min-width:0}
.step-body h3{margin:0 0 8px;font-size:15px;font-weight:700;color:var(--text)}

/* forms */
form.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px 14px}
form.grid label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--text-dim)}
form.grid label.wide{grid-column:1 / -1}
form.grid .actions{grid-column:1 / -1;display:flex;align-items:center;gap:12px;margin-top:4px;flex-wrap:wrap}
input,select,textarea{width:100%;background:var(--surface);color:var(--text);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:8px 10px;font:inherit;font-size:13px;outline:none;
  transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
input::placeholder,textarea::placeholder{color:var(--text-faint)}
textarea{min-height:96px;resize:vertical;line-height:1.5}

/* buttons */
button{background:linear-gradient(180deg,var(--accent-2),var(--accent));color:var(--accent-ink);
  border:1px solid var(--accent-deep);border-radius:var(--radius-sm);padding:8px 16px;font:inherit;
  font-weight:600;letter-spacing:.01em;cursor:pointer;box-shadow:var(--shadow-sm);
  transition:transform .12s,box-shadow .12s,filter .12s}
button:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 4px 14px var(--accent-glow)}
button:active{transform:translateY(0);filter:brightness(.98)}
button:disabled{opacity:.45;cursor:default;filter:none;transform:none;box-shadow:none}
button.ghost{background:var(--surface);color:var(--text);border:1px solid var(--line);font-weight:500}
button.ghost:hover{background:var(--surface-3);border-color:#d6c2c9;filter:none;box-shadow:var(--shadow-sm)}
.msg{font-size:12px;color:var(--text-faint)}
.msg.err{color:var(--danger)}.msg.ok{color:var(--ok)}

/* upload / slice progress bars. Determinate (width-driven) for byte uploads;
   .indeterminate animates a sweeping chip when % is unknown (slicing). */
.pq-bar{height:6px;margin:8px 0 2px;border-radius:999px;background:var(--surface-3);
  border:1px solid var(--line-soft);overflow:hidden}
.pq-bar>i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--accent-2),var(--accent));transition:width .15s ease}
.pq-bar.indeterminate>i{width:40%;transition:none;animation:pq-sweep 1.1s ease-in-out infinite}
@keyframes pq-sweep{0%{margin-left:-40%}100%{margin-left:100%}}
@media (prefers-reduced-motion:reduce){
  .pq-bar.indeterminate>i{animation:none;width:100%;opacity:.5}}

/* status board (downward stack of read-only printer cards) */
.stack{display:flex;flex-direction:column;gap:14px}
.card{padding:16px 18px;display:flex;flex-direction:column;gap:12px}
.card .top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.card .name{font-size:15px;font-weight:650;color:var(--text)}
.card .addr{color:var(--text-faint);font-size:12px}
.card .right{margin-left:auto;display:flex;gap:8px;align-items:center}

.badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  padding:3px 9px;border-radius:999px;border:1px solid var(--line)}
.badge.printing{color:var(--accent-ink);background:linear-gradient(180deg,var(--accent-2),var(--accent));border-color:var(--accent-deep)}
.badge.paused{color:var(--warn);background:#fbf1d8;border-color:#e6cd8e}
.badge.standby,.badge.complete,.badge.idle{color:var(--ok);background:#eaf5ea;border-color:#bfe0c1}
.badge.error,.badge.cancelled{color:var(--danger);background:#f9e3e0;border-color:#e0b3ad}
.badge.offline,.badge.unknown{color:var(--text-faint);background:var(--surface-3)}

.meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px 18px}
.meta .k{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}
.meta .v{font-size:13.5px;color:var(--text);margin-top:2px}

.bar{height:8px;border-radius:999px;background:var(--surface-3);border:1px solid var(--line);overflow:hidden}
.bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent-deep),var(--accent))}

/* aggregate printer status pills (no per-machine detail exposed) */
.status-row{display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center}
.status-pill{font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface-2);color:var(--text-dim)}
.status-pill.ok{color:var(--ok);background:#eaf5ea;border-color:#bfe0c1}
.status-pill.busy{color:var(--warn);background:#fbf1d8;border-color:#e6cd8e}
.status-pill.off{color:var(--text-faint);background:var(--surface-3)}

/* delivery / material-loaded indicator */
#deliveryView .delivery-ok,#deliveryView .delivery-wait{font-size:14px;padding:10px 14px;
  border-radius:var(--radius-sm);border:1px solid var(--line)}
#deliveryView .delivery-ok{color:#2c6e2f;background:#eaf5ea;border-color:#bfe0c1}
#deliveryView .delivery-wait{color:var(--warn);background:#fbf1d8;border-color:#e6cd8e}
/* the computed delivery date result (below the timeline overview) */
#deliveryView .delivery-eta{margin-top:12px;font-size:14.5px;color:var(--text)}
#deliveryView .delivery-eta b{color:var(--accent);font-weight:700}
/* shipping-estimate section (above delivery): address inputs + estimated cost */
#shipEstView .ship-result{margin-top:12px;font-size:14px}
#shipEstView .ship-result b{color:var(--accent);font-weight:700}
/* read-only ship-to address on the payment-only checkout page */
.ship-to{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--line-soft);font-size:13.5px;line-height:1.4}
.ship-to .hint{display:block;margin-bottom:3px}
/* coupon code entry on checkout */
.coupon-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}
.coupon-row input{width:auto;flex:0 1 180px}
.coupon-row button{flex:0 0 auto}
/* bottom-align the address fields so City/State/ZIP/Country inputs line up even when a
   longer label (e.g. "ZIP / postal code") wraps to two lines in a narrow cell. */
#shipForm{align-items:end}
/* address autocomplete: type-ahead suggestions dropdown under the street field */
.addr-ac{position:relative}
.addr-ac>input{width:100%}
.addr-suggest{position:absolute;top:100%;left:0;right:0;z-index:30;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow);
  max-height:240px;overflow:auto;margin-top:3px}
.addr-suggest .addr-item{padding:8px 12px;cursor:pointer;font-size:13px;color:var(--text);
  border-bottom:1px solid var(--line-soft)}
.addr-suggest .addr-item:last-child{border-bottom:none}
.addr-suggest .addr-item:hover,.addr-suggest .addr-item.active{background:var(--surface-3)}

/* delivery timeline: Print start -> Print handling -> Shipping, with a time per stage */
.timeline{display:flex;align-items:flex-start;margin-top:16px;overflow-x:auto;padding-bottom:2px}
.timeline .tl-step{display:flex;flex-direction:column;align-items:center;text-align:center;
  flex:0 0 auto;min-width:96px}
.timeline .tl-bar{flex:1 1 auto;min-width:24px;height:2px;background:var(--line);margin:14px 4px 0}
.timeline .tl-dot{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:13px;color:var(--accent-ink);
  background:linear-gradient(180deg,var(--accent-2),var(--accent));border:1px solid var(--accent-deep);
  box-shadow:var(--shadow-sm)}
.timeline .tl-label{margin-top:8px;font-size:12.5px;font-weight:600;color:var(--text)}
.timeline .tl-time{margin-top:2px;font-size:12px;color:var(--text-dim);font-variant-numeric:tabular-nums}

/* material selector (PLA / PETG / ABS) */
.material-buttons{display:flex;gap:10px;flex-wrap:wrap}
.material-buttons .mat-btn{display:inline-flex;flex-direction:column;align-items:center;gap:3px;
  min-width:96px;background:var(--surface);color:var(--text);border:1.5px solid var(--line);
  border-radius:var(--radius-sm);padding:12px 18px;font-weight:700;font-size:15px;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:border-color .12s,background .12s}
.material-buttons .mat-btn:hover{border-color:#d6c2c9;background:var(--surface-3);filter:none;transform:none;box-shadow:var(--shadow-sm)}
.material-buttons .mat-btn.active{color:var(--accent-ink);border-color:var(--accent-deep);
  background:linear-gradient(180deg,var(--accent-2),var(--accent))}
/* no in-stock colors: grayed out and unselectable */
.material-buttons .mat-btn.out,.material-buttons .mat-btn:disabled{opacity:.42;cursor:not-allowed;box-shadow:none}
.material-buttons .mat-btn.out:hover{border-color:var(--line);background:var(--surface)}

/* color sub-selector (appears under the chosen type) */
.color-label{margin:14px 0 6px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:11px}
.color-buttons{display:flex;flex-wrap:wrap;gap:8px}
.color-buttons .color-btn{display:inline-flex;align-items:center;gap:7px;background:var(--surface);
  color:var(--text);border:1.5px solid var(--line);border-radius:999px;padding:6px 13px 6px 8px;
  font-weight:600;font-size:13px;cursor:pointer;box-shadow:var(--shadow-sm)}
.color-buttons .color-btn:hover{border-color:#d6c2c9;background:var(--surface-3);filter:none;transform:none;box-shadow:var(--shadow-sm)}
.color-buttons .color-btn.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.color-buttons .swatch{width:16px;height:16px;border-radius:999px;border:1px solid rgba(0,0,0,.18);flex:0 0 auto}
/* rolls-in-stock badge (0–5, then 5+/10+/50+) */
.color-buttons .qty{margin-left:3px;min-width:18px;text-align:center;font-size:11px;font-weight:700;
  color:var(--text-faint);background:var(--surface-3);border-radius:999px;padding:1px 6px}
.color-buttons .color-btn.active .qty{color:var(--accent-ink)}
/* out of stock: grayed out and not selectable */
.color-buttons .color-btn.out,.color-buttons .color-btn:disabled{opacity:.42;cursor:not-allowed;box-shadow:none}
.color-buttons .color-btn.out:hover{border-color:var(--line);background:var(--surface)}
.color-buttons .color-btn.out .qty{color:var(--bad,#c0392b)}

/* customer-facing "Your quote" line items: label (+optional hint) on the left,
   amount right-aligned with a hairline between rows. */
.quote-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding:9px 2px;font-size:13.5px;border-bottom:1px solid var(--line-soft)}
.quote-row:first-child{padding-top:3px}
.quote-row:last-of-type{border-bottom:none}
.quote-row > span{color:var(--text-dim)}
.quote-row .hint{color:var(--text-faint);font-weight:400;font-size:11.5px}
.quote-row > b{font-weight:650;color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap}
/* checkout summary's grand total (the .total variant of a quote row) */
.quote-row.total{margin-top:8px;padding-top:12px;border-top:2px solid var(--accent-glow)}
.quote-row.total > span{color:var(--text);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:13px}
.quote-row.total > b{font-size:19px;font-weight:800;color:var(--accent)}

/* the all-in total: separated from the line items, large and accented. */
.cost-line{display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  margin-top:10px;padding:13px 2px 2px;border-top:2px solid var(--accent-glow)}
.cost-line .cost-label{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:700}
.cost-line .cost-amt{font-size:30px;font-weight:800;color:var(--accent);
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1}

.hidden{display:none}
.empty{color:var(--text-faint);padding:20px;text-align:center;border:1px dashed var(--line);
  border-radius:var(--radius);background:var(--surface-2)}
.empty.soon{padding:54px 20px;font-size:16px;font-weight:600;color:var(--text-dim)}

@media(max-width:680px){form.grid{grid-template-columns:1fr 1fr}.step{flex-direction:column;gap:10px}}

/* quote card + BOM table */
.quote-card{border:1px solid #e0c2cb;box-shadow:var(--shadow);
  background:linear-gradient(180deg,var(--accent-soft),var(--surface) 84px)}
.quote-card h2.sec{margin-top:2px}
.quote-table{width:100%;border-collapse:collapse;font-size:13.5px;margin-top:4px}
.quote-table th,.quote-table td{padding:7px 10px;text-align:left;border-bottom:1px solid var(--line-soft)}
.quote-table th{color:var(--text-faint);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.quote-table .num{text-align:right;font-variant-numeric:tabular-nums}
.quote-table tfoot td{border-top:1px solid var(--line);border-bottom:none}
.quote-table tr.grand td{font-size:15px;color:var(--accent);border-top:2px solid var(--line)}

/* your print queue (My Queue) */
.myq{width:100%;border-collapse:collapse;font-size:13.5px}
.myq th,.myq td{padding:7px 10px;text-align:left;border-bottom:1px solid var(--line-soft)}
.myq th{color:var(--text-faint);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.badge.st-queued{color:var(--warn);background:#fbf1d8;border-color:#e6cd8e}
.badge.st-printing{color:var(--accent-ink);background:linear-gradient(180deg,var(--accent-2),var(--accent));border-color:var(--accent-deep)}
.badge.st-done{color:var(--ok);background:#eaf5ea;border-color:#bfe0c1}
.badge.st-canceled,.badge.st-failed{color:var(--danger);background:#f9e3e0;border-color:#e0b3ad}
.badge.st-paid,.badge.st-rated{color:var(--warn);background:#fbf1d8;border-color:#e6cd8e}
.badge.st-fulfilled{color:var(--ok);background:#eaf5ea;border-color:#bfe0c1}
.badge.st-draft,.badge.st-awaiting_payment{color:var(--text-faint);background:var(--surface-3)}
button.link{background:none;border:none;color:var(--accent);cursor:pointer;font:inherit;padding:0;text-decoration:underline}

/* ---- order cards + fulfillment stepper (My orders) ---- */
.ordcard{border:1px solid var(--line);border-radius:var(--radius);padding:13px 15px 15px;margin-bottom:10px;background:var(--surface-2)}
.ordcard:last-child{margin-bottom:0}
.ordcard-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}
.ordcard-head b{font-size:14px}
.ordcard-total{font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums;font-size:16px;white-space:nowrap}
.ordcard-track{margin-top:12px}

.fsteps{display:flex;list-style:none;margin:2px 0;padding:0}
.fstep{flex:1 1 0;position:relative;text-align:center;min-width:0}
/* connector to the previous step (centered on the 18px dot) */
.fstep::before{content:"";position:absolute;top:9px;left:-50%;width:100%;height:2px;background:var(--line);z-index:0}
.fstep:first-child::before{display:none}
.fdot{position:relative;z-index:1;display:block;width:18px;height:18px;margin:0 auto 7px;border-radius:50%;
  background:var(--surface);border:2px solid var(--line)}
.flabel{font-size:10.5px;color:var(--text-faint);letter-spacing:.01em;display:block;line-height:1.25}
.fstep.done .fdot{background:var(--accent);border-color:var(--accent)}
.fstep.done::before{background:var(--accent)}
.fstep.done .flabel{color:var(--text-dim)}
.fstep.active .fdot{background:var(--accent-ink);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.fstep.active::before{background:var(--accent)}
.fstep.active .flabel{color:var(--accent);font-weight:700}

/* ---- Manage board (mgmt): stage selectors + design-request triage ---- */
.stage-sel{width:auto;min-width:128px;padding:5px 8px;font-size:12.5px}
details.dreq summary{cursor:pointer;font-weight:600;color:var(--text);font-size:13.5px}
details.dreq summary:hover{color:var(--accent)}
.dreq-body{margin-top:7px;color:var(--text-dim);font-size:13px;line-height:1.5}
.dreq-body .hint{margin-top:5px}

/* ---- design picture upload: previews on the form + thumbnails in lists ---- */
form.grid .img-previews{grid-column:1 / -1}
.img-previews{display:flex;flex-wrap:wrap;gap:10px;margin-top:2px}
.img-previews[hidden]{display:none}
.img-thumb{position:relative;width:96px;height:96px;border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;background:var(--surface-3)}
.img-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.img-thumb.uploading img{opacity:.5}
.img-thumb.uploading::after{content:"uploading…";position:absolute;inset:auto 0 0 0;padding:2px 0;text-align:center;
  font-size:10px;color:var(--accent-ink);background:var(--accent)}
.img-x{position:absolute;top:3px;right:3px;width:20px;height:20px;padding:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;line-height:1;font-size:15px;font-weight:700;
  background:rgba(20,15,18,.62);border:none;color:#fff;box-shadow:none}
.img-x:hover{background:var(--danger);transform:none;filter:none;box-shadow:none}
/* small read-only thumbnails in the requests/triage lists */
.dthumbs{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}
.dthumb{width:52px;height:52px;object-fit:cover;border:1px solid var(--line);border-radius:var(--radius-sm);
  display:block;background:var(--surface-3);transition:transform .12s}
.dthumb:hover{transform:scale(1.04);border-color:#d6c2c9}
/* a file input shouldn't carry the heavy text-input chrome */
input[type=file]{padding:7px 8px;font-size:12.5px;background:var(--surface-2);cursor:pointer}

/* design-request status badges (Design page "Your requests" + Manage triage) */
.badge.ds-new{color:var(--warn);background:#fbf1d8;border-color:#e6cd8e}
.badge.ds-reviewing,.badge.ds-quoted{color:var(--accent);background:var(--accent-soft);border-color:#e0c2cb}
.badge.ds-accepted{color:var(--accent-ink);background:linear-gradient(180deg,var(--accent-2),var(--accent));border-color:var(--accent-deep)}
.badge.ds-completed{color:var(--ok);background:#eaf5ea;border-color:#bfe0c1}
.badge.ds-declined{color:var(--danger);background:#f9e3e0;border-color:#e0b3ad}

/* live print-cam modal (orders.js) — overlay lives on <body>, outside the polled queue
   table, so the 10s refresh never tears down an open MJPEG stream. */
#camModal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
#camModal[hidden]{display:none}
.cam-backdrop{position:absolute;inset:0;background:rgba(20,15,18,.55);backdrop-filter:blur(2px)}
.cam-box{position:relative;width:min(92vw,860px);background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.cam-head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 14px;border-bottom:1px solid var(--line-soft)}
.cam-title{font-weight:700;font-size:14px;color:var(--text)}
.cam-x{background:none;border:none;font-size:22px;line-height:1;color:var(--text-faint);cursor:pointer;padding:0 4px}
.cam-x:hover{color:var(--accent)}
.cam-stage{position:relative;background:#000;min-height:240px;display:flex;align-items:center;justify-content:center}
.cam-img{display:block;max-width:100%;max-height:78vh;width:auto;height:auto}
.cam-img[src=""]{display:none}
.cam-msg{position:absolute;color:var(--text-faint);padding:14px;text-align:center}
