/* =============================================================
   FEBOSOFT ERP — DESIGN SYSTEM 2025
   Pulito e consolidato — zero ridefinizioni, zero codice morto
   ============================================================= */

/* ── VARIABILI GLOBALI ──────────────────────────────────────── */
:root {
    --fb-navy:       #0f2540;
    --fb-blue:       #1e3a5f;
    --fb-blue-mid:   #2a527d;
    --fb-sky:        #42a5f5;
    --fb-accent:     #4a90c4;
    --fb-green:      #2e7d5e;
    --fb-red:        #f44336;
    --fb-orange:     #ff9800;

    --fb-bg:         #f0f4f8;
    --fb-surface:    #ffffff;
    --fb-surface-2:  #f7fafd;
    --fb-border:     #dce6f0;
    --fb-text:       #1a2a3a;
    --fb-text-muted: #607890;

    --fb-row-odd:    #e8f1f8;
    --fb-row-even:   #f7fafd;
    --fb-row-hover:  #bbdefb;
    --fb-thead-bg:   #1e3a5f;
    --fb-thead-2:    #c62828;

    --fb-radius:     6px;
    --fb-radius-lg:  10px;
    --fb-shadow:     0 2px 12px rgba(13,31,60,.10);
    --fb-shadow-md:  0 4px 20px rgba(13,31,60,.15);

    --fb-font:       'Segoe UI', system-ui, -apple-system, sans-serif;
    --fb-mono:       'Consolas', 'Courier New', monospace;
    --fb-transition: 0.18s ease;
}

/* ── RESET BASE ─────────────────────────────────────────────── */
body {
    font-family: var(--fb-font) !important;
    background-color: var(--fb-bg) !important;
    color: var(--fb-text) !important;
    font-size: 13px !important;
    line-height: 1.55 !important;
    -webkit-font-smoothing: antialiased;
}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.wrapper       { background-color: var(--fb-bg) !important; }
.content-wrapper {
    background-color: var(--fb-bg) !important;
    min-height: 100vh !important;
}

/* ── NAVBAR / HEADER ────────────────────────────────────────── */
.main-header {
    max-height: 54px !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.18) !important;
}

.skin-blue-light .main-header .logo,
.skin-blue-light .main-header .logo:hover,
.skin-green .main-header .logo,
.skin-green .main-header .logo:hover {
    background-color: var(--fb-navy) !important;
    color: var(--fb-accent) !important;
    border-bottom: none !important;
    font-weight: 800 !important;
    letter-spacing: 0.05em !important;
    font-size: 15px !important;
    height: 54px !important;
    line-height: 54px !important;
}

.main-header .logo {
    height: 54px !important;
    line-height: 54px !important;
}

/* Se ci sono immagini nel logo, invertiamo i colori per adattarli al tema scuro TOLTO SOLO PER SUN ECO POWER * /

/* .main-header .logo img,
.skin-blue-light .main-header .logo .logo-mini img {
    filter: brightness(0) invert(1) !important;
},
.skin-blue-light .main-header .logo .logo-lg img {
    filter: brightness(0) invert(1) !important;
} */

.skin-blue-light .main-header .navbar,
.skin-green .main-header .navbar {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    border-bottom: none !important;
    box-shadow: none !important;
    min-height: 54px !important;
}

.skin-blue-light .main-header .navbar .nav > li > a,
.skin-green .main-header .navbar .nav > li > a {
    color: rgba(255,255,255,.80) !important;
    line-height: 54px !important;
    padding: 0 15px !important;
    transition: color var(--fb-transition), background var(--fb-transition) !important;
}

.skin-blue-light .main-header .navbar .nav > li > a:hover,
.skin-green .main-header .navbar .nav > li > a:hover {
    background: rgba(255,255,255,.12) !important;
    color: #fff !important;
}

.main-header .navbar .nav > li > a > .label,
.main-header .navbar .nav > li > a > .badge {
    background-color: var(--fb-accent) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    border-radius: 10px !important;
    padding: 2px 6px !important;
}

.sidebar-toggle {
    color: rgba(255,255,255,.80) !important;
    font-size: 15px !important;
    /*line-height: 54px !important;*/
    transition: background var(--fb-transition) !important;
}

.sidebar-toggle:hover {
    background: rgba(255,255,255,.10) !important;
    color: #fff !important;
}

/* ── SIDEBAR ───────────────────────── */
.main-sidebar {
    background-color: #ffffff !important;
    border-right: 1px solid var(--fb-border) !important;
    box-shadow: 2px 0 12px rgba(13,31,60,.08) !important;
    position: fixed !important;
    top: 0;
    bottom: 0;
    height: 100% !important;
    min-height: 100vh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important; /* Questo taglia i menu */
    width: 230px;
}

.sidebar {
    padding-top: 6px !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important; /* Questo taglia i menu */
}

.sidebar::-webkit-scrollbar { width: 3px !important; }
.sidebar::-webkit-scrollbar-thumb {
    background: #c5d5e8 !important;
    border-radius: 3px !important;
}

/* ── COLLAPSED ────────────────────────────────── */

/* Quando è contratta, dobbiamo "aprire" i cancelli dell'overflow */
.sidebar-collapse .main-sidebar,
.sidebar-collapse .sidebar {
    /* Permettiamo ai contenuti di uscire lateralmente */
    overflow: visible !important; 
    overflow-x: visible !important;
}

/* I sottomenu devono essere posizionati in modo da sovrapporsi a tutto */
.sidebar-collapse .treeview-menu {
    position: absolute !important;
    left: 100% !important; /* Si attacca al bordo destro della sidebar */
    top: 0 !important;
    width: 200px !important;
    background: #ffffff !important;
    border: 1px solid var(--fb-border) !important;
    box-shadow: 5px 0 15px rgba(0,0,0,0.1) !important;
    display: none; 
    z-index: 9999 !important;
}

/* Forza la visualizzazione al passaggio del mouse */
.sidebar-collapse .sidebar-menu li:hover > .treeview-menu {
    display: block !important;
}

/* User panel */
.user-panel {
    background: linear-gradient(135deg, #f0f6fc 0%, #e8f1f8 100%) !important;
    border-bottom: 1px solid var(--fb-border) !important;
    padding: 14px 12px !important;
    margin-bottom: 6px !important;
}
.user-panel .info p {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--fb-navy) !important;
    margin-bottom: 2px !important;
}
.user-panel .info a {
    font-size: 11.5px !important;
    color: var(--fb-text-muted) !important;
}

/* Intestazioni sezione */
.sidebar-menu > li.header {
    color: #aab8c8 !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    padding: 16px 15px 5px !important;
    background: transparent !important;
}

/* Voci primo livello */
.sidebar-menu > li > a {
    color: #2c3e55 !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 11px 15px !important;
    border-left: 3px solid transparent !important;
    background: transparent !important;
    transition: all var(--fb-transition) !important;
}
.sidebar-menu > li > a:hover {
    background: #eef4fb !important;
    color: var(--fb-blue) !important;
    border-left-color: var(--fb-sky) !important;
}
.sidebar-menu > li.active > a,
.sidebar-menu > li.menu-open > a {
    background: #dbedf8 !important;
    color: var(--fb-navy) !important;
    border-left-color: var(--fb-accent) !important;
    font-weight: 700 !important;
}

/* Icone primo livello */
.sidebar-menu > li > a > .fa {
    color: #7a9ab8 !important;
    margin-right: 10px !important;
    font-size: 13.5px !important;
    width: 16px !important;
    text-align: center !important;
    transition: color var(--fb-transition) !important;
}
.sidebar-menu > li.active > a > .fa,
.sidebar-menu > li.menu-open > a > .fa,
.sidebar-menu > li > a:hover > .fa { color: var(--fb-accent) !important; }

/* Colori speciali icone */
.sidebar-menu > li > a > .fa.text-green   { color: #2e7d5e !important; }
.sidebar-menu > li > a > .fa.text-blue    { color: var(--fb-accent) !important; }
.sidebar-menu > li > a > .fa.text-yellow  { color: #f39c12 !important; }
.sidebar-menu > li > a > .fa.text-red     { color: #f44336 !important; }
.sidebar-menu > li > a > .fa.text-maroon  { color: #d81b60 !important; }
.sidebar-menu > li > a > .fa.text-teal    { color: #00c0ef !important; }
.sidebar-menu > li > a > .fa.text-fuchsia { color: #f012be !important; }

/* Freccia treeview */
.sidebar-menu > li > a > .fa-angle-left {
    color: #b0c4d8 !important;
    transition: transform 0.2s ease !important;
}
.sidebar-menu > li.menu-open > a > .fa-angle-left {
    transform: rotate(-90deg) !important;
    color: var(--fb-accent) !important;
}

/* Sottomenu */
.treeview-menu {
    background: #f4f9fd !important;
    border-left: 3px solid var(--fb-accent) !important;
    padding: 4px 0 !important;
}
.treeview-menu > li > a {
    color: #3d5266 !important;
    font-size: 12.5px !important;
    font-weight: 400 !important;
    padding: 8px 14px 8px 34px !important;
    background: transparent !important;
    transition: all var(--fb-transition) !important;
    border-left: none !important;
}
.treeview-menu > li > a:hover {
    background: #dbedf8 !important;
    color: var(--fb-navy) !important;
}
.treeview-menu > li.active > a,
.treeview-menu > li > a.active {
    color: var(--fb-navy) !important;
    font-weight: 700 !important;
    background: #cce4f5 !important;
}
.treeview-menu > li > a > .fa {
    color: #95afc0 !important;
    margin-right: 7px !important;
    font-size: 11px !important;
}

/* Terzo livello */
.treeview-menu .treeview-menu {
    background: #eaf2f8 !important;
    border-left: 2px solid #aacde6 !important;
}
.treeview-menu .treeview-menu > li > a {
    padding-left: 48px !important;
    font-size: 12px !important;
    color: #4a6070 !important;
}

/* ── CONTENT HEADER ─────────────────────────────────────────── */
.content-header {
    background: var(--fb-surface) !important;
    border-bottom: 1px solid var(--fb-border) !important;
    padding: 14px 20px !important;
    margin-bottom: 18px !important;
}
.content-header h1 {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--fb-navy) !important;
    letter-spacing: -0.01em !important;
}
.content-header .breadcrumb {
    background: transparent !important;
    font-size: 12px !important;
    color: var(--fb-text-muted) !important;
}
.content-header .breadcrumb > .active {
    color: var(--fb-blue) !important;
    font-weight: 600 !important;
}

/* ── BOX / CARD ─────────────────────────────────────────────── */
.box {
    background: var(--fb-surface) !important;
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: var(--fb-shadow) !important;
    margin-bottom: 20px !important;
    transition: box-shadow var(--fb-transition) !important;
    border-top: none !important;
}
.box:hover { box-shadow: var(--fb-shadow-md) !important; }

.box-header {
    padding: 14px 18px !important;
    border-bottom: 1px solid var(--fb-border) !important;
    background: transparent !important;
    border-radius: var(--fb-radius-lg) var(--fb-radius-lg) 0 0 !important;
}
.box-header.with-border { border-bottom: 1px solid var(--fb-border) !important; }
.box-header .box-title {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--fb-navy) !important;
}
.box-body {
    padding: 16px !important;
    border-radius: 0 0 var(--fb-radius-lg) var(--fb-radius-lg) !important;
}
.box-footer {
    background: var(--fb-surface-2) !important;
    border-top: 1px solid var(--fb-border) !important;
    border-radius: 0 0 var(--fb-radius-lg) var(--fb-radius-lg) !important;
    padding: 12px 16px !important;
}

/* Strisce colorate box */
.box.box-primary { border-top: 3px solid var(--fb-blue) !important; }
.box.box-info    { border-top: 3px solid var(--fb-sky) !important; }
.box.box-success { border-top: 3px solid var(--fb-green) !important; }
.box.box-danger  { border-top: 3px solid var(--fb-red) !important; }
.box.box-warning { border-top: 3px solid var(--fb-orange) !important; }

/* ── TABELLE ────────────────────────────────────────────────── */
.table {
    font-size: 12.5px !important;
    margin-bottom: 0 !important;
}

.table > thead > tr > th,
.table > thead > tr > td {
    font-size: 13.5px !important;
    font-weight: 700 !important;
  /*   text-transform: uppercase !important; */
    letter-spacing: 0.04em !important;
    padding: 12px 8px !important;
    vertical-align: middle !important;
    /* white-space: nowrap !important; */
    border-bottom: 2px solid rgba(255,255,255,.20) !important;
}

/* Colonne icona a larghezza fissa */
.table > thead > tr > th[style*="font-size: 0"],
.table > thead > tr > th[style*="font-size:0"],
.table th.all[style*="font-size: 0"],
.table th.all[style*="font-size:0"] {
    padding: 4px 3px !important;
    width: 1px !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    font-size: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    overflow: hidden !important;
}

.table > tbody > tr > td {
    font-size: 14px !important;
    padding: 8px 10px !important;
    vertical-align: middle !important;
    border-top: 1px solid var(--fb-border) !important;
    transition: background var(--fb-transition) !important;
    line-height: 1.5 !important;
    color: #333 !important;
}

/* table-striped */
.table-striped > thead > tr {
    background-color: var(--fb-thead-bg) !important;
    color: #fff !important;
}
.table-striped > tbody > tr:nth-of-type(odd)  { background-color: var(--fb-row-odd)}
.table-striped > tbody > tr:nth-of-type(even) { background-color: var(--fb-row-even)}
.table-striped .group-title {
    background-color: rgba(255, 152, 0, 0.18) !important;
    font-weight: 700 !important;
    border-left: 3px solid var(--fb-orange) !important;
}

/* table2-striped (header rosso) */
.table2-striped > thead > tr {
    background-color: var(--fb-thead-2) !important;
    color: #fff !important;
}
.table2-striped > tbody > tr:nth-of-type(odd)  { background-color: var(--fb-row-odd)}
.table2-striped > tbody > tr:nth-of-type(even) { background-color: var(--fb-row-even)}
.table2-striped .group-title {
    background-color: rgba(255, 152, 0, 0.18) !important;
    font-weight: 700 !important;
}

/* hover */
.table-hover > tbody > tr:hover,
.table2-hover > tbody > tr:hover {
    background-color: var(--fb-row-hover) !important;
    cursor: pointer;
}

/* table-bordered */
.table-bordered,
.table-bordered > thead > tr > th,
.table-bordered > thead > tr > td,
.table-bordered > tbody > tr > td {
    border-color: var(--fb-border) !important;
}

/* table-bordered_report */
.table-bordered_report > thead > tr > th,
.table-bordered_report > tbody > tr > th,
.table-bordered_report > tfoot > tr > th,
.table-bordered_report > thead > tr > td,
.table-bordered_report > tbody > tr > td,
.table-bordered_report > tfoot > tr > td {
    border: 1px solid #000000;
}

/* Link dentro DataTable */
.dataTable a {
    color: var(--fb-blue) !important;
    text-decoration: none !important;
    font-size: inherit !important;
    font-weight: 600 !important;
    transition: color var(--fb-transition) !important;
}
.dataTable a:hover {
    color: var(--fb-sky) !important;
    text-decoration: underline !important;
}

/* Frecce ordinamento DataTables */
table.dataTable thead .sorting_desc:after {
    content: "\e156";
    opacity: 1 !important;
    color: var(--fb-accent) !important;
}
table.dataTable thead .sorting_asc:after {
    content: "\e155";
    opacity: 1 !important;
    color: var(--fb-accent) !important;
}

/* ── DATATABLE WRAPPER ──────────────────────────────────────── */
.dataTables_wrapper { font-size: 13px !important; }

div.dataTables_filter {
    float: right !important;
    margin-right: 0 !important;
}
div.dataTables_filter label,
div.dataTables_length label {
    font-weight: 500 !important;
    color: var(--fb-text-muted) !important;
    font-size: 12.5px !important;
}
div.dataTables_filter input,
div.dataTables_length select {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius) !important;
    padding: 5px 10px !important;
    font-size: 12.5px !important;
    outline: none !important;
    transition: border-color var(--fb-transition), box-shadow var(--fb-transition) !important;
}
div.dataTables_filter input:focus,
div.dataTables_length select:focus {
    border-color: var(--fb-blue) !important;
    box-shadow: 0 0 0 3px rgba(21,101,192,.12) !important;
}
.dataTables_info {
    font-size: 12px !important;
    color: var(--fb-text-muted) !important;
}
.dataTables_paginate .paginate_button {
    border-radius: var(--fb-radius) !important;
    font-size: 12.5px !important;
    transition: all var(--fb-transition) !important;
}
.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
    background: var(--fb-blue) !important;
    border-color: var(--fb-blue) !important;
    color: #fff !important;
}
.dataTables_paginate .paginate_button:hover:not(.current) {
    background: var(--fb-row-hover) !important;
    border-color: var(--fb-border) !important;
    color: var(--fb-blue) !important;
}

/* ── DATATABLES RESPONSIVE: expand/collapse ─────────────────── */
table.dataTable.dtr-inline.collapsed > tbody > tr[role="row"] > td:first-child,
table.dataTable.dtr-inline.collapsed > tbody > tr[role="row"] > th:first-child {
    padding-left: 32px !important;
    position: relative !important;
}

table.dataTable.dtr-inline.collapsed > tbody > tr[role="row"] > td:first-child::before,
table.dataTable.dtr-inline.collapsed > tbody > tr[role="row"] > th:first-child::before {
    background-color: #2e7d5e !important;
    border: none !important;
    border-radius: 50% !important;
    width: 18px !important;
    height: 18px !important;
    line-height: 18px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    left: 5px !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.25) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #fff !important;
}

table.dataTable.dtr-inline.collapsed > tbody > tr.shown[role="row"] > td:first-child::before,
table.dataTable.dtr-inline.collapsed > tbody > tr.shown[role="row"] > th:first-child::before {
    background-color: #1e88e5 !important;
    content: '-' !important;
    font-size: 20px !important;
    line-height: 16px !important;
}

/* ── DETAILS-CONTROL (expand manuale via JS) ────────────────── */
table tbody tr td.details-control,
td.details-control {
    background-image: none !important;
    background: transparent !important;
    padding: 0 5px !important;
    width: 28px !important;
    min-width: 28px !important;
    max-width: 28px !important;
    text-align: center !important;
    vertical-align: middle !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    border-right: 1px solid var(--fb-border) !important;
    background-size: 0 !important;
}

table tbody tr td.details-control::before,
td.details-control::before {
    content: "\f067" !important;
    font-family: 'FontAwesome' !important;
    font-style: normal !important;
    font-weight: 900 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 22px !important;
    height: 22px !important;
    border-radius: 50% !important;
    background-color: #2e7d5e !important;
    color: #fff !important;
    font-size: 10px !important;
    line-height: 1 !important;
    box-shadow: 0 1px 5px rgba(0,0,0,.20) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease !important;
    vertical-align: middle !important;
}
table tbody tr td.details-control:hover::before,
td.details-control:hover::before {
    background-color: #1d5c43 !important;
    transform: scale(1.18) !important;
    box-shadow: 0 3px 10px rgba(0,200,117,.40) !important;
}
table tbody tr.shown td.details-control::before,
tr.shown td.details-control::before {
    content: "\f068" !important;
    background-color: #1e88e5 !important;
    box-shadow: 0 1px 5px rgba(21,101,192,.30) !important;
}
table tbody tr.shown td.details-control:hover::before,
tr.shown td.details-control:hover::before {
    background-color: #1565c0 !important;
    transform: scale(1.18) !important;
}

/* ── SELEZIONE MULTIPLA RIGHE ───────────────────────────────── */
table.dataTable tbody tr.selected,
.table-striped > tbody > tr.selected,
.table-striped > tbody > tr.selected:nth-of-type(odd),
.table-striped > tbody > tr.selected:nth-of-type(even),
.table > tbody > tr.selected {
    background-color: #bbdefb !important;
    outline: 2px solid var(--fb-blue) !important;
    outline-offset: -2px !important;
    position: relative !important;
}
table.dataTable tbody tr.selected > td,
.table > tbody > tr.selected > td {
    background-color: #bbdefb !important;
    color: var(--fb-navy) !important;
    font-weight: 600 !important;
}
table.dataTable tbody tr.selected:hover,
.table-hover > tbody > tr.selected:hover,
.table-striped > tbody > tr.selected:hover {
    background-color: #90caf9 !important;
}

td.noselect { cursor: default !important; }
td.dt-center { text-align: center !important; }
td i.center  { width: 100% !important; text-align: center !important; }

/* ── DATATABLES BUTTONS ─────────────────────────────────────── */
.dt-buttons {
    display: inline-flex !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}

.dt-button,
a.dt-button,
button.dt-button,
div.dt-button {
    background: var(--fb-surface) !important;
    background-image: none !important;
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius) !important;
    color: var(--fb-text) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    padding: 6px 14px !important;
    cursor: pointer !important;
    transition: all var(--fb-transition) !important;
    box-shadow: none !important;
    text-shadow: none !important;
}
.dt-button:hover,
a.dt-button:hover,
button.dt-button:hover {
    background: var(--fb-row-hover) !important;
    border-color: var(--fb-sky) !important;
    color: var(--fb-blue) !important;
    box-shadow: none !important;
}
.dt-button:active,
.dt-button.active {
    background: var(--fb-blue) !important;
    color: #fff !important;
    border-color: var(--fb-blue) !important;
    box-shadow: none !important;
}

div.dt-button-collection {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: var(--fb-shadow-md) !important;
    background: var(--fb-surface) !important;
    padding: 6px !important;
}
div.dt-button-collection button.dt-button:active:not(.disabled),
div.dt-button-collection button.dt-button.active:not(.disabled) {
    background-color: var(--fb-row-hover) !important;
    background-image: none !important;
    box-shadow: none !important;
    color: var(--fb-blue) !important;
}

/* ── BUTTONS BOOTSTRAP ──────────────────────────────────────── */
.btn {
    border-radius: var(--fb-radius) !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    padding: 7px 16px !important;
    transition: all var(--fb-transition) !important;
    border: none !important;
    letter-spacing: 0.02em !important;
    cursor: pointer !important;
    box-shadow: 0 1px 3px rgba(0,0,0,.10) !important;
}
.btn:active {
    box-shadow: none !important;
    transform: translateY(1px) !important;
}
.btn-success {
    background-color: var(--fb-green) !important;
    border-color: var(--fb-green) !important;
    color: #fff !important;
}
.btn-success:hover, .btn-success:focus {
    background-color: #236b4f !important;
    color: #fff !important;
}
.btn-info {
    background-color: var(--fb-blue) !important;
    border-color: var(--fb-blue) !important;
    color: #fff !important;
}
.btn-info:hover, .btn-info:focus {
    background-color: var(--fb-blue-mid) !important;
    color: #fff !important;
}
.btn-primary {
    background-color: var(--fb-blue) !important;
    border-color: var(--fb-blue) !important;
    color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus {
    background-color: var(--fb-blue-mid) !important;
    color: #fff !important;
}
.btn-danger {
    background-color: var(--fb-red) !important;
    border-color: var(--fb-red) !important;
    color: #fff !important;
}
.btn-warning {
    background-color: var(--fb-orange) !important;
    border-color: var(--fb-orange) !important;
    color: #fff !important;
}
.btn-default {
    background-color: var(--fb-surface) !important;
    border: 1px solid var(--fb-border) !important;
    color: var(--fb-text) !important;
}
.btn-default:hover {
    background-color: var(--fb-row-odd) !important;
    border-color: var(--fb-sky) !important;
    color: var(--fb-blue) !important;
}
.btn-group .btn-success { width: auto !important; }

/* ── FORM CONTROLS ──────────────────────────────────────────── */
.form-control {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius) !important;
    font-size: 14px !important;
    /*height: 36px !important;*/
    line-height: 1.5 !important;
    padding: 7px 10px !important;
    color: var(--fb-text) !important;
    background-color: var(--fb-surface) !important;
    box-shadow: none !important;
    transition: border-color var(--fb-transition), box-shadow var(--fb-transition) !important;
}

.form-control:not(textarea) {
    height: 36px !important;
}

.form-control:focus {
    border-color: var(--fb-blue) !important;
    box-shadow: 0 0 0 3px rgba(21,101,192,.12) !important;
    background-color: #fff !important;
}
.form-control[disabled],
.form-control[readonly],
fieldset[disabled] .form-control {
    background-color: #eef2f7 !important;
    color: var(--fb-text-muted) !important;
    opacity: 1 !important;
}
textarea.form-control {
    min-height: 70px !important;
    line-height: 1.6 !important;
}
select.form-control { width: 100% !important; }

.form-group { margin-bottom: 16px !important; }
.form-group label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #444 !important;
    margin-bottom: 4px !important;
    line-height: 1.4 !important;
}
.form-group.dashed {
    border-bottom: 1px solid var(--fb-border) !important;
    padding-bottom: 10px !important;
    margin-bottom: 14px !important;
}
.form-group.has-error .select2-selection {
    border: 1px solid var(--fb-red) !important;
    box-shadow: 0 0 0 3px rgba(244,67,54,.10) !important;
}

/* Input group */
.input-group-addon {
    background-color: var(--fb-row-odd) !important;
    border-color: var(--fb-border) !important;
    color: var(--fb-text-muted) !important;
    border-radius: var(--fb-radius) !important;
    font-size: 14px !important;
    padding: 7px 10px !important;
}

/* ── SELECT2 ────────────────────────────────────────────────── */
.select2-container { width: 100% !important; }

.select2-container--default .select2-selection--single {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius) !important;
    height: 34px !important;
    transition: border-color var(--fb-transition) !important;
}
.select2-container--default .select2-selection--single:focus,
.select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--fb-blue) !important;
    box-shadow: 0 0 0 3px rgba(21,101,192,.10) !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow { height: 30px !important; }
.select2-container--default .select2-selection--single .select2-selection__rendered {
    font-size: 14px !important;
    line-height: 34px !important;
    color: var(--fb-text) !important;
    padding-left: 8px !important;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: var(--fb-blue) !important;
    border: none !important;
    border-radius: 4px !important;
    color: #fff !important;
    font-size: 11.5px !important;
    padding: 2px 8px !important;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: rgba(255,255,255,.8) !important;
    margin-right: 4px !important;
}
.select2-dropdown {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: var(--fb-shadow-md) !important;
}
.select2-results__option--highlighted[aria-selected] {
    background-color: var(--fb-blue) !important;
}

/* ── FORM SEPARATORS (versione definitiva) ──────────────────── */
.form-separator,
.form-separator-red {
    display: flex !important;
    align-items: center !important;
    border-radius: 5px !important;
    padding: 7px 14px !important;
    margin-top: 24px !important;
    margin-bottom: 12px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    border-bottom: none !important;
}

.form-separator {
    background: #e8eef7 !important;
    color: #1e3a5f !important;
    border-left: 4px solid #1e3a5f !important;
}
.form-separator label {
    color: #1e3a5f !important;
    font-weight: 700 !important;
    margin: 0 !important;
    cursor: default !important;
    font-size: 11px !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.form-separator-red {
    background: #fdecea !important;
    color: #b71c1c !important;
    border-left: 4px solid #b71c1c !important;
}
.form-separator-red label {
    color: #b71c1c !important;
    font-weight: 700 !important;
    margin: 0 !important;
    cursor: default !important;
    font-size: 11px !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

/* Varianti colore */
.form-separator.text-red  { background: #fdecea !important; color: #b71c1c !important; border-left-color: #b71c1c !important; }
.form-separator.text-red label { color: #b71c1c !important; }
.form-separator.text-green { background: #e8f5ee !important; color: #1b5e3b !important; border-left-color: #2e7d5e !important; }
.form-separator.text-green label { color: #1b5e3b !important; }
.form-separator.text-yellow { background: #fff8e1 !important; color: #7a5000 !important; border-left-color: #f59e0b !important; }
.form-separator.text-yellow label { color: #7a5000 !important; }

/* Banner header: SOLO primo figlio diretto di group-border-end */
.group-border-end > .form-separator:first-child {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    color: #fff !important;
    border-left: none !important;
    border-radius: 5px 5px 0 0 !important;
    padding: 10px 16px !important;
    margin: 0 -16px 16px -16px !important;
}
.group-border-end > .form-separator:first-child label { color: #fff !important; }

.group-border-end > .form-separator-red:first-child {
    background: linear-gradient(90deg, #7f1d1d 0%, #b71c1c 100%) !important;
    color: #fff !important;
    border-left: none !important;
    border-radius: 5px 5px 0 0 !important;
    padding: 10px 16px !important;
    margin: 0 -16px 16px -16px !important;
}
.group-border-end > .form-separator-red:first-child label { color: #fff !important; }

/* Override lightyellow: mantieni pill rossa */
[style*="lightyellow"] .form-separator-red {
    background: #fdecea !important;
    color: #b71c1c !important;
    border-left: 4px solid #b71c1c !important;
    border-bottom: none !important;
    border-radius: 5px !important;
    padding: 7px 14px !important;
    margin: 24px 0 12px 0 !important;
}
[style*="lightyellow"] .form-separator-red label { color: #b71c1c !important; }

/* ── TABS ───────────────────────────────────────────────────── */
.nav-tabs-custom {
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: var(--fb-shadow) !important;
    border: 1px solid var(--fb-border) !important;
}
.nav-tabs-custom > .nav-tabs {
    background: #1e3a5f !important;
    border-radius: 10px 10px 0 0 !important;
    border: none !important;
    padding: 6px 6px 0 6px !important;
    margin: 0 !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    overflow-x: auto !important;
}
.nav-tabs-custom > .nav-tabs > li {
    float: none !important;
    flex: 1 1 auto !important;
    margin: 0 !important;
    border-top: none !important;
    border-radius: 8px 8px 0 0 !important;
    overflow: hidden !important;
    transition: background 0.18s ease !important;
}
.nav-tabs-custom > .nav-tabs > li.active {
    background: #ffffff !important;
}
.nav-tabs-custom > .nav-tabs > li > a {
    display: block !important;
    padding: 12px 16px !important;
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: rgba(255,255,255,.75) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    text-align: center !important;
    white-space: nowrap !important;
    transition: color 0.18s ease, background 0.18s ease !important;
    margin: 0 !important;
}
.nav-tabs-custom > .nav-tabs > li > a:hover {
    color: #ffffff !important;
    background: rgba(255,255,255,.15) !important;
    border: none !important;
    border-radius: 6px 6px 0 0 !important;
}
.nav-tabs-custom > .nav-tabs > li.active > a,
.nav-tabs-custom > .nav-tabs > li.active > a:hover,
.nav-tabs-custom > .nav-tabs > li.active > a:focus {
    background: #ffffff !important;
    color: var(--fb-navy) !important;
    font-weight: 800 !important;
    border: none !important;
	font-size: 1.2rem !important;
}
.nav-tabs-custom > .tab-content {
    background: var(--fb-surface) !important;
    border: none !important;
    border-radius: 0 0 10px 10px !important;
    padding: 24px !important;
    box-shadow: 0 4px 16px rgba(13,31,60,.10) !important;
}

/* ── MODALI ─────────────────────────────────────────────────── */
.modal-content {
    border: none !important;
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: 0 10px 40px rgba(13,31,60,.22) !important;
}
.modal-header {
    background: var(--fb-blue) !important;
    color: #fff !important;
    border-radius: var(--fb-radius-lg) var(--fb-radius-lg) 0 0 !important;
    padding: 14px 20px !important;
}
.modal-header .modal-title {
    font-weight: 700 !important;
    font-size: 15px !important;
}
.modal-header .close {
    color: rgba(255,255,255,.8) !important;
    opacity: 1 !important;
    text-shadow: none !important;
    font-size: 20px !important;
}
.modal-header .close:hover { color: #fff !important; }
.modal-footer {
    background: var(--fb-surface-2) !important;
    border-top: 1px solid var(--fb-border) !important;
    border-radius: 0 0 var(--fb-radius-lg) var(--fb-radius-lg) !important;
    padding: 12px 20px !important;
}
.modal-body {
    padding: 20px !important;
    font-size: 13px !important;
}
.modal-warning .modal-header,
.modal-warning .modal-footer,
.bg-yellow-active {
    background-color: var(--fb-blue) !important;
}
.bootbox.modal { z-index: 9999; }

/* ── ALERT ──────────────────────────────────────────────────── */
.alert {
    padding: 10px 20px 10px 14px !important;
    margin-bottom: 10px !important;
    border-radius: var(--fb-radius) !important;
    font-size: 13px !important;
    border: none !important;
    border-left: 4px solid transparent !important;
}
.alert-success  { background-color: #e8f8f1 !important; color: #1e7e50 !important; border-left-color: var(--fb-green) !important; }
.alert-info     { background-color: #e3f0fb !important; color: #1155aa !important; border-left-color: var(--fb-blue) !important; }
.alert-warning  { background-color: #fff8e1 !important; color: #8a5a00 !important; border-left-color: var(--fb-orange) !important; }
.alert-danger   { background-color: #fdecea !important; color: #b71c1c !important; border-left-color: var(--fb-red) !important; }

/* ── LABELS / BADGE ─────────────────────────────────────────── */
.label {
    border-radius: 4px !important;
    font-size: 10.5px !important;
    font-weight: 700 !important;
    padding: 3px 7px !important;
    letter-spacing: 0.03em !important;
}
.label-primary  { background-color: var(--fb-blue) !important; }
.label-success  { background-color: var(--fb-green) !important; }
.label-info     { background-color: var(--fb-sky) !important; }
.label-warning  { background-color: var(--fb-orange) !important; }
.label-danger   { background-color: var(--fb-red) !important; }

.badge {
    border-radius: 10px !important;
    font-size: 10.5px !important;
    font-weight: 700 !important;
    padding: 3px 8px !important;
}

/* ── SMALL BOXES ────────────────────────────────────────────── */
.small-box {
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: var(--fb-shadow) !important;
    overflow: hidden !important;
    transition: transform var(--fb-transition), box-shadow var(--fb-transition) !important;
}
.small-box:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--fb-shadow-md) !important;
}
.small-box .inner { padding: 16px !important; }
.small-box > .small-box-footer {
    font-size: 12px !important;
    font-weight: 600 !important;
    padding: 8px 14px !important;
    background: rgba(0,0,0,.08) !important;
    transition: background var(--fb-transition) !important;
}
.small-box:hover > .small-box-footer { background: rgba(0,0,0,.14) !important; }

/* ── INFO BOX ───────────────────────────────────────────────── */
.info-box {
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: var(--fb-shadow) !important;
    border: 1px solid var(--fb-border) !important;
    min-height: 70px !important;
}
.info-box-icon {
    border-radius: var(--fb-radius-lg) 0 0 var(--fb-radius-lg) !important;
    font-size: 28px !important;
}

/* ── LOGIN ──────────────────────────────────────────────────── */
.login-page,
.register-page {
    background: linear-gradient(135deg, var(--fb-navy) 0%, #1565c0 60%, #1e88e5 100%) !important;
}
.login-box-body,
.register-box-body {
    background: var(--fb-surface) !important;
    border-radius: var(--fb-radius-lg) !important;
    padding: 28px !important;
    box-shadow: var(--fb-shadow-md) !important;
    color: var(--fb-text) !important;
    border: 1px solid var(--fb-border) !important;
}

/* ── GROUP BORDER ───────────────────────────────────────────── */
.group-border-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-bottom: 20px !important;
}
.group-border {
    border-radius: var(--fb-radius-lg) !important;
    padding: 0 !important;
    overflow: hidden !important;
}
.group-border-stack {
    border: 1px solid var(--fb-border) !important;
    border-bottom: none !important;
    border-radius: var(--fb-radius-lg) var(--fb-radius-lg) 0 0 !important;
    background: var(--fb-surface) !important;
    padding: 0 4px !important;
}
.group-border-end {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius-lg) !important;
    background: var(--fb-surface) !important;
    box-shadow: var(--fb-shadow) !important;
    padding: 0 16px 16px 16px !important;
    overflow: visible !important;
}

/* ── STATO ATTIVO (lightyellow) ─────────────────────────────── */
[style*="lightyellow"] {
    background-color: #f0f8fd !important;
    border: 1px solid #b8dff5 !important;
    border-radius: var(--fb-radius-lg) !important;
    overflow: visible !important;
    padding: 0 16px 16px 16px !important;
    margin-top: 12px !important;
}
[style*="lightyellow"] .form-separator {
    background: linear-gradient(90deg, var(--fb-navy) 0%, var(--fb-blue) 100%) !important;
    color: #fff !important;
    border-bottom: none !important;
    border-left: none !important;
    padding: 10px 16px !important;
    margin: 0 -16px 16px -16px !important;
    border-radius: 4px 4px 0 0 !important;
}
[style*="lightyellow"] .form-separator label { color: #fff !important; font-weight: 700 !important; }

/* ── FANCYBOX ───────────────────────────────────────────────── */
.fancybox-overlay {
    background: rgba(13,31,60,.55) !important;
    backdrop-filter: blur(3px) !important;
}
.fancybox-skin {
    border-radius: var(--fb-radius-lg) !important;
    box-shadow: 0 20px 60px rgba(13,31,60,.30) !important;
    padding: 0 !important;
    background: var(--fb-surface) !important;
}
.fancybox-inner {
    border-radius: var(--fb-radius-lg) !important;
    overflow: auto !important;
}
.fancybox-inner .box.box-primary {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    margin-bottom: 0 !important;
}
.fancybox-inner .box.box-primary > .box-header.with-border { display: none !important; }
.fancybox-inner .box.box-primary > .box-body { padding: 0 !important; }

/* Separatori dentro fancybox: linea sottile */
.fancybox-inner .form-separator,
.fancybox-inner .form-separator.text-red,
.fancybox-inner .form-separator.text-green,
.fancybox-inner .form-separator.text-yellow,
.fancybox-inner .form-separator-red {
    background: transparent !important;
    border-left: none !important;
    border-bottom: 2px solid currentColor !important;
    border-radius: 0 !important;
    padding: 0 0 5px 0 !important;
    margin: 20px 0 12px 0 !important;
}
.fancybox-inner .form-separator { color: #1e3a5f !important; border-bottom-color: #1e3a5f !important; }
.fancybox-inner .form-separator label { color: #1e3a5f !important; }
.fancybox-inner .form-separator-red { color: #b71c1c !important; border-bottom-color: #b71c1c !important; }
.fancybox-inner .form-separator-red label { color: #b71c1c !important; }

/* Banner header fancybox — primo separator */
.fancybox-inner .box-body .form-separator:first-child,
.fancybox-inner .box-body > div > .form-separator:first-child,
.fancybox-inner .box-body > div > div > .form-separator:first-child,
.fancybox-inner .group-border-end > .form-separator:first-child {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 14px 20px !important;
    margin: 0 0 20px 0 !important;
}
.fancybox-inner .box-body .form-separator:first-child label,
.fancybox-inner .box-body > div > .form-separator:first-child label,
.fancybox-inner .box-body > div > div > .form-separator:first-child label,
.fancybox-inner .group-border-end > .form-separator:first-child label {
    color: #fff !important;
}

/* Padding laterale contenuto fancybox */
.fancybox-inner .box-body .col-md-12,
.fancybox-inner .box-body .group-border-container,
.fancybox-inner .group-border-end,
.fancybox-inner .group-border-stack {
    padding-left: 20px !important;
    padding-right: 20px !important;
}

/* Footer fancybox */
.fancybox-inner .box-footer {
    background: var(--fb-surface-2) !important;
    border-top: 1px solid var(--fb-border) !important;
    padding: 14px 20px !important;
    display: flex !important;
    justify-content: flex-end !important;
    border-radius: 0 0 var(--fb-radius-lg) var(--fb-radius-lg) !important;
}
.fancybox-inner .box-footer .btn {
    min-width: 100px !important;
    padding: 9px 24px !important;
    font-weight: 700 !important;
}

/* Label contatto inside fancybox */
.fancybox-inner label[style*="lightyellow"] {
    display: block !important;
    background: #e8f4fd !important;
    border: 1px solid #b8dff5 !important;
    border-radius: var(--fb-radius) !important;
    padding: 10px 14px !important;
    font-size: 13px !important;
    color: var(--fb-navy) !important;
    margin: 0 0 16px 0 !important;
    line-height: 1.6 !important;
    font-weight: 400 !important;
}

/* ── BOTTONI AZIONE CRM ─────────────────────────────────────── */
.elenco-attivita-btn,
.nuova-attivita-btn,
.nuovo-memo-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 10px !important;
    text-decoration: none !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease !important;
    position: relative !important;
    margin: 0 3px !important;
    flex-shrink: 0 !important;
}
.elenco-attivita-btn i.fa,
.nuova-attivita-btn i.fa,
.nuovo-memo-btn i.fa {
    font-size: 16px !important;
    margin: 0 !important;
    line-height: 1 !important;
    color: inherit !important;
}
.elenco-attivita-btn:hover,
.nuova-attivita-btn:hover,
.nuovo-memo-btn:hover {
    transform: translateY(-2px) !important;
    text-decoration: none !important;
}

.elenco-attivita-btn {
    background: var(--fb-blue) !important;
    color: #fff !important;
    box-shadow: 0 2px 8px rgba(21,101,192,.28) !important;
}
.elenco-attivita-btn:hover {
    background: var(--fb-blue-mid) !important;
    box-shadow: 0 5px 14px rgba(21,101,192,.40) !important;
    color: #fff !important;
}

.nuova-attivita-btn {
    background: #e8f5e9 !important;
    color: #2e7d32 !important;
    box-shadow: 0 2px 8px rgba(46,125,50,.18) !important;
    border: 1px solid #c8e6c9 !important;
}
.nuova-attivita-btn:hover {
    background: #c8e6c9 !important;
    box-shadow: 0 5px 14px rgba(46,125,50,.28) !important;
    color: #1b5e20 !important;
}
.nuova-attivita-btn:has(i.fa-phone-square) {
    background: #e8f5e9 !important; color: #2e7d32 !important;
    border-color: #c8e6c9 !important; box-shadow: 0 2px 8px rgba(46,125,50,.18) !important;
}
.nuova-attivita-btn:has(i.fa-calendar) {
    background: #fce4ec !important; color: #c62828 !important;
    border-color: #f8bbd0 !important; box-shadow: 0 2px 8px rgba(198,40,40,.18) !important;
}
.nuova-attivita-btn:has(i.fa-phone-square):hover {
    background: #c8e6c9 !important;
    box-shadow: 0 5px 14px rgba(46,125,50,.30) !important;
}
.nuova-attivita-btn:has(i.fa-calendar):hover {
    background: #f8bbd0 !important;
    box-shadow: 0 5px 14px rgba(198,40,40,.28) !important;
    color: #b71c1c !important;
}

.nuovo-memo-btn {
    background: #fff8e1 !important;
    color: #e65100 !important;
    box-shadow: 0 2px 8px rgba(230,81,0,.18) !important;
    border: 1px solid #ffe082 !important;
}
.nuovo-memo-btn:hover {
    background: #ffe0b2 !important;
    box-shadow: 0 5px 14px rgba(230,81,0,.28) !important;
    color: #bf360c !important;
}
.elenco-attivita-btn[title],
.nuova-attivita-btn[title],
.nuovo-memo-btn[title] { cursor: pointer !important; }

/* Reset per wrapper che contengono <button> */
.nuovo-memo-btn:has(button),
.nuova-attivita-btn:has(button),
.elenco-attivita-btn:has(button) {
    display: block !important; width: auto !important; height: auto !important;
    border-radius: 0 !important; background: transparent !important;
    box-shadow: none !important; border: none !important; margin: 0 !important; padding: 0 !important;
}
.nuovo-memo-btn:has(button):hover,
.nuova-attivita-btn:has(button):hover,
.elenco-attivita-btn:has(button):hover {
    transform: none !important; box-shadow: none !important; background: transparent !important;
}
.nuovo-memo-btn:has(button) button,
.nuova-attivita-btn:has(button) button,
.elenco-attivita-btn:has(button) button {
    display: block !important; width: 100% !important;
}

/* ── FEBO PANNELLO COSTI ────────────────────────────────────── */
.febo-sep {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 7px 12px 7px 10px;
    margin-bottom: 14px;
    margin-top: 6px;
    border-left: 3px solid;
    display: flex;
    align-items: center;
}
.febo-sep-blue { background: #e8f2fb; color: #185FA5; border-color: #337AB7; }
.febo-sep-gray { background: #f4f4f4; color: #555; border-color: #aaa; }

.febo-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 12px; }

.febo-metric {
    background: #f7f7f7;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 12px 16px;
    flex: 1 1 130px;
    min-width: 120px;
}
.febo-metric label {
    font-size: 12px;
    color: #666;
    display: block;
    margin-bottom: 5px;
    font-weight: 600;
    cursor: default;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}
.febo-metric .febo-val { font-size: 18px; font-weight: 700; color: #222; line-height: 1.2; }
.febo-metric.febo-highlight { background: #fff; border: 1px solid #c8d8e8; }
.febo-highlight-blue { border-top: 3px solid #337AB7 !important; }
.febo-highlight-gray { border-top: 3px solid #aaa !important; }
.febo-val-blue { color: #185FA5 !important; }

.febo-margine-row { display: flex; align-items: center; gap: 8px; margin-top: 2px; }
.febo-badge {
    display: inline-flex; align-items: center;
    font-size: 12px; font-weight: 700;
    padding: 3px 9px; border-radius: 4px;
}
.febo-badge-green { background: #dff0d8; color: #3c763d; }
.febo-badge-amber { background: #fcf8e3; color: #8a6d3b; }
.febo-badge-red   { background: #f2dede; color: #a94442; }

.febo-bar-wrap { height: 5px; background: #e0e0e0; border-radius: 4px; overflow: hidden; margin-top: 8px; }
.febo-bar { height: 100%; border-radius: 4px; }

/* ── TICKET STATUS ──────────────────────────────────────────── */
div.ticket_status {
    display: flex;
    align-items: center;
    padding: 4px 6%;
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius) !important;
    width: 100%;
    max-width: 300px;
    gap: 10px;
    background-color: var(--fb-row-even) !important;
    cursor: pointer;
    transition: all var(--fb-transition) !important;
}
div.ticket_status:hover {
    border-color: var(--fb-sky) !important;
    background-color: var(--fb-row-hover) !important;
}
div.ticket_status.selected {
    background-color: #d4f0e2 !important;
    border: 2px solid var(--fb-green) !important;
    color: #00613d !important;
}
div.ticket_status h3 { font-size: 1.4rem !important; font-weight: 700 !important; margin: 0 !important; }

/* ── COLONNA STATO ──────────────────────────────────────────── */
div.colonna_stato {
    border: 1px solid var(--fb-border) !important;
    padding: 20px !important;
    border-radius: var(--fb-radius-lg) !important;
    background-color: var(--fb-surface) !important;
    box-shadow: var(--fb-shadow) !important;
    position: relative;
}
div.colonna_stato h2 { font-size: 1.4rem !important; margin-bottom: 16px !important; color: var(--fb-text-muted) !important; margin-top: 0; }
div.container_stati { width: 100%; display: flex; flex-direction: column; gap: 10px; margin: 20px; }

/* ── TIMELINE ───────────────────────────────────────────────── */
.timeline_container ul, li { list-style: none; padding: 0; }
.timeline_container { display: flex; justify-content: flex-start; align-items: center; padding: 0 1rem; }
.box_wrapper { padding: 2rem; border-radius: 15px; }
.box_wrapper h3, .note_interne h3 { font-size: 1.5rem; font-weight: bold; color: var(--fb-blue) !important; }
.box_wrapper .timeline_sessions { margin-top: 2rem; border-radius: 12px; position: relative; }
.timeline_container .box_wrapper li {
    padding-bottom: 1.5rem;
    border-left: 2px solid var(--fb-blue) !important;
    position: relative; padding-left: 20px; margin-left: 10px;
}
.timeline_container .box_wrapper li:last-child { border: 0; padding-bottom: 0; }
.timeline_container .box_wrapper li:before {
    content: ""; width: 15px; height: 15px; background: white;
    border: 1px solid #32ad96; box-shadow: 3px 3px 0 #32ad96;
    border-radius: 50%; position: absolute; left: -10px; top: 0;
}
.timeline_container .box_wrapper .time { font-size: 1.2rem; font-weight: 900; color: #6b809b; }
.box_wrapper p { color: #7e7e7e; line-height: 1.5; margin-top: 0.4rem; }

/* Note interne */
.lista_note_interne { padding: 0; }
.lista_note_interne li {
    position: relative; padding: 8px; border-radius: 8px;
    color: #555; font-size: 1.2rem; font-weight: 600;
    margin-top: 30px; word-break: break-word;
}
.lista_note_interne li.mittente  { text-align: right; border: 2px solid #acddb7; }
.lista_note_interne li.assegnatario { border: 2px solid #9eb6f9; }
.lista_note_interne span.utente,
.lista_note_interne span.data { font-size: 1.2rem; font-weight: 700; color: #8c92a5; }
.lista_note_interne span.messaggio { font-size: 1.5rem; }

/* ── STORICO CONTATTO ───────────────────────────────────────── */
div.storico_contatto .box-header { display: flex; gap: 22px; align-items: center; }
div.storico_contatto .box-header img { max-width: 40px; }
div.storico_contatto .box-header h2 { font-size: 2rem; color: #939393; font-weight: 500; }
div.storico_box h3 { font-size: 2rem; color: #4f748f; font-weight: 900; }

div.storico_container {
    padding: 8px;
    border: 2px solid #a8c7bf;
    border-radius: 4px;
    min-height: 400px;
    max-height: 400px;
    overflow: auto;
}
div.storico_container ul {
    display: flex; flex-direction: column; gap: 6px;
    justify-content: flex-start; align-items: flex-start; padding: 0;
}
div.storico_container ul li {
    position: relative;
    display: grid; grid-template-columns: repeat(2, 50%);
    width: 100%; padding: 4px; cursor: pointer;
    font-size: 1rem; border-bottom: 1px solid #a8c7bf;
}
div.storico_container ul li:hover {
    border: 1px solid #abcfe9; background-color: whitesmoke; color: #585858;
}
div.storico_container ul li p { margin: 4px; font-size: 1.1rem; font-weight: 600; }
div.storico_container::-webkit-scrollbar { width: 2px; }
div.storico_container::-webkit-scrollbar-track { box-shadow: inset 0 0 2px rgba(50,154,161,.3); }
div.storico_container::-webkit-scrollbar-thumb { background-color: #4f748f; outline: 1px solid #4f748f; }
div.storico_container ul li .target_link { position: absolute; top: -6px; right: -2px; font-size: 1.5rem; z-index: 100; color: #20b720; }

@media screen and (max-width: 500px) {
    div.storico_container ul li { display: grid; grid-template-columns: 100%; }
}

/* ── LOADING ANIMATION ──────────────────────────────────────── */
div#loading-animation {
    display: none;
    position: fixed;
    top: 0; bottom: 0; right: 0; left: 0;
    width: 100vw; height: 100vh;
    z-index: 100000;
    display: flex; justify-content: center; align-items: center;
    backdrop-filter: blur(2px);
}
div.loading_container {
    width: 50%;
    display: flex; justify-content: center; align-items: center;
    border: 2px solid #48b3b7; padding: 12px; border-radius: 6px;
    gap: 40px; background-color: white;
}
div.loading_container img { max-width: 120px; }
div.loading_container h3 { font-size: 2rem; font-weight: 900; color: #4a6089; }

/* ── FORM MATERIAL ──────────────────────────────────────────── */
.form-control-material {
    background-color: transparent;
    border: none;
    border-bottom: 1px solid #127d81;
    border-left: 4px solid #127d81;
    border-top: 1px solid #d8dbdf;
    border-right: 1px solid #d8dbdf;
    width: 100%; padding: 10px 16px; outline: none; border-radius: 6px;
}
.material-button {
    background-color: #14b4b9; color: white; border: none;
    border-radius: 0; padding: 2px 20px; cursor: pointer;
}
span#messaggi_ticket {
    display: none; position: absolute; right: 15px; top: 14px;
    padding: 5px 20px; color: #555; font-weight: 800;
}
span#messaggi_ticket.error {
    display: block; color: white; background-color: tomato;
}

/* ── WIDGET / UTENTE ────────────────────────────────────────── */
.widget-user-2 .widget-user-image > img {
    width: 38px !important;
    border-radius: 50% !important;
    border: 2px solid var(--fb-border) !important;
}

/* ── RADIO GROUP ────────────────────────────────────────────── */
.radio-group { background: #fff; width: 100%; padding-top: 5px; padding-left: 5px; }
div.radio_group { display: flex; justify-content: flex-start; gap: 18px; margin-bottom: 2px; font-size: 1.2rem; align-items: center; }
div.radio_group label { font-weight: 600; color: #13979b; }
.spacer { display: inline-block; width: 20px; }

/* ── ICHECK ─────────────────────────────────────────────────── */
.iradio_flat-blue:not(.checked),
.icheckbox_flat-blue:not(.checked),
.icheckbox_flat-red:not(.checked) {
    filter: drop-shadow(0px 0px 1px rgba(0,0,0,.5));
}

/* ── CUSTOM RADIO/CHECKBOX ──────────────────────────────────── */
.container {
    display: block; position: relative; padding-left: 35px;
    margin-bottom: 12px; cursor: pointer; font-size: 22px;
    user-select: none;
}
.container input { position: absolute; opacity: 0; cursor: pointer; }
.checkmark {
    position: absolute; top: 0; left: 0;
    height: 25px; width: 25px;
    background-color: #c3c3c3; border-radius: 50%;
}
.container:hover input ~ .checkmark { background-color: #ccc; }
.container input:checked ~ .checkmark { background-color: #2196F3; }
.checkmark:after { content: ""; position: absolute; display: none; }
.container input:checked ~ .checkmark:after { display: block; }
.container .checkmark:after {
    top: 9px; left: 9px; width: 8px; height: 8px;
    border-radius: 50%; background: white;
}

/* ── TOOLTIP ────────────────────────────────────────────────── */
.tooltip2 { position: relative !important; display: inline-block !important; padding-bottom: 5px !important; font-weight: 700 !important; }
.tooltip2 .tooltiptext2 {
    visibility: hidden !important; background-color: var(--fb-navy) !important;
    color: #fff !important; text-align: center !important;
    padding: 6px 10px !important; border-radius: var(--fb-radius) !important;
    position: absolute !important; z-index: 9999 !important;
    width: 130px !important; bottom: 110% !important;
    left: 50% !important; margin-left: -65px !important;
    font-size: 11.5px !important; box-shadow: var(--fb-shadow) !important;
}
.tooltip2:hover .tooltiptext2 { visibility: visible !important; }

span.mytooltip:hover { position: relative; }
span.mytooltip[aria-label]:hover:after {
    position: absolute; content: attr(aria-label);
    padding: 8px; z-index: 20; background: white;
    border: 1px solid black; width: auto;
}

i[data-toggle="tooltip"] {
    cursor: pointer !important;
    color: var(--fb-blue-mid) !important;
    transition: color var(--fb-transition) !important;
}
i[data-toggle="tooltip"]:hover { color: var(--fb-sky) !important; }

/* ── AUTOCOMPLETE ───────────────────────────────────────────── */
.ui-autocomplete {
    border: 1px solid var(--fb-border) !important;
    border-radius: var(--fb-radius-lg) !important;
    border-color: var(--fb-blue) !important;
    box-shadow: var(--fb-shadow-md) !important;
    background: var(--fb-surface) !important;
    list-style-type: none !important; padding: 4px 0 !important; z-index: 99999 !important;
    width: auto !important;
    max-width: 300px !important;
}
.ui-autocomplete-loading { background: url('../img/ui-anim_basic_16x16.gif') no-repeat right center; }
.ui-menu-item { padding: 7px 14px !important; font-size: 13px !important; transition: background var(--fb-transition) !important; }
.ui-state-focus { border: none !important; background-color: var(--fb-row-hover) !important; color: var(--fb-navy) !important; }

/* ── MINI TABLE HORIZONTAL ──────────────────────────────────── */
.mini-table-horizontal th { font-weight: normal; color: gray; }
.mini-table-horizontal td span.big   { height: 25px; font-weight: 900; font-size: 18px; }
.mini-table-horizontal td span.medium { height: 25px; font-weight: 900; font-size: 14px; }
.mini-table-horizontal th,
.mini-table-horizontal td { padding: 0 10px; }
.mini-table-horizontal th:not(:last-child),
.mini-table-horizontal td:not(:last-child) { border-right: 1px dashed gray; }

/* ── TABELLA LEGENDA ────────────────────────────────────────── */
.tabella-legenda { display: inline-block; width: 100%; margin: 0; padding: 0; }
.tabella-legenda table { border-collapse: collapse; border-spacing: 0; width: 100%; height: 100%; margin: 0; padding: 0; }
.tabella-legenda tr:first-child td {
    background-color: #cccccc;
    text-align: center; font-size: 10px; font-family: Arial; font-weight: bold; color: #000;
}
.tabella-legenda td {
    vertical-align: middle; background-color: #e5e5e5;
    text-align: left; padding: 2px; font-size: 10px; font-family: Arial; color: #000;
}

/* ── ATTACHMENTS ────────────────────────────────────────────── */
#attachments-default {
    height: 73px; width: 100%; border: 1px solid #000;
    background-color: #fff; overflow: auto;
}
.filename-attachment-default:hover { background-color: #6495ED; }
input.attachment-close {
    float: right; margin-top: 1px; margin-right: 5px;
    color: #ff0000; font-weight: 900; height: 15px; line-height: 10px;
}

/* ── FILE UPLOAD ────────────────────────────────────────────── */
.upload_file_button { padding: 4px; margin-bottom: 4px; width: 100%; text-indent: 0 !important; }
.submit_file_button { width: 100%; }

.input-group-btn-file { vertical-align: top; }
.btn-file { position: relative; overflow: hidden; }
.btn-file input[type=file] {
    position: absolute; top: 0; right: 0;
    min-width: 100%; min-height: 100%;
    font-size: 100px; text-align: right;
    opacity: 0; outline: none; background: white;
    cursor: inherit; display: block;
}

button.delete_file_btn {
    font-size: 1.4rem !important; background: transparent !important; border: none !important;
    position: absolute !important; right: 12px !important;
    color: var(--fb-red) !important; cursor: pointer !important;
    transition: opacity var(--fb-transition) !important;
}
button.delete_file_btn:hover { opacity: 0.7 !important; }

/* ── PROFILE PICTURE ────────────────────────────────────────── */
.profile-picture-box { display: inline-block; width: 35px; height: 35px; border: 1px solid black; }
.profile-picture-box img { vertical-align: baseline; }
.profile-picture-box-header { width: 55px; height: 44px; }

/* ── PERMESSI ───────────────────────────────────────────────── */
.permessi td.middle { vertical-align: middle !important; }
.permessi td:first-child { width: 200px; }
.permessi td:nth-child(2) { width: 300px; }

/* ── TABELLA CONCORRENTI / CONTATTI ─────────────────────────── */
.tabella-concorrenti td,
.tabella-contatti td { padding: 0 !important; }

/* ── VARIE UTILITY ──────────────────────────────────────────── */
.select_filter     { width: 100% !important; padding-left: 0 !important; padding-right: 0 !important; }
button.checkbox_filter { width: 100% !important; border-radius: var(--fb-radius) !important; }
.bb-body-centered  { text-align: center !important; }
.col_right_separator { border-right: 2px solid var(--fb-sky) !important; }
.background-yellow { background-color: #fffde7 !important; padding: 14px !important; border-radius: var(--fb-radius) !important; border: 1px solid #ffe082 !important; }

.date-on-click,
.datetime-on-click,
.datepicker-show { cursor: pointer !important; }

td[data-type="readonly"]:hover { cursor: default !important; }
td[data-type]:not([data-type="readonly"]):hover { cursor: pointer !important; }

.sign-cell { line-height: 14px !important; font-size: 15px !important; font-weight: 900 !important; width: 15px !important; text-align: right !important; }

.required-notice { color: var(--fb-red) !important; float: right !important; font-size: 11px !important; }
.label-required  { color: var(--fb-red) !important; }
.label-green     { color: #00a65a !important; }
.label-red       { color: var(--fb-red) !important; }
.label-blue      { color: var(--fb-blue) !important; }

.numero_errori_label { line-height: 30px; }
.numero_errori_value { font-weight: 900; font-size: 24px !important; line-height: 24px !important; padding: 0 0 0 10px !important; }
.numero_errori_value_rosso { color: red; }

.border-green { border-color: #398439; }
.label-scaduti,
.modal-scaduti .modal-body,
.bg-light-blue {
    background-color: #ffe0b2 !important;
    color: #7a3800 !important;
    border-left: 4px solid var(--fb-orange) !important;
}

ul.list.clickable li.selected {
    border: 2px solid #266f78;
    border-radius: 4px;
}

/* ── FACCINE STATUS ─────────────────────────────────────────── */
.fa-smile-o { color: #fff !important; background-color: #2e7d5e !important; border-radius: 50% !important; padding: 1px !important; width: 16px !important; height: 16px !important; text-align: center !important; }
.fa-meh-o   { color: #fff !important; background-color: var(--fb-orange) !important; border-radius: 50% !important; padding: 1px !important; width: 16px !important; height: 16px !important; text-align: center !important; }
.fa-frown-o { color: #fff !important; background-color: var(--fb-red) !important; border-radius: 50% !important; padding: 1px !important; width: 16px !important; height: 16px !important; text-align: center !important; }
.select2-results .fa-smile-o,
.select2-results .fa-meh-o,
.select2-results .fa-frown-o { height: 16px; }

/* ── SEPARATOR ANNULLATO (classe dedicata helper) ───────────── */
.separator-annullato {
    background: #fdecea !important; color: #b71c1c !important;
    border-left: 4px solid #b71c1c !important;
    border-radius: 5px !important; padding: 7px 14px !important;
    margin-top: 24px !important; margin-bottom: 12px !important;
    font-size: 11px !important; font-weight: 700 !important;
    letter-spacing: 0.08em !important; text-transform: uppercase !important;
    display: flex !important; align-items: center !important;
}
.separator-annullato label { color: #b71c1c !important; font-weight: 700 !important; margin: 0 !important; cursor: default !important; }

/* ── DHTMLX SCHEDULER ───────────────────────────────────────── */
.dhx_cal_radio label { margin-left: 3px; margin-right: 20px; }
.dhx_cal_custom_button {
    color: #747473; width: 85px; text-decoration: none;
    font-weight: 700; font-family: arial; font-size: 12px;
    height: 30px; line-height: 30px; background: transparent;
    border: 1px solid #CECECE; text-align: center; cursor: pointer;
}

/* ── TABLE INPUT WIDE ───────────────────────────────────────── */
#table-integratori { margin-top: 5px; }
.table-input-wide { width: 100%; }

/* ── SCROLLBAR GLOBALE ──────────────────────────────────────── */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--fb-surface-2); }
::-webkit-scrollbar-thumb { background: #b8cfe8; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--fb-sky); }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 767px) {
    .box-body        { padding: 10px !important; }
    .content-header  { padding: 10px 14px !important; }
    .modal-content   { margin: 10px !important; }
    .dt-buttons      { gap: 4px !important; }
    div.storico_container ul li { display: grid; grid-template-columns: 100%; }
    .timeline_container .box_wrapper .time { margin-bottom: 0.3rem; }
}


.form-group label[style*="color:red"],
.form-group label[style*="color: red"],
.form-group label[style*="color:Red"],
.form-group label[style*="color: Red"] {
    color: #c0392b !important;
}

.help-block {
    color: #c0392b !important;
    font-weight: 600 !important;
}

/* ── TOGGLE SWITCH — sostituisce tutte le checkbox .form-control ── */
input[type="checkbox"] {
    appearance: none !important;
    -webkit-appearance: none !important;
    position: relative !important;
    width: 36px !important;
    height: 20px !important;
    background: #ccc !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    flex-shrink: 0 !important;
    vertical-align: middle !important;
    border: none !important;
    outline: none !important;
}

input[type="checkbox"]::after {
    content: '' !important;
    position: absolute !important;
    width: 14px !important;
    height: 14px !important;
    border-radius: 50% !important;
    background: white !important;
    top: 3px !important;
    left: 3px !important;
    transition: left 0.2s ease !important;
}

input[type="checkbox"]:checked {
    background: #1e3a5f !important;
}

input[type="checkbox"]:checked::after {
    left: 19px !important;
}

/* ── FORM GROUP con checkbox — etichetta sinistra, toggle destra ── */
.form-group:has(input[type="checkbox"]) {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    background: var(--fb-surface) !important;
    border: 0.5px solid var(--fb-border) !important;
    border-radius: var(--fb-radius) !important;
    padding: 10px 14px !important;
    cursor: pointer !important;
    margin-bottom: 8px !important;
}

.form-group:has(input[type="checkbox"]):hover {
    background: var(--fb-surface-2) !important;
}

.form-group:has(input[type="checkbox"]) label {
    margin: 0 !important;
    cursor: pointer !important;
    font-size: 14px !important;
    color: var(--fb-text) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
}

/* ═══════════════════════════════════════════════════════════════
   DHTMLX SCHEDULER — restyling Febosoft
   ═══════════════════════════════════════════════════════════════ */

.dhx_cal_navline {
    background: #1e3a5f !important;
    border-bottom: none !important;
    height: 44px !important;
}
.dhx_cal_prev_button,
.dhx_cal_next_button,
.dhx_cal_today_button {
    background-color: rgba(255,255,255,0.15) !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    color: #fff !important;
    border-radius: 4px !important;
}
.dhx_cal_date {
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}
.dhx_cal_tab {
    background: rgba(255,255,255,0.12) !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    color: #fff !important;
    border-radius: 4px !important;
}
.dhx_cal_tab.active,
.dhx_cal_tab_selected {
    background: #fff !important;
    color: #1e3a5f !important;
    font-weight: 700 !important;
    border: 2px solid #fff !important;
}
.dhx_cal_header {
    background: #f0f4f8 !important;
    border-bottom: 2px solid #dce6f0 !important;
}
.dhx_scale_bar {
    color: #1e3a5f !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    border-right: 1px solid #dce6f0 !important;
}
.dhx_scale_hour {
    color: #607890 !important;
    font-size: 11px !important;
    border-bottom: 1px solid #eef2f7 !important;
}
.dhx_scale_holder_now {
    background-image: none !important;
    background-color: #f0f6fc !important;
}
.dhx_cal_event {
    border-radius: 4px !important;
    border: none !important;
    overflow: hidden !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.20) !important;
    z-index: 10 !important;
    border-left: 3px solid rgba(255,255,255,0.35) !important;
}
.dhx_event_move.dhx_header,
.dhx_event_move.dhx_title,
.dhx_body {
    border-radius: 0 !important;
    border: none !important;
    margin: 0 !important;
    padding: 2px 6px !important;
}
.dhx_cal_event div,
.dhx_cal_event_line {
    font-size: 10px !important;
    line-height: 1.35 !important;
    font-family: 'Segoe UI', system-ui, sans-serif !important;
}
.dhx_event_resize {
    display: none !important;
}

/* Quick info popup */
.dhx_quick_info {
    border-radius: 8px !important;
    border: none !important;
    box-shadow: 0 8px 30px rgba(13,31,60,0.20) !important;
    overflow: hidden !important;
    font-family: 'Segoe UI', system-ui, sans-serif !important;
}

.dhx_quick_info_title {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    padding: 12px 16px !important;
    border-radius: 8px 8px 0 0 !important;
}

.dhx_quick_info_date {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    color: rgba(255,255,255,0.85) !important;
    font-size: 11px !important;
    padding: 0 16px 10px 16px !important;
    font-weight: 500 !important;
}

.dhx_quick_info_content {
    background: #fff !important;
    padding: 14px 16px !important;
    font-size: 12px !important;
    color: #1a2a3a !important;
    line-height: 1.7 !important;
    border-bottom: 1px solid #dce6f0 !important;
}

.dhx_quick_info_footer {
    background: #f7fafd !important;
    padding: 10px 16px !important;
    border-radius: 0 0 8px 8px !important;
}

.dhx_qi_big_icon {
    background: #fdecea !important;
    color: #b71c1c !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 6px 12px !important;
}
.dhx_qi_big_icon:hover {
    background: #f44336 !important;
    color: #fff !important;
}

.dhx_cal_quick_info {
    border-radius: 8px !important;
    border: none !important;
    box-shadow: 0 8px 30px rgba(13,31,60,0.20) !important;
    overflow: hidden !important;
    font-family: 'Segoe UI', system-ui, sans-serif !important;
}

.dhx_cal_qi_title {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    padding: 12px 16px 10px 16px !important;
    border-bottom: none !important;
}

.dhx_cal_qi_tcontent {
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
}

.dhx_cal_qi_tdate {
    color: rgba(255,255,255,0.80) !important;
    font-size: 11px !important;
    margin-top: 4px !important;
}

.dhx_cal_qi_content {
    background: #fff !important;
    padding: 14px 16px !important;
    font-size: 12px !important;
    color: #1a2a3a !important;
    line-height: 1.8 !important;
    border-bottom: 1px solid #dce6f0 !important;
}

.dhx_cal_qi_controls {
    background: #f7fafd !important;
    padding: 10px 16px !important;
    border-radius: 0 0 8px 8px !important;
}

.dhx_qi_big_icon {
    background: #fdecea !important;
    color: #b71c1c !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 6px 12px !important;
    cursor: pointer !important;
}

.dhx_qi_big_icon:hover {
    background: #f44336 !important;
    color: #fff !important;
}

.dhx_cal_quick_info {
    border-radius: 8px !important;
    border: none !important;
    box-shadow: 0 8px 30px rgba(13,31,60,0.22) !important;
    overflow: hidden !important;
    padding: 0 !important;
    background: #fff !important;
}

.dhx_cal_qi_title {
    background: linear-gradient(90deg, #0f2540 0%, #1e3a5f 100%) !important;
    padding: 12px 16px 10px 16px !important;
    border-radius: 8px 8px 0 0 !important;
    margin: 0 !important;
}

.dhx_cal_qi_controls {
    background: #f7fafd !important;
    padding: 10px 16px !important;
    border-radius: 0 0 8px 8px !important;
    border-top: 1px solid #dce6f0 !important;
    margin: 0 !important;
}

/* ── CHECKLIST DOCUMENTALE ──────────────────────────────────── */

/* Contenitore esterno */
#checklist, #checklist2 {
    border: 1px solid var(--fb-border);
    border-radius: var(--fb-radius-lg);
    overflow: hidden;
    box-shadow: var(--fb-shadow);
    margin: 8px 0 14px 0;
}

/* Ogni riga */
#checklist .form-group,
#checklist2 .form-group {
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 7px 12px !important;
    border-bottom: 1px solid var(--fb-border) !important;
    background: var(--fb-surface) !important;
    min-height: 0 !important;
}
#checklist .col-md-12:last-child .form-group,
#checklist2 .col-md-12:last-child .form-group {
    border-bottom: none !important;
}

/* Testo voce */
#checklist .col-md-10,
#checklist2 .col-md-10 {
    flex: 1 !important;
    width: auto !important;
    padding: 0 !important;
    float: none !important;
}
#checklist .label_checklist,
#checklist2 .label_checklist {
    font-size: 13px !important;
    color: var(--fb-text) !important;
    font-weight: 500 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}

/* Colonne radio */
#checklist .col-md-1,
#checklist2 .col-md-1 {
    flex: 0 0 auto !important;
    width: auto !important;
    padding: 0 0 0 6px !important;
    float: none !important;
}
#checklist .col-md-1 .form-group,
#checklist2 .col-md-1 .form-group {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

/* Reset completo label.container dentro checklist */
#checklist .container,
#checklist2 .container {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    width: auto !important;
    height: auto !important;
    font-size: 0 !important;
    cursor: pointer !important;
    position: static !important;
    user-select: none !important;
}

/* Nascondi la checkmark circolare originale */
#checklist .container .checkmark,
#checklist2 .container .checkmark {
    display: none !important;
}

/* Pill via ::after */
#checklist .container::after,
#checklist2 .container::after {
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 2px 8px !important;
    border-radius: 20px !important;
    border: 1.5px solid var(--fb-border) !important;
    background: var(--fb-surface) !important;
    color: var(--fb-text-muted) !important;
    line-height: 1.4 !important;
    display: inline-block !important;
    transition: all 0.15s ease !important;
    cursor: pointer !important;
}

/* Prima colonna radio = Sì, seconda = No */
#checklist .col-md-1:nth-of-type(2) .container::after,
#checklist2 .col-md-1:nth-of-type(2) .container::after {
    content: 'Sì' !important;
}
#checklist .col-md-1:nth-of-type(3) .container::after,
#checklist2 .col-md-1:nth-of-type(3) .container::after {
    content: 'No' !important;
}

/* Pill attiva Sì */
#checklist .col-md-1:nth-of-type(2) .container:has(input:checked)::after,
#checklist2 .col-md-1:nth-of-type(2) .container:has(input:checked)::after {
    background: #e8f5ee !important;
    border-color: var(--fb-green) !important;
    color: var(--fb-green) !important;
}

/* Pill attiva No */
#checklist .col-md-1:nth-of-type(3) .container:has(input:checked)::after,
#checklist2 .col-md-1:nth-of-type(3) .container:has(input:checked)::after {
    background: #fdecea !important;
    border-color: var(--fb-red) !important;
    color: var(--fb-red) !important;
}