/* ═══════════════════════════════════════════════════════════
   Cinghialupi Design System — Template Shell v1
   Phase 1: topbar + sidebar (tutte le pagine)
   ═══════════════════════════════════════════════════════════ */

/* ── TOKENS ─────────────────────────────────────────────── */
:root {
  --bg-app:         #06090f;
  --bg-surface:     #0A0F1A;
  --bg-card:        #0f1828;
  --bg-card-alt:    #0d1525;
  --bg-card-raised: #172337;
  --border-subtle:  rgba(255,255,255,0.07);
  --border-card:    rgba(255,255,255,0.11);
  --border-hover:   rgba(255,255,255,0.22);
  --text-primary:   #f1f5f9;
  --text-secondary: #94a3b8;
  --text-muted:     #64748b;
  --accent-green:   #4FDBE6;
  --accent-cyan:    #4FDBE6;
  --accent-gold:    #fbbf24;
  --accent-blue:    #60a5fa;
  --accent-red:     #f87171;
  --role-P: #b45309;
  --role-D: #047857;
  --role-C: #1d4ed8;
  --role-A: #b91c1c;
  --topbar-h:    100px;
  --countdown-h: 0px;
  --sidebar-w:   52px;
  --sidebar-exp: 220px;
}

/* ── RESET — override sb-admin.css e Bootstrap ───────────── */
*,
*::before,
*::after { box-sizing: border-box; }

html,
body { height: 100%; }

body {
  background: var(--bg-app) !important;
  color: var(--text-primary) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px;
  margin-top: 0 !important;   /* override sb-admin margin-top: 100px/50px */
  padding-top: 0 !important;  /* override Bootstrap navbar padding */
  scrollbar-width: thin;
  scrollbar-color: #1e2a40 transparent;
}

body::-webkit-scrollbar { width: 4px; }
body::-webkit-scrollbar-thumb { background: #1e2a40; border-radius: 2px; }

a { text-decoration: none; }

/* ── LAYOUT OVERRIDE (sb-admin) ──────────────────────────── */
#wrapper {
  padding-left: 0 !important;          /* override sb-admin padding-left: 225px */
  margin-left: var(--sidebar-w);
  transition: margin-left .25s ease;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

#wrapper.sidebar-expanded {
  margin-left: var(--sidebar-exp);
}

#page-wrapper {
  background-color: transparent !important;  /* override sb-admin #fff */
  flex: 1;
  padding: 20px !important;
}

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar {
  height: var(--topbar-h);
  background: var(--bg-surface);
  border-bottom: 2px solid #4FDBE6;
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 10px;
  position: sticky;
  top: 0;
  z-index: 200;
  flex-shrink: 0;
}

.topbar-toggle {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  font-size: 16px;
  flex-shrink: 0;
  transition: color .15s, background .15s;
}
.topbar-toggle:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}

.topbar-brand,
.topbar-brand:hover,
.topbar-brand:focus {
  flex-shrink: 0;
  text-decoration: none;
  display: flex;
  align-items: center;
}

.topbar-logo {
  height: 98px;
  width: auto;
  display: block;
}

.topbar-badge-test {
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 10px;
  letter-spacing: .08em;
  color: var(--accent-gold);
  background: rgba(251,191,36,0.1);
  border: 1px solid rgba(251,191,36,0.25);
  border-radius: 4px;
  padding: 2px 6px;
  flex-shrink: 0;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}

.topbar-btn {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  color: var(--text-secondary);
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 500;
  padding: 5px 10px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background .15s, color .15s;
  white-space: nowrap;
  text-decoration: none;
}
.topbar-btn:hover {
  background: rgba(255,255,255,0.09);
  color: var(--text-primary);
}
.topbar-btn.state-ok {
  color: var(--accent-green);
  border-color: rgba(79,219,230,0.3);
}
.topbar-btn.state-ok:hover { background: rgba(79,219,230,0.08); }
.topbar-btn.state-token {
  color: var(--accent-gold);
  border-color: rgba(251,191,36,0.3);
}
.topbar-btn.state-ko { color: var(--text-muted); pointer-events: none; cursor: default; opacity: 0.55; }
.topbar-st-badge.state-ko { color: #f87171; background: rgba(248,113,113,0.1); border-color: rgba(248,113,113,0.3); }

/* ── TOPBAR RIGHT BLOCK — 3 righe verticali [btn | stato/countdown] ── */
.topbar-right-block {
  margin-left: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
}
/* Singola riga: [pulsante] [info a destra] */
.topbar-action-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
/* Pulsanti compatti nella action-row */
.topbar-action-row .topbar-btn {
  justify-content: flex-start;
  width: 112px;
  font-size: 11px;
  padding: 3px 8px;
  min-height: 26px;
}
/* Area info: badge stato + countdown */
.topbar-row-info {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 200px;
}
/* Countdown testuale nella topbar action-row */
.topbar-row-cd {
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 11px;
  color: var(--text-primary);
  letter-spacing: .02em;
  white-space: nowrap;
}

.topbar-divider {
  width: 1px;
  height: 20px;
  background: var(--border-subtle);
  flex-shrink: 0;
}

/* User dropdown */
.topbar-user { position: relative; }

.topbar-user-btn {
  background: none;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 6px;
  transition: color .15s, background .15s;
}
.topbar-user-btn:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}

.topbar-user-dropdown {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: 8px;
  min-width: 140px;
  padding: 4px;
  z-index: 9999;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
.topbar-user-dropdown.open { display: block; }
.topbar-user-dropdown a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 5px;
  font-size: 12px;
  color: var(--text-secondary);
  transition: color .15s, background .15s;
}
.topbar-user-dropdown a:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text-primary);
}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: var(--sidebar-w);
  background: var(--bg-surface);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  z-index: 300;
  transition: width .25s ease;
  overflow: hidden;
}

#wrapper.sidebar-expanded .sidebar {
  width: var(--sidebar-exp);
}

.sidebar-inner {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 0;
  scrollbar-width: none;
}
.sidebar-inner::-webkit-scrollbar { display: none; }

/* ── RAIL ITEMS ──────────────────────────────────────────── */
.rail-item,
.rail-group-toggle {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 9px 0 9px 14px;
  gap: 10px;
  color: var(--text-muted);
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 500;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  white-space: nowrap;
  transition: color .15s, background .15s;
  position: relative;
  text-decoration: none;
}
.rail-item:hover,
.rail-group-toggle:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.04);
}
.rail-item.active {
  color: var(--accent-green);
}
.rail-group.active > .rail-group-toggle {
  color: var(--accent-green);
}
.rail-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 3px;
  background: var(--accent-green);
  border-radius: 0 2px 2px 0;
}

.rail-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 14px;
}

.rail-label {
  opacity: 0;
  transition: opacity .15s ease;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}
#wrapper.sidebar-expanded .rail-label { opacity: 1; }

.rail-caret {
  margin-right: 10px;
  font-size: 10px;
  opacity: 0;
  transition: opacity .15s, transform .2s;
}
#wrapper.sidebar-expanded .rail-caret { opacity: 1; }
.rail-group.open > .rail-group-toggle .rail-caret {
  transform: rotate(180deg);
}

/* ── SUBLINKS ────────────────────────────────────────────── */
.rail-sublinks {
  display: none;
  padding: 0 0 4px 48px;
}
#wrapper.sidebar-expanded .rail-group.open .rail-sublinks {
  display: block;
}
.rail-sublink {
  display: block;
  padding: 5px 0 5px 4px;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  color: var(--text-muted);
  transition: color .15s;
  text-decoration: none;
  white-space: nowrap;
}
.rail-sublink:hover { color: var(--text-primary); }
.rail-sublink.active { color: var(--accent-green); }

/* ── FLYOUT (sidebar collassata, hover su gruppo) ────────── */
.rail-flyout {
  display: none;
  position: fixed;
  left: var(--sidebar-w);
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: 0 8px 8px 0;
  min-width: 160px;
  padding: 6px 0;
  z-index: 9999;
  box-shadow: 4px 4px 20px rgba(0,0,0,0.5);
}
.flyout-label {
  font-family: 'DM Sans', sans-serif;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 4px 14px 6px;
}
.flyout-link {
  display: block;
  padding: 6px 14px;
  font-size: 12px;
  color: var(--text-secondary);
  transition: color .15s, background .15s;
  text-decoration: none;
}
.flyout-link:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.04);
}
.flyout-link.active { color: var(--accent-green); }

/* ── TOOLTIP — CSS tooltip disabilitato dentro th di qualsiasi db-table (usa JS tooltip) ── */
/* Il JS tooltip (dbInitTooltip, position:fixed) gestisce th .db-tip; il CSS ::after è ridondante. */
.db-table th .db-tip::after,
.db-table th .db-tip::before { display: none !important; }

/* ── TOOLTIP ─────────────────────────────────────────────── */
.tip,
.db-tip {
  position: relative;
  overflow: visible;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.tip::after,
.db-tip::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 7px);
  left: 50%;
  transform: translateX(-50%);
  background: #1e2a40;
  color: var(--text-primary);
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  padding: 4px 9px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,0.15);
  box-shadow: 0 4px 14px rgba(0,0,0,0.6);
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s ease .05s;
  z-index: 9999;
}
.tip::before,
.db-tip::before {
  content: '';
  position: absolute;
  bottom: calc(100% + 2px);
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: #1e2a40;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s ease .05s;
  z-index: 9999;
}
.tip:hover::after,
.tip:hover::before,
.db-tip:hover::after,
.db-tip:hover::before { opacity: 1; }
th { overflow: visible !important; }

/* Tooltip nella topbar: appare SOTTO l'elemento (non sopra) per non scomparire fuori schermo */
.topbar .db-tip::after {
  bottom: auto;
  top: calc(100% + 7px);
}
.topbar .db-tip::before {
  bottom: auto;
  top: calc(100% + 2px);
  border-top-color: transparent;
  border-bottom-color: #1e2a40;
}

/* ── COUNTDOWN BAR ─────────────────────────────────────────
   Sticky appena sotto il topbar; bordo ciano per continuità
   visiva con il border-bottom del topbar stesso.             */
.countdown-bar {
  background: var(--bg-surface);
  border-bottom: 1px solid rgba(79,219,230,0.25);
  padding: 7px 24px;
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
  flex-shrink: 0;
  position: sticky;
  top: var(--topbar-h);
  z-index: 160; /* sopra tabbar (150) e sticky table headers (5), sotto topbar (200) e sidebar (300) */
}
.countdown-bar .cb-item {
  display: flex;
  align-items: center;
  gap: 7px;
}
.countdown-bar .cb-icon { color: #4FDBE6; font-size: 11px; opacity: .8; }
.countdown-bar .cb-label { font-size: 11px; color: var(--text-muted); letter-spacing: .04em; }
.countdown-bar .cb-time {
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: var(--text-primary);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 5px;
  padding: 1px 8px;
  letter-spacing: .03em;
}
.cb-time.countdown-warning { color: #fbbf24; border-color: rgba(251,191,36,0.3); background: rgba(251,191,36,0.06); }
.cb-time.countdown-danger  { color: #f87171; border-color: rgba(248,113,113,0.3); background: rgba(248,113,113,0.06); }
.cb-time.countdown-end     { color: var(--text-muted); border-color: transparent; background: transparent; text-decoration: line-through; }

/* ── TOPBAR STATE BADGE (riusato nella action-row) ──────────── */
.topbar-st-badge {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  border-radius: 4px;
  padding: 1px 0;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  color: var(--text-muted);
  min-width: 52px;
  text-align: center;
  flex-shrink: 0;
}
.topbar-st-badge.state-ok,
.topbar-st-badge.state-token {
  color: #4ade80;
  background: rgba(74,222,128,0.1);
  border-color: rgba(74,222,128,0.3);
}
/* Desktop: countdown-bar mobile nascosta (rimpiazzata dal topbar-right-block) */
@media (min-width: 768px) {
  .countdown-bar { display: none !important; }
}

/* ── DISPLAY-ALERTS ──────────────────────────────────────── */
#display-alerts { padding: 0; }

/* Override Bootstrap .alert-info per dark theme */
.alert.alert-info {
  background: rgba(79,219,230,0.07);
  border-color: rgba(79,219,230,0.3);
  color: #a8d8df;
}

/* ── SIDEBAR MOBILE ACTIONS (visibili solo su mobile) ────────── */
.sidebar-mobile-actions { display: none; }

/* ── MOBILE (< 768px) ────────────────────────────────────── */
@media (max-width: 767px) {
  :root { --topbar-h: 60px; }

  .topbar-logo { height: 44px; }

  .topbar-right-block { display: none; }

  .sidebar {
    top: var(--topbar-h);
    height: calc(100vh - var(--topbar-h));
    left: calc(-1 * var(--sidebar-exp));
    width: var(--sidebar-exp);
    transition: left .25s ease, width .25s ease;
  }
  #wrapper.sidebar-expanded .sidebar {
    left: 0;
    width: var(--sidebar-exp);
  }
  #wrapper {
    margin-left: 0 !important;
  }

  .sidebar-mobile-actions {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 8px;
    border-bottom: 1px solid var(--border-subtle);
    margin-bottom: 4px;
  }
  .sidebar-mobile-actions .topbar-btn {
    justify-content: flex-start;
    padding: 8px 12px;
    font-size: 13px;
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════════════
   COMPONENTS — riutilizzabili su tutte le pagine
   ═══════════════════════════════════════════════════════════ */

/* ── Card ────────────────────────────────────────────────── */
.db-card { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: 10px; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.3); }
.db-card-header {
  padding: 10px 14px;
  background: linear-gradient(90deg, rgba(79,219,230,0.15) 0%, rgba(79,219,230,0.04) 70%, transparent 100%);
  border-top: 1px solid rgba(79,219,230,0.10);
  border-bottom: 1px solid rgba(79,219,230,0.25);
  font-family: 'DM Sans', sans-serif;
  font-weight: 900; font-size: 11px; letter-spacing: .13em; text-transform: uppercase;
  color: #f1f5f9;
  display: flex; align-items: center; gap: 8px;
}
.db-card-header i { color: #4FDBE6; opacity: 0.85; }

.db-card-body { padding: 12px 14px; }
.db-card-footer { padding: 10px 14px; border-top: 1px solid var(--border-subtle); background: var(--bg-card-alt); color: var(--text-secondary); }
.db-card-footer:hover { background: rgba(255,255,255,0.03); }

/* ── Coppa: riga partita ─────────────────────────────────── */
.cup-match-row {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.cup-match-row--clickable { cursor: pointer; }
.cup-match-row--clickable:hover { filter: brightness(1.25); }
.cup-match-home { flex: 1; text-align: left; }
.cup-match-score { width: 80px; text-align: center; font-weight: 700; color: var(--accent-cyan); }
.cup-match-away { flex: 1; text-align: right; }
.cup-winner { color: var(--accent-green); font-weight: 700; }
.cup-aggregate { display: block; font-size: 11px; color: #888; margin-top: 2px; }

/* ── Coppa: blocco giornata (wrapper per separatore) ─────── */
.cup-giornata-block + .cup-giornata-block > .cup-giornata-header {
  border-top: 2px solid rgba(251,191,36,0.18);
}
/* In calendario: margine superiore e alternanza colore per separare giornate */
#body-calendario .cup-giornata-block + .cup-giornata-block { margin-top: 18px; }
#body-calendario .cup-giornata-block:nth-child(even) { background: rgba(255,255,255,0.025); border-radius: 4px; }

/* ── Coppa: header giornata ──────────────────────────────── */
.cup-giornata-header {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900;
  font-size: 12px;
  color: var(--accent-gold);
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 8px 14px;
  background: linear-gradient(90deg, rgba(251,191,36,0.13) 0%, transparent 60%);
  border-bottom: 1px solid rgba(251,191,36,0.18);
  margin-bottom: 10px;
}

/* ── Coppa: fase-selector (livello principale, stile cyan) ── */
#row-fase-selector > div { padding-left: 0; padding-right: 0; }
#fase-selector.db-tabbar { position: static; }
#fase-selector .cup-fase-tab.active { color: var(--text-primary) !important; border-bottom-color: var(--accent-cyan) !important; }

/* ── Coppa: coppa-tabbar come sottomenu (quando fase-selector visibile) ── */
#coppa-tabbar.cup-tabbar--sub {
  padding-left: 8px;
  background: rgba(255,255,255,0.015);
  border-left: 3px solid rgba(251,191,36,0.35);
  position: static;
}
/* Freccia unica sul container, non sui singoli tab */
#coppa-tabbar.cup-tabbar--sub::before {
  content: '↳';
  color: var(--accent-gold);
  opacity: 0.65;
  font-size: 12px;
  padding: 0 8px;
  align-self: center;
  flex-shrink: 0;
}
#coppa-tabbar.cup-tabbar--sub .db-tab { color: var(--accent-gold); opacity: 0.75; }
#coppa-tabbar.cup-tabbar--sub .db-tab.active {
  color: var(--text-primary) !important;
  border-bottom-color: var(--accent-gold) !important;
  opacity: 1;
}
#coppa-tabbar.cup-tabbar--sub .db-tab::before { content: none; }
#coppa-tabbar:not(.cup-tabbar--sub) .db-tab.active { border-bottom-color: var(--accent-cyan); }

/* ── Coppa: zone classifica (per leghe 20 squadre) — verde/gold/ciano/arancio/rosso */
.cup-zona-cl      { border-left: 3px solid #22c55e; background: linear-gradient(90deg, rgba(34,197,94,0.22) 0%, transparent 55%) !important; }
.cup-zona-playoff { border-left: 3px solid #fbbf24; background: linear-gradient(90deg, rgba(251,191,36,0.22) 0%, transparent 55%) !important; }
.cup-zona-el      { border-left: 3px solid #4FDBE6; background: linear-gradient(90deg, rgba(79,219,230,0.22) 0%, transparent 55%) !important; }
.cup-zona-playout { border-left: 3px solid #f97316; background: linear-gradient(90deg, rgba(249,115,22,0.22) 0%, transparent 55%) !important; }
.cup-zona-conf    { border-left: 3px solid #ef4444; background: linear-gradient(90deg, rgba(239,68,68,0.22) 0%, transparent 55%) !important; }

/* ── Coppa: match rows migliorati ────────────────────────── */
.cup-match-home, .cup-match-away { font-weight: 600; font-size: 13px; }
.cup-match-row:nth-child(even) { background: rgba(255,255,255,0.02); }

/* ── Card collassabile ───────────────────────────────────── */
.db-card--collapsible .db-card-header { cursor: pointer; user-select: none; }
.db-card--collapsible .db-card-header::after {
  content: '▼';
  margin-left: auto;
  font-size: 10px;
  opacity: 0.6;
  transition: transform 0.2s;
}
.db-card--collapsible.collapsed .db-card-header::after { transform: rotate(-90deg); }
.db-card--collapsible.collapsed .db-card-body { display: none; }

/* ── KPI card ────────────────────────────────────────────── */
.kpi-card {
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: 9px;
  padding: 14px 16px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
.kpi-label { font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted); }
.kpi-value { font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 32px; line-height: 1; margin-top: 10px; }
.kpi-sub   { font-size: 11px; color: var(--text-muted); margin-top: 4px; }

/* ── KPI pill ────────────────────────────────────────────── */
.kpi-pill { display: flex; align-items: center; gap: 10px; padding: 8px 14px; background: var(--bg-card); border: 1px solid var(--border-card); border-radius: 8px; }
.kpi-pill-label { font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); }
.kpi-pill-value { font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 20px; margin-left: 4px; }

/* ── Badge ───────────────────────────────────────────────── */
.db-badge { font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 10px; letter-spacing: .07em; text-transform: uppercase; padding: 2px 8px; border-radius: 4px; }
.db-badge-green { background: rgba(34,197,94,0.12);   border: 1px solid rgba(34,197,94,0.3);   color: #4ade80; }
.db-badge-red   { background: rgba(248,113,113,0.12); border: 1px solid rgba(248,113,113,0.3); color: #f87171; }
.db-badge-blue  { background: rgba(96,165,250,0.12);  border: 1px solid rgba(96,165,250,0.3);  color: #93c5fd; }
.db-badge-gold  { background: rgba(251,191,36,0.12);  border: 1px solid rgba(251,191,36,0.3);  color: #fbbf24; }
.db-badge-gray  { background: rgba(100,116,139,0.12); border: 1px solid rgba(100,116,139,0.3); color: #94a3b8; }
.db-badge-cyan  { background: rgba(79,219,230,0.12);  border: 1px solid rgba(79,219,230,0.35);  color: #4FDBE6; }

/* ── Banner informativo ──────────────────────────────────── */
.db-banner { border-left: 3px solid var(--accent-cyan); background: rgba(79,219,230,0.06); border-radius: 0 8px 8px 0; padding: 14px 18px; color: var(--text-primary); margin-bottom: 16px; }
.db-banner p { margin: 0 0 8px 0; }
.db-banner p:last-child { margin-bottom: 0; }

/* ── Progress stat (card con barra avanzamento) ──────────── */
.db-progress-stat { padding: 4px 0; }
.db-progress-stat .db-progress-numbers { display: flex; justify-content: space-between; font-size: 13px; margin-bottom: 6px; }
.db-progress-stat .db-progress-numbers .done { font-size: 22px; font-weight: 700; color: var(--text-primary); line-height: 1; }
.db-progress-stat .db-progress-numbers .missing { color: var(--text-muted); align-self: flex-end; }

/* ── Role badge (square, tabelle) ────────────────────────── */
.role-badge { width: 20px; height: 20px; border-radius: 5px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 10px; }
.role-badge.P { background: rgba(180,83,9,0.18);  border: 1px solid rgba(180,83,9,0.4);  color: #b45309; }
.role-badge.D { background: rgba(4,120,87,0.18);  border: 1px solid rgba(4,120,87,0.4);  color: #047857; }
.role-badge.C { background: rgba(29,78,216,0.18); border: 1px solid rgba(29,78,216,0.4); color: #1d4ed8; }
.role-badge.A { background: rgba(185,28,28,0.18); border: 1px solid rgba(185,28,28,0.4); color: #b91c1c; }

/* ── Role badge (circle, formazione) ─────────────────────── */
.role-badge-circle { width: 24px; height: 24px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 11px; color: #fff; }
.role-badge-circle.P { background: #b45309; }
.role-badge-circle.D { background: #047857; }
.role-badge-circle.C { background: #1d4ed8; }
.role-badge-circle.A { background: #b91c1c; }

/* ── Captain badge ───────────────────────────────────────── */
.capt-badge { width: 22px; height: 22px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 9px; }
.capt-badge.C  { border: 2px solid #fbbf24; background: rgba(251,191,36,0.15); color: #fbbf24; }
.capt-badge.VC { border: 2px solid #94a3b8; background: rgba(148,163,184,0.12); color: #94a3b8; }

/* ── Table ───────────────────────────────────────────────── */
.db-table { width: 100%; border-collapse: collapse; }
.db-table thead tr { background: rgba(255,255,255,0.025); border-bottom: 1px solid var(--border-subtle); }
.db-table thead th { padding: 8px 14px; font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 10px; letter-spacing: .09em; text-transform: uppercase; color: var(--text-muted); overflow: visible; position: relative; }
.db-table th.sort-active { color: var(--accent-green); border-bottom: 2px solid var(--accent-green); }
.db-table th.db-sortable { cursor: pointer; user-select: none; }
.db-table tbody tr { border-bottom: 1px solid rgba(255,255,255,0.04); transition: background .1s; }
.db-table tbody tr:nth-child(even) { background: rgba(255,255,255,0.015); }
.db-table tbody tr:hover { background: rgba(255,255,255,0.035) !important; }
.db-table tbody td { padding: 9px 14px; }
/* Header tabelle: gradiente ciano con colori solidi (niente rgba trasparenti → niente bleeding
   del contenuto dietro le righe sticky durante lo scroll). Colori calcolati su #0A0F1A:
   rgba(79,219,230,0.15) → #142E39 | rgba(79,219,230,0.05) → #0D1924 */
tr.db-table-thead {
  background: linear-gradient(90deg, #142E39 0%, #0D1924 60%, #0A0F1A 100%) !important;
}
/* Border applicata sui th (non tr) perché border-collapse ignora i border dei tr.
   background: transparent override il tablesorter-bootstrap che imposta #eee sugli th. */
tr.db-table-thead th {
  color: var(--text-secondary);
  border-bottom: 2px solid rgba(79,219,230,0.3) !important;
  background: transparent !important;
}

.db-sticky thead { position: sticky; top: 0; z-index: 5; }
.db-sticky thead tr { background: var(--bg-surface); }
.db-sticky thead tr.db-table-thead {
  background: linear-gradient(90deg, #142E39 0%, #0D1924 60%, #0A0F1A 100%) !important;
}

/* ── Filtri per colonna (riga sotto gli header, es. calciatori-v2) ─── */
.calc-filter-th { padding: 4px 6px !important; background: rgba(255,255,255,0.03); }
.calc-col-filter {
  width: 100%; box-sizing: border-box;
  font-size: 10px; padding: 3px 5px;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 4px; color: var(--text-secondary);
  font-family: 'DM Sans', sans-serif;
}
.calc-col-filter:focus { outline: none; border-color: rgba(79,219,230,0.4); background: rgba(79,219,230,0.06); }
/* Nasconde le frecce spinner degli input number */
.calc-col-filter[type=number]::-webkit-inner-spin-button,
.calc-col-filter[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.calc-col-filter[type=number] { -moz-appearance: textfield; }

/* ── Toolbar + pills ─────────────────────────────────────── */
.db-toolbar { display: flex; align-items: center; gap: 8px; padding: 10px 16px; border-bottom: 1px solid var(--border-subtle); background: var(--bg-surface); flex-shrink: 0; flex-wrap: wrap; }
.db-pill { padding: 4px 12px; border-radius: 6px; cursor: pointer; font-family: 'DM Sans', sans-serif; font-weight: 800; font-size: 12px; letter-spacing: .06em; border: 1.5px solid rgba(255,255,255,0.09); background: transparent; color: var(--text-muted); transition: all .12s; }
.db-pill.active    { border-color: var(--accent-green); background: rgba(79,219,230,0.1); color: var(--accent-green); }
.db-pill.active-P  { border-color: #b45309; background: rgba(180,83,9,0.1);   color: #b45309; }
.db-pill.active-D  { border-color: #047857; background: rgba(4,120,87,0.1);   color: #047857; }
.db-pill.active-C  { border-color: #1d4ed8; background: rgba(29,78,216,0.1);  color: #1d4ed8; }
.db-pill.active-A  { border-color: #b91c1c; background: rgba(185,28,28,0.1);  color: #b91c1c; }
.db-pill.active-AV { border-color: #4ade80; background: rgba(34,197,94,0.1);   color: #4ade80; }
.db-pill.active-AP { border-color: #f87171; background: rgba(248,113,113,0.1); color: #f87171; }
.db-pill.active-AC { border-color: #fbbf24; background: rgba(251,191,36,0.1);  color: #fbbf24; }
.db-pill.active-VE { border-color: #94a3b8; background: rgba(100,116,139,0.1); color: #94a3b8; }
/* Select giornata nella toolbar della pagina punteggi */
.pnt-select { background: var(--bg-surface); border: 1.5px solid var(--border-subtle); border-radius: 6px; color: var(--text-primary); font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 13px; padding: 4px 10px; cursor: pointer; outline: none; transition: border-color .12s; }
.pnt-select:hover, .pnt-select:focus { border-color: var(--border-hover); }

/* ── Search ──────────────────────────────────────────────── */
.db-search { height: 30px; padding: 0 10px; width: 180px; background: rgba(255,255,255,0.04); border: 1.5px solid rgba(255,255,255,0.1); border-radius: 7px; color: var(--text-primary); font-family: 'DM Sans', sans-serif; font-size: 12px; outline: none; }
.db-search::placeholder { color: var(--text-muted); }

/* ── Stat row ────────────────────────────────────────────── */
.stat-row { display: flex; align-items: center; gap: 10px; padding: 8px 14px; border-bottom: 1px solid rgba(255,255,255,0.04); transition: background .1s; }
.stat-row:hover { background: rgba(255,255,255,0.025); }
.stat-icon { width: 18px; font-size: 12px; display: flex; justify-content: center; flex-shrink: 0; }
.stat-label { flex: 1; font-size: 13px; color: var(--text-secondary); }
.stat-value { font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 16px; }

/* Card wrapper per i grafici Highcharts nella pagina statistiche v2 */
.stat-chart-card { background: var(--bg-card-raised); border: 1px solid var(--border-card); border-radius: 10px; padding: 16px 8px 8px; }

/* ── Section headers ─────────────────────────────────────── */
.form-section-header { padding: 7px 16px; background: rgba(255,255,255,0.04); border-top: 1px solid rgba(255,255,255,0.07); border-bottom: 1px solid rgba(255,255,255,0.07); display: flex; align-items: center; gap: 8px; font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.rosa-section-header td { padding: 6px 14px; border-top: 1px solid rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); }
.rosa-section-label { font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }

/* ── Modal ───────────────────────────────────────────────── */
.db-modal-overlay { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: flex-start; justify-content: center; padding-top: 80px; background: rgba(0,0,0,0.75); backdrop-filter: blur(4px); }
.db-modal { background: #0d1525; border: 1px solid rgba(255,255,255,0.13); border-radius: 12px; width: 92%; max-width: 860px; max-height: 88vh; display: flex; flex-direction: column; box-shadow: 0 24px 64px rgba(0,0,0,0.8); }
.db-modal-header { padding: 12px 18px; border-bottom: 1px solid rgba(255,255,255,0.08); display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.db-modal-body { overflow-y: auto; flex: 1; }
.db-modal-close { width: 28px; height: 28px; border-radius: 6px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); color: var(--text-muted); display: flex; align-items: center; justify-content: center; cursor: pointer; margin-left: 8px; font-size: 13px; }
.db-modal-close:hover { background: rgba(255,255,255,0.12); }

/* ── Grid helpers ────────────────────────────────────────── */
.db-grid-4   { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.db-grid-2   { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.db-grid-1-1 { display: grid; grid-template-columns: 1.1fr 1fr; gap: 14px; }
@media (max-width: 900px) {
  .db-grid-4   { grid-template-columns: repeat(2,1fr); }
  .db-grid-2, .db-grid-1-1 { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .db-grid-4 { grid-template-columns: 1fr; }
}

/* ── Number helpers ──────────────────────────────────────── */
.db-zero      { color: rgba(100,116,139,0.4); font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 13px; }
.db-num       { font-family: 'DM Sans', sans-serif; font-weight: 900; font-size: 13px; color: var(--text-primary); }
.db-num-green { color: #4ade80; }
.db-num-red   { color: #f87171; }
.db-num-gold  { color: #fbbf24; }
.fmed-high    { color: #4ade80; background: rgba(74,222,128,0.1);  padding: 1px 5px; border-radius: 4px; }
.fmed-mid     { color: #a3e635; background: rgba(163,230,53,0.08); padding: 1px 5px; border-radius: 4px; }
.fmed-ok      { color: var(--text-primary); }
.fmed-warn    { color: #f59e0b; }
.fmed-low     { color: #f87171; }

/* ── Profile strip ───────────────────────────────────────── */
.profile-strip { display: flex; align-items: center; gap: 16px; background: var(--bg-card); border: 1px solid var(--border-card); border-radius: 10px; padding: 14px 18px; box-shadow: 0 1px 3px rgba(0,0,0,0.3); margin-bottom: 14px; }

/* ── Rosa player link ────────────────────────────────────── */
.rosa-player-link { font-family: 'DM Sans', sans-serif; font-weight: 800; font-size: 13px; color: var(--text-primary); line-height: 1.1; text-decoration: none; display: block; }
.rosa-player-link:hover { color: var(--accent-green); text-decoration: underline; }

/* ═══════════════════════════════════════════════════════════
   ROSE PAGE
   ═══════════════════════════════════════════════════════════ */

/* ── Grid ────────────────────────────────────────────────── */
.rose-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  padding: 14px 0;
}
.rose-grid > .db-card { min-width: 0; }
@media (max-width: 1400px) { .rose-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1100px) { .rose-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px)  { .rose-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .rose-grid { grid-template-columns: 1fr; } }

/* ── Card interna ────────────────────────────────────────── */
.rose-subheader {
  font-style: italic;
  font-size: 12px;
  color: var(--text-secondary);
  padding: 5px 12px;
  border-bottom: 1px solid var(--border-subtle);
}
.rose-logo-section {
  text-align: center;
  padding: 8px;
  border-bottom: 1px solid var(--border-subtle);
}
.rose-logo {
  max-height: 200px;
  max-width: 100%;
  display: inline-block;
}

/* ── Player row base ─────────────────────────────────────── */
.rose-row {
  height: 26px;
  padding: 0 8px 0 10px;
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  border-left: 3px solid transparent;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
}
.rose-row-name {
  flex: 1;
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Gradiente + bordo per ruolo ─────────────────────────── */
/* Self-contained: funzionano sia su .rose-row (div) sia standalone su div/tr */
.rose-row-p {
  background: linear-gradient(90deg, rgba(180,83,9,0.18) 0%, rgba(180,83,9,0.05) 60%, transparent 100%);
  border-left: 3px solid #b45309;
}
.rose-row-d {
  background: linear-gradient(90deg, rgba(4,120,87,0.18) 0%, rgba(4,120,87,0.05) 60%, transparent 100%);
  border-left: 3px solid #047857;
}
.rose-row-c {
  background: linear-gradient(90deg, rgba(29,78,216,0.18) 0%, rgba(29,78,216,0.05) 60%, transparent 100%);
  border-left: 3px solid #1d4ed8;
}
.rose-row-a {
  background: linear-gradient(90deg, rgba(185,28,28,0.18) 0%, rgba(185,28,28,0.05) 60%, transparent 100%);
  border-left: 3px solid #b91c1c;
}
.rose-row-bench {
  background: linear-gradient(90deg, rgba(0,0,0,0.50) 0%, rgba(0,0,0,0.18) 60%, transparent 100%);
  border-left: 3px solid rgba(255,255,255,0.18);
}
/* Su <tr> in tabelle border-collapse il border va sul primo td */
tr.rose-row-p > td:first-child { border-left: 3px solid #b45309; }
tr.rose-row-d > td:first-child { border-left: 3px solid #047857; }
tr.rose-row-c > td:first-child { border-left: 3px solid #1d4ed8; }
tr.rose-row-a > td:first-child { border-left: 3px solid #b91c1c; }
/* !important necessario: su <tr> in db-table, nth-child(even) e :hover !important sovrascrivono il gradiente ruolo */
.db-table tbody tr.rose-row-p { background: linear-gradient(90deg, rgba(180,83,9,0.18) 0%, rgba(180,83,9,0.05) 60%, transparent 100%) !important; }
.db-table tbody tr.rose-row-d { background: linear-gradient(90deg, rgba(4,120,87,0.18) 0%, rgba(4,120,87,0.05) 60%, transparent 100%) !important; }
.db-table tbody tr.rose-row-c { background: linear-gradient(90deg, rgba(29,78,216,0.18) 0%, rgba(29,78,216,0.05) 60%, transparent 100%) !important; }
.db-table tbody tr.rose-row-a { background: linear-gradient(90deg, rgba(185,28,28,0.18) 0%, rgba(185,28,28,0.05) 60%, transparent 100%) !important; }
/* Hover gold — stesso stile di rose.php */
.db-table tbody tr.rose-row-p:hover,
.db-table tbody tr.rose-row-d:hover,
.db-table tbody tr.rose-row-c:hover,
.db-table tbody tr.rose-row-a:hover { background: rgba(251,191,36,0.82) !important; filter: brightness(1) !important; }
.db-table tbody tr.rose-row-p:hover .rosa-player-link,
.db-table tbody tr.rose-row-d:hover .rosa-player-link,
.db-table tbody tr.rose-row-c:hover .rosa-player-link,
.db-table tbody tr.rose-row-a:hover .rosa-player-link,
.db-table tbody tr.rose-row-p:hover .db-num,
.db-table tbody tr.rose-row-d:hover .db-num,
.db-table tbody tr.rose-row-c:hover .db-num,
.db-table tbody tr.rose-row-a:hover .db-num,
.db-table tbody tr.rose-row-p:hover .db-num-green,
.db-table tbody tr.rose-row-d:hover .db-num-green,
.db-table tbody tr.rose-row-c:hover .db-num-green,
.db-table tbody tr.rose-row-a:hover .db-num-green,
.db-table tbody tr.rose-row-p:hover .db-num-red,
.db-table tbody tr.rose-row-d:hover .db-num-red,
.db-table tbody tr.rose-row-c:hover .db-num-red,
.db-table tbody tr.rose-row-a:hover .db-num-red,
.db-table tbody tr.rose-row-p:hover .db-num-gold,
.db-table tbody tr.rose-row-d:hover .db-num-gold,
.db-table tbody tr.rose-row-c:hover .db-num-gold,
.db-table tbody tr.rose-row-a:hover .db-num-gold,
.db-table tbody tr.rose-row-p:hover .db-zero,
.db-table tbody tr.rose-row-d:hover .db-zero,
.db-table tbody tr.rose-row-c:hover .db-zero,
.db-table tbody tr.rose-row-a:hover .db-zero { color: #1a1a2e !important; }

/* ── Gradiente + bordo per stati speciali (sovrascrivono il ruolo) ── */
.rose-row-token {
  background: linear-gradient(90deg, rgba(251,191,36,0.55) 0%, rgba(251,191,36,0.28) 50%, rgba(251,191,36,0.08) 100%);
  border-left-color: #fbbf24;
}
.rose-row-nolist {
  background: linear-gradient(90deg, rgba(100,116,139,0.45) 0%, rgba(100,116,139,0.20) 50%, rgba(100,116,139,0.06) 100%);
  border-left-color: rgba(255,255,255,0.3);
}
.rose-row-nolist .rose-row-name { color: var(--text-muted); text-decoration: line-through; }
.rose-row-new {
  background: linear-gradient(90deg, rgba(251,191,36,0.55) 0%, rgba(251,191,36,0.28) 50%, rgba(251,191,36,0.08) 100%);
  border-left-color: #fbbf24;
}
/* Giocatore della propria rosa — gradiente ciano, hover gold via page CSS */
.rose-row-own {
  background: linear-gradient(90deg, rgba(79,219,230,0.25) 0%, rgba(79,219,230,0.10) 60%, transparent 100%);
  border-left-color: #4FDBE6;
}
tr.rose-row-own > td:first-child { border-left: 3px solid #4FDBE6; }

/* ── Slot vuoto ──────────────────────────────────────────── */
.rose-row-empty {
  height: 26px;
  border-bottom: 1px dashed rgba(255,255,255,0.06);
}

/* ── Icone stato ─────────────────────────────────────────── */
.rose-icon       { font-size: 10px; flex-shrink: 0; }
.rose-icon-gold  { color: #fbbf24; }
.rose-icon-muted { color: var(--text-muted); }
.rose-icon-cyan  { color: #4FDBE6; }
.rose-row-p .rose-icon-role { color: #b45309; }
.rose-row-d .rose-icon-role { color: #047857; }
.rose-row-c .rose-icon-role { color: #1d4ed8; }
.rose-row-a .rose-icon-role { color: #b91c1c; }

/* ── Hover riga giocatore (stesso stile mercato: bg gold, testo scuro) ── */
.rose-row:hover {
  background: rgba(251,191,36,0.82) !important;
  filter: none !important;
}
.rose-row:hover .rose-row-name,
.rose-row:hover .rose-icon {
  color: #1a1a2e !important;
}

/* ── Manager List ────────────────────────────────────────── */
/* Flex sul row così tutte le card della stessa riga si allineano in altezza */
#ml-cards-view { display: flex; flex-wrap: wrap; }
#ml-cards-view > div[class*="col-"] { display: flex; flex-direction: column; }
.ml-manager-card { display: flex; flex-direction: column; flex: 1; margin-bottom: 20px; }
.ml-card-body { padding: 14px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
/* Riga identità: logo 60% | info 40% */
.ml-identity-row { display: flex; flex-direction: row; align-items: center; gap: 0; }
.ml-identity-logo { flex: 0 0 60%; display: flex; align-items: center; justify-content: center; }
.ml-identity-info { flex: 0 0 40%; display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.ml-team-logo-big { max-width: 90px; max-height: 90px; width: 100%; object-fit: contain; }
.ml-no-logo { width: 60px; height: 60px; border-radius: 50%; background: rgba(255,255,255,0.05); }
.ml-manager-name { font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 13px; color: var(--text-primary); word-break: break-word; }
.ml-manager-username { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--text-muted); }
.ml-patrimonio { margin-top: 6px; display: flex; flex-direction: column; gap: 2px; }
.ml-patrimonio-val { font-size: 18px !important; }
.ml-stat-label { font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); display: block; }
.ml-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ml-stat { display: flex; flex-direction: column; gap: 2px; }
.ml-stat-full { grid-column: span 2; }

.ml-card-footer { padding: 10px 14px; border-top: 1px solid var(--border-subtle); cursor: pointer; }
.ml-card-footer:hover { background: rgba(255,255,255,0.03); }
.ml-card-footer .dettaglioUtente { color: var(--text-muted); font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 700; white-space: nowrap; }
.ml-card-footer .dettaglioUtente:hover { color: var(--accent-green); }

/* ── Tab bar (condiviso: dashboard, classifica, …) ───────── */
.db-tabbar {
  display: flex;
  align-items: stretch;
  border-bottom: 1px solid var(--border-subtle);
  background: var(--bg-surface);
  padding-left: 24px;
  flex-shrink: 0;
  overflow-x: auto;
  position: sticky;
  top: calc(var(--topbar-h) + var(--countdown-h, 0px));
  z-index: 150;
}
.db-tab {
  height: 40px;
  padding: 0 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-muted);
  cursor: pointer;
  transition: all .12s;
  white-space: nowrap;
}
.db-tab.active { color: var(--text-primary); border-bottom-color: var(--accent-green); }
.db-tab:hover:not(.active) { color: var(--text-secondary); }
.db-content.tab-padded { padding: 20px; }

/* ── Classifica — righe top/bottom ───────────────────────── */
/* Selettore più specifico di db-table tbody tr:nth-child(even) — evita che lo striped sovrascriva il gradiente */
.db-table tbody tr.clf-row-top    { border-left: 3px solid var(--accent-gold); background: linear-gradient(90deg, rgba(251,191,36,0.18) 0%, transparent 60%); }
.db-table tbody tr.clf-row-bottom { border-left: 3px solid var(--accent-red);  background: linear-gradient(90deg, rgba(248,113,113,0.18) 0%, transparent 60%); }
.db-table tbody tr.clf-row-top:hover    { background: linear-gradient(90deg, rgba(251,191,36,0.32) 0%, transparent 60%) !important; }
.db-table tbody tr.clf-row-bottom:hover { background: linear-gradient(90deg, rgba(248,113,113,0.32) 0%, transparent 60%) !important; }

/* ── Montepremi — bottoni di voto e conferma ─────────────── */
.mp-vote-btn { display:inline-flex; align-items:center; justify-content:center; min-width:48px; height:48px; padding:0 16px; border-radius:8px; border:1.5px solid var(--border-subtle); background:var(--bg-surface); color:var(--text-secondary); font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:22px; cursor:pointer; transition:all .12s; user-select:none; margin:0; }
.mp-vote-btn:hover:not(.disabled) { border-color:var(--border-hover); color:var(--text-primary); background:rgba(255,255,255,0.05); }
.mp-vote-btn.active { border-color:#4FDBE6; background:rgba(79,219,230,0.12); color:#4FDBE6; }
.mp-vote-btn.disabled { opacity:0.3; cursor:not-allowed; pointer-events:none; }
.mp-confirm-btn { display:inline-flex; align-items:center; padding:10px 24px; border-radius:8px; border:1.5px solid rgba(79,219,230,0.4); background:rgba(79,219,230,0.08); color:#4FDBE6; font-family:'DM Sans',sans-serif; font-weight:900; font-size:12px; letter-spacing:.07em; text-transform:uppercase; cursor:pointer; transition:all .12s; }
.mp-confirm-btn:hover:not(:disabled) { background:rgba(79,219,230,0.16); border-color:#4FDBE6; }
.mp-confirm-btn:disabled { opacity:0.35; cursor:not-allowed; }

/* ── Bootbox / Modal dark theme ──────────────────────────── */
.bootbox .modal-content {
  background: rgba(10,14,26,0.98) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 10px !important;
  color: #e8eaf0 !important;
  font-family: 'DM Sans', sans-serif;
}
.bootbox .modal-header {
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  background: transparent !important;
  padding: 12px 16px;
}
.bootbox .modal-header .close {
  color: rgba(255,255,255,0.35) !important;
  opacity: 1 !important;
  text-shadow: none !important;
  font-size: 18px;
}
.bootbox .modal-header .close:hover { color: rgba(255,255,255,0.7) !important; }
.bootbox .modal-body {
  background: transparent !important;
  color: #c8cfe0 !important;
  padding: 16px !important;
  font-size: 14px;
}
.bootbox .modal-body h3,
.bootbox .modal-body h4 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 18px !important;
  margin-bottom: 8px !important;
  color: #c8cfe0 !important;
}
.bootbox .modal-footer {
  border-top: 1px solid rgba(255,255,255,0.06) !important;
  background: transparent !important;
  padding: 10px 16px;
}
.bootbox .btn {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  letter-spacing: .05em !important;
  border-radius: 7px !important;
  padding: 0 16px !important;
  height: 32px !important;
  line-height: 30px !important;
  border-width: 1.5px !important;
  transition: background .12s !important;
}
.bootbox .btn-primary {
  background: rgba(34,197,94,0.1) !important;
  border-color: rgba(34,197,94,0.55) !important;
  color: #4ade80 !important;
}
.bootbox .btn-primary:hover { background: rgba(34,197,94,0.2) !important; }
.bootbox .btn-default {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.12) !important;
  color: #94a3b8 !important;
}
.bootbox .btn-default:hover { background: rgba(255,255,255,0.08) !important; }
.bootbox .btn-danger {
  background: rgba(239,68,68,0.1) !important;
  border-color: rgba(239,68,68,0.45) !important;
  color: #f87171 !important;
}
.bootbox .btn-danger:hover { background: rgba(239,68,68,0.2) !important; }
/* Input nel bootbox prompt */
.bootbox .form-control {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-subtle) !important;
  color: #f1f5f9 !important;
  -webkit-text-fill-color: #f1f5f9 !important;
  font-family: 'DM Sans', sans-serif;
  border-radius: 6px !important;
}
.bootbox .form-control:focus {
  border-color: var(--accent-green) !important;
  box-shadow: 0 0 0 2px rgba(79,219,230,0.12) !important;
}
/* Varianti per tipo alert */
.alert_error   .modal-content { border-color: rgba(239,68,68,0.45)  !important; }
.alert_error   .modal-body h3 { color: #f87171 !important; }
.alert_warning .modal-content { border-color: rgba(251,191,36,0.45) !important; }
.alert_warning .modal-body h3 { color: #fbbf24 !important; }
.alert_ok      .modal-content { border-color: rgba(34,197,94,0.45)  !important; }
.alert_ok      .modal-body h3 { color: #4ade80 !important; }
.alert_info    .modal-content { border-color: rgba(79,219,230,0.45) !important; }
.alert_info    .modal-body h3 { color: #4FDBE6 !important; }
/* Testo bianco in bootbox prompt: header e autofill browser */
.bootbox .modal-header .modal-title,
.bootbox .modal-header h3,
.bootbox .modal-header h4 { color: var(--text-primary) !important; }
.bootbox .form-control:-webkit-autofill,
.bootbox .form-control:-webkit-autofill:hover,
.bootbox .form-control:-webkit-autofill:focus {
  -webkit-text-fill-color: #f1f5f9 !important;
  -webkit-box-shadow: 0 0 0px 1000px #0f1828 inset !important;
  transition: background-color 5000s ease-in-out 0s;
}

/* ── Aste reminder bar ────────────────────────────────────
   Strip ambra persistente sotto la topbar: visibile su tutte le pagine
   finché l'utente ha aste da effettuare. Renderizzata server-side in menu.php. */
.aste-reminder-bar {
    background: rgba(245,158,11,0.10);
    border-bottom: 1px solid rgba(245,158,11,0.35);
    color: #fbbf24;
    padding: 8px 18px;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* ── Aste / Compravendite — righe offerta ────────────────────────────── */
.aste-offer-row { display:flex; align-items:center; gap:10px; padding:7px 14px; border-bottom:1px solid var(--border-subtle); font-size:13px; }
.aste-offer-row:last-child { border-bottom:none; }
.aste-offer-row .aste-icon { width:18px; text-align:center; flex-shrink:0; }
.aste-offer-row .aste-squadra { flex:1; color:var(--text-primary); }

.aste-win  { background:linear-gradient(90deg,rgba(74,222,128,0.12) 0%,rgba(74,222,128,0.04) 60%,transparent 100%); border-left:3px solid #4ade80; }
.aste-win  .aste-icon { color:#4ade80; }

.aste-asta { background:linear-gradient(90deg,rgba(251,191,36,0.12) 0%,rgba(251,191,36,0.04) 60%,transparent 100%); border-left:3px solid #fbbf24; }
.aste-asta .aste-icon { color:#fbbf24; }

.aste-lose { background:linear-gradient(90deg,rgba(248,113,113,0.10) 0%,rgba(248,113,113,0.03) 60%,transparent 100%); border-left:3px solid #f87171; }
.aste-lose .aste-icon { color:#f87171; }

.aste-proprietario { background:linear-gradient(90deg,rgba(79,219,230,0.12) 0%,rgba(79,219,230,0.04) 60%,transparent 100%); border-left:3px solid #4FDBE6; }
.aste-proprietario .aste-icon { color:#4FDBE6; }

.aste-card-list { display:flex; flex-direction:column; gap:16px; padding:0 0 20px; }

/* ── Titoli — card griglia ───────────────────────────────────────────── */
.titolo-card {
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border-card);
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
    transition: transform 0.2s, box-shadow 0.2s;
    cursor: default;
    display: flex;
    flex-direction: column;
}
.titolo-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.5);
}

/* Immagine quadrata tramite padding-top trick */
.titolo-card-img {
    width: 100%;
    padding-top: 100%;
    background-size: cover;
    background-position: center;
    background-color: var(--bg-card);
    flex-shrink: 0;
}

/* Blocco testo sotto l'immagine */
.titolo-card-body {
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    background: var(--bg-card);
    flex: 1;
}

/* Nome titolo */
.titolo-card-nome {
    font-family: 'DM Sans', sans-serif;
    font-weight: 900;
    font-size: 16px;
    color: var(--text-primary);
    line-height: 1.2;
}

/* Descrizione — min-height 2 righe per allineare altezze tra card */
.titolo-card-descr {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.4;
    min-height: calc(1.4em * 2);
}

/* Footer: squadra a sinistra, valore a destra */
.titolo-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 2px;
}

/* Badge valore — colori da db-badge-gold */
.titolo-card-valore {
    font-size: 11px;
}

/* Detentore / "Non assegnato" */
.titolo-card-detentore {
    font-size: 12px;
    color: var(--text-secondary);
}

/* Titolo non ancora assegnato */
.titolo-card--unassigned {
    filter: grayscale(1);
    opacity: 0.4;
}

/* ── ASTA TOPBAR (gestisci_offerte, offerte_asta) ───────────────────────── */
.asta-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 16px;
    background: var(--bg-surface);
    border-bottom: 1px solid var(--border-subtle);
    position: sticky;
    top: 0;
    z-index: 50;
    flex-wrap: wrap;
    gap: 8px;
}
.asta-status-bar { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.asta-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    font-size: 13px;
    font-weight: 700;
    border-radius: 5px;
    cursor: default;
}
.asta-badge img { width: 16px; height: 16px; opacity: .8; object-fit: contain; flex-shrink: 0; }
.asta-badge-label { font-family: 'DM Sans', sans-serif; font-size: 10px; opacity: .6; text-transform: uppercase; letter-spacing: .07em; }
.asta-actions { display: flex; gap: 8px; margin-left: auto; flex-shrink: 0; }
.asta-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 6px;
    border: 1.5px solid rgba(255,255,255,0.12);
    background: transparent;
    color: var(--text-secondary);
    font-family: 'DM Sans', sans-serif;
    font-weight: 700;
    font-size: 11px;
    letter-spacing: .06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .12s;
}
.asta-btn:hover:not(:disabled) { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.22); color: var(--text-primary); }
.asta-btn:disabled { opacity: .35; cursor: not-allowed; }
.asta-btn-ok  { border-color: rgba(34,197,94,0.55);  color: #4ade80; }
.asta-btn-ok:hover:not(:disabled)  { background: rgba(34,197,94,0.08);  border-color: rgba(34,197,94,0.75); color: #4ade80; }
.asta-btn-err { border-color: rgba(239,68,68,0.35);  color: #fca5a5; }
.asta-btn-err:hover:not(:disabled) { background: rgba(239,68,68,0.08);  border-color: rgba(239,68,68,0.55); color: #fca5a5; }
.asta-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 4px;
    border: 1px solid var(--border-subtle);
    background: transparent;
    color: var(--text-muted);
    font-size: 11px;
    cursor: pointer;
    transition: all .12s;
}
.asta-action-btn:hover { background: rgba(255,255,255,0.07); color: var(--text-secondary); }
@media (max-width: 767px) {
    .asta-badge-label { display: none; }
    .asta-actions { width: 100%; justify-content: stretch; }
    .asta-actions .asta-btn { flex: 1; justify-content: center; }
}

/* ── LOGIN FORM — redesign slate-medium ─── */
.form-login {
    background: linear-gradient(145deg, #1e2d45 0%, #172337 100%);
    border: 1px solid rgba(79,219,230,0.2);
    border-radius: 20px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.45), 0 0 0 1px rgba(79,219,230,0.08);
    padding: 28px 28px 24px;
    margin-top: 100px;
}
.form-login h4 {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 800;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-primary);
    border-bottom: 1px solid rgba(79,219,230,0.25);
    padding-bottom: 12px;
    margin-bottom: 16px;
    text-align: center;
}
.form-login .form-control {
    background: #0f1828;
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-primary);
    border-radius: 8px;
}
.form-login .form-control:focus {
    background: #0f1828;
    border-color: var(--accent-cyan);
    color: var(--text-primary);
    box-shadow: 0 0 0 2px rgba(79,219,230,0.15);
    outline: none;
}
.form-login .form-control::placeholder {
    color: var(--text-muted);
}
.form-login .form-control:-webkit-autofill,
.form-login .form-control:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px #0f1828 inset;
    -webkit-text-fill-color: var(--text-primary);
}
.form-login .btn-primary {
    background: rgba(79,219,230,0.08);
    border: 1.5px solid rgba(79,219,230,0.4);
    color: var(--accent-cyan);
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 800;
    font-size: 15px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: 8px;
    width: 100%;
    padding: 8px 0;
    transition: background .12s;
}
.form-login .btn-primary:hover,
.form-login .btn-primary:focus,
.form-login .btn-primary:active {
    background: rgba(79,219,230,0.16);
    border-color: var(--accent-cyan);
    color: var(--accent-cyan);
}

/* ═══════════════════════════════════════════════════════════
   Bootstrap 3 legacy — align al design system
   Panel → db-card look, table → db-table look, form controls dark
   ═══════════════════════════════════════════════════════════ */

/* ── Page header ──────────────────────────────────────────── */
h1.page-header,
h2.page-header,
.page-header {
  color: var(--text-primary) !important;
  border-color: var(--border-subtle) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
}

/* ── Page title (v2 replacement for Bootstrap 3 .page-header h1) */
.page-title {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: 22px;
  color: var(--text-primary);
  margin: 0 0 16px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

hr { border-color: var(--border-subtle) !important; }

/* ── Panel → db-card look ─────────────────────────────────── */
.panel {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-card) !important;
  border-radius: 10px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
  overflow: hidden !important;
}

/* Panel heading: gradiente cyan identico a db-card-header */
.panel-heading {
  background: linear-gradient(90deg, rgba(79,219,230,0.15) 0%, rgba(79,219,230,0.04) 70%, transparent 100%) !important;
  border-top: 1px solid rgba(79,219,230,0.10) !important;
  border-bottom: 1px solid rgba(79,219,230,0.25) !important;
  color: var(--text-primary) !important;
  padding: 10px 14px !important;
}
.panel-heading .panel-title,
.panel-title {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 900 !important;
  font-size: 11px !important;
  letter-spacing: .13em !important;
  text-transform: uppercase !important;
  color: var(--text-primary) !important;
}
.panel-body {
  padding: 14px !important;
  color: var(--text-primary) !important;
}
.panel-body h1, .panel-body h2, .panel-body h3, .panel-body h4 {
  color: var(--text-primary) !important;
}
.panel-footer {
  background: var(--bg-card-alt) !important;
  border-color: var(--border-subtle) !important;
  color: var(--text-secondary) !important;
}

/* Varianti colorate: solo la banda sinistra, heading rimane cyan */
.panel-success { border-left: 3px solid #22c55e !important; }
.panel-warning { border-left: 3px solid var(--accent-gold) !important; }
.panel-danger  { border-left: 3px solid var(--accent-red) !important; }
.panel-info    { border-left: 3px solid #67e8f9 !important; }

/* ── List-group ───────────────────────────────────────────── */
.list-group { border-radius: 10px; overflow: hidden; }
.list-group-item {
  background: var(--bg-card) !important;
  border-color: var(--border-subtle) !important;
  color: var(--text-primary) !important;
  font-family: 'DM Sans', sans-serif;
}
.list-group-item:hover,
.list-group-item:focus {
  background: rgba(255,255,255,0.04) !important;
  color: var(--text-primary) !important;
}
.list-group-item.active,
.list-group-item.active:hover {
  background: rgba(79,219,230,0.12) !important;
  border-color: rgba(79,219,230,0.3) !important;
  color: #4FDBE6 !important;
}
.list-group-item.disabled { background: rgba(255,255,255,0.03) !important; color: var(--text-muted) !important; }

/* list-title: stesso gradiente dell'header card */
.list-title,
.list-group .list-title {
  background: linear-gradient(90deg, rgba(79,219,230,0.15) 0%, rgba(79,219,230,0.04) 70%, transparent 100%) !important;
  border-bottom: 1px solid rgba(79,219,230,0.25) !important;
  color: var(--text-primary) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 900 !important;
  font-size: 11px !important;
  letter-spacing: .13em !important;
  text-transform: uppercase !important;
}

/* ── Bootstrap .table → db-table look ────────────────────── */
.table {
  color: var(--text-primary) !important;
}
.table > thead > tr > th {
  background: rgba(255,255,255,0.025) !important;
  border-bottom: 1px solid var(--border-subtle) !important;
  border-color: var(--border-subtle) !important;
  color: var(--text-muted) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 700 !important;
  font-size: 10px !important;
  letter-spacing: .09em !important;
  text-transform: uppercase !important;
  padding: 8px 14px !important;
}
.table > tbody > tr > td,
.table > tbody > tr > th,
.table > tfoot > tr > td {
  border-color: rgba(255,255,255,0.04) !important;
  color: var(--text-primary) !important;
  padding: 9px 14px !important;
}
.table > tbody > tr:nth-child(even) > td { background: rgba(255,255,255,0.015) !important; }
.table > tbody > tr:hover > td { background: rgba(255,255,255,0.035) !important; }
.table-striped > tbody > tr:nth-of-type(odd) { background: rgba(255,255,255,0.02) !important; }
.table-hover > tbody > tr:hover { background: rgba(255,255,255,0.05) !important; }

/* ── Form controls ────────────────────────────────────────── */
.form-control {
  background: var(--bg-card-alt) !important;
  border-color: var(--border-card) !important;
  color: var(--text-primary) !important;
  border-radius: 6px !important;
}
.form-control:focus {
  border-color: var(--accent-blue) !important;
  box-shadow: 0 0 0 2px rgba(96,165,250,0.2) !important;
  background: var(--bg-card-alt) !important;
  color: var(--text-primary) !important;
}
.form-control::placeholder { color: var(--text-muted) !important; }
select.form-control option { background: var(--bg-surface); color: var(--text-primary); }
.input-group-addon {
  background: var(--bg-card-alt) !important;
  border-color: var(--border-card) !important;
  color: var(--text-secondary) !important;
}
label { color: var(--text-secondary) !important; }
.radio label, .checkbox label { color: var(--text-primary) !important; }

/* ── Btn-default ──────────────────────────────────────────── */
.btn-default {
  background: var(--bg-card) !important;
  border-color: var(--border-card) !important;
  color: var(--text-primary) !important;
  border-radius: 6px !important;
}
.btn-default:hover,
.btn-default:focus,
.btn-default.active,
.btn-default:active {
  background: rgba(255,255,255,0.08) !important;
  border-color: var(--accent-blue) !important;
  color: var(--text-primary) !important;
}

/* ── Well ─────────────────────────────────────────────────── */
.well {
  background: var(--bg-card) !important;
  border-color: var(--border-card) !important;
  color: var(--text-primary) !important;
  border-radius: 8px !important;
}

/* ── Progress ─────────────────────────────────────────────── */
.progress { background: var(--bg-card-alt) !important; border-radius: 4px !important; }

/* ── Nav-tabs ─────────────────────────────────────────────── */
.nav-tabs { border-color: var(--border-subtle) !important; }
.nav-tabs > li > a {
  background: var(--bg-card-alt) !important;
  border-color: var(--border-subtle) !important;
  color: var(--text-secondary) !important;
  border-radius: 6px 6px 0 0 !important;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .04em;
}
.nav-tabs > li > a:hover { background: rgba(255,255,255,0.05) !important; color: var(--text-primary) !important; }
.nav-tabs > li.active > a,
.nav-tabs > li.active > a:hover {
  background: var(--bg-card) !important;
  border-color: var(--border-subtle) !important;
  border-bottom-color: var(--bg-card) !important;
  color: var(--text-primary) !important;
}

/* ── Buttons — dark theme override ──────────────────────── */
.btn-primary {
  background: rgba(79,219,230,0.18) !important;
  color: #4FDBE6 !important;
  border-color: rgba(79,219,230,0.35) !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.open > .dropdown-toggle.btn-primary {
  background: rgba(79,219,230,0.28) !important;
  color: #4FDBE6 !important;
  border-color: rgba(79,219,230,0.5) !important;
  box-shadow: none !important;
  outline: none !important;
}
.btn-danger {
  background: rgba(239,68,68,0.15) !important;
  color: #f87171 !important;
  border-color: rgba(239,68,68,0.3) !important;
}
.btn-danger:hover,
.btn-danger:focus,
.btn-danger:active,
.btn-danger.active {
  background: rgba(239,68,68,0.25) !important;
  color: #f87171 !important;
  border-color: rgba(239,68,68,0.5) !important;
  box-shadow: none !important;
  outline: none !important;
}
/* Bottoni in bootbox usano la palette verde/rossa — specificity più alta preservata */

/* ── Datetimepicker — dark theme ────────────────────────── */
.bootstrap-datetimepicker-widget {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-card) !important;
  border-radius: 10px !important;
  box-shadow: 0 6px 24px rgba(0,0,0,0.7) !important;
}
.bootstrap-datetimepicker-widget table thead tr th {
  color: var(--text-muted) !important;
}
.bootstrap-datetimepicker-widget table thead tr th:hover,
.bootstrap-datetimepicker-widget table thead tr th.picker-switch:hover {
  background: rgba(255,255,255,0.06) !important;
  color: var(--text-primary) !important;
  border-radius: 5px;
}
.bootstrap-datetimepicker-widget table thead tr th.picker-switch {
  color: var(--text-primary) !important;
}
.bootstrap-datetimepicker-widget table td {
  color: var(--text-secondary) !important;
  background: transparent !important;
  height: 34px !important;
}
.bootstrap-datetimepicker-widget table td:hover > div,
.bootstrap-datetimepicker-widget table td:hover {
  background: rgba(255,255,255,0.06) !important;
  color: var(--text-primary) !important;
  border-radius: 5px;
}
.bootstrap-datetimepicker-widget table td.day:hover,
.bootstrap-datetimepicker-widget table td.hour:hover,
.bootstrap-datetimepicker-widget table td.minute:hover,
.bootstrap-datetimepicker-widget table td.second:hover {
  background: rgba(255,255,255,0.07) !important;
  border-radius: 5px;
}
.bootstrap-datetimepicker-widget table td.active,
.bootstrap-datetimepicker-widget table td.active:hover {
  background: rgba(79,219,230,0.25) !important;
  color: #4FDBE6 !important;
  border-radius: 5px;
  text-shadow: none !important;
}
.bootstrap-datetimepicker-widget table td.today::before {
  border-bottom-color: #4FDBE6 !important;
}
.bootstrap-datetimepicker-widget table td.old,
.bootstrap-datetimepicker-widget table td.new {
  color: var(--text-muted) !important;
}
.bootstrap-datetimepicker-widget table td span {
  color: var(--text-secondary) !important;
  background: transparent !important;
}
.bootstrap-datetimepicker-widget table td span:hover {
  background: rgba(255,255,255,0.07) !important;
  color: var(--text-primary) !important;
}
.bootstrap-datetimepicker-widget table td span.active,
.bootstrap-datetimepicker-widget table td span.active:hover {
  background: rgba(79,219,230,0.25) !important;
  color: #4FDBE6 !important;
  text-shadow: none !important;
}
.bootstrap-datetimepicker-widget table td span.disabled,
.bootstrap-datetimepicker-widget table td.disabled {
  color: var(--text-muted) !important;
  opacity: 0.4;
}
.bootstrap-datetimepicker-widget a[data-action] {
  color: #4FDBE6 !important;
}
.bootstrap-datetimepicker-widget a[data-action]:hover {
  background: rgba(79,219,230,0.12) !important;
  border-radius: 5px;
}
.bootstrap-datetimepicker-widget .timepicker-hour,
.bootstrap-datetimepicker-widget .timepicker-minute,
.bootstrap-datetimepicker-widget .timepicker-second {
  color: var(--text-primary) !important;
  background: transparent !important;
}
.bootstrap-datetimepicker-widget .separator {
  color: var(--text-muted) !important;
}
.bootstrap-datetimepicker-widget ul.list-unstyled li {
  color: var(--text-secondary) !important;
}
.bootstrap-datetimepicker-widget .datepicker-days .dow {
  color: var(--text-muted) !important;
}
