/* =============================================================
   custom.themes.css — sm2care
   Visual System: Midnight Ember (Enterprise)
   Scope: Metronic app shell + core content surfaces
   ============================================================= */

/* =============================================================
   1) Global Tokens
   ============================================================= */
:root {
    /* Neutrals */
    --mbi-white: #ffffff;
    --mbi-ink-950: #0e0f13;
    --mbi-ink-900: #12141a;
    --mbi-slate-700: #3f4652;
    --mbi-slate-600: #5c6470;
    --mbi-slate-500: #6b7280;
    --mbi-slate-400: #9aa4b2;
    --mbi-slate-200: #e7ecf2;

    /* Brand accent */
    --mbi-ember-600: #f97316;
    --mbi-ember-500: #fb923c;

    /* Global sm2care brand aliases.
       Default = warm Midnight Ember. Per cambiare palette in un nuovo
       progetto, sovrascrivere SOLO le --brand-primary* in smconfig/variabili.php
       (SM_BRAND_CSS_VARS). Tutto il resto (badge, btn-primary, page-link, etc.)
       seguira' automaticamente via cascading Bootstrap. */
    --sm2care-primary:            var(--brand-primary, var(--mbi-ember-600));
    --sm2care-primary-hover:      var(--brand-primary-hover, #ea580c);
    --sm2care-primary-active:     var(--brand-primary-active, #c2410c);
    --sm2care-primary-rgb:        var(--brand-primary-rgb, 249, 115, 22);
    --sm2care-primary-hover-rgb:  var(--brand-primary-hover-rgb, 234, 88, 12);
    --sm2care-primary-active-rgb: var(--brand-primary-active-rgb, 194, 65, 12);
    --sm2care-primary-light:      rgba(var(--sm2care-primary-rgb), 0.12);

    /* Radius */
    --mbi-radius-sm: 10px;
    --mbi-radius-md: 12px;
    --mbi-radius-lg: 15px;

    /* Shadows */
    --mbi-shadow-header: 0 1px 2px rgba(15, 23, 42, 0.035), 0 6px 18px rgba(15, 23, 42, 0.045);
    --mbi-shadow-card: 0 1px 2px rgba(15, 23, 42, 0.04), 0 8px 24px rgba(15, 23, 42, 0.06);

    /* Base fallback surfaces */
    --mbi-surface-canvas: #fafbfc;
    --mbi-surface-toolbar: #fafbfc;
    --mbi-surface-card: #ffffff;
    --mbi-surface-border: #e7ecf2;

    /* Bootstrap semantic primary remap */
    --bs-primary: var(--sm2care-primary);
    --bs-primary-rgb: var(--sm2care-primary-rgb);
    --bs-primary-hover: var(--sm2care-primary-hover);
    --bs-primary-hover-rgb: var(--sm2care-primary-hover-rgb);
    --bs-primary-active: var(--sm2care-primary-active);
    --bs-primary-active-rgb: var(--sm2care-primary-active-rgb);
    --bs-text-primary: var(--sm2care-primary);
    --bs-link-color: var(--sm2care-primary);
    --bs-link-hover-color: var(--sm2care-primary-hover);
    --bs-link-hover-color-rgb: var(--sm2care-primary-hover-rgb);
    --bs-focus-ring-color: rgba(var(--sm2care-primary-rgb), 0.24);
    --bs-primary-text-emphasis: #9a3412;
    --bs-primary-bg-subtle: rgba(var(--sm2care-primary-rgb), 0.12);
    --bs-primary-border-subtle: rgba(var(--sm2care-primary-rgb), 0.28);
}

/* Global primary behavior across the whole app (all pages/themes) */
.btn-primary {
    --bs-btn-color: #ffffff;
    --bs-btn-bg: var(--sm2care-primary);
    --bs-btn-border-color: var(--sm2care-primary);
    --bs-btn-hover-color: #ffffff;
    --bs-btn-hover-bg: var(--sm2care-primary-hover);
    --bs-btn-hover-border-color: var(--sm2care-primary-hover);
    --bs-btn-focus-shadow-rgb: var(--sm2care-primary-rgb);
    --bs-btn-active-color: #ffffff;
    --bs-btn-active-bg: var(--sm2care-primary-active);
    --bs-btn-active-border-color: var(--sm2care-primary-active);
    --bs-btn-disabled-color: #ffffff;
    --bs-btn-disabled-bg: var(--sm2care-primary);
    --bs-btn-disabled-border-color: var(--sm2care-primary);
}

.btn-outline-primary {
    --bs-btn-color: var(--sm2care-primary);
    --bs-btn-border-color: rgba(var(--sm2care-primary-rgb), 0.45);
    --bs-btn-hover-color: #ffffff;
    --bs-btn-hover-bg: var(--sm2care-primary);
    --bs-btn-hover-border-color: var(--sm2care-primary);
    --bs-btn-focus-shadow-rgb: var(--sm2care-primary-rgb);
    --bs-btn-active-color: #ffffff;
    --bs-btn-active-bg: var(--sm2care-primary-active);
    --bs-btn-active-border-color: var(--sm2care-primary-active);
    --bs-btn-disabled-color: var(--sm2care-primary);
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: rgba(var(--sm2care-primary-rgb), 0.35);
}

/* =============================================================
   2) Theme: Shell Light
   ============================================================= */
:root[data-sm2care-theme="shell-light"] {
    /* Header */
    --mbi-header-bg: rgba(255, 255, 255, 0.8);
    --mbi-header-border: rgba(148, 163, 184, 0.24);
    --mbi-header-text: #6b7280;
    --mbi-header-text-hover: #111827;
    --mbi-header-btn-bg: rgba(255, 255, 255, 0.64);
    --mbi-header-btn-bg-hover: rgba(255, 255, 255, 0.86);

    /* Sidebar */
    --mbi-sidebar-bg-top: #151821;
    --mbi-sidebar-bg-bottom: #1a1d26;
    --mbi-sidebar-border: rgba(148, 163, 184, 0.12);
    --mbi-sidebar-text: #9aa4b2;
    --mbi-sidebar-text-hover: #f3f4f6;
    --mbi-sidebar-text-active: #eef2f7;
    --mbi-sidebar-heading: #737f90;
    --mbi-menu-hover-bg: rgba(255, 255, 255, 0.035);
    --mbi-menu-active-bg: rgba(249, 115, 22, 0.08);
    --mbi-menu-active-bar: #f97316;
    --mbi-menu-icon-active: #fb923c;
    --mbi-menu-arrow: #697487;
    --mbi-menu-bullet: #5f6979;
    --mbi-menu-bullet-active: #fb923c;
    --mbi-menu-submenu-bg: rgba(255, 255, 255, 0.02);
    --mbi-sidebar-scroll-track: #171b25;
    --mbi-sidebar-scroll-thumb: #3c4554;
    --mbi-sidebar-scroll-thumb-hover: #4d5868;

    /* Content */
    --mbi-surface-canvas: #fafbfd;
    --mbi-surface-toolbar: #f8fafd;
    --mbi-surface-card: #fdfefe;
    --mbi-surface-border: #e7edf4;
    --mbi-surface-muted: #f4f8fc;

    /* Typography */
    --mbi-text-strong: #111827;
    --mbi-text-body: #374151;
    --mbi-text-muted: #6b7280;
    --mbi-table-hover: #fafbfd;

    /* Layout rhythm */
    --mbi-menu-radius: 11px;
    --mbi-menu-item-min-h: 40px;
    --mbi-menu-item-padding-x: 12px;
    --mbi-menu-active-bar-w: 2px;
    --mbi-menu-active-bar-r: 0 999px 999px 0;
}

/* Variant: light sidebar + light top bar */
:root[data-sm2care-theme="shell-light"] {
    --mbi-header-bg: rgba(255, 255, 255, 0.82);
    --mbi-header-border: #e8edf3;
    --mbi-header-text: #6b7280;
    --mbi-header-text-hover: #111827;
    --mbi-header-btn-bg: rgba(255, 255, 255, 0.74);
    --mbi-header-btn-bg-hover: rgba(255, 255, 255, 0.9);

    --mbi-sidebar-bg-top: #f9fafb;
    --mbi-sidebar-bg-bottom: #f3f5f8;
    --mbi-sidebar-border: rgba(148, 163, 184, 0.2);
    --mbi-sidebar-text: #6b7280;
    --mbi-sidebar-text-hover: #111827;
    --mbi-sidebar-text-active: #111827;
    --mbi-sidebar-heading: #9ca3af;
    --mbi-menu-hover-bg: rgba(0, 0, 0, 0.04);
    --mbi-menu-active-bg: rgba(249, 115, 22, 0.06);
    --mbi-menu-active-bar: #f97316;
    --mbi-menu-submenu-bg: rgba(148, 163, 184, 0.09);
    --mbi-menu-arrow: #9ca3af;
    --mbi-menu-bullet: #bcc5d1;
    --mbi-sidebar-scroll-track: #eef2f7;
    --mbi-sidebar-scroll-thumb: #c4ccda;
    --mbi-sidebar-scroll-thumb-hover: #b1bbcc;

    --mbi-surface-canvas: #fafbfd;
    --mbi-surface-card: #ffffff;
    --mbi-surface-border: #e7ecf2;
}

/* =============================================================
   3) Header
   ============================================================= */
:root[data-sm2care-theme="shell-light"] #kt_app_header {
    background-color: var(--mbi-header-bg) !important;
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--mbi-header-border) !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06), 0 1px 0 rgba(255, 255, 255, 0.52) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.28) 0%, rgba(255, 255, 255, 0) 65%);
}

:root[data-sm2care-theme="shell-light"] #kt_app_header::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 1px;
    background: linear-gradient(90deg, rgba(148, 163, 184, 0) 0%, rgba(148, 163, 184, 0.32) 52%, rgba(148, 163, 184, 0) 100%);
    pointer-events: none;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header .app-header-separator {
    display: none;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_toggle,
:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_mobile_toggle,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-icon,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-custom {
    background-color: var(--mbi-header-btn-bg) !important;
    color: var(--mbi-header-text) !important;
    border: 1px solid rgba(148, 163, 184, 0.26);
    border-radius: var(--mbi-radius-sm);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
    transition: background-color 0.16s ease, color 0.16s ease, border-color 0.16s ease;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_toggle:hover,
:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_mobile_toggle:hover,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-icon:hover,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-custom:hover {
    background-color: var(--mbi-header-btn-bg-hover) !important;
    color: var(--mbi-header-text-hover) !important;
    border-color: rgba(148, 163, 184, 0.36);
}

/* Top bar theme switcher */
:root[data-sm2care-theme="shell-light"] #sm2care-theme-switcher {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.26);
    background: rgba(255, 255, 255, 0.6);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

:root[data-sm2care-theme="shell-light"] #sm2care-theme-switcher button {
    appearance: none;
    border: 1px solid transparent;
    background: transparent;
    color: var(--mbi-header-text);
    border-radius: 999px;
    padding: 0.28rem 0.68rem;
    font-size: 0.73rem;
    font-weight: 650;
    line-height: 1.1;
    letter-spacing: 0.01em;
    transition: background-color 0.16s ease, color 0.16s ease, border-color 0.16s ease;
}

:root[data-sm2care-theme="shell-light"] #sm2care-theme-switcher button:hover {
    background: rgba(255, 255, 255, 0.5);
}

:root[data-sm2care-theme="shell-light"] #sm2care-theme-switcher button.active {
    background: rgba(255, 255, 255, 0.86);
    color: #111827;
    border-color: rgba(148, 163, 184, 0.34);
}

:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-icon:focus-visible,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-custom:focus-visible,
:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_toggle:focus-visible,
:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_mobile_toggle:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.14);
    border-color: rgba(249, 115, 22, 0.34);
}

:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-icon i,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-custom i {
    color: inherit;
}

:root[data-sm2care-theme="shell-light"] #kt_header_user_menu_toggle .symbol img {
    border: 2px solid #e7edf4;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header_logo .app-sidebar-logo img {
    filter: none;
}

/* =============================================================
   4) Sidebar
   ============================================================= */
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .app-sidebar-wrapper,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .hover-scroll-y {
    background: linear-gradient(180deg, var(--mbi-sidebar-bg-top) 0%, var(--mbi-sidebar-bg-bottom) 100%) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar {
    border-right: 1px solid var(--mbi-sidebar-border) !important;
    box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.015), inset -18px 0 24px -22px rgba(11, 14, 21, 0.75);
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar {
    box-shadow: inset -1px 0 0 rgba(148, 163, 184, 0.2), inset -12px 0 20px -16px rgba(148, 163, 184, 0.24);
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar_wrapper {
    padding-top: 10px;
    padding-bottom: 10px;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-heading {
    color: var(--mbi-sidebar-heading) !important;
    font-size: 0.67rem;
    font-weight: 640;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-top: 0.3rem;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-link {
    color: var(--mbi-sidebar-text) !important;
    border-radius: var(--mbi-menu-radius);
    min-height: var(--mbi-menu-item-min-h);
    padding-left: var(--mbi-menu-item-padding-x);
    padding-right: var(--mbi-menu-item-padding-x);
    position: relative;
    transition: background-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-link .menu-title,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-link .menu-icon i,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-link .menu-icon svg {
    color: var(--mbi-sidebar-text) !important;
    transition: color 0.16s ease;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-link .menu-arrow {
    color: var(--mbi-menu-arrow) !important;
    transition: color 0.16s ease;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-bullet .bullet {
    background-color: var(--mbi-menu-bullet) !important;
    transition: background-color 0.16s ease;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-sub-accordion {
    background-color: var(--mbi-menu-submenu-bg) !important;
    border-radius: calc(var(--mbi-menu-radius) - 1px);
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar_wrapper::-webkit-scrollbar {
    width: 8px;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar_wrapper::-webkit-scrollbar-track {
    background: var(--mbi-sidebar-scroll-track);
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar_wrapper::-webkit-scrollbar-thumb {
    background: var(--mbi-sidebar-scroll-thumb);
    border-radius: 999px;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar_wrapper::-webkit-scrollbar-thumb:hover {
    background: var(--mbi-sidebar-scroll-thumb-hover);
}

/* =============================================================
   5) Menu States
   ============================================================= */
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item:not(.here):not(.active):not(.open) > .menu-link:hover {
    background-color: var(--mbi-menu-hover-bg) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item:not(.here):not(.active):not(.open) > .menu-link:hover .menu-title,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item:not(.here):not(.active):not(.open) > .menu-link:hover .menu-icon i,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item:not(.here):not(.active):not(.open) > .menu-link:hover .menu-icon svg {
    color: var(--mbi-sidebar-text-hover) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link {
    background-color: var(--mbi-menu-active-bg) !important;
    box-shadow: inset 0 0 0 1px rgba(249, 115, 22, 0.14);
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link::before,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link::before,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link::before {
    content: "";
    position: absolute;
    left: 0;
    top: 8px;
    bottom: 8px;
    width: var(--mbi-menu-active-bar-w);
    border-radius: var(--mbi-menu-active-bar-r);
    background-color: var(--mbi-menu-active-bar);
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link .menu-title,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link .menu-title,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link .menu-title {
    color: var(--mbi-sidebar-text-active) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link .menu-icon i,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link .menu-icon i,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link .menu-icon i,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link .menu-icon svg,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link .menu-icon svg,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link .menu-icon svg {
    color: var(--mbi-menu-icon-active) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link .menu-arrow,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link .menu-arrow,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link .menu-arrow {
    color: var(--mbi-menu-bullet-active) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active .menu-bullet .bullet,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here .menu-bullet .bullet,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open .menu-bullet .bullet {
    background-color: var(--mbi-menu-bullet-active) !important;
}

/* =============================================================
   6) Toolbar / Content
   ============================================================= */
:root[data-sm2care-theme="shell-light"] .app-wrapper,
:root[data-sm2care-theme="shell-light"] .app-main,
:root[data-sm2care-theme="shell-light"] .app-content,
:root[data-sm2care-theme="shell-light"] #kt_app_content,
:root[data-sm2care-theme="shell-light"] #kt_app_main {
    background-color: var(--mbi-surface-canvas) !important;
    background-image: linear-gradient(90deg, rgba(26, 29, 38, 0.045) 0, rgba(26, 29, 38, 0.016) 88px, rgba(26, 29, 38, 0) 160px) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_toolbar,
:root[data-sm2care-theme="shell-light"] .app-toolbar {
    background-color: var(--mbi-surface-toolbar) !important;
    border-bottom: 1px solid rgba(148, 163, 184, 0.2);
    box-shadow: none;
}

:root[data-sm2care-theme="shell-light"] .page-heading,
:root[data-sm2care-theme="shell-light"] .text-gray-900 {
    color: var(--mbi-text-strong) !important;
}

:root[data-sm2care-theme="shell-light"] .text-gray-700,
:root[data-sm2care-theme="shell-light"] .text-gray-600 {
    color: var(--mbi-text-body) !important;
}

:root[data-sm2care-theme="shell-light"] .text-muted,
:root[data-sm2care-theme="shell-light"] .text-gray-500 {
    color: var(--mbi-text-muted) !important;
}

/* =============================================================
   7) Card System
   ============================================================= */
:root[data-sm2care-theme="shell-light"] .card {
    background-color: var(--mbi-surface-card);
    border: 1px solid var(--mbi-surface-border);
    border-radius: var(--mbi-radius-lg);
    box-shadow: var(--mbi-shadow-card);
}

:root[data-sm2care-theme="shell-light"] .card.card-bordered,
:root[data-sm2care-theme="shell-light"] .card.border,
:root[data-sm2care-theme="shell-light"] .card .border,
:root[data-sm2care-theme="shell-light"] .border,
:root[data-sm2care-theme="shell-light"] .border-top,
:root[data-sm2care-theme="shell-light"] .border-bottom,
:root[data-sm2care-theme="shell-light"] .separator {
    border-color: var(--mbi-surface-border) !important;
}

:root[data-sm2care-theme="shell-light"] .card-header {
    border-bottom-color: var(--mbi-surface-border);
}

:root[data-sm2care-theme="shell-light"] .card-header.bg-gray-50 {
    background-color: var(--mbi-surface-muted) !important;
}

/* =============================================================
   8) Table Minimal
   ============================================================= */
:root[data-sm2care-theme="shell-light"] .table > thead > tr > th {
    color: var(--mbi-text-muted) !important;
    border-bottom-color: var(--mbi-surface-border) !important;
    font-weight: 700;
}

:root[data-sm2care-theme="shell-light"] .table > tbody > tr > td {
    border-bottom-color: var(--mbi-surface-border) !important;
    color: var(--mbi-text-body);
}

:root[data-sm2care-theme="shell-light"] .table.table-row-dashed > tbody > tr {
    transition: background-color 0.14s ease;
}

:root[data-sm2care-theme="shell-light"] .table.table-row-dashed > tbody > tr:hover > td {
    background-color: var(--mbi-table-hover) !important;
}

/* =============================================================
   9) Form Elements Essentials
   ============================================================= */
:root[data-sm2care-theme="shell-light"] .form-control,
:root[data-sm2care-theme="shell-light"] .form-select,
:root[data-sm2care-theme="shell-light"] .form-control-solid,
:root[data-sm2care-theme="shell-light"] .form-select-solid,
:root[data-sm2care-theme="shell-light"] .input-group-text {
    background-color: var(--mbi-white);
    border-color: var(--mbi-surface-border);
    color: var(--mbi-text-body);
    border-radius: var(--mbi-radius-sm);
}

:root[data-sm2care-theme="shell-light"] .form-control::placeholder {
    color: #9aa4b2;
}

:root[data-sm2care-theme="shell-light"] .form-control:focus,
:root[data-sm2care-theme="shell-light"] .form-select:focus {
    border-color: rgba(249, 115, 22, 0.34);
    box-shadow: 0 0 0 0.2rem rgba(249, 115, 22, 0.1);
}

:root[data-sm2care-theme="shell-light"] .btn-light {
    background-color: #f4f7fa;
    border-color: #e7edf3;
    color: #4b5563;
}

:root[data-sm2care-theme="shell-light"] .btn-light:hover,
:root[data-sm2care-theme="shell-light"] .btn-light:focus {
    background-color: #edf2f7;
    border-color: #dde6ef;
    color: #374151;
}

:root[data-sm2care-theme="shell-light"] .btn-light-primary {
    background-color: rgba(249, 115, 22, 0.08);
    border-color: rgba(249, 115, 22, 0.16);
    color: #c2410c;
}

:root[data-sm2care-theme="shell-light"] .btn-light-primary:hover,
:root[data-sm2care-theme="shell-light"] .btn-light-primary:focus {
    background-color: rgba(249, 115, 22, 0.12);
    border-color: rgba(249, 115, 22, 0.22);
    color: #9a3412;
}

/* =============================================================
   9.1) Primary Color System (Buttons, Badges, Labels, Utilities)
   ============================================================= */
:root[data-sm2care-theme="shell-light"] .btn-primary {
    background-color: var(--sm2care-primary) !important;
    border-color: var(--sm2care-primary) !important;
    color: #ffffff !important;
}

:root[data-sm2care-theme="shell-light"] .btn-primary:hover,
:root[data-sm2care-theme="shell-light"] .btn-primary:focus,
:root[data-sm2care-theme="shell-light"] .btn-primary:focus-visible {
    background-color: var(--sm2care-primary-hover) !important;
    border-color: var(--sm2care-primary-hover) !important;
    color: #ffffff !important;
    box-shadow: 0 0 0 0.2rem rgba(var(--sm2care-primary-rgb), 0.24) !important;
}

:root[data-sm2care-theme="shell-light"] .btn-check:checked + .btn-primary,
:root[data-sm2care-theme="shell-light"] .btn-primary:active,
:root[data-sm2care-theme="shell-light"] .btn-primary.active,
:root[data-sm2care-theme="shell-light"] .show > .btn-primary.dropdown-toggle {
    background-color: var(--sm2care-primary-active) !important;
    border-color: var(--sm2care-primary-active) !important;
    color: #ffffff !important;
}

:root[data-sm2care-theme="shell-light"] .btn-outline-primary {
    color: var(--sm2care-primary) !important;
    border-color: rgba(var(--sm2care-primary-rgb), 0.45) !important;
}

:root[data-sm2care-theme="shell-light"] .btn-outline-primary:hover,
:root[data-sm2care-theme="shell-light"] .btn-outline-primary:focus,
:root[data-sm2care-theme="shell-light"] .btn-outline-primary:active,
:root[data-sm2care-theme="shell-light"] .btn-check:checked + .btn-outline-primary {
    background-color: var(--sm2care-primary) !important;
    border-color: var(--sm2care-primary) !important;
    color: #ffffff !important;
    box-shadow: 0 0 0 0.2rem rgba(var(--sm2care-primary-rgb), 0.2) !important;
}

:root[data-sm2care-theme="shell-light"] .badge-primary,
:root[data-sm2care-theme="shell-light"] .label-primary {
    background-color: var(--sm2care-primary) !important;
    color: #ffffff !important;
}

:root[data-sm2care-theme="shell-light"] .badge-light-primary,
:root[data-sm2care-theme="shell-light"] .label-light-primary {
    background-color: rgba(var(--sm2care-primary-rgb), 0.12) !important;
    color: #9a3412 !important;
    border: 1px solid rgba(var(--sm2care-primary-rgb), 0.2) !important;
}

:root[data-sm2care-theme="shell-light"] .text-primary,
:root[data-sm2care-theme="shell-light"] .link-primary {
    color: var(--sm2care-primary) !important;
}

:root[data-sm2care-theme="shell-light"] a.text-primary:hover,
:root[data-sm2care-theme="shell-light"] a.link-primary:hover {
    color: var(--sm2care-primary-hover) !important;
}

:root[data-sm2care-theme="shell-light"] .bg-primary {
    background-color: var(--sm2care-primary) !important;
}

:root[data-sm2care-theme="shell-light"] .border-primary {
    border-color: rgba(var(--sm2care-primary-rgb), 0.42) !important;
}

:root[data-sm2care-theme="shell-light"] .nav-pills .nav-link.active,
:root[data-sm2care-theme="shell-light"] .nav-pills .show > .nav-link {
    background-color: var(--sm2care-primary) !important;
}

:root[data-sm2care-theme="shell-light"] .page-item.active .page-link {
    background-color: var(--sm2care-primary) !important;
    border-color: var(--sm2care-primary) !important;
    color: #ffffff !important;
}

:root[data-sm2care-theme="shell-light"] .page-link {
    color: var(--sm2care-primary) !important;
}

:root[data-sm2care-theme="shell-light"] .page-link:hover,
:root[data-sm2care-theme="shell-light"] .page-link:focus {
    color: var(--sm2care-primary-hover) !important;
    box-shadow: 0 0 0 0.2rem rgba(var(--sm2care-primary-rgb), 0.16) !important;
}

:root[data-sm2care-theme="shell-light"] .page-item.active .page-link:hover,
:root[data-sm2care-theme="shell-light"] .page-item.active .page-link:focus {
    color: #ffffff !important;
}

:root[data-sm2care-theme="shell-light"] .form-check-input:checked {
    background-color: var(--sm2care-primary) !important;
    border-color: var(--sm2care-primary) !important;
}

:root[data-sm2care-theme="shell-light"] .form-check-input:focus {
    border-color: rgba(var(--sm2care-primary-rgb), 0.38) !important;
    box-shadow: 0 0 0 0.2rem rgba(var(--sm2care-primary-rgb), 0.16) !important;
}

/* =============================================================
   10) Dropdown / Modal Minimal
   ============================================================= */
:root[data-sm2care-theme="shell-light"] .dropdown-menu,
:root[data-sm2care-theme="shell-light"] .modal-content {
    background-color: var(--mbi-white);
    border: 1px solid var(--mbi-surface-border);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.1);
}

:root[data-sm2care-theme="shell-light"] .dropdown-item {
    color: var(--mbi-text-body);
}

:root[data-sm2care-theme="shell-light"] .dropdown-item:hover,
:root[data-sm2care-theme="shell-light"] .dropdown-item:focus {
    background-color: #fff8f3;
    color: #111827;
}

/* =============================================================
   11) Shell Light Premium
   ============================================================= */

/* 1. Theme selector [data-sm2care-theme="shell-light"] */
:root[data-sm2care-theme="shell-light"] {
    --mbi-menu-radius: 12px;
    --mbi-menu-item-min-h: 42px;
    --mbi-menu-item-padding-x: 14px;
}

/* 2. Sidebar */
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .app-sidebar-wrapper,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .hover-scroll-y {
    background: linear-gradient(180deg, #f9fafb 0%, #f3f5f8 100%) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar {
    border-right: 1px solid rgba(148, 163, 184, 0.2) !important;
    box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.72), 14px 0 28px -28px rgba(148, 163, 184, 0.58) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar_wrapper {
    padding-top: 12px;
    padding-bottom: 12px;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item > .menu-link {
    margin: 2px 6px;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item + .menu-item > .menu-link {
    box-shadow: inset 0 1px 0 rgba(148, 163, 184, 0.08);
}

/* 3. Menu states (hover/active) */
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item:not(.here):not(.active):not(.open) > .menu-link:hover {
    background-color: rgba(0, 0, 0, 0.04) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link {
    background-color: rgba(249, 115, 22, 0.06) !important;
    box-shadow: inset 0 0 0 1px rgba(249, 115, 22, 0.11), 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.active > .menu-link::before,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.here > .menu-link::before,
:root[data-sm2care-theme="shell-light"] #kt_app_sidebar .menu-item.open > .menu-link::before {
    left: 6px;
    top: 9px;
    bottom: 9px;
    width: 2px;
    background-color: #f97316;
}

/* 4. Topbar */
:root[data-sm2care-theme="shell-light"] #kt_app_header {
    background-color: rgba(255, 255, 255, 0.82) !important;
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid #e8edf3 !important;
    box-shadow: 0 8px 20px rgba(148, 163, 184, 0.18), 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header::before {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.32) 0%, rgba(255, 255, 255, 0) 70%);
}

:root[data-sm2care-theme="shell-light"] #kt_app_header::after {
    background: linear-gradient(90deg, rgba(232, 237, 243, 0) 0%, rgba(232, 237, 243, 0.9) 52%, rgba(232, 237, 243, 0) 100%);
}

:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_toggle,
:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_mobile_toggle,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-icon,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-custom {
    background-color: rgba(255, 255, 255, 0.74) !important;
    color: #6b7280 !important;
    border-color: rgba(148, 163, 184, 0.24) !important;
}

:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_toggle:hover,
:root[data-sm2care-theme="shell-light"] #kt_app_header #kt_app_sidebar_mobile_toggle:hover,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-icon:hover,
:root[data-sm2care-theme="shell-light"] #kt_app_header .app-navbar-item .btn-custom:hover {
    background-color: rgba(255, 255, 255, 0.9) !important;
    color: #111827 !important;
}

/* 5. Content background */
:root[data-sm2care-theme="shell-light"] .app-wrapper,
:root[data-sm2care-theme="shell-light"] .app-main,
:root[data-sm2care-theme="shell-light"] .app-content,
:root[data-sm2care-theme="shell-light"] #kt_app_content,
:root[data-sm2care-theme="shell-light"] #kt_app_main {
    background-color: #fafbfd !important;
    background-image: linear-gradient(90deg, rgba(243, 245, 248, 0.75) 0, rgba(243, 245, 248, 0.34) 96px, rgba(250, 251, 253, 0) 180px) !important;
}

/* 6. Card minimal fixes */
:root[data-sm2care-theme="shell-light"] .card {
    background-color: #ffffff;
    border-color: #e7ecf2;
    border-radius: 16px;
    box-shadow: 0 1px 2px rgba(148, 163, 184, 0.2), 0 10px 26px rgba(148, 163, 184, 0.16);
}

/* =============================================================
   12) Reusable Stats Cards (KPI)
   ============================================================= */
.stats-card {
    --stats-accent: #3b82f6;
    --stats-accent-soft: rgba(59, 130, 246, 0.1);
    position: relative;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid #e5e7eb !important;
    border-radius: 14px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 8px 18px rgba(15, 23, 42, 0.05);
    transition: transform 0.18s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.stats-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--stats-accent);
    opacity: 0.92;
}

.stats-card:hover {
    transform: translateY(-2px);
    border-color: #dbe2ea !important;
    box-shadow: 0 2px 5px rgba(15, 23, 42, 0.06), 0 12px 22px rgba(15, 23, 42, 0.07);
}

.stats-card__body {
    gap: 14px;
    padding: 1rem 1.1rem !important;
}

.stats-card__icon {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px;
    border-radius: 12px !important;
    margin-right: 0.1rem !important;
    background: var(--stats-accent-soft) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.78);
}

.stats-card__icon i {
    color: var(--stats-accent) !important;
    font-size: 1.45rem !important;
    line-height: 1;
}

.stats-card__content {
    min-width: 0;
}

.stats-card__value {
    color: #0f172a !important;
    font-size: clamp(1.45rem, 1.85vw, 1.8rem) !important;
    line-height: 1.05;
    font-weight: 760 !important;
    letter-spacing: -0.01em;
}

.stats-card__label {
    margin-top: 0.3rem;
    color: #64748b !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em;
}

.stats-card--primary {
    --stats-accent: #3b82f6;
    --stats-accent-soft: rgba(59, 130, 246, 0.1);
}

.stats-card--success {
    --stats-accent: #22c55e;
    --stats-accent-soft: rgba(34, 197, 94, 0.1);
}

.stats-card--purple {
    --stats-accent: #7c3aed;
    --stats-accent-soft: rgba(124, 58, 237, 0.1);
}

.stats-card--warning {
    --stats-accent: #f59e0b;
    --stats-accent-soft: rgba(245, 158, 11, 0.12);
}

.stats-card--danger {
    --stats-accent: #ef4444;
    --stats-accent-soft: rgba(239, 68, 68, 0.1);
}

/* Scoped tuning for Aziende KPI row */
.stats-grid--legacy .stats-card {
    min-height: 118px;
}

/* Scoped tuning for Utenti SM KPI row */
.stats-grid--utenti-sm .stats-card {
    min-height: 118px;
}

/* Scoped tuning for Analisi KPI row */
.stats-grid--analisi .stats-card {
    min-height: 118px;
}

/* Scoped tuning for Admin Area Utenti KPI row */
.stats-grid--admin-utenti .stats-card {
    min-height: 118px;
}

/* Scoped tuning for Admin Area Moduli KPI row */
.stats-grid--admin-moduli .stats-card {
    min-height: 118px;
}

/* Scoped tuning for Admin Area Analisi KPI row */
.stats-grid--admin-analisi .stats-card {
    min-height: 118px;
}

@media (max-width: 1399.98px) {
    .stats-grid--legacy .stats-card__body {
        padding: 0.95rem 1rem !important;
    }

    .stats-grid--utenti-sm .stats-card__body {
        padding: 0.95rem 1rem !important;
    }

    .stats-grid--analisi .stats-card__body {
        padding: 0.95rem 1rem !important;
    }

    .stats-grid--admin-utenti .stats-card__body {
        padding: 0.95rem 1rem !important;
    }

    .stats-grid--admin-moduli .stats-card__body {
        padding: 0.95rem 1rem !important;
    }

    .stats-grid--admin-analisi .stats-card__body {
        padding: 0.95rem 1rem !important;
    }
}

@media (max-width: 575.98px) {
    .stats-card__icon {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px;
    }

    .stats-card__value {
        font-size: 1.35rem !important;
    }
}
