/*
 * BusZilla — design system for the public portal and the B2B dashboard.
 *
 * Authoritative reference: docs/BusZilla_BrandBook_v1.0.pdf.
 * Two themes coexist in this stylesheet:
 *   - .theme-public  → public portal (yellow + navy + orange + cream, mascot accessoria)
 *   - .theme-b2b     → B2B dashboard  (navy + orange + grey + white, mascot ASSENTE)
 *
 * Hand-written CSS, no build step. Loaded BEFORE any Tailwind Play CDN script so
 * Tailwind utilities (when reachable) can still override on top.
 */

/* ------------------------------------------------------------------
 * 1. Tokens (brand book v1.0)
 * ------------------------------------------------------------------ */
:root {
    /* Primary palette */
    --bz-yellow:       #FFC107;
    --bz-yellow-soft:  #FFE082;
    --bz-yellow-deep:  #E0A800;
    --bz-black:        #1A1A1A;
    --bz-orange:       #FF7A45;
    --bz-orange-soft:  #FFD9C9;

    /* Support palette */
    --bz-navy:         #2D3142;
    --bz-navy-soft:    #3D4256;
    --bz-navy-deep:    #21242F;
    --bz-cream:        #FFF8E6;
    --bz-cream-deep:   #FFEFC2;

    /* Greys (B2B canvas) */
    --bz-grey-50:      #F9FAFB;
    --bz-grey-100:     #F3F4F6;
    --bz-grey-200:     #E5E7EB;
    --bz-grey-300:     #D1D5DB;
    --bz-grey-400:     #9CA3AF;
    --bz-grey-500:     #6B7280;
    --bz-grey-600:     #4B5563;
    --bz-grey-700:     #374151;
    --bz-grey-800:     #1F2937;

    /* Semantic (brand book §04) */
    --bz-success:      #97C459;
    --bz-success-soft: #E6F1D1;
    --bz-warning:      #EF9F27;
    --bz-warning-soft: #FCEACE;
    --bz-danger:       #E24B4A;
    --bz-danger-soft:  #F8D6D5;
    --bz-info:         #5599DD;
    --bz-info-soft:    #DBE9F7;

    /* Shadows */
    --bz-shadow-sm:    0 1px 2px rgba(26,26,26,0.06);
    --bz-shadow:       0 1px 3px rgba(26,26,26,0.07), 0 4px 12px rgba(26,26,26,0.05);
    --bz-shadow-lg:    0 8px 20px rgba(26,26,26,0.08), 0 20px 40px rgba(26,26,26,0.05);
    --bz-shadow-hero:  0 30px 60px -20px rgba(26,26,26,0.25);
    --bz-shadow-stamp: 0 4px 0 0 rgba(26,26,26,0.18);

    /* Radii */
    --bz-radius-xs:    0.375rem;
    --bz-radius-sm:    0.5rem;
    --bz-radius:       0.875rem;
    --bz-radius-lg:    1.25rem;
    --bz-radius-xl:    1.75rem;
    --bz-radius-full:  9999px;

    /* Container sizing */
    --bz-container:       72rem;
    --bz-container-wide:  84rem;

    /* Typography (brand book §06) */
    --bz-font-sans:    "Inter", ui-sans-serif, system-ui, -apple-system,
                       "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --bz-font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular,
                       Menlo, Consolas, monospace;
}

/* ------------------------------------------------------------------
 * 2. Reset & base
 * ------------------------------------------------------------------ */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }
html, body { margin: 0; padding: 0; }

body {
    font-family: var(--bz-font-sans);
    font-feature-settings: "cv11", "ss01";
    font-size: 16px;
    line-height: 1.55;
    color: var(--bz-black);
    background: var(--bz-cream);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* B2B canvas override */
body.theme-b2b {
    background: var(--bz-grey-50);
    color: var(--bz-grey-800);
}

h1, h2, h3, h4 {
    margin: 0 0 0.5em;
    line-height: 1.15;
    letter-spacing: -0.02em;
    font-weight: 800;
}
h1 { font-size: clamp(2.2rem, 4.5vw, 3.4rem); font-weight: 900; }
h2 { font-size: clamp(1.55rem, 2.6vw, 2.1rem); }
h3 { font-size: 1.22rem; }
h4 { font-size: 1.05rem; }
p  { margin: 0 0 1em; }

a   { color: inherit; text-decoration: none; transition: color 150ms ease; }
a:hover { color: var(--bz-orange); }

ul  { list-style: none; padding: 0; margin: 0; }
img, svg { max-width: 100%; display: block; }

hr  { border: 0; border-top: 1px solid var(--bz-grey-200); margin: 2.5rem 0; }

::selection { background: var(--bz-yellow); color: var(--bz-black); }
:focus-visible { outline: 3px solid var(--bz-orange); outline-offset: 2px; border-radius: 4px; }

/* JetBrains Mono utility class for numeric/data fields */
.bz-mono { font-family: var(--bz-font-mono); font-feature-settings: "tnum"; }

/* ------------------------------------------------------------------
 * 3. Layout primitives
 * ------------------------------------------------------------------ */
.bz-container {
    width: 100%;
    max-width: var(--bz-container);
    margin: 0 auto;
    padding: 0 1.25rem;
}
.bz-container--wide { max-width: var(--bz-container-wide); }

.bz-section { padding: 4rem 0; }
.bz-section--tight { padding: 2.5rem 0; }
.bz-section--cream { background: var(--bz-cream); }
.bz-section--cream-deep { background: var(--bz-cream-deep); }
.bz-section--white { background: #fff; }
.bz-section--navy { background: var(--bz-navy); color: #fff; }
.bz-section--navy h2, .bz-section--navy h3 { color: #fff; }

/* ==================================================================
 * 4. Public portal components (theme-public)
 *    Palette: yellow + navy + orange + cream; mascot accessoria.
 * ================================================================== */

/* ---- Nav (public) ---- */
.bz-nav {
    position: sticky; top: 0; z-index: 1100;
    background: var(--bz-yellow);
    border-bottom: 3px solid var(--bz-black);
    box-shadow: var(--bz-shadow-sm);
}
.bz-nav__inner {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1.5rem; padding: 0.75rem 1.25rem;
    max-width: var(--bz-container); margin: 0 auto;
}
.bz-nav__logo { display: inline-flex; align-items: center; gap: 0.6rem; }
.bz-nav__wordmark { height: 38px; width: auto; }
.bz-nav__wordmark-text {
    font-weight: 900;
    font-size: 1.45rem;
    letter-spacing: -0.01em;
    color: var(--bz-black);
}
/* Real BusZilla mascot as a rounded symbol, framed with the brand's black
   outline so it reads against the yellow navbar (same yellow background). */
.bz-nav__symbol {
    height: 40px; width: 40px;
    border-radius: var(--bz-radius-sm);
    border: 2.5px solid var(--bz-black);
    object-fit: cover;
    box-shadow: 2px 2px 0 0 var(--bz-black);
    flex-shrink: 0;
}
.bz-nav__links { display: flex; align-items: center; gap: 1.75rem; font-weight: 600; font-size: 0.95rem; }
.bz-nav__link { position: relative; padding: 0.25rem 0; }
.bz-nav__link::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -4px;
    height: 3px; background: var(--bz-black);
    transform: scaleX(0); transform-origin: left;
    transition: transform 180ms ease;
}
.bz-nav__link:hover { color: var(--bz-black); }
.bz-nav__link:hover::after { transform: scaleX(1); }
.bz-nav__link--domatore {
    background: var(--bz-black);
    color: var(--bz-yellow);
    padding: 0.45rem 0.9rem;
    border-radius: var(--bz-radius-full);
    font-size: 0.82rem;
    font-weight: 700;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    transition: background 150ms ease, color 150ms ease, transform 120ms ease;
}
.bz-nav__link--domatore::after { display: none; }
.bz-nav__link--domatore:hover {
    background: var(--bz-orange);
    color: var(--bz-black);
    transform: translateY(-1px);
}

/* ---- Hero (public landing) ---- */
.bz-hero {
    position: relative; overflow: hidden;
    background:
        radial-gradient(ellipse at 80% -20%, rgba(255,122,69,0.35), transparent 55%),
        radial-gradient(ellipse at -10% 110%, rgba(255,239,194,0.9), transparent 55%),
        var(--bz-yellow);
    padding: clamp(3rem, 7vw, 6rem) 0 clamp(3rem, 6vw, 5rem);
}
.bz-hero::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(26,26,26,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(26,26,26,0.06) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,0.6), transparent 80%);
    pointer-events: none;
}
.bz-hero__grid {
    position: relative; display: grid;
    grid-template-columns: 1.4fr 1fr;
    align-items: center; gap: 2.5rem;
}
.bz-hero__copy { max-width: 36rem; }
.bz-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 0.5rem;
    background: var(--bz-black); color: var(--bz-yellow);
    padding: 0.35rem 0.85rem; border-radius: var(--bz-radius-full);
    font-size: 0.78rem; font-weight: 700;
    letter-spacing: 0.06em; text-transform: uppercase;
    margin-bottom: 1.25rem;
}
.bz-hero__title {
    font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 900;
    color: var(--bz-black); margin-bottom: 1rem; line-height: 1.05;
}
.bz-hero__title em {
    font-style: normal; color: #fff; background: var(--bz-black);
    padding: 0 0.25em; border-radius: 6px;
    box-decoration-break: clone; -webkit-box-decoration-break: clone;
}
.bz-hero__lede { font-size: 1.15rem; color: rgba(26,26,26,0.78); margin-bottom: 1.75rem; }
.bz-hero__ctas { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.bz-hero__mascot {
    position: relative; aspect-ratio: 1 / 1;
    max-width: 340px; margin: 0 auto;
    filter: drop-shadow(var(--bz-shadow-hero));
    animation: bz-mascot-bob 4.5s ease-in-out infinite;
}
.bz-hero__mascot svg,
.bz-hero__mascot img { width: 100%; height: 100%; object-fit: contain; }
@keyframes bz-mascot-bob {
    0%, 100% { transform: translateY(0) rotate(-1.5deg); }
    50%      { transform: translateY(-10px) rotate(1.5deg); }
}
@media (max-width: 820px) {
    .bz-hero__grid { grid-template-columns: 1fr; }
    .bz-hero__mascot { max-width: 220px; order: -1; }
}

/* ==================================================================
 * 4b. Mobile refinements (public portal) — brand book §05 friendly
 *     Keeps the yellow+navy+orange+cream palette; just tightens
 *     spacing and tap targets on small screens.
 * ================================================================== */
@media (max-width: 600px) {
    /* Nav: wrap links under the logo, larger tap targets */
    .bz-nav__inner { flex-wrap: wrap; gap: 0.5rem 1rem; padding: 0.6rem 1rem; }
    .bz-nav__wordmark { height: 30px; }
    .bz-nav__wordmark-text { font-size: 1.25rem; }
    .bz-nav__symbol { height: 34px; width: 34px; }
    .bz-nav__links {
        gap: 0.85rem 1.1rem; font-size: 0.9rem; flex-wrap: wrap;
        width: 100%; justify-content: flex-start;
    }
    .bz-nav__link { padding: 0.35rem 0; }

    /* Section rhythm: less air on small screens */
    .bz-section { padding: 2.5rem 0; }
    .bz-section--tight { padding: 1.75rem 0; }
    .bz-container { padding: 0 1rem; }

    /* Hero: full-width tappable CTAs, tighter lede */
    .bz-hero { padding: 2.25rem 0 2.5rem; }
    .bz-hero__lede { font-size: 1.05rem; margin-bottom: 1.5rem; }
    .bz-hero__ctas { gap: 0.6rem; }
    .bz-hero__ctas .bz-btn { flex: 1 1 100%; justify-content: center; text-align: center; }
    .bz-hero__mascot { max-width: 180px; }

    /* Map: a touch shorter so the card + legend fit one screen */
    .bz-map-wrap { padding: 0.6rem; border-radius: var(--bz-radius-lg); }
    .bz-map { height: clamp(300px, 52vh, 420px); }
    .bz-legend { gap: 0.6rem 1rem; font-size: 0.8rem; }

    /* Stat pills stack comfortably */
    .bz-stat-row { gap: 0.6rem; }
    .bz-stat-pill { font-size: 0.85rem; }

    /* Footer: single column on phones */
    .bz-footer { padding: 2.5rem 0 1.5rem; margin-top: 2.5rem; }
    .bz-footer__grid { grid-template-columns: 1fr; gap: 1.75rem; }
}

/* Respect users who prefer reduced motion (mascot bob, transitions) */
@media (prefers-reduced-motion: reduce) {
    .bz-hero__mascot { animation: none; }
    * { scroll-behavior: auto; }
}

/* ---- Buttons (sentence case only — brand book §07) ---- */
.bz-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 0.5rem; padding: 0.75rem 1.25rem;
    border-radius: var(--bz-radius-full);
    font-family: inherit; font-weight: 700; font-size: 0.95rem; line-height: 1;
    border: 2px solid transparent; cursor: pointer;
    transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease;
    text-decoration: none; white-space: nowrap;
}
.bz-btn:hover { transform: translateY(-1px); text-decoration: none; }
.bz-btn:active { transform: translateY(0); }
.bz-btn--primary { background: var(--bz-black); color: var(--bz-yellow); box-shadow: var(--bz-shadow-stamp); }
.bz-btn--primary:hover { background: #000; color: var(--bz-yellow); }
.bz-btn--ghost   { background: transparent; color: var(--bz-black); border-color: var(--bz-black); }
.bz-btn--ghost:hover { background: var(--bz-black); color: var(--bz-yellow); }
.bz-btn--orange  { background: var(--bz-orange); color: #fff; }
.bz-btn--orange:hover { background: #ef6730; color: #fff; }
.bz-btn--domatore {
    background: var(--bz-orange);
    color: var(--bz-black);
    border-color: var(--bz-black);
    box-shadow: 4px 4px 0 0 var(--bz-black);
}
.bz-btn--domatore:hover {
    background: var(--bz-black);
    color: var(--bz-orange);
    box-shadow: 6px 6px 0 0 var(--bz-orange);
}
.bz-btn--sm { padding: 0.5rem 0.95rem; font-size: 0.85rem; }

/* ---- Stat pills (hero) ---- */
.bz-stat-row { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1.5rem; }
.bz-stat-pill {
    display: inline-flex; align-items: center; gap: 0.5rem;
    background: #fff; border: 2px solid var(--bz-black);
    border-radius: var(--bz-radius-full); padding: 0.45rem 0.95rem;
    font-size: 0.85rem; font-weight: 600;
    box-shadow: 0 3px 0 0 rgba(26,26,26,0.15);
}
.bz-stat-pill strong { font-weight: 900; font-size: 1rem; font-family: var(--bz-font-mono); }
.bz-stat-pill__dot {
    width: 0.55rem; height: 0.55rem; border-radius: 50%;
    background: var(--bz-orange);
    box-shadow: 0 0 0 3px rgba(255,122,69,0.25);
}

/* ---- Generic public card ---- */
.bz-card {
    background: #fff; border-radius: var(--bz-radius-lg);
    padding: 1.5rem; box-shadow: var(--bz-shadow);
    border: 1px solid rgba(26,26,26,0.06);
}
.bz-card--flat { box-shadow: none; border: 1px solid var(--bz-grey-200); }

/* ==================================================================
 * 4c. Gadget shop (public portal — friendly palette)
 * ================================================================== */
.bz-hero--gadget {
    background:
        radial-gradient(ellipse at 80% -20%, rgba(255,122,69,0.35), transparent 55%),
        radial-gradient(ellipse at -10% 110%, rgba(255,239,194,0.9), transparent 55%),
        var(--bz-yellow);
}

.bz-gadget-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
}
@media (max-width: 900px) { .bz-gadget-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .bz-gadget-grid { grid-template-columns: 1fr; } }

.bz-gadget-card {
    display: flex; flex-direction: column;
    background: #fff;
    border: 3px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    box-shadow: 6px 6px 0 0 var(--bz-black);
    overflow: hidden;
    transition: transform 140ms ease, box-shadow 140ms ease;
}
.bz-gadget-card:hover { transform: translate(-2px, -2px); box-shadow: 9px 9px 0 0 var(--bz-black); }

/* Real product photo fills the art area. */
.bz-gadget-card__photo { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Product "mockups" rendered in CSS — fallback when no photo. */
.bz-gadget-card__art {
    position: relative;
    aspect-ratio: 4 / 3;
    display: flex; align-items: center; justify-content: center;
    gap: 0.6rem;
    border-bottom: 3px solid var(--bz-black);
    overflow: hidden;
}
.bz-gadget-card__art--tee  { background: radial-gradient(circle at 50% 40%, #fff, var(--bz-cream-deep)); }
.bz-gadget-card__art--pins { background: radial-gradient(circle at 50% 40%, var(--bz-cream), var(--bz-yellow-soft)); flex-wrap: wrap; padding: 1rem; }
.bz-gadget-card__art--cap  { background: radial-gradient(circle at 50% 30%, #fff, var(--bz-cream-deep)); }

/* T-shirt mockup */
.bz-gadget-tee {
    position: relative;
    width: 62%; aspect-ratio: 1 / 1;
    background: var(--bz-yellow);
    border: 2.5px solid var(--bz-black);
    border-radius: 1.4rem 1.4rem 0.6rem 0.6rem;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    box-shadow: 3px 3px 0 0 rgba(26,26,26,0.18);
}
.bz-gadget-tee::before, .bz-gadget-tee::after {
    content: ""; position: absolute; top: -2px; width: 26%; height: 30%;
    background: var(--bz-yellow); border: 2.5px solid var(--bz-black);
}
.bz-gadget-tee::before { left: -16%; transform: rotate(28deg); border-radius: 0.4rem; }
.bz-gadget-tee::after  { right: -16%; transform: rotate(-28deg); border-radius: 0.4rem; }
.bz-gadget-tee img { width: 46%; height: auto; position: relative; z-index: 1; }
.bz-gadget-tee__claim {
    font-weight: 800; font-size: 0.6rem; text-transform: lowercase;
    letter-spacing: 0.02em; color: var(--bz-black); margin-top: 0.25rem; z-index: 1;
}

/* Enamel pins */
.bz-gadget-pin {
    width: 33%; aspect-ratio: 1 / 1;
    background: #fff; border: 2.5px solid var(--bz-black); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 2px 2px 0 0 rgba(26,26,26,0.2);
}
.bz-gadget-pin img { width: 64%; height: auto; }

/* Cap mockup */
.bz-gadget-cap { position: relative; width: 60%; }
.bz-gadget-cap__panel {
    display: flex; align-items: center; justify-content: center;
    height: 78px;
    background: var(--bz-yellow);
    border: 2.5px solid var(--bz-black);
    border-radius: 50% 50% 18% 18% / 70% 70% 18% 18%;
}
.bz-gadget-cap__panel img { width: 46px; height: 46px; }
.bz-gadget-cap__brim {
    display: block; height: 16px; width: 130%; margin: -2px auto 0;
    background: var(--bz-black);
    border-radius: 0 0 50% 50% / 0 0 100% 100%;
}

.bz-gadget-card__body { padding: 1.25rem 1.25rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.bz-gadget-card__tag {
    align-self: flex-start;
    font-size: 0.68rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--bz-orange); margin-bottom: 0.35rem;
}
.bz-gadget-card__title { font-size: 1.2rem; font-weight: 800; margin: 0 0 0.4rem; color: var(--bz-black); }
.bz-gadget-card__desc { font-size: 0.9rem; color: var(--bz-grey-700); margin: 0 0 0.9rem; }
.bz-gadget-card__variants { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 1rem; }
.bz-gadget-chip {
    font-size: 0.72rem; font-weight: 600;
    padding: 0.2rem 0.55rem; border-radius: var(--bz-radius-full);
    background: var(--bz-cream-deep); color: var(--bz-grey-800);
    border: 1.5px solid var(--bz-black);
}
.bz-gadget-card__foot {
    margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 0.75rem;
}
.bz-gadget-card__price {
    font-family: var(--bz-font-mono); font-weight: 800; font-size: 1.15rem; color: var(--bz-black);
}
.bz-gadget-card__price small { font-size: 0.7rem; font-weight: 600; color: var(--bz-grey-500); }

/* ---- Slogan gallery ---- */
.bz-slogan-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}
@media (max-width: 820px) { .bz-slogan-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .bz-slogan-grid { grid-template-columns: 1fr; } }

.bz-slogan {
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.1rem 1.2rem;
    box-shadow: 4px 4px 0 0 var(--bz-black);
    font-weight: 700; font-size: 1rem; line-height: 1.25;
    transition: transform 140ms ease, box-shadow 140ms ease;
}
.bz-slogan:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 0 var(--bz-black); }
.bz-slogan--yellow { background: var(--bz-yellow); color: var(--bz-black); }
.bz-slogan--dark   { background: var(--bz-black); color: #fff; }
.bz-slogan--cream  { background: var(--bz-cream-deep); color: var(--bz-black); }
.bz-slogan__brand { display: block; margin-top: 0.45rem; font-weight: 800; }
.bz-slogan--dark .bz-slogan__brand { color: var(--bz-yellow); }
.bz-slogan--yellow .bz-slogan__brand,
.bz-slogan--cream .bz-slogan__brand { color: var(--bz-orange); }

/* ---- Steps ("Come funziona") ---- */
.bz-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.5rem; }
@media (max-width: 820px) { .bz-steps { grid-template-columns: 1fr; } }
.bz-step {
    position: relative; background: #fff;
    border-radius: var(--bz-radius-lg);
    padding: 1.75rem 1.5rem 1.5rem;
    box-shadow: var(--bz-shadow);
    border: 1px solid rgba(26,26,26,0.06);
}
.bz-step__num {
    position: absolute; top: -18px; left: 1.5rem;
    width: 36px; height: 36px;
    border-radius: var(--bz-radius-full);
    background: var(--bz-black); color: var(--bz-yellow);
    font-weight: 900; display: inline-flex;
    align-items: center; justify-content: center;
    font-size: 0.95rem; box-shadow: var(--bz-shadow-stamp);
}
.bz-step__title { font-size: 1.15rem; font-weight: 800; margin: 0.5rem 0; }
.bz-step__body  { color: var(--bz-grey-700); font-size: 0.95rem; }

/* ---- Map (public) ---- */
.bz-map-wrap {
    background: #fff; border-radius: var(--bz-radius-xl);
    padding: 1rem; box-shadow: var(--bz-shadow-lg);
    border: 1px solid rgba(26,26,26,0.06);
    /* Trap Leaflet's internal z-indexes (panes + controls reach 1000) inside a
       local stacking context so they can't paint over the sticky navbar. */
    position: relative; z-index: 0;
}

/* ---- Stop search (autocomplete) ---- */
.bz-search {
    position: relative;
    max-width: 540px;
    margin: 0 0 1.25rem;
    z-index: 20;
}
.bz-search__icon {
    position: absolute;
    left: 0.9rem; top: 50%;
    transform: translateY(-50%);
    font-size: 1rem;
    pointer-events: none;
    opacity: 0.7;
}
.bz-search__input {
    width: 100%;
    font-family: var(--bz-font-sans);
    font-size: 1rem;
    padding: 0.8rem 1rem 0.8rem 2.5rem;
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius);
    background: #fff;
    color: var(--bz-black);
    outline: none;
    box-shadow: 3px 3px 0 0 var(--bz-black);
    transition: box-shadow 120ms ease, transform 120ms ease;
}
.bz-search__input::placeholder { color: rgba(26,26,26,0.45); }
.bz-search__input:focus { transform: translate(-1px,-1px); box-shadow: 5px 5px 0 0 var(--bz-orange); }
.bz-search__results {
    list-style: none;
    margin: 0.4rem 0 0;
    padding: 0.3rem;
    position: absolute;
    left: 0; right: 0;
    background: #fff;
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius);
    box-shadow: var(--bz-shadow-lg);
    max-height: 360px;
    overflow-y: auto;
}
.bz-search__item {
    padding: 0.6rem 0.7rem;
    border-radius: var(--bz-radius-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}
.bz-search__item:hover,
.bz-search__item.is-active { background: var(--bz-cream-deep); }
.bz-search__item-main { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; }
.bz-search__item-name { font-weight: 700; color: var(--bz-black); }
.bz-search__item-sub { font-size: 0.82rem; color: rgba(26,26,26,0.6); }
.bz-search__item-dist {
    flex: 0 0 auto;
    font-family: var(--bz-font-mono);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--bz-orange);
}
.bz-search__header {
    padding: 0.4rem 0.7rem 0.5rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(26,26,26,0.55);
}
.bz-search__msg {
    padding: 0.7rem;
    font-size: 0.88rem;
    color: rgba(26,26,26,0.6);
}
.bz-map {
    height: clamp(360px, 60vh, 540px);
    border-radius: var(--bz-radius-lg);
    overflow: hidden;
    background: linear-gradient(135deg, var(--bz-grey-100), var(--bz-grey-200));
    display: flex; align-items: center; justify-content: center;
    color: var(--bz-grey-500); font-size: 0.9rem;
}
.bz-map:empty::before { content: "Mappa non disponibile — script bloccato."; }

/* ---- Legend ---- */
.bz-legend {
    display: flex; flex-wrap: wrap; gap: 1.25rem;
    margin-top: 1rem; padding: 0 0.5rem;
    font-size: 0.85rem; color: var(--bz-grey-700);
}
.bz-legend__item { display: inline-flex; align-items: center; gap: 0.5rem; }
.bz-legend__dot {
    width: 0.7rem; height: 0.7rem; border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(0,0,0,0.05);
}
.bz-legend__dot--high    { background: var(--bz-success); box-shadow: 0 0 0 3px rgba(151,196,89,0.25); }
.bz-legend__dot--medium  { background: var(--bz-warning); box-shadow: 0 0 0 3px rgba(239,159,39,0.25); }
.bz-legend__dot--low     { background: var(--bz-danger);  box-shadow: 0 0 0 3px rgba(226,75,74,0.25); }
.bz-legend__dot--none    { background: var(--bz-grey-400); box-shadow: 0 0 0 3px rgba(156,163,175,0.25); }

/* ---- Footer ---- */
.bz-footer { background: var(--bz-navy); color: #cdd0db; padding: 3.5rem 0 2rem; margin-top: 4rem; }
.bz-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; margin-bottom: 2.5rem; }
@media (max-width: 820px) { .bz-footer__grid { grid-template-columns: 1fr 1fr; } }
.bz-footer__brand img,
.bz-footer__brand svg { height: 44px; width: auto; }
.bz-footer__tagline { margin-top: 0.75rem; color: #9aa0b3; font-size: 0.9rem; max-width: 18rem; }
.bz-footer__heading {
    color: var(--bz-yellow); font-weight: 700; font-size: 0.78rem;
    letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.85rem;
}
.bz-footer__list li { margin-bottom: 0.4rem; font-size: 0.9rem; }
.bz-footer__list a { color: #cdd0db; }
.bz-footer__list a:hover { color: #fff; }
.bz-footer__bottom {
    border-top: 1px solid rgba(255,255,255,0.08);
    padding-top: 1.5rem;
    display: flex; justify-content: space-between; gap: 1rem;
    color: #8990a3; font-size: 0.8rem; flex-wrap: wrap;
}

/* ---- Prose (legal / methodology pages) ---- */
.bz-prose { max-width: 44rem; margin: 0 auto; color: var(--bz-black); }
.bz-prose h1 { font-size: clamp(2rem, 4vw, 2.75rem); margin-bottom: 0.5em; }
.bz-prose__kicker {
    display: inline-block; background: var(--bz-yellow); color: var(--bz-black);
    font-size: 0.78rem; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 0.3rem 0.7rem; border-radius: var(--bz-radius-full);
    margin-bottom: 1rem;
}
.bz-prose__lede { font-size: 1.2rem; color: var(--bz-grey-700); margin-bottom: 2rem; }
.bz-prose h2 { margin-top: 2.5rem; font-size: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--bz-grey-200); }
.bz-prose h3 { margin-top: 2rem; font-size: 1.15rem; }
.bz-prose p, .bz-prose ul, .bz-prose ol { font-size: 1rem; line-height: 1.7; }
.bz-prose ul, .bz-prose ol { padding-left: 1.25rem; margin: 0 0 1em; }
.bz-prose ul li { list-style: disc; margin-bottom: 0.35em; }
.bz-prose ol li { list-style: decimal; margin-bottom: 0.35em; }
.bz-prose strong { color: var(--bz-black); }
.bz-prose code { background: var(--bz-grey-100); padding: 0.1em 0.4em; border-radius: 4px; font-family: var(--bz-font-mono); font-size: 0.9em; }
.bz-prose blockquote {
    margin: 1.5rem 0; padding: 1rem 1.25rem;
    border-left: 4px solid var(--bz-orange);
    background: var(--bz-cream); border-radius: 0 var(--bz-radius) var(--bz-radius) 0;
    font-style: italic; color: var(--bz-grey-700);
}
.bz-prose table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: 0.95rem; }
.bz-prose th, .bz-prose td { text-align: left; padding: 0.65rem 0.75rem; border-bottom: 1px solid var(--bz-grey-200); }
.bz-prose th { background: var(--bz-grey-100); font-weight: 700; }

/* ---- Geofence explainer (Metodologia §2) ---- */
.bz-geofence {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 1.5rem;
    align-items: center;
    background: var(--bz-cream);
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.5rem;
    margin: 1.5rem 0;
    box-shadow: 4px 4px 0 0 var(--bz-black);
}
.bz-geofence__diagram {
    position: relative;
    width: 200px;
    height: 200px;
    margin: 0 auto;
}
.bz-geofence__ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 3px dashed var(--bz-orange);
    background: radial-gradient(circle, rgba(255,193,7,0.20) 0%, rgba(255,122,69,0.10) 70%, transparent 100%);
}
.bz-geofence__radius {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) translateY(-42px);
    font-family: var(--bz-font-mono);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--bz-grey-700);
    background: #fff;
    padding: 0.05rem 0.4rem;
    border-radius: var(--bz-radius-full);
}
.bz-geofence__stop {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2.1rem;
    line-height: 1;
}
.bz-geofence__ok {
    position: absolute;
    top: 32%;
    left: 70%;
    transform: translate(-50%, -50%);
    font-size: 1.35rem;
}
.bz-geofence__ko {
    position: absolute;
    bottom: -14px;
    right: -10px;
    font-size: 1.7rem;
    opacity: 0.85;
}
.bz-geofence__legend p {
    margin: 0 0 0.6rem;
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}
.bz-geofence__dot {
    flex: 0 0 auto;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-top: 0.4rem;
    border: 1.5px solid var(--bz-black);
}
.bz-geofence__dot--ok { background: var(--bz-success); }
.bz-geofence__dot--ko { background: var(--bz-danger); }
@media (max-width: 560px) {
    .bz-geofence { grid-template-columns: 1fr; }
}

/* ---- Line detail page ---- */
.bz-line-header { display: flex; align-items: center; gap: 1.25rem; margin-bottom: 2rem; }
.bz-line-badge {
    background: var(--bz-yellow); color: var(--bz-black);
    font-weight: 900; font-size: 1.6rem;
    padding: 0.6rem 1rem;
    border-radius: var(--bz-radius);
    border: 2px solid var(--bz-black);
    box-shadow: var(--bz-shadow-stamp);
    font-family: var(--bz-font-mono);
}
.bz-kpi-card {
    background: #fff; border-radius: var(--bz-radius-lg);
    padding: 1.75rem; box-shadow: var(--bz-shadow);
    display: flex; align-items: center; justify-content: space-between;
    gap: 1.5rem; flex-wrap: wrap;
}
.bz-kpi-card__big { font-size: clamp(2.5rem, 6vw, 3.5rem); font-weight: 900; line-height: 1; font-family: var(--bz-font-mono); }
.bz-pill {
    display: inline-flex; align-items: center;
    padding: 0.4rem 0.85rem;
    border-radius: var(--bz-radius-full);
    font-size: 0.85rem; font-weight: 700;
}
.bz-pill--high { background: var(--bz-success-soft); color: #4F7A29; }
.bz-pill--mid  { background: var(--bz-warning-soft); color: #B4690F; }
.bz-pill--low  { background: var(--bz-danger-soft);  color: #9B1F1F; }
.bz-pill--none { background: var(--bz-grey-100);     color: var(--bz-grey-500); }

/* ==================================================================
 * 5. B2B Dashboard components (theme-b2b)
 *    Palette: navy + orange + grey + white. Mascot ASSENTE.
 *    Tono: professionale, data-driven (brand book §05, §07).
 * ================================================================== */

/* ---- B2B Top nav ---- */
.b2b-nav {
    background: #fff; border-bottom: 1px solid var(--bz-grey-200);
    position: sticky; top: 0; z-index: 50;
}
.b2b-nav__inner {
    max-width: var(--bz-container-wide); margin: 0 auto;
    display: flex; align-items: center; gap: 1.5rem;
    padding: 0.85rem 1.5rem;
}
.b2b-nav__brand { display: inline-flex; align-items: center; gap: 0.6rem; flex-shrink: 0; }
.b2b-nav__brand img,
.b2b-nav__brand svg { height: 32px; width: auto; }
.b2b-nav__brand-tag {
    background: var(--bz-grey-100); color: var(--bz-grey-600);
    font-size: 0.7rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.08em;
    padding: 0.25rem 0.55rem; border-radius: var(--bz-radius-full);
    white-space: nowrap;
}
.b2b-nav__links {
    display: flex; align-items: center; gap: 0.25rem;
    flex: 1; margin-left: 1.5rem; font-size: 0.92rem; font-weight: 500;
    color: var(--bz-grey-600); flex-wrap: wrap;
}
.b2b-nav__link {
    padding: 0.55rem 0.9rem;
    border-radius: var(--bz-radius-sm);
    transition: background 120ms ease, color 120ms ease;
}
.b2b-nav__link:hover { color: var(--bz-grey-900, var(--bz-black)); background: var(--bz-grey-100); }
.b2b-nav__link.is-active { color: var(--bz-orange); background: var(--bz-orange-soft); font-weight: 600; }
.b2b-nav__right { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }
.b2b-nav__org {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.5rem 0.9rem;
    background: var(--bz-grey-50);
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-sm);
    color: var(--bz-grey-700);
    font-size: 0.9rem; font-weight: 500;
}
.b2b-nav__org::after {
    content: "▾"; font-size: 0.7rem; color: var(--bz-grey-500); margin-left: 0.25rem;
}
.b2b-nav__avatar {
    width: 36px; height: 36px;
    border-radius: var(--bz-radius-full);
    background: var(--bz-navy); color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 0.85rem; letter-spacing: 0.04em;
}

/* ---- B2B Page header ---- */
.b2b-page {
    max-width: var(--bz-container-wide); margin: 0 auto;
    padding: 2rem 1.5rem;
}
.b2b-page__header {
    display: flex; justify-content: space-between; gap: 1.5rem;
    align-items: flex-start; margin-bottom: 1.75rem; flex-wrap: wrap;
}
.b2b-page__title { font-size: 1.85rem; font-weight: 800; color: var(--bz-grey-900, var(--bz-black)); margin: 0 0 0.35rem; letter-spacing: -0.02em; }
.b2b-page__subtitle { color: var(--bz-grey-500); font-size: 0.95rem; margin: 0; }
.b2b-page__meta { font-size: 0.82rem; color: var(--bz-grey-500); }

/* ---- B2B Filter bar ---- */
.b2b-filters {
    display: flex; align-items: center; flex-wrap: wrap;
    gap: 0.5rem; margin-bottom: 1.5rem;
}
.b2b-filter {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.55rem 0.95rem;
    background: #fff;
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-full);
    font-size: 0.88rem; font-weight: 500; color: var(--bz-grey-700);
    cursor: pointer; transition: all 120ms ease;
    white-space: nowrap;
}
.b2b-filter:hover { border-color: var(--bz-grey-400); }
.b2b-filter.is-active {
    background: var(--bz-navy); border-color: var(--bz-navy); color: #fff;
}
.b2b-filter--add {
    border-style: dashed; color: var(--bz-grey-500);
}
.b2b-filters__spacer { flex: 1; }

/* ---- B2B KPI grid ---- */
.b2b-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem; margin-bottom: 1.5rem;
}
@media (max-width: 1000px) { .b2b-kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .b2b-kpi-grid { grid-template-columns: 1fr; } }
.b2b-kpi {
    background: #fff;
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-lg);
    padding: 1.25rem;
}
.b2b-kpi__label {
    color: var(--bz-grey-500);
    font-size: 0.72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.1em;
    margin-bottom: 0.5rem;
}
.b2b-kpi__value {
    font-family: var(--bz-font-mono);
    font-size: clamp(2rem, 3.4vw, 2.5rem);
    font-weight: 800; color: var(--bz-grey-900, var(--bz-black));
    line-height: 1.05; letter-spacing: -0.02em;
}
.b2b-kpi__delta {
    display: inline-flex; align-items: center; gap: 0.3rem;
    margin-top: 0.5rem; padding: 0.25rem 0.55rem;
    font-size: 0.78rem; font-weight: 600;
    border-radius: var(--bz-radius-full);
}
.b2b-kpi__delta--positive { background: var(--bz-success-soft); color: #4F7A29; }
.b2b-kpi__delta--negative { background: var(--bz-danger-soft);  color: #9B1F1F; }
.b2b-kpi__delta--neutral  { background: var(--bz-grey-100);     color: var(--bz-grey-600); }

/* ---- B2B Cards (charts / map) ---- */
.b2b-card {
    background: #fff;
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-lg);
    padding: 1.5rem;
}
.b2b-card__header {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 1rem; margin-bottom: 1rem; flex-wrap: wrap;
}
.b2b-card__title { font-size: 1.1rem; font-weight: 800; color: var(--bz-grey-900, var(--bz-black)); margin: 0; }
.b2b-card__hint  { font-size: 0.82rem; color: var(--bz-grey-500); }

.b2b-two-col {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 1rem; margin-bottom: 1.5rem;
}
@media (max-width: 980px) { .b2b-two-col { grid-template-columns: 1fr; } }

/* ---- B2B Hotspot map (real Leaflet map) ---- */
.b2b-hotspot-map {
    height: 300px;
    border-radius: var(--bz-radius);
    overflow: hidden;
    border: 1px solid var(--bz-grey-200);
    background: var(--bz-grey-100);
}
.b2b-hotspot-map .leaflet-container { font-family: var(--bz-font-sans); background: var(--bz-grey-100); }
.b2b-hotspot-empty {
    height: 300px;
    display: flex; align-items: center; justify-content: center;
    text-align: center; padding: 1rem;
    color: var(--bz-grey-500); font-size: 0.9rem;
    background: var(--bz-grey-50);
    border: 1px dashed var(--bz-grey-200);
    border-radius: var(--bz-radius);
}

/* ---- B2B Hotspot map (legacy CSS-rendered placeholder + legend) ---- */
.b2b-hotspot {
    position: relative;
    height: 300px;
    background: var(--bz-cream);
    border-radius: var(--bz-radius);
    overflow: hidden;
    border: 1px solid var(--bz-grey-200);
}
.b2b-hotspot__bubble {
    position: absolute;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    display: flex; align-items: center; justify-content: center;
    transition: transform 200ms ease;
}
.b2b-hotspot__bubble:hover { transform: translate(-50%, -50%) scale(1.05); }
.b2b-hotspot__bubble::after {
    content: ""; position: absolute; inset: 0;
    border-radius: 50%; opacity: 0.25;
    background: currentColor;
}
.b2b-hotspot__bubble-core {
    width: 16px; height: 16px; border-radius: 50%;
    background: currentColor; box-shadow: 0 0 0 4px rgba(255,255,255,0.6);
    position: relative; z-index: 2;
}
.b2b-hotspot__bubble--ok       { color: var(--bz-success); }
.b2b-hotspot__bubble--warning  { color: var(--bz-warning); }
.b2b-hotspot__bubble--critical { color: var(--bz-danger); }
.b2b-hotspot__label {
    position: absolute; top: 50%; left: calc(100% + 8px);
    transform: translateY(-50%);
    background: #fff; border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-sm); padding: 0.3rem 0.6rem;
    font-size: 0.75rem; font-weight: 600; color: var(--bz-grey-800);
    white-space: nowrap; box-shadow: var(--bz-shadow-sm);
    z-index: 3;
}
.b2b-hotspot__label small { display: block; font-family: var(--bz-font-mono); color: var(--bz-danger); font-weight: 700; }
.b2b-hotspot__legend {
    position: absolute; bottom: 0.75rem; left: 0.75rem;
    display: flex; gap: 0.85rem; flex-wrap: wrap;
    background: rgba(255,255,255,0.95); backdrop-filter: blur(6px);
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-full);
    padding: 0.4rem 0.85rem; font-size: 0.78rem; color: var(--bz-grey-700);
}
.b2b-hotspot__legend-item { display: inline-flex; align-items: center; gap: 0.35rem; }
.b2b-hotspot__legend-dot { width: 0.55rem; height: 0.55rem; border-radius: 50%; }

/* ---- B2B Hour-chart (CSS bars) ---- */
.b2b-bars {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, 1fr);
    align-items: end;
    gap: 0.55rem;
    height: 220px;
    padding: 0 0.25rem 1.5rem;
}
.b2b-bar {
    position: relative;
    border-radius: var(--bz-radius-sm) var(--bz-radius-sm) 0 0;
    background: var(--bz-grey-200);
    min-height: 8px;
    transition: opacity 200ms ease;
}
.b2b-bar--ok       { background: var(--bz-success); }
.b2b-bar--warning  { background: var(--bz-warning); }
.b2b-bar--critical { background: var(--bz-danger); }
.b2b-bar__label {
    position: absolute; top: 100%;
    left: 50%; transform: translateX(-50%);
    margin-top: 0.4rem;
    font-size: 0.72rem;
    font-family: var(--bz-font-mono);
    color: var(--bz-grey-500);
    white-space: nowrap;
}
.b2b-bar__value {
    position: absolute; bottom: 100%; left: 50%;
    transform: translateX(-50%); margin-bottom: 0.2rem;
    font-size: 0.7rem; color: var(--bz-grey-500);
    opacity: 0; transition: opacity 150ms ease;
    font-family: var(--bz-font-mono);
}
.b2b-bar:hover .b2b-bar__value { opacity: 1; }

/* ---- B2B Lines table ---- */
.b2b-table-card { padding: 0; overflow: hidden; }
.b2b-table-card__header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--bz-grey-200);
}
.b2b-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
.b2b-table thead tr { background: var(--bz-grey-50); }
.b2b-table th {
    text-align: left; padding: 0.85rem 1.5rem;
    font-size: 0.7rem; font-weight: 700;
    color: var(--bz-grey-500);
    text-transform: uppercase; letter-spacing: 0.08em;
    border-bottom: 1px solid var(--bz-grey-200);
    white-space: nowrap;
}
.b2b-table td {
    padding: 0.9rem 1.5rem;
    border-bottom: 1px solid var(--bz-grey-100);
    vertical-align: middle;
    color: var(--bz-grey-700);
}
.b2b-table tbody tr { transition: background 120ms ease; }
.b2b-table tbody tr:hover { background: var(--bz-grey-50); }
.b2b-table tbody tr:last-child td { border-bottom: 0; }
.b2b-table .num { font-family: var(--bz-font-mono); text-align: right; color: var(--bz-grey-900, var(--bz-black)); font-weight: 600; }
.b2b-table .line-badge {
    display: inline-block;
    background: var(--bz-grey-900, var(--bz-black));
    color: #fff;
    font-family: var(--bz-font-mono); font-weight: 700;
    padding: 0.25rem 0.6rem; border-radius: var(--bz-radius-xs);
    font-size: 0.85rem; min-width: 2.5rem; text-align: center;
}

.b2b-status {
    display: inline-flex; align-items: center;
    padding: 0.3rem 0.7rem; border-radius: var(--bz-radius-full);
    font-size: 0.78rem; font-weight: 600;
}
.b2b-status--stable   { background: var(--bz-success-soft); color: #4F7A29; }
.b2b-status--warning  { background: var(--bz-warning-soft); color: #B4690F; }
.b2b-status--critical { background: var(--bz-danger-soft);  color: #9B1F1F; }

/* ==================================================================
 * 6. Tailwind utility shim (kept minimal — used by inline classes)
 * ================================================================== */
.bg-bz-yellow { background-color: var(--bz-yellow); }
.bg-bz-cream  { background-color: var(--bz-cream); }
.bg-bz-navy   { background-color: var(--bz-navy); }
.bg-bz-black  { background-color: var(--bz-black); }
.bg-bz-orange { background-color: var(--bz-orange); }
.bg-white     { background-color: #ffffff; }
.bg-gray-50   { background-color: var(--bz-grey-50); }
.text-bz-yellow { color: var(--bz-yellow); }
.text-bz-black  { color: var(--bz-black); }
.text-bz-orange { color: var(--bz-orange); }
.text-bz-navy   { color: var(--bz-navy); }
.text-white     { color: #fff; }
.text-bz-black\/70 { color: rgba(26,26,26,0.7); }
.text-bz-black\/60 { color: rgba(26,26,26,0.6); }
.text-bz-black\/50 { color: rgba(26,26,26,0.5); }
.max-w-xl  { max-width: 36rem; margin-left: auto; margin-right: auto; }
.max-w-4xl { max-width: 56rem; margin-left: auto; margin-right: auto; }
.max-w-6xl { max-width: 72rem; margin-left: auto; margin-right: auto; }
.max-w-7xl { max-width: 80rem; margin-left: auto; margin-right: auto; }
.mx-auto { margin-left: auto; margin-right: auto; }
.flex { display: flex; }
.grid { display: grid; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.flex-wrap { flex-wrap: wrap; }
.gap-2 { gap: 0.5rem; } .gap-4 { gap: 1rem; } .gap-6 { gap: 1.5rem; } .gap-8 { gap: 2rem; }
.text-center { text-align: center; }
.font-mono { font-family: var(--bz-font-mono); }
.font-bold  { font-weight: 700; }
.font-black { font-weight: 900; }
.rounded-full { border-radius: 9999px; }
.shadow { box-shadow: var(--bz-shadow); }
.transition-colors { transition: color 150ms ease; }
.hover\:text-orange:hover { color: var(--bz-orange); }
.hover\:text-white:hover  { color: #fff; }
.uppercase { text-transform: uppercase; }
.tracking-wide { letter-spacing: 0.05em; }
table { border-collapse: collapse; width: 100%; }
th, td { text-align: left; padding: 0.5rem; }
#map {
    min-height: 32rem;
    height: 32rem;
    border-radius: var(--bz-radius-lg);
    background: linear-gradient(135deg, var(--bz-grey-100), var(--bz-grey-200));
    overflow: hidden;
}
.leaflet-container { font-family: var(--bz-font-sans); }
.leaflet-popup-content-wrapper {
    border-radius: var(--bz-radius);
    border: 2px solid var(--bz-black);
    box-shadow: 4px 4px 0 0 var(--bz-black);
}
.leaflet-popup-tip { background: var(--bz-black); }

/* ==================================================================
 * 9. Stop detail page (Stop/Detail.cshtml)
 * ================================================================== */
.bz-stop__back {
    display: inline-block;
    margin-bottom: 1rem;
    color: var(--bz-black);
    text-decoration: none;
    font-weight: 600;
    opacity: 0.65;
}
.bz-stop__back:hover { opacity: 1; }

.bz-stop__hero {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center;
    background: var(--bz-yellow);
    border: 3px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.5rem 1.75rem;
    box-shadow: 6px 6px 0 0 var(--bz-black);
    margin-bottom: 1.5rem;
}
.bz-stop__eyebrow {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bz-orange);
    margin: 0 0 0.3rem;
}
.bz-stop__title {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 900;
    margin: 0 0 0.2rem;
    color: var(--bz-black);
}
.bz-stop__city { margin: 0 0 0.4rem; color: rgba(26,26,26,0.65); }
.bz-stop__coords {
    margin: 0 0 0.6rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: rgba(26,26,26,0.7);
}
.bz-stop__coords-link {
    color: var(--bz-black);
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.bz-stop__coords-link:hover { color: var(--bz-orange); }
.bz-stop__mood {
    margin: 0 0 1rem;
    font-weight: 700;
    color: var(--bz-black);
}
.bz-stop__kpis {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}
.bz-stop__kpi {
    background: var(--bz-black);
    color: var(--bz-yellow);
    border-radius: var(--bz-radius);
    padding: 0.6rem 0.9rem;
    min-width: 130px;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}
.bz-stop__kpi-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    opacity: 0.65;
}
.bz-stop__kpi-value { font-size: 1.4rem; font-weight: 700; }
.bz-stop__mascot img {
    width: 120px;
    height: 120px;
    filter: drop-shadow(4px 4px 0 var(--bz-black));
}
.bz-stop__mini-map {
    height: 220px;
    border-radius: var(--bz-radius-lg);
    border: 2.5px solid var(--bz-black);
    overflow: hidden;
    margin-bottom: 1.5rem;
}
.bz-stop__h2 {
    font-size: 1.3rem;
    font-weight: 800;
    margin: 0 0 1rem;
    color: var(--bz-navy);
}
.bz-stop__lines {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1rem;
}
.bz-stop__line {
    background: #fff;
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.1rem 1.25rem;
    box-shadow: 4px 4px 0 0 var(--bz-black);
}
.bz-stop__line-head { display: flex; gap: 0.8rem; align-items: center; margin-bottom: 0.85rem; }
.bz-stop__line-badge {
    background: var(--bz-yellow);
    color: var(--bz-black);
    border: 2px solid var(--bz-black);
    border-radius: var(--bz-radius-sm);
    font-family: var(--bz-font-mono);
    font-weight: 700;
    font-size: 0.95rem;
    padding: 0.2rem 0.65rem;
    min-width: 44px;
    text-align: center;
}
.bz-stop__line-name { margin: 0 0 0.2rem; font-weight: 700; color: var(--bz-black); }
.bz-stop-tier {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.12rem 0.5rem;
    border-radius: var(--bz-radius-full);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.bz-stop-tier--ok   { background: var(--bz-success-soft); color: #4F7A29; }
.bz-stop-tier--warn { background: var(--bz-warning-soft); color: #B4690F; }
.bz-stop-tier--bad  { background: var(--bz-danger-soft);  color: #9B1F1F; }
.bz-stop-tier--none { background: var(--bz-grey-200);     color: var(--bz-grey-700); }
.bz-stop__line-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.4rem 1rem;
}
.bz-stop__line-stats > div { display: flex; justify-content: space-between; gap: 0.5rem; font-size: 0.88rem; }
.bz-stop__line-stats span { color: rgba(26,26,26,0.55); }
.bz-stop__line-stats strong { color: var(--bz-black); }

/* ---- Tomorrow forecast block (per line) ---- */
.bz-forecast {
    margin-top: 0.9rem;
    padding: 0.8rem 0.9rem;
    border-radius: var(--bz-radius);
    border: 2px solid var(--bz-black);
    background: var(--bz-cream);
}
.bz-forecast--ok       { background: var(--bz-success-soft); }
.bz-forecast--warning  { background: var(--bz-warning-soft); }
.bz-forecast--critical { background: var(--bz-danger-soft); }
.bz-forecast__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.4rem;
}
.bz-forecast__tag {
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(26,26,26,0.6);
}
.bz-forecast__delay {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--bz-black);
}
.bz-forecast__msg {
    margin: 0 0 0.4rem;
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--bz-black);
}
.bz-forecast__meta {
    margin: 0;
    font-size: 0.75rem;
    color: rgba(26,26,26,0.6);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
}
.bz-forecast__badge {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.05rem 0.4rem;
    border-radius: var(--bz-radius-full);
    background: rgba(26,26,26,0.12);
    color: rgba(26,26,26,0.7);
}
.bz-forecast__badge--synth { background: rgba(26,26,26,0.08); }

/* ==================================================================
 * 7. PIN login (Account/Login.cshtml)
 *    Friendly palette per brand book §05 (giallo + nero + arancione +
 *    crema). Mascotte sospettosa in alto, monospazio per il PIN.
 * ================================================================== */
.bz-pin-body {
    margin: 0;
    min-height: 100vh;
    background:
        radial-gradient(circle at 12% 18%, var(--bz-yellow-soft) 0, transparent 38%),
        radial-gradient(circle at 88% 82%, var(--bz-orange-soft) 0, transparent 42%),
        var(--bz-yellow);
    font-family: var(--bz-font-sans);
    color: var(--bz-black);
}
.bz-pin {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    gap: 1.5rem;
}
.bz-pin__back {
    align-self: flex-start;
    color: var(--bz-black);
    text-decoration: none;
    font-weight: 600;
    opacity: 0.65;
    margin-left: 0.5rem;
}
.bz-pin__back:hover { opacity: 1; }
.bz-pin__card {
    width: min(440px, 100%);
    background: #fff;
    border: 3px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    box-shadow: 10px 10px 0 0 var(--bz-black);
    padding: 2rem 1.75rem 2.25rem;
}
.bz-pin__head {
    text-align: center;
    margin-bottom: 1.25rem;
}
.bz-pin__mascot {
    width: 110px;
    height: 110px;
    display: block;
    margin: -3.5rem auto 0.75rem;
    filter: drop-shadow(4px 4px 0 var(--bz-black));
    transition: transform 150ms ease;
}
/* Wrong PIN → BusZilla è scatenato: angry mascot trembles with rage. */
.bz-pin__mascot.is-angry {
    animation: bz-pin-rage 0.5s ease-in-out;
    transform-origin: center bottom;
}
@keyframes bz-pin-rage {
    0%, 100% { transform: rotate(0) scale(1); }
    15%      { transform: rotate(-6deg) scale(1.06); }
    30%      { transform: rotate(5deg)  scale(1.06); }
    45%      { transform: rotate(-4deg) scale(1.04); }
    60%      { transform: rotate(4deg)  scale(1.04); }
    75%      { transform: rotate(-2deg) scale(1.02); }
}
/* The whole card jolts once on a failed attempt. */
.bz-pin__card.is-shaking { animation: bz-pin-shake 0.4s ease-in-out; }
@keyframes bz-pin-shake {
    0%, 100% { transform: translateX(0); }
    20%      { transform: translateX(-9px); }
    40%      { transform: translateX(8px); }
    60%      { transform: translateX(-5px); }
    80%      { transform: translateX(3px); }
}
@media (prefers-reduced-motion: reduce) {
    .bz-pin__mascot.is-angry,
    .bz-pin__card.is-shaking { animation: none; }
}
.bz-pin__eyebrow {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bz-orange);
    margin: 0 0 0.5rem;
}
.bz-pin__title {
    font-size: 1.85rem;
    font-weight: 900;
    line-height: 1.1;
    margin: 0 0 0.5rem;
}
.bz-pin__subtitle {
    font-size: 0.95rem;
    color: rgba(26,26,26,0.7);
    margin: 0;
    line-height: 1.5;
}
.bz-pin__form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.bz-pin__label {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(26,26,26,0.55);
    margin: 0.5rem 0 0.5rem;
}
.bz-pin__triplet {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}
.bz-pin__chunk {
    flex: 1 1 0;
    min-width: 0;
    font-family: var(--bz-font-mono);
    font-size: 2.4rem;
    font-weight: 700;
    text-align: center;
    letter-spacing: 0.12em;
    padding: 0.9rem 0.4rem;
    border: 3px solid var(--bz-black);
    border-radius: var(--bz-radius);
    background: var(--bz-cream);
    color: var(--bz-black);
    outline: none;
    transition: box-shadow 120ms ease, transform 120ms ease, background 120ms ease;
    -moz-appearance: textfield;
}
.bz-pin__chunk::-webkit-outer-spin-button,
.bz-pin__chunk::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.bz-pin__chunk:focus {
    box-shadow: 4px 4px 0 0 var(--bz-orange);
    transform: translate(-1px, -1px);
    background: #fff;
}
.bz-pin__chunk.is-invalid {
    border-color: var(--bz-danger);
    background: var(--bz-danger-soft);
}
.bz-pin__sep {
    color: rgba(26,26,26,0.35);
    font-family: var(--bz-font-mono);
    font-size: 1.8rem;
    font-weight: 700;
    user-select: none;
}
.bz-pin__error {
    margin-top: 0.5rem;
    padding: 0.6rem 0.8rem;
    background: var(--bz-danger-soft);
    color: #9B1F1F;
    border: 2px solid var(--bz-danger);
    border-radius: var(--bz-radius-sm);
    font-weight: 600;
    font-size: 0.9rem;
}
.bz-pin__cta {
    margin-top: 1rem;
    padding: 0.95rem 1.25rem;
    background: var(--bz-black);
    color: var(--bz-yellow);
    border: 3px solid var(--bz-black);
    border-radius: var(--bz-radius);
    font-family: var(--bz-font-sans);
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    text-decoration: none;
    box-shadow: 4px 4px 0 0 var(--bz-orange);
    transition: transform 120ms ease, box-shadow 120ms ease;
}
.bz-pin__cta:hover {
    transform: translate(-1px, -1px);
    box-shadow: 6px 6px 0 0 var(--bz-orange);
}
.bz-pin__cta:active {
    transform: translate(2px, 2px);
    box-shadow: 1px 1px 0 0 var(--bz-orange);
}
.bz-pin__legal {
    margin: 0.75rem 0 0;
    font-size: 0.72rem;
    color: rgba(26,26,26,0.45);
    text-align: center;
}
.bz-pin__tagline {
    font-size: 0.9rem;
    color: rgba(26,26,26,0.6);
    margin: 0;
}
.bz-pin__tagline strong { color: var(--bz-black); }

/* ==================================================================
 * 8. Domatore admin dashboard (Admin/Dashboard.cshtml)
 *    Brand palette completa: giallo come canvas energetico, nero
 *    strutturale, arancione come accent, crema soffice, navy per i
 *    titoli. La mascotte è presente perché questa è l'area "founder",
 *    non il B2B aziende. Tono ironico-complice da brand book §07.
 * ================================================================== */
.theme-domatore {
    background:
        radial-gradient(1100px 500px at 0% -10%, var(--bz-yellow-soft) 0, transparent 60%),
        radial-gradient(800px 500px at 100% 110%, var(--bz-orange-soft) 0, transparent 70%),
        var(--bz-cream);
    color: var(--bz-black);
    min-height: 100vh;
}

.bz-admin-nav {
    background: var(--bz-black);
    color: var(--bz-yellow);
    border-bottom: 4px solid var(--bz-yellow);
}
.bz-admin-nav__inner {
    max-width: var(--bz-container-wide);
    margin: 0 auto;
    padding: 0.9rem 1.5rem;
    display: flex;
    align-items: center;
    gap: 1.5rem;
}
.bz-admin-nav__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    color: var(--bz-yellow);
}
.bz-admin-nav__brand img {
    height: 28px;
    display: block;
}
.bz-admin-nav__pill {
    background: var(--bz-yellow);
    color: var(--bz-black);
    padding: 0.18rem 0.5rem;
    border-radius: var(--bz-radius-full);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.bz-admin-nav__links {
    display: flex;
    gap: 0.25rem;
    margin-left: 1rem;
    flex-grow: 1;
}
.bz-admin-nav__link {
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    padding: 0.4rem 0.8rem;
    border-radius: var(--bz-radius-sm);
    font-size: 0.92rem;
    font-weight: 600;
    transition: background 120ms ease, color 120ms ease;
}
.bz-admin-nav__link:hover { color: var(--bz-yellow); }
.bz-admin-nav__link.is-active {
    color: var(--bz-black);
    background: var(--bz-yellow);
}
.bz-admin-nav__logout-btn {
    background: transparent;
    color: var(--bz-yellow);
    border: 2px solid var(--bz-yellow);
    border-radius: var(--bz-radius-full);
    padding: 0.35rem 0.9rem;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
}
.bz-admin-nav__logout-btn:hover {
    background: var(--bz-yellow);
    color: var(--bz-black);
}

.bz-admin {
    max-width: var(--bz-container-wide);
    margin: 0 auto;
    padding: 2rem 1.5rem 5rem;
    display: flex;
    flex-direction: column;
    gap: 1.75rem;
}

.bz-adm-flash {
    background: var(--bz-success-soft);
    color: #2F5817;
    border: 2px solid var(--bz-success);
    border-radius: var(--bz-radius);
    padding: 0.85rem 1.1rem;
    font-size: 0.95rem;
    box-shadow: 3px 3px 0 0 rgba(151,196,89,0.5);
}
.bz-adm-flash--error {
    background: var(--bz-danger-soft);
    color: #7A1A1A;
    border-color: var(--bz-danger);
    box-shadow: 3px 3px 0 0 rgba(226,75,74,0.4);
}

.bz-adm-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 1.2rem;
}
.bz-adm-cta {
    background: var(--bz-black);
    color: var(--bz-yellow);
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius);
    padding: 0.6rem 1.1rem;
    font-family: var(--bz-font-sans);
    font-size: 0.92rem;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 3px 3px 0 0 var(--bz-orange);
    transition: transform 120ms ease, box-shadow 120ms ease;
}
.bz-adm-cta:hover { transform: translate(-1px, -1px); box-shadow: 5px 5px 0 0 var(--bz-orange); }
.bz-adm-cta:active { transform: translate(2px, 2px); box-shadow: 1px 1px 0 0 var(--bz-orange); }
.bz-adm-cta--primary { background: var(--bz-black); color: var(--bz-yellow); }
.bz-adm-cta--ghost {
    background: transparent;
    color: var(--bz-black);
    border-color: var(--bz-black);
    box-shadow: 3px 3px 0 0 var(--bz-black);
}
.bz-adm-cta--ghost:hover { box-shadow: 5px 5px 0 0 var(--bz-black); }

/* ---- Hero ---- */
.bz-adm-hero {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center;
    background: var(--bz-yellow);
    border: 3px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.75rem 2rem;
    box-shadow: 8px 8px 0 0 var(--bz-black);
}
.bz-adm-hero__eyebrow {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bz-black);
    opacity: 0.6;
    margin: 0 0 0.4rem;
}
.bz-adm-hero__title {
    font-size: clamp(1.7rem, 3vw, 2.4rem);
    font-weight: 900;
    line-height: 1.05;
    color: var(--bz-black);
    margin: 0 0 0.6rem;
}
.bz-adm-hero__sub {
    font-size: 1.02rem;
    color: rgba(26,26,26,0.78);
    margin: 0 0 1rem;
    max-width: 38em;
}
.bz-adm-hero__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.bz-adm-hero__chip {
    background: var(--bz-black);
    color: var(--bz-yellow);
    padding: 0.3rem 0.7rem;
    border-radius: var(--bz-radius-full);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.bz-adm-hero__mascot img {
    width: 150px;
    height: 150px;
    filter: drop-shadow(5px 5px 0 var(--bz-black));
}

/* ---- KPI grid ---- */
.bz-adm-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}
.bz-adm-kpi {
    background: #fff;
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.25rem 1.35rem;
    box-shadow: 4px 4px 0 0 var(--bz-black);
}
.bz-adm-kpi--primary {
    background: var(--bz-black);
    color: var(--bz-yellow);
    box-shadow: 4px 4px 0 0 var(--bz-orange);
}
.bz-adm-kpi--primary .bz-adm-kpi__sub { color: rgba(255,255,255,0.65); }
.bz-adm-kpi__label {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    opacity: 0.65;
    margin: 0 0 0.35rem;
}
.bz-adm-kpi__value {
    font-family: var(--bz-font-mono);
    font-size: 2.2rem;
    font-weight: 700;
    margin: 0 0 0.35rem;
    line-height: 1.05;
}
.bz-adm-kpi__sub {
    font-size: 0.85rem;
    color: rgba(26,26,26,0.6);
    margin: 0;
}

/* ---- Inventory grid ---- */
.bz-adm-inv {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.6rem;
    background: var(--bz-cream-deep);
    border: 2px dashed var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1rem;
}
.bz-adm-inv__cell {
    background: #fff;
    border-radius: var(--bz-radius);
    padding: 0.9rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    border-bottom: 3px solid var(--bz-black);
}
.bz-adm-inv__cell--accent {
    background: var(--bz-orange);
    color: var(--bz-black);
}
.bz-adm-inv__num {
    font-family: var(--bz-font-mono);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--bz-black);
    line-height: 1.1;
}
.bz-adm-inv__lbl {
    font-size: 0.78rem;
    font-weight: 600;
    color: rgba(26,26,26,0.65);
}
.bz-adm-inv__cell--accent .bz-adm-inv__lbl { color: rgba(26,26,26,0.85); }

/* ---- Two column section ---- */
.bz-adm-two-col {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 1.25rem;
}

/* ---- Generic card ---- */
.bz-adm-card {
    background: #fff;
    border: 2.5px solid var(--bz-black);
    border-radius: var(--bz-radius-lg);
    padding: 1.5rem 1.5rem 1.75rem;
    box-shadow: 4px 4px 0 0 var(--bz-black);
}
.bz-adm-card__head {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}
.bz-adm-card__title {
    font-size: 1.15rem;
    font-weight: 800;
    margin: 0;
    color: var(--bz-navy);
}
.bz-adm-card__hint {
    font-size: 0.82rem;
    color: rgba(26,26,26,0.55);
}

.bz-adm-map {
    height: 30rem;
    border-radius: var(--bz-radius-lg);
    border: 2.5px solid var(--bz-black);
    overflow: hidden;
}
.bz-adm-map__note {
    margin: 0.85rem 0 0;
    font-size: 0.82rem;
    color: rgba(26,26,26,0.55);
}
.bz-adm-pin { background: none; border: none; }
.bz-adm-pin__badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 2px solid var(--bz-black);
    box-shadow: 0 1px 3px rgba(0,0,0,0.4);
    color: #fff;
    font-family: var(--bz-font-sans);
    font-weight: 800;
    font-size: 0.72rem;
    letter-spacing: 0.02em;
    text-shadow: 0 1px 1px rgba(0,0,0,0.35);
}

.bz-adm-empty {
    display: flex;
    gap: 1.5rem;
    align-items: center;
}
.bz-adm-empty img { width: 110px; height: 110px; }
.bz-adm-empty__sub { color: rgba(26,26,26,0.65); margin: 0.4rem 0 0; }
.bz-adm-empty-inline {
    text-align: center;
    padding: 1.5rem 0;
    color: rgba(26,26,26,0.5);
    font-size: 0.92rem;
}

/* ---- Daily bars chart ---- */
.bz-adm-bars {
    display: grid;
    grid-template-columns: repeat(14, 1fr);
    gap: 4px;
    height: 180px;
    align-items: end;
    padding: 0 0.25rem;
}
.bz-adm-bar {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: end;
    height: 100%;
    cursor: help;
}
.bz-adm-bar__fill {
    width: 100%;
    border-radius: 4px 4px 0 0;
    transition: height 200ms ease;
    background: var(--bz-grey-200);
}
.bz-adm-bar.is-good  .bz-adm-bar__fill { background: var(--bz-success); }
.bz-adm-bar.is-ok    .bz-adm-bar__fill { background: var(--bz-yellow); }
.bz-adm-bar.is-warn  .bz-adm-bar__fill { background: var(--bz-warning); }
.bz-adm-bar.is-bad   .bz-adm-bar__fill { background: var(--bz-danger); }
.bz-adm-bar.is-empty .bz-adm-bar__fill { background: var(--bz-grey-200); opacity: 0.6; }
.bz-adm-bar__val {
    font-size: 0.62rem;
    font-weight: 700;
    text-align: center;
    color: rgba(26,26,26,0.72);
    margin-bottom: 3px;
    font-variant-numeric: tabular-nums;
    line-height: 1;
}
.bz-adm-bar__lbl {
    position: absolute;
    bottom: -1.3rem;
    left: 50%;
    transform: translateX(-50%) rotate(-50deg);
    transform-origin: top left;
    font-size: 0.65rem;
    color: rgba(26,26,26,0.55);
    white-space: nowrap;
}
.bz-adm-bars__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
    margin-top: 2.2rem;
    font-size: 0.78rem;
    color: rgba(26,26,26,0.6);
}
.bz-adm-bars__legend-item { display: inline-flex; align-items: center; gap: 0.35rem; }
.bz-adm-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
}
.bz-adm-dot--good { background: var(--bz-success); }
.bz-adm-dot--ok   { background: var(--bz-yellow); }
.bz-adm-dot--warn { background: var(--bz-warning); }
.bz-adm-dot--bad  { background: var(--bz-danger); }

/* ---- Mood distribution ---- */
.bz-adm-moods {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.55rem;
}
.bz-adm-mood {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 0.85rem;
    align-items: center;
    background: var(--bz-cream);
    border-radius: var(--bz-radius);
    padding: 0.55rem 0.85rem;
}
.bz-adm-mood__face {
    width: 44px;
    height: 44px;
}
.bz-adm-mood__top {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 0.3rem;
}
.bz-adm-mood__name {
    font-weight: 700;
    color: var(--bz-black);
    font-size: 0.95rem;
}
.bz-adm-mood__count {
    color: rgba(26,26,26,0.65);
    font-size: 0.88rem;
}
.bz-adm-mood__bar {
    height: 8px;
    background: rgba(26,26,26,0.08);
    border-radius: var(--bz-radius-full);
    overflow: hidden;
}
.bz-adm-mood__fill {
    display: block;
    height: 100%;
    border-radius: var(--bz-radius-full);
    transition: width 280ms ease;
}
.bz-adm-mood--happy      .bz-adm-mood__fill { background: var(--bz-success); }
.bz-adm-mood--neutral    .bz-adm-mood__fill { background: var(--bz-grey-400); }
.bz-adm-mood--suspicious .bz-adm-mood__fill { background: var(--bz-warning); }
.bz-adm-mood--angry      .bz-adm-mood__fill { background: var(--bz-danger); }
.bz-adm-mood--sleeping   .bz-adm-mood__fill { background: var(--bz-info); }
.bz-adm-mood--celebrate  .bz-adm-mood__fill { background: var(--bz-orange); }

/* ---- Table ---- */
.bz-adm-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.93rem;
}
.bz-adm-table thead th {
    text-align: left;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(26,26,26,0.55);
    padding: 0.5rem 0.6rem;
    border-bottom: 2px solid var(--bz-black);
}
.bz-adm-table tbody td {
    padding: 0.75rem 0.6rem;
    border-bottom: 1px solid rgba(26,26,26,0.08);
    vertical-align: middle;
}
.bz-adm-table tbody tr:last-child td { border-bottom: none; }
.bz-adm-table__num { text-align: right; }
.bz-adm-table__primary { display: block; font-weight: 700; color: var(--bz-black); }
.bz-adm-table__secondary {
    display: block;
    font-size: 0.78rem;
    color: rgba(26,26,26,0.55);
    margin-top: 0.1rem;
}

.bz-adm-badge {
    display: inline-block;
    background: var(--bz-yellow);
    color: var(--bz-black);
    border: 2px solid var(--bz-black);
    border-radius: var(--bz-radius-sm);
    font-family: var(--bz-font-mono);
    font-weight: 700;
    font-size: 0.85rem;
    padding: 0.18rem 0.55rem;
    min-width: 40px;
    text-align: center;
}
.bz-adm-badge--feed { background: var(--bz-cream-deep); }

/* ---- Stops ranked list ---- */
.bz-adm-stops {
    list-style: none;
    margin: 0;
    padding: 0;
}
.bz-adm-stops__row {
    display: grid;
    grid-template-columns: 28px 1fr auto auto;
    align-items: center;
    gap: 0.85rem;
    padding: 0.7rem 0.25rem;
    border-bottom: 1px solid rgba(26,26,26,0.07);
}
.bz-adm-stops__row:last-child { border-bottom: none; }
.bz-adm-stops__rank {
    font-family: var(--bz-font-mono);
    font-weight: 700;
    font-size: 0.85rem;
    color: var(--bz-orange);
}
.bz-adm-stops__name { font-weight: 600; }
.bz-adm-stops__count { color: rgba(26,26,26,0.85); font-size: 0.9rem; }
.bz-adm-stops__delay {
    color: rgba(26,26,26,0.6);
    font-size: 0.82rem;
    min-width: 70px;
    text-align: right;
}

/* ---- Feed ---- */
.bz-adm-feed {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}
.bz-adm-feed__item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: center;
    padding: 0.75rem 0.85rem;
    background: var(--bz-cream);
    border-radius: var(--bz-radius);
}
.bz-adm-feed__line {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    align-items: center;
    font-size: 0.93rem;
}
.bz-adm-feed__meta {
    margin: 0.2rem 0 0;
    font-size: 0.78rem;
    color: rgba(26,26,26,0.5);
}
.bz-adm-feed__delay {
    font-size: 0.82rem;
    color: var(--bz-danger);
}
.bz-adm-feed__occ {
    font-size: 0.78rem;
    color: rgba(26,26,26,0.55);
    text-transform: lowercase;
}
.bz-adm-feed__valid {
    font-size: 0.75rem;
    color: var(--bz-success);
    font-weight: 700;
}

/* ---- Status pills ---- */
.bz-adm-pill {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.15rem 0.55rem;
    border-radius: var(--bz-radius-full);
    background: var(--bz-grey-200);
    color: var(--bz-grey-700);
}
.bz-adm-pill--ok   { background: var(--bz-success-soft); color: #4F7A29; }
.bz-adm-pill--warn { background: var(--bz-warning-soft); color: #B4690F; }
.bz-adm-pill--bad  { background: var(--bz-danger-soft);  color: #9B1F1F; }
.bz-adm-pill--info { background: var(--bz-info-soft);    color: #1A4D80; }

.bz-mono { font-family: var(--bz-font-mono); }

.bz-adm-footnote {
    text-align: center;
    font-size: 0.82rem;
    color: rgba(26,26,26,0.45);
    margin: 1rem 0 0;
}

@media (max-width: 720px) {
    .bz-adm-hero { grid-template-columns: 1fr; text-align: left; }
    .bz-adm-hero__mascot img { width: 110px; height: 110px; }
    .bz-admin-nav__links { display: none; }
}

/* ==================================================================
 * 10. B2B login (institutional palette, no mascot — brand book §07)
 *     Used by Views/B2B/Login.cshtml and AccessDenied.cshtml.
 * ================================================================== */
.b2b-login__body {
    margin: 0;
    min-height: 100vh;
    background:
        radial-gradient(circle at 18% 22%, rgba(85,153,221,0.25) 0, transparent 45%),
        radial-gradient(circle at 80% 78%, rgba(255,122,69,0.18) 0, transparent 45%),
        var(--bz-navy);
    color: #fff;
    font-family: var(--bz-font-sans);
}
.b2b-login {
    min-height: 100vh;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 2.5rem 1rem; gap: 1.5rem;
}
.b2b-login__back {
    color: rgba(255,255,255,0.6); font-size: 0.85rem; text-decoration: none;
    align-self: flex-start; margin-bottom: 0.5rem; padding-left: 0.25rem;
}
.b2b-login__back:hover { color: #fff; }
.b2b-login__card {
    width: 100%; max-width: 56rem;
    display: grid; grid-template-columns: 1.4fr 1fr;
    background: #fff; color: var(--bz-grey-800);
    border-radius: var(--bz-radius-lg);
    overflow: hidden;
    box-shadow: 0 30px 70px -25px rgba(0,0,0,0.55);
}
@media (max-width: 760px) { .b2b-login__card { grid-template-columns: 1fr; } }
.b2b-login__head { padding: 2.5rem 2.5rem 1.5rem; }
.b2b-login__eyebrow {
    text-transform: uppercase; font-size: 0.72rem; font-weight: 700;
    letter-spacing: 0.14em; color: var(--bz-orange); margin: 0 0 0.6rem;
}
.b2b-login__title { font-size: 1.85rem; font-weight: 800; margin: 0 0 0.7rem; color: var(--bz-grey-900, var(--bz-black)); letter-spacing: -0.02em; }
.b2b-login__subtitle { color: var(--bz-grey-600); margin: 0; font-size: 0.95rem; }
.b2b-login__form { padding: 0 2.5rem 2.5rem; }
.b2b-login__label {
    display: block; font-size: 0.78rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--bz-grey-500); margin: 0.85rem 0 0.35rem;
}
.b2b-login__input {
    width: 100%; padding: 0.7rem 0.9rem;
    border: 1.5px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-sm);
    font-size: 0.95rem; font-family: var(--bz-font-sans);
    background: #fff; color: var(--bz-grey-900, var(--bz-black));
    transition: border-color 120ms ease, box-shadow 120ms ease;
}
.b2b-login__input:focus {
    outline: none; border-color: var(--bz-navy);
    box-shadow: 0 0 0 3px rgba(45,49,66,0.15);
}
.b2b-login__input.is-invalid { border-color: var(--bz-danger); box-shadow: 0 0 0 3px rgba(226,75,74,0.15); }
.b2b-login__error {
    margin-top: 0.85rem; padding: 0.55rem 0.8rem;
    background: var(--bz-danger-soft); color: #9B1F1F;
    border-radius: var(--bz-radius-sm);
    font-size: 0.85rem; font-weight: 600;
}
.b2b-login__cta {
    display: inline-flex; align-items: center; gap: 0.4rem;
    margin-top: 1.5rem;
    padding: 0.85rem 1.5rem;
    background: var(--bz-navy); color: #fff; border: 0;
    font-weight: 700; font-size: 0.95rem;
    border-radius: var(--bz-radius-sm);
    cursor: pointer; transition: background 150ms ease;
    text-decoration: none;
}
.b2b-login__cta:hover { background: var(--bz-navy-deep); }
.b2b-login__legal {
    margin-top: 1.5rem; font-size: 0.78rem; color: var(--bz-grey-500);
}
.b2b-login__aside {
    background: var(--bz-grey-50);
    border-left: 1px solid var(--bz-grey-200);
    padding: 2.5rem;
    display: flex; flex-direction: column; gap: 0.75rem;
}
.b2b-login__aside-title { margin: 0; font-weight: 800; color: var(--bz-grey-800); }
.b2b-login__aside-body  { margin: 0; font-size: 0.9rem; color: var(--bz-grey-600); }
.b2b-login__aside-link  {
    margin-top: auto; align-self: flex-start;
    color: var(--bz-orange); font-weight: 600; text-decoration: none;
    font-size: 0.92rem;
}
.b2b-login__aside-link:hover { text-decoration: underline; }
.b2b-login__tagline { color: rgba(255,255,255,0.75); font-size: 0.85rem; }

/* ==================================================================
 * 11. B2B portal — top nav extensions (logout button + plan bar)
 * ================================================================== */
.b2b-nav__logout {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.45rem 0.75rem;
    background: var(--bz-grey-50); color: var(--bz-grey-600);
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-sm);
    font-size: 0.85rem; font-weight: 600; cursor: pointer;
    font-family: inherit;
}
.b2b-nav__logout:hover { background: var(--bz-grey-100); color: var(--bz-grey-900, var(--bz-black)); }
.b2b-nav__logout-label { display: inline; }
@media (max-width: 760px) { .b2b-nav__logout-label { display: none; } }

.b2b-nav__planbar {
    background: var(--bz-navy);
    color: rgba(255,255,255,0.85);
    font-size: 0.82rem;
    padding: 0.4rem 1.5rem;
    border-bottom: 1px solid var(--bz-navy-deep);
}
.b2b-nav__planbar strong { color: #fff; font-weight: 700; }
.b2b-nav__planbar a { color: var(--bz-orange); text-decoration: none; margin-left: 0.25rem; }
.b2b-nav__planbar a:hover { text-decoration: underline; }

/* ==================================================================
 * 12. B2B API documentation pages (Views/B2BApiDocs/*)
 * ================================================================== */
.b2b-plan-badge {
    display: inline-flex; align-items: center; gap: 0.3rem;
    padding: 0.4rem 0.85rem;
    background: var(--bz-grey-100); color: var(--bz-grey-700);
    border-radius: var(--bz-radius-full);
    font-weight: 700; font-size: 0.8rem;
    text-transform: uppercase; letter-spacing: 0.04em;
    border: 1px solid var(--bz-grey-200);
}
.b2b-plan-badge--dashboardonly { background: var(--bz-grey-100);     color: var(--bz-grey-700); }
.b2b-plan-badge--starter       { background: var(--bz-info-soft);    color: #1d4f80; border-color: rgba(85,153,221,0.4); }
.b2b-plan-badge--pro           { background: var(--bz-success-soft); color: #4F7A29; border-color: rgba(151,196,89,0.4); }
.b2b-plan-badge--enterprise    { background: var(--bz-navy);         color: #fff;     border-color: var(--bz-navy-deep); }

.b2b-api-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem; margin-bottom: 1.5rem;
}
@media (max-width: 1000px) { .b2b-api-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .b2b-api-grid { grid-template-columns: 1fr; } }

.b2b-code {
    background: #0F1320;
    color: #E2E8F0;
    border-radius: var(--bz-radius-sm);
    padding: 1rem 1.1rem;
    overflow-x: auto;
    font-family: var(--bz-font-mono);
    font-size: 0.83rem;
    line-height: 1.55;
    margin: 0.5rem 0;
}
.b2b-code code { color: inherit; background: transparent; padding: 0; font-family: inherit; }
.b2b-code-inline {
    font-family: var(--bz-font-mono); font-size: 0.85rem;
    padding: 0.1rem 0.4rem; border-radius: var(--bz-radius-xs);
    background: var(--bz-grey-100); color: var(--bz-grey-800);
}

.b2b-pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}
.b2b-pricing {
    background: #fff;
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-lg);
    padding: 1.5rem;
    display: flex; flex-direction: column;
    gap: 0.75rem;
}
.b2b-pricing.is-current {
    border-color: var(--bz-navy);
    box-shadow: 0 0 0 3px rgba(45,49,66,0.10);
}
.b2b-pricing__name {
    font-size: 1.2rem; font-weight: 800; margin: 0;
    color: var(--bz-grey-900, var(--bz-black));
}
.b2b-pricing__price {
    margin: 0; color: var(--bz-grey-600); font-size: 0.92rem;
}
.b2b-pricing__features {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 0.45rem;
    font-size: 0.88rem; color: var(--bz-grey-700);
    border-top: 1px dashed var(--bz-grey-200);
    padding-top: 0.85rem;
}
.b2b-pricing__features strong { color: var(--bz-grey-900, var(--bz-black)); }
.b2b-pricing__cta {
    display: inline-block;
    margin-top: auto;
    padding: 0.65rem 1rem;
    background: var(--bz-orange); color: #fff;
    border-radius: var(--bz-radius-sm);
    font-weight: 700; font-size: 0.9rem;
    text-decoration: none; text-align: center;
}
.b2b-pricing__cta:hover { background: #E65A1E; }
.b2b-pricing.is-current .b2b-pricing__cta {
    background: var(--bz-navy);
}

.b2b-api-doc {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 1.5rem;
    align-items: flex-start;
}
@media (max-width: 800px) { .b2b-api-doc { grid-template-columns: 1fr; } }

.b2b-api-doc__aside {
    background: #fff;
    border: 1px solid var(--bz-grey-200);
    border-radius: var(--bz-radius-lg);
    padding: 1.25rem;
    position: sticky; top: 80px;
}
.b2b-api-doc__aside-label {
    text-transform: uppercase; letter-spacing: 0.08em;
    font-size: 0.72rem; font-weight: 700;
    color: var(--bz-grey-500); margin: 0 0 0.6rem;
}
.b2b-api-doc__aside-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.b2b-api-doc__aside-list a {
    display: block;
    padding: 0.45rem 0.65rem;
    color: var(--bz-grey-700);
    font-family: var(--bz-font-mono); font-size: 0.78rem;
    border-radius: var(--bz-radius-sm);
    text-decoration: none;
    line-height: 1.4;
}
.b2b-api-doc__aside-list a:hover { background: var(--bz-grey-50); color: var(--bz-grey-900, var(--bz-black)); }
.b2b-api-doc__aside-list a.is-active {
    background: var(--bz-orange-soft); color: var(--bz-orange); font-weight: 700;
}
.b2b-api-doc__main { min-width: 0; }

