/* catalog page — loaded AFTER site.css; reuses its tokens. Clean, light, readable. */
.cat-head{background:var(--bg2);border-bottom:1px solid var(--line)}
.cat-head .wrap{padding:38px 28px 34px}
.cat-head .kick{font-family:"Roboto Mono",monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);font-weight:600;margin:0 0 9px}
.cat-head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;flex-wrap:wrap}
.cat-head h1{font-size:32px;letter-spacing:-.01em;margin:0;text-wrap:balance}
.cat-search{position:relative;flex:1 1 360px;max-width:480px}
.cat-search svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#9aa8b6}
#q{width:100%;padding:14px 16px 14px 44px;border:1px solid #d4dde6;border-radius:10px;background:#fff;font-size:16px;outline:none;color:var(--ink)}
#q:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,120,230,.14)}

.cat-main{padding:20px 28px 70px}
/* chips */
.cats{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1px solid var(--line);background:#fff;color:var(--slate);padding:7px 14px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .14s}
.chip:hover{border-color:#bcd0ec;color:var(--ink)}
.chip.on{background:var(--blue);border-color:var(--blue);color:#fff}
.chip .n{opacity:.6;margin-left:6px;font-family:"Roboto Mono",monospace;font-size:12px}
.result-bar{padding:10px 0 14px;color:var(--muted);font-size:14px}
#count strong{color:var(--ink)}
/* grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:transform .16s,box-shadow .16s,border-color .16s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#cfe0f6}
.card-img{height:172px;background:#f1f5fa center/contain no-repeat;border-bottom:1px solid var(--line)}
.card-img.ph{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#5a6a7d;font-size:13px;gap:8px}
.ph-mark{width:38px;height:auto;opacity:.28}
.card-body{padding:15px 16px 17px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-cat{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);font-weight:600;font-family:"Roboto Mono",monospace}
.card-name{font-size:15.5px;font-weight:500;margin:0;line-height:1.3}
.card-pn{display:flex;flex-wrap:wrap;gap:5px}
.pn{font-family:"Roboto Mono",monospace;font-size:12.5px;background:#eef3f9;color:#1c3a5c;padding:2px 8px;border-radius:5px;border:1px solid #e1eaf3}
.card-desc{font-size:14px;color:var(--muted);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.empty{text-align:center;color:var(--muted);padding:60px 0}
.linklike{background:none;border:none;color:var(--blue-d);cursor:pointer;text-decoration:underline;font-size:inherit}
/* detail */
.detail{padding:8px 0 30px}
.back{display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:var(--slate);cursor:pointer;font-size:14px;padding:6px 0;margin-bottom:18px}
.back:hover{color:var(--blue)}
.detail-top{display:grid;grid-template-columns:minmax(0,420px) 1fr;gap:44px;align-items:start}
.detail-figure{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;display:flex;align-items:center;justify-content:center;min-height:300px}
.detail-figure img{max-width:100%;max-height:360px}
.detail-figure.ph{color:#b6c6d4}
.detail-cat{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);font-weight:600;font-family:"Roboto Mono",monospace}
.detail h1{font-size:28px;margin:8px 0 14px;line-height:1.18;letter-spacing:-.01em}
.detail-pn{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.detail-pn .pn{font-size:13px;padding:5px 12px}
.detail-desc{font-size:16.5px;color:var(--slate);margin:0 0 6px}
.detail-cap{font-size:13px;color:var(--muted);white-space:pre-line}
.specs{margin-top:34px}
.specs h2{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;font-family:"Roboto Mono",monospace;margin:0;padding-bottom:10px;border-bottom:2px solid var(--blue)}
.spec-row{display:grid;grid-template-columns:230px 1fr;gap:24px;padding:14px 2px;border-bottom:1px solid var(--line)}
.spec-label{font-weight:500;color:var(--ink);font-size:14px}
.spec-val{color:var(--slate);white-space:pre-line;font-family:"Roboto Mono",monospace;font-size:14px}
.note{margin-top:26px;padding:14px 16px;background:#eef4fc;border:1px solid #cfe0f6;border-left:3px solid var(--blue);border-radius:8px;font-size:14px;color:#23425f;white-space:pre-line}
@media(max-width:760px){.cat-search{flex-basis:100%;max-width:none}.detail-top{grid-template-columns:1fr;gap:22px}.spec-row{grid-template-columns:1fr;gap:2px}}

/* ============ request-a-quote (RFQ) ============ */
.qbadge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:8px;border-radius:9px;background:#fff;color:var(--blue);font-size:11.5px;font-weight:700;font-family:"Roboto Mono",monospace}
.card-foot{margin-top:auto;padding-top:11px}
.add-btn{width:100%;border:1px solid #cfe0f6;background:#fff;color:var(--blue-d);font-weight:500;font-size:14px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:all .14s;font-family:inherit}
.add-btn:hover{background:#eef4fc;border-color:var(--blue)}
.add-btn.on{background:var(--blue);border-color:var(--blue);color:#fff}
.add-lg{width:auto;padding:12px 22px;font-size:14.5px}
.detail-actions{display:flex;align-items:center;gap:18px;margin-top:24px;flex-wrap:wrap}
.q-link{background:none;border:none;color:var(--slate);cursor:pointer;font-size:14px;text-decoration:underline;font-family:inherit}
.q-link:hover{color:var(--blue)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(10,24,47,.5);backdrop-filter:blur(2px);z-index:60;animation:qfade .2s ease}
@keyframes qfade{from{opacity:0}to{opacity:1}}
.q-clip{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:61}
.drawer{position:absolute;top:0;right:0;bottom:0;width:420px;max-width:92vw;background:#fff;pointer-events:auto;display:flex;flex-direction:column;box-shadow:-24px 0 60px rgba(10,24,47,.28);transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}
.drawer.open{transform:none}
.q-head{display:flex;align-items:flex-start;gap:14px;padding:22px 22px 18px;border-bottom:1px solid var(--line)}
.q-head h2{margin:0;font-size:20px}
.q-sub{margin:5px 0 0;font-size:13px;color:var(--muted);line-height:1.5}
.q-close{margin-left:auto;background:none;border:none;font-size:26px;line-height:1;color:var(--muted);cursor:pointer;padding:0 2px}
.q-close:hover{color:var(--ink)}
.q-scroll{flex:1;overflow-y:auto;padding:18px 22px}
.q-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.q-item{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:10px;padding:9px 10px}
.q-thumb{width:46px;height:46px;border-radius:7px;background:#f1f5fa center/contain no-repeat;border:1px solid var(--line);flex:none}
.q-meta{min-width:0;flex:1}
.q-name{font-size:14px;font-weight:500;line-height:1.25}
.q-pn{font-size:13px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.q-rm{background:none;border:none;color:#b6c3d1;font-size:20px;line-height:1;cursor:pointer;flex:none;padding:0 4px}
.q-rm:hover{color:#d93025}
.q-empty{text-align:center;color:var(--muted);padding:30px 10px}
.q-empty-ic{width:44px;height:44px;border-radius:50%;border:2px dashed #c5d4e6;color:#9fb4cd;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 12px}
.q-empty .sub{font-size:13px;margin-top:4px}
.q-form{margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.q-form h3{margin:0 0 12px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-family:"Roboto Mono",monospace}
.q-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.q-form label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--slate);font-weight:500}
.q-form .q-full{margin-top:11px}
.q-form input,.q-form textarea{border:1px solid #d4dde6;border-radius:8px;padding:9px 11px;font-size:16px;font-family:inherit;color:var(--ink);outline:none;background:#fff}
.q-form input:focus,.q-form textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,120,230,.13)}
.q-form textarea{resize:vertical}
.q-foot{display:flex;align-items:center;gap:14px;padding:15px 22px;border-top:1px solid var(--line);background:var(--bg2)}
.q-foot-n{font-size:13px;color:var(--slate)}
.q-foot .btn{margin-left:auto}
.q-foot .btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.q-success{text-align:center;padding:34px 18px}
.q-check{width:56px;height:56px;border-radius:50%;background:var(--blue);color:#fff;font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.q-success h3{margin:0 0 8px;font-size:20px}
.q-success p{font-size:14px;color:var(--slate);margin:0 auto 20px;max-width:300px;line-height:1.6}
.q-mini-label{display:none}
@media(max-width:680px){.drawer{width:100%;max-width:100%}.q-grid{grid-template-columns:1fr}}
/* catalog nav: quote button collapses to compact "Quote" + green corner-flag at the SAME ≤900 breakpoint as the rest of the nav (matches site.css). Phone-only layout (drawer/form-grid) stays at ≤680 above. */
@media(max-width:900px){.nav-cta .quote-open{display:inline-flex}.q-full-label{display:none}.q-mini-label{display:inline}.nav-cta{gap:8px}
  /* items-in-quote shown as a small green corner flag, not a width-changing number */
  .quote-open{position:relative;overflow:hidden}
  .qbadge{position:absolute;top:0;right:0;margin:0;padding:0;min-width:0;width:15px;height:15px;border-radius:0;background:#22c55e;font-size:0;clip-path:polygon(100% 0,0 0,100% 100%)}}

/* ===== authorized-customer account mode (private ?c= link) ===== */
body[data-mode="public"] .quote-open{display:none !important}   /* public/lookyloo: no quote path */
body[data-mode="account"] .browse-cta{display:none}            /* account mode shows the order button in that slot instead */
/* price - card */
.price{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;margin-top:2px}
.price-list{text-decoration:line-through;color:var(--muted);font-size:13px;font-family:"Roboto Mono",monospace}
.price-you{color:var(--blue);font-weight:700;font-size:18px;font-family:"Roboto Mono",monospace}
.price-off{background:#e7f6ee;color:var(--ok-d);font-weight:700;font-size:11px;padding:2px 7px;border-radius:5px;font-family:"Roboto Mono",monospace}
.price-qty{flex-basis:100%;font-size:12.5px;color:var(--muted);font-family:"Roboto Mono",monospace}
.price-qty b{color:var(--slate)}
/* price - detail */
.price-lg{border:1px solid var(--line);border-radius:10px;overflow:hidden;max-width:340px;margin:6px 0 2px;background:#fff}
.price-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:none}
.pl-label{font-size:13px;color:var(--slate);width:74px;flex:none}
.price-row .price-list{font-size:14px}
.price-row .price-you{font-size:20px}
.price-qtyv{font-family:"Roboto Mono",monospace;font-size:14px;color:var(--ink)}
.price-note{font-size:12.5px;color:var(--muted);margin:8px 0 0}
.price-note.pub{margin:18px 0 0;padding:11px 14px;background:var(--bg2);border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:8px;color:var(--slate);font-size:13.5px;max-width:430px}
/* drawer line price + subtotal */
.q-line-pr{font-size:14px;color:var(--blue);font-weight:700;font-family:"Roboto Mono",monospace;white-space:nowrap;flex:none}
.q-sum{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:14px;padding-top:13px;border-top:1px dashed var(--line)}
.q-sum b{font-size:19px;color:var(--blue);font-family:"Roboto Mono",monospace;flex:none}
.q-sum-note{font-size:12px;color:var(--muted);font-weight:400}

/* ============================================================
   PREMIUM PASS — catalog + account-mode elevation (catalog-scoped).
   Synthesis of 3 design directions: precision-instrument depth +
   SaaS-grade polish + heritage-industrial brass accent. Additive +
   load-order-safe; the homepage does not load this file. Brass = signature.
   ============================================================ */
:root{
  --hair:#eef2f7;
  --plate:#0b1730; --navy-ink:#070f1f; --plate-2:#0f2140;
  --brass:#c79a4b; --brass-l:#e2bd73; --brass-glow:rgba(199,154,75,.30);
  --ok-d:#0a7d49; --ok-bg:#e7f6ee;
  --ring:0 0 0 3px rgba(31,120,230,.18);
  --e1:0 1px 2px rgba(10,24,47,.05);
  --e2:0 2px 6px rgba(10,24,47,.05),0 10px 24px rgba(10,24,47,.08);
  --e3:0 14px 30px rgba(10,24,47,.12),0 4px 10px rgba(10,24,47,.06);
  --ease:cubic-bezier(.4,0,.2,1); --ease-out:cubic-bezier(.16,1,.3,1);
  --grid-line:rgba(255,255,255,.05);
}
.pn,.price-you,.price-list,.price-off,.price-qty,.price-qtyv,.spec-val,
.q-line-pr,.q-sum b,.pl-label{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}
::selection{background:rgba(31,120,230,.16);color:var(--ink)}

/* ---- catalog header: instrument faceplate ---- */
.cat-head{position:relative;overflow:hidden;border-bottom:1px solid var(--brass);
  background:radial-gradient(900px 360px at 82% -40%,rgba(31,120,230,.24),transparent 60%),linear-gradient(180deg,var(--navy-ink),var(--plate))}
.cat-head::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:42px 42px;-webkit-mask-image:radial-gradient(720px 320px at 80% 0,#000,transparent 72%);mask-image:radial-gradient(720px 320px at 80% 0,#000,transparent 72%);opacity:.6;pointer-events:none}
.cat-head .wrap{position:relative;padding:28px 28px 24px}
.cat-head .kick{color:var(--brass-l);font-weight:700;letter-spacing:.2em}
.cat-head h1{color:#fff;font-size:clamp(26px,4vw,36px);letter-spacing:-.02em}
.serial{margin:13px 0 0;display:inline-flex;align-items:center;gap:10px;font-family:"Roboto Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--brass-l);text-transform:uppercase;font-weight:600}
.serial::before{content:"";width:30px;height:1px;background:var(--brass);flex:none}
.cat-search svg{color:#7e93ad}
#q{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:11px;transition:border-color .16s,background .16s,box-shadow .16s}
#q::placeholder{color:#90a4bd}
#q:focus{border-color:var(--brass);background:rgba(255,255,255,.10);box-shadow:0 0 0 3px var(--brass-glow)}
.cat-search:focus-within svg{color:var(--brass-l)}

/* ---- chips: machined filter rail ---- */
.chip{border-radius:8px;font-size:13.5px;box-shadow:var(--e1);transition:all .14s var(--ease)}
.chip:hover{border-color:#c4d8f1;color:var(--ink);transform:translateY(-1px)}
.chip.on{background:var(--navy3);border-color:var(--navy3);color:#fff;box-shadow:0 4px 12px rgba(10,24,47,.2),inset 0 -2px 0 var(--brass)}
.chip.on .n{color:var(--brass-l);opacity:1}

/* ---- cards: spec-sheet tiles, brass datum edge ---- */
.grid{gap:20px}
.card{border-radius:12px;box-shadow:var(--e1);position:relative;background:linear-gradient(180deg,#fff,#fbfcfe);transition:transform .2s var(--ease-out),box-shadow .2s var(--ease),border-color .2s var(--ease)}
.card::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .26s var(--ease-out);z-index:2;border-radius:12px 12px 0 0}
.card:hover{transform:translateY(-4px);box-shadow:var(--e3);border-color:#cdd9e6}
.card:hover::after{transform:scaleX(1)}
.card-body{gap:9px}
.card-cat{font-size:11px;letter-spacing:.09em}
.card-name{font-size:15.5px;font-weight:600;letter-spacing:-.005em}
.card-desc{font-size:13.5px}
.pn{background:#f1f4f9;border:1px solid #e1e9f2;color:#1c3a5c;border-radius:5px;font-size:12px}

/* ---- per-card price tile ---- */
.price{margin-top:10px;padding:10px 12px;background:linear-gradient(180deg,#fff,#f7faff);border:1px solid var(--line);border-radius:10px;gap:6px 8px;box-shadow:inset 0 1px 0 #fff}
.price-list{font-size:12.5px}
.price-you{font-size:19px;line-height:1.05;letter-spacing:-.01em;color:var(--navy3)}
.price-off{background:var(--ok-bg);color:var(--ok-d);border:1px solid #c7ecd6;font-size:10.5px;align-self:center}
.price-qty{flex-basis:100%;margin-top:2px;padding-top:7px;border-top:1px dashed var(--line);font-size:12px;color:var(--muted)}
.price-qty b{color:var(--ink)}

/* ---- detail: datasheet ---- */
.detail-figure{border:1px solid var(--line);border-radius:12px;box-shadow:var(--e2);background:radial-gradient(420px 200px at 50% 0,rgba(31,120,230,.05),transparent 70%),#fff;padding:28px}
.detail-cat{letter-spacing:.09em}
.detail h1{font-size:clamp(23px,3.2vw,30px)}
.detail-desc{font-size:16px;color:var(--ink)}
.specs{margin-top:34px;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--e1)}
.specs h2{margin:0;padding:12px 18px;background:var(--bg2);border-bottom:2px solid var(--brass);color:var(--ink);letter-spacing:.13em}
.spec-row{grid-template-columns:240px 1fr;gap:24px;padding:13px 18px;border-bottom:1px solid var(--hair);align-items:baseline;transition:background .12s}
.spec-row:hover{background:#fbfdff}
.spec-row:last-child{border-bottom:none}
.spec-label{color:var(--ink);font-weight:600;font-size:13.5px}
.spec-val{color:var(--navy3);font-size:13.5px}
.note{background:#fbf6ec;border:1px solid #ecdcb8;border-left:3px solid var(--brass);color:#5a4a26;border-radius:8px}

/* ---- detail price plate (the readout) ---- */
.price-lg{max-width:380px;border:1px solid var(--line);border-radius:12px;box-shadow:var(--e2);background:linear-gradient(180deg,#fff,#fafcff);overflow:hidden}
.price-lg::before{content:"Account pricing";display:block;font-family:"Roboto Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:9px 16px;background:var(--bg2);border-bottom:1px solid var(--line)}
.price-row{padding:12px 16px;gap:12px;border-bottom:1px solid var(--hair)}
.price-row:last-child{border-bottom:none}
.pl-label{width:78px;color:var(--muted);font-family:"Roboto Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.price-row .price-list{font-size:14px;margin-left:auto}
.price-row .price-you{font-size:24px;margin-left:auto;color:var(--navy-ink)}
.price-row .price-off{margin-left:8px}
.price-qtyv{margin-left:auto;font-size:14px;color:var(--ink)}
.price-row:nth-child(2){background:linear-gradient(90deg,rgba(199,154,75,.07),transparent);box-shadow:inset 3px 0 0 var(--brass)}
.price-note{font-size:12px;color:var(--muted)}
.price-note.pub{margin:18px 0 0;padding:11px 14px;background:var(--bg2);border:1px solid var(--line);border-left:3px solid var(--brass);border-radius:8px;color:var(--slate);font-size:13.5px;max-width:430px}

/* ---- buttons + quote drawer ---- */
.add-btn{border-radius:9px;border-color:#d2e2f5;color:var(--blue-d);font-weight:600;transition:all .15s var(--ease)}
.add-btn:hover{background:#f0f6fe;border-color:var(--blue);box-shadow:var(--e1)}
.add-btn:active{transform:translateY(1px)}
.add-btn.on{background:var(--navy3);border-color:var(--navy3);color:#fff;box-shadow:inset 2px 0 0 var(--brass)}
.drawer{width:440px;box-shadow:-30px 0 80px rgba(10,24,47,.32);transition:transform .42s var(--ease-out)}
.q-head{background:linear-gradient(180deg,#f7faff,#fff)}
.q-item{box-shadow:var(--e1);transition:border-color .14s,box-shadow .14s}
.q-item:hover{border-color:#cfe0f6;box-shadow:var(--e2)}
.q-line-pr{font-size:14.5px;color:var(--navy3)}
.q-rm:hover{color:#d93025}
.q-sum{background:linear-gradient(180deg,#fff,#f7faff);border:1px solid var(--line);border-radius:12px;padding:14px;box-shadow:var(--e1);border-top:1px solid var(--line)}
.q-sum b{font-size:22px;color:var(--navy-ink);letter-spacing:-.01em}
.q-foot{box-shadow:0 -1px 0 var(--line),0 -10px 24px rgba(10,24,47,.06)}

/* ---- mobile safety ---- */
@media(max-width:520px){
  .cat-head .wrap{padding:30px 16px 26px}
  .serial{font-size:10px;letter-spacing:.16em}
  .cat-main{padding:24px 16px 60px}
  .spec-row{grid-template-columns:1fr;gap:3px;padding:12px 14px}
  .price-row .price-you{font-size:21px}
}

/* ---- type sizing: err larger (feedback: too many fonts too small). Readable >=14, data labels >=12. ---- */
.cat-head .kick{font-size:12.5px}
.serial{font-size:12px}
.chip{font-size:14.5px}
.chip .n{font-size:12.5px}
.result-bar{font-size:14.5px}
.card-cat,.detail-cat{font-size:12px}
.card-name{font-size:16px}
.card-desc{font-size:14.5px}
.pn{font-size:13px}
.detail-desc{font-size:16.5px}
.detail-cap{font-size:14px}
.spec-label{font-size:14.5px}
.spec-val{font-size:14.5px}
.price-list{font-size:13.5px}
.price-you{font-size:20px}
.price-off{font-size:11.5px}
.price-qty{font-size:13px}
.pl-label{font-size:12.5px}
.price-lg::before{font-size:11.5px}
.price-row .price-list{font-size:15px}
.price-row .price-you{font-size:25px}
.price-qtyv{font-size:15px}
.price-note{font-size:13px}
.price-note.pub{font-size:14.5px}
.q-sub{font-size:13.5px}
.q-name{font-size:14.5px}
.q-line-pr{font-size:15px}
.q-sum-note{font-size:12.5px}
@media(max-width:520px){
  .serial{font-size:11px}
  .price-row .price-you{font-size:22px}
}

/* ---- card typography: calmer + aligned (prose=sans, data=mono; ~5 sizes, fewer colors) ---- */
.card-cat{font-family:Roboto,system-ui,sans-serif;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--slate)}
.card-name{font-size:16px;font-weight:600;color:var(--ink)}
.card-desc{font-size:14px;color:var(--muted)}
.card .pn{font-size:13px;color:var(--ink)}
.card .price{margin-top:auto;padding:12px 0 0;border:none;border-top:1px solid var(--line);border-radius:0;background:none;box-shadow:none;display:block}
.card .price-row1{display:flex;align-items:baseline;gap:7px}
.card .price-you{font-family:"Roboto Mono",monospace;font-size:21px;font-weight:700;color:var(--ink);letter-spacing:-.01em;margin-left:auto}
.card .price-list{font-family:"Roboto Mono",monospace;font-size:13px;font-weight:400;color:var(--muted);text-decoration:line-through;background:none;border:none;padding:0}
.card .price-off{font-family:"Roboto Mono",monospace;font-size:13px;font-weight:600;color:var(--ok-d);background:none;border:none;padding:0;align-self:baseline}
.card .price-qty{display:flex;align-items:baseline;justify-content:space-between;gap:10px;font-family:"Roboto Mono",monospace;font-size:13px;font-weight:400;margin-top:6px}
.card .qlabel{color:var(--muted)}
.card .qval{color:var(--ink)}

/* ---- detail price block: same clean baseline language as the cards, sized up (was a boxed readout) ---- */
.detail-price{max-width:340px;margin:16px 0 2px;padding-top:14px;border-top:1px solid var(--line)}
.detail-price .price-row1{display:flex;align-items:baseline;gap:9px}
.detail-price .price-list{font-family:"Roboto Mono",monospace;font-size:15px;font-weight:400;color:var(--muted);text-decoration:line-through;background:none;border:none;padding:0}
.detail-price .price-off{font-family:"Roboto Mono",monospace;font-size:15px;font-weight:600;color:var(--ok-d);background:none;border:none;padding:0;align-self:baseline}
.detail-price .price-you{font-family:"Roboto Mono",monospace;font-size:27px;font-weight:700;color:var(--ink);letter-spacing:-.01em;margin-left:auto}
.detail-price .price-qty{display:flex;align-items:baseline;justify-content:space-between;gap:10px;font-family:"Roboto Mono",monospace;font-size:14px;font-weight:400;margin-top:9px}
.detail-price .qlabel{color:var(--muted)}
.detail-price .qval{color:var(--ink)}

/* nudge the two section labels off the 12px floor (err larger; they read as headings) */
.specs h2,.q-form h3{font-size:13px}

/* ---- quote line items: quantity stepper + live line totals ---- */
.q-item{align-items:flex-start}
.q-meta{flex:1;min-width:0}
.q-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.q-name{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.3}
.q-pn{font-size:12.5px;color:var(--muted);margin-top:2px}
.q-line{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.q-qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:8px;overflow:hidden;flex:none}
.q-step{width:30px;height:30px;border:none;background:var(--bg2);color:var(--ink);font-size:17px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.q-step:hover{background:#e7eef7}
.q-qin{width:44px;height:30px;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font-size:16px;color:var(--ink);background:#fff;outline:none;-moz-appearance:textfield;padding:0}
.q-qin::-webkit-outer-spin-button,.q-qin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.q-amt{display:flex;flex-direction:column;align-items:flex-end;line-height:1.3;flex:none}
.q-amt .q-unit{font-size:12px;color:var(--muted)}
.q-amt .q-unit.vol{color:var(--ok-d);font-weight:600}
.q-amt .q-line-pr{font-size:15px;font-weight:700;color:var(--ink)}
.q-rm{flex:none;margin:-2px -2px 0 0}
.q-refline{font-family:"Roboto Mono",monospace;font-size:13px;color:var(--muted);margin:0 0 10px}
.q-refline .q-ref{color:var(--ink)}
.price-note.pub{width:fit-content;max-width:100%;text-wrap:balance}   /* box hugs the text, not a fixed-width slab */
.card .card-foot{margin-top:12px;padding-top:0}
.card .add-btn{font-size:14px}

/* audit: larger touch targets on phones */
@media(max-width:680px){
  .add-btn{padding:11px 12px}
  .chip{padding:9px 14px}
  .q-step{width:36px;height:36px}
  .q-qin{height:36px}
}
