h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}
/* ===== Sorting Simulator (.so-*) ===== */
.so-shell { font-family: system-ui, -apple-system, "Segoe UI", sans-serif; color: #1c2733; }
.so-top { display: flex; align-items: center; gap: 1.5rem; padding: .6rem 1.2rem; background: #0f2740; color: #fff; }
.so-brand { font-size: 1.05rem; } .so-brand b { color: #7cc0ff; }
.so-switch { display: flex; gap: .3rem; }
.so-tab { background: transparent; color: #b9c8d8; border: 0; padding: .4rem .8rem; border-radius: 7px; cursor: pointer; font-size: .9rem; }
.so-tab:hover { background: #1c3b5a; color: #fff; }
.so-tab-on { background: #2563eb; color: #fff; }
.so-top-right { margin-left: auto; color: #7e96ad; font-size: .82rem; }
.so-main { padding: 1rem 1.2rem 3rem; max-width: 1100px; margin: 0 auto; }

.so-card { background: #fff; border: 1px solid #e1e8ef; border-radius: 12px; padding: 1rem 1.1rem; margin-bottom: 1rem; }
.so-card-h { font-weight: 600; margin-bottom: .6rem; font-size: .95rem; }
.so-h2 { font-size: 1.1rem; margin: 0 0 .4rem; }
.so-note { color: #5b6b7b; font-size: .85rem; }
.so-empty { color: #8696a6; font-style: italic; }
.so-warn { background: #fff7ed; border-color: #fed7aa; }
.so-soon { text-align: center; color: #5b6b7b; }

.so-transport { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap; background: #fff; border: 1px solid #e1e8ef; border-radius: 12px; padding: .6rem .9rem; margin-bottom: 1rem; }
.so-tgroup { display: flex; align-items: center; gap: .35rem; }
.so-tlabel { color: #8696a6; font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; margin-right: .2rem; }
.so-tclock { margin-left: auto; font-variant-numeric: tabular-nums; color: #334; font-weight: 600; }
.so-btn { border: 1px solid #cfd9e3; background: #f6f9fc; border-radius: 8px; padding: .4rem .8rem; cursor: pointer; font-size: .9rem; }
.so-btn:hover { background: #eef4fa; }
.so-btn-go { background: #16a34a; color: #fff; border-color: #16a34a; }
.so-chip { border: 1px solid #cfd9e3; background: #fff; border-radius: 999px; padding: .25rem .6rem; cursor: pointer; font-size: .82rem; }
.so-chip-on { background: #2563eb; color: #fff; border-color: #2563eb; }

.so-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(135px, 1fr)); gap: .7rem; margin-bottom: 1rem; }
.so-kpi-tile { background: #fff; border: 1px solid #e1e8ef; border-radius: 10px; padding: .7rem .8rem; }
.so-kpi-accent { background: #eff6ff; border-color: #bfdbfe; }
.so-kpi-warn { background: #fef2f2; border-color: #fecaca; }
.so-kpi-v { font-size: 1.5rem; font-weight: 700; color: #0b62c4; line-height: 1.1; }
.so-kpi-accent .so-kpi-v { color: #1d4ed8; } .so-kpi-warn .so-kpi-v { color: #dc2626; }
.so-kpi-l { font-size: .78rem; color: #5b6b7b; margin-top: .2rem; }
.so-kpi-s { font-size: .72rem; color: #8696a6; }

.so-bufbars { width: 100%; }
.so-svg { width: 100%; height: auto; display: block; }
.so-bands { display: flex; gap: 1.2rem; margin-top: .5rem; font-size: .8rem; color: #5b6b7b; }
.so-band i { display: inline-block; width: 11px; height: 11px; border-radius: 2px; margin-right: .35rem; vertical-align: -1px; }

.so-log { font-size: .82rem; max-height: 280px; overflow: auto; }
.so-logrow { display: flex; gap: .6rem; padding: .2rem 0; border-bottom: 1px solid #f1f4f7; }
.so-logt { color: #8696a6; font-variant-numeric: tabular-nums; min-width: 64px; }
.so-logk { font-weight: 600; min-width: 86px; }
.so-logm { color: #334; }
.so-k-storage { color: #0b62c4; } .so-k-robotplace, .so-k-orderready { color: #0e9f6e; }
.so-k-backpressure, .so-k-nolocation { color: #c2410c; } .so-k-flush { color: #7c3aed; }

/* header live/storico */
.so-live { color: #34d399; font-weight: 600; font-size: .8rem; }
.so-rew { color: #fbbf24; font-weight: 600; font-size: .8rem; }

/* timeline */
.so-timeline { display: flex; align-items: center; gap: .8rem; background: #fff; border: 1px solid #e1e8ef; border-radius: 12px; padding: .5rem .9rem; margin-bottom: 1rem; flex-wrap: wrap; }
.so-range { flex: 1; min-width: 120px; accent-color: #2563eb; }
/* larghezza riservata: la label non deve far "saltare" lo slider quando passa da "live" a "snapshot N/M" */
.so-timelbl { flex: 0 0 auto; width: 150px; text-align: right; font-variant-numeric: tabular-nums; margin-right: 0; }
/* navigazione storico: pulsanti passo-passo + salto diretto */
.so-tlnav { display: flex; align-items: center; gap: .25rem; flex: 0 0 auto; }
.so-tlbtn { border: 1px solid #cfd9e3; background: #fff; border-radius: 7px; padding: .25rem .5rem; cursor: pointer; font-size: .8rem; line-height: 1; color: #334155; }
.so-tlbtn:hover:not(:disabled) { background: #f1f5fb; border-color: #2563eb; color: #2563eb; }
.so-tlbtn:disabled { opacity: .4; cursor: default; }
.so-tljump { display: flex; align-items: center; gap: .3rem; flex: 0 0 auto; }
.so-tlnum { width: 64px; padding: .2rem .35rem; border: 1px solid #cfd9e3; border-radius: 7px; font-size: .8rem; font-variant-numeric: tabular-nums; }

/* tabelle generiche */
.so-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.so-table th, .so-table td { text-align: left; padding: .35rem .55rem; border-bottom: 1px solid #f1f4f7; }
.so-table th { color: #5b6b7b; font-weight: 600; }
.so-table code, .so-feedrow code, .so-kv code { font-size: .82em; color: #0b62c4; }
.so-old { background: #fff7ed; }
.so-sis { color: #5b6b7b; max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* lane hit + detail */
.so-lanehit { cursor: pointer; }
.so-lanehead { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.so-x { border: 0; background: #eef2f6; border-radius: 6px; cursor: pointer; padding: .15rem .5rem; }

/* ingresso */
.so-cols2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 720px) { .so-cols2 { grid-template-columns: 1fr; } }
.so-feed { max-height: 320px; overflow: auto; }
.so-feedrow { display: flex; gap: .7rem; align-items: center; padding: .3rem .2rem; border-bottom: 1px solid #f1f4f7; cursor: pointer; }
.so-feedrow:hover { background: #f6f9fc; }
.so-feedrow-on { background: #eff6ff; }
.so-muted, .so-feedrow .so-muted { color: #8696a6; margin-left: auto; font-size: .8rem; }
.so-kv { width: 100%; font-size: .88rem; }
.so-kv td { padding: .3rem .4rem; border-bottom: 1px solid #f4f6f9; }
.so-kv td:first-child { color: #5b6b7b; width: 42%; }
.so-anoms { margin: 0; padding-left: 1.2rem; font-size: .85rem; }

/* giacenza / prelievo */
.so-filter { float: right; border: 1px solid #cfd9e3; border-radius: 7px; padding: .25rem .5rem; font-size: .82rem; min-width: 190px; }
.so-gd-hit { cursor: pointer; }
.so-gd-hit:hover { background: #f6f9fc; }
.so-caret { color: #8696a6; width: 1.2rem; text-align: center; user-select: none; }
.so-gd-row > td { background: #f8fafc; padding: .2rem .55rem .5rem 1.8rem; }
.so-gd-tbl { width: auto; min-width: 360px; font-size: .82rem; }
.so-gd-tbl th, .so-gd-tbl td { border-bottom: 1px solid #e8edf2; padding: .25rem .8rem .25rem 0; }
.so-gd-tbl td:last-child, .so-gd-tbl th:last-child { text-align: right; }
.so-modebar { font-size: .9rem; color: #334; margin-bottom: 1rem; }
.so-chan { display: flex; gap: .3rem; }

/* linee di scarico */
.so-lines { display: flex; gap: 1rem; flex-wrap: wrap; }
.so-line { flex: 1; min-width: 220px; border: 1px solid #e1e8ef; border-radius: 9px; padding: .55rem .7rem; display: flex; flex-direction: column; gap: .25rem; }
.so-line-h { font-weight: 600; font-size: .85rem; }
.so-line-bay { display: flex; align-items: center; gap: .45rem; font-size: .82rem; padding: .1rem 0; }
.so-bay-n { color: #8696a6; font-size: .72rem; min-width: 44px; }
.so-line-busy { font-size: .82rem; color: #1d4ed8; }
.so-line-change { font-size: .82rem; color: #b45309; }
.so-line-free { font-size: .82rem; color: #16a34a; }

/* pannello impostazioni tempi */
.so-setcard .so-bufhead { margin-bottom: 0; }
.so-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1.1rem; margin-top: .8rem; }
.so-formgrp { display: flex; flex-direction: column; gap: .4rem; }
.so-formh { font-weight: 600; font-size: .8rem; color: #334; border-bottom: 1px solid #eef2f6; padding-bottom: .25rem; }
.so-form label { display: flex; flex-direction: column; gap: .15rem; font-size: .76rem; color: #5b6b7b; }
.so-form input { border: 1px solid #cfd9e3; border-radius: 6px; padding: .28rem .45rem; font-size: .85rem; }
.so-form input:focus { outline: 2px solid #bfdbfe; border-color: #93c5fd; }
.so-formbar { display: flex; align-items: center; gap: .8rem; margin-top: 1rem; flex-wrap: wrap; }

/* BufferView B (layout top-down) */
.so-bufhead { display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.so-toggle { display: flex; gap: .3rem; }
.so-flowhint { color: #8696a6; font-style: italic; }
.so-svgt { font-size: 9px; fill: #334; font-family: system-ui, sans-serif; }
.so-svgt-mut { fill: #8696a6; font-size: 8px; }
.so-svgt-in { fill: #20303f; font-size: 8.5px; }
.so-svgt-band { fill: #5b6b7b; font-size: 9.5px; font-weight: 600; }
.so-svgt-nav { fill: #5b4500; font-size: 7px; font-weight: 700; }
.so-svgt-onfill { fill: #fff; font-size: 8.5px; font-weight: 600; }
.so-svgt-region { fill: #5b6b7b; font-size: 10px; font-weight: 700; }

/* RackPreview (anteprima cavalletto) */
.so-rackgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(520px, 1fr)); gap: .9rem; margin-bottom: .6rem; }
/* card cavalletto: viste a sinistra, griglia vetri a destra */
.so-rack-body { display: flex; gap: 1rem; align-items: flex-start; margin-top: .4rem; }
.so-rack-left { flex: 0 0 230px; min-width: 0; }
.so-rack-right { flex: 1 1 0; min-width: 0; overflow-x: auto; }
.so-rack { border: 1px solid #e1e8ef; border-radius: 10px; padding: .55rem .7rem; background: #fff; }
.so-rack-h { display: flex; justify-content: space-between; align-items: center; font-size: .82rem; gap: .5rem; }
.so-rack-state { font-size: .7rem; padding: .1rem .45rem; border-radius: 999px; font-weight: 600; white-space: nowrap; }
.so-st-load { background: #eff6ff; color: #1d4ed8; }
.so-st-sat { background: #fef3c7; color: #b45309; }
.so-st-ship { background: #dcfce7; color: #166534; }
.so-rack-occ { margin-top: .3rem; display: flex; flex-direction: column; gap: .25rem; }
.so-occrow { display: flex; align-items: center; gap: .5rem; font-size: .74rem; color: #5b6b7b; }
.so-occrow > span:first-child { width: 58px; }
.so-occbar { flex: 1; height: 8px; background: #eef2f6; border-radius: 4px; overflow: hidden; }
.so-occfill { height: 100%; background: #2563eb; }
.so-occfill-w { background: #c2410c; }
.so-occv { font-variant-numeric: tabular-nums; min-width: 104px; text-align: right; }

/* Storico scarichi */
.so-ship-table { font-size: .8rem; }
.so-ship-time { font-variant-numeric: tabular-nums; white-space: nowrap; color: #5b6b7b; }
.so-ship-id { font-size: .72rem; color: #7b8fa1; }
.so-ship-racktype { font-size: .7rem; color: #9ca3af; margin-left: .3rem; }
.so-ship-pct { font-size: .72rem; color: #6b7280; }
.so-ship-why { font-size: .72rem; font-style: italic; color: #6b7280; }
.so-ship-full { color: #15803d; font-weight: 600; }
.so-ship-ok   { color: #2563eb; }
.so-ship-low  { color: #b45309; }
.so-ship-burro { background: #f8fafc; }
.so-ship-cassa { background: #fdf4ff; }

/* Drill-down allocazione: Impianto → Buffer → Corsia */
.so-bufhit { cursor: pointer; fill: transparent; transition: fill .1s; }
.so-bufhit:hover { fill: rgba(37, 99, 235, .12); stroke: #2563eb; stroke-width: 2; }

.so-crumbs { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; margin-bottom: .7rem; }
.so-crumb { border: 0; background: transparent; color: #2563eb; cursor: pointer; font-size: .9rem; padding: .15rem .3rem; border-radius: 6px; }
.so-crumb:hover { background: #eff6ff; }
.so-crumb-cur { color: #1c2733; font-weight: 600; cursor: default; }
.so-crumb-cur:hover { background: transparent; }
.so-crumb-sep { color: #b6c2cf; }
.so-crumb-fill { flex: 1; min-width: .5rem; }
.so-crumb-back { padding: .25rem .6rem; font-size: .82rem; }

.so-bd-head { display: flex; align-items: center; gap: .4rem; }
.so-bd-cls { display: inline-block; width: 12px; height: 12px; border-radius: 3px; vertical-align: -1px; margin-right: .15rem; }
.so-bd-lanes { display: flex; flex-direction: column; gap: 3px; max-height: 460px; overflow-y: auto; padding-right: .2rem; }
.so-bd-lane { display: flex; align-items: center; gap: .5rem; cursor: pointer; padding: 1px 2px; border-radius: 5px; }
.so-bd-lane:hover { background: #f1f6fc; }
.so-bd-laneid { flex: 0 0 76px; font-size: .72rem; font-variant-numeric: tabular-nums; color: #5b6b7b; }
.so-bd-track { flex: 1; min-width: 0; display: flex; height: 16px; background: #eef2f6; border: 1px solid #e1e8ef; border-radius: 3px; overflow: hidden; }
.so-bd-seg { flex-grow: 0; flex-shrink: 0; height: 100%; box-shadow: inset 0 0 0 .5px rgba(255,255,255,.55); }
.so-bd-gap { flex-grow: 0; flex-shrink: 0; height: 100%; background: transparent; }
.so-bd-lane:hover .so-bd-track { border-color: #93c5fd; }
.so-bd-occ { flex: 0 0 42px; text-align: right; font-size: .72rem; font-variant-numeric: tabular-nums; color: #5b6b7b; }
.so-bd-foot { margin-top: .5rem; font-size: .76rem; color: #8696a6; font-style: italic; }

.so-swatch { display: inline-block; width: 9px; height: 9px; border-radius: 2px; vertical-align: 0; margin-right: .35rem; }

/* Prelievo v5 — contenitori, destinazione, fill */
.so-rackcard { border: 1px solid #e1e8ef; border-radius: 10px; padding: .55rem .7rem; background: #fff; display: flex; flex-direction: column; gap: .3rem; }
.so-rackcard.so-shippable { border-color: #16a34a; background: #f0fdf4; }
.so-rack-hdr { display: flex; align-items: center; gap: .5rem; font-size: .82rem; font-weight: 600; }
.so-rack-fill { font-size: .76rem; color: #5b6b7b; }
.so-ready-badge { margin-left: auto; background: #16a34a; color: #fff; border-radius: 999px; padding: .1rem .5rem; font-size: .7rem; }
.so-dest { font-size: .78rem; font-weight: 600; }
.so-sale { color: #7c3aed; }
.so-proc { color: #0369a1; }
.so-ct { font-size: .78rem; color: #374151; }

/* Prelievo — barra di saturazione contenitore */
.so-satcell { display: flex; align-items: center; gap: .4rem; }
.so-satbar { flex: 0 0 70px; height: 8px; background: #eef2f6; border-radius: 4px; overflow: hidden; }
.so-satfill { height: 100%; background: #94a3b8; }
.so-satfill.so-sat-mid { background: #2563eb; }
.so-satfill.so-sat-hi { background: #16a34a; }
.so-satv { font-variant-numeric: tabular-nums; font-size: .76rem; color: #5b6b7b; min-width: 34px; }

/* RackPreview: viste laterale + frontale */
.so-rackviews { display: flex; flex-direction: column; gap: .5rem; }
.so-rackview { min-width: 0; }
.so-rackview-t { font-size: .68rem; color: #8696a6; text-transform: uppercase; letter-spacing: .03em; margin-bottom: .15rem; }

/* Storico scarichi — dettaglio composizione */
.so-shipdetail { display: flex; flex-wrap: wrap; gap: 1rem; align-items: flex-start; padding: .3rem 0; }
.so-shipdetail-view { flex: 1 1 320px; min-width: 0; max-width: 460px; }
.so-shipdetail > table { flex: 1 1 240px; align-self: flex-start; }

/* Griglia vetri dentro la card del cavalletto attivo */
.so-rack-tbl { font-size: .72rem; margin-top: .45rem; }
.so-rack-tbl th, .so-rack-tbl td { padding: .18rem .35rem; white-space: nowrap; }
.so-rack-tbl code { font-size: .68rem; }

/* Storico missioni (Console): filtro per matricola/ordine + esito non-ok */
.so-mrfilter { width: 210px; padding: .2rem .5rem; border: 1px solid #cbd5e1; border-radius: 6px; font-size: .78rem; }
.so-mrfilter:focus { outline: none; border-color: #0b62c4; }
.so-mr-ko { color: #b45309; font-weight: 600; }

/* Configura impianto (PlantSetup) */
.so-setup { display: flex; flex-direction: column; gap: .8rem; }
.so-setup-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .6rem; }
.so-setup-head h3 { margin: 0; }
.so-setup-preset { display: flex; align-items: center; gap: .4rem; font-size: .82rem; }
.so-setup-preset select { padding: .25rem .5rem; border: 1px solid #cbd5e1; border-radius: 6px; }
.so-setup-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.so-setup-grid .so-card { padding: .7rem .8rem; }
.so-setup-grid .so-card h4 { margin: 0 0 .5rem; font-size: .9rem; display: flex; align-items: center; gap: .5rem; }
.so-span2 { grid-column: 1 / span 2; }
.so-tbl { width: 100%; border-collapse: collapse; font-size: .78rem; }
.so-tbl th { text-align: left; color: #64748b; font-weight: 600; padding: .15rem .3rem; }
.so-tbl td { padding: .15rem .3rem; }
.so-in { padding: .2rem .4rem; border: 1px solid #cbd5e1; border-radius: 6px; font-size: .78rem; width: 100%; box-sizing: border-box; }
.so-in:focus { outline: none; border-color: #0b62c4; }
.so-in-n { width: 5.5rem; }
.so-mini { font-size: .72rem; padding: .12rem .5rem; border: 1px solid #cbd5e1; border-radius: 6px; background: #f1f5f9; cursor: pointer; }
.so-mini:hover { background: #e2e8f0; }
.so-mini-x { color: #b91c1c; border-color: #fecaca; background: #fef2f2; }
.so-radio { display: block; font-size: .82rem; margin: .25rem 0; cursor: pointer; }
.so-syn { margin-top: .5rem; display: flex; flex-direction: column; gap: .35rem; font-size: .8rem; }
.so-syn label { display: flex; align-items: center; gap: .4rem; }
.so-setup-actions { display: flex; align-items: center; gap: .8rem; }
.so-setup-msg { font-size: .82rem; color: #166534; }
.so-mut { color: #64748b; font-size: .76rem; margin-top: .4rem; }
.so-cap { margin-top: .2rem; }
.so-cap-profile { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: .6rem; font-size: .82rem; }
.so-cap-profile label { display: flex; align-items: center; gap: .4rem; }
.so-captbl th, .so-captbl td { text-align: right; }
.so-captbl th:first-child, .so-captbl td:first-child { text-align: left; }
.so-captbl td b { color: #0b62c4; }
.so-cap-warn { background: #fef2f2; }
.so-cap-warn td { color: #b91c1c; }
.so-in-bad { border-color: #dc2626 !important; background: #fef2f2; }
.so-in-bad:focus { border-color: #dc2626 !important; }
.so-mixsum-bad { margin-top: .4rem; font-size: .8rem; color: #b91c1c; font-weight: 600; }
.so-upl { display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; margin: .5rem 0; font-size: .82rem; }
.so-map1 { display: inline-flex; align-items: center; gap: .4rem; font-size: .8rem; margin: .3rem 0; }
.so-mapgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .5rem .8rem; margin: .4rem 0; }
.so-mapgrid label { display: flex; flex-direction: column; gap: .2rem; font-size: .76rem; color: #475569; }
.so-maprule { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; margin-top: .5rem; }
.so-maprule > div { font-size: .8rem; }
.so-maprule .so-in { display: inline-block; width: auto; min-width: 7rem; }
.so-maprule .so-in-n { min-width: 4rem; width: 4rem; }
.so-cap-src { margin: .6rem 0; padding: .6rem .7rem; border: 1px dashed #cbd5e1; border-radius: 8px; background: #f8fafc; }
.so-cap-srctitle { font-size: .82rem; margin-bottom: .3rem; }
.so-setup-saved { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; font-size: .82rem; padding: .2rem 0; }
.so-setup-saved .so-in { width: auto; min-width: 9rem; }
.so-saved-lbl { color: #475569; font-weight: 600; }
.so-saved-msg { color: #166534; }
.so-hints { margin: .5rem 0; padding: .5rem .7rem; border-left: 3px solid #f59e0b; background: #fffbeb; font-size: .8rem; border-radius: 0 6px 6px 0; }
.so-hints ul { margin: .3rem 0 0; padding-left: 1.1rem; }
.so-hints li { margin: .15rem 0; color: #92400e; }

/* Overlay globale "Attendere…" durante elaborazioni/caricamenti */
.so-busy { position: fixed; inset: 0; z-index: 9999; background: rgba(15, 23, 42, .45);
    display: flex; align-items: center; justify-content: center; }
.so-busy-box { background: #fff; border-radius: 12px; padding: 1.4rem 1.8rem; box-shadow: 0 10px 40px rgba(0,0,0,.25);
    display: flex; flex-direction: column; align-items: center; gap: .8rem; min-width: 220px; }
.so-busy-msg { font-size: .9rem; color: #0f172a; font-weight: 600; text-align: center; }
.so-spinner { width: 38px; height: 38px; border: 4px solid #dbeafe; border-top-color: #0b62c4;
    border-radius: 50%; animation: so-spin .8s linear infinite; }
@keyframes so-spin { to { transform: rotate(360deg); } }

/* === Caricamento dati guidato (PlantSetup): banner di stato, badge, blocco obbligatori, opzionali === */
.so-statusbar { display: flex; align-items: center; gap: .4rem; padding: .45rem .7rem; border-radius: 6px;
    font-size: .85rem; margin: .4rem 0; font-weight: 600; }
.so-status-ok { background: #dcfce7; color: #166534; border: 1px solid #16a34a; }
.so-status-warn { background: #fef9c3; color: #854d0e; border: 1px solid #f59e0b; }
.so-status-neutral { background: #f1f5f9; color: #475569; border: 1px solid #cbd5e1; }

.so-okpill { color: #166534; font-size: .78rem; font-weight: 600; margin-left: .4rem; }
.so-badge-req { color: #b91c1c; font-size: .78rem; font-weight: 600; margin-left: .4rem; }

.so-step { margin: .7rem 0 .2rem; font-size: .92rem; }

.so-srcopt { display: flex; align-items: flex-start; gap: .5rem; padding: .35rem .2rem; cursor: pointer; }
.so-srcopt input { margin-top: .25rem; }
.so-srcopt-txt { display: flex; flex-direction: column; line-height: 1.35; }

.so-req { margin: .4rem 0; padding: .55rem .7rem; border-left: 3px solid #0b62c4; background: #f8fafc; border-radius: 4px; }
.so-req > label { display: flex; align-items: center; gap: .4rem; margin: .3rem 0; }
.so-reqth { margin-top: .4rem; display: flex; flex-wrap: wrap; align-items: center; gap: .4rem .8rem; }
.so-reqth-lbl { font-weight: 600; }

.so-optional { margin: .5rem 0; }
.so-optional > summary { cursor: pointer; font-weight: 600; color: #0b62c4; padding: .35rem 0; user-select: none; }
.so-optional[open] > summary { margin-bottom: .4rem; }

.so-cta { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; margin-top: .5rem; }
.so-result-lbl { font-size: .85rem; color: #475569; font-weight: 600; margin: .6rem 0 .3rem; }

/* === Schermata di avvio (WASM: mentre il runtime .NET si scarica) === */
.so-boot { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 1rem; background: #0f2740; color: #cfe1f5; font-family: system-ui, -apple-system, "Segoe UI", sans-serif; }
.so-boot .so-spinner { border-color: #1c3b5a; border-top-color: #7cc0ff; }
.so-boot-msg { font-size: .95rem; }

/* === Banner "nuova versione disponibile" (PWA update flow, Fase 4) === */
.so-update-banner { position: fixed; left: 50%; bottom: 1rem; transform: translateX(-50%); z-index: 2000;
    display: flex; align-items: center; gap: .8rem; padding: .6rem 1rem; border-radius: 10px;
    background: #0f2740; color: #fff; box-shadow: 0 6px 24px rgba(0,0,0,.28); font-size: .9rem;
    font-family: system-ui, -apple-system, "Segoe UI", sans-serif; max-width: calc(100vw - 2rem); }
.so-update-banner button { cursor: pointer; border: 0; border-radius: 7px; font-weight: 600; font-size: .85rem; }
#so-update-go { background: #2563eb; color: #fff; padding: .35rem .8rem; }
#so-update-go:hover { background: #1d4ed8; }
#so-update-x { background: transparent; color: #9fb6cf; padding: .2rem .4rem; }
#so-update-x:hover { color: #fff; }

/* Dataset di esempio (PlantSetup) */
.so-sample { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; margin: .5rem 0 .2rem;
    padding: .5rem .6rem; background: #f1f5f9; border: 1px dashed #cbd5e1; border-radius: 6px; }
