:root {
    --internal-bg: #101214;
    --internal-panel: #181c20;
    --internal-panel-soft: #20262b;
    --internal-border: #343b43;
    --internal-text: #f3f4f2;
    --internal-muted: #aeb6bd;
    --internal-gold: #d6a83f;
    --internal-red: #d86155;
    --internal-yellow: #d8b84e;
    --internal-green: #58b77a;
    --internal-blue: #6d99d6;
}

/* Layout app-like: topbar fissa + pannelli a scrolling indipendente */
.internal-app {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
    background: var(--internal-bg);
    color: var(--internal-text);
}

.internal-login {
    margin: 0;
    min-height: 100vh;
    background: var(--internal-bg);
    color: var(--internal-text);
}

/* ══ TOPBAR INTERNA — 2 righe ═══════════════════════════════════════════
   Riga 1: brand
   Riga 2: [🧪 ? + AI bar ←sinistra]   [nav →destra]
══════════════════════════════════════════════════════════════════════════ */
.internal-topbar {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 9px clamp(12px, 2vw, 28px) 8px;
    border-bottom: 1px solid var(--internal-border);
    background: #121518;
}

/* Riga 1: brand */
.itb-row1 {
    display: flex;
    align-items: center;
}
.itb-logo {
    display: flex;
    align-items: center;
    gap: 7px;
}
.itb-mark {
    color: var(--internal-gold);
    font-size: 14px; font-weight: 900; line-height: 1;
}
.itb-titles { display: flex; flex-direction: column; gap: 1px; line-height: 1; }
.itb-kicker {
    font-size: 8px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .1em; color: var(--internal-gold); opacity: .7;
}
.itb-name {
    font-size: 13px; font-weight: 800; color: #e5e5e5;
    letter-spacing: .02em; text-transform: uppercase;
}

/* Riga 2: AI bar (sinistra, flex:1) + nav (destra, auto) */
.itb-row2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.itb-row2-left {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
    min-width: 0;
}

/* Nav destra */
.itb-nav {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}
.itb-nav-links {
    display: flex; align-items: center; gap: 2px;
    padding-right: 6px; border-right: 1px solid rgba(255,255,255,.08);
}
.itb-nav-links a {
    color: var(--internal-gold); font-size: 11px; font-weight: 600;
    padding: 4px 8px; border-radius: 4px; transition: background .15s; white-space: nowrap;
}
.itb-nav-links a:hover { background: rgba(214,168,63,.1); }
.itb-user {
    display: flex; align-items: center; gap: 8px;
    padding-left: 6px; border-left: 1px solid rgba(255,255,255,.08);
}
.itb-logout { font-size: 11px; color: rgba(255,255,255,.35) !important; transition: color .15s; }
.itb-logout:hover { color: rgba(255,255,255,.7) !important; }

/* itb-utils rimosso — i pulsanti ora sono in itb-row2-left direttamente */

/* Gruppo passthrough — portali esterni (solo admin) */
.nav-passthrough-group {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 3px 8px;
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 5px;
    background: rgba(255,255,255,.03);
}
.nav-passthrough-group a {
    color: rgba(255,255,255,.45) !important;
    font-size: 11px;
    transition: color .15s;
    white-space: nowrap;
}
.nav-passthrough-group a:hover { color: rgba(255,255,255,.8) !important; }

/* Compat — topbar h1/p restano usati dal login panel */
.internal-topbar h1,
.internal-login-panel h1 {
    margin: 4px 0 6px;
    font-size: 30px;
    letter-spacing: 0;
}
.internal-topbar p,
.internal-login-panel p {
    margin: 0;
    color: var(--internal-muted);
}
.internal-topbar a { color: var(--internal-gold); }

/* ── V7: badge ruolo utente nella nav ──────────────────────── */
.nav-user-info { display: flex; align-items: center; gap: 5px; font-size: 11px; color: rgba(255,255,255,.6); }
.nav-role-badge {
    font-size: 8px; font-weight: 800; text-transform: uppercase;
    letter-spacing: .08em; padding: 2px 6px; border-radius: 3px;
    vertical-align: middle;
}
.nav-role-badge.role-admin       { background: rgba(214,168,63,.18);  color: #d6a83f; border: 1px solid rgba(214,168,63,.3); }
.nav-role-badge.role-logistica   { background: rgba(99,179,237,.12);  color: #63b3ed; border: 1px solid rgba(99,179,237,.25); }
.nav-role-badge.role-operatore   { background: rgba(74,222,128,.10);  color: #4ade80; border: 1px solid rgba(74,222,128,.2); }
.nav-role-badge.role-subvettori  { background: rgba(167,139,250,.10); color: #a78bfa; border: 1px solid rgba(167,139,250,.2); }
.nav-role-badge.role-operatore_base { background: rgba(248,113,113,.08); color: #f87171; border: 1px solid rgba(248,113,113,.2); }

/* Classe body per CSS basato su ruolo */
body.role-subvettori .pv1-sel-targa-label,
body.role-operatore  .pv1-sel-targa-label { display: none; } /* nascondi targa nel header dettaglio */
.colli-match-type-only {
    font-size: 12px; padding: 6px 8px; margin: 4px 0;
    border-radius: 4px; background: rgba(255,255,255,.03);
}

.internal-kicker {
    display: block;
    color: var(--internal-gold);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.internal-shell {
    flex: 1;
    min-height: 0;               /* permette di shrinkare dentro il flex parent */
    display: grid;
    grid-template-columns: minmax(360px, 0.88fr) minmax(420px, 1.12fr);
    gap: 18px;
    padding: 14px clamp(16px, 4vw, 48px);
    align-items: stretch;        /* pannelli a tutta altezza disponibile */
}

.internal-panel,
.internal-login-panel {
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    background: var(--internal-panel);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
}

.internal-form-panel,
.internal-results {
    position: relative;
    overflow: visible;      /* il bordo del gruppo deve restare libero: l'etichetta vi sborda sopra */
    display: flex;
    flex-direction: column;
    /* Con overflow: visible il browser non azzera piu' automaticamente la
       dimensione minima dell'elemento nella griglia (lo fa solo per overflow
       non-visible): senza questo min-height esplicito la riga della griglia
       cresce fino al contenuto, il pannello perde l'altezza vincolata e lo
       scorrimento interno (quindi quello "della pagina") sparisce. */
    min-height: 0;
}

/* Contenitore interno scorrevole: qui vivono padding e overflow, separati dal
   bordo del pannello, cosi' l'etichetta INPUT/OUTPUT puo' sovrapporsi al bordo
   senza essere tagliata dallo scrollport. */
.internal-panel-scroll {
    padding: 18px;
    overflow-y: auto;
    overflow-x: clip;   /* clip non blocca position:sticky a differenza di hidden */
    flex: 1;
    min-height: 0;
}

/* Tab INPUT / OUTPUT — etichetta "a rubrica": sborda e si sovrappone al bordo
   superiore del gruppo, restando interamente visibile (il pannello ora ha
   overflow: visible, quindi non viene piu' tagliata). */
.internal-form-panel::before,
.internal-results::before {
    position: absolute;
    top: -9px;
    right: 22px;
    padding: 2px 12px 4px;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 0.16em;
    border-radius: 5px;
    pointer-events: none;
    z-index: 2;
}

.internal-form-panel::before {
    content: 'INPUT';
    background: rgba(36, 34, 28, 0.92);
    border: 1px solid rgba(255,255,255,0.14);
    color: rgba(184, 192, 199, 0.75);
}

.internal-results::before {
    content: 'OUTPUT';
    right: auto;
    left: 22px;   /* speculare a INPUT che è right: 22px */
    background: rgba(36, 34, 28, 0.92);
    border: 1px solid rgba(214, 168, 63, 0.32);
    color: rgba(214, 168, 63, 0.75);
}

/* Header pannello form: tab a sinistra + tasto Calcola a destra */
.form-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 14px;
}
.btn-calcola-top {
    position: relative;
    overflow: hidden;
    /* Distanza fissa dall'etichetta "INPUT" (posizionata a right:22px, top:0 sul pannello):
       margine ancorato per evitare sovrapposizioni quando si tocca il layout.
       Il bagliore (box-shadow) è stato inoltre ridotto perché il suo alone
       arrivava visivamente a toccare l'etichetta anche col margine aumentato. */
    margin-right: 52px;
    margin-top: 2px;
    padding: 5px 18px;
    font-size: 12.5px;
    font-weight: 800;
    background:
        linear-gradient(135deg, #f0cf7a 0%, var(--internal-gold) 45%, #c79530 100%);
    color: #16140e;
    border: 1px solid rgba(255,255,255,.35);
    border-radius: 6px;
    cursor: pointer;
    letter-spacing: .02em;
    flex-shrink: 0;
    box-shadow: 0 1px 0 rgba(255,255,255,.55) inset, 0 2px 6px rgba(214,168,63,.4);
    transition: box-shadow .15s, transform .12s, filter .12s;
}
/* Riflesso diagonale che scorre sul tasto Calcola: lo distingue dagli altri,
   sottolineandone l'importanza con un effetto "vetro lucido" più ricco */
.btn-calcola-top::after {
    content: "";
    position: absolute;
    top: -60%;
    left: -30%;
    width: 35%;
    height: 220%;
    background: linear-gradient(115deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.55) 50%, rgba(255,255,255,0) 100%);
    transform: rotate(0deg);
    transition: left .5s ease;
    pointer-events: none;
}
.btn-calcola-top:hover::after { left: 130%; }
.btn-calcola-top:hover {
    filter: brightness(1.08);
    box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 3px 10px rgba(214,168,63,.55);
    transform: translateY(-1px);
}
.btn-calcola-top:active { transform: translateY(0); filter: brightness(.96); }

.internal-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 0;
}

.internal-tabs button,
.internal-actions button,
.internal-login-form button {
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    padding: 5px 14px;
    font-size: 12.5px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0) 60%),
        var(--internal-panel-soft);
    color: var(--internal-text);
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 1px 0 rgba(255,255,255,.07) inset;
    transition: box-shadow .15s, transform .12s, border-color .12s;
}
.internal-tabs button:hover,
.internal-actions button:hover:not(:disabled),
.internal-login-form button:hover {
    border-color: var(--internal-gold);
    box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 0 0 1px rgba(214,168,63,.3);
    transform: translateY(-1px);
}

.internal-tabs button.active,
.internal-actions button:first-child,
.internal-login-form button {
    border-color: var(--internal-gold);
    background:
        linear-gradient(180deg, rgba(255,255,255,.32), rgba(255,255,255,0) 55%),
        var(--internal-gold);
    background-blend-mode: overlay;
    color: #16140e;
    box-shadow: 0 1px 0 rgba(255,255,255,.45) inset, 0 2px 10px rgba(214,168,63,.4);
}

.internal-actions button:disabled,
.internal-login-form button:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.internal-form {
    display: grid;
    gap: 8px;    /* ridotto da 16px */
}

.internal-grid {
    display: grid;
    gap: 6px;    /* ridotto da 12px */
}

.internal-grid.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Label-as-box: il bordo è sulla label, non sull'input.
   Il testo della label diventa micro-header in alto a sinistra. */
.internal-form label {
    display: flex;
    flex-direction: column;
    gap: 1px;
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    padding: 4px 9px 4px;
    background: #0f1215;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--internal-muted);
    cursor: default;
}

.internal-login-form label {
    display: grid;
    gap: 7px;
    color: var(--internal-muted);
    font-size: 13px;
    font-weight: 700;
}

/* ── STOP LIST MULTI-FERMATA ──────────────────────────────────────────────── */
.stops-wrapper { display: flex; flex-direction: column; gap: 4px; }
.stops-list    { display: flex; flex-direction: column; gap: 2px; }

.stop-row {
    display: flex; align-items: center; gap: 6px;
    padding: 5px 6px;
    border: 1px solid var(--internal-border);
    border-radius: 6px; background: #0f1215;
    cursor: default; transition: background 80ms; user-select: none;
}
.stop-row.not-verified { border-color: var(--internal-yellow); }
.stop-row.dragging     { opacity: 0.45; }
.stop-row.drag-over    { border-color: var(--internal-gold); background: #1a1e22; }

.drag-handle { color: var(--internal-muted); font-size: 14px; cursor: grab; flex-shrink: 0; line-height: 1; }
.drag-handle:active { cursor: grabbing; }

.stop-num {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--internal-panel-soft); border: 1px solid var(--internal-border);
    font-size: 10px; font-weight: 900; color: var(--internal-muted);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

.stop-tipo-badge {
    flex-shrink: 0; padding: 2px 8px; border-radius: 4px;
    font-size: 9px; font-weight: 900; letter-spacing: 0.08em; white-space: nowrap;
}
.stop-tipo-badge.carico  { background: rgba(88,183,122,0.15); color: var(--internal-green); border: 1px solid rgba(88,183,122,0.3); }
.stop-tipo-badge.scarico { background: rgba(216,97,85,0.15);  color: var(--internal-red);   border: 1px solid rgba(216,97,85,0.3); }

.stop-tipo-sel {
    flex-shrink: 0 !important;
    width: 115px !important;   /* !important: sovrascrive .internal-form select {width:100%} */
    height: 24px !important;
    border: 1px solid var(--internal-border) !important;
    border-radius: 4px !important;
    padding: 2px 4px !important;
    background: #0f1215 !important;
    color: var(--internal-text) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
}

.stop-addr-wrap { flex: 1 !important; min-width: 0; position: relative; }
.stop-addr-input {
    width: 100% !important;
    border: none !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;   /* sottile line visibile */
    border-radius: 0 !important;
    padding: 2px 0 !important;
    background: transparent !important;
    color: var(--internal-text) !important;
    font-size: 12px !important;
    height: 22px !important;
    box-sizing: border-box !important;
}
.stop-addr-input::placeholder { color: rgba(174,182,189,0.4); }
.stop-addr-input.addr-warn { color: var(--internal-yellow) !important; }
.stop-addr-input:focus { outline: none; border-bottom-color: var(--internal-gold) !important; }

.stop-cond-toggle {
    flex-shrink: 0; width: 24px; height: 24px;
    border: 1px solid var(--internal-border); border-radius: 4px;
    background: var(--internal-panel-soft); color: var(--internal-muted);
    font-size: 12px; cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.stop-cond-toggle:hover { border-color: var(--internal-gold); color: var(--internal-gold); }

.stop-remove-btn {
    flex-shrink: 0 !important;
    width: 22px !important; height: 22px !important;
    border: 1px solid rgba(216,97,85,0.4) !important; border-radius: 4px !important;
    background: rgba(216,97,85,0.1) !important; color: var(--internal-red) !important;
    font-size: 15px !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    padding: 0 !important;
}
.stop-remove-placeholder { width: 20px; flex-shrink: 0; }

.stop-cond-panel {
    background: #12161a; border: 1px solid var(--internal-border);
    border-top: none; border-radius: 0 0 6px 6px; padding: 8px 10px 6px; margin-bottom: 2px;
}
/* Wrapper date ritiro+consegna: span 2 colonne, layout interno a 2 colonne */
.date-time-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* Snapshot mappa per stampa: nascosta a schermo, visibile solo @media print */
.map-print-snapshot { display: none; }

/* ── Label inline: testo + select su una riga (per campi compatti) ────── */
.internal-grid .label-inline,
.internal-form .label-inline {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    white-space: nowrap;
}
.internal-grid .label-inline select,
.internal-grid .label-inline input,
.internal-form .label-inline select,
.internal-form .label-inline input {
    flex: 1;
    min-width: 0;
}

/* ── Bottone test (solo utente luca, reso via PHP) ─────────────────────── */
/* Pulsanti utility compatti (icona-only nella nuova topbar) */
.btn-test-fill {
    font-size: 13px; line-height: 1; padding: 4px 6px;
    background: rgba(167,139,250,.08); border: 1px solid rgba(167,139,250,.22);
    color: #a78bfa; border-radius: 4px; cursor: pointer;
    transition: background .12s; opacity: .7;
}
.btn-test-fill:hover { opacity: 1; background: rgba(167,139,250,.16); }

.btn-guide {
    font-size: 11px; font-weight: 800; padding: 4px 7px;
    background: rgba(99,179,237,.08); border: 1px solid rgba(99,179,237,.22);
    color: #63b3ed; border-radius: 4px; cursor: pointer;
    transition: background .12s; opacity: .7;
}
.btn-guide:hover { opacity: 1; background: rgba(99,179,237,.18); }

/* Pulsante Importa AI (Groq) */
/* ── Zona AI header — SINGOLA RIGA compatta ─────────────────────────────────
   Layout: [⚡ AI] | [↑ Trascina/sfoglia  PDF·DOCX] | [📍 maps URL  Importa]
   Altezza allineata ai link nav: nessuna colonna, tutto su un'unica riga.
─────────────────────────────────────────────────────────────────────────── */
.haz-container {
    display: flex;
    align-items: center;
    background: rgba(214,168,63,.05);
    border: 1px solid rgba(214,168,63,.2);
    border-radius: 6px;
    overflow: hidden;
    min-width: 0;
    height: 28px;
}

/* Etichetta sinistra: icona + badge, niente testo lungo */
.haz-left {
    display: flex; align-items: center; gap: 6px;
    padding: 0 10px; flex-shrink: 0; height: 100%;
}
.haz-ai-icon {
    width: 20px; height: 20px; border-radius: 5px;
    background: rgba(214,168,63,.12);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.haz-label-group { display: flex; flex-direction: column; gap: 0; }
.haz-label-title { font-size: 10px; font-weight: 800; color: var(--internal-gold); white-space: nowrap; }
.haz-label-sub   { display: none; }  /* rimosso: troppo stretto */
.haz-badge {
    font-size: 8px; font-weight: 800; padding: 1px 5px;
    border-radius: 100px; background: rgba(214,168,63,.15);
    color: var(--internal-gold); border: 1px solid rgba(214,168,63,.2);
    white-space: nowrap; flex-shrink: 0;
}

/* Separatore verticale */
.haz-vsep { width: 1px; background: rgba(214,168,63,.15); flex-shrink: 0; align-self: stretch; }

/* Destra: file zone + maps zone su una riga */
.haz-right {
    flex: 1; display: flex; flex-direction: row;
    align-items: center; min-width: 0; height: 100%;
}

/* Zona file drop — sempre visibile, espandersi */
.haz-dropzone {
    flex: 1; display: flex; align-items: center; gap: 6px;
    padding: 0 10px; cursor: pointer; height: 100%;
    border-right: 1px solid rgba(214,168,63,.1);
    transition: background .15s;
}
.haz-dropzone:hover,
.haz-dropzone.haz-drag-over { background: rgba(214,168,63,.07); }
.haz-dropzone.haz-has-file  { background: rgba(74,222,128,.04); }

.haz-drop-hint  { font-size: 11px; color: var(--internal-muted); white-space: nowrap; }
.haz-drop-hint strong { color: var(--internal-gold); font-weight: 700; }
.haz-drop-formats { font-size: 10px; color: #404040; white-space: nowrap; }

/* Stato file — inline nella zona drop */
.haz-meta {
    display: flex; align-items: center; gap: 5px; flex-shrink: 0;
}
.haz-meta-text {
    font-size: 10px; color: #888;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 160px;
}
.haz-clear {
    background: none; border: none; color: #555;
    cursor: pointer; font-size: 11px; padding: 0; line-height: 1; flex-shrink: 0;
}
.haz-clear:hover { color: #f87171; }

/* Footer (analizza / loading) — mai visibile nella nuova UI, auto-analisi */
.haz-footer { display: none !important; }
.haz-analyze-btn { display: none !important; }
.haz-loading { font-size: 10px; color: #888; }

/* Mini-campo "incolla testo libero" — riquadro poco invasivo ma riconoscibile,
   affiancato alla zona di trascinamento file (stessa riga, stessa altezza) */
.haz-textarea {
    display: block; flex-shrink: 0;
    width: 124px; height: 20px; resize: none; overflow: hidden;
    padding: 2px 7px; font-size: 9px; line-height: 1.4;
    background: rgba(0,0,0,.24); border: 1px solid rgba(214,168,63,.18);
    color: #ccc; border-radius: 4px; font-family: inherit; outline: none;
    transition: border-color .15s, background .15s;
}
.haz-textarea:hover   { background: rgba(214,168,63,.05); }
.haz-textarea:focus   { border-color: rgba(214,168,63,.45); background: rgba(0,0,0,.3); }
.haz-textarea::placeholder { color: #6b6558; }

/* Zona Google Maps — width fissa a destra */
.haz-maps-row {
    display: flex; align-items: center; gap: 6px;
    padding: 0 8px 0 9px; flex-shrink: 0; height: 100%;
}
.haz-maps-url {
    width: 190px; padding: 3px 7px;
    background: rgba(0,0,0,.22); border: 1px solid rgba(255,255,255,.07);
    color: #ccc; border-radius: 4px; font-size: 10px;
    font-family: inherit; transition: border-color .15s; outline: none;
}
.haz-maps-url:focus { border-color: rgba(99,179,237,.4); }
.haz-maps-url::placeholder { color: #383838; }
.haz-maps-btn {
    padding: 3px 9px; background: rgba(99,179,237,.1);
    border: 1px solid rgba(99,179,237,.22); color: #63b3ed;
    border-radius: 4px; font-size: 10px; font-weight: 700;
    cursor: pointer; white-space: nowrap; flex-shrink: 0;
    font-family: inherit; transition: all .15s;
}
.haz-maps-btn:hover  { background: rgba(99,179,237,.2); }
.haz-maps-btn:disabled { opacity: .5; cursor: not-allowed; }

/* Sovraimpressione conferma testo incollato — evita che un testo lungo
   scombini la barra AI: si apre una finestra centrale con il testo,
   l'utente verifica e conferma (o annulla) prima dell'analisi */
.haz-paste-overlay {
    position: fixed; inset: 0; z-index: 4000;
    background: rgba(8,7,4,.62);
    display: flex; align-items: flex-start; justify-content: center;
    padding-top: 84px;
}
.haz-paste-overlay[hidden] { display: none; }
.haz-paste-card {
    background: #211f18; border: 1px solid rgba(214,168,63,.28);
    border-radius: 10px; padding: 16px; width: min(560px, 92vw);
    box-shadow: 0 14px 44px rgba(0,0,0,.55);
    display: flex; flex-direction: column; gap: 10px;
}
.haz-paste-title { font-size: 12px; font-weight: 800; color: var(--internal-gold); letter-spacing: .02em; }
.haz-paste-card textarea {
    width: 100%; min-height: 190px; max-height: 52vh; resize: vertical;
    background: rgba(0,0,0,.3); border: 1px solid rgba(255,255,255,.09);
    border-radius: 6px; color: #ddd; padding: 9px; font-size: 12px;
    font-family: inherit; line-height: 1.45; outline: none; box-sizing: border-box;
}
.haz-paste-card textarea:focus { border-color: rgba(214,168,63,.4); }
.haz-paste-actions { display: flex; justify-content: flex-end; gap: 8px; }
.haz-paste-actions button {
    font-size: 11px; font-weight: 700; padding: 6px 14px; border-radius: 6px;
    cursor: pointer; font-family: inherit; transition: all .15s; border: 1px solid;
}
.haz-paste-cancel  { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); color: #aaa; }
.haz-paste-cancel:hover  { background: rgba(255,255,255,.1); }
.haz-paste-confirm { background: rgba(214,168,63,.15); border-color: rgba(214,168,63,.35); color: var(--internal-gold); }
.haz-paste-confirm:hover { background: rgba(214,168,63,.28); }

/* Status sotto la barra (feedback analisi / maps) */
.haz-status-bar {
    font-size: 10px; color: #666; text-align: center;
    min-height: 0.9em; padding: 1px 0;
    transition: color .2s;
}

.btn-import-text {
    font-size: 10px; font-weight: 700; padding: 3px 10px;
    background: rgba(74,222,128,.08); border: 1px solid rgba(74,222,128,.22);
    color: #4ade80; border-radius: 4px; cursor: pointer;
    transition: background .12s; opacity: .82;
}
.btn-import-text:hover { opacity: 1; background: rgba(74,222,128,.18); }

/* ══ PANNELLO SUBVETTORI SUGGERITI ═══════════════════════════════════════════ */

/* Pannello slide-in fisso a destra, collassabile tramite maniglia
   --svs-top viene impostato via JS misurando l'altezza reale della topbar */
.svs-panel {
    position: fixed;
    top: var(--svs-top, 0px); right: 0; bottom: 0;
    width: 360px;
    /* Trasparenza + blur: si vede la mappa sfocata sotto */
    background: rgba(13, 16, 19, 0.60);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-left: 1px solid rgba(214,168,63,.22);
    z-index: 90;
    display: flex;
    flex-direction: row;
    box-shadow: -8px 0 32px rgba(0,0,0,.55);
    animation: svs-in .2s ease;
    transition: width .25s ease;
    overflow: hidden;
}
@keyframes svs-in { from { transform: translateX(360px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.svs-panel[hidden] { display: none; }

/* Collassato: mostra solo la maniglia (36 px) */
.svs-panel.svs-collapsed {
    width: 36px;
    animation: none;
}

/* Maniglia laterale — sempre cliccabile */
.svs-handle {
    width: 36px;
    flex-shrink: 0;
    border: none;
    border-right: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.02);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 16px 0;
    transition: background .15s;
    font-family: inherit;
}
.svs-handle:hover { background: rgba(214,168,63,.07); }

.svs-handle-arrow {
    color: var(--internal-gold);
    font-size: 18px;
    font-weight: 900;
    line-height: 1;
    transition: transform .25s;
}
/* Pannello espanso: freccia › punta a destra = "chiudi/comprimi" */
/* Pannello collassato: freccia ruota 180° = ‹ = "espandi" */
.svs-panel.svs-collapsed .svs-handle-arrow { transform: rotate(180deg); }

.svs-handle-badge {
    background: var(--internal-gold);
    color: #111;
    font-size: 10px;
    font-weight: 900;
    border-radius: 999px;
    padding: 2px 5px;
    min-width: 18px;
    text-align: center;
    line-height: 1.4;
    display: none;
}
.svs-handle-badge:not(:empty) { display: block; }

.svs-handle-label {
    writing-mode: vertical-rl;
    font-size: 9px;
    color: #555;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
}

/* Contenitore del contenuto espandibile */
.svs-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.svs-header {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 14px 14px 10px; border-bottom: 1px solid rgba(255,255,255,.06); flex-shrink: 0;
}
.svs-title { font-size: 13px; font-weight: 800; color: #e5e5e5; flex: 1; }
.svs-sub   { font-size: 10px; color: #555; margin-top: 2px; }
/* .svs-close mantenuto solo per il modal incarichi */
.svs-close {
    background: none; border: none; color: #555;
    font-size: 18px; cursor: pointer; line-height: 1; padding: 0 2px; flex-shrink: 0;
}
.svs-close:hover { color: #fff; }

.svs-filters {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    padding: 8px 14px; border-bottom: 1px solid rgba(255,255,255,.05); flex-shrink: 0;
    font-size: 10px; color: #777;
}
.svs-filter-label { display: flex; align-items: center; gap: 4px; cursor: pointer; }
.svs-filter-label input { accent-color: var(--internal-gold); }
.svs-filter-sep { flex: 1; }
.svs-count { font-size: 10px; color: #555; font-weight: 700; }
.svs-dash-link { font-size: 10px; color: var(--internal-gold); text-decoration: none; font-weight: 700; white-space: nowrap; }
.svs-dash-link:hover { text-decoration: underline; }

.svs-list { flex: 1; overflow-y: auto; padding: 8px 10px; }
.svs-empty { font-size: 11px; color: #444; padding: 20px; text-align: center; }

/* Card subvettore nel pannello */
.svs-card {
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 7px; padding: 10px 11px; margin-bottom: 7px;
    cursor: pointer; transition: border-color .15s;
}
.svs-card:hover { border-color: rgba(214,168,63,.3); }
.svs-card.top3 { border-color: rgba(214,168,63,.22); background: rgba(214,168,63,.03); }

.svs-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.svs-card-name { font-size: 12px; font-weight: 800; color: #e5e5e5; line-height: 1.3; }
.svs-card-prov { font-size: 9px; font-weight: 700; background: rgba(255,255,255,.07);
    color: #888; padding: 2px 5px; border-radius: 3px; white-space: nowrap; flex-shrink: 0; }

/* Score bar */
.svs-score-wrap { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.svs-score-bar-bg { flex: 1; height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; }
.svs-score-bar-fill { height: 4px; border-radius: 2px; transition: width .3s; }
.svs-score-num { font-size: 11px; font-weight: 900; min-width: 28px; text-align: right; }
.svs-score-good  { color: #4ade80; }
.svs-score-mid   { color: #fbbf24; }
.svs-score-low   { color: #f87171; }
.fill-good  { background: #4ade80; }
.fill-mid   { background: #fbbf24; }
.fill-low   { background: #f87171; }

/* Tags mezzo */
.svs-tags { display: flex; flex-wrap: wrap; gap: 3px; margin-bottom: 6px; }
.svs-tag { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 3px; }
.svs-tag-aperti     { background:#0ea5e9; color:#fff; }
.svs-tag-centinati  { background:var(--internal-gold); color:#111; }
.svs-tag-ribassati  { background:#22c55e; color:#000; }
.svs-tag-eccezionali{ background:#ef4444; color:#fff; }
.svs-tag-other      { background:rgba(255,255,255,.07); color:#888; }

/* Badge iscrizione portale */
.svs-reg-badge { font-size: 9px; font-weight: 800; padding: 2px 7px; border-radius: 999px; }
.svs-reg-yes { background: rgba(74,222,128,.1); color: #4ade80; border: 1px solid rgba(74,222,128,.25); }
.svs-reg-no  { background: rgba(251,191,36,.08); color: #fbbf24; border: 1px solid rgba(251,191,36,.2); }

/* Score detail hover */
.svs-reasons { font-size: 9px; color: #555; line-height: 1.5; margin-bottom: 5px; }

/* Info rapide */
.svs-info { font-size: 10px; color: #777; margin-bottom: 4px; }
.svs-tariffa { font-size: 11px; font-weight: 800; color: #fbbf24; margin-bottom: 6px; }
.svs-tariffa span { font-size: 9px; font-weight: 400; color: #555; margin-left: 4px; }

/* Azioni rapide */
.svs-actions { display: flex; flex-wrap: wrap; gap: 4px; }
.svs-btn {
    font-size: 9px; font-weight: 700; padding: 3px 7px; border-radius: 4px;
    cursor: pointer; font-family: inherit; transition: all .15s; border: 1px solid;
}
.svs-btn-copy  { background: rgba(56,189,248,.08); border-color: rgba(56,189,248,.2); color: #7dd3fc; }
.svs-btn-send  { background: rgba(74,222,128,.08); border-color: rgba(74,222,128,.22); color: #4ade80; }
.svs-btn-scheda{ background: rgba(214,168,63,.08); border-color: rgba(214,168,63,.2); color: var(--internal-gold); }
.svs-btn:hover { opacity: .85; }

/* (svs-toggle-btn rimosso: sostituito dalla maniglia laterale svs-handle) */

/* Modal proposta incarico */
.svs-modal-backdrop {
    position: fixed; inset: 0; background: rgba(0,0,0,.72); z-index: 200;
    display: flex; align-items: center; justify-content: center; padding: 20px;
}
.svs-modal-backdrop[hidden] { display: none; }
.svs-modal {
    background: #141618; border: 1px solid rgba(74,222,128,.28);
    border-radius: 10px; max-width: 560px; width: 100%;
    max-height: 88vh; overflow-y: auto;
    padding: 18px 20px; box-shadow: 0 20px 60px rgba(0,0,0,.6);
}
.svs-modal-head { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.svs-modal-title { font-size: 14px; font-weight: 800; color: #4ade80; flex: 1; }
.svs-modal-body { font-size: 12px; color: #aaa; line-height: 1.55; }
.svs-modal-body strong { color: #e5e5e5; }
.svs-modal-msg {
    background: rgba(0,0,0,.25); border: 1px solid rgba(255,255,255,.08);
    border-radius: 6px; padding: 10px 12px; font-size: 11px;
    color: #ccc; white-space: pre-wrap; margin: 10px 0;
    font-family: 'IBM Plex Mono', monospace; line-height: 1.6;
}
.svs-modal-actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.svs-modal-btn {
    padding: 7px 14px; border-radius: 6px; font-size: 11px; font-weight: 800;
    cursor: pointer; font-family: inherit; border: 1.5px solid; transition: all .15s;
}
.svs-modal-btn-green { background: rgba(74,222,128,.1); border-color: rgba(74,222,128,.3); color: #4ade80; }
.svs-modal-btn-sky   { background: rgba(56,189,248,.1); border-color: rgba(56,189,248,.3); color: #7dd3fc; }
.svs-modal-btn-plain { background: transparent; border-color: rgba(255,255,255,.1); color: #666; }
/* ══ FINE PANNELLO SUBVETTORI ════════════════════════════════════════════════ */

/* Badge dati test */
.test-data-badge {
    background: rgba(251,191,36,.12); border: 1px solid rgba(251,191,36,.4);
    color: #fbbf24; font-size: 10px; font-weight: 800;
    padding: 4px 10px; border-radius: 4px; text-align: center;
    letter-spacing: .04em; margin-top: 4px;
}

/* ── Sezioni collassabili nel form ────────────────────────────────────── */
.form-section {
    margin: 4px 0;
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    overflow: hidden;
}
.form-section-toggle {
    width: 100%; display: flex; align-items: center; gap: 6px;
    padding: 1px 8px; cursor: pointer;
    background: var(--internal-bg2); border: none;
    color: var(--internal-muted); font-size: 11px; font-weight: 700;
    text-align: left; transition: background .12s, color .12s;
    font-family: var(--internal-font);
}
.form-section-toggle:hover { background: var(--internal-bg3); color: var(--internal-text); }
.fs-icon { font-size: 14px; }
.fs-arrow { margin-left: auto; font-size: 13px; transition: transform .15s; }
.form-section-body {
    padding: 10px 12px 12px;
    background: var(--internal-bg);
    border-top: 1px solid var(--internal-border);
}

/* ── Blocco targhe specifiche ──────────────────────────────────────────── */
.targhe-block {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
}

/* ── V5.3: Badge targa selezionata via chip flotta ─────────────────────── */
.mezzo-targa-badge[hidden] { display: none; }
.mezzo-targa-badge {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: rgba(214,168,63,.06);
    border: 1px solid rgba(214,168,63,.22);
    border-radius: 6px;
    margin-top: 2px;
}
.mezzo-targa-pill {
    font-size: 11px;
    font-weight: 800;
    color: var(--internal-gold);
    flex: 1;
}
.mezzo-targa-clear {
    background: none;
    border: none;
    color: #555;
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    padding: 0 2px;
    flex-shrink: 0;
    font-family: inherit;
}
.mezzo-targa-clear:hover { color: #fff; }

/* ── Blocco subvettore ─────────────────────────────────────────────────── */
.subvettore-block { grid-column: 1 / -1; display: flex; flex-direction: column; gap: 4px; position: relative; }
.subvettore-input { width: 100%; }

.subvettore-dropdown {
    position: fixed; z-index: 9999; list-style: none; margin: 0; padding: 3px 0;
    background: #1a1a1a; border: 1px solid #333;
    border-radius: 6px; max-height: 260px; overflow-y: auto;
    box-shadow: 0 8px 28px rgba(0,0,0,.75);
}
.subv-drop-item {
    padding: 6px 12px; cursor: pointer; font-size: 12px; color: var(--internal-text);
    display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.subv-drop-item:hover { background: rgba(214,168,63,.1); color: var(--internal-gold); }
.subv-drop-prov { font-size: 10px; color: var(--internal-muted); font-weight: 700; flex-shrink: 0; }

/* Card anagrafica subvettore */
.subvettore-card {
    background: rgba(214,168,63,.06); border: 1px solid rgba(214,168,63,.25);
    border-radius: 7px; padding: 10px 12px; font-size: 12px;
}
.subv-card-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 8px; margin-bottom: 8px; padding-bottom: 6px;
    border-bottom: 1px solid rgba(214,168,63,.18);
}
.subv-name { font-weight: 700; color: var(--internal-text); font-size: 13px; }
.subv-prov  { margin-left: 6px; font-size: 10px; font-weight: 700; color: var(--internal-muted);
              background: var(--internal-bg3); padding: 1px 5px; border-radius: 3px; }
.subv-verified { margin-left: 6px; font-size: 10px; color: #4ade80; font-weight: 700; }
.subv-stars { color: var(--internal-gold); font-size: 12px; flex-shrink: 0; letter-spacing: 1px; }

.subv-body { display: flex; flex-direction: column; gap: 4px; }
.subv-row  { display: flex; gap: 8px; align-items: baseline; flex-wrap: wrap; }
.subv-lbl  { font-size: 10px; color: var(--internal-muted); text-transform: uppercase;
             letter-spacing: .04em; min-width: 52px; flex-shrink: 0; }
.subv-mono { font-family: monospace; font-size: 11px; }
.subv-link { color: var(--internal-gold); text-decoration: none; font-size: 12px; }
.subv-link:hover { text-decoration: underline; }
.subv-email { color: #38bdf8; font-size: 11px; }
.subv-mezzi { display: flex; flex-wrap: wrap; gap: 4px; }
.subv-mb    { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 3px;
              background: rgba(214,168,63,.12); color: var(--internal-gold);
              border: 1px solid rgba(214,168,63,.25); }
.subv-note  { font-size: 11px; color: #fcd34d; background: rgba(245,158,11,.06);
              border: 1px solid rgba(245,158,11,.18); border-radius: 4px;
              padding: 4px 7px; margin-top: 2px; line-height: 1.4; }
.subv-dim   { color: var(--internal-muted); font-size: 11px; }

/* ── Wrapper icona calendario: ::after sul wrapper, non sulla label,
   così non interferisce con il time-range-inline sotto */
.date-input-wrap {
    position: relative;
}
.date-input-wrap::after {
    content: '';
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    pointer-events: none;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23d6a83f' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
}
/* Indicatore nativo grande per coprire il ::after — click passa attraverso il wrapper */
.date-input-wrap input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0;
    cursor: pointer;
    width: 28px;
    height: 100%;
    position: relative;
    z-index: 1;
}

/* Rimuovi il vecchio ::after sulla label per date (ora gestito dal .date-input-wrap) */
.internal-form label:has(input[type="date"])::after {
    display: none;
}

/* Riga orario inline nelle label data ──────────────────────────────────── */
.time-range-inline {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 3px;
    flex-wrap: nowrap;
}
.time-range-inline .tr-label {
    font-size: 10px;
    color: rgba(174,182,189,0.6);
    white-space: nowrap;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}
.time-range-inline select {
    width: auto !important;
    flex: 0 0 auto !important;
    height: 22px !important;
    padding: 0 3px !important;
    font-size: 11px !important;
    border-radius: 4px !important;
    border: 1px solid var(--internal-border) !important;
    background: #0f1215 !important;
    color: var(--internal-text) !important;
    min-width: 60px;
}
.tassativo-inline {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 3px !important;
    border: none !important;
    background: transparent !important;
    padding: 0 0 0 4px !important;
    font-size: 10px !important;
    color: var(--internal-muted) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    cursor: pointer;
}
.tassativo-hint {
    font-size: 9px;
    color: var(--internal-gold);
    font-weight: 700;
    opacity: .7;
}

.stop-cond-date-row { margin-bottom: 8px; }
.stop-cond-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5px;
    margin-bottom: 4px;
}
/* Label inline: testo e select sulla stessa riga, più compatto */
.stop-cond-grid label {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 10px !important;
    white-space: nowrap;
}
.stop-cond-grid label select {
    flex: 1;
    min-width: 0;
    font-size: 11px !important;
    padding: 3px 4px !important;
    height: auto !important;
}
.stop-cond-summary { font-size: 10px; color: var(--internal-muted); display: block; }

.stops-footer { display: flex; align-items: center; gap: 10px; margin-top: 4px; }
.stops-colli-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 5px;
    padding: 2px 0;
}
.stops-colli-bar-sep {
    flex: 1;  /* spinge i due gruppi ai lati opposti */
    border-top: 1px dashed var(--internal-border);
    margin: 0 6px;
    align-self: center;
}
.stops-add-btn {
    font-size: 11px; font-weight: 700; padding: 3px 10px;
    background: rgba(214,168,63,.1); border: 1px solid rgba(214,168,63,.35);
    color: var(--internal-gold); border-radius: 4px; cursor: pointer;
    transition: background .12s;
}
.stops-add-btn:hover:not(:disabled) { background: rgba(214,168,63,.2); }
.stops-add-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.stops-count { font-size: 10px; color: var(--internal-muted); font-weight: 700; }

/* Google Maps URL import row */
.ip-maps-row {
    display: flex; align-items: center; gap: 6px;
    padding: 5px 8px 5px 6px;
    background: rgba(99,179,237,.04); border: 1px solid rgba(99,179,237,.15);
    border-radius: 6px; margin-bottom: 6px;
}
.ip-maps-url-inp {
    flex: 1; min-width: 0; padding: 4px 8px;
    background: rgba(0,0,0,.2); border: 1px solid rgba(255,255,255,.07);
    color: var(--internal-text); border-radius: 4px; font-size: 11px;
    font-family: var(--font-ui, inherit); transition: border-color .15s;
}
.ip-maps-url-inp:focus { outline: none; border-color: rgba(99,179,237,.45); }
.ip-maps-url-inp::placeholder { color: rgba(174,182,189,.35); }
.ip-maps-btn {
    padding: 4px 10px; font-size: 10px; font-weight: 700;
    background: rgba(99,179,237,.12); border: 1px solid rgba(99,179,237,.3);
    color: #63b3ed; border-radius: 4px; cursor: pointer;
    font-family: inherit; transition: all .15s; white-space: nowrap; flex-shrink: 0;
}
.ip-maps-btn:hover { background: rgba(99,179,237,.22); }
.ip-maps-btn:disabled { opacity: .5; cursor: not-allowed; }
.ip-maps-status { font-size: 10px; flex-shrink: 0; max-width: 180px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.stop-marker-num {
    width: 22px; height: 22px; border-radius: 50%; border: 2px solid #fff;
    color: #fff; font-size: 10px; font-weight: 900;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 6px rgba(0,0,0,0.5); cursor: pointer;
}

/* ── ICONA CALENDARIO ─────────────────────────────────────────────────────── */
/* Icona calendario: nascondo quella nativa e la sostituisco con SVG oro via ::after */
.internal-form label:has(input[type="date"]) {
    position: relative;
}

.internal-form label:has(input[type="date"])::after {
    content: '';
    position: absolute;
    right: 8px;
    bottom: 7px;
    width: 14px;
    height: 14px;
    pointer-events: none;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23d6a83f' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
}

.internal-form input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0;   /* nasconde l'icona nativa nera */
    cursor: pointer;
    width: 20px;
    height: 20px;
}

/* Inputs dentro la label-box: niente bordo, sfondo che eredita dal container */
.internal-form input:not([type="checkbox"]),
.internal-form textarea {
    width: 100%;
    box-sizing: border-box;
    border: none;
    border-radius: 0;
    padding: 2px 0;
    height: 26px;
    background: transparent;
    color: var(--internal-text);
    font: inherit;
    font-size: 13px;
    font-weight: 500;
}

/* Select: sfondo esplicito scuro (transparent non funziona sui select nativi) */
.internal-form select {
    width: 100%;
    box-sizing: border-box;
    border: none;
    border-radius: 0;
    padding: 2px 0;
    height: 26px;
    background: #0f1215;
    color: var(--internal-text);
    font: inherit;
    font-size: 13px;
    font-weight: 500;
    -webkit-appearance: auto;
}

/* Login form mantiene lo stile originale */
.internal-login-form input {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    padding: 10px 11px;
    background: #0f1215;
    color: var(--internal-text);
    font: inherit;
}

/* Il bordo "not-verified" sale sulla label container */
.internal-form label:has(input.not-verified) {
    border-color: var(--internal-yellow);
}
.internal-form input.not-verified {
    border: none;
}

/* Cliente non presente in lista — rosso tenue semitrasparente */
.internal-form label.cliente-unknown {
    border-color: rgba(216, 97, 85, 0.45) !important;
    background: rgba(216, 97, 85, 0.04) !important;
}

/* Wrapper per i suggerimenti cliente */
.cliente-suggestions-wrap {
    position: relative;
}

/* Checkbox labels: riga orizzontale */
.internal-form label:has(input[type="checkbox"]) {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    min-height: 34px;
    font-size: 11px;
}

/* Textarea: compatta */
.internal-form label textarea {
    height: 46px !important;
    min-height: 46px !important;
    resize: none !important;
    overflow-y: auto !important;
    padding: 3px 0 !important;
}

/* Multi-select: altezza adeguata */
.internal-form label select[multiple] {
    height: 72px !important;
    padding: 3px 0 !important;
}

.address-field {
    position: relative;
}

.address-suggestions {
    position: absolute;
    z-index: 80;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    max-height: 240px;
    overflow-y: auto;
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    background: #11161a;
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.35);
}

.address-suggestions:empty,
.address-suggestions[hidden] {
    display: none;
}

.address-suggestion {
    display: grid;
    gap: 3px;
    width: 100%;
    border: 0;
    border-bottom: 1px solid var(--internal-border);
    padding: 10px 11px;
    background: transparent;
    color: var(--internal-text);
    text-align: left;
    cursor: pointer;
}

.address-suggestion:hover,
.address-suggestion:focus {
    background: #20262b;
}

.address-suggestion span,
.address-suggestion.muted {
    color: var(--internal-muted);
    font-size: 12px;
}

.internal-form input.not-verified {
    border-color: var(--internal-yellow);
}

.internal-form select[multiple] {
    min-height: 108px;
}

.internal-manual {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 10px 12px;
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    background: #14181c;
}

.internal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.internal-actions.compact {
    margin-bottom: 14px;
}

.internal-empty {
    display: grid;
    min-height: 260px;
    place-items: center;
    color: var(--internal-muted);
    text-align: center;
}

/* Riga superiore: sidebar prezzi a sinistra + mappa quadrata a destra */
/* Layout principale: sidebar sticky | contenuto principale */
.results-layout {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.results-main {
    flex: 1;
    min-width: 0;
}

/* Sidebar prezzi: stessa altezza della mappa, flex verticale */
.result-price-sidebar {
    width: 192px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: sticky;
    top: 20px;
    align-self: flex-start;
    /* altezza gestita dal contenuto, non fissa */
}

/* Card compresse: label a sx (span 2 righe) | prezzo riga 1 + €/km riga 2 */
.result-price-sidebar .internal-price {
    flex: 0 0 auto;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    column-gap: 8px;
    padding: 5px 10px;
    min-height: 0;
}
.result-price-sidebar .internal-price span {
    grid-column: 1;
    grid-row: 1 / 3;
    align-self: center;
    font-size: 10px;
    white-space: nowrap;
}
.result-price-sidebar .internal-price strong {
    grid-column: 2;
    grid-row: 1;
    font-size: 15px;
    text-align: right;
    white-space: nowrap;
    line-height: 1.2;
}
.result-price-sidebar .internal-price.featured strong {
    font-size: 17px;
}
.result-price-sidebar .price-km {
    grid-column: 2;
    grid-row: 2;
    font-size: 9px;
    text-align: right;
    color: var(--internal-muted);
    white-space: nowrap;
    line-height: 1.2;
}

/* ── Checkbox ruotabile nella tabella colli ────────────────────────────── */
.collo-rotatable { width: 14px; height: 14px; cursor: pointer; accent-color: var(--internal-gold); }

/* ── Pannello Verifica Carico V1 ───────────────────────────────────────── */
/* ── V5.2: Debug panel V1 collassato ────────────────────────────────────── */
.pv1-debug-wrap {
    margin-top: 6px; border: 1px solid var(--internal-border);
    border-radius: 4px; font-size: 10px;
}
.pv1-debug-sum {
    padding: 4px 8px; cursor: pointer; font-size: 9px; font-weight: 700;
    color: var(--internal-muted); list-style: none; user-select: none;
}
.pv1-debug-sum::-webkit-details-marker { display: none; }
.pv1-debug-sum::marker { display: none; }
.pv1-debug-sum:hover { color: var(--internal-text); }
.pv1-debug-hint { font-weight: 400; font-style: italic; }
/* Non-compatibili collassati */
.colli-match-nok-wrap { margin-top: 2px; }
.colli-match-nok-sum  { font-size: 10px; color: #f87171; cursor: pointer;
    padding: 2px 4px; list-style: none; user-select: none; }
.colli-match-nok-sum::-webkit-details-marker { display: none; }
.colli-match-nok-sum::marker { display: none; }
.colli-match-nok-sum:hover { opacity: .85; }

.pv1-panel {
    margin-top: 8px;
    border-top: 1px dashed var(--internal-border);
    padding-top: 8px;
}
.pv1-title {
    font-size: 9px; font-weight: 800; text-transform: uppercase;
    letter-spacing: .06em; color: var(--internal-muted); margin-bottom: 6px;
}
.pv1-row { margin-bottom: 6px; border-radius: 5px; overflow: hidden; }
.pv1-header {
    display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
    padding: 5px 8px; font-size: 11px;
}
.pv1-ok   { background: rgba(74,222,128,.08);  border: 1px solid rgba(74,222,128,.2); }
.pv1-warn { background: rgba(251,191,36,.08);  border: 1px solid rgba(251,191,36,.2); }
.pv1-fail { background: rgba(248,113,113,.08); border: 1px solid rgba(248,113,113,.2); }
.pv1-ok   .pv1-icon { color: #4ade80; }
.pv1-warn .pv1-icon { color: #fbbf24; }
.pv1-fail .pv1-icon { color: #f87171; }
.pv1-targa   { font-weight: 800; color: var(--internal-text); }
.pv1-verdict { font-weight: 700; font-size: 10px; }
.pv1-ok   .pv1-verdict { color: #4ade80; }
.pv1-warn .pv1-verdict { color: #fbbf24; }
.pv1-fail .pv1-verdict { color: #f87171; }
.pv1-stats { font-size: 9px; color: var(--internal-muted); margin-left: auto; }
.pv1-reasons {
    list-style: none; margin: 0; padding: 2px 8px 4px;
    background: rgba(0,0,0,.12);
}
.pv1-reason-fail { font-size: 10px; color: #f87171; padding: 1px 0; }
.pv1-reason-warn { font-size: 10px; color: #fbbf24; padding: 1px 0; }
.pv1-reason-data { font-size: 10px; color: #38bdf8; padding: 1px 0; opacity: .85; }
/* ── Pannello V2 packing 2D ─────────────────────────────────────────────── */
.pv2-panel { margin: 4px 0 2px; border-radius: 4px; overflow: hidden; font-size: 10px; }
.pv2-ok   { background: rgba(74,222,128,.06);  border: 1px solid rgba(74,222,128,.2); }
.pv2-fail { background: rgba(248,113,113,.06); border: 1px solid rgba(248,113,113,.2); }
.pv2-info { background: rgba(56,189,248,.05);  border: 1px solid rgba(56,189,248,.15); }
.pv2-header { display: flex; align-items: center; gap: 5px; padding: 4px 8px; }
.pv2-icon  { font-size: 11px; font-weight: 800; }
.pv2-ok   .pv2-icon { color: #4ade80; }
.pv2-fail .pv2-icon { color: #f87171; }
.pv2-info .pv2-icon { color: #38bdf8; }
.pv2-label { font-weight: 700; color: var(--internal-text); flex: 1; }
.pv2-conf  { font-size: 8px; font-weight: 800; padding: 1px 5px; border-radius: 10px; text-transform: uppercase; }
.pv2-conf-alta  { background: rgba(74,222,128,.12);  color: #4ade80; }
.pv2-conf-media { background: rgba(251,191,36,.1);   color: #fbbf24; }
.pv2-conf-bassa { background: rgba(248,113,113,.1);  color: #f87171; }
.pv2-rows { padding: 2px 8px 4px; border-top: 1px solid rgba(255,255,255,.06); }
.pv2-row-line { display: flex; align-items: center; gap: 6px; padding: 1px 0; font-size: 9px; }
.pv2-ri    { color: var(--internal-gold); font-weight: 800; min-width: 18px; }
.pv2-rw,.pv2-rl { color: var(--internal-muted); min-width: 50px; }
.pv2-ritems { display: flex; flex-wrap: wrap; gap: 3px; }
.pv2-item  { background: rgba(255,255,255,.05); padding: 1px 5px; border-radius: 3px; color: var(--internal-text); }
.pv2-item.rotated { border: 1px solid rgba(214,168,63,.3); color: var(--internal-gold); }
.pv2-unplaced { padding: 3px 8px; font-size: 9px; color: #f87171; border-top: 1px solid rgba(255,255,255,.06); }
.pv2-unpl-item { font-style: italic; }
.pv2-warn { padding: 2px 8px; font-size: 9px; color: #fbbf24; }

.pv1-disclaimer {
    font-size: 8px; color: var(--internal-muted);
    font-style: italic; margin-top: 4px; text-align: right;
}

/* ── V4: Preview 3D isometrica SVG ─────────────────────────────────────── */
.pv4-wrap {
    margin: 4px 0 2px;
    border: 1px solid rgba(74,222,128,.2);
    border-radius: 5px; background: rgba(74,222,128,.03);
    font-size: 10px; overflow: hidden;
}
.pv4-summary {
    padding: 4px 8px; cursor: pointer; font-weight: 700;
    color: var(--internal-muted); font-size: 10px;
    list-style: none; user-select: none;
}
.pv4-summary::-webkit-details-marker { display: none; }
.pv4-summary::marker              { display: none; }
.pv4-summary:hover                { color: var(--internal-text); }
.pv4-status { color: #4ade80; font-size: 9px; }
.pv4-body   { padding: 4px 0 6px; border-top: 1px solid rgba(74,222,128,.1); }
.pv4-dims   { font-size: 7px; color: var(--internal-muted); text-align: right; margin-top: 2px; }
.pv4-limited, .pv4-note {
    font-size: 8px; color: var(--internal-muted);
    margin-top: 2px; font-style: italic;
}
.pv4-limited { color: #fbbf24; }
.pv4-na {
    font-size: 9px; color: var(--internal-muted); padding: 4px 8px; font-style: italic;
}

/* ── V5: Viewer 3D interattivo Three.js ────────────────────────────────── */
.pv5-wrap {
    margin: 4px 0 2px;
    border: 1px solid rgba(99,179,237,.22);
    border-radius: 5px; background: rgba(99,179,237,.03);
    font-size: 10px; overflow: hidden;
}
.pv5-summary {
    padding: 4px 8px; cursor: pointer; font-weight: 700;
    color: var(--internal-muted); font-size: 10px;
    list-style: none; user-select: none;
}
.pv5-summary::-webkit-details-marker { display: none; }
.pv5-summary::marker              { display: none; }
.pv5-summary:hover                { color: var(--internal-text); }
.pv5-status { color: #63b3ed; font-size: 9px; font-weight: 400; margin-left: 4px; }
.pv5-canvas-wrap {
    width: 100%; max-width: 100%; box-sizing: border-box;
    overflow: hidden; background: #0a0a0a;
    /* altezza impostata via JS basandosi su clientWidth;
       la sincronizzazione con eventuali variazioni di larghezza (es. comparsa
       della barra di scorrimento del pannello) è gestita via ResizeObserver
       in packing-three-viewer.js, cosi' il canvas non resta mai piu' largo
       dell'area visibile e non viene tagliato. */
}
.pv5-canvas-wrap canvas { display: block; width: 100% !important; max-width: 100%; }
.pv5-controls {
    padding: 3px 8px 4px; border-top: 1px solid rgba(99,179,237,.10);
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.btn-pv5-reset {
    font-size: 9px; padding: 2px 8px;
    background: rgba(99,179,237,.10); border: 1px solid rgba(99,179,237,.25);
    color: #63b3ed; border-radius: 3px; cursor: pointer; transition: background .12s;
}
.btn-pv5-reset:hover { background: rgba(99,179,237,.20); }
.pv5-hint    { font-size: 8px; color: var(--internal-muted); font-style: italic; }
.pv5-limited { font-size: 8px; color: #fbbf24; font-style: italic; }
.pv5-msg     { font-size: 9px; color: var(--internal-muted); padding: 6px 10px; font-style: italic; }
.pv5-na      { color: var(--internal-muted); }

/* ── V3-A: Riga stacking nella tabella colli ────────────────────────────── */
.collo-stack-cell {
    padding: 1px 6px 2px !important;
    width: 100%;
    background: rgba(214,168,63,.03);
    border-top: 1px dashed rgba(214,168,63,.15);
}
.collo-stack-inner {
    display: flex; flex-wrap: nowrap; flex-direction: row; align-items: center; gap: 8px;
    width: 100%;
    line-height: 1;
    overflow-x: auto;
}
.stack-cb {
    display: inline-flex !important; align-items: center !important; gap: 3px !important;
    font-size: 9px !important; line-height: 1 !important; color: var(--internal-muted) !important;
    cursor: pointer; white-space: nowrap;
    flex: 0 0 auto;
    flex-direction: row !important;
}
.stack-cb input[type=checkbox] { width: 10px; height: 10px; margin: 0; accent-color: var(--internal-gold); flex-shrink: 0; }
.stack-input-lbl {
    display: inline-flex !important; align-items: center !important; gap: 4px !important;
    font-size: 9px !important; line-height: 1 !important; color: var(--internal-muted) !important;
    font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: 0.04em !important;
    white-space: nowrap; flex: 0 0 auto;
    flex-direction: row !important;
}
.stack-lbl-text { order: 1; font-weight: inherit; text-transform: inherit; letter-spacing: inherit; }
.stack-input-lbl input {
    order: 2; width: 32px; font-size: 9px !important; line-height: 1;
    padding: 0 2px 1px; margin: 0; text-align: left;
    background: transparent; border: none; border-bottom: 1px solid rgba(214,168,63,.3);
    color: var(--internal-text); height: auto;
}
.stack-input-lbl input:focus { border-bottom-color: var(--internal-gold); outline: none; }
.stack-warn-hint {
    display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
    align-items: center; overflow: hidden;
    font-size: 6.5px; line-height: 1.15; color: #e0a83f;
    background: rgba(224,168,63,.10); border: 1px solid rgba(224,168,63,.3);
    border-radius: 4px; padding: 2px 5px;
    white-space: normal; word-break: break-word;
    flex: 1 1 0; min-width: 0; max-width: 100%;
}
.stack-warn-hint[hidden] { display: none; }

/* ── V3-A: Pannello risultato stacking 3D ───────────────────────────────── */
.pv3a-section {
    margin: 4px 0 2px;
    border: 1px solid rgba(251,191,36,.2);
    border-radius: 5px; background: rgba(251,191,36,.03);
    font-size: 10px; overflow: hidden;
}
.pv3a-na { border-color: rgba(136,136,136,.15); background: transparent; padding: 4px 8px; }
.pv3a-na-msg { color: var(--internal-muted); font-style: italic; font-size: 9px; }
.pv3a-header {
    display: flex; align-items: center; gap: 6px;
    padding: 4px 8px; border-bottom: 1px solid rgba(251,191,36,.1);
}
.pv3a-title { font-weight: 800; color: #fbbf24; flex: 1; }
.pv3a-reason { padding: 2px 8px; font-size: 9px; color: var(--internal-muted); }
.pv3a-stacks-label { padding: 2px 8px; font-size: 9px; color: #fbbf24; font-weight: 700; }
.pv3a-stack {
    display: flex; align-items: center; gap: 5px;
    padding: 2px 8px; border-top: 1px solid rgba(255,255,255,.04);
    font-size: 9px;
}
.pv3a-base  { font-weight: 700; color: var(--internal-text); }
.pv3a-arr   { color: var(--internal-muted); }
.pv3a-above { color: #fbbf24; }
.pv3a-ht    { color: var(--internal-muted); margin-left: auto; }
.pv3a-note  { padding: 2px 8px 4px; font-size: 8px; color: var(--internal-muted); font-style: italic; border-top: 1px solid rgba(255,255,255,.04); }

/* ── V3-C: Pannello verifica a zone / culla ────────────────────────────── */
.pv3-seg-section {
    margin: 6px 0 2px;
    border: 1px solid rgba(163,230,53,.25);
    border-radius: 6px;
    background: rgba(163,230,53,.03);
    font-size: 10px;
    overflow: hidden;
}
.pv3-seg-header {
    display: flex; align-items: center; gap: 6px;
    padding: 5px 10px; border-bottom: 1px solid rgba(163,230,53,.12);
}
.pv3-seg-icon  { font-size: 12px; font-weight: 800; }
.pv3-seg-title { font-weight: 800; color: #a3e635; flex: 1; }
.pv3-seg-label { font-size: 9px; color: var(--internal-muted); }
.pv3-seg-reason { padding: 3px 10px; font-size: 9px; color: var(--internal-muted); }
.pv3-zone {
    display: grid; grid-template-columns: auto 1fr auto;
    align-items: center; gap: 4px;
    padding: 3px 10px; border-top: 1px solid rgba(255,255,255,.04);
}
.pv3-zone-label  { font-weight: 700; color: var(--internal-text); font-size: 9px; }
.pv3-zone-dims   { font-size: 8px; color: var(--internal-muted); }
/* Badge posizione zona culla: ANT. / CEN. / POST. */
.pv3-zone-pos { display:inline-block; font-size:7px; font-weight:800; padding:1px 4px;
                border-radius:2px; margin-left:4px; vertical-align:middle; letter-spacing:.03em; }
.pv3-pos-anteriore  { background:rgba(74,222,128,.15); color:#4ade80; border:1px solid rgba(74,222,128,.3); }
.pv3-pos-centrale   { background:rgba(214,168,63,.12); color:#d6a83f; border:1px solid rgba(214,168,63,.3); }
.pv3-pos-posteriore { background:rgba(99,179,237,.12); color:#63b3ed; border:1px solid rgba(99,179,237,.3); }
.pv3-zone-stats  { font-size: 9px; color: var(--internal-muted); text-align: right; }
.pv3-zone-items  { grid-column: 1 / -1; font-size: 8px; color: var(--internal-muted);
                   padding: 1px 0 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── V3-B: Pannello suggerimento multi-mezzo ───────────────────────────── */
.pv3-multi-section {
    margin: 6px 0 2px;
    border: 1px solid rgba(56,189,248,.25);
    border-radius: 6px;
    background: rgba(56,189,248,.04);
    font-size: 10px;
    overflow: hidden;
}
.pv3-na { border-color: rgba(136,136,136,.2); background: transparent; padding: 5px 8px; }
.pv3-na-msg { color: var(--internal-muted); font-style: italic; }
.pv3-multi-header {
    display: flex; align-items: center; gap: 6px;
    padding: 5px 10px; border-bottom: 1px solid rgba(56,189,248,.12);
}
.pv3-multi-icon  { font-size: 12px; font-weight: 800; }
.pv3-multi-title { font-weight: 800; color: #38bdf8; flex: 1; }
.pv3-veh-badge   { font-size: 9px; font-weight: 800; padding: 1px 6px; border-radius: 10px;
                   background: rgba(56,189,248,.12); color: #38bdf8; }
.pv3-conf        { font-size: 8px; font-weight: 800; padding: 1px 5px; border-radius: 10px;
                   text-transform: uppercase; }
.pv3-conf-alta   { background: rgba(74,222,128,.12);  color: #4ade80; }
.pv3-conf-media  { background: rgba(251,191,36,.1);   color: #fbbf24; }
.pv3-conf-bassa  { background: rgba(248,113,113,.1);  color: #f87171; }
.pv3-reason      { padding: 3px 10px; font-size: 9px; color: var(--internal-muted); }
.pv3-assignment  { padding: 3px 10px 4px; border-top: 1px solid rgba(255,255,255,.04); }
.pv3-asgn-head   { display: flex; align-items: center; gap: 6px; }
.pv3-asgn-num    { font-size: 9px; font-weight: 800; color: #38bdf8;
                   background: rgba(56,189,248,.1); padding: 1px 5px; border-radius: 3px; }
.pv3-asgn-label  { font-weight: 700; color: var(--internal-text); }
.pv3-asgn-tipo   { font-size: 9px; color: var(--internal-muted); }
.pv3-asgn-stats  { font-size: 9px; color: var(--internal-muted); margin-left: auto; }
.pv3-p2ok   { color: #4ade80; font-weight: 700; }
.pv3-p2warn { color: #fbbf24; font-weight: 700; }
.pv3-asgn-items  { font-size: 9px; color: var(--internal-muted); padding: 1px 0 2px 20px;
                   white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pv3-asgn-warn   { font-size: 9px; color: #fbbf24; padding: 1px 0 2px 20px; }
.pv3-unassigned  { padding: 4px 10px; font-size: 9px; color: #f87171;
                   border-top: 1px solid rgba(248,113,113,.15);
                   background: rgba(248,113,113,.04); }
.pv3-unassigned-item { font-style: italic; }
.pv3-multi-warn  { padding: 3px 10px; font-size: 9px; color: #fbbf24; }
.pv3-disclaimer  { padding: 3px 10px 5px; font-size: 8px; color: var(--internal-muted);
                   font-style: italic; border-top: 1px solid rgba(255,255,255,.05); }

/* ── Preview 2D SVG del pianale ────────────────────────────────────────── */
.pv2-preview-wrap {
    margin: 6px 0 2px;
    border: 1px solid rgba(214,168,63,.2);
    border-radius: 5px;
    overflow: hidden;
    background: rgba(214,168,63,.03);
}
.pv2-preview-summary {
    padding: 5px 10px;
    cursor: pointer;
    font-size: 10px;
    font-weight: 700;
    color: var(--internal-muted);
    user-select: none;
    list-style: none;
}
.pv2-preview-summary::-webkit-details-marker { display: none; }
.pv2-preview-summary::marker { display: none; }
.pv2-preview-summary:hover { color: var(--internal-text); }
.pv2-preview-body {
    padding: 6px 10px 8px;
    border-top: 1px solid rgba(214,168,63,.15);
}
.pv2-dims-label {
    font-size: 8px;
    color: var(--internal-muted);
    margin-top: 3px;
    text-align: center;
}
.pv2-unplaced-list {
    font-size: 9px;
    color: #fbbf24;
    margin-top: 4px;
    padding: 3px 6px;
    background: rgba(251,191,36,.06);
    border-radius: 3px;
}
.pv2-unpl { font-style: normal; }
.pv2-unpl em { opacity: .7; }
.pv2-preview-na {
    font-size: 9px;
    color: var(--internal-muted);
    padding: 4px 8px;
    font-style: italic;
}

/* ── Widget Confidence ─────────────────────────────────────────────────── */
.conf-widget { margin: 4px 0 2px; }

/* Pill colorata */
.conf-pill {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px; border-radius: 20px; font-size: 12px; font-weight: 700;
    border: 1px solid; margin-bottom: 6px; width: 100%; box-sizing: border-box;
}
.conf-alta    { background: rgba(74,222,128,.1);  color: #4ade80; border-color: rgba(74,222,128,.3); }
.conf-media   { background: rgba(251,191,36,.1);  color: #fbbf24; border-color: rgba(251,191,36,.28); }
.conf-bassa   { background: rgba(248,113,113,.1); color: #f87171; border-color: rgba(248,113,113,.28); }
.conf-manuale { background: rgba(136,136,136,.1); color: #888;    border-color: rgba(136,136,136,.25); }
.conf-dot     { font-size: 10px; }
.conf-label-lvl { flex: 1; }
.conf-score-num { font-size: 10px; font-weight: 600; opacity: .75; }

/* Barra con zone colorate */
.conf-track {
    position: relative; height: 6px; border-radius: 3px;
    overflow: visible; display: flex; margin-bottom: 2px;
}
.conf-zone { height: 100%; }
.conf-z-bassa { background: rgba(248,113,113,.35); border-radius: 3px 0 0 3px; }
.conf-z-media { background: rgba(251,191,36,.35); }
.conf-z-alta  { background: rgba(74,222,128,.35); border-radius: 0 3px 3px 0; }
.conf-needle  {
    position: absolute; top: -2px; width: 2px; height: 10px;
    background: #fff; border-radius: 1px; transform: translateX(-50%);
    box-shadow: 0 0 3px rgba(0,0,0,.5);
}

/* Tick numbers */
.conf-ticks {
    position: relative; height: 12px; font-size: 8px;
    color: var(--internal-muted); margin-bottom: 2px;
}
.conf-ticks span {
    position: absolute; transform: translateX(-50%);
}

/* Prezzo manuale nel sidebar */
.sidebar-manual-wrap {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 6px 10px;
    border: 1px dashed rgba(214,168,63,.35);
    border-radius: 6px;
    background: rgba(214,168,63,.04);
}
.sidebar-manual-label {
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--internal-muted);
    font-weight: 700;
}
.sidebar-manual-input {
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(214,168,63,.4);
    color: var(--internal-gold);
    font-size: 16px;
    font-weight: 800;
    width: 100%;
    padding: 2px 0;
    outline: none;
    font-family: var(--internal-font);
}
.sidebar-manual-input::placeholder { color: rgba(214,168,63,.3); font-size: 13px; font-weight: 400; }
.sidebar-manual-input:focus { border-bottom-color: var(--internal-gold); }

/* Sezione badge sotto le card */
.sidebar-badges-section {
    flex: 1;
    border-top: 1px solid var(--internal-border);
    padding-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    overflow-y: auto;
}

.sidebar-badges-section .internal-badge {
    align-self: flex-start;
    font-size: 11px;
    padding: 5px 8px;
}

.sidebar-badge-row {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sidebar-badge-row .sb-label {
    font-size: 10px;
    font-weight: 700;
    color: var(--internal-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sidebar-badge-row .sb-value {
    font-size: 12px;
    font-weight: 700;
    color: var(--internal-text);
}

.internal-map-card {
    position: relative;
    width: 650px;
    height: 650px;
    overflow: hidden;
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    background: #101418;
    flex-shrink: 0;
    margin-left: auto;
    margin-bottom: 18px;
}

.internal-route-map {
    /* position absolute + inset: 0 è il pattern corretto per Leaflet
       in un container responsive. Evita che Leaflet legga dimensioni
       sbagliate prima che il layout CSS grid sia stabilizzato. */
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 160ms ease;
}

.internal-route-map.ready {
    opacity: 1;
}

/* ── Selettore stile mappa — icone sempre visibili, etichette su hover 2s ── */
#map-style-switcher {
    position: absolute;
    bottom: 30px;
    left: 10px;
    z-index: 10;
}
.mss-panel {
    background: rgba(10,10,10,.88);
    border: 1px solid #2a2a2a;
    border-radius: 8px;
    padding: 4px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    backdrop-filter: blur(8px);
    box-shadow: 0 4px 20px rgba(0,0,0,.55);
    /* collassato: larghezza esatta dell'icona + padding */
    width: 34px;
    overflow: hidden;
    transition: width .25s ease;
}
.mss-panel.expanded { width: 140px; }

.mss-btn {
    display: flex;
    align-items: center;
    padding: 6px 4px;
    background: none;
    border: 1px solid transparent;
    border-radius: 5px;
    color: #888;
    cursor: pointer;
    white-space: nowrap;
    width: 100%;
    transition: background .12s, color .12s, border-color .12s;
}
.mss-btn:hover  { background: rgba(255,255,255,.06); color: #e5e5e5; }
.mss-btn.active { border-color: #d6a83f; color: #d6a83f; background: rgba(214,168,63,.09); }

.mss-icon {
    font-size: 16px;
    line-height: 1;
    flex-shrink: 0;
    width: 22px;
    text-align: center;
}
/* Etichetta: nascosta di default, scorre in entrata/uscita */
.mss-label {
    font-family: Inter, sans-serif;
    font-size: 11px;
    font-weight: 700;
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    margin-left: 0;
    transition: max-width .22s ease, opacity .18s ease, margin-left .22s ease;
    white-space: nowrap;
}
.mss-panel.expanded .mss-label {
    max-width: 100px;
    opacity: 1;
    margin-left: 6px;
}

/* Popup Mapbox: forza testo scuro su sfondo bianco (il tema scuro ereditava color:#fff) */
.mapboxgl-popup-content {
    color: #111 !important;
    font-size: 12px;
    font-family: Inter, sans-serif;
    padding: 8px 12px;
    border-radius: 6px;
    box-shadow: 0 2px 12px rgba(0,0,0,.35);
}

.internal-map-placeholder {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 20px;
    color: var(--internal-muted);
    text-align: center;
    background: linear-gradient(135deg, #11161a, #171c21);
}

.internal-map-placeholder[hidden] {
    display: none !important;
}

.internal-map-fallback {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 80px minmax(0, 1fr);
    align-items: center;
    gap: 14px;
    height: 100%;
    padding: 24px;
    background: #11161a;
}

.internal-map-fallback > div:not(.internal-map-fallback-line) {
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    padding: 12px;
    background: #181c20;
}

.internal-map-fallback strong,
.internal-map-fallback span {
    display: block;
    overflow-wrap: anywhere;
}

.internal-map-fallback span {
    margin-top: 4px;
    color: var(--internal-muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.internal-map-fallback-line {
    height: 2px;
    border-top: 2px dashed var(--internal-gold);
}

.internal-map-meta {
    position: absolute;
    left: 10px;
    top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    pointer-events: none;
    z-index: 2;
}

.internal-map-meta span {
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    padding: 5px 8px;
    background: rgba(16, 18, 20, 0.84);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
}

.internal-guide {
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    padding: 18px;
    background: var(--internal-panel-soft);
}

.internal-guide h2 {
    margin: 0 0 8px;
    font-size: 22px;
}

.internal-guide p,
.internal-guide li,
.internal-muted {
    color: var(--internal-muted);
}

.internal-preview-card {
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    padding: 18px;
    background: #151a1f;
}

.internal-preview-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 16px;
}

.internal-preview-head h2 {
    margin: 4px 0 0;
    font-size: 24px;
}

.internal-badge.preview {
    color: #ffe2a1;
    background: #27200f;
}

.internal-preview-range {
    border: 1px solid rgba(214, 168, 63, 0.42);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 14px;
    background: #211c12;
}

.internal-preview-range span {
    display: block;
    color: var(--internal-muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.internal-preview-range strong {
    display: block;
    margin-top: 6px;
    color: var(--internal-gold);
    font-size: 30px;
}

.preview-prices .internal-price {
    min-height: 78px;
    opacity: 0.9;
}

.preview-prices .internal-price strong {
    font-size: 20px;
}

.preview-prices .internal-price.featured strong {
    font-size: 24px;
}

.internal-report-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.internal-report h2 {
    margin: 3px 0;
    font-size: 25px;
    letter-spacing: 0;
}

.internal-report h3 {
    margin: 24px 0 10px;
    font-size: 17px;
}

.internal-badge,
.internal-price,
.internal-summary-grid > div {
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    background: var(--internal-panel-soft);
}

.internal-badge {
    align-self: start;
    padding: 8px 10px;
    color: var(--internal-gold);
    font-weight: 800;
}

.internal-summary-grid,
.internal-price-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 7px;    /* compattato da 10px */
}

.internal-summary-grid > div,
.internal-price {
    padding: 8px 10px;   /* compattato da 12px */
}

.internal-summary-grid span,
.internal-price span {
    display: block;
    color: var(--internal-muted);
    font-size: 11px;
    font-weight: 700;
}

.internal-summary-grid strong,
.internal-price strong {
    display: block;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

/* Auto-scaling: max 2 righe, JS riduce il font se sfora */
.metric-value {
    line-height: 1.35;
    max-height: calc(1.35em * 2);   /* esattamente 2 righe */
    overflow: hidden;
    word-break: break-word;
}

/* Badge velocità media — diagnostica routing camion vs auto */
.speed-badge {
    display: inline-block;
    font-size: 9px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 3px;
    vertical-align: middle;
    line-height: 1.6;
    letter-spacing: .02em;
    white-space: nowrap;
}
.speed-ok   { background: rgba(74,222,128,.15); color: #4ade80; border: 1px solid rgba(74,222,128,.35); }
.speed-warn { background: rgba(251,191,36,.13); color: #fbbf24; border: 1px solid rgba(251,191,36,.35); }
.speed-bad  { background: rgba(248,113,113,.13); color: #f87171; border: 1px solid rgba(248,113,113,.35); }

.internal-price-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 16px 0;
}

.internal-price-grid.featured {
    align-items: stretch;
}

.internal-price {
    min-height: 94px;
}

.internal-price strong {
    font-size: 24px;
}

.internal-price.featured {
    border-color: var(--internal-gold);
    background: #262115;
}

.internal-price.featured strong {
    font-size: 32px;
    color: var(--internal-gold);
}

.internal-price .price-km {
    display: block;
    margin-top: 5px;
    font-size: 11px;
    font-weight: 700;
    color: var(--internal-muted);
    text-align: right;
    letter-spacing: 0.02em;
}

.internal-price.featured .price-km {
    color: rgba(214, 168, 63, 0.65);
}

.internal-risk-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 9px;
    margin: 8px 0 18px;
}

.internal-risk-row span:not(.internal-badge) {
    border: 1px solid var(--internal-border);
    border-radius: 999px;
    padding: 7px 10px;
    color: var(--internal-muted);
    background: #12161a;
    font-size: 13px;
    font-weight: 700;
}

.internal-price.danger strong { color: var(--internal-red); }
.internal-price.ok strong { color: var(--internal-green); }
.internal-price.info strong { color: var(--internal-blue); }

.internal-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--internal-border);
    border-radius: 8px;
}

.internal-table-wrap table {
    width: 100%;
    border-collapse: collapse;
    min-width: 0;       /* nessun overflow orizzontale */
    table-layout: auto;
}

.internal-table-wrap th,
.internal-table-wrap td {
    padding: 10px;
    border-bottom: 1px solid var(--internal-border);
    text-align: left;
    vertical-align: top;
}

.internal-table-wrap th {
    background: #11161a;
    color: var(--internal-gold);
}

.internal-table-wrap .breakdown-category td {
    background: #20262b;
    color: var(--internal-gold);
    font-weight: 800;
    text-transform: uppercase;
    font-size: 12px;
    cursor: pointer;
    user-select: none;
    position: relative;        /* per il subtotale assoluto */
}

.internal-table-wrap .breakdown-category td:hover {
    background: #262e35;
}

/* Quando la categoria è aperta, importo e subtotale già visibili nelle righe dati */
.breakdown-category.open td.money {
    opacity: 0.3;
}

.cat-toggle {
    display: inline-block;
    width: 14px;
    font-size: 10px;
    transition: transform 120ms;
}

/* Fonte e Note nascoste di default */
.col-details { display: none; }
.show-details .col-details { display: table-cell; }

/* Pulsante toggle dettagli tecnici */
.breakdown-details-btn {
    float: right;
    margin-bottom: 6px;
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    padding: 4px 10px;
    background: var(--internal-panel-soft);
    color: var(--internal-muted);
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
}
.breakdown-details-btn:hover { border-color: var(--internal-gold); color: var(--internal-gold); }

/* h3 collassabili */
.section-toggle {
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
    gap: 6px;
}
.section-toggle::before {
    content: '▾';
    font-size: 11px;
    color: var(--internal-gold);
    transition: transform 120ms;
}
.section-toggle.collapsed::before { transform: rotate(-90deg); }
.section-content.collapsed { display: none; }

/* Tabella 3 colonne: Voce (auto), Importo (90px), Subtotale (90px) */
.internal-table-wrap th:nth-child(1),
.internal-table-wrap td:nth-child(1) { width: auto; }
.internal-table-wrap th:nth-child(2),
.internal-table-wrap td:nth-child(2) { width: 90px; white-space: nowrap; }
.internal-table-wrap th:nth-child(3),
.internal-table-wrap td:nth-child(3) { width: 90px; white-space: nowrap; }

/* Cella Voce a due livelli */
.voce-cell { vertical-align: top; padding: 8px 10px !important; }
.voce-label { font-size: 13px; font-weight: 600; line-height: 1.3; }
.voce-detail { font-size: 10px; color: var(--internal-muted); margin-top: 3px; line-height: 1.4; }
.voce-note   { font-size: 9px;  color: rgba(174,182,189,0.55); margin-top: 2px; line-height: 1.3; }

.money {
    white-space: nowrap;
    text-align: right;
}

/* Colonna subtotale progressivo nella scomposizione analitica */
.internal-table-wrap th.subtotale-col,
.internal-table-wrap td.subtotale-col {
    border-left: 2px solid rgba(214, 168, 63, 0.25);
    background: rgba(214, 168, 63, 0.06);
    white-space: nowrap;
    text-align: right;
}

.internal-table-wrap th.subtotale-col {
    color: var(--internal-gold);
    font-weight: 800;
}

.internal-table-wrap td.subtotale-col {
    color: var(--internal-gold);
    font-weight: 700;
}

.internal-alert {
    margin: 12px 0;
    border-radius: 8px;
    padding: 12px;
    border: 1px solid var(--internal-border);
}

.internal-alert-danger { border-color: var(--internal-red); color: #ffd7d3; }
.internal-alert-warning { border-color: var(--internal-yellow); color: #fff0b8; }
.internal-alert-ok { border-color: var(--internal-green); color: #d7ffe4; }

.internal-warning-list {
    color: var(--internal-muted);
    padding-left: 20px;
}

.internal-login {
    display: grid;
    place-items: center;
    padding: 24px;
}

.internal-login-panel {
    width: min(440px, 100%);
    padding: 26px;
}

.internal-login-logo {
    display: block;
    max-width: 180px;
    margin-bottom: 20px;
}

.internal-login-form {
    display: grid;
    gap: 14px;
    margin-top: 20px;
}

.internal-history-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    padding: 12px;
    border: 1px solid var(--internal-border);
    border-radius: 8px;
    background: #14181c;
}

.internal-history-filters input[type="search"],
.internal-history-filters input[type="date"],
.internal-history-filters select {
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    padding: 8px 10px;
    background: #0f1215;
    color: var(--internal-text);
    font: inherit;
    font-size: 13px;
}

.internal-history-filters input[type="search"] {
    flex: 1 1 180px;
    min-width: 140px;
}

.internal-history-filters input[type="date"] {
    flex: 0 0 auto;
}

.internal-history-filters select {
    flex: 0 1 160px;
}

.internal-history-filters button {
    border: 1px solid var(--internal-border);
    border-radius: 6px;
    padding: 8px 12px;
    background: var(--internal-panel-soft);
    color: var(--internal-text);
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    white-space: nowrap;
}

.internal-history-filters button:hover {
    border-color: var(--internal-gold);
}

.internal-history-filters .internal-muted {
    font-size: 12px;
    white-space: nowrap;
}

.history-row {
    cursor: pointer;
    transition: background 120ms ease;
}

.history-row:hover td {
    background: #20262b;
}

@media (max-width: 1100px) {
    .internal-shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .internal-topbar,
    .internal-report-head {
        flex-direction: column;
    }
    .internal-grid.two,
    .internal-manual,
    .internal-summary-grid,
    .internal-price-grid {
        grid-template-columns: 1fr;
    }
    .internal-tabs {
        overflow-x: auto;
    }
}

/* ── Tabella colli ─────────────────────────────────────────────────────── */
.colli-section { grid-column: 1 / -1; margin: 2px 0 6px; }
.colli-section-head {
    display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.colli-section-title {
    font-size: 11px; font-weight: 700; color: var(--internal-muted);
    text-transform: uppercase; letter-spacing: .06em;
}
.btn-collo-add {
    font-size: 11px; font-weight: 700; padding: 3px 10px;
    background: rgba(214,168,63,.1); border: 1px solid rgba(214,168,63,.35);
    color: var(--internal-gold); border-radius: 4px; cursor: pointer;
    transition: background .12s;
}
.btn-collo-add:hover { background: rgba(214,168,63,.2); }
.btn-collo-clear {
    font-size: 11px; padding: 3px 8px; margin-left: auto;
    background: none; border: 1px solid rgba(248,113,113,.3);
    color: #f87171; border-radius: 4px; cursor: pointer;
}
.colli-auto-note { font-size: 10px; color: var(--internal-gold); font-weight: 400; }

.colli-table-wrap {
    background: var(--internal-bg2); border: 1px solid var(--internal-border);
    border-radius: 6px; overflow: hidden; margin-bottom: 8px;
}
.colli-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.colli-table th {
    background: var(--internal-bg3); color: var(--internal-muted);
    font-size: 10px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .04em; padding: 5px 6px; text-align: left;
    border-bottom: 1px solid var(--internal-border);
}
.collo-row td {
    padding: 3px 4px; border-bottom: 1px solid rgba(255,255,255,.04);
    vertical-align: middle;
}
/* Colonna N°/quantità: larghezza fissata (ancorata) per non farla mai
   schiacciare quando il browser ridistribuisce lo spazio tra le colonne. */
.colli-th-n { width: 48px; min-width: 48px; max-width: 48px; }
.collo-n {
    font-size: 11px; color: var(--internal-muted); text-align: center;
    width: 48px; min-width: 48px; max-width: 48px; box-sizing: border-box;
}
/* Pezzi identici: campo numerico libero nella colonna N°, ben leggibile */
.collo-qty {
    width: 100%; max-width: 38px; box-sizing: border-box;
    text-align: center; font-size: 13px; font-weight: 700;
    color: var(--internal-text);
}
.collo-input {
    width: 100%; background: transparent; border: none; border-bottom: 1px solid transparent;
    color: var(--internal-text); font-family: var(--internal-font); font-size: 12px;
    padding: 2px 3px; outline: none; transition: border-color .12s;
}
.collo-input:focus { border-bottom-color: var(--internal-gold); }
.collo-desc { min-width: 120px; }
.collo-dim  { width: 60px; text-align: right; }
.collo-del-btn {
    background: none; border: none; color: #f87171; cursor: pointer;
    font-size: 12px; padding: 2px 4px; opacity: .5; transition: opacity .1s;
}
.collo-del-btn:hover { opacity: 1; }
.colli-total-row td {
    background: var(--internal-bg3); padding: 4px 6px;
    border-top: 1px solid var(--internal-border); font-size: 11px;
}
.colli-tot-label { font-weight: 700; color: var(--internal-text); }
.colli-tot-val   { color: var(--internal-gold); font-weight: 700; text-align: right; white-space: nowrap; }
.colli-tot-sub   { font-size: 9px; color: var(--internal-muted); font-weight: 400; }

/* Matching flotta */
.colli-match-panel { padding: 8px 10px; }
.colli-match-title {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    font-size: 10px; font-weight: 800; color: var(--internal-muted);
    text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px;
}
.cmt-text { flex: 1; }
.colli-match-empty-hint { font-style: italic; opacity: .8; text-transform: none; letter-spacing: normal; }

/* Select mezzo previsto inline nel titolo compatibilità flotta */
.mezzo-inline-wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    flex-shrink: 0;
}
.mezzo-inline-label {
    font-size: 8px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(214,168,63,.6);
    white-space: nowrap;
}
.mezzo-inline-select {
    font-size: 11px; font-weight: 700;
    background: #1a1d20;
    border: 1px solid rgba(214,168,63,.3);
    color: var(--internal-gold);
    border-radius: 5px;
    padding: 3px 6px;
    cursor: pointer;
    font-family: inherit;
    width: auto;
    max-width: 148px;
    text-transform: none;
    letter-spacing: 0;
}
.mezzo-inline-select:focus { outline: 1px solid var(--internal-gold); }
/* Fix bianco-su-bianco: colora le opzioni native del dropdown */
.mezzo-inline-select option {
    background: #1a1d20;
    color: #e5e5e5;
}
/* Highlight quando tipo generico attivo (non Da definire, non targa chip) */
.mezzo-inline-select.mz-generic-active {
    border-color: rgba(214,168,63,.65);
    background: rgba(214,168,63,.07);
}

/* ── Step 1 modal tariffa subvettore ────────────────────────────────────── */
.svs-tariffa-stage1 { padding: 2px 0 4px; }
.svs-tariffa-stage1-hint { font-size: 11px; color: #666; margin-bottom: 14px; line-height: 1.5; }
.svs-tariffa-edit-row { display: flex; flex-direction: column; gap: 5px; margin-bottom: 10px; }
.svs-tariffa-edit-label {
    font-size: 9px; font-weight: 800; color: var(--internal-gold);
    text-transform: uppercase; letter-spacing: .08em;
}
.svs-tariffa-input {
    background: #1a1d20;
    border: 1px solid rgba(214,168,63,.35);
    color: #e5e5e5;
    border-radius: 6px;
    padding: 9px 12px;
    font-size: 20px; font-weight: 900;
    width: 160px;
    font-family: inherit;
    transition: border-color .15s;
}
.svs-tariffa-input:focus { outline: none; border-color: var(--internal-gold); }
.svs-tariffa-input.svs-tariffa-inp-error { border-color: #f87171 !important; }
.svs-tariffa-floor-hint { font-size: 10px; color: #555; font-style: italic; }
.svs-tariffa-error {
    font-size: 11px; color: #f87171;
    padding: 6px 9px; margin-bottom: 10px;
    background: rgba(248,113,113,.07);
    border: 1px solid rgba(248,113,113,.2);
    border-radius: 5px;
}
.svs-tariffa-warn {
    font-size: 11px; color: #fbbf24;
    padding: 6px 9px; margin-bottom: 10px;
    background: rgba(251,191,36,.05);
    border: 1px solid rgba(251,191,36,.18);
    border-radius: 5px;
}
/* V5.4 — feedback margine in tempo reale nel modal tariffa */
.svs-tariffa-feedback {
    font-size: 11px; padding: 6px 10px; border-radius: 5px;
    min-height: 28px; margin-bottom: 10px;
    transition: background .15s, color .15s;
}
.svs-tariffa-fb-good {
    color: #4ade80;
    background: rgba(74,222,128,.08);
    border: 1px solid rgba(74,222,128,.22);
}
.svs-tariffa-fb-neutral {
    color: #aaa;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
}
.svs-tariffa-fb-warn {
    color: #fbbf24;
    background: rgba(251,191,36,.07);
    border: 1px solid rgba(251,191,36,.2);
}
.colli-match-list { display: flex; flex-direction: column; gap: 4px; }
.colli-match-row {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    font-size: 12px; padding: 4px 6px; border-radius: 5px;
}
.match-ok  { background: rgba(74,222,128,.07); border: 1px solid rgba(74,222,128,.2); }
.match-no  { background: rgba(248,113,113,.05); border: 1px solid rgba(248,113,113,.15); opacity: .8; }
.match-warn{ background: rgba(251,191,36,.07);  border: 1px solid rgba(251,191,36,.2); }
.match-icon { font-size: 13px; flex-shrink: 0; }
.match-ok  .match-icon { color: #4ade80; }
.match-no  .match-icon { color: #f87171; }
.match-nome { font-weight: 700; color: var(--internal-text); }
.match-nveh { font-size: 10px; color: var(--internal-muted); }
.match-badge { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 10px; }
.match-adr  { background: rgba(56,189,248,.12); color: #38bdf8; border: 1px solid rgba(56,189,248,.2); }
.match-reasons { font-size: 10px; color: #f87171; margin-left: auto; }

/* Nuova UI matching veicoli individuali */
.match-ok-color { color: #4ade80; }
.match-no-color { color: #f87171; }
.match-suggerito { color: var(--internal-gold); font-weight: 700; font-size: 10px; }
.colli-match-group { margin-bottom: 6px; }
.cmg-label { font-size: 9px; font-weight: 800; text-transform: uppercase;
             letter-spacing: .05em; color: var(--internal-muted); margin-bottom: 4px; }
.cmg-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.colli-chip {
    display: inline-flex; flex-direction: column; align-items: center;
    padding: 3px 8px; border-radius: 5px; font-size: 11px; font-weight: 700;
    cursor: default; line-height: 1.3; border: 1px solid transparent;
    background: none; font-family: inherit; text-align: center;
}
/* V5.1: chip cliccabili come button */
button.colli-chip { cursor: pointer; transition: background .12s, border-color .12s, transform .08s; }
button.colli-chip:hover  { opacity: 1; filter: brightness(1.2); transform: translateY(-1px); }
button.colli-chip:active { transform: translateY(0); }
.colli-chip small { font-size: 8px; font-weight: 400; opacity: .75; }
.chip-ok   { background: rgba(74,222,128,.10);  border-color: rgba(74,222,128,.25);  color: #4ade80; }
.chip-warn { background: rgba(251,191,36,.10);  border-color: rgba(251,191,36,.30);  color: #fbbf24; }
.chip-no   { background: rgba(248,113,113,.07); border-color: rgba(248,113,113,.18); color: #f87171; opacity: .8; }
/* Stato selezionato */
.fleet-chip-selected,
button.colli-chip.fleet-chip-selected {
    outline: 2px solid currentColor; outline-offset: 2px;
    opacity: 1 !important; filter: brightness(1.3);
    box-shadow: 0 0 6px -1px currentColor;
}

/* ── Multi-veicolo: griglia viewer 3D ───────────────────── */
.mv-section { margin-top: 10px; border: 1px solid rgba(214,168,63,.2); border-radius: 5px;
              background: rgba(214,168,63,.02); overflow: hidden; }
.mv-header  { padding: 6px 12px; font-size: 11px; font-weight: 700; color: var(--internal-text);
              border-bottom: 1px solid rgba(214,168,63,.15); }
.mv-unassigned { padding: 4px 12px; font-size: 9px; color: #fbbf24; font-style: italic; }
.mv-grid    { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
              gap: 1px; background: var(--internal-border); }
.mv-card    { background: var(--internal-bg3); padding: 10px 12px; }
.mv-card-header { display: flex; align-items: center; gap: 7px; margin-bottom: 4px; flex-wrap: wrap; }
.mv-num     { font-size: 9px; font-weight: 800; padding: 1px 6px; background: rgba(214,168,63,.15);
              color: var(--internal-gold); border-radius: 3px; }
.mv-targa   { font-size: 12px; font-weight: 800; color: var(--internal-text); }
.mv-tipo    { font-size: 10px; color: var(--internal-muted); }
.mv-stats   { font-size: 10px; color: var(--internal-muted); margin-left: auto; }
.mv-ok      { color: #4ade80; font-weight: 700; }
.mv-warn    { color: #fbbf24; font-weight: 700; }
.mv-items   { font-size: 9px; color: var(--internal-muted); margin-bottom: 6px; font-style: italic; }
.mv-warn-text { font-size: 9px; color: #fbbf24; margin-bottom: 4px; }
.mv-canvas  { border-radius: 3px; }
.mv-status  { font-size: 8px; color: var(--internal-muted); text-align: right;
              padding: 2px 4px; font-style: italic; }

/* ── V5.1: pannello dettaglio veicolo selezionato ────────── */
.pv1-selected-detail { margin-top: 10px; }
.pv1-sel-header {
    font-size: 11px; font-weight: 700; color: var(--internal-text);
    padding: 5px 10px; background: rgba(99,179,237,.08);
    border: 1px solid rgba(99,179,237,.18); border-radius: 4px;
    margin-bottom: 6px;
}
.pv1-sel-tipo      { color: var(--internal-muted); font-weight: 400; }
.pv1-sel-unverified{ color: #fbbf24; font-size: 10px; }
.pv1-sel-empty {
    font-size: 9px; color: var(--internal-muted); font-style: italic;
    padding: 8px 10px; text-align: center;
}

/* ── V5.1: pannello quote e volumi ──────────────────────── */
.packing-quotes-panel {
    background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07);
    border-radius: 4px; padding: 6px 10px; margin-bottom: 6px; font-size: 10px;
}
.pq-row { display: flex; gap: 8px; align-items: baseline; padding: 2px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.pq-row:last-child { border-bottom: none; }
.pq-lbl { color: var(--internal-muted); min-width: 130px; flex-shrink: 0; }
.pq-val { color: var(--internal-text); }
.pq-pct-hi  { color: #4ade80; font-weight: 700; }
.pq-pct-mid { color: #fbbf24; }
.pq-pct-lo  { color: var(--internal-muted); }
.pq-seg-title { font-size: 10px; font-weight: 700; color: #63b3ed; margin-bottom: 4px; }
.pq-zone { border: 1px solid rgba(99,179,237,.15); border-radius: 3px; padding: 4px 7px; margin-bottom: 3px; }
.pq-zone-header { font-size: 10px; color: var(--internal-text); }
.pq-zone-items  { font-size: 9px; color: var(--internal-muted); margin-top: 2px; }
.pq-nom     { color: var(--internal-muted); font-size: 9px; }
.pq-tech-w  { color: #fbbf24; font-size: 8px; margin-left: 3px; }
.pq-warn    { font-size: 9px; color: #fbbf24; margin-top: 4px; padding: 3px 6px;
               background: rgba(251,191,36,.07); border-radius: 3px; }

/* ── Sezione "Dati richiesta" nel report ───────────────────── */
.report-input-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2px 12px;
    margin-top: 4px;
}
.report-input-row {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding: 4px 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    min-width: 0;
}
.report-input-label {
    font-size: 10px;
    color: var(--internal-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.report-input-value {
    font-size: 12px;
    color: var(--internal-text);
    word-break: break-word;
}

/* ══════════════════════════════════════════════════════════════════
   STAMPA — Preventivatore interno Schiavetta Trasporti
   Layout A4 ottimizzato: nessuno spazio sprecato, dati compatti
   ══════════════════════════════════════════════════════════════════ */
@media print {

    /* ── Pagina A4 con margini uniformi ──────────────────────── */
    @page {
        size: A4 portrait;
        margin: 11mm 14mm 11mm 14mm;
    }

    /* ── Reset colori su bianco ──────────────────────────────── */
    *, *::before, *::after {
        background: #fff !important;
        color: #111 !important;
        box-shadow: none !important;
        text-shadow: none !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    body { font-size: 8pt; line-height: 1.3; font-family: 'Inter', Arial, sans-serif; margin: 0; }

    /* ── Nascondi: UI, form, packing, viewer, label decorativi ─ */
    .internal-topbar, nav,
    .internal-form-panel, .form-panel-header,
    .internal-actions, .internal-tabs,
    .internal-history, .internal-guide,
    .internal-preview-card,
    /* label pseudo-elementi INPUT / OUTPUT (visivi, non stampabili) */
    .internal-form-panel::before, .internal-results::before,
    /* packing previews e viewer 3D */
    .colli-match-panel, #selectedVehiclePackingPanel,
    .pv1-debug-wrap, .pv1-panel, .pv2-preview-wrap,
    .pv4-wrap, .pv5-wrap, .pv3-multi-section, .mv-section,
    /* controlli mappa */
    .internal-route-map, .internal-map-meta, .mapboxgl-control-container,
    .internal-map-placeholder,
    /* bottoni e hint */
    .breakdown-details-btn, .section-toggle::before,
    .btn-pv5-reset, .pv5-controls, .pv5-hint,
    /* sezioni non utili in stampa */
    .internal-report > p.internal-muted,
    .internal-report > h3:last-of-type {
        display: none !important;
    }

    /* ── Shell e pannelli: nessun bordo, nessun padding ─────── */
    .internal-shell { display: block !important; padding: 0 !important; }
    .internal-panel, .internal-results {
        border: 0 !important; box-shadow: none !important;
        padding: 0 !important; overflow: visible !important;
        position: static !important; /* rimuove sticky/absolute */
    }
    /* Rimuove il bordo pseudo-element dall'interno-results */
    .internal-results { outline: none !important; }

    /* Messaggio se nessun preventivo calcolato */
    .internal-result-content:empty::after,
    .internal-result-content > .internal-guide::after {
        content: 'Nessun preventivo calcolato — calcola prima di stampare.';
        display: block;
        padding: 20px;
        font-size: 10pt;
        color: #888;
        text-align: center;
    }

    /* ══════════════════════════════════════════════════════════
       LAYOUT STAMPA: Prezzi orizzontali → Mappa strip → Report
       ══════════════════════════════════════════════════════════ */

    /* Flatten: no sidebar/main split — tutto in colonna unica */
    .results-layout {
        display: block !important;
        width: 100% !important;
    }
    .results-main {
        display: block !important;
        width: 100% !important;
    }

    /* ── Prezzi: barra orizzontale a 3 colonne ─────────────── */
    .result-price-sidebar {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 6px !important;
        width: 100% !important;
        height: auto !important;
        margin-bottom: 6px !important;
        align-items: start !important;
        position: static !important;  /* sovrascrive sticky */
    }
    /* Badge sidebar (confidence, margine) sotto la griglia prezzi */
    .sidebar-badges-section {
        grid-column: 1 / -1 !important;
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 4px 10px !important;
        border-top: 0.5pt solid #ccc !important;
        padding-top: 3px !important;
        margin-top: 0 !important;
    }
    .result-price-sidebar .internal-price {
        border: 0.75pt solid #bbb !important;
        border-radius: 3pt !important;
        padding: 5px 8px !important;
        min-height: 0 !important;
        text-align: center !important;
        page-break-inside: avoid !important;
    }
    .result-price-sidebar .internal-price.featured {
        border: 1.5pt solid #111 !important;
    }
    .result-price-sidebar .internal-price span { font-size: 6.5pt !important; color: #666 !important; }
    .result-price-sidebar .internal-price strong { font-size: 14pt !important; display: block; margin: 1px 0; }
    .result-price-sidebar .internal-price.featured strong { font-size: 16pt !important; }
    .result-price-sidebar .price-km { font-size: 6pt !important; color: #888 !important; }
    .sidebar-badge-row { font-size: 6.5pt !important; }
    .sidebar-badge-row .sb-label { color: #777 !important; }
    .sidebar-badge-row .sb-value { color: #111 !important; font-weight: 700; }
    .sidebar-badges-section .internal-badge {
        font-size: 6.5pt !important; padding: 1px 5px !important;
        color: #111 !important; border: 0.5pt solid #999 !important;
    }

    /* ── Mappa: strip orizzontale compatta ───────────────────── */
    .internal-map-card {
        width: 100% !important;
        height: 70px !important;
        max-height: 70px !important;
        aspect-ratio: unset !important;
        overflow: hidden !important;
        border: 0.5pt solid #ccc !important;
        border-radius: 3pt !important;
        margin: 0 0 5px !important;
    }
    .map-print-snapshot {
        display: block !important;
        width: 100% !important;
        height: 70px !important;
        object-fit: cover !important;
        object-position: center !important;
    }

    /* ── Intestazione report ─────────────────────────────────── */
    .internal-kicker { font-size: 7pt !important; color: #666 !important; display: block; margin-bottom: 1px; }
    .internal-report-head {
        display: flex !important;
        justify-content: space-between !important;
        align-items: flex-start !important;
        border-bottom: 1.5pt solid #111 !important;
        padding-bottom: 4px !important;
        margin-bottom: 5px !important;
    }
    .internal-report h2 { font-size: 13pt !important; margin: 1px 0 !important; }
    .internal-report-head p { font-size: 8pt !important; margin: 1px 0 !important; color: #444 !important; }

    /* ── Titoli di sezione compatti ──────────────────────────── */
    .internal-report h3,
    .internal-report h3.section-toggle,
    .internal-report h3.section-toggle.collapsed {
        font-size: 7.5pt !important;
        font-weight: 800 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.05em !important;
        color: #555 !important;
        margin: 5px 0 2px !important;
        padding: 2px 0 2px !important;
        border-bottom: 0.5pt solid #ccc !important;
        page-break-after: avoid !important;
    }
    /* "Report e sintesi" è già nascosto sopra, ma per sicurezza: */
    .internal-report > h3:last-of-type { display: none !important; }

    /* ── Forza apertura sezioni collassate ───────────────────── */
    .section-content, .section-content.collapsed,
    .section-toggle.collapsed + .section-content,
    .section-toggle + .section-content.collapsed { display: block !important; }
    .breakdown-details, .breakdown-details.collapsed { display: table-row !important; }
    .internal-table-wrap tr  { display: table-row   !important; }
    .internal-table-wrap td,
    .internal-table-wrap th  { display: table-cell  !important; }

    /* ── Dati richiesta: 3 colonne ───────────────────────────── */
    .report-input-grid {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 0 8px !important;
        margin: 0 !important;
    }
    .report-input-row {
        border-bottom: 0.5pt solid #e8e8e8 !important;
        padding: 2px 0 !important;
        break-inside: avoid !important;
    }
    .report-input-label { font-size: 6pt !important; color: #777 !important; display: block; }
    .report-input-value { font-size: 7.5pt !important; color: #111 !important; font-weight: 600; display: block; }

    /* ── Riepilogo operativo: 5 colonne ──────────────────────── */
    .internal-summary-grid {
        display: grid !important;
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 3px !important;
        margin: 0 !important;
    }
    .internal-summary-grid > div {
        border: 0.5pt solid #ccc !important;
        padding: 3px 5px !important;
        break-inside: avoid !important;
    }
    .internal-summary-grid span  { font-size: 6pt  !important; color: #666 !important; display: block; }
    .internal-summary-grid strong{ font-size: 7.5pt !important; display: block; margin-top: 1px; }

    /* ── Tabella scomposizione analitica ─────────────────────── */
    .internal-table-wrap {
        border: 0.75pt solid #ccc !important;
        border-radius: 0 !important;
        overflow: visible !important;
        margin-top: 0 !important;
    }
    .internal-table-wrap table { width: 100% !important; font-size: 7pt !important; border-collapse: collapse !important; }
    .internal-table-wrap th {
        background: #f2f2f2 !important; color: #111 !important;
        border: 0.5pt solid #ccc !important;
        padding: 2.5px 5px !important; font-size: 6.5pt !important; font-weight: 700 !important;
    }
    .internal-table-wrap td {
        color: #111 !important; border: 0.5pt solid #e0e0e0 !important;
        padding: 2px 5px !important;
    }
    .internal-table-wrap td.subtotale-col,
    .internal-table-wrap th.subtotale-col {
        background: #fdf6e3 !important; color: #7a5a00 !important;
        border-left: 1.5pt solid #c8a830 !important; font-weight: 700 !important;
    }
    .internal-table-wrap .breakdown-category td {
        background: #ebebeb !important; color: #111 !important;
        font-size: 7pt !important; font-weight: 700 !important;
    }

    /* ── Alert (deroga, warning) ─────────────────────────────── */
    .internal-alert {
        border: 0.5pt solid #999 !important; color: #111 !important;
        padding: 4px 7px !important; margin: 3px 0 !important;
        font-size: 7.5pt !important; break-inside: avoid !important;
    }

    /* ── Lista warning ───────────────────────────────────────── */
    .internal-warning-list {
        color: #333 !important; font-size: 7pt !important;
        margin: 2px 0 !important; padding-left: 14px !important;
    }

    /* ── Confidence / badge ──────────────────────────────────── */
    .internal-badge {
        border: 0.5pt solid #999 !important; color: #111 !important;
        font-size: 7pt !important; padding: 2px 5px !important;
    }
    .internal-risk-row {
        margin: 2px 0 5px !important; flex-wrap: wrap !important; gap: 4px !important;
    }
    .internal-risk-row span:not(.internal-badge) {
        border: 0.5pt solid #ccc !important; color: #555 !important;
        background: #f6f6f6 !important; font-size: 7pt !important; padding: 2px 6px !important;
    }

    /* ── Interruzioni di pagina ──────────────────────────────── */
    .internal-table-wrap   { page-break-inside: auto !important; }
    .internal-summary-grid { page-break-inside: avoid !important; }
    .internal-alert        { page-break-inside: avoid !important; }
    h3.section-toggle      { page-break-after: avoid !important; }
    .internal-report-head  { page-break-after: avoid !important; }
}

/* ── Scrollbar sottili e coerenti con il tema scuro ─────────────────────────── */
::-webkit-scrollbar              { width: 5px; height: 5px; }
::-webkit-scrollbar-track        { background: transparent; }
::-webkit-scrollbar-thumb        { background: rgba(255,255,255,.13); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover  { background: rgba(214,168,63,.38); }
::-webkit-scrollbar-corner       { background: transparent; }
*                                { scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.13) transparent; }
