/* /Components/Layout/MainLayout.razor.rz.scp.css */
.page[b-i4cvv3bc03] {
    position: relative;
    display: flex;
    flex-direction: column;
}

main[b-i4cvv3bc03] {
    flex: 1;
}

.sidebar[b-i4cvv3bc03] {
    background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
}

.top-row[b-i4cvv3bc03] {
    background-color: #f7f7f7;
    border-bottom: 1px solid #d6d5d5;
    justify-content: flex-end;
    height: 3.5rem;
    display: flex;
    align-items: center;
}

    .top-row[b-i4cvv3bc03]  a, .top-row[b-i4cvv3bc03]  .btn-link {
        white-space: nowrap;
        margin-left: 1.5rem;
        text-decoration: none;
    }

    .top-row[b-i4cvv3bc03]  a:hover, .top-row[b-i4cvv3bc03]  .btn-link:hover {
        text-decoration: underline;
    }

    .top-row[b-i4cvv3bc03]  a:first-child {
        overflow: hidden;
        text-overflow: ellipsis;
    }

@media (max-width: 640.98px) {
    .top-row[b-i4cvv3bc03] {
        justify-content: space-between;
    }

    .top-row[b-i4cvv3bc03]  a, .top-row[b-i4cvv3bc03]  .btn-link {
        margin-left: 0;
    }
}

@media (min-width: 641px) {
    .page[b-i4cvv3bc03] {
        flex-direction: row;
    }

    .sidebar[b-i4cvv3bc03] {
        width: 250px;
        height: 100vh;
        position: sticky;
        top: 0;
    }

    .top-row[b-i4cvv3bc03] {
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .top-row.auth[b-i4cvv3bc03]  a:first-child {
        flex: 1;
        text-align: right;
        width: 0;
    }

    .top-row[b-i4cvv3bc03], article[b-i4cvv3bc03] {
        padding-left: 2rem !important;
        padding-right: 1.5rem !important;
    }
}

#blazor-error-ui[b-i4cvv3bc03] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss[b-i4cvv3bc03] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-oa1opl20xp],
.components-reconnect-repeated-attempt-visible[b-oa1opl20xp],
.components-reconnect-failed-visible[b-oa1opl20xp],
.components-pause-visible[b-oa1opl20xp],
.components-resume-failed-visible[b-oa1opl20xp],
.components-rejoining-animation[b-oa1opl20xp] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-retrying[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-failed[b-oa1opl20xp],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-oa1opl20xp] {
    display: block;
}


#components-reconnect-modal[b-oa1opl20xp] {
    background-color: white;
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 0;
    border-radius: 0.5rem;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: display 0.5s allow-discrete, overlay 0.5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity-b-oa1opl20xp 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-oa1opl20xp 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-oa1opl20xp 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-oa1opl20xp]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-oa1opl20xp 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-oa1opl20xp {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-oa1opl20xp {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-oa1opl20xp {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-oa1opl20xp] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-oa1opl20xp] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-oa1opl20xp] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-oa1opl20xp] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-oa1opl20xp] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-oa1opl20xp] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-oa1opl20xp] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-oa1opl20xp 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-oa1opl20xp] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-oa1opl20xp {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0px;
        left: 0px;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}
/* /Components/Pages/BStock.razor.rz.scp.css */
/* B-Stock deals — same card language as the catalogue (public palette),
   with the amber deal accent for the discount badge. */

.bs-wrap[b-2busxhyl8y]{
  --ink:#14202e; --soft:#566373;
  --g100:#eceff3; --g300:#c4ccd6; --g500:#7b8694;
  --edge:#e4e8ee; --radius:16px;
  --amber:#d97706;
}

.bs-head[b-2busxhyl8y]{ margin:0 0 1rem; }
.bs-h1[b-2busxhyl8y]{
  font-family:'Poppins','Segoe UI',sans-serif; font-weight:600;
  font-size:1.7rem; color:var(--ink); margin:0;
}
.bs-lead[b-2busxhyl8y]{ color:var(--soft); max-width:64ch; margin:.5rem 0 0; }

.bs-grid[b-2busxhyl8y]{
  margin:1.1rem 0 2rem;
  display:grid; gap:clamp(1rem,2.4vw,1.8rem);
  grid-template-columns:repeat(auto-fill, minmax(230px, 1fr));
}

.bcard[b-2busxhyl8y]{
  position:relative;
  display:flex; flex-direction:column; align-items:stretch;
  background:#fff; border:1px solid var(--edge);
  border-radius:var(--radius); overflow:hidden;
  text-align:center; color:inherit;
  transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.bcard:hover[b-2busxhyl8y]{
  box-shadow:0 6px 18px rgba(13,27,42,.10), 0 2px 6px rgba(13,27,42,.06);
  transform:translateY(-3px); border-color:var(--amber);
}

.bcard-pct[b-2busxhyl8y]{
  position:absolute; top:.6rem; left:.6rem; z-index:1;
  padding:.2rem .6rem; border-radius:999px;
  background:linear-gradient(180deg,#f59e0b,#d97706); color:#fff;
  font-weight:800; font-size:.85rem; letter-spacing:.02em;
  box-shadow:0 2px 6px rgba(13,27,42,.15);
}

.bcard-media[b-2busxhyl8y]{
  aspect-ratio:4/3; background:#fff;
  display:flex; align-items:center; justify-content:center; padding:1.1rem;
}
.bcard-media img[b-2busxhyl8y]{ max-width:100%; max-height:100%; object-fit:contain; transition:transform .25s ease; }
.bcard:hover .bcard-media img[b-2busxhyl8y]{ transform:scale(1.04); }
.bcard-noimg[b-2busxhyl8y]{ font-size:3rem; color:var(--g300); }

.bcard-body[b-2busxhyl8y]{
  padding:.5rem .8rem 1rem; border-top:1px solid var(--g100);
  display:flex; flex-direction:column; gap:.25rem; align-items:center;
}
.bcard-name[b-2busxhyl8y]{
  font-size:.92rem; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink); margin:.3rem 0 0;
}
.bcard-serial[b-2busxhyl8y]{
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.72rem; color:var(--g500);
}
.bcard-rrp[b-2busxhyl8y]{ font-size:.78rem; color:var(--g500); }
.bcard-rrp s[b-2busxhyl8y]{ color:var(--g500); }
.bcard-rrp b[b-2busxhyl8y]{ color:var(--ink); margin-left:.25rem; }
.bcard-from[b-2busxhyl8y]{
  font-size:.72rem; font-weight:600; color:var(--g500);
  text-transform:uppercase; letter-spacing:.05em; margin-top:.2rem;
}
.bcard-net[b-2busxhyl8y]{ font-size:1.15rem; font-weight:800; color:var(--amber); }
/* payment-term spread (2026-06-20): cheapest headline + caption + term-day line */
.bcard-early[b-2busxhyl8y]{ font-size:.66rem; font-weight:700; color:#1c7a44; text-transform:uppercase; letter-spacing:.04em; }
.bcard-later[b-2busxhyl8y]{ font-size:.74rem; font-weight:600; color:var(--g500); margin-bottom:.35rem; }
.bcard-noprice[b-2busxhyl8y]{ font-size:.92rem; font-weight:600; font-style:italic; color:var(--g500); margin:.4rem 0; }
/* /Components/Pages/Catalogue.razor.rz.scp.css */
/* ============================================================================
   Dealer card grid — ported from the public site's catalogue.css so the dealer
   portal and the public catalogue share ONE visual language. Self-contained:
   the portal has no styles.css :root palette, so the tokens are inlined here as
   concrete values. The brand accent arrives per-feed as the inline --c variable
   (set on .cat-wrap / .cmodal-panel from CatalogueFeed.brand.accent).
   ========================================================================== */

.cat-wrap[b-ji5xu0ul9r]{
  --c:#3a6ea5;                    /* overridden inline per brand accent */
  /* tokens = the public styles.css :root palette, value for value */
  --ink:#14202e; --soft:#566373;
  --g50:#f5f7fa; --g100:#eceff3; --g300:#c4ccd6; --g500:#7b8694; --g700:#404a57;
  --edge:#e4e8ee; --radius:16px; --radius-sm:11px;
}

/* ------- B-Stock entry (amber, above the brand tiles — public .btn--deal) */
.dealsbar[b-ji5xu0ul9r]{ margin:0 0 .9rem; }
.btn-deal[b-ji5xu0ul9r]{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.78rem 1.35rem; border-radius:11px;
  font-weight:700; font-size:.96rem; cursor:pointer; border:1px solid transparent;
  transition:.18s; white-space:nowrap; text-decoration:none;
  background:linear-gradient(180deg,#f59e0b,#d97706);
  color:#fff; box-shadow:0 6px 18px rgba(13,27,42,.10), 0 2px 6px rgba(13,27,42,.06);
}
.btn-deal:hover[b-ji5xu0ul9r]{ filter:brightness(1.07); transform:translateY(-1px); }

/* ------- brand tiles (brand-first nav, public .brandtabs/.brandchip) ----- */
.brandtabs[b-ji5xu0ul9r]{
  margin:0 0 .9rem;
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(.45rem,1.5vw,.8rem);
}
@media (min-width:760px){
  .brandtabs[b-ji5xu0ul9r]{ grid-template-columns:repeat(4,160px); }   /* cap tile size on desktop */
}
.brandchip[b-ji5xu0ul9r]{
  font:inherit; font-weight:700; font-size:.88rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  min-height:52px; padding:.5rem .55rem; border-radius:14px;
  border:2px solid var(--g300);
  background:#fff; color:var(--chip, var(--g700));
  transition:border-color .15s, box-shadow .15s;
}
.brandchip img[b-ji5xu0ul9r]{
  max-width:100%; max-height:30px; display:block;
  filter:grayscale(1) opacity(.5);
  transition:filter .15s;
}
.brandchip:hover[b-ji5xu0ul9r]{ box-shadow:0 2px 10px rgba(0,0,0,.12); }
.brandchip:hover img[b-ji5xu0ul9r]{ filter:none; }
.brandchip.active[b-ji5xu0ul9r]{
  border-color:var(--chip, #2f74e0);
  box-shadow:0 2px 12px rgba(0,0,0,.10);
}
.brandchip.active img[b-ji5xu0ul9r]{ filter:none; }
/* text fallback (no logo file for the brand): dot + name pill */
.brandchip-text[b-ji5xu0ul9r]::before{
  content:""; width:.7rem; height:.7rem; border-radius:50%;
  background:var(--chip, #3a6ea5); flex:none; margin-right:.5rem;
}
.brandchip-text.active[b-ji5xu0ul9r]{ background:var(--chip, #2f74e0); color:#fff; }
.brandchip-text.active[b-ji5xu0ul9r]::before{ background:#fff; }

/* ------------------------------ page header ----------------------------- */
.cat-head[b-ji5xu0ul9r]{ margin:0 0 .4rem; }
.cat-titles[b-ji5xu0ul9r]{ display:flex; align-items:center; gap:.7rem; flex-wrap:wrap; }
.cat-dot[b-ji5xu0ul9r]{ width:1rem; height:1rem; border-radius:50%; background:var(--c); flex:none; }
.cat-h1[b-ji5xu0ul9r]{ color:var(--ink); }
.cat-cat[b-ji5xu0ul9r]{
  font-size:1rem; font-weight:600; color:var(--g700);
  padding:.2rem .7rem; background:var(--g100); border-radius:999px;
}
.cat-lead[b-ji5xu0ul9r]{ color:var(--soft); max-width:64ch; margin:.5rem 0 0; }

/* --------------------------- category tab strip ------------------------- */
.cattabs[b-ji5xu0ul9r]{ display:flex; flex-wrap:wrap; gap:.5rem; margin:.9rem 0 0; }
.cattab[b-ji5xu0ul9r]{
  font:inherit; font-weight:600; font-size:.9rem; cursor:pointer;
  padding:.45rem 1rem; border-radius:999px;
  border:1px solid var(--g300); background:var(--g50); color:var(--g700);
  transition:background .15s, color .15s, border-color .15s;
}
.cattab:hover[b-ji5xu0ul9r]{ border-color:var(--c); color:var(--ink); }
.cattab.active[b-ji5xu0ul9r]{ background:var(--c); border-color:var(--c); color:#fff; }

/* ------------------------------ filter bar ------------------------------ */
.cat-filters[b-ji5xu0ul9r]{ display:flex; flex-wrap:wrap; gap:.7rem 1rem; align-items:center; margin:1rem 0 0; }
.cat-search[b-ji5xu0ul9r]{
  flex:1 1 260px; max-width:360px; padding:.6rem .75rem; font:inherit;
  border:1px solid var(--g300); border-radius:var(--radius-sm);
  background:var(--g50); color:var(--ink);
}
.cat-search:focus[b-ji5xu0ul9r]{ outline:2px solid var(--c); outline-offset:1px; background:#fff; }
.cat-listhead[b-ji5xu0ul9r]{ margin-left:auto; font-size:.78rem; font-weight:700; color:var(--soft); }

/* ------------------------------- card grid ------------------------------ */
.cat-grid[b-ji5xu0ul9r]{
  margin:1.1rem 0 2rem;
  display:grid; gap:clamp(1rem,2.4vw,1.8rem);
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
}
.cat-empty[b-ji5xu0ul9r]{ grid-column:1/-1; padding:1.6rem 1.1rem; color:var(--soft); font-size:.95rem; }

.pcard[b-ji5xu0ul9r]{
  display:flex; flex-direction:column; align-items:stretch;
  background:#fff; border:1px solid var(--edge);
  border-radius:var(--radius); overflow:hidden; cursor:pointer;
  font:inherit; text-align:center; color:inherit; padding:0;
  transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.pcard:hover[b-ji5xu0ul9r]{
  box-shadow:0 6px 18px rgba(13,27,42,.10), 0 2px 6px rgba(13,27,42,.06);
  transform:translateY(-3px); border-color:var(--c);
}
.pcard:focus-visible[b-ji5xu0ul9r]{ outline:2px solid var(--c); outline-offset:2px; }

.pcard-media[b-ji5xu0ul9r]{
  position:relative; aspect-ratio:4/3; background:#fff;
  display:flex; align-items:center; justify-content:center; padding:1.1rem;
}
.pcard-media img[b-ji5xu0ul9r]{ max-width:100%; max-height:100%; object-fit:contain; transition:transform .25s ease; }
.pcard:hover .pcard-media img[b-ji5xu0ul9r]{ transform:scale(1.04); }
.pcard-noimg[b-ji5xu0ul9r]{ font-size:3rem; color:var(--g300); }

.pcard-body[b-ji5xu0ul9r]{
  padding:.5rem .8rem 1rem; border-top:1px solid var(--g100);
  display:flex; flex-direction:column; gap:.2rem;
}
.pcard-name[b-ji5xu0ul9r]{
  font-size:.92rem; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink); margin:.3rem 0 .1rem;
}
.pcard-from[b-ji5xu0ul9r]{ font-size:.72rem; font-weight:600; color:var(--g500); text-transform:uppercase; letter-spacing:.05em; }
.pcard-price[b-ji5xu0ul9r]{ font-size:1.05rem; font-weight:700; color:var(--ink); }
.pcard-noprice[b-ji5xu0ul9r]{ font-size:.92rem; font-weight:600; font-style:italic; color:var(--g500); }
.pcard-rrp[b-ji5xu0ul9r]{ font-size:.72rem; font-weight:600; color:var(--g500); }
/* payment-term spread (2026-06-20): headline = cheapest, caption + term-day line */
.pcard-early[b-ji5xu0ul9r]{ font-size:.66rem; font-weight:700; color:#1c7a44; text-transform:uppercase; letter-spacing:.04em; }
.pcard-later[b-ji5xu0ul9r]{ font-size:.74rem; font-weight:600; color:var(--g500); }
.pcard-foot[b-ji5xu0ul9r]{ display:flex; gap:.5rem; align-items:center; justify-content:center; flex-wrap:wrap; margin-top:.4rem; }
.pcard-count[b-ji5xu0ul9r]{ font-size:.72rem; font-weight:600; color:var(--g500); }

.chip[b-ji5xu0ul9r]{ font-size:.7rem; font-weight:700; padding:.15rem .55rem; border-radius:999px; letter-spacing:.03em; }
.chip-stock[b-ji5xu0ul9r]{ background:#e6f5ec; color:#1c7a44; }

/* -------------------------------- modal --------------------------------- */
.cmodal[b-ji5xu0ul9r]{
  position:fixed; inset:0; z-index:1400; display:flex;
  align-items:center; justify-content:center; padding:clamp(.8rem,3vw,2rem);
  background:rgba(18,22,28,.55);
}
.cmodal-panel[b-ji5xu0ul9r]{
  /* .cmodal is a sibling of .cat-wrap, so the tokens are re-declared here */
  --c:#3a6ea5; --radius:16px; --edge:#e4e8ee;
  /* 1040px, not the public site's 680: the dealer table carries two extra
     columns (your net + the qty/Add order column) that don't fit in 680.
     On a narrow window the panel caps at 100% and the long price/VAT headers
     wrap (see below) so the Option name keeps its own line instead of being
     crushed to one word per line. */
  width:min(1040px,100%); max-height:90vh; overflow:auto;
  background:#fff; border-radius:var(--radius); box-shadow:0 24px 60px rgba(0,0,0,.3);
  border-top:4px solid var(--c);
}
.cmodal-head[b-ji5xu0ul9r]{
  display:flex; gap:1rem; align-items:center; padding:1.1rem 1.2rem;
  border-bottom:1px solid var(--edge); position:relative;
}
.cmodal-thumb[b-ji5xu0ul9r]{
  width:90px; height:68px; flex:none; background:#fff;
  display:flex; align-items:center; justify-content:center;
  border:1px solid #eceff3; border-radius:8px; padding:.3rem;
}
.cmodal-thumb img[b-ji5xu0ul9r]{ max-width:100%; max-height:100%; object-fit:contain; }
.cmodal-titles h2[b-ji5xu0ul9r]{ font-size:1.3rem; margin:0; color:#14202e; }
.cmodal-titles p[b-ji5xu0ul9r]{ margin:.15rem 0 0; font-size:.8rem; color:#7b8694; }
.cmodal-close[b-ji5xu0ul9r]{
  position:absolute; top:.6rem; right:.7rem; width:2rem; height:2rem;
  border:0; border-radius:50%; background:#eceff3; color:#404a57;
  font-size:1.3rem; line-height:1; cursor:pointer;
}
.cmodal-close:hover[b-ji5xu0ul9r]{ background:#c4ccd6; color:#14202e; }

.vtable[b-ji5xu0ul9r]{ width:100%; border-collapse:collapse; font-size:.92rem; }
.vtable th[b-ji5xu0ul9r]{
  text-align:left; font-size:.7rem; font-weight:700; letter-spacing:.05em;
  text-transform:uppercase; color:#7b8694;
  padding:.6rem 1.2rem; border-bottom:1px solid #e4e8ee; background:#f5f7fa;
}
.vtable td[b-ji5xu0ul9r]{ padding:.55rem 1.2rem; border-bottom:1px solid #eceff3; color:#14202e; }
.vtable tr:last-child td[b-ji5xu0ul9r]{ border-bottom:0; }
.vtable tr:hover td[b-ji5xu0ul9r]{ background:#f5f7fa; }
.vtable .v-code[b-ji5xu0ul9r]{
  display:block; font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.72rem; color:#7b8694; margin-top:.1rem;
}
/* The Option name (+ its code on the line below) stays on its own line: a
   nowrap cell takes its min-content from the longest single line, never from
   the longest word, so "Rega Brio MK7" / "AMP-BRIO-MK7-EU" no longer break
   per word. The long price/VAT *headers* are allowed to wrap to two lines so
   they don't force the table wider than a narrow dealer window — the values
   themselves never wrap. */
.vtable .v-name[b-ji5xu0ul9r]{ min-width:14ch; white-space:nowrap; }
.vtable td.v-price[b-ji5xu0ul9r]{ text-align:right; white-space:nowrap; font-weight:700; }
.vtable th.v-price[b-ji5xu0ul9r]{ text-align:right; white-space:normal; }
.vtable .v-stock[b-ji5xu0ul9r]{ text-align:center; }
.vtable th.v-stock[b-ji5xu0ul9r]{ text-align:center; }
/* Rega pre-order ETA under the out-of-stock indicator (amber = incoming) */
.vtable .v-eta[b-ji5xu0ul9r]{ margin-top:3px; font-size:.72rem; line-height:1.15; color:#9a6a00; font-weight:600; white-space:normal; }
.vtable .v-cart[b-ji5xu0ul9r]{ white-space:nowrap; text-align:right; }
.vtable th.v-cart[b-ji5xu0ul9r]{ text-align:right; }

/* ------- qty stepper (modal Order column — caddy add, default 1) --------- */
.qtybox[b-ji5xu0ul9r]{
  display:inline-flex; align-items:center; vertical-align:middle;
  margin-right:.45rem; border:1px solid #c4ccd6; border-radius:999px;
  overflow:hidden; background:#fff;
}
.qbtn[b-ji5xu0ul9r]{
  width:26px; height:26px; border:0; background:#f5f7fa; color:#404a57;
  font:inherit; font-weight:700; line-height:1; cursor:pointer;
}
.qbtn:hover[b-ji5xu0ul9r]{ background:#eceff3; color:#14202e; }
.qinput[b-ji5xu0ul9r]{
  width:44px; border:0; text-align:center; font:inherit; font-weight:700;
  color:#14202e; appearance:textfield; -moz-appearance:textfield;
}
.qinput:focus[b-ji5xu0ul9r]{ outline:none; background:#f5f7fa; }
.qinput[b-ji5xu0ul9r]::-webkit-outer-spin-button, .qinput[b-ji5xu0ul9r]::-webkit-inner-spin-button{
  -webkit-appearance:none; margin:0;
}
.vtable .noprice[b-ji5xu0ul9r]{ font-weight:600; color:#7b8694; font-style:italic; }
/* payment-term spread in the net cell: the cheapest (<=8 d) is the hero; the
   term-day price is a small, muted footnote so the best price is what stands out */
.vtable .v-best[b-ji5xu0ul9r]{ font-size:1.02rem; color:#14202e; }
.vtable .v-sub[b-ji5xu0ul9r]{ display:block; font-size:.62rem; font-weight:600; color:#1c7a44; text-transform:uppercase; letter-spacing:.03em; }
.vtable .v-later[b-ji5xu0ul9r]{ margin-top:.05rem; font-size:.72rem; font-weight:500; color:#9aa3ad; white-space:nowrap; }

.cmodal-foot[b-ji5xu0ul9r]{ padding:.8rem 1.2rem 1.1rem; font-size:.78rem; color:#7b8694; }
.cmodal-foot-legend[b-ji5xu0ul9r]{ display:block; margin-top:.25rem; }

@media (max-width:480px){
  .cmodal-thumb[b-ji5xu0ul9r]{ display:none; }
  .vtable th[b-ji5xu0ul9r], .vtable td[b-ji5xu0ul9r]{ padding-left:.9rem; padding-right:.9rem; }
}
