:root {
    --color-bg: #f4f6f8;
    --color-surface: #ffffff;
    --color-surface-soft: #f8fafc;
    --color-border: #e5e7eb;
    --color-border-strong: #d1d5db;
    --color-text: #111827;
    --color-muted: #6b7280;
    --color-primary: #7a1f3d;
    --color-primary-hover: #681933;
    --color-primary-soft: #fce7f3;
    --color-blue: #2563eb;
    --color-blue-hover: #1d4ed8;
    --color-green-bg: #dcfce7;
    --color-green-text: #166534;
    --color-yellow-bg: #fef3c7;
    --color-yellow-text: #92400e;
    --color-red-bg: #fee2e2;
    --color-red-text: #991b1b;
    --color-gray-bg: #f3f4f6;
    --color-gray-text: #374151;
    --header-bg: #111827;
    --header-border: #1f2937;
    --header-text: #f9fafb;
    --header-text-soft: #cbd5e1;
    --header-hover: #2a1b22;
    --header-dropdown-bg: #0f172a;
    --header-dropdown-border: #334155;
    --danger-bg: #7f1d1d;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
    --shadow-md: 0 8px 22px rgba(15, 23, 42, 0.08);
}

/* ======================================================
   RESET / BASE
====================================================== */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    min-height: 100vh;
    font-family: Arial, Helvetica, sans-serif;
    background: var(--color-bg);
    color: var(--color-text);
    font-size: 14px;
    line-height: 1.45;
}
a { color: inherit; }
img { max-width: 100%; }

/* ======================================================
   HEADER / MENU
====================================================== */
.main-header {
    position: sticky;
    top: 0;
    z-index: 2000;
    background: var(--header-bg);
    border-bottom: 1px solid var(--header-border);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
}
.header-shell { max-width: 1450px; margin: 0 auto; padding: 8px 18px; }
.header-row { display: flex; align-items: center; gap: 14px; min-height: 56px; }
.brand-block { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--header-text); flex-shrink: 0; }
.brand-logo {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary);
    color: #fff;
    font-size: 18px;
    box-shadow: 0 6px 18px rgba(122, 31, 61, 0.28);
}
.brand-text { display: flex; flex-direction: column; gap: 1px; }
.brand-title { font-size: 16px; font-weight: 800; line-height: 1.1; color: var(--header-text); }
.brand-subtitle { font-size: 11px; color: var(--header-text-soft); line-height: 1.1; }
.main-nav { display: flex; align-items: center; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.nav-link, .nav-dropdown-toggle, .dropdown-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 8px 12px;
    border-radius: 10px;
    text-decoration: none;
    color: var(--header-text-soft);
    background: transparent;
    border: 1px solid transparent;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: 0.2s ease;
    font-family: inherit;
}
.nav-link:hover, .nav-dropdown-toggle:hover, .dropdown-link:hover { background: var(--header-hover); color: var(--header-text); }
.nav-link.is-active, .nav-dropdown.is-active > .nav-dropdown-toggle, .dropdown-link.is-active { background: var(--color-primary); color: #fff; }
.nav-icon { width: 18px; text-align: center; line-height: 1; font-size: 15px; flex-shrink: 0; }
.nav-dropdown { position: relative; }
.dropdown-arrow { font-size: 11px; margin-left: 2px; transition: transform 0.2s ease; }
.nav-dropdown.is-open .dropdown-arrow { transform: rotate(180deg); }
.nav-dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 280px;
    background: var(--header-dropdown-bg);
    border: 1px solid var(--header-dropdown-border);
    border-radius: 12px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
    padding: 8px;
    z-index: 3000;
}
.nav-dropdown.is-open .nav-dropdown-menu { display: block; }
.dropdown-link { width: 100%; justify-content: flex-start; }
.nav-link-logout { color: #fecaca; }
.nav-link-logout:hover { background: var(--danger-bg); color: #fff; }
.nav-user { display: inline-flex; flex-direction: column; gap: 1px; padding: 5px 10px; border-left: 1px solid #374151; color: var(--header-text-soft); line-height: 1.1; }
.nav-user-name { font-size: 12px; font-weight: 700; color: var(--header-text); }
.nav-user-role { font-size: 10px; text-transform: uppercase; color: var(--header-text-soft); }
.nav-toggle { display: none; margin-left: auto; border: 1px solid #374151; background: transparent; color: var(--header-text); border-radius: 10px; padding: 7px 11px; font-size: 20px; cursor: pointer; }

/* ======================================================
   LAYOUT / COMPONENTI GENERALI
====================================================== */
.page-content { max-width: 1450px; margin: 0 auto; padding: 20px; }
.page-header, .header-flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}
.page-title { margin: 0; font-size: 26px; font-weight: 800; color: var(--color-text); }
.page-subtitle { margin: 4px 0 0; color: var(--color-muted); }
.main-footer { margin-top: 30px; padding: 20px; color: var(--color-muted); font-size: 13px; }
.footer-shell { max-width: 1450px; margin: 0 auto; display: flex; gap: 8px; justify-content: center; align-items: center; }

.box, .card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 18px;
    margin-bottom: 20px;
    box-shadow: var(--shadow-sm);
}
.card-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.card-title { margin: 0; font-size: 18px; font-weight: 800; }
.card-subtitle { margin: 4px 0 0; color: var(--color-muted); font-size: 13px; }
.grid { display: grid; gap: 16px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.table-wrap { width: 100%; overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; background: var(--color-surface); }
.table th, .table td { padding: 10px 12px; border: 1px solid var(--color-border); text-align: left; vertical-align: top; }
.table th { background: var(--color-surface-soft); font-weight: 700; white-space: nowrap; }
.table tbody tr:hover { background: #fafafa; }
.table-compact th, .table-compact td { padding: 7px 9px; font-size: 13px; }
.table-hover tbody tr:hover { background: #f8fafc; }

.form-grid { display: grid; gap: 14px; }
.form-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.form-grid-full { grid-column: 1 / -1; }
.form-row { display: flex; gap: 12px; flex-wrap: wrap; align-items: end; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
label { font-weight: 700; color: var(--color-text); }
input[type="text"], input[type="email"], input[type="password"], input[type="date"], input[type="time"], input[type="number"], input[type="datetime-local"], input[type="url"], input[type="file"], select, textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-family: inherit;
    background: #fff;
    color: var(--color-text);
}
textarea { resize: vertical; min-height: 90px; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(122, 31, 61, 0.12); }
.help-text, .field-help { color: var(--color-muted); font-size: 12px; }

.action-buttons, .actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 38px;
    padding: 8px 13px;
    border-radius: var(--radius-sm);
    border: 1px solid transparent;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    transition: 0.18s ease;
    line-height: 1.2;
}
.btn-primary { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); }
.btn-blue { background: var(--color-blue); border-color: var(--color-blue); color: #fff; }
.btn-blue:hover { background: var(--color-blue-hover); border-color: var(--color-blue-hover); }
.btn-light, .btn-secondary { background: #e5e7eb; color: var(--color-text); border-color: #e5e7eb; }
.btn-light:hover, .btn-secondary:hover { background: #d1d5db; border-color: #d1d5db; }
.btn-outline { background: #fff; color: var(--color-text); border-color: var(--color-border-strong); }
.btn-outline:hover { background: var(--color-surface-soft); }
.btn-danger { background: #dc2626; border-color: #dc2626; color: #fff; }
.btn-danger:hover { background: #b91c1c; border-color: #b91c1c; }
.btn-success { background: #16a34a; border-color: #16a34a; color: #fff; }
.btn-success:hover { background: #15803d; border-color: #15803d; }
.btn-sm { min-height: 30px; padding: 5px 9px; font-size: 12px; }

.badge, .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}
.badge { padding: 4px 9px; }
.mini-badge { padding: 6px 10px; }
.badge-success, .badge-green, .mini-badge.success { background: var(--color-green-bg); color: var(--color-green-text); }
.badge-warning, .badge-yellow, .mini-badge.warning { background: var(--color-yellow-bg); color: var(--color-yellow-text); }
.badge-danger, .badge-red, .mini-badge.danger { background: var(--color-red-bg); color: var(--color-red-text); }
.badge-neutral, .badge-gray, .mini-badge.neutral { background: var(--color-gray-bg); color: var(--color-gray-text); }
.badge-primary, .mini-badge.primary { background: var(--color-primary-soft); color: var(--color-primary); }
.badge-aperta, .badge-open { background: var(--color-red-bg); color: var(--color-red-text); }
.badge-in_lavorazione, .badge-working { background: var(--color-yellow-bg); color: var(--color-yellow-text); }
.badge-chiusa, .badge-closed { background: var(--color-green-bg); color: var(--color-green-text); }

.flash-stack { display: grid; gap: 10px; margin-bottom: 18px; }
.flash, .alert { padding: 12px 14px; border-radius: var(--radius-md); border: 1px solid transparent; font-weight: 700; }
.flash-success, .alert-success { background: var(--color-green-bg); color: var(--color-green-text); border-color: #bbf7d0; }
.flash-error, .alert-error, .alert-danger { background: var(--color-red-bg); color: var(--color-red-text); border-color: #fecaca; }
.flash-warning, .alert-warning { background: var(--color-yellow-bg); color: var(--color-yellow-text); border-color: #fde68a; }
.flash-info, .alert-info { background: #dbeafe; color: #1e40af; border-color: #bfdbfe; }

.empty-state { padding: 18px; border: 1px dashed var(--color-border-strong); border-radius: 12px; background: #fafafa; color: var(--color-muted); }
.small-muted, .text-muted { color: var(--color-muted); }
.text-small { font-size: 12px; }
.text-right { text-align: right; }
.text-center { text-align: center; }
.nowrap { white-space: nowrap; }
.hidden { display: none !important; }
.pre-line { white-space: pre-line; }
.mt-0 { margin-top: 0; }
.mt-2 { margin-top: 14px; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 14px; }
.mb-3 { margin-bottom: 20px; }
.row-disabled { opacity: 0.6; }
.cliente-bloccato { background-color: #fef2f2 !important; }

/* ======================================================
   LOGIN
====================================================== */
.login-body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: radial-gradient(circle at top left, rgba(122, 31, 61, 0.06), transparent 32%), radial-gradient(circle at bottom right, rgba(17, 24, 39, 0.06), transparent 30%), var(--color-bg);
}
.login-header { background: var(--header-bg); border-bottom: 1px solid var(--header-border); box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18); }
.login-header-shell { max-width: 1450px; margin: 0 auto; padding: 8px 18px; }
.login-header-row { min-height: 56px; display: flex; align-items: center; }
.login-brand { display: inline-flex; align-items: center; gap: 12px; color: var(--header-text); text-decoration: none; }
.login-brand-logo { width: 42px; height: 42px; border-radius: 12px; background: var(--color-primary); display: inline-flex; align-items: center; justify-content: center; overflow: hidden; color: #fff; font-size: 20px; box-shadow: 0 6px 18px rgba(122, 31, 61, 0.28); }
.login-brand-logo img { width: 30px; height: 30px; object-fit: contain; }
.login-brand-text { display: flex; flex-direction: column; gap: 2px; }
.login-brand-title { font-size: 16px; font-weight: 800; color: var(--header-text); line-height: 1.1; }
.login-brand-subtitle { font-size: 11px; color: var(--header-text-soft); line-height: 1.1; }
.login-main { flex: 1; display: flex; align-items: center; justify-content: center; padding: 34px 18px; }
.login-shell { width: 100%; max-width: 1180px; }
.login-card { display: grid; grid-template-columns: 1fr 0.95fr; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 24px; overflow: hidden; box-shadow: 0 18px 45px rgba(17, 24, 39, 0.14); }
.login-panel { min-height: 610px; }
.login-panel-info { padding: 42px; border-right: 1px solid var(--color-border); background: linear-gradient(135deg, #fff 0%, #f8fafc 100%); display: flex; align-items: center; justify-content: center; }
.login-info-box { width: 100%; max-width: 440px; min-height: 430px; background: #fbfcfe; border: 2px solid #d8dee8; border-radius: 24px; display: flex; flex-direction: column; justify-content: center; text-align: center; padding: 32px; }
.login-info-icon { width: 86px; height: 86px; border-radius: 22px; margin: 0 auto 22px; display: inline-flex; align-items: center; justify-content: center; background: var(--color-primary-soft); color: var(--color-primary); font-size: 42px; }
.login-info-box h1 { margin: 0 0 12px; font-size: 28px; line-height: 1.15; color: var(--color-text); }
.login-info-box p { margin: 0; color: var(--color-muted); font-size: 15px; }
.login-feature-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 26px; }
.login-feature { display: flex; flex-direction: column; gap: 6px; padding: 12px; background: #fff; border: 1px solid var(--color-border); border-radius: 14px; font-size: 13px; }
.login-feature span { font-size: 24px; }
.login-panel-form { display: flex; align-items: center; justify-content: center; padding: 42px; }
.login-form-wrap { width: 100%; max-width: 390px; }
.login-form-head { margin-bottom: 22px; }
.login-form-head h2 { margin: 0 0 6px; font-size: 26px; color: var(--color-text); }
.login-form-head p { margin: 0; color: var(--color-muted); }
.login-form { display: grid; gap: 16px; margin-top: 18px; }
.login-submit { width: 100%; margin-top: 4px; }
.login-links { margin-top: 18px; text-align: center; }
.login-links a { color: var(--color-primary); font-weight: 700; text-decoration: none; }
.login-links a:hover { text-decoration: underline; }
.login-footer { padding: 18px; color: var(--color-muted); font-size: 13px; display: flex; justify-content: center; gap: 8px; }

/* ======================================================
   DASHBOARD
====================================================== */
.dashboard-page { display: flex; flex-direction: column; gap: 18px; }
.dashboard-page .page-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; flex-wrap: wrap; margin-bottom: 0; }
.dashboard-page .page-head h1 { margin: 0 0 4px; font-size: 34px; font-weight: 800; color: #111827; }
.dashboard-page .page-subtitle { margin: 0; color: #666; font-size: 15px; }
.dashboard-page .days-filter-box { display: flex; flex-direction: column; gap: 6px; min-width: 220px; max-width: 340px; margin-left: auto; }
.dashboard-page .days-filter-box label { font-size: 13px; font-weight: 700; color: #444; }
.dashboard-page .days-filter-row { display: flex; gap: 8px; align-items: center; }
.dashboard-page .days-filter-row input { width: 100%; min-width: 110px; padding: 10px 12px; border: 1px solid #ccc; border-radius: 8px; font-size: 14px; box-sizing: border-box; }
.stats-grid, .dashboard-page .stats-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.summary-card, .dashboard-page .summary-card { border: 1px solid var(--color-border); background: var(--color-surface); border-radius: var(--radius-lg); padding: 18px; text-decoration: none; color: var(--color-text); box-shadow: var(--shadow-sm); transition: 0.2s ease; display: flex; flex-direction: column; gap: 8px; }
.summary-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.summary-label { font-size: 13px; color: var(--color-muted); font-weight: 800; text-transform: uppercase; letter-spacing: 0.03em; }
.summary-number { font-size: 32px; font-weight: 900; line-height: 1; }
.charts-grid, .dashboard-page .charts-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.dashboard-page .box-admin { background: #fff; border: 1px solid #ddd; border-radius: 14px; padding: 18px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
.chart-card { min-height: 390px; }
.chart-card canvas { width: 100% !important; height: 285px !important; max-height: 285px !important; }
.card-head, .dashboard-page .card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.card-head h3, .dashboard-page .card-head h3 { margin: 0; font-size: 18px; font-weight: 800; }
.lists-grid { display: grid; gap: 18px; }
.lists-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.lists-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.list-card { min-width: 0; }
.mini-list, .calls-list { display: flex; flex-direction: column; gap: 10px; }
.mini-list-item, .call-list-item { display: flex; gap: 12px; border: 1px solid var(--color-border); border-radius: 12px; padding: 12px; text-decoration: none; color: var(--color-text); transition: 0.2s ease; }
.mini-list-item { justify-content: space-between; align-items: flex-start; background: #fafafa; }
.call-list-item { flex-direction: column; }
.mini-list-item:hover, .call-list-item:hover { background: #f8fafc; border-color: var(--color-border-strong); }
.call-item-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.call-item-badges { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.call-item-meta { font-size: 12px; color: var(--color-muted); display: flex; flex-wrap: wrap; gap: 4px; }
.call-item-desc, .mini-problem { font-size: 13px; color: var(--color-gray-text); line-height: 1.4; }
.row-recente { background: #fff8db; }
.row-vecchia { background: #fdeaea; }
.mini-list-main { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.mini-list-side { flex-shrink: 0; }
.dashboard-page .btn-outline, .dashboard-page .btn-primary { display: inline-block; padding: 9px 12px; border-radius: 8px; text-decoration: none; cursor: pointer; transition: 0.2s; font-size: 14px; box-sizing: border-box; }
.dashboard-page .btn-outline { border: 1px solid #888; color: #222; background: #fff; }
.dashboard-page .btn-outline:hover { background: #f5f5f5; }
.dashboard-page .btn-primary { border: 1px solid #222; color: #fff; background: #222; }
.dashboard-page .btn-primary:hover { background: #111; border-color: #111; }
.dashboard-page .btn-sm { padding: 6px 10px; font-size: 13px; }

/* ======================================================
   CONFIG / ANAGRAFICA
====================================================== */
.config-code { margin: 12px 0 0; padding: 12px; background: #111827; color: #e5e7eb; border-radius: 10px; overflow-x: auto; font-size: 13px; line-height: 1.5; }
.checkbox-line { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; }
.checkbox-line input[type="checkbox"] { width: auto; }
.section-title-small { margin: 6px 0 2px; font-size: 16px; font-weight: 800; color: var(--color-text); }
hr { width: 100%; border: 0; border-top: 1px solid var(--color-border); margin: 12px 0; }
.anagrafica-filter-row { align-items: end; }
.filter-grow { flex: 1 1 280px; }
.pagination { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 16px; }
.pagination a { display: inline-flex; align-items: center; justify-content: center; min-width: 34px; height: 34px; padding: 0 10px; border-radius: 8px; border: 1px solid var(--color-border-strong); background: #fff; color: var(--color-text); text-decoration: none; font-weight: 700; }
.pagination a:hover { background: var(--color-surface-soft); }
.pagination a.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.detail-list { display: grid; gap: 12px; margin-top: 14px; }
.detail-list > div { display: flex; justify-content: space-between; gap: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--color-border); }
.detail-list > div:last-child { border-bottom: 0; padding-bottom: 0; }
.detail-list span { color: var(--color-muted); }
.detail-list strong { text-align: right; }
.summary-mini-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 14px; }
.summary-mini { padding: 12px; border-radius: 12px; background: var(--color-surface-soft); border: 1px solid var(--color-border); display: flex; flex-direction: column; gap: 4px; }
.summary-mini span { color: var(--color-muted); font-size: 12px; font-weight: 700; }
.summary-mini strong { font-size: 18px; }

/* ======================================================
   CLIENTE DETTAGLIO
====================================================== */
.cliente-page { display: flex; flex-direction: column; gap: 18px; }
.cliente-page .page-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; flex-wrap: wrap; }
.cliente-page .page-head h1 { margin: 0 0 4px; }
.cliente-page .page-subtitle { margin: 0; color: #666; font-size: 15px; }
.cliente-page .top-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.cliente-page .top-layout { display: grid; grid-template-columns: 1.1fr 1fr; gap: 18px; }
.cliente-page .msg-ok, .cliente-page .msg-err { padding: 12px 14px; border-radius: 10px; font-weight: 600; }
.cliente-page .msg-ok { background: #e8f7ee; color: #1f7a3f; border: 1px solid #bfe5cb; }
.cliente-page .msg-err { background: #fdecea; color: #b42318; border: 1px solid #f3c4c1; }
.cliente-page .box { background: #fff; border: 1px solid #ddd; border-radius: 14px; padding: 18px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
.cliente-page .box-inner { margin-top: 18px; background: #fafafa; }
.cliente-page .section-title-row, .cliente-page .panel-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.cliente-page .section-title-row h2, .cliente-page .panel-head h2 { margin: 0; font-size: 20px; }
.cliente-page .panel-head-actions, .cliente-page .toolbar-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cliente-page .info-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.cliente-page .info-item { background: #fafafa; border: 1px solid #ececec; border-radius: 10px; padding: 12px; display: flex; flex-direction: column; gap: 5px; }
.cliente-page .info-item-full { grid-column: 1 / -1; }
.cliente-page .info-label { font-size: 12px; text-transform: uppercase; letter-spacing: 0.03em; color: #666; font-weight: 700; }
.cliente-page .info-value { font-size: 15px; color: #222; word-break: break-word; }
.cliente-page .editable-value { cursor: pointer; display: inline-block; border-bottom: 1px dashed transparent; transition: 0.2s; }
.cliente-page .editable-value:hover { border-bottom-color: #666; color: #000; }
.cliente-page .inline-edit input { width: 100%; padding: 9px 10px; border: 1px solid #bbb; border-radius: 8px; font-size: 14px; box-sizing: border-box; }
.cliente-page .inline-edit-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 16px; padding-top: 16px; border-top: 1px solid #ececec; flex-wrap: wrap; }
.cliente-page .status-badge, .cliente-page .panel-badge { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; font-size: 12px; font-weight: 700; padding: 6px 10px; white-space: nowrap; }
.cliente-page .status-active { background: #e8f7ee; color: #1f7a3f; }
.cliente-page .status-inactive { background: #fdecea; color: #b42318; }
.cliente-page .panel-badge { background: #f3f4f6; color: #444; }
.cliente-page .admin-badge { background: #eef2ff; color: #3743a5; }
.cliente-page .map-box { display: flex; flex-direction: column; }
.cliente-page .map-frame-wrap { min-height: 320px; border-radius: 12px; overflow: hidden; border: 1px solid #ddd; background: #f8f8f8; }
.cliente-page .map-address { margin: 10px 0 0; color: #555; font-size: 14px; }
.cliente-page .summary-cards { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.cliente-page .summary-cards-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.cliente-page .summary-card { background: #fff; border: 1px solid #ddd; border-radius: 14px; padding: 16px; text-align: center; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); display: block; }
.cliente-page .summary-card:hover { transform: none; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
.cliente-page .summary-number { display: block; font-size: 28px; font-weight: 800; color: #222; line-height: 1.1; }
.cliente-page .summary-label { display: block; margin-top: 6px; color: #666; font-size: 14px; text-transform: none; letter-spacing: normal; }
.cliente-page .tabs-box { padding-top: 12px; }
.cliente-page .tabs-nav { display: flex; gap: 8px; flex-wrap: wrap; border-bottom: 1px solid #e6e6e6; padding-bottom: 12px; margin-bottom: 16px; }
.cliente-page .tab-btn { border: 1px solid #d5d5d5; background: #f8f8f8; color: #333; border-radius: 10px; padding: 10px 14px; cursor: pointer; font-weight: 600; transition: 0.2s; }
.cliente-page .tab-btn:hover { background: #f1f1f1; }
.cliente-page .tab-btn.active { background: #222; color: #fff; border-color: #222; }
.cliente-page .tab-panel { display: none; }
.cliente-page .tab-panel.active { display: block; }
.cliente-page .cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 14px; }
.cliente-page .products-grid { margin-top: 12px; }
.cliente-page .entity-card { display: block; text-decoration: none; color: inherit; background: #fff; border: 1px solid #ddd; border-radius: 12px; padding: 14px; transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s; }
.cliente-page .entity-card:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08); border-color: #cfcfcf; }
.cliente-page .entity-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.cliente-page .entity-card h3 { margin: 0; font-size: 16px; line-height: 1.3; }
.cliente-page .card-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.cliente-page .entity-list { display: flex; flex-direction: column; gap: 7px; font-size: 14px; color: #333; }
.cliente-page .product-card-inactive, .cliente-page .sede-card-inactive { background: #fff7f7; border-color: #f1c8c8; }
.cliente-page .product-links-box { margin-top: 8px; padding-top: 8px; border-top: 1px dashed #ddd; }
.cliente-page .product-public-link { margin-top: 4px; word-break: break-all; }
.cliente-page .product-qr-actions { margin-top: 8px; }
.cliente-page .search-input { width: 100%; padding: 10px 12px; border: 1px solid #ccc; border-radius: 10px; outline: none; font-size: 14px; }
.cliente-page .search-input:focus { border-color: #999; }
.cliente-page .toner-block { margin-top: 14px; padding-top: 12px; border-top: 1px solid #ececec; }
.cliente-page .toner-title-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.cliente-page .small-muted, .cliente-page .field-help { color: #777; font-size: 12px; }
.cliente-page .toner-list { display: flex; flex-direction: column; gap: 8px; }
.cliente-page .toner-row { display: grid; grid-template-columns: 72px 1fr 48px; align-items: center; gap: 8px; }
.cliente-page .toner-label, .cliente-page .toner-value { font-size: 13px; color: #444; }
.cliente-page .toner-value { text-align: right; }
.cliente-page .toner-bar { height: 10px; background: #ececec; border-radius: 999px; overflow: hidden; }
.cliente-page .toner-fill { height: 100%; border-radius: 999px; }
.cliente-page .toner-black { background: #1f1f1f; }
.cliente-page .toner-cyan { background: #00b7d6; }
.cliente-page .toner-magenta { background: #d6418d; }
.cliente-page .toner-yellow { background: #f1c40f; }
.cliente-page .table-wrap { overflow-x: auto; }
.cliente-page .table { width: 100%; border-collapse: collapse; margin-top: 4px; }
.cliente-page .table th, .cliente-page .table td { border: 1px solid #ddd; padding: 9px 10px; text-align: left; vertical-align: top; font-size: 14px; }
.cliente-page .table th { background: #f8f8f8; white-space: nowrap; }
.cliente-page .table tr:hover td { background: #fafcff; }
.cliente-page .table input, .cliente-page .table select { width: 100%; padding: 8px 10px; border: 1px solid #ccc; border-radius: 8px; font-size: 14px; box-sizing: border-box; }
.cliente-page .desc-col { min-width: 240px; }
.cliente-page .placeholder-box, .cliente-page .empty-state { padding: 18px; border: 1px dashed #ccc; border-radius: 12px; background: #fafafa; color: #555; }
.cliente-page .btn-outline, .clienti-page .btn-outline { display: inline-block; padding: 9px 12px; border: 1px solid #888; border-radius: 8px; text-decoration: none; color: #222; background: #fff; transition: 0.2s; cursor: pointer; }
.cliente-page .btn-outline:hover, .clienti-page .btn-outline:hover { background: #f5f5f5; }
.cliente-page .btn-primary, .clienti-page .btn-primary { display: inline-block; padding: 9px 14px; border: 1px solid #222; border-radius: 8px; text-decoration: none; color: #fff; background: #222; transition: 0.2s; cursor: pointer; }
.cliente-page .btn-primary:hover, .clienti-page .btn-primary:hover { background: #111; border-color: #111; }
.cliente-page .btn-sm { padding: 6px 10px; font-size: 13px; min-height: auto; }
.cliente-page .form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.cliente-page .form-row { display: flex; flex-direction: column; gap: 6px; }
.cliente-page .form-row-full { grid-column: 1 / -1; }
.cliente-page .form-row label { font-size: 13px; font-weight: 700; color: #444; }
.cliente-page .form-row input, .cliente-page .form-row select, .cliente-page .form-row textarea { width: 100%; padding: 10px 12px; border: 1px solid #ccc; border-radius: 8px; font-size: 14px; font-family: inherit; box-sizing: border-box; }
.cliente-page .form-row textarea { resize: vertical; min-height: 90px; }
.cliente-page .form-row input:focus, .cliente-page .form-row select:focus, .cliente-page .form-row textarea:focus, .cliente-page .inline-edit input:focus { outline: none; border-color: #888; box-shadow: none; }
.cliente-page .inline-combo { display: flex; gap: 8px; align-items: center; }
.cliente-page .inline-combo select { flex: 1; }
.cliente-page .quick-contact-box { border: 1px dashed #cfcfcf; background: #fafafa; border-radius: 10px; padding: 14px; }
.cliente-page .quick-contact-box h4 { margin: 0 0 12px; font-size: 15px; }

/* ======================================================
   MODALI CLIENTE
====================================================== */
.cliente-page .modal-overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.45); display: none; align-items: flex-start; justify-content: center; padding: 20px; z-index: 9999; overflow-y: auto; box-sizing: border-box; }
.cliente-page .modal-overlay.is-open { display: flex; }
.cliente-page .modal-box { width: 100%; max-width: 640px; max-height: calc(100vh - 40px); background: #fff; border-radius: 14px; box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2); overflow: hidden; display: flex; flex-direction: column; margin: auto 0; }
.cliente-page .modal-box-lg { max-width: 760px; }
.cliente-page .modal-box-xl { max-width: 1100px; }
.cliente-page .modal-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 18px 20px; border-bottom: 1px solid #e8e8e8; flex: 0 0 auto; }
.cliente-page .modal-header h3 { margin: 0; font-size: 20px; }
.cliente-page .modal-close { border: 0; background: transparent; font-size: 30px; line-height: 1; cursor: pointer; color: #555; }
.cliente-page .modal-close:hover { color: #111; }
.cliente-page .modal-form { padding: 20px; overflow-y: auto; flex: 1 1 auto; }
.cliente-page .modal-actions { display: flex; justify-content: flex-end; gap: 10px; flex-wrap: wrap; margin-top: 18px; padding-top: 16px; border-top: 1px solid #ececec; }
body.modal-open { overflow: hidden; }

/* ======================================================
   CLIENTI - ELENCO
====================================================== */
.clienti-page { display: flex; flex-direction: column; gap: 18px; }
.clienti-page .page-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; flex-wrap: wrap; }
.clienti-page .page-head h1 { margin: 0 0 4px; }
.clienti-page .page-subtitle { margin: 0; color: #666; font-size: 15px; }
.clienti-page .top-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.clienti-page .box { background: #fff; border: 1px solid #ddd; border-radius: 14px; padding: 18px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
.clienti-page .filter-toolbar { display: grid; grid-template-columns: minmax(260px, 1fr) 220px 220px; gap: 14px; align-items: end; }
.clienti-page .filter-item { display: flex; flex-direction: column; gap: 6px; }
.clienti-page .filter-item-grow { min-width: 0; }
.clienti-page .filter-item label { font-size: 13px; font-weight: 700; color: #444; }
.clienti-page .filter-item input, .clienti-page .filter-item select { width: 100%; padding: 10px 12px; border: 1px solid #ccc; border-radius: 8px; font-size: 14px; box-sizing: border-box; }
.clienti-page .filter-item input:focus, .clienti-page .filter-item select:focus { outline: none; border-color: #888; box-shadow: none; }
.clienti-page .table-wrap { overflow-x: auto; }
.clienti-page .table { width: 100%; border-collapse: collapse; }
.clienti-page .table th, .clienti-page .table td { border: 1px solid #ddd; padding: 10px 12px; text-align: left; vertical-align: middle; font-size: 14px; }
.clienti-page .table th { background: #f8f8f8; white-space: nowrap; cursor: pointer; user-select: none; }
.clienti-page .table th:hover { background: #f1f1f1; }
.clienti-page .clickable-row:hover td { background: #fafcff; }
.clienti-page .row-blocked td { background: #fff7f7; }
.clienti-page .row-blocked:hover td { background: #fdeaea; }
.clienti-page .pagination-bar { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }

/* ======================================================
   FIX DEFINITIVO MODALI CLIENTE - NUOVO INTERVENTO / ORDINE
   Deve stare in fondo al file app.css
====================================================== */
.cliente-page #chiamataModal .modal-box,
.cliente-page #ordineModal .modal-box { width: min(1180px, calc(100vw - 64px)); max-width: 1180px; max-height: calc(100vh - 64px); }
.cliente-page #chiamataModal .modal-form,
.cliente-page #ordineModal .modal-form { padding: 24px 28px; overflow-y: auto; }
.cliente-page #chiamataModal .modal-form > .form-grid,
.cliente-page #ordineModal .modal-form > .form-grid { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 18px 22px !important; align-items: start !important; }
.cliente-page #chiamataModal .form-row,
.cliente-page #ordineModal .form-row { display: flex !important; flex-direction: column !important; gap: 7px !important; min-width: 0 !important; width: 100% !important; }
.cliente-page #chiamataModal .form-row-full,
.cliente-page #ordineModal .form-row-full,
.cliente-page #chiamataQuickContattoBox,
.cliente-page #ordineQuickContattoBox,
.cliente-page #ordineModal .box-inner { grid-column: 1 / -1 !important; width: 100% !important; }
.cliente-page #chiamataModal label,
.cliente-page #ordineModal label { display: block !important; width: 100% !important; text-align: left !important; margin: 0 !important; padding: 0 !important; font-size: 13px !important; font-weight: 800 !important; color: #374151 !important; line-height: 1.25 !important; }
.cliente-page #chiamataModal input,
.cliente-page #chiamataModal select,
.cliente-page #chiamataModal textarea,
.cliente-page #ordineModal input,
.cliente-page #ordineModal select,
.cliente-page #ordineModal textarea { width: 100% !important; min-height: 42px !important; padding: 10px 12px !important; border: 1px solid #d1d5db !important; border-radius: 10px !important; background: #fff !important; color: #111827 !important; font-size: 14px !important; font-family: inherit !important; box-sizing: border-box !important; }
.cliente-page #chiamataModal .inline-combo,
.cliente-page #ordineModal .inline-combo { display: grid !important; grid-template-columns: minmax(0, 1fr) auto !important; gap: 10px !important; align-items: stretch !important; width: 100% !important; }
.cliente-page #chiamataModal .inline-combo select,
.cliente-page #ordineModal .inline-combo select { width: 100% !important; min-width: 0 !important; }
.cliente-page #chiamataModal .inline-combo button,
.cliente-page #ordineModal .inline-combo button { white-space: nowrap !important; min-height: 42px !important; }
.cliente-page #form_chiamata_descrizione,
.cliente-page #form_ordine_note { min-height: 130px !important; resize: vertical !important; }
.cliente-page #form_chiamata_prova_stampa { padding: 8px 10px !important; background: #fff !important; }
.cliente-page #chiamataQuickContattoBox[hidden],
.cliente-page #ordineQuickContattoBox[hidden] { display: none !important; }
.cliente-page #chiamataQuickContattoBox,
.cliente-page #ordineQuickContattoBox { margin-top: 0 !important; }
.cliente-page #chiamataQuickContattoBox .quick-contact-box,
.cliente-page #ordineQuickContattoBox .quick-contact-box { width: 100% !important; padding: 18px !important; border-radius: 14px !important; border: 1px dashed #d1d5db !important; background: #fafafa !important; }
.cliente-page #chiamataQuickContattoBox .quick-contact-box h4,
.cliente-page #ordineQuickContattoBox .quick-contact-box h4 { margin: 0 0 16px !important; font-size: 17px !important; font-weight: 800 !important; color: #111827 !important; }
.cliente-page #chiamataQuickContattoBox .form-grid,
.cliente-page #ordineQuickContattoBox .form-grid { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 16px 18px !important; }
.cliente-page #ordineModal .box-inner { margin-top: 4px !important; padding: 18px !important; border: 1px solid #e5e7eb !important; border-radius: 14px !important; background: #fafafa !important; }
.cliente-page #ordineModal .box-inner .section-title-row { display: flex !important; justify-content: space-between !important; align-items: center !important; gap: 12px !important; margin-bottom: 14px !important; }
.cliente-page #ordineModal .box-inner h2 { margin: 0 !important; font-size: 18px !important; font-weight: 800 !important; }
.cliente-page #ordineModal .toolbar-actions { display: flex !important; gap: 8px !important; flex-wrap: wrap !important; }
.cliente-page #ordineModal .table-wrap { width: 100% !important; overflow-x: auto !important; }
.cliente-page #ordineModal table { width: 100% !important; border-collapse: collapse !important; }
.cliente-page #ordineModal table th,
.cliente-page #ordineModal table td { padding: 9px 10px !important; border: 1px solid #e5e7eb !important; text-align: left !important; vertical-align: middle !important; }
.cliente-page #chiamataModal .modal-actions,
.cliente-page #ordineModal .modal-actions { position: sticky !important; bottom: 0 !important; z-index: 5 !important; display: flex !important; justify-content: flex-end !important; gap: 10px !important; margin: 22px -28px -24px !important; padding: 16px 28px !important; background: #fff !important; border-top: 1px solid #e5e7eb !important; }
.cliente-page #chiamataModal .modal-actions button,
.cliente-page #ordineModal .modal-actions button { min-width: 130px !important; min-height: 42px !important; }

/* ======================================================
   RESPONSIVE
====================================================== */
@media (max-width: 1400px) {
    .lists-grid-3, .lists-grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 1200px) {
    .charts-grid, .dashboard-page .charts-grid { grid-template-columns: 1fr; }
    .stats-grid, .dashboard-page .stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .chart-card { min-height: 360px; }
    .cliente-page .summary-cards-5 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 1100px) {
    .header-shell { padding: 8px 14px; }
    .header-row { min-height: auto; flex-wrap: wrap; }
    .nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
    .main-nav { display: none; width: 100%; margin-left: 0; flex-direction: column; align-items: stretch; gap: 6px; padding-top: 10px; }
    .main-nav.is-open { display: flex; }
    .nav-link, .nav-dropdown-toggle, .dropdown-link { width: 100%; justify-content: flex-start; }
    .nav-dropdown { width: 100%; }
    .nav-dropdown-menu { position: static; min-width: 0; margin-top: 6px; box-shadow: none; }
    .nav-user { border-left: none; border-top: 1px solid #374151; padding-top: 10px; }
    .cliente-page .top-layout { grid-template-columns: 1fr; }
    .cliente-page .summary-cards, .cliente-page .summary-cards-5 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
    .page-content { padding: 16px; }
    .grid-2, .grid-3, .grid-4, .form-grid-2, .form-grid-3 { grid-template-columns: 1fr; }
    .page-title { font-size: 22px; }
    .login-card { grid-template-columns: 1fr; }
    .login-panel { min-height: auto; }
    .login-panel-info { border-right: none; border-bottom: 1px solid var(--color-border); padding: 26px; }
    .login-info-box { max-width: none; min-height: auto; }
    .login-panel-form { padding: 26px; }
    .stats-grid, .dashboard-page .stats-grid { grid-template-columns: 1fr; }
    .dashboard-page .page-head { flex-direction: column; align-items: stretch; }
    .dashboard-page .days-filter-box { max-width: none; margin-left: 0; }
    .days-filter-row, .dashboard-page .days-filter-row { flex-direction: column; }
    .call-item-top { flex-direction: column; align-items: stretch; }
    .call-item-badges { justify-content: flex-start; }
    .detail-list > div { flex-direction: column; gap: 4px; }
    .detail-list strong { text-align: left; }
    .summary-mini-grid { grid-template-columns: 1fr; }
    .clienti-page .filter-toolbar { grid-template-columns: 1fr; }
    .clienti-page .page-head { flex-direction: column; align-items: stretch; }
    .cliente-page #chiamataModal .modal-box, .cliente-page #ordineModal .modal-box { width: calc(100vw - 24px) !important; max-width: calc(100vw - 24px) !important; max-height: calc(100vh - 24px) !important; }
    .cliente-page #chiamataModal .modal-form > .form-grid, .cliente-page #ordineModal .modal-form > .form-grid, .cliente-page #chiamataQuickContattoBox .form-grid, .cliente-page #ordineQuickContattoBox .form-grid { grid-template-columns: 1fr !important; }
    .cliente-page #chiamataModal .inline-combo, .cliente-page #ordineModal .inline-combo { grid-template-columns: 1fr !important; }
    .cliente-page #chiamataModal .inline-combo button, .cliente-page #ordineModal .inline-combo button { width: 100% !important; }
    .cliente-page #chiamataModal .modal-actions, .cliente-page #ordineModal .modal-actions { flex-direction: column-reverse !important; }
    .cliente-page #chiamataModal .modal-actions button, .cliente-page #ordineModal .modal-actions button { width: 100% !important; }
}
@media (max-width: 700px) {
    .cliente-page .info-grid, .cliente-page .form-grid { grid-template-columns: 1fr; }
    .cliente-page .summary-cards, .cliente-page .summary-cards-5, .cliente-page .cards-grid { grid-template-columns: 1fr; }
    .cliente-page .page-head { flex-direction: column; align-items: stretch; }
    .cliente-page .toner-row { grid-template-columns: 60px 1fr 42px; }
    .cliente-page .modal-overlay { padding: 10px; }
    .cliente-page .modal-box, .cliente-page .modal-box-lg, .cliente-page .modal-box-xl { max-width: 100%; max-height: calc(100vh - 20px); }
    .cliente-page .inline-combo { flex-direction: column; align-items: stretch; }
}
@media (max-width: 560px) {
    .brand-title { font-size: 15px; }
    .brand-subtitle { font-size: 10px; }
    .brand-logo { width: 34px; height: 34px; font-size: 17px; }
    .header-shell { padding: 8px 10px; }
    .page-content { padding: 12px; }
    .box, .card { padding: 14px; border-radius: 12px; }
    .btn { width: 100%; }
    .action-buttons, .actions { width: 100%; }
    .login-feature-list { grid-template-columns: 1fr; }
    .login-info-box { padding: 24px; }
    .login-info-box h1 { font-size: 22px; }
    .login-brand-subtitle { display: none; }
}

/* ======================================================
   PRODOTTI - ELENCO E MODIFICA RAPIDA
====================================================== */

.prodotti-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.prodotti-page .prodotti-page-header {
    margin-bottom: 0;
}

.prodotti-page .filter-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    width: 100%;
    margin-bottom: 0;
}

.prodotti-page .filter-bar .form-control {
    min-width: 0;
    width: auto;
}

.prodotti-page .filter-cliente {
    flex: 1 1 240px;
    max-width: 320px;
}

.prodotti-page .filter-sede {
    flex: 1 1 200px;
    max-width: 280px;
}

.prodotti-page .filter-stato {
    flex: 0 1 180px;
    max-width: 190px;
}

.prodotti-page .filter-seriale {
    flex: 0 1 160px;
    max-width: 180px;
}

.prodotti-page .filter-bar .btn {
    flex: 0 0 auto;
    white-space: nowrap;
}

.prodotti-page .products-table tbody tr {
    transition: background-color .15s ease, filter .15s ease;
}

.prodotti-page .clickable-row {
    cursor: pointer;
}

.prodotti-page .clickable-row:hover {
    filter: brightness(0.97);
}

.prodotti-page .row-non-attiva {
    background: #fdecea;
    color: #c0392b;
}

.prodotti-page .row-magazzino {
    background: #fff3cd;
    color: #856404;
}

.prodotti-page .badge-stato {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.prodotti-page .badge-attivo {
    background: #e8f5e9;
    color: #2e7d32;
}

.prodotti-page .badge-dismesso {
    background: #fdecea;
    color: #c0392b;
}

.prodotti-page .badge-in_manutenzione {
    background: #fff3cd;
    color: #856404;
}

/* Modal modifica prodotto */
.custom-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
}

.custom-modal.show {
    display: block;
}

.custom-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .45);
}

.custom-modal-box {
    position: relative;
    background: #fff;
    width: min(620px, calc(100% - 30px));
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    margin: 20px auto;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .25);
    padding: 20px;
}

.custom-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 15px;
}

.custom-modal-header h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 800;
}

.custom-modal .modal-close {
    border: 0;
    background: transparent;
    font-size: 30px;
    line-height: 1;
    cursor: pointer;
    color: #555;
}

.custom-modal .modal-close:hover {
    color: #111;
}

.custom-modal .modal-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.custom-modal .modal-form .form-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.custom-modal .modal-form input[readonly] {
    background: #f7f7f7;
    cursor: not-allowed;
}

.custom-modal .modal-actions {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
}

.custom-modal .modal-alert {
    padding: 10px 12px;
    border-radius: 8px;
    margin-bottom: 15px;
    font-weight: 700;
}

.custom-modal .modal-alert.success {
    background: #e8f5e9;
    color: #2e7d32;
}

.custom-modal .modal-alert.error {
    background: #fdecea;
    color: #c0392b;
}

@media (max-width: 900px) {
    .prodotti-page .filter-cliente,
    .prodotti-page .filter-sede,
    .prodotti-page .filter-stato,
    .prodotti-page .filter-seriale {
        flex: 1 1 calc(50% - 10px);
        max-width: none;
        width: auto;
    }

    .prodotti-page .filter-bar .btn {
        flex: 1 1 auto;
    }
}

@media (max-width: 700px) {
    .custom-modal .modal-form {
        grid-template-columns: 1fr;
    }

    .custom-modal .modal-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .custom-modal .modal-actions .btn {
        width: 100%;
    }

    .custom-modal-box {
        margin: 15px auto;
        width: calc(100% - 24px);
        padding: 16px;
    }
}

@media (max-width: 600px) {
    .prodotti-page .filter-cliente,
    .prodotti-page .filter-sede,
    .prodotti-page .filter-stato,
    .prodotti-page .filter-seriale,
    .prodotti-page .filter-bar .btn {
        flex: 1 1 100%;
        max-width: none;
        width: 100%;
    }
}

/* ======================================================
   CHIAMATE - ELENCO
====================================================== */

.chiamate-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.chiamate-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.chiamate-page .page-head h1 {
    margin: 0 0 4px;
}

.chiamate-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.chiamate-page .top-actions,
.chiamate-page .filter-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.chiamate-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.chiamate-page .stats-grid-three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.chiamate-page .stat-card,
.chiamate-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.chiamate-page .stat-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 16px;
    color: #222;
    text-decoration: none;
    transition: 0.2s;
}

.chiamate-page .stat-card:hover {
    transform: translateY(-1px);
    background: #fafafa;
}

.chiamate-page .stat-label {
    font-size: 13px;
    color: #666;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.chiamate-page .stat-value {
    font-size: 28px;
    font-weight: 800;
    color: #111;
}

.chiamate-page .box {
    padding: 18px;
}

.chiamate-page .filter-toolbar {
    display: flex;
    gap: 14px;
    align-items: end;
    flex-wrap: wrap;
    justify-content: space-between;
}

.chiamate-page .filter-block,
.chiamate-page .filter-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.chiamate-page .filter-block label,
.chiamate-page .filter-item label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.chiamate-page .filter-item {
    min-width: 260px;
}

.chiamate-page .filter-item-search {
    min-width: 320px;
    flex: 1;
    max-width: 520px;
}

.chiamate-page .filter-item input,
.chiamate-page .filter-item select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.chiamate-page .filter-item input:focus,
.chiamate-page .filter-item select:focus {
    outline: none;
    border-color: #888;
    box-shadow: none;
}

.chiamate-page .table-wrap {
    overflow-x: auto;
}

.chiamate-page .table {
    width: 100%;
    border-collapse: collapse;
}

.chiamate-page .table th,
.chiamate-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}

.chiamate-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.chiamate-page .table th.sortable {
    cursor: pointer;
    user-select: none;
}

.chiamate-page .table th.sortable:hover {
    background: #f1f1f1;
}

.chiamate-page .table th.sortable::after {
    content: " ↕";
    font-size: 12px;
    color: #999;
}

.chiamate-page .clickable-row:hover td {
    background: #eef3fb;
}

.chiamate-page .row-recente td {
    background: #fff8db;
}

.chiamate-page .row-vecchia td {
    background: #fdeaea;
}

.chiamate-page .row-chiusa td {
    background: #e9f8ee;
}

.chiamate-page .row-non-assegnata td {
    background: #eef6ff;
}

.chiamate-page .small-muted {
    color: #777;
    font-size: 12px;
}

.chiamate-page .problem-col {
    min-width: 260px;
}

.chiamate-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.chiamate-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.chiamate-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.chiamate-page .mini-badge.warning {
    background: #fff4db;
    color: #9a6700;
}

.chiamate-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #444;
}

.chiamate-page .btn-outline,
.chiamate-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    transition: 0.2s;
    cursor: pointer;
}

.chiamate-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.chiamate-page .btn-outline:hover {
    background: #f5f5f5;
}

.chiamate-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.chiamate-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.chiamate-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}

@media (max-width: 1100px) {
    .chiamate-page .stats-grid,
    .chiamate-page .stats-grid-three {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .chiamate-page .page-head,
    .chiamate-page .filter-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .chiamate-page .filter-item,
    .chiamate-page .filter-item-search {
        max-width: none;
        min-width: 0;
    }
}

@media (max-width: 600px) {
    .chiamate-page .stats-grid,
    .chiamate-page .stats-grid-three {
        grid-template-columns: 1fr;
    }
}

/* ======================================================
   ORDINI - ELENCO
====================================================== */

.ordini-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.ordini-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.ordini-page .page-head h1 {
    margin: 0 0 4px;
}

.ordini-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.ordini-page .top-actions,
.ordini-page .filter-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ordini-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.ordini-page .filter-toolbar {
    display: flex;
    gap: 14px;
    align-items: end;
    flex-wrap: wrap;
}

.ordini-page .filter-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 180px;
}

.ordini-page .filter-actions {
    min-width: auto;
}

.ordini-page .filter-item label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.ordini-page .filter-item input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.ordini-page .filter-item input:focus {
    outline: none;
    border-color: #888;
    box-shadow: none;
}

.ordini-page .table-wrap {
    overflow-x: auto;
}

.ordini-page .table {
    width: 100%;
    border-collapse: collapse;
}

.ordini-page .table th,
.ordini-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}

.ordini-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.ordini-page .clickable-row:hover td {
    background: #eef3fb;
}

.ordini-page .row-aperto td {
    background: #fff1f1;
}

.ordini-page .row-parziale td {
    background: #fff8df;
}

.ordini-page .row-evaso td {
    background: #edf9ef;
}

.ordini-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.ordini-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.ordini-page .mini-badge.warning {
    background: #fff1cc;
    color: #8a5a00;
}

.ordini-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.ordini-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #444;
}

.ordini-page .btn-outline,
.ordini-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    transition: 0.2s;
    cursor: pointer;
}

.ordini-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.ordini-page .btn-outline:hover {
    background: #f5f5f5;
}

.ordini-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.ordini-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.ordini-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}

@media (max-width: 900px) {
    .ordini-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }

    .ordini-page .filter-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .ordini-page .filter-item {
        min-width: 0;
    }
}

/* ======================================================
   CHIAMATA DETTAGLIO
====================================================== */

.chiamata-page {
display: flex;
    flex-direction: column;
    gap: 18px;
}
.chiamata-page .page-head {
display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}
.chiamata-page .page-head h1 {
margin: 0 0 4px;
}
.chiamata-page .page-subtitle {
margin: 0;
    color: #666;
    font-size: 15px;
}
.chiamata-page .top-actions {
display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.chiamata-page .box {
background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.chiamata-page .section-title-row {
display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.chiamata-page .section-title-row h2 {
margin: 0;
    font-size: 20px;
}
.chiamata-page .info-grid {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.chiamata-page .info-item {
background: #fafafa;
    border: 1px solid #ececec;
    border-radius: 10px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.chiamata-page .info-item-full {
grid-column: 1 / -1;
}
.chiamata-page .info-item-link {
padding: 0;
    overflow: hidden;
}
.chiamata-page .info-item-anchor {
display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 12px;
    text-decoration: none;
    color: inherit;
    min-height: 100%;
}
.chiamata-page .info-item-anchor:hover {
background: #f5f5f5;
}
.chiamata-page .info-item-anchor .info-label,
.chiamata-page .info-item-anchor .info-value {
color: inherit;
}
.chiamata-page .info-label {
font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .03em;
    color: #666;
    font-weight: 700;
}
.chiamata-page .info-value {
font-size: 15px;
    color: #222;
    word-break: break-word;
}
.chiamata-page .referente-meta {
margin-top: 6px;
}
.chiamata-page .snapshot-inline {
display: inline-block;
    margin-top: 6px;
}
.chiamata-page .priority-actions {
justify-content: flex-start;
}
.chiamata-page .toolbar-actions {
display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
}
.chiamata-page .cards-grid {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}
.chiamata-page .counters-grid {
margin-bottom: 18px;
}
.chiamata-page .entity-card {
background: #fff;
    border: 1px solid #ddd;
    border-radius: 12px;
    padding: 14px;
}
.chiamata-page .entity-card-head {
display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.chiamata-page .entity-card h3 {
margin: 0;
    font-size: 16px;
    line-height: 1.3;
}
.chiamata-page .entity-list {
display: flex;
    flex-direction: column;
    gap: 7px;
    font-size: 14px;
    color: #333;
}
.chiamata-page .list-cards {
display: flex;
    flex-direction: column;
    gap: 12px;
}
.chiamata-page .mini-card {
border: 1px solid #ddd;
    border-radius: 12px;
    padding: 12px 14px;
    background: #fafafa;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}
.chiamata-page .mini-card-main {
display: flex;
    flex-direction: column;
    gap: 4px;
}
.chiamata-page .mini-card-actions {
display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.chiamata-page .small-muted {
color: #777;
    font-size: 12px;
}
.chiamata-page .helper-text {
color: #666;
    font-size: 12px;
}
.chiamata-page .subsection-box {
margin-top: 18px;
    border-top: 1px solid #ececec;
    padding-top: 18px;
}
.chiamata-page .subsection-box h3 {
margin-top: 0;
}
.chiamata-page .form-grid {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.chiamata-page .form-row {
display: flex;
    flex-direction: column;
    gap: 6px;
}
.chiamata-page .form-row-full {
grid-column: 1 / -1;
}
.chiamata-page .form-row label {
font-size: 13px;
    font-weight: 700;
    color: #444;
}
.chiamata-page .form-row input,
.chiamata-page .form-row select,
.chiamata-page .form-row textarea,
.chiamata-page .upload-form input[type="file"] {
width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    box-sizing: border-box;
}
.chiamata-page .form-row textarea {
resize: vertical;
    min-height: 100px;
}
.chiamata-page .form-row input:focus,
.chiamata-page .form-row select:focus,
.chiamata-page .form-row textarea:focus {
outline: none;
    border-color: #888;
}
.chiamata-page .parts-section {
margin-top: 18px;
}
.chiamata-page .parts-head {
display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.chiamata-page .parts-head h4 {
margin: 0;
}
.chiamata-page .parts-head-actions {
display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.chiamata-page .part-row {
display: grid;
    grid-template-columns: 1fr 120px auto;
    gap: 10px;
    margin-bottom: 10px;
}
.chiamata-page .part-row select,
.chiamata-page .part-row input {
padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}
.chiamata-page .new-part-box {
margin-top: 14px;
    padding: 14px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
}
.chiamata-page .parti-list {
margin: 6px 0 0 18px;
    padding: 0;
}
.chiamata-page .empty-state {
padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}
.chiamata-page .msg-box {
padding: 12px 14px;
    border-radius: 10px;
    font-weight: 600;
}
.chiamata-page .msg-ok {
background: #e8f7ee;
    color: #1f7a3f;
    border: 1px solid #bfe5cb;
}
.chiamata-page .msg-err {
background: #fdecea;
    color: #b42318;
    border: 1px solid #f3c4c1;
}
.chiamata-page .mini-badge {
display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}
.chiamata-page .mini-badge.success {
background: #e8f7ee;
    color: #1f7a3f;
}
.chiamata-page .mini-badge.danger {
background: #fdecea;
    color: #b42318;
}
.chiamata-page .mini-badge.neutral {
background: #f3f4f6;
    color: #444;
}
.chiamata-page .btn-outline {
display: inline-block;
    padding: 9px 12px;
    border: 1px solid #888;
    border-radius: 8px;
    text-decoration: none;
    color: #222;
    background: #fff;
    transition: .2s;
    cursor: pointer;
}
.chiamata-page .btn-outline:hover {
background: #f5f5f5;
}
.chiamata-page .btn-primary {
display: inline-block;
    padding: 9px 14px;
    border: 1px solid #222;
    border-radius: 8px;
    text-decoration: none;
    color: #fff;
    background: #222;
    transition: .2s;
    cursor: pointer;
}
.chiamata-page .btn-primary:hover {
background: #111;
    border-color: #111;
}
.chiamata-page .btn-sm {
padding: 6px 10px;
    font-size: 13px;
}
.chiamata-page .modal-actions {
display: flex;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #ececec;
}
.chiamata-page .no-border {
border-top: 0;
    padding-top: 0;
}
.chiamata-page .small-actions {
margin-top: 10px;
}
@media (max-width: 900px) {
.chiamata-page .page-head {
flex-direction: column;
        align-items: stretch;
}
.chiamata-page .info-grid,
.chiamata-page .form-grid {
grid-template-columns: 1fr;
}
.chiamata-page .part-row {
grid-template-columns: 1fr;
}

}

/* ======================================================
   INSERISCI IN CALENDARIO
====================================================== */

.calendar-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.calendar-page .calendar-grid {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.calendar-page .sidebar-card,
.calendar-page .content-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, .05);
}

.calendar-page .sidebar-card {
    padding: 16px;
}

.calendar-page .content-card {
    padding: 20px;
    min-width: 0;
}

.calendar-page .page-title {
    margin: 0 0 8px;
    font-size: 28px;
    line-height: 1.2;
}

.calendar-page .page-subtitle {
    color: #64748b;
    margin: 0 0 16px;
}

.calendar-page .toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}

.calendar-page .toolbar-left,
.calendar-page .toolbar-right {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.calendar-page .btn,
.calendar-page .btn-link,
.calendar-page .view-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    text-decoration: none;
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 14px;
    cursor: pointer;
    border: 1px solid #cbd5e1;
    background: #ffffff;
    color: #0f172a;
}

.calendar-page .btn-primary {
    background: #2563eb;
    color: #ffffff;
    border-color: #2563eb;
}

.calendar-page .btn-secondary {
    background: #f8fafc;
}

.calendar-page .view-tab.active {
    background: #0f172a;
    color: #ffffff;
    border-color: #0f172a;
}

.calendar-page .info-box {
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 16px;
    font-size: 14px;
}

.calendar-page .info-success {
    background: #ecfdf5;
    border: 1px solid #86efac;
    color: #166534;
}

.calendar-page .info-error {
    background: #fef2f2;
    border: 1px solid #fca5a5;
    color: #991b1b;
}

.calendar-page .call-details {
    display: grid;
    gap: 12px;
}

.calendar-page .detail-row {
    border-bottom: 1px solid #eef2f7;
    padding-bottom: 10px;
}

.calendar-page .detail-row:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.calendar-page .detail-label {
    font-size: 12px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 4px;
}

.calendar-page .detail-value {
    font-size: 14px;
    color: #0f172a;
    word-break: break-word;
}

.calendar-page .filter-box {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid #e2e8f0;
}

.calendar-page .form-group {
    margin-bottom: 14px;
}

.calendar-page .form-group label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #334155;
}

.calendar-page .form-control {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 14px;
    background: #ffffff;
    box-sizing: border-box;
}

.calendar-page .calendar-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

.calendar-page .calendar-table th,
.calendar-page .calendar-table td {
    border: 1px solid #e2e8f0;
    vertical-align: top;
}

.calendar-page .calendar-table th {
    background: #f8fafc;
    padding: 10px;
    font-size: 13px;
    text-align: center;
}

.calendar-page .time-col {
    width: 86px;
    background: #f8fafc;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
}

.calendar-page .slot-cell {
    min-height: 56px;
    padding: 6px;
    background: #ffffff;
}

.calendar-page .slot-free {
    background: #f0fdf4;
}

.calendar-page .slot-busy {
    background: #fef2f2;
}

.calendar-page .mini-btn {
    border: 1px solid #16a34a;
    background: #22c55e;
    color: #ffffff;
    border-radius: 8px;
    padding: 6px 10px;
    cursor: pointer;
    font-size: 13px;
}

.calendar-page .mini-btn[disabled] {
    background: #cbd5e1;
    border-color: #cbd5e1;
    cursor: not-allowed;
}

.calendar-page .event-box {
    background: #ffffff;
    border: 1px solid #fecaca;
    border-left: 4px solid #ef4444;
    border-radius: 10px;
    padding: 8px;
    font-size: 13px;
    margin-bottom: 6px;
}

.calendar-page .event-time {
    font-weight: 700;
    margin-bottom: 4px;
}

.calendar-page .event-title {
    font-weight: 600;
    margin-bottom: 3px;
}

.calendar-page .event-meta {
    color: #475569;
    font-size: 12px;
}

.calendar-page .event-continue {
    font-size: 12px;
    color: #991b1b;
    font-style: italic;
}

.calendar-page .month-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    border: 1px solid #e2e8f0;
    border-right: 0;
    border-bottom: 0;
}

.calendar-page .month-head {
    background: #f8fafc;
    border-right: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0;
    padding: 10px;
    font-size: 13px;
    font-weight: 700;
    text-align: center;
}

.calendar-page .month-cell {
    min-height: 140px;
    border-right: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0;
    padding: 8px;
    background: #ffffff;
}

.calendar-page .month-cell.other-month {
    background: #f8fafc;
    color: #94a3b8;
}

.calendar-page .month-cell.today {
    box-shadow: inset 0 0 0 2px #2563eb;
}

.calendar-page .month-day-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.calendar-page .month-day-number {
    font-weight: 700;
}

.calendar-page .month-day-link {
    font-size: 12px;
    text-decoration: none;
    color: #2563eb;
}

.calendar-page .month-event {
    display: block;
    text-decoration: none;
    font-size: 12px;
    margin-bottom: 6px;
    padding: 6px;
    border-radius: 8px;
    background: #eff6ff;
    color: #1e3a8a;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.calendar-page .legend {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 14px;
    font-size: 13px;
    color: #475569;
}

.calendar-page .legend-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.calendar-page .legend-color {
    width: 16px;
    height: 16px;
    border-radius: 4px;
    border: 1px solid #cbd5e1;
}

.calendar-page .legend-free {
    background: #f0fdf4;
}

.calendar-page .legend-busy {
    background: #fef2f2;
}

.calendar-page .small-note {
    font-size: 12px;
    color: #64748b;
    margin-top: 6px;
}

@media (max-width: 1100px) {
    .calendar-page .calendar-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .calendar-page {
        padding: 12px;
    }

    .calendar-page .month-grid {
        grid-template-columns: 1fr;
    }

    .calendar-page .month-head {
        display: none;
    }

    .calendar-page .calendar-table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
}

/* ======================================================
   ORDINE DETTAGLIO
====================================================== */

.ordine-dettaglio-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.ordine-dettaglio-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.ordine-dettaglio-page .page-head h1 {
    margin: 0 0 4px;
}

.ordine-dettaglio-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.ordine-dettaglio-page .top-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ordine-dettaglio-page .top-layout {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 18px;
}

.ordine-dettaglio-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.ordine-dettaglio-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.ordine-dettaglio-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.ordine-dettaglio-page .info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.ordine-dettaglio-page .info-item {
    background: #fafafa;
    border: 1px solid #ececec;
    border-radius: 10px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.ordine-dettaglio-page .info-item-full {
    grid-column: 1 / -1;
}

.ordine-dettaglio-page .info-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .03em;
    color: #666;
    font-weight: 700;
}

.ordine-dettaglio-page .info-value {
    font-size: 15px;
    color: #222;
    word-break: break-word;
}

.ordine-dettaglio-page .summary-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.ordine-dettaglio-page .summary-mini-card {
    border: 1px solid #e8e8e8;
    background: #fafafa;
    border-radius: 12px;
    padding: 14px;
    text-align: center;
}

.ordine-dettaglio-page .summary-mini-number {
    display: block;
    font-size: 26px;
    font-weight: 800;
    line-height: 1.1;
}

.ordine-dettaglio-page .summary-mini-label {
    display: block;
    margin-top: 6px;
    color: #666;
    font-size: 13px;
}

.ordine-dettaglio-page .alert {
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid transparent;
}

.ordine-dettaglio-page .alert-success {
    background: #e8f7ee;
    border-color: #cde9d6;
    color: #1f7a3f;
}

.ordine-dettaglio-page .alert-error {
    background: #fdecea;
    border-color: #f5c7c3;
    color: #b42318;
}

.ordine-dettaglio-page .panel-badge,
.ordine-dettaglio-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.ordine-dettaglio-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.ordine-dettaglio-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.ordine-dettaglio-page .mini-badge.warning {
    background: #fff1cc;
    color: #8a5a00;
}

.ordine-dettaglio-page .mini-badge.neutral,
.ordine-dettaglio-page .panel-badge {
    background: #f3f4f6;
    color: #444;
}

.ordine-dettaglio-page .magazzino-toolbar {
    display: flex;
    margin-bottom: 16px;
    gap: 14px;
    flex-wrap: wrap;
}

.ordine-dettaglio-page .table-wrap {
    overflow-x: auto;
}

.ordine-dettaglio-page .table {
    width: 100%;
    border-collapse: collapse;
}

.ordine-dettaglio-page .table th,
.ordine-dettaglio-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}

.ordine-dettaglio-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.ordine-dettaglio-page .table tr:hover td {
    background: #fafcff;
}

.ordine-dettaglio-page .table input,
.ordine-dettaglio-page .table select,
.ordine-dettaglio-page .table textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.ordine-dettaglio-page .row-stock-low td {
    background: #fff8df;
}

.ordine-dettaglio-page .stock-missing {
    color: #b42318;
    font-weight: 700;
}

.ordine-dettaglio-page .spedizione-footer {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-top: 16px;
    align-items: flex-end;
    flex-wrap: wrap;
}

.ordine-dettaglio-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ordine-dettaglio-page .form-row-small {
    min-width: 220px;
}

.ordine-dettaglio-page .form-row-wide {
    min-width: 320px;
    flex: 1;
}

.ordine-dettaglio-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.ordine-dettaglio-page .form-row input,
.ordine-dettaglio-page .form-row select,
.ordine-dettaglio-page .form-row textarea {
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
}

.ordine-dettaglio-page .form-row textarea {
    resize: vertical;
    min-height: 80px;
}

.ordine-dettaglio-page .action-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.ordine-dettaglio-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

.ordine-dettaglio-page .btn-outline {
    display: inline-block;
    padding: 9px 12px;
    border: 1px solid #888;
    border-radius: 8px;
    text-decoration: none;
    color: #222;
    background: #fff;
    transition: .2s;
    cursor: pointer;
}

.ordine-dettaglio-page .btn-outline:hover {
    background: #f5f5f5;
}

.ordine-dettaglio-page .btn-primary {
    display: inline-block;
    padding: 9px 14px;
    border: 1px solid #222;
    border-radius: 8px;
    text-decoration: none;
    color: #fff;
    background: #222;
    transition: .2s;
    cursor: pointer;
}

.ordine-dettaglio-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.ordine-dettaglio-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}

@media (max-width: 1000px) {
    .ordine-dettaglio-page .top-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .ordine-dettaglio-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }

    .ordine-dettaglio-page .info-grid,
    .ordine-dettaglio-page .summary-mini-grid {
        grid-template-columns: 1fr;
    }

    .ordine-dettaglio-page .spedizione-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .ordine-dettaglio-page .form-row-wide,
    .ordine-dettaglio-page .form-row-small {
        min-width: 0;
    }
}

/* ======================================================
   CONSUMABILI STATO
====================================================== */

.consumabili-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.consumabili-page .page-head h1{
    margin: 0 0 4px;
}

.consumabili-page .page-subtitle{
    margin: 0;
    color: #666;
    font-size: 15px;
}

.consumabili-page .box{
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
}

.consumabili-page .section-title-row{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.consumabili-page .section-title-row h2{
    margin: 0;
    font-size: 20px;
}

.consumabili-page .panel-badge{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
    background: #f3f4f6;
    color: #444;
}

.consumabili-page .section-note{
    margin-bottom: 14px;
    color: #666;
    font-size: 14px;
}

.consumabili-page .filters-form .form-grid-consumabili{
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}

.consumabili-page .form-row{
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.consumabili-page .form-row label{
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.consumabili-page .form-row input,
.consumabili-page .form-row select{
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.consumabili-page .filters-help{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #ececec;
}

.consumabili-page .check-pill{
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    border: 1px solid #ddd;
    background: #fafafa;
    padding: 8px 10px;
    border-radius: 999px;
    font-size: 14px;
}

.consumabili-page .static-pill{
    flex-direction: column;
    border-radius: 12px;
    padding: 10px 12px;
}

.consumabili-page .static-pill span{
    font-weight: 700;
    color: #333;
}

.consumabili-page .static-pill small{
    color: #666;
    font-size: 12px;
    line-height: 1.3;
}

.consumabili-page .filters-actions{
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.consumabili-page .table-actions{
    justify-content: flex-end;
}

.consumabili-page .btn-outline,
.consumabili-page .btn-primary{
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: .2s;
}

.consumabili-page .btn-outline{
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.consumabili-page .btn-outline:hover{
    background: #f5f5f5;
}

.consumabili-page .btn-primary{
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.consumabili-page .btn-primary:hover{
    background: #111;
    border-color: #111;
}

.consumabili-page .alert-grid{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 12px;
}

.consumabili-page .alert-card{
    border: 1px solid #ead9d2;
    background: #fff8f5;
    border-radius: 12px;
    padding: 14px;
}

.consumabili-page .alert-title{
    font-weight: 700;
    margin-bottom: 4px;
    color: #222;
}

.consumabili-page .alert-client{
    color: #444;
    font-weight: 600;
}

.consumabili-page .alert-site{
    color: #666;
    font-size: 13px;
    margin-top: 2px;
    margin-bottom: 10px;
}

.consumabili-page .alert-toners{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-weight: 700;
    margin-bottom: 8px;
}

.consumabili-page .alert-total{
    color: #333;
}

.consumabili-page .table-wrap{
    overflow-x: auto;
}

.consumabili-page .table{
    width: 100%;
    min-width: 1100px;
    border-collapse: collapse;
}

.consumabili-page .table th,
.consumabili-page .table td{
    border: 1px solid #ddd;
    padding: 9px 10px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}

.consumabili-page .table th{
    background: #f8f8f8;
    white-space: nowrap;
}

.consumabili-page .table tr:hover td{
    background: #fafcff;
}

.consumabili-page .row-low td{
    background: #fffaf5;
}

.consumabili-page .sub-info{
    font-size: 12px;
    color: #666;
    margin-top: 2px;
}

.consumabili-page .cell-main{
    font-weight: 600;
    color: #222;
}

.consumabili-page .order-selects{
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 54px;
}

.consumabili-page .chk-line{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
}

.consumabili-page .chk-line input{
    margin: 0;
}

.consumabili-page .toner-cell{
    min-width: 140px;
}

.consumabili-page .toner-head{
    display: flex;
    justify-content: space-between;
    gap: 8px;
    align-items: center;
    margin-bottom: 4px;
}

.consumabili-page .toner-value-inline{
    font-weight: 600;
}

.consumabili-page .toner-alert-badge{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 7px;
    white-space: nowrap;
}

.consumabili-page .toner-alert-badge.alert-open{
    background: #fff1cc;
    color: #8a5a00;
}

.consumabili-page .toner-alert-badge.alert-ordered{
    background: #e0f2fe;
    color: #075985;
}

.consumabili-page .toner-alert-badge.alert-shipped{
    background: #e8f7ee;
    color: #1f7a3f;
}

.consumabili-page .toner-bar{
    width: 100%;
    height: 16px;
    background: #e9ecef;
    border-radius: 999px;
    overflow: hidden;
    border: 1px solid #d5d5d5;
}

.consumabili-page .toner-bar.small{
    height: 12px;
}

.consumabili-page .toner-fill{
    height: 100%;
    border-radius: 999px;
}

.consumabili-page .toner-cyan{
    background: linear-gradient(90deg, #8fefff 0%, #00bcd4 100%);
}

.consumabili-page .toner-magenta{
    background: linear-gradient(90deg, #ffb3df 0%, #d81b60 100%);
}

.consumabili-page .toner-yellow{
    background: linear-gradient(90deg, #fff3a6 0%, #f4c20d 100%);
}

.consumabili-page .toner-black{
    background: linear-gradient(90deg, #8b8b8b 0%, #1f1f1f 100%);
}

.consumabili-page .pagination{
    margin-top: 18px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.consumabili-page .page-link{
    display: inline-block;
    min-width: 34px;
    padding: 8px 10px;
    text-align: center;
    border: 1px solid #ccc;
    border-radius: 6px;
    text-decoration: none;
    color: #222;
    background: #fff;
}

.consumabili-page .page-link.active{
    background: #222;
    color: #fff;
    border-color: #222;
}

.consumabili-page .empty-state{
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

.consumabili-page .error-state{
    color: #b42318;
    border-color: #efb3b3;
    background: #fff6f6;
}

.consumabili-page .messages-stack{
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.consumabili-page .msg{
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    border: 1px solid transparent;
}

.consumabili-page .msg-success{
    background: #f0fdf4;
    border-color: #bbf7d0;
    color: #166534;
}

.consumabili-page .msg-warning{
    background: #fffbeb;
    border-color: #fde68a;
    color: #92400e;
}

.consumabili-page .msg-error{
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

.consumabili-page #results-column.loading{
    opacity: 0.55;
    transition: opacity 0.2s ease;
}

@media (max-width: 1400px) {
    .consumabili-page .filters-form .form-grid-consumabili{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .consumabili-page .filters-form .form-grid-consumabili{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .consumabili-page .filters-form .form-grid-consumabili{
        grid-template-columns: 1fr;
    }

    .consumabili-page .filters-help{
        flex-direction: column;
    }

    .consumabili-page .filters-actions,
    .consumabili-page .table-actions{
        flex-direction: column;
        align-items: stretch;
    }

    .consumabili-page .btn-outline,
    .consumabili-page .btn-primary{
        width: 100%;
        text-align: center;
    }
}

/* ======================================================
   DISPOSITIVI MONITORAGGIO
====================================================== */

.dispositivi-monitoraggio-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.dispositivi-monitoraggio-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.dispositivi-monitoraggio-page .page-head h1 {
    margin: 0 0 4px;
}

.dispositivi-monitoraggio-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.dispositivi-monitoraggio-page .role-box {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dispositivi-monitoraggio-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .04);
}

.dispositivi-monitoraggio-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.dispositivi-monitoraggio-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.dispositivi-monitoraggio-page .section-note {
    margin-bottom: 12px;
    color: #666;
    font-size: 14px;
}

.dispositivi-monitoraggio-page .summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.dispositivi-monitoraggio-page .summary-card {
    border: 1px solid #e8e8e8;
    background: #fafafa;
    border-radius: 12px;
    padding: 14px;
    text-align: center;
}

.dispositivi-monitoraggio-page .summary-number {
    display: block;
    font-size: 26px;
    font-weight: 800;
    line-height: 1.1;
}

.dispositivi-monitoraggio-page .summary-label {
    display: block;
    margin-top: 6px;
    color: #666;
    font-size: 13px;
    text-transform: none;
    letter-spacing: normal;
}

.dispositivi-monitoraggio-page .panel-badge,
.dispositivi-monitoraggio-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.dispositivi-monitoraggio-page .panel-badge,
.dispositivi-monitoraggio-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #444;
}

.dispositivi-monitoraggio-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.dispositivi-monitoraggio-page .mini-badge.warning {
    background: #fff1cc;
    color: #8a5a00;
}

.dispositivi-monitoraggio-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.dispositivi-monitoraggio-page .filters-form .form-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.dispositivi-monitoraggio-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.dispositivi-monitoraggio-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.dispositivi-monitoraggio-page .form-row input,
.dispositivi-monitoraggio-page .form-row select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.dispositivi-monitoraggio-page .filters-actions {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.dispositivi-monitoraggio-page .btn-outline,
.dispositivi-monitoraggio-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: .2s;
}

.dispositivi-monitoraggio-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.dispositivi-monitoraggio-page .btn-outline:hover {
    background: #f5f5f5;
}

.dispositivi-monitoraggio-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.dispositivi-monitoraggio-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.dispositivi-monitoraggio-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}

.dispositivi-monitoraggio-page .table-wrap {
    overflow-x: auto;
}

.dispositivi-monitoraggio-page .table {
    width: 100%;
    min-width: 1100px;
    border-collapse: collapse;
}

.dispositivi-monitoraggio-page .table th,
.dispositivi-monitoraggio-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}

.dispositivi-monitoraggio-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.dispositivi-monitoraggio-page .table tr:hover td {
    background: #fafcff;
}

.dispositivi-monitoraggio-page .messages-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dispositivi-monitoraggio-page .msg {
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    border: 1px solid transparent;
}

.dispositivi-monitoraggio-page .msg-warning {
    background: #fffbeb;
    border-color: #fde68a;
    color: #92400e;
}

.dispositivi-monitoraggio-page .msg-error {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

.dispositivi-monitoraggio-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

@media (max-width: 1100px) {
    .dispositivi-monitoraggio-page .summary-grid,
    .dispositivi-monitoraggio-page .filters-form .form-grid {
        grid-template-columns: 1fr;
    }

    .dispositivi-monitoraggio-page .filters-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .dispositivi-monitoraggio-page .btn-outline,
    .dispositivi-monitoraggio-page .btn-primary {
        width: 100%;
        text-align: center;
    }
}

/* ======================================================
   CONTATORI
====================================================== */

.contatori-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.contatori-page .page-head h1 {
    margin: 0 0 4px;
}

.contatori-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.contatori-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
}

.contatori-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.contatori-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.contatori-page .panel-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
    background: #f3f4f6;
    color: #444;
}

.contatori-page .filters-form .form-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
}

.contatori-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.contatori-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.contatori-page .form-row input,
.contatori-page .form-row select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.contatori-page .columns-box {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #ececec;
}

.contatori-page .columns-title {
    font-size: 13px;
    font-weight: 700;
    color: #444;
    margin-bottom: 10px;
}

.contatori-page .columns-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.contatori-page .check-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid #ddd;
    background: #fafafa;
    padding: 8px 10px;
    border-radius: 999px;
    cursor: pointer;
    font-size: 14px;
}

.contatori-page .check-pill input {
    width: auto;
    margin: 0;
}

.contatori-page .filters-actions {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.contatori-page .btn-outline,
.contatori-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: .2s;
}

.contatori-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.contatori-page .btn-outline:hover {
    background: #f5f5f5;
}

.contatori-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.contatori-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.contatori-page .table-wrap {
    overflow-x: auto;
}

.contatori-page .table {
    width: 100%;
    border-collapse: collapse;
}

.contatori-page .table th,
.contatori-page .table td {
    border: 1px solid #ddd;
    padding: 9px 10px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
    white-space: nowrap;
}

.contatori-page .table th {
    background: #f8f8f8;
}

.contatori-page .table tr:hover td {
    background: #fafcff;
}

.contatori-page .table tfoot th,
.contatori-page .table tfoot td {
    background: #f4f7fb;
    font-weight: 800;
}

.contatori-page .totals-row th,
.contatori-page .totals-row td {
    border-top: 2px solid #cfd8e3;
}

.contatori-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

@media (max-width: 1200px) {
    .contatori-page .filters-form .form-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .contatori-page .filters-form .form-grid {
        grid-template-columns: 1fr;
    }

    .contatori-page .columns-grid {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ======================================================
   MAGAZZINO - PAGINA
====================================================== */
.magazzino-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.magazzino-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.magazzino-page .page-head h1 {
    margin: 0 0 4px;
}

.magazzino-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.magazzino-page .top-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.magazzino-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.magazzino-page .stat-box {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.magazzino-page .stat-label {
    color: #666;
    font-size: 14px;
    font-weight: 700;
}

.magazzino-page .stat-value {
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
}

.magazzino-page .danger-text {
    color: #b42318;
}

.magazzino-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

.magazzino-page .alert {
    border-radius: 12px;
    padding: 14px 16px;
    border: 1px solid transparent;
    font-size: 14px;
}

.magazzino-page .alert.success {
    background: #ecfdf3;
    border-color: #abe4c0;
    color: #166534;
}

.magazzino-page .alert.error {
    background: #fef3f2;
    border-color: #f5c2c0;
    color: #b42318;
}

.magazzino-page .hint-box {
    border: 1px dashed #cbd5e1;
    background: #f8fafc;
    color: #475569;
    border-radius: 12px;
    padding: 14px;
    font-size: 14px;
}

.magazzino-page .filter-toolbar {
    display: flex;
    gap: 14px;
    align-items: end;
    flex-wrap: wrap;
}

.magazzino-page .form-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.magazzino-page .filter-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 180px;
    flex: 1 1 180px;
}

.magazzino-page .filter-item.full {
    flex: 1 1 100%;
}

.magazzino-page .filter-item label,
.magazzino-page .section-title {
    font-size: 13px;
    font-weight: 700;
    color: #444;
    margin: 0;
}

.magazzino-page .section-title {
    font-size: 18px;
    margin-bottom: 14px;
}

.magazzino-page .filter-item input,
.magazzino-page .filter-item select,
.magazzino-page .filter-item textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
    background: #fff;
}

.magazzino-page .filter-item input:focus,
.magazzino-page .filter-item select:focus,
.magazzino-page .filter-item textarea:focus {
    outline: none;
    border-color: #888;
}

.magazzino-page .filter-actions {
    min-width: auto;
}

.magazzino-page .filter-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.magazzino-page .magazzino-grid {
    display: grid;
    grid-template-columns: 420px minmax(0, 1fr);
    gap: 18px;
}

.magazzino-page .left-column,
.magazzino-page .right-column {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.magazzino-page .table-wrap {
    overflow-x: auto;
}

.magazzino-page .table {
    width: 100%;
    border-collapse: collapse;
}

.magazzino-page .table th,
.magazzino-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}

.magazzino-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.magazzino-page .row-warning td {
    background: #fff8df;
}

.magazzino-page .note-row td {
    background: #fafafa;
    border-top: 0;
}

.magazzino-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.magazzino-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.magazzino-page .mini-badge.warning {
    background: #fff1cc;
    color: #8a5a00;
}

.magazzino-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.magazzino-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #444;
}

.magazzino-page .btn-outline {
    display: inline-block;
    padding: 9px 12px;
    border: 1px solid #888;
    border-radius: 8px;
    text-decoration: none;
    color: #222;
    background: #fff;
    transition: .2s;
    cursor: pointer;
    font: inherit;
}

.magazzino-page .btn-outline:hover {
    background: #f5f5f5;
}

.magazzino-page .btn-primary {
    display: inline-block;
    padding: 9px 14px;
    border: 1px solid #222;
    border-radius: 8px;
    text-decoration: none;
    color: #fff;
    background: #222;
    transition: .2s;
    cursor: pointer;
    font: inherit;
}

.magazzino-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.magazzino-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}

.magazzino-page .checkbox-row {
    justify-content: center;
}

.magazzino-page .checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    color: #222;
}

.magazzino-page .muted-line {
    color: #666;
    font-size: 13px;
}

.magazzino-page .modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(17, 24, 39, 0.55);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 5000;
    padding: 20px;
}

.magazzino-page .modal-overlay.is-open {
    display: flex;
}

.magazzino-page .modal-box {
    width: 100%;
    max-width: 720px;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #ddd;
    box-shadow: 0 20px 60px rgba(0,0,0,0.22);
    padding: 18px;
}

.magazzino-page .modal-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}

.magazzino-page .modal-head h2 {
    margin: 0;
    font-size: 22px;
}

.magazzino-page .modal-close {
    border: 1px solid #ccc;
    background: #fff;
    border-radius: 10px;
    width: 40px;
    height: 40px;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
}

.magazzino-page .modal-close:hover {
    background: #f5f5f5;
}

.magazzino-page .modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

@media (max-width: 1200px) {
    .magazzino-page .magazzino-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .magazzino-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }

    .magazzino-page .filter-toolbar,
.magazzino-page .form-grid {
        flex-direction: column;
        align-items: stretch;
    }

    .magazzino-page .filter-item {
        min-width: 0;
    }

    .magazzino-page .stats-grid {
        grid-template-columns: 1fr;
    }

    .magazzino-page .modal-actions {
        flex-direction: column;
    }
}

/* ======================================================
   GESTIONE CARICO MAGAZZINO
====================================================== */

.magazzino-carico-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}.magazzino-carico-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}.magazzino-carico-page .page-head h1 {
    margin: 0 0 4px;
}.magazzino-carico-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}.magazzino-carico-page .role-box {
    display: flex;
    align-items: center;
    gap: 8px;
}.magazzino-carico-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
}.magazzino-carico-page .readonly-box {
    border-color: #d8e1ef;
    background: #f8fbff;
}.magazzino-carico-page .readonly-message {
    padding: 12px 14px;
    border-radius: 10px;
    background: #f3f7ff;
    border: 1px solid #d8e4ff;
    color: #24406c;
    font-size: 14px;
}.magazzino-carico-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}.magazzino-carico-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}.magazzino-carico-page .section-divider {
    border-top: 1px solid #ececec;
    margin: 18px 0;
}.magazzino-carico-page .panel-badge,
.magazzino-carico-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}.magazzino-carico-page .panel-badge {
    background: #f3f4f6;
    color: #444;
}.magazzino-carico-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}.magazzino-carico-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #444;
}.magazzino-carico-page .form-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}.magazzino-carico-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}.magazzino-carico-page .form-row-wide {
    grid-column: span 2;
}.magazzino-carico-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}.magazzino-carico-page .form-row input,
.magazzino-carico-page .form-row select,
.magazzino-carico-page .form-row textarea,
.magazzino-carico-page .table input,
.magazzino-carico-page .table select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
}.magazzino-carico-page .form-row textarea {
    resize: vertical;
    min-height: 80px;
}.magazzino-carico-page .filters-actions {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}.magazzino-carico-page .btn-outline,
.magazzino-carico-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: .2s;
}.magazzino-carico-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}.magazzino-carico-page .btn-outline:hover {
    background: #f5f5f5;
}.magazzino-carico-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}.magazzino-carico-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}.magazzino-carico-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}.magazzino-carico-page .table-wrap {
    overflow-x: auto;
}.magazzino-carico-page .table {
    width: 100%;
    min-width: 1150px;
    border-collapse: collapse;
}.magazzino-carico-page .table th,
.magazzino-carico-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}.magazzino-carico-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}.magazzino-carico-page .table tr:hover td {
    background: #fafcff;
}.magazzino-carico-page .material-inline-cell {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 420px;
}.magazzino-carico-page .material-filter-inline {
    width: 82px !important;
    min-width: 82px;
    max-width: 82px;
    text-align: center;
    background: #fbfdff;
    padding-left: 8px !important;
    padding-right: 8px !important;
}.magazzino-carico-page .material-select-inline {
    flex: 1 1 auto;
    min-width: 300px;
}.magazzino-carico-page .messages-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
}.magazzino-carico-page .msg {
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    border: 1px solid transparent;
}.magazzino-carico-page .msg-success {
    background: #f0fdf4;
    border-color: #bbf7d0;
    color: #166534;
}.magazzino-carico-page .msg-error {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

@media (max-width: 1300px) {
.magazzino-carico-page .form-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }.magazzino-carico-page .form-row-wide {
        grid-column: span 3;
    }

}

@media (max-width: 900px) {
.magazzino-carico-page .material-inline-cell {
        min-width: 360px;
    }.magazzino-carico-page .material-filter-inline {
        width: 72px !important;
        min-width: 72px;
        max-width: 72px;
    }.magazzino-carico-page .material-select-inline {
        min-width: 260px;
    }

}

@media (max-width: 800px) {
.magazzino-carico-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }.magazzino-carico-page .form-grid {
        grid-template-columns: 1fr;
    }.magazzino-carico-page .form-row-wide {
        grid-column: span 1;
    }.magazzino-carico-page .filters-actions {
        flex-direction: column;
        align-items: stretch;
    }.magazzino-carico-page .btn-outline,
.magazzino-carico-page .btn-primary {
        width: 100%;
        text-align: center;
    }.magazzino-carico-page .material-inline-cell {
        min-width: 340px;
    }

}

/* ======================================================
   OPERATORI / TECNICI
====================================================== */

.operatori-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.operatori-page .operatori-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 2px;
}

.operatori-page .operatori-head h2 {
    margin: 0;
    font-size: 24px;
    font-weight: 800;
    color: var(--color-text, #111827);
}

.operatori-page .operatori-box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.operatori-page .operatori-table th,
.operatori-page .operatori-table td {
    vertical-align: middle;
}

.operatori-page tr.clickable {
    cursor: pointer;
}

.operatori-page tr.clickable:hover td {
    background: #eef3fb;
}

.operatori-page .operatori-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    padding: 5px 9px;
    white-space: nowrap;
}

.operatori-page .badge-success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.operatori-page .badge-secondary {
    background: #f3f4f6;
    color: #444;
}

.operatori-page .operatori-actions {
    white-space: nowrap;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.operatori-page .btn-warning {
    background: #f59e0b;
    border-color: #f59e0b;
    color: #fff;
}

.operatori-page .btn-warning:hover {
    background: #d97706;
    border-color: #d97706;
}

@media (max-width: 900px) {
    .operatori-page .operatori-head {
        align-items: stretch;
        flex-direction: column;
    }

    .operatori-page .operatori-head .btn {
        width: 100%;
    }
}

/* ======================================================
   MATERIALI
====================================================== */

.materiali-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.materiali-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.materiali-page .page-head h1 {
    margin: 0 0 4px;
}

.materiali-page .page-subtitle {
    margin: 0;
    color: var(--color-muted);
    font-size: 15px;
}

.materiali-page .top-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.materiali-page .box {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 18px;
    box-shadow: var(--shadow-sm);
}

.materiali-page .materiale-row {
    cursor: pointer;
}

.materiali-page .editable {
    cursor: text;
}

.materiali-page .editable:hover {
    background: #fff8db;
}

.materiali-page .editable input,
.materiali-page .editable select {
    width: 100%;
    min-width: 140px;
    padding: 7px 9px;
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-family: inherit;
}

.materiali-page .materiali-debug-box {
    display: none;
    margin-top: 2px;
    padding: 10px;
    border: 1px solid var(--color-border);
    background: #f9f9f9;
    white-space: pre-wrap;
    font-family: monospace;
    border-radius: var(--radius-sm);
}

.materiali-page .materiali-debug-box:not(:empty) {
    display: block;
}

@media (max-width: 900px) {
    .materiali-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   MATERIALE FORM
====================================================== */

.materiale-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.materiale-form-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.materiale-form-page .page-head h1 {
    margin: 0 0 4px;
}

.materiale-form-page .top-actions,
.materiale-form-page .form-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.materiale-form-page .form-actions {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.materiale-form-page .materiale-model-select {
    min-height: 260px;
}

@media (max-width: 900px) {
    .materiale-form-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   FORM TECNICO / OPERATORE
====================================================== */

.tecnico-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.tecnico-form-page .tecnico-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.tecnico-form-page .tecnico-head h1 {
    margin: 0 0 4px;
    font-size: 26px;
    font-weight: 800;
}

.tecnico-form-page .tecnico-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.tecnico-form-page .tecnico-box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.tecnico-form-page .tecnico-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
    max-width: 900px;
}

.tecnico-form-page .form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.tecnico-form-page .form-group.full,
.tecnico-form-page .form-actions.full {
    grid-column: 1 / -1;
}

.tecnico-form-page .attivo-box {
    grid-column: 1 / -1;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}

.tecnico-form-page .attivo-box input[type="checkbox"] {
    width: auto;
}

.tecnico-form-page .form-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 8px;
}

@media (max-width: 800px) {
    .tecnico-form-page .tecnico-form-grid {
        grid-template-columns: 1fr;
    }

    .tecnico-form-page .tecnico-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   PARTI
====================================================== */

.parti-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.parti-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.parti-page .page-head h1 {
    margin: 0 0 4px;
}

.parti-page .page-subtitle {
    margin: 0;
    color: var(--color-muted);
    font-size: 15px;
}

.parti-page .top-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.parti-page .box {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 18px;
    box-shadow: var(--shadow-sm);
}

.parti-page .parte-row {
    cursor: pointer;
}

.parti-page .editable {
    cursor: text;
}

.parti-page .editable:hover {
    background: #fff8db;
}

.parti-page .editable input,
.parti-page .editable select {
    width: 100%;
    min-width: 140px;
    padding: 7px 9px;
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-family: inherit;
}

.parti-page .parti-debug-box {
    display: none;
    margin-top: 2px;
    padding: 10px;
    border: 1px solid var(--color-border);
    background: #f9f9f9;
    white-space: pre-wrap;
    font-family: monospace;
    border-radius: var(--radius-sm);
}

.parti-page .parti-debug-box:not(:empty) {
    display: block;
}

@media (max-width: 900px) {
    .parti-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   PARTE FORM
====================================================== */

.parte-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.parte-form-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.parte-form-page .page-head h1 {
    margin: 0 0 4px;
}

.parte-form-page .top-actions,
.parte-form-page .form-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.parte-form-page .form-actions {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border, #e5e7eb);
}

.parte-form-page .parte-active-line {
    min-height: 40px;
    align-items: center;
}

.parte-form-page .parte-model-select {
    min-height: 260px;
}

@media (max-width: 900px) {
    .parte-form-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   MODELLI PRODOTTI
====================================================== */

.modelli-prodotti-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.modelli-prodotti-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.modelli-prodotti-page .page-head h1 {
    margin: 0 0 4px;
}

.modelli-prodotti-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.modelli-prodotti-page .top-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.modelli-prodotti-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.modelli-prodotti-page .table-wrap {
    overflow-x: auto;
}

.modelli-prodotti-page .table {
    width: 100%;
    border-collapse: collapse;
}

.modelli-prodotti-page .table th,
.modelli-prodotti-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}

.modelli-prodotti-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.modelli-prodotti-page .modello-row {
    cursor: pointer;
}

.modelli-prodotti-page .modello-row:hover td {
    background: #fafcff;
}

.modelli-prodotti-page .editable {
    cursor: text;
}

.modelli-prodotti-page .inline-edit-control {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
}

.modelli-prodotti-page textarea.inline-edit-control {
    min-height: 80px;
    resize: vertical;
}

.modelli-prodotti-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

.modelli-prodotti-page .modelli-debug-box {
    margin-top: 2px;
    padding: 10px;
    border: 1px solid #ccc;
    background: #f9f9f9;
    border-radius: 10px;
    white-space: pre-wrap;
    font-family: monospace;
    color: #374151;
}

@media (max-width: 900px) {
    .modelli-prodotti-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   FORM MODELLO PRODOTTO
====================================================== */

.modello-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.modello-form-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.modello-form-page .page-head h1 {
    margin: 0 0 4px;
}

.modello-form-page .top-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.modello-form-page .form-box {
    max-width: 780px;
}

.modello-form-page .form-grid-1 {
    grid-template-columns: 1fr;
}

.modello-form-page .form-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border);
}

@media (max-width: 700px) {
    .modello-form-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   ORDINE FORM
====================================================== */

.ordine-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.ordine-form-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.ordine-form-page .page-head h1 {
    margin: 0 0 4px;
}

.ordine-form-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.ordine-form-page .top-actions,
.ordine-form-page .toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ordine-form-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.ordine-form-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.ordine-form-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.ordine-form-page .form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.ordine-form-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ordine-form-page .form-row-full {
    grid-column: 1 / -1;
}

.ordine-form-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.ordine-form-page .form-row input,
.ordine-form-page .form-row select,
.ordine-form-page .form-row textarea,
.ordine-form-page .table input,
.ordine-form-page .table select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
}

.ordine-form-page .form-row textarea {
    resize: vertical;
    min-height: 100px;
}

.ordine-form-page .form-row input:focus,
.ordine-form-page .form-row select:focus,
.ordine-form-page .form-row textarea:focus,
.ordine-form-page .table input:focus,
.ordine-form-page .table select:focus {
    outline: none;
    border-color: #888;
    box-shadow: none;
}

.ordine-form-page .table-wrap {
    overflow-x: auto;
}

.ordine-form-page .table {
    width: 100%;
    border-collapse: collapse;
}

.ordine-form-page .table th,
.ordine-form-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}

.ordine-form-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.ordine-form-page .ordine-righe-table th:nth-child(2),
.ordine-form-page .ordine-righe-table td:nth-child(2) {
    width: 120px;
}

.ordine-form-page .ordine-righe-table th:nth-child(4),
.ordine-form-page .ordine-righe-table td:nth-child(4) {
    width: 120px;
}

.ordine-form-page .empty-state {
    margin-top: 14px;
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

.ordine-form-page .form-actions-end {
    display: flex;
    justify-content: flex-end;
}

.ordine-form-page .btn-outline {
    display: inline-block;
    padding: 9px 12px;
    border: 1px solid #888;
    border-radius: 8px;
    text-decoration: none;
    color: #222;
    background: #fff;
    transition: 0.2s;
    cursor: pointer;
}

.ordine-form-page .btn-outline:hover {
    background: #f5f5f5;
}

.ordine-form-page .btn-primary {
    display: inline-block;
    padding: 9px 14px;
    border: 1px solid #222;
    border-radius: 8px;
    text-decoration: none;
    color: #fff;
    background: #222;
    transition: 0.2s;
    cursor: pointer;
}

.ordine-form-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.ordine-form-page .btn-sm {
    padding: 6px 10px;
    font-size: 13px;
}

@media (max-width: 900px) {
    .ordine-form-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }

    .ordine-form-page .form-grid {
        grid-template-columns: 1fr;
    }
}

/* ======================================================
   CHIAMATA FORM
====================================================== */

.chiamata-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.chiamata-form-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.chiamata-form-page .page-head h1 {
    margin: 0 0 4px;
}

.chiamata-form-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.chiamata-form-page .top-actions,
.chiamata-form-page .form-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.chiamata-form-page .msg-ok {
    background: #e8f7ee;
    color: #1f7a3f;
    border: 1px solid #bfe5cb;
    padding: 12px 14px;
    border-radius: 10px;
    font-weight: 600;
}

.chiamata-form-page .msg-err {
    background: #fdecea;
    color: #b42318;
    border: 1px solid #f3c4c1;
    padding: 12px 14px;
    border-radius: 10px;
    font-weight: 600;
}

.chiamata-form-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.chiamata-form-page .chiamata-form-box {
    max-width: 1100px;
}

.chiamata-form-page .form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px 18px;
}

.chiamata-form-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 7px;
    min-width: 0;
}

.chiamata-form-page .form-row-full {
    grid-column: 1 / -1;
}

.chiamata-form-page label {
    font-size: 13px;
    font-weight: 800;
    color: #374151;
}

.chiamata-form-page input,
.chiamata-form-page select,
.chiamata-form-page textarea {
    width: 100%;
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid #d1d5db;
    border-radius: 10px;
    background: #fff;
    color: #111827;
    font-size: 14px;
    font-family: inherit;
    box-sizing: border-box;
}

.chiamata-form-page textarea {
    min-height: 130px;
    resize: vertical;
}

.chiamata-form-page input:focus,
.chiamata-form-page select:focus,
.chiamata-form-page textarea:focus {
    outline: none;
    border-color: var(--color-primary, #7a1f3d);
    box-shadow: 0 0 0 3px rgba(122, 31, 61, 0.12);
}

.chiamata-form-page .inline-combo {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: stretch;
}

.chiamata-form-page .inline-combo button {
    white-space: nowrap;
}

.chiamata-form-page .quick-contact-box {
    width: 100%;
    padding: 18px;
    border-radius: 14px;
    border: 1px dashed #d1d5db;
    background: #fafafa;
}

.chiamata-form-page .quick-contact-box h3 {
    margin: 0 0 16px;
    font-size: 17px;
    font-weight: 800;
    color: #111827;
}

.chiamata-form-page .field-help {
    color: #777;
    font-size: 12px;
}

.chiamata-form-page .form-actions {
    justify-content: flex-end;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid #ececec;
}

.chiamata-form-page .btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 9px 12px;
    border: 1px solid #888;
    border-radius: 8px;
    text-decoration: none;
    color: #222;
    background: #fff;
    transition: 0.2s;
    cursor: pointer;
    font-weight: 700;
    font-family: inherit;
}

.chiamata-form-page .btn-outline:hover {
    background: #f5f5f5;
}

.chiamata-form-page .btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 9px 14px;
    border: 1px solid #222;
    border-radius: 8px;
    text-decoration: none;
    color: #fff;
    background: #222;
    transition: 0.2s;
    cursor: pointer;
    font-weight: 700;
    font-family: inherit;
}

.chiamata-form-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

@media (max-width: 900px) {
    .chiamata-form-page .form-grid {
        grid-template-columns: 1fr;
    }

    .chiamata-form-page .inline-combo {
        grid-template-columns: 1fr;
    }

    .chiamata-form-page .form-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .chiamata-form-page .btn-outline,
    .chiamata-form-page .btn-primary {
        width: 100%;
    }
}

/* ======================================================
   CHIAMATA FORM - REFERENTE
====================================================== */

.chiamata-form-page .referente-row {
    align-items: stretch;
    text-align: left;
}

.chiamata-form-page .referente-row label {
    text-align: left;
    display: block;
    width: 100%;
}

.chiamata-form-page .referente-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: stretch;
    width: 100%;
}

.chiamata-form-page .referente-actions select {
    width: 100%;
    min-width: 0;
}

.chiamata-form-page .referente-actions .btn {
    white-space: nowrap;
}

.chiamata-form-page .nuovo-referente-box[hidden] {
    display: none !important;
}

.chiamata-form-page .quick-contact-box {
    width: 100%;
    border: 1px dashed var(--color-border-strong);
    background: var(--color-surface-soft);
    border-radius: 14px;
    padding: 18px;
    text-align: left;
}

.chiamata-form-page .quick-contact-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.chiamata-form-page .quick-contact-head h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 800;
}

@media (max-width: 800px) {
    .chiamata-form-page .referente-actions {
        grid-template-columns: 1fr;
    }

    .chiamata-form-page .referente-actions .btn {
        width: 100%;
    }

    .chiamata-form-page .quick-contact-head {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ======================================================
   CONSUMABILI ALERT STORICO
====================================================== */

.consumabili-alert-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.consumabili-alert-page .page-head h1 {
    margin: 0 0 4px;
}

.consumabili-alert-page .page-subtitle {
    margin: 0;
    color: var(--color-muted, #666);
    font-size: 15px;
}

.consumabili-alert-page .box {
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border, #ddd);
    border-radius: 14px;
    padding: 18px;
    box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,.04));
}

.consumabili-alert-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.consumabili-alert-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.consumabili-alert-page .panel-badge,
.consumabili-alert-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.consumabili-alert-page .panel-badge {
    background: var(--color-gray-bg, #f3f4f6);
    color: var(--color-gray-text, #444);
}

.consumabili-alert-page .mini-badge.success {
    background: var(--color-green-bg, #e8f7ee);
    color: var(--color-green-text, #1f7a3f);
}

.consumabili-alert-page .mini-badge.warning {
    background: var(--color-yellow-bg, #fff1cc);
    color: var(--color-yellow-text, #8a5a00);
}

.consumabili-alert-page .mini-badge.info {
    background: #e0f2fe;
    color: #075985;
}

.consumabili-alert-page .mini-badge.danger {
    background: var(--color-red-bg, #fdecea);
    color: var(--color-red-text, #b42318);
}

.consumabili-alert-page .mini-badge.neutral {
    background: var(--color-gray-bg, #f3f4f6);
    color: var(--color-gray-text, #444);
}

.consumabili-alert-page .filters-form .form-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}

.consumabili-alert-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.consumabili-alert-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.consumabili-alert-page .form-row input,
.consumabili-alert-page .form-row select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.consumabili-alert-page .filters-actions {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.consumabili-alert-page .btn-outline,
.consumabili-alert-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: .2s;
}

.consumabili-alert-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.consumabili-alert-page .btn-outline:hover {
    background: #f5f5f5;
}

.consumabili-alert-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.consumabili-alert-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.consumabili-alert-page .summary-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.consumabili-alert-page .summary-card {
    border: 1px solid #e8e8e8;
    background: #fafafa;
    border-radius: 12px;
    padding: 14px;
    text-align: center;
}

.consumabili-alert-page .summary-number {
    display: block;
    font-size: 26px;
    font-weight: 800;
    line-height: 1.1;
}

.consumabili-alert-page .summary-label {
    display: block;
    margin-top: 6px;
    color: #666;
    font-size: 13px;
}

.consumabili-alert-page .table-wrap {
    overflow-x: auto;
}

.consumabili-alert-page .table {
    width: 100%;
    min-width: 1500px;
    border-collapse: collapse;
}

.consumabili-alert-page .table th,
.consumabili-alert-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}

.consumabili-alert-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.consumabili-alert-page .table tr:hover td {
    background: #fafcff;
}

.consumabili-alert-page .cell-main {
    font-weight: 600;
    color: #222;
}

.consumabili-alert-page .sub-info {
    font-size: 12px;
    color: #666;
    margin-top: 2px;
}

.consumabili-alert-page .color-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 5px 9px;
    font-size: 12px;
    font-weight: 700;
}

.consumabili-alert-page .color-nero {
    background: #ececec;
    color: #111;
}

.consumabili-alert-page .color-magenta {
    background: #ffe0f0;
    color: #9c1458;
}

.consumabili-alert-page .color-ciano {
    background: #dff7fb;
    color: #0b7285;
}

.consumabili-alert-page .color-giallo {
    background: #fff5cc;
    color: #8a6d00;
}

.consumabili-alert-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

@media (max-width: 1300px) {
    .consumabili-alert-page .filters-form .form-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .consumabili-alert-page .summary-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 800px) {
    .consumabili-alert-page .filters-form .form-grid,
    .consumabili-alert-page .summary-grid {
        grid-template-columns: 1fr;
    }

    .consumabili-alert-page .filters-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .consumabili-alert-page .btn-outline,
    .consumabili-alert-page .btn-primary {
        width: 100%;
        text-align: center;
    }
}

/* ======================================================
   MAGAZZINO CLIENTI
====================================================== */

.consumabili-alert-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.consumabili-alert-page .page-head h1 {
    margin: 0 0 4px;
}

.consumabili-alert-page .page-subtitle {
    margin: 0;
    color: var(--color-muted, #666);
    font-size: 15px;
}

.consumabili-alert-page .box {
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border, #ddd);
    border-radius: 14px;
    padding: 18px;
    box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,.04));
}

.consumabili-alert-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.consumabili-alert-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.consumabili-alert-page .panel-badge,
.consumabili-alert-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.consumabili-alert-page .panel-badge {
    background: var(--color-gray-bg, #f3f4f6);
    color: var(--color-gray-text, #444);
}

.consumabili-alert-page .mini-badge.success {
    background: var(--color-green-bg, #e8f7ee);
    color: var(--color-green-text, #1f7a3f);
}

.consumabili-alert-page .mini-badge.warning {
    background: var(--color-yellow-bg, #fff1cc);
    color: var(--color-yellow-text, #8a5a00);
}

.consumabili-alert-page .mini-badge.info {
    background: #e0f2fe;
    color: #075985;
}

.consumabili-alert-page .mini-badge.danger {
    background: var(--color-red-bg, #fdecea);
    color: var(--color-red-text, #b42318);
}

.consumabili-alert-page .mini-badge.neutral {
    background: var(--color-gray-bg, #f3f4f6);
    color: var(--color-gray-text, #444);
}

.consumabili-alert-page .filters-form .form-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}

.consumabili-alert-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.consumabili-alert-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.consumabili-alert-page .form-row input,
.consumabili-alert-page .form-row select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.consumabili-alert-page .filters-actions {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.consumabili-alert-page .btn-outline,
.consumabili-alert-page .btn-primary {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: .2s;
}

.consumabili-alert-page .btn-outline {
    border: 1px solid #888;
    color: #222;
    background: #fff;
}

.consumabili-alert-page .btn-outline:hover {
    background: #f5f5f5;
}

.consumabili-alert-page .btn-primary {
    border: 1px solid #222;
    color: #fff;
    background: #222;
}

.consumabili-alert-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.consumabili-alert-page .summary-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.consumabili-alert-page .summary-card {
    border: 1px solid #e8e8e8;
    background: #fafafa;
    border-radius: 12px;
    padding: 14px;
    text-align: center;
}

.consumabili-alert-page .summary-number {
    display: block;
    font-size: 26px;
    font-weight: 800;
    line-height: 1.1;
}

.consumabili-alert-page .summary-label {
    display: block;
    margin-top: 6px;
    color: #666;
    font-size: 13px;
}

.consumabili-alert-page .table-wrap {
    overflow-x: auto;
}

.consumabili-alert-page .table {
    width: 100%;
    min-width: 1500px;
    border-collapse: collapse;
}

.consumabili-alert-page .table th,
.consumabili-alert-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}

.consumabili-alert-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.consumabili-alert-page .table tr:hover td {
    background: #fafcff;
}

.consumabili-alert-page .cell-main {
    font-weight: 600;
    color: #222;
}

.consumabili-alert-page .sub-info {
    font-size: 12px;
    color: #666;
    margin-top: 2px;
}

.consumabili-alert-page .color-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 5px 9px;
    font-size: 12px;
    font-weight: 700;
}

.consumabili-alert-page .color-nero {
    background: #ececec;
    color: #111;
}

.consumabili-alert-page .color-magenta {
    background: #ffe0f0;
    color: #9c1458;
}

.consumabili-alert-page .color-ciano {
    background: #dff7fb;
    color: #0b7285;
}

.consumabili-alert-page .color-giallo {
    background: #fff5cc;
    color: #8a6d00;
}

.consumabili-alert-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

@media (max-width: 1300px) {
    .consumabili-alert-page .filters-form .form-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .consumabili-alert-page .summary-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 800px) {
    .consumabili-alert-page .filters-form .form-grid,
    .consumabili-alert-page .summary-grid {
        grid-template-columns: 1fr;
    }

    .consumabili-alert-page .filters-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .consumabili-alert-page .btn-outline,
    .consumabili-alert-page .btn-primary {
        width: 100%;
        text-align: center;
    }
}

/* ======================================================
   TONER SOSTITUITI
====================================================== */

.toner-sostituiti-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.toner-sostituiti-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.toner-sostituiti-page .page-head h1 {
    margin: 0 0 4px;
}

.toner-sostituiti-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.toner-sostituiti-page .top-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.toner-sostituiti-page .box {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.toner-sostituiti-page .summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.toner-sostituiti-page .summary-card {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 16px;
    text-align: center;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.toner-sostituiti-page .summary-danger {
    border-color: #fecaca;
    background: #fff7f7;
}

.toner-sostituiti-page .summary-number {
    display: block;
    font-size: 28px;
    font-weight: 800;
}

.toner-sostituiti-page .summary-label {
    display: block;
    margin-top: 6px;
    color: #666;
    font-size: 13px;
}

.toner-sostituiti-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.toner-sostituiti-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.toner-sostituiti-page .panel-badge {
    display: inline-flex;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    background: #f3f4f6;
    color: #444;
}

.toner-sostituiti-page .filters-form {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: end;
}

.toner-sostituiti-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 220px;
    max-width: 260px;
}

.toner-sostituiti-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.toner-sostituiti-page .form-row select {
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
}

.toner-sostituiti-page .table-wrap {
    overflow-x: auto;
}

.toner-sostituiti-page .table {
    width: 100%;
    min-width: 1150px;
    border-collapse: collapse;
}

.toner-sostituiti-page .table th,
.toner-sostituiti-page .table td {
    border: 1px solid #ddd;
    padding: 10px 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}

.toner-sostituiti-page .table th {
    background: #f8f8f8;
    white-space: nowrap;
}

.toner-sostituiti-page .sub-info {
    color: #666;
    font-size: 12px;
    margin-top: 2px;
}

.toner-sostituiti-page .row-danger td {
    background: #fff7f7;
}

.toner-sostituiti-page .empty-state {
    padding: 18px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

.toner-sostituiti-page .mini-badge,
.toner-sostituiti-page .color-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.toner-sostituiti-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.toner-sostituiti-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #444;
}

.toner-sostituiti-page .color-black {
    background: #2b2b2b;
    color: #fff;
}

.toner-sostituiti-page .color-magenta {
    background: #ffe4f1;
    color: #a41355;
}

.toner-sostituiti-page .color-cyan {
    background: #dcf8ff;
    color: #00738a;
}

.toner-sostituiti-page .color-yellow {
    background: #fff6bf;
    color: #806000;
}

.toner-sostituiti-page .color-neutral {
    background: #f3f4f6;
    color: #444;
}

@media (max-width: 900px) {
    .toner-sostituiti-page .summary-grid {
        grid-template-columns: 1fr;
    }

    .toner-sostituiti-page .form-row {
        max-width: none;
        width: 100%;
    }
}

/* ======================================================
   TONER SOSTITUITI - FILTRI CLIENTE / PARAMETRI
====================================================== */

.toner-sostituiti-page .form-row-wide {
    min-width: 320px;
    max-width: 520px;
    flex: 1 1 360px;
}

.toner-sostituiti-page .filter-actions {
    display: flex;
    align-items: end;
    gap: 8px;
}

.toner-sostituiti-page .params-box {
    background: #fafafa;
}

.toner-sostituiti-page .params-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.toner-sostituiti-page .param-item {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.toner-sostituiti-page .param-label {
    font-size: 12px;
    font-weight: 800;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .03em;
}

.toner-sostituiti-page .param-value {
    font-size: 22px;
    font-weight: 900;
    color: #111827;
}

@media (max-width: 1100px) {
    .toner-sostituiti-page .params-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .toner-sostituiti-page .params-grid {
        grid-template-columns: 1fr;
    }

    .toner-sostituiti-page .filter-actions,
    .toner-sostituiti-page .filter-actions .btn-outline {
        width: 100%;
    }
}

/* ======================================================
   FORGOT PASSWORD DEBUG
====================================================== */

.forgot-debug-box {
    width: min(980px, calc(100vw - 32px));
    margin: 18px auto 40px;
    background: #111827;
    color: #e5e7eb;
    border-radius: 14px;
    padding: 18px;
    border: 1px solid #374151;
}

.forgot-debug-box h2 {
    margin: 0 0 8px;
    color: #fff;
    font-size: 20px;
}

.forgot-debug-box p {
    margin: 0 0 14px;
    color: #cbd5e1;
}

.forgot-debug-box code {
    background: #0f172a;
    color: #fbbf24;
    padding: 2px 5px;
    border-radius: 5px;
}

.forgot-debug-box details {
    background: #0f172a;
    border: 1px solid #334155;
    border-radius: 10px;
    margin-top: 10px;
    overflow: hidden;
}

.forgot-debug-box summary {
    cursor: pointer;
    padding: 10px 12px;
    font-weight: 800;
    color: #f9fafb;
}

.forgot-debug-box pre {
    margin: 0;
    padding: 12px;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
    border-top: 1px solid #334155;
    color: #d1d5db;
    font-size: 12px;
    line-height: 1.45;
}

.forgot-debug-empty {
    padding: 12px;
    background: #0f172a;
    border: 1px dashed #475569;
    border-radius: 10px;
    color: #cbd5e1;
}

.auth-warning {
    background: #fff7ed;
    color: #9a3412;
    border: 1px solid #fed7aa;
}

/* ======================================================
   AUTH / FORGOT / RESET PASSWORD
====================================================== */

.auth-body {
    min-height: 100vh;
    margin: 0;
    background:
        radial-gradient(circle at top left, rgba(122, 31, 61, 0.22), transparent 34%),
        radial-gradient(circle at bottom right, rgba(122, 31, 61, 0.10), transparent 30%),
        linear-gradient(135deg, #f7f2f4 0%, #f3f4f6 45%, #ffffff 100%);
    color: #111827;
}

.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
    box-sizing: border-box;
}

.auth-card {
    width: min(480px, 100%);
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 22px;
    padding: 30px;
    box-shadow: 0 22px 60px rgba(17, 24, 39, 0.12);
    box-sizing: border-box;
}

.auth-logo {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 24px;
}

.auth-logo-icon {
    width: 54px;
    height: 54px;
    min-width: 54px;
    border-radius: 18px;
    background: #7a1f3d;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    box-shadow: 0 10px 24px rgba(122, 31, 61, 0.28);
}

.auth-logo h1 {
    margin: 0;
    font-size: 25px;
    font-weight: 850;
    color: #111827;
    line-height: 1.15;
}

.auth-logo p {
    margin: 4px 0 0;
    color: #6b7280;
    font-size: 14px;
}

.auth-form {
    display: grid;
    gap: 16px;
}

.auth-form .form-group {
    display: grid;
    gap: 7px;
}

.auth-form label {
    font-size: 13px;
    font-weight: 800;
    color: #374151;
}

.auth-form input {
    width: 100%;
    min-height: 46px;
    padding: 11px 13px;
    border: 1px solid #d1d5db;
    border-radius: 12px;
    font-size: 15px;
    box-sizing: border-box;
    background: #ffffff;
    color: #111827;
}

.auth-form input:focus {
    outline: none;
    border-color: #7a1f3d;
    box-shadow: 0 0 0 4px rgba(122, 31, 61, 0.12);
}

.auth-submit,
.auth-link-button {
    width: 100%;
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border-radius: 12px;
    font-weight: 800;
    text-decoration: none;
    box-sizing: border-box;
}

.auth-card .btn-primary,
.auth-submit {
    background: #7a1f3d;
    border: 1px solid #7a1f3d;
    color: #ffffff;
    cursor: pointer;
    transition:
        transform 0.15s ease,
        box-shadow 0.15s ease,
        background 0.15s ease,
        border-color 0.15s ease;
}

.auth-card .btn-primary:hover,
.auth-submit:hover {
    background: #651832;
    border-color: #651832;
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(122, 31, 61, 0.22);
}

.auth-card .btn-primary:active,
.auth-submit:active {
    transform: translateY(0);
    box-shadow: none;
}

.auth-links {
    margin-top: 18px;
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}

.auth-links a,
.auth-secondary-link {
    color: #7a1f3d;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.auth-links a:hover,
.auth-secondary-link:hover {
    text-decoration: underline;
}

.auth-alert {
    border-radius: 14px;
    padding: 13px 14px;
    margin-bottom: 18px;
    font-size: 14px;
    line-height: 1.45;
}

.auth-alert-success {
    background: #e8f7ee;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.auth-alert-error {
    background: #fdecea;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.forgot-password-page .auth-card,
.reset-password-page .auth-card {
    position: relative;
    overflow: hidden;
}

.forgot-password-page .auth-card::before,
.reset-password-page .auth-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, #7a1f3d, #b8325f, #7a1f3d);
}

.reset-user-box {
    border: 1px solid #e5e7eb;
    background: #f9fafb;
    border-radius: 14px;
    padding: 13px 14px;
    margin-bottom: 18px;
    display: grid;
    gap: 3px;
}

.reset-user-label {
    color: #6b7280;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.reset-user-box strong {
    color: #111827;
    font-size: 15px;
}

.reset-user-box small {
    color: #6b7280;
    font-size: 13px;
}

.password-rules {
    margin: 0;
    padding: 12px 14px;
    border-radius: 12px;
    background: #f9fafb;
    border: 1px dashed #d1d5db;
    color: #6b7280;
    font-size: 13px;
    line-height: 1.45;
}

.reset-expired-box {
    text-align: center;
    display: grid;
    gap: 14px;
}

.reset-expired-icon {
    width: 62px;
    height: 62px;
    margin: 0 auto 2px;
    border-radius: 22px;
    background: #fdecea;
    color: #991b1b;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
}

.reset-expired-box h2 {
    margin: 0;
    font-size: 22px;
    font-weight: 850;
    color: #111827;
}

.reset-expired-box p {
    margin: 0 0 4px;
    color: #6b7280;
    font-size: 14px;
    line-height: 1.5;
}

/* ======================================================
   MARCA FORM
====================================================== */

.marca-form-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.marca-form-page .summary-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.marca-form-page .summary-card {
    background: #ffffff;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: 14px;
    padding: 16px;
    box-shadow: var(--shadow-soft, 0 2px 8px rgba(0, 0, 0, 0.04));
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.marca-form-page .summary-number {
    font-size: 30px;
    font-weight: 850;
    line-height: 1;
    color: #111827;
}

.marca-form-page .summary-label {
    font-size: 13px;
    color: #6b7280;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.marca-form-page .section-title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 16px;
}

.marca-form-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
    font-weight: 850;
    color: #111827;
}

.marca-form-page .section-subtitle {
    margin: 4px 0 0;
    color: #6b7280;
    font-size: 14px;
}

.marca-form-page .table-wrap {
    overflow-x: auto;
}

.marca-form-page .table {
    width: 100%;
    border-collapse: collapse;
}

.marca-form-page .table th,
.marca-form-page .table td {
    border: 1px solid #e5e7eb;
    padding: 10px 12px;
    text-align: left;
    vertical-align: middle;
    font-size: 14px;
}

.marca-form-page .table th {
    background: #f9fafb;
    font-weight: 800;
    color: #374151;
    white-space: nowrap;
}

.marca-form-page .table tbody tr:hover td {
    background: #fafafa;
}

.marca-form-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    padding: 6px 10px;
    white-space: nowrap;
}

.marca-form-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.marca-form-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.marca-form-page .marca-form-box {
    max-width: 760px;
}

.marca-form-page .form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.marca-form-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.marca-form-page .form-row label {
    font-size: 13px;
    font-weight: 800;
    color: #374151;
}

.marca-form-page input {
    width: 100%;
    min-height: 44px;
    padding: 10px 12px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 10px;
    font-size: 14px;
    box-sizing: border-box;
    background: #ffffff;
}

.marca-form-page input:focus {
    outline: none;
    border-color: var(--color-primary, #7a1f3d);
    box-shadow: 0 0 0 3px rgba(122, 31, 61, 0.12);
}

.marca-form-page .field-help {
    color: #6b7280;
    font-size: 12px;
}

/* Pulsanti Annulla / Salva marca */
.marca-form-page .form-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
    margin-top: 20px;
}

.marca-form-page .form-actions .btn-outline,
.marca-form-page .form-actions .btn-primary {
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-sizing: border-box;
    cursor: pointer;
}

.marca-form-page .form-actions .btn-outline {
    background: #ffffff;
    color: #374151;
    border: 1px solid #d1d5db;
}

.marca-form-page .form-actions .btn-outline:hover {
    background: #f9fafb;
    border-color: #9ca3af;
}

.marca-form-page .form-actions .btn-primary {
    background: var(--color-primary, #7a1f3d);
    color: #ffffff;
    border: 1px solid var(--color-primary, #7a1f3d);
}

.marca-form-page .form-actions .btn-primary:hover {
    background: #651832;
    border-color: #651832;
}

@media (max-width: 900px) {
    .marca-form-page .summary-cards {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .marca-form-page .section-title-row {
        flex-direction: column;
    }

    .marca-form-page .form-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .marca-form-page .form-actions .btn-outline,
    .marca-form-page .form-actions .btn-primary {
        width: 100%;
    }
}

/* ======================================================
   GESTIONE EVASIONE CONSUMABILI - ORDINI COMPATTI
====================================================== */

.gestione-evasione-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.gestione-evasione-page .page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}

.gestione-evasione-page .page-head h1 {
    margin: 0 0 4px;
}

.gestione-evasione-page .page-subtitle {
    margin: 0;
    color: #666;
    font-size: 15px;
}

.gestione-evasione-page .top-actions,
.gestione-evasione-page .filters-actions,
.gestione-evasione-page .pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.gestione-evasione-page .box,
.gestione-evasione-page .summary-card,
.gestione-evasione-page .order-card {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.gestione-evasione-page .summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.gestione-evasione-page .summary-card {
    padding: 16px;
    text-align: center;
}

.gestione-evasione-page .summary-number {
    display: block;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.1;
}

.gestione-evasione-page .summary-label {
    display: block;
    margin-top: 6px;
    color: #666;
    font-size: 13px;
}

.gestione-evasione-page .section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.gestione-evasione-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
}

.gestione-evasione-page .panel-badge,
.gestione-evasione-page .mini-badge,
.gestione-evasione-page .color-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 10px;
    white-space: nowrap;
}

.gestione-evasione-page .panel-badge,
.gestione-evasione-page .mini-badge.neutral,
.gestione-evasione-page .color-neutral {
    background: #f3f4f6;
    color: #444;
}

.gestione-evasione-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.gestione-evasione-page .mini-badge.warning {
    background: #fff1cc;
    color: #8a5a00;
}

.gestione-evasione-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.gestione-evasione-page .color-black {
    background: #2b2b2b;
    color: #fff;
}

.gestione-evasione-page .color-magenta {
    background: #ffe4f1;
    color: #a41355;
}

.gestione-evasione-page .color-cyan {
    background: #dcf8ff;
    color: #00738a;
}

.gestione-evasione-page .color-yellow {
    background: #fff6bf;
    color: #806000;
}

.gestione-evasione-page .filters-form .form-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 14px;
}

.gestione-evasione-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.gestione-evasione-page .form-row-wide {
    grid-column: span 3;
}

.gestione-evasione-page .form-row label {
    font-size: 13px;
    font-weight: 700;
    color: #444;
}

.gestione-evasione-page .form-row input,
.gestione-evasione-page .form-row select,
.gestione-evasione-page .action-note {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.gestione-evasione-page .filters-actions {
    margin-top: 16px;
    gap: 10px;
}

.gestione-evasione-page .orders-list {
    display: grid;
    gap: 14px;
}

.gestione-evasione-page .order-card {
    padding: 0;
    overflow: visible;
}

.gestione-evasione-page .order-head {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(230px, 0.8fr) auto;
    gap: 14px;
    padding: 14px 16px;
    background: #fafafa;
    border-bottom: 1px solid #e5e7eb;
    align-items: center;
}

.gestione-evasione-page .order-title-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.gestione-evasione-page .order-id {
    font-size: 18px;
    font-weight: 800;
    color: #222;
}

.gestione-evasione-page .order-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 7px;
    color: #666;
    font-size: 13px;
}

.gestione-evasione-page .order-client-block {
    display: flex;
    flex-direction: column;
    gap: 3px;
    text-align: right;
    min-width: 0;
}

.gestione-evasione-page .order-client-block strong {
    color: #222;
}

.gestione-evasione-page .order-client-block span,
.gestione-evasione-page .order-client-block small {
    color: #666;
}

.gestione-evasione-page .order-links-block {
    display: flex;
    justify-content: flex-end;
}

.gestione-evasione-page .order-note {
    margin: 12px 16px 0;
    padding: 10px 12px;
    border-radius: 10px;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    color: #555;
    font-size: 13px;
}

.gestione-evasione-page .order-lines-table-wrap {
    padding: 14px 16px 16px;
    overflow-x: auto;
}

.gestione-evasione-page .order-lines-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 1100px;
}

.gestione-evasione-page .order-lines-table th,
.gestione-evasione-page .order-lines-table td {
    border: 1px solid #e5e7eb;
    padding: 9px 10px;
    vertical-align: top;
    font-size: 13px;
}

.gestione-evasione-page .order-lines-table th {
    background: #f9fafb;
    font-weight: 800;
    color: #374151;
    white-space: nowrap;
}

.gestione-evasione-page .order-lines-table tr.line-shipped td {
    background: #fbfffc;
}

.gestione-evasione-page .order-lines-table tr.line-not-shipped td {
    background: #fafafa;
}

.gestione-evasione-page .material-cell {
    min-width: 240px;
}

.gestione-evasione-page .material-cell strong,
.gestione-evasione-page .material-cell span,
.gestione-evasione-page .material-cell small {
    display: block;
}

.gestione-evasione-page .material-cell strong {
    color: #222;
    font-size: 14px;
}

.gestione-evasione-page .material-cell span {
    color: #333;
    margin-top: 2px;
}

.gestione-evasione-page .material-cell small {
    color: #777;
    margin-top: 2px;
}

.gestione-evasione-page .badges-cell {
    min-width: 150px;
}

.gestione-evasione-page .badges-cell .color-badge,
.gestione-evasione-page .badges-cell .mini-badge {
    margin: 0 4px 4px 0;
}

.gestione-evasione-page .qty-cell {
    min-width: 150px;
}

.gestione-evasione-page .qty-cell div {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    border-bottom: 1px dashed #e5e7eb;
    padding: 2px 0;
}

.gestione-evasione-page .qty-cell div:last-child {
    border-bottom: 0;
}

.gestione-evasione-page .qty-cell span {
    color: #777;
    font-weight: 700;
}

.gestione-evasione-page .level-cell {
    min-width: 110px;
    font-weight: 800;
}

.gestione-evasione-page .level-cell small {
    display: block;
    margin-top: 3px;
    color: #777;
    font-weight: 400;
}

.gestione-evasione-page .notes-cell {
    min-width: 230px;
    color: #555;
}

.gestione-evasione-page .notes-cell div + div {
    margin-top: 5px;
}

.gestione-evasione-page .actions-cell {
    min-width: 210px;
}

.gestione-evasione-page .actions-details {
    position: relative;
}

.gestione-evasione-page .actions-details summary {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 7px 11px;
    border-radius: 8px;
    background: #222;
    color: #fff;
    font-weight: 800;
    list-style: none;
}

.gestione-evasione-page .actions-details summary::-webkit-details-marker {
    display: none;
}

.gestione-evasione-page .actions-panel {
    display: grid;
    gap: 8px;
    margin-top: 8px;
    padding: 10px;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
}

.gestione-evasione-page .line-action-form {
    display: grid;
    gap: 5px;
}

.gestione-evasione-page .action-note {
    padding: 7px 8px;
    font-size: 12px;
}

.gestione-evasione-page .line-no-actions {
    color: #777;
    font-size: 13px;
}

.gestione-evasione-page .empty-state,
.gestione-evasione-page .compact-empty {
    padding: 16px;
    border: 1px dashed #ccc;
    border-radius: 12px;
    background: #fafafa;
    color: #555;
}

.gestione-evasione-page .compact-empty {
    margin: 14px 16px 16px;
}

.gestione-evasione-page .msg {
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    border: 1px solid transparent;
}

.gestione-evasione-page .msg-success {
    background: #f0fdf4;
    border-color: #bbf7d0;
    color: #166534;
}

.gestione-evasione-page .msg-error {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

.gestione-evasione-page .btn-outline,
.gestione-evasione-page .btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    cursor: pointer;
    transition: 0.2s;
    text-align: center;
    border: 1px solid transparent;
    box-sizing: border-box;
    font-weight: 700;
}

.gestione-evasione-page .btn-outline {
    border-color: #888;
    color: #222;
    background: #fff;
}

.gestione-evasione-page .btn-outline:hover {
    background: #f5f5f5;
}

.gestione-evasione-page .btn-primary {
    border-color: #222;
    color: #fff;
    background: #222;
}

.gestione-evasione-page .btn-primary:hover {
    background: #111;
    border-color: #111;
}

.gestione-evasione-page .btn-sm {
    padding: 7px 10px;
    font-size: 13px;
    min-height: 34px;
}

.gestione-evasione-page button:disabled,
.gestione-evasione-page .btn-outline:disabled,
.gestione-evasione-page .btn-primary:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    transform: none;
}

.gestione-evasione-page .danger-action {
    border-color: #dc2626;
    color: #991b1b;
}

.gestione-evasione-page .danger-action:hover:not(:disabled) {
    background: #fef2f2;
}

.gestione-evasione-page .pagination {
    margin-top: 18px;
    gap: 6px;
}

.gestione-evasione-page .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    padding: 8px 10px;
    text-align: center;
    border: 1px solid #ccc;
    border-radius: 6px;
    text-decoration: none;
    color: #222;
    background: #fff;
}

.gestione-evasione-page .page-link.active {
    background: #222;
    color: #fff;
    border-color: #222;
}

@media (max-width: 1400px) {
    .gestione-evasione-page .filters-form .form-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .gestione-evasione-page .summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .gestione-evasione-page .order-head {
        grid-template-columns: 1fr;
    }

    .gestione-evasione-page .order-client-block {
        text-align: left;
    }

    .gestione-evasione-page .order-links-block {
        justify-content: flex-start;
    }
}

@media (max-width: 800px) {
    .gestione-evasione-page .filters-form .form-grid,
    .gestione-evasione-page .summary-grid {
        grid-template-columns: 1fr;
    }

    .gestione-evasione-page .form-row-wide {
        grid-column: auto;
    }

    .gestione-evasione-page .page-head {
        flex-direction: column;
        align-items: stretch;
    }

    .gestione-evasione-page .filters-actions,
    .gestione-evasione-page .top-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .gestione-evasione-page .btn-outline,
    .gestione-evasione-page .btn-primary {
        width: 100%;
    }
}

/* ======================================================
   CRON MANAGEMENT
====================================================== */

.cron-management-page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.cron-management-page .summary-cards-3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.cron-management-page .summary-card {
    background: #ffffff;
    border: 1px solid var(--color-border, #e5e7eb);
    border-radius: 14px;
    padding: 16px;
    box-shadow: var(--shadow-soft, 0 2px 8px rgba(0, 0, 0, 0.04));
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cron-management-page .summary-number {
    font-size: 30px;
    font-weight: 850;
    line-height: 1;
    color: #111827;
}

.cron-management-page .summary-label {
    font-size: 13px;
    color: #6b7280;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.cron-management-page .section-title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 16px;
}

.cron-management-page .section-title-row h2 {
    margin: 0;
    font-size: 20px;
    font-weight: 850;
    color: #111827;
}

.cron-management-page .section-subtitle {
    margin: 4px 0 0;
    color: #6b7280;
    font-size: 14px;
}

.cron-management-page .info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.cron-management-page .info-item {
    border: 1px solid #e5e7eb;
    background: #f9fafb;
    border-radius: 12px;
    padding: 12px;
    display: grid;
    gap: 5px;
    min-width: 0;
}

.cron-management-page .info-label {
    font-size: 12px;
    color: #6b7280;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.cron-management-page .info-value {
    font-size: 13px;
    font-weight: 800;
    color: #111827;
    word-break: break-all;
}

.cron-management-page .small-muted {
    color: #6b7280;
    font-size: 12px;
}

.cron-management-page .cron-jobs-list {
    display: grid;
    gap: 14px;
}

.cron-management-page .cron-job-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 16px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    border-radius: 14px;
    padding: 16px;
}

.cron-management-page .cron-job-card.is-disabled {
    background: #fafafa;
}

.cron-management-page .cron-job-title-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}

.cron-management-page .cron-job-title-row h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 850;
    color: #111827;
}

.cron-management-page .cron-job-main p {
    margin: 0 0 10px;
    color: #4b5563;
    font-size: 14px;
    line-height: 1.45;
}

.cron-management-page .cron-job-meta {
    display: grid;
    gap: 4px;
    font-size: 12px;
    color: #6b7280;
    word-break: break-all;
}

.cron-management-page .cron-job-controls {
    display: grid;
    gap: 10px;
    align-content: start;
}

.cron-management-page .switch-row {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 800;
    color: #374151;
}

.cron-management-page .switch-row input {
    width: 18px;
    height: 18px;
}

.cron-management-page .form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.cron-management-page .form-row label {
    font-size: 12px;
    font-weight: 800;
    color: #374151;
}

.cron-management-page select,
.cron-management-page input[type="text"] {
    width: 100%;
    min-height: 42px;
    padding: 9px 11px;
    border: 1px solid var(--color-border, #d1d5db);
    border-radius: 10px;
    background: #ffffff;
    font-size: 14px;
    box-sizing: border-box;
}

.cron-management-page select:focus,
.cron-management-page input[type="text"]:focus {
    outline: none;
    border-color: var(--color-primary, #7a1f3d);
    box-shadow: 0 0 0 3px rgba(122, 31, 61, 0.12);
}

.cron-management-page .mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    padding: 6px 10px;
    white-space: nowrap;
}

.cron-management-page .mini-badge.success {
    background: #e8f7ee;
    color: #1f7a3f;
}

.cron-management-page .mini-badge.neutral {
    background: #f3f4f6;
    color: #4b5563;
}

.cron-management-page .mini-badge.danger {
    background: #fdecea;
    color: #b42318;
}

.cron-management-page .form-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 18px;
}

.cron-management-page .cron-log-pre {
    margin: 0;
    max-height: 420px;
    overflow: auto;
    background: #111827;
    color: #e5e7eb;
    border-radius: 14px;
    padding: 14px;
    font-size: 12px;
    line-height: 1.45;
    white-space: pre-wrap;
    word-break: break-word;
}

.cron-management-page .danger-zone {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    border-color: #fecaca;
    background: #fff7f7;
}

.cron-management-page .danger-zone h2 {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 850;
    color: #991b1b;
}

.cron-management-page .danger-zone p {
    margin: 0;
    color: #7f1d1d;
    font-size: 14px;
}

@media (max-width: 1100px) {
    .cron-management-page .cron-job-card {
        grid-template-columns: 1fr;
    }

    .cron-management-page .info-grid,
    .cron-management-page .summary-cards-3 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .cron-management-page .section-title-row,
    .cron-management-page .danger-zone {
        flex-direction: column;
        align-items: stretch;
    }

    .cron-management-page .form-actions {
        justify-content: stretch;
    }

    .cron-management-page .form-actions .btn-primary,
    .cron-management-page .danger-zone .btn-outline {
        width: 100%;
        text-align: center;
    }
}


