/* /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/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 */
  --ink:#14181f; --soft:#5b6270;
  --g50:#f8f9fa; --g100:#eef0f2; --g300:#d4d8dd; --g500:#6b7280; --g700:#374151;
  --edge:#e3e6ea; --radius:12px; --radius-sm:8px;
}

/* ------------------------------ 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-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 10px 30px rgba(20,24,31,.12);
  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); }
.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]{
  --c:#3a6ea5;
  width:min(680px,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 #eef0f2; 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:#14181f; }
.cmodal-titles p[b-ji5xu0ul9r]{ margin:.15rem 0 0; font-size:.8rem; color:#6b7280; }
.cmodal-close[b-ji5xu0ul9r]{
  position:absolute; top:.6rem; right:.7rem; width:2rem; height:2rem;
  border:0; border-radius:50%; background:#eef0f2; color:#374151;
  font-size:1.3rem; line-height:1; cursor:pointer;
}
.cmodal-close:hover[b-ji5xu0ul9r]{ background:#d4d8dd; color:#14181f; }

.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:#6b7280;
  padding:.6rem 1.2rem; border-bottom:1px solid #e3e6ea; background:#f8f9fa;
}
.vtable td[b-ji5xu0ul9r]{ padding:.55rem 1.2rem; border-bottom:1px solid #eef0f2; color:#14181f; }
.vtable tr:last-child td[b-ji5xu0ul9r]{ border-bottom:0; }
.vtable tr:hover td[b-ji5xu0ul9r]{ background:#f8f9fa; }
.vtable .v-code[b-ji5xu0ul9r]{
  display:block; font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.72rem; color:#6b7280; margin-top:.1rem;
}
.vtable .v-price[b-ji5xu0ul9r]{ text-align:right; white-space:nowrap; font-weight:700; }
.vtable th.v-price[b-ji5xu0ul9r]{ text-align:right; }
.vtable .v-stock[b-ji5xu0ul9r]{ text-align:center; }
.vtable th.v-stock[b-ji5xu0ul9r]{ text-align:center; }
.vtable .noprice[b-ji5xu0ul9r]{ font-weight:600; color:#6b7280; font-style:italic; }

.cmodal-foot[b-ji5xu0ul9r]{ padding:.8rem 1.2rem 1.1rem; font-size:.78rem; color:#6b7280; }

@media (max-width:480px){
  .cmodal-thumb[b-ji5xu0ul9r]{ display:none; }
  .vtable th[b-ji5xu0ul9r], .vtable td[b-ji5xu0ul9r]{ padding-left:.9rem; padding-right:.9rem; }
}
