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

/* ── TOKENS ─────────────────────────────────────────────── */
:root {
  --bg-app:         #02040e;
  --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:     #94a3b8;
  --accent-green:   #3cd1ed;
  --accent-cyan:    #3cd1ed;
  --bg-topbar:      #02040E;
  --accent-gold:    #fbbf24;
  --accent-blue:    #3cd1ed;
  --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: #172337 transparent;
}

body::-webkit-scrollbar { width: 4px; }
body::-webkit-scrollbar-thumb { background: #172337; 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-topbar);
  border-bottom: 2px solid #3cd1ed;
  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(60,209,237,0.3);
}
.topbar-btn.state-ok:hover { background: rgba(60,209,237,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;
  margin-right: 78px; /* spazio per icona fixed (52px) + gap + separatore */
  padding-right: 14px;
  border-right: 2px solid rgba(60,209,237,0.50);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0px;
}
/* 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: 150px;
}
/* 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: #172337;
  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: #172337;
  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: #172337;
}

/* ── 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(60,209,237,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: #3cd1ed; 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 per dark theme */
.alert.alert-info {
  background: rgba(60,209,237,0.07);
  border-color: rgba(60,209,237,0.3);
  color: #a8d8df;
}
.alert.alert-success {
  background: rgba(34,197,94,0.07);
  border-color: rgba(34,197,94,0.3);
  color: #4ade80;
}
.alert.alert-danger {
  background: rgba(239,68,68,0.07);
  border-color: rgba(239,68,68,0.3);
  color: #f87171;
}
.alert.alert-warning {
  background: rgba(251,191,36,0.07);
  border-color: rgba(251,191,36,0.3);
  color: #fbbf24;
}

/* ── 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; }
  /* Admin: il pulsante topbar lungo va nella sidebar-mobile-actions */
  .topbar-actions { display: none; }

  /* Su mobile right-block è nascosto: margin-left: auto spinge l'icona busta a destra */
  .topbar-msg-icon { margin-left: auto; }

  .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(60,209,237,0.15) 0%, rgba(60,209,237,0.04) 70%, transparent 100%);
  border-top: 1px solid rgba(60,209,237,0.10);
  border-bottom: 1px solid rgba(60,209,237,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: #3cd1ed; 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; }
.cup-avulsa-btn { background: none; border: none; padding: 0 3px; cursor: pointer; color: var(--accent-gold); font-size: 13px; opacity: 0.7; vertical-align: middle; line-height: 1; }
.cup-avulsa-btn:hover { opacity: 1; }

/* ── 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 #4ade80; 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 #3cd1ed; background: linear-gradient(90deg, rgba(60,209,237,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: #3cd1ed; }
.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(60,209,237,0.12);  border: 1px solid rgba(60,209,237,0.35);  color: #3cd1ed; }

/* ── Banner informativo ──────────────────────────────────── */
.db-banner { border-left: 3px solid var(--accent-cyan); background: rgba(60,209,237,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(60,209,237,0.15) → #142E39 | rgba(60,209,237,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(60,209,237,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(60,209,237,0.4); background: rgba(60,209,237,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(60,209,237,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(60,209,237,0.25) 0%, rgba(60,209,237,0.10) 60%, transparent 100%);
  border-left-color: #3cd1ed;
}
tr.rose-row-own > td:first-child { border-left: 3px solid #3cd1ed; }

/* ── 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: #3cd1ed; }
.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; }
/* Variante div — usata dal layout a due colonne di classifica-v2.js */
div.clf-row-top    { border-left: 3px solid var(--accent-gold) !important; background: linear-gradient(90deg, rgba(251,191,36,0.18) 0%, transparent 60%) !important; }
div.clf-row-bottom { border-left: 3px solid var(--accent-red)  !important; background: linear-gradient(90deg, rgba(248,113,113,0.18) 0%, transparent 60%) !important; }
div.clf-row-top:hover    { background: linear-gradient(90deg, rgba(251,191,36,0.32) 0%, transparent 60%) !important; }
div.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:#3cd1ed; background:rgba(60,209,237,0.12); color:#3cd1ed; }
.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(60,209,237,0.4); background:rgba(60,209,237,0.08); color:#3cd1ed; 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(60,209,237,0.16); border-color:#3cd1ed; }
.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(60,209,237,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(60,209,237,0.45) !important; }
.alert_info    .modal-body h3 { color: #3cd1ed !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(60,209,237,0.12) 0%,rgba(60,209,237,0.04) 60%,transparent 100%); border-left:3px solid #3cd1ed; }
.aste-proprietario .aste-icon { color:#3cd1ed; }

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

/* Nome calciatore nella card header aste — si tronca su mobile invece di rompere il layout */
.aste-card-nome {
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-weight: 800; font-size: 16px; font-family: 'DM Sans', sans-serif;
  text-transform: none; letter-spacing: normal;
}
/* Riga data/ora sotto l'header della card asta — stesso stile di cv-session-date */
.aste-subheader {
  padding: 5px 14px 6px;
  font-size: 11px;
  color: var(--text-muted);
  font-family: 'DM Sans', sans-serif;
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid var(--border-subtle);
}

/* ── Titoli — card griglia ───────────────────────────────────────────── */

/* Flexbox sul row per equalizzare altezza card nella stessa riga (BS3 usa float, non equalizza) */
#titoli-grid .row {
    display: flex;
    flex-wrap: wrap;
}
#titoli-grid .row > [class*='col-'] {
    display: flex;
    flex-direction: column;
}

.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(60,209,237,0.2);
    border-radius: 20px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.45), 0 0 0 1px rgba(60,209,237,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(60,209,237,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(60,209,237,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(60,209,237,0.08);
    border: 1.5px solid rgba(60,209,237,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(60,209,237,0.16);
    border-color: var(--accent-cyan);
    color: var(--accent-cyan);
}
.form-login p {
    color: var(--text-secondary);
}
.form-login .form-link {
    color: var(--text-secondary);
    font-size: 12px;
    transition: color .12s;
}
.form-login .form-link:hover {
    color: var(--accent-cyan);
    text-decoration: none;
}

/* ═══════════════════════════════════════════════════════════
   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(60,209,237,0.15) 0%, rgba(60,209,237,0.04) 70%, transparent 100%) !important;
  border-top: 1px solid rgba(60,209,237,0.10) !important;
  border-bottom: 1px solid rgba(60,209,237,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 #4ade80 !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 #3cd1ed !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(60,209,237,0.12) !important;
  border-color: rgba(60,209,237,0.3) !important;
  color: #3cd1ed !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(60,209,237,0.15) 0%, rgba(60,209,237,0.04) 70%, transparent 100%) !important;
  border-bottom: 1px solid rgba(60,209,237,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(60,209,237,0.18) !important;
  color: #3cd1ed !important;
  border-color: rgba(60,209,237,0.35) !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.open > .dropdown-toggle.btn-primary {
  background: rgba(60,209,237,0.28) !important;
  color: #3cd1ed !important;
  border-color: rgba(60,209,237,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(60,209,237,0.25) !important;
  color: #3cd1ed !important;
  border-radius: 5px;
  text-shadow: none !important;
}
.bootstrap-datetimepicker-widget table td.today::before {
  border-bottom-color: #3cd1ed !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(60,209,237,0.25) !important;
  color: #3cd1ed !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: #3cd1ed !important;
}
.bootstrap-datetimepicker-widget a[data-action]:hover {
  background: rgba(60,209,237,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;
}


/* ══════════════════════════════════════════════════════════════════════
   MIGRATED FROM custom.css — kept verbatim; dead rules cleaned up later
   ══════════════════════════════════════════════════════════════════════ */


.btn-default.disabled, .btn-default.disabled.active, .btn-default.disabled.focus, .btn-default.disabled:active, .btn-default.disabled:focus, .btn-default.disabled:hover, .btn-default[disabled], .btn-default[disabled].active, .btn-default[disabled].focus, .btn-default[disabled]:active, .btn-default[disabled]:focus, .btn-default[disabled]:hover, fieldset[disabled] .btn-default, fieldset[disabled] .btn-default.active, fieldset[disabled] .btn-default.focus, fieldset[disabled] .btn-default:active, fieldset[disabled] .btn-default:focus, fieldset[disabled] .btn-default:hover {
    background-color: #a4a1a1;
    border-color: #ff0a0a;
}

.bootbox-large .row-player td {
    text-align: center;
    padding: 3px 3px 3px 3px !important;

}

.badge-fascia {
    display: inline-block;
    min-width: 50px;
    padding: 3px 15px;
    font-size: 12px;
    font-weight: bold;
    line-height: 1;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    background-color: #000000;
    border-radius: 10px;
    color: #ffe717;
    border: 3px solid #fc3c3c;
    float: right;
}

.bootbox-large .badge-fascia  {
	float: none;
}

.invert_effect {
            filter: invert(100%);
        }

#widget-maglie .title {
	overflow: hidden;
	white-space: nowrap;
	font-size: 22px;
}
#widget-maglie .subtitle {
	overflow: hidden;
	white-space: nowrap;
	font-size: 17px;
}

#widget-albo-doro-rose td {
	font-size: 11px;
	color: #000000;
	border: 1px solid #3c3c3c;
}
#widget-albo-doro-rose th {
	font-size: 13px;
	font-weight: bold;
    color: #000000;
    border: 1px solid #3c3c3c;
    background-color: #dedede;
}
#widget-albo-doro-rose .row-title {
font-size: 30px;
    color: #000000;
    border: 1px solid #3c3c3c;
    padding: 10px;
}

.list-shirt {
	height : 240px;
}
.list-logo {
	height : 260px;
}

.acq_perso {
	text-decoration: line-through;
}

.logo_micro {
	max-height : 50px !important;
}
.logo_min {
	max-height : 100px !important;
}
.logo_medio {
	max-height : 200px !important;
}

#widget-rose .logo_medio {
	max-width:100%;
}

.list-group-item .dettaglioUtente {
	font-weight: bold !important;
}

.align-middle {
  vertical-align: middle !important;
}


.alert-success h3{
	color: #000000;
}

.alert_error .modal-body{
	background-color: #ff0000c2;
}

.alert_error .modal-footer{
	background-color:#a90a0a;
}
.alert_error .modal-footer .btn-primary{
	background-color:#000000;
	border-color:#ffffff;
	color: #ffffff;
	font-weight: bold;
}

.alert_error .modal-body h3{
	color: #000000;
}


.alert_ok .modal-body{
	background-color: #4af557c2;
}

.alert_ok .modal-footer{
	background-color:#06690d;
}
.alert_ok .modal-footer .btn-primary{
	background-color:#000000;
	border-color:#ffffff;
	color: #ffffff;
	font-weight: bold;
}

.alert_ok .modal-body h3{
	color: #000000;
}


.alert_warning .modal-body{
	background-color: #ff6e08c2;
}

.alert_warning .modal-footer{
	background-color:#b7520a;
}
.alert_warning .modal-footer .btn-primary{
	background-color:#000000;
	border-color:#ffffff;
	color: #ffffff;
	font-weight: bold;
}

.alert_warning .modal-body h3{
	color: #000000;
}

.alert_info .modal-header, .alert_info .modal-body{
	background-color: #a8c9f9c2;
}
.alert_info .modal-footer{
	background-color:#368ad2;
}
.alert_info .modal-footer .btn-primary{
	background-color:#000000;
	border-color:#ffffff;
	color: #ffffff;
	font-weight: bold;
}

.alert_info .modal-header h3,.alert_info .modal-body h3{
	color: #000000;
}





.modal-dialog .btn-danger {
	color: #000000;
	border-color: #000000;
	background-color: #d9534f;
	font-weight: bold;
	margin-bottom:0px;
}
.modal-dialog .btn-success {
	color: #000000 !important;
	border-color: #000000 !important;
	background-color: #28a745 !important;
	font-weight: bold;
	margin-bottom:0px;
}



.col-xs-2-5,
.col-sm-2-5,
.col-md-2-5,
.col-lg-2-5 {
position: relative;
min-height: 1px;
padding-left: 15px;
padding-right: 15px;
}
.col-xs-2-5 {
width: 20%;
}

@media (min-width: 768px) {
.col-sm-2-5 {
float: left;
}
.col-sm-2-5 {
width: 20%;
}
}

@media (min-width: 992px) {
.col-md-2-5 {
float: left;
}
.col-md-2-5 {
width: 20%;
}
}

@media (min-width: 1200px) {
.col-lg-2-5 {
float: left;
}
.col-lg-2-5 {
width: 20%;
}
}





body {
	background-image: url('../images/index_top.png'),url('../images/index_bottom.png');
	background-repeat: repeat-x, repeat;
	margin-top: 50px;
}

h1, h2, h3, h4 {
	color: #dddddd;
}

.btn-default.active, .btn-default.focus, .btn-default:active, .btn-default:focus, .btn-default:hover, .open>.dropdown-toggle.btn-default {
  color: #FFF;
  background-color: #000000;
  border-color: #F4E700;
}

.panel-body h1, .panel-body h2,.panel-body h3, .panel-body h4 {
	color: black;
}

.jqte {
  margin : 15px 0;
}
.jqte_tool.jqte_tool_1 .jqte_tool_label {
  height: 22px;
}

.jqte_editor {
  min-height: 200px;
}


.color_white {
	color: white;
}
.color_yellow {
	color: #dcd729;
}

.bootbox, .bootbox h4 {
	color: black;
}
.bootbox .modal-footer {
	text-align: center;
}

.btn, .input-group { margin:5px;}
#widget-albo-doro .btn { margin:0px;}

#page-wrapper {
	background: none;
}
.page-header {
  margin: 10px 0 20px; color: #dddddd;
}

.border-bottom {
	border-bottom: 1px solid #eee;
	margin-bottom: 20px;
	padding-bottom: 20px;
}


.navbar-brand img {
	height: 50px;
	top: 0;
	position: absolute;
}

.side-nav {
	background-color:#02101a;
}
.navbar-inverse  {
	background-color:#02101a; border-color:#266981;
}

.navbar-toggle {
	z-index : 3000;
}
.navbar-inverse .navbar-nav > li > a:hover,
.navbar-inverse .navbar-nav > li > a:focus,
.navbar-inverse .navbar-nav > .active > a,
.navbar-inverse .navbar-nav > .active > a:hover,
.navbar-inverse .navbar-nav > .active > a:focus {
  color: #ffffff !important;
  background-color: #00254C !important;
}
.navbar-inverse .navbar-nav > .open > a,
.navbar-inverse .navbar-nav > .open > a:hover,
.navbar-inverse .navbar-nav > .open > a:focus {
  color: #ffffff !important;
  background-color: #00254C !important;
}

.side-nav > li.dropdown > ul.dropdown-menu > li > a:hover,
.side-nav > li.dropdown > ul.dropdown-menu > li.active > a,
.side-nav > li.dropdown > ul.dropdown-menu > li > a:focus {
  color: #ffffff !important;
  background-color: #00254C !important;
}

.nav a:hover,
.nav li.active > a,
.nav a:focus {
  color: #ffffff !important;
  background-color: #00254C !important;
}

.nav-tabs>li>a {
    border: 1px solid #ccc !important;
}

.form-control {
	border-radius: 10px;
}

.wrapper {
	text-align: center;
}

.fuori-classifica{
	background-color: #ffe0f6;
	font-style: italic;   
	text-decoration: line-through;
}


.row-player {
	color: black; font-weight: bold; font-size: 14px; padding-left: 10px !important; padding:3px; min-height: 30px;
}
.row-player td, .row-player th {
	color: black; font-weight: bold; font-size: 13px !important; padding:3px 0px 3px 10px !important; border: 1px solid #000000 !important;
}
.row-player .punti1{
	position: absolute; right: 10px;
	color:#213f7f;
}
.row-player .punti0{
	position: absolute; right: 10px;
	color:#777777;
}

#punteggio_detail .row-player .punti0, #punteggio_detail .row-player .punti1{
	position: inherit; 
}

.row-player-font {
	font-weight: bold;
}
.row-player-font a {
	color: #002654;
}

.panel-p {
	/*background-color: #FF9E00 !important;*/
	background-color: #D87C01 !important;
}

/*
.row-p {
	background-color: #FFC26F !important;
}
*/
.row-pan {
	color: #000000 !important;
	border: 1px solid #000000;
	background-color: #ffffff;
}

.row-rosa{
	color: #000000 !important;
	border: 1px solid #000000;
	background-color:  #e9f3ff !important;
}

.row-p {
	color: #000000 !important;
	border: 1px solid #000000;
	background-color: #ffe2ba;
}


.row-p-font {
	color: #D87C01 !important;
}


.panel-d {
	/*background-color: #008D30 !important;*/
	background-color: #004A19 !important;
}
/*
.row-d {
	background-color: #28915D !important;
}*/
.row-d {
	color: #000000 !important;
	border: 1px solid #000000;
	background-color: #dcfbc9;
}
.row-d-font {
	color: #28915D !important;
}

.panel-c {
	/*background-color: #0056FF !important;*/
	background-color: #3cd1ed !important;
}
/*
.row-c {
	background-color: #3cd1ed !important;
}*/
.row-c {
	color: #000000 !important;
	border: 1px solid #000000;
	background-color: #c9effb;
}
.row-c-font {
	color: #004C9D !important;
}

.panel-a {
	/*background-color: #FF0000 !important;*/
	background-color: #BD0000 !important;
}
/*
.row-a {
	background-color: #BA5151 !important;
}*/
.row-a {
	color: #000000 !important;
	border: 1px solid #000000;
	background-color: #fbc9c9;
}
.row-a-font {
	color: #BA5151 !important;
}


.row-nolist {
	background-color:black !important;
	color:white !important;
	border: 1px solid #ffffff;
}
.row-nolist-table {
	background-color:#564E4E !important;
	color:white !important;
}


.row-token {
    background-color: #ff0000 !important;
    color: #ffffff !important;
}
.row-token-table {
    background-color: #ff0000 !important;
    color: #ffffff !important;
}

.row-acquistato {
	background-color:#C0FFBB !important;
}
.row-new {
	background-color:yellow!important; color:black;
	border: 1px solid #000000;
}
.row-new-team {
	background-color:#FFFFB9 !important;
}
.row-nosell {
	background-color:#FEE1FF  !important;
}

.row-title {
	font-weight: bold;
    font-size: 17px;
    border: 1px solid #3cd1ed;
    margin-bottom: 0px;
    background-color: #dedede;
}

.row-win-lost {
	background-color:#cccccc !important;
	border: 1px solid #3cd1ed;
}

.row-win {
	background-color:#C0FFBB !important;
	border: 1px solid #3cd1ed;
}
.row-asta {
	background-color:#FFFFB9 !important;
	border: 1px solid #3cd1ed;
}
.row-asta-conf {
	background-color:#F5D67F !important;
	border: 1px solid #3cd1ed;
}

.row-lose {
	background-color:#FEE1FF  !important;
	border: 1px solid #3cd1ed;
}

.badge-vinto {
	background-color:#18ab0c !important;
}
.badge-perso {
	background-color:#ff0023 !important;
}
.badge-asta {
	background-color:#eaab00 !important;
}
.badge-noasta {
	background-color:#838383 !important;
}

.row-occupato {
	font-style: italic;	background-color:#BABABA !important;
}
.row-head {
	background-color: #1b1a1a !important; color: rgb(182, 182, 182); text-align: center; font-size: 11px; font-weight: bold;
}
.row-head-detail {
	background-color: #ffffff !important; color: #f00202; text-align: center; font-size: 11px; font-weight: bold;
}
.row-head-mod {
	background-color: #3cd1ed !important; color: white; text-align: center; font-size: 9px;
}
.row-head-mod-2 {
	background-color: #3cd1ed !important; color: white; text-align: center; font-size: 10px;
}
.row-conta-1 {
	background-color: #e9f3ff !important;
}
.row-conta-0 {
	background-color: #d0d0d0 !important;
}
.row-conta-panca-1 {
	background-color: #e9f3ff !important;
}
.row-conta-panca-0 {
	background-color: #d0d0d0 !important;
}
.badge_left{
	display: inline-block;
    min-width: 10px;
    padding: 4px 6px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 10px;
}
.badge_right{
	float: right;
	display: inline-block;
    min-width: 10px;
    padding: 4px 6px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 10px;
}

.badge_black{
 	background-color: #000000 !important;
}


.badge_P1{
 	background-color: #D87C01 !important;
}
.badge_D1{
 	background-color:#28915D !important;
}
.badge_C1{
 	background-color: #004C9D !important;
}
.badge_A1{
 	background-color: #BA5151 !important;
}
.badge_P0, .badge_D0, .badge_C0, .badge_A0{
	background-color: #777777 !important;
	font-style: normal !important; 
}


.bg-red {
	/*background-color: #FF0000 !important;*/
	background-color: #BD0000 !important;
}
.status .panel-title {
  font-size: 50px; font-weight: bold; color: #fff; line-height: 45px; padding: 10px 5px;
}




.non_in_lista {
	font-style: italic;
	color: #B89465;
}

.no-margin {
	margin : 0 !important;
}
.no-padding {
	padding : 0 !important;
}


.width-100 {
	width:100%;
}


.status .panel-heading {
	padding: 10px 5px;
}
.panel-heading {
	padding: 10px 10px;
}

.calciatore_team{
	float:left;
	width:40px;
	text-align: center;
}
.calciatore_team img{
	max-height:30px;
}



#widget-rose .panel-heading, #widget-rose .panel-body,#widget-formazioni .panel-heading, #widget-formazioni .panel-body,#widget-punteggi .panel-heading, #widget-punteggi .panel-body   {
	overflow: hidden; white-space: nowrap;
}
#widget-rose a ,#widget-rosa a ,#widget-lista a {
	color : inherit;
}

#widget-punteggi .row-head-detail {
	cursor: pointer;
}

#widget-punteggi .row-head-detail:hover {
	background-color: #fff763 !important;
}


#widget-formazioni .panel-heading, #widget-punteggi .panel-heading {
	padding: 5px;  font-size: 14px; text-transform: uppercase; text-align: center;

}
#widget-rose .squadra  {
	font-weight: bold; font-size: 14px;  text-align: center;
}
#widget-rose .user  {
	font-style: italic;font-size: 14px;  text-align: center;
}

#widget-formazioni hr, #widget-punteggi hr  {
	margin:5px;
}
#widget-formazioni span {
	 font-size: 10px;
}
#widget-punteggi .panel-heading span {
	text-align: center;
	font-size: 30px;
}

.coppa_winner  {
	font-weight: bold;
	color : #009c24;
}
.cup_match {
	cursor: pointer;
}
.cup_match:hover {
	background-color: #fff763 !important;
}

#widget-lista-operazioni .list-group-item {
	word-break: break-all;
}

/* #widget-mini-coppe .list-group-item, #widget-supercoppa .list-group-item, #widget-albo-doro .list-group-item, #widget-risultati .list-group-item  {*/
.list-group-item {
	min-height: 42px;
}
.list-group-item .disabled {
    background-color: #dddddd;
    color: #777777;
}

#widget-info-squadra .list-group, #widget-home .list-group, #widget-statistiche .list-group {
    margin-right: 5px;
    margin-left: 5px;
}


.list-title {
  text-align: center;
  font-weight: bold
}

#widget-info-squadra .row , #widget-home .row ,#widget-statistiche .row {
    margin-right: -10px;
    margin-left: -10px;
}

#widget-info-squadra hr , #widget-home hr ,#widget-statistiche hr {
    margin-top: 20px;
    margin-bottom: 30px;
    border: 0;
    border-top: 3px solid #3cd1ed;
}

.dettaglioUtente, .dettaglioCalciatore {
	cursor: pointer;
}
.dettaglioUtente:hover, .dettaglioCalciatore:hover  {
	background-color: #fff763 !important;
	color: #000000;
}

.bootbox h2 {
	color : black;
}


#widget-risultati h4, #widget-risultati-correnti h4, #widget-risultati-next h4  {
	text-align: center;
	color : black;
}
#widget-risultati td, #widget-risultati-correnti td, #widget-risultati-next td  {
	white-space: nowrap;
}

.classifica_php .btn-group > label,.punteggi_php .btn-group > label,
.archivio_aste_php .btn-group > label, .compravendite_php .btn-group > label,
.lista_operazioni_php .btn-group > label{
	width: 43px!important;
	margin-left: 0px;
}

.regolamento .row {
	padding-top : 40px;
}
.regolamento .heading {
	padding-top : 0px !important;
}


.regolamento .new {
	color: #ffa4a4;
}

.regolamento p, .regolamento li {
color : #7ae0ff;}

.regolamento .esempio {
	padding: 30px;
	color: #00ff2b;
	font-style: italic;
}
.regolamento .esempio_ul {
	padding: 0px 70px;
}
.regolamento .esempio_ul li {

	color: #00ff2b !important;
	font-style: italic;
}

.graphic_container {
	height: 500px;
	min-width: 310px;
/*	max-width: 800px;*/
	margin: 0 auto;
}


#widget-titoli img {
	width: 200px;
	border: 3px solid yellow;
}
#widget-info-squadra img, #widget-home img, #widget-statistiche img  {
	height: 200px;
	max-width: 100%;
	border: 3px solid #444444;
}

#widget-info-squadra .list-group-item, #widget-home .list-group-item, #widget-statistiche .list-group-item, #widget-formazione .list-group-item, #widget-classifica .list-group-item{
   background-color:#f0f0f0;
}

 #widget-classifica .list-group-item,  #widget-classifica-ug .list-group-item{
   line-height:50px;
}
 #widget-classifica .badge,  #widget-classifica-ug .badge{
   font-size: 20px; 
   background-color: #2c00b2;
   padding: 5px 10px;
}


#widget-info-squadra .list-group-item img, #widget-home .list-group-item img, #widget-statistiche .list-group-item img, #widget-classifica .list-group-item img {
	border: none!important;
}

#widget-titoli .detentore {
  font-size: 35px;
  color: #8ECDFA;
  overflow: hidden;
  word-wrap:break-word;
}

#widget-titoli .valore, #widget-info-squadra .valore, #widget-home .valore, #widget-statistiche .valore {
  font-size: 45px;
  color: #A7D4F4;
}

.tabletitle{
    background-color: #6b6b6b !important;
    color: #ffff !important;
}
.tabletitle div{
    border-right: 1px solid #fff;
}

.andata-ritorno {
    min-height: 55px !important;
}


.bg-alert-info{
	color: #31708f;
    background-color: #d9edf7 !important;
}
.bg-alert-warning{
    color: #8a6d3b;
    background-color: #fcf8e3 !important;
}
.bg-alert-danger{
    color: #a94442;
    background-color: #f2dede !important;
}

.bg-alert-good{
    color: #42a944;
    background-color: #bcffb2 !important;
}
.bg-alert-action{
	color: #ffffff;
    background-color: #2721ed !important;
}

.out-of-ranking {
	background-color: #f9f9f9;
}


.list-title {
  background-color:#b5b3b3 !important;
}

#widget-rose .list-title
{
    background-color: #b5b3b3 !important;
    padding: 5px;
    font-weight: 800;
    min-height: 20px;
 }

/* Countdown bar: stile gestito da cinghialupi-design.css (.countdown-bar).
   Manteniamo solo il blink per stato critico, tutto il resto è nel design system. */
#barra-countdown .countdown-danger {
  animation: countdown-blink 1s step-start infinite;
}

@keyframes countdown-blink {
  50% { opacity: 0.2; }
}

@media (min-width: 500px) {

		.bootbox-large .modal-dialog {
	    width: 700px;
	}
}

@media screen and (min-width: 768px) and (max-width: 950px) {
	#widget-titoli h2 {
		font-size: 20px;
	}
		#widget-titoli h4 {
  		font-size: 14px;
	}
		#widget-titoli .detentore {
  		font-size: 25px;
	}
		#widget-titoli .valore  {
  		font-size: 35px;
	}
}

@media (max-width: 767px) {
	#widget-titoli {
		text-align: center;
	}

	.top-nav {
		margin: 7.5px -15px;
		border-bottom: 1px solid white;
		padding-left: 4px;
	}
	.top-nav li, .top-nav li a{
	    width: 100%;
	    height: 40px;
	    padding-top: 0px;
	}

	#widget-risultati .list-group-item, #widget-risultati-correnti .list-group-item, #widget-risultati-next .list-group-item {
		min-height: 80px !important;
	}
}

@media (max-width: 680px) {
	.list-group-item>.badge {
		float: none;
		width: 100%;
		margin-bottom: 10px;
	}


@media (max-width: 450px) {
	.navbar-brand img {
		width: 300px;
		z-index: -10;
		height: auto;
		margin-top: 6px;
	}

	.status .panel-title{
		font-size: 40px;
	}
	.status .panel-body{
		font-size: 12px;
	}
}
@media (min-width: 400px) {

	#widget-punteggi > .col-xs-12{
		width: 50%;
	}
}





@media (min-width: 1500px) {
	#widget-formazioni .col-lg-2-5,#widget-punteggi .col-lg-2-5,#widget-rose .col-lg-2-5{
		float:left;
		width: 16.66%;
	}
}

/* ══════════════════════════════════════════════════════════
   BACHECA MESSAGGI — layout due colonne stile FM
   ══════════════════════════════════════════════════════════ */

.inbox-wrap {
  padding: 20px 20px 0;
  border-top: 3px solid var(--accent-cyan);
}

.inbox-header {
  font-family: 'Barlow Condensed', sans-serif; font-weight: 900; font-size: 20px;
  color: var(--text-primary); margin-bottom: 14px; letter-spacing: .03em;
  display: flex; align-items: center; gap: 8px;
}

.inbox-tabbar {
  position: static; padding-left: 0; margin-bottom: 0;
  border-color: var(--border-card);
}
.inbox-tabbar .db-tab.active { border-bottom-color: var(--accent-cyan); color: var(--text-primary); }
.inbox-tabbar .db-tab { font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 12px; letter-spacing: .04em; }

.inbox-tab-badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: #fbbf24; color: #0A0F1A;
  font-size: 10px; font-weight: 900; border-radius: 50%;
  min-width: 18px; height: 18px; padding: 0 3px;
  margin-left: 6px; vertical-align: middle; line-height: 1;
}

/* ── Layout due colonne via position absolute ────────────── */
/* Usiamo position absolute per essere immuni a qualsiasi
   override display:inline-block / display:flex sul parent.
   .inbox-layout è il contenitore con altezza fissa calcolata;
   i due pannelli si posizionano dentro come elementi assoluti. */
.inbox-layout {
  position: relative;
  height: calc(100vh - var(--topbar-h) - var(--countdown-h, 0px) - 155px);
  min-height: 500px;
  border: 1px solid var(--border-card);
  border-top: none;
  border-radius: 0 0 10px 10px;
  overflow: hidden;
  background: var(--bg-card);
  box-shadow: 0 4px 24px rgba(0,0,0,0.4);
}

/* Pannello sinistra: anteprima — larghezza fissa 320px */
.inbox-panel-list {
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 320px;
  border-right: 2px solid rgba(60,209,237,0.35);
  background: var(--bg-surface);
  overflow: hidden;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-orient: vertical; -webkit-box-direction: normal;
  -ms-flex-direction: column; flex-direction: column;
}

#inbox-list {
  -webkit-box-flex: 1; -ms-flex: 1; flex: 1;
  overflow-y: auto;
}

/* Pannello destra: messaggio completo — occupa il resto */
.inbox-panel-detail {
  position: absolute;
  top: 0; left: 322px; right: 0; bottom: 0;
  overflow: hidden;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-orient: vertical; -webkit-box-direction: normal;
  -ms-flex-direction: column; flex-direction: column;
}

#inbox-detail {
  -webkit-box-flex: 1; -ms-flex: 1; flex: 1;
  overflow-y: auto;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-orient: vertical; -webkit-box-direction: normal;
  -ms-flex-direction: column; flex-direction: column;
}

/* Label header nei pannelli — stesso stile di .db-card-header */
.inbox-panel-label {
  padding: 10px 14px;
  background: linear-gradient(90deg, rgba(60,209,237,0.15) 0%, rgba(60,209,237,0.04) 70%, transparent 100%);
  border-top: 1px solid rgba(60,209,237,0.10);
  border-bottom: 1px solid rgba(60,209,237,0.25);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900; font-size: 11px; letter-spacing: .13em; text-transform: uppercase;
  color: #f1f5f9;
  -ms-flex-negative: 0; flex-shrink: 0;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  gap: 7px;
}
.inbox-panel-label i { color: #3cd1ed; opacity: 0.85; }

/* ── Righe lista: ogni riga è un riquadro con bordo ciano ── */
.inbox-row {
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  gap: 10px;
  margin: 5px 8px;
  padding: 10px 12px;
  border: 1px solid rgba(60,209,237,0.12);
  border-radius: 7px;
  cursor: pointer !important;
  -webkit-transition: background .12s, border-color .12s;
  transition: background .12s, border-color .12s;
  /* Annulla qualsiasi display:block imposto da Bootstrap su div */
  -webkit-box-sizing: border-box; box-sizing: border-box;
}
.inbox-row:hover { background: rgba(60,209,237,0.06); border-color: rgba(60,209,237,0.3); cursor: pointer !important; }
.inbox-row.unread { border-color: rgba(60,209,237,0.28); }
.inbox-row.selected { background: rgba(251,191,36,0.08); border-color: #fbbf24; border-left: 3px solid #fbbf24 !important; }

/* Dot unread */
.inbox-dot {
  width: 8px; height: 8px; border-radius: 50%; -ms-flex-negative: 0; flex-shrink: 0;
  background: var(--accent-cyan);
  visibility: hidden;
}
.inbox-row.unread .inbox-dot { visibility: visible; }

/* Avatar lettera */
.inbox-avatar {
  width: 36px; height: 36px; border-radius: 50%; -ms-flex-negative: 0; flex-shrink: 0;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: #0A0F1A;
  -ms-flex-item-align: center; align-self: center;
}

/* Corpo riga: due righe */
.inbox-row-body { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; min-width: 0; }
.inbox-row-top  {
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between;
  -webkit-box-align: baseline; -ms-flex-align: baseline; align-items: baseline;
  gap: 6px; margin-bottom: 3px;
}

.inbox-sender {
  font-size: 14px; font-weight: 800; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.inbox-row.unread .inbox-sender { color: #fff; }

.inbox-date { font-size: 10px; color: var(--text-muted); white-space: nowrap; -ms-flex-negative: 0; flex-shrink: 0; }

.inbox-row-sub {
  font-size: 12px; color: var(--text-muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.inbox-row.unread .inbox-row-sub { color: var(--text-secondary); }

/* ── Stato vuoto / caricamento ──────────────────────────── */
.inbox-empty {
  padding: 48px 20px; text-align: center;
  color: var(--text-muted); font-size: 13px; line-height: 1.7;
}
.inbox-empty i   { font-size: 30px; opacity: .25; display: block; margin-bottom: 10px; }
.inbox-loading   { padding: 30px; text-align: center; color: var(--text-muted); font-size: 13px; }

/* ── Pannello dettaglio ─────────────────────────────────── */
.inbox-detail-empty {
  -webkit-box-flex: 1; -ms-flex: 1; flex: 1;
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-orient: vertical; -webkit-box-direction: normal;
  -ms-flex-direction: column; flex-direction: column;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  color: var(--text-muted); font-size: 13px; text-align: center; padding: 40px;
}
.inbox-detail-empty i  { font-size: 40px; opacity: .2; display: block; margin-bottom: 14px; }
.inbox-detail-empty p  { margin: 0; }

.inbox-detail-content  { padding: 28px 36px; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }

.inbox-detail-header   { padding-bottom: 16px; border-bottom: 1px solid rgba(60,209,237,0.2); margin-bottom: 18px; }
.inbox-detail-meta     {
  display: -webkit-box; display: -ms-flexbox; display: flex;
  -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between;
  -webkit-box-align: baseline; -ms-flex-align: baseline; align-items: baseline;
  margin-bottom: 8px;
}
.inbox-detail-from     { font-size: 12px; font-weight: 700; color: var(--accent-cyan); letter-spacing: .04em; }
.inbox-detail-date     { font-size: 11px; color: var(--text-muted); }
.inbox-detail-title    { margin: 0; font-size: 18px; font-weight: 700; color: var(--text-primary); font-family: 'DM Sans', sans-serif; }

.inbox-detail-body     { font-size: 14px; color: var(--text-secondary); line-height: 1.8; }
.inbox-detail-body p   { margin-bottom: 12px; }
.inbox-detail-body p:last-child { margin-bottom: 0; }

/* Icona busta nel topbar */
@keyframes inbox-pulse-gold {
  0%, 100% { box-shadow: 0 2px 14px rgba(60,209,237,0.18); }
  50%       { box-shadow: 0 0 0 5px rgba(251,191,36,0.25), 0 0 20px rgba(251,191,36,0.45); }
}
.topbar-msg-icon {
  display: flex; align-items: center; justify-content: center;
  position: relative; width: 42px; height: 42px;
  color: var(--text-secondary); font-size: 22px;
  text-decoration: none; transition: color .15s; margin-left: 6px;
}
.topbar-msg-icon.has-unread { animation: inbox-pulse-gold 2s ease-in-out infinite; }
.topbar-msg-icon:hover,
.topbar-msg-icon:focus { color: var(--accent-cyan); text-decoration: none; }
.topbar-msg-badge {
  position: absolute; top: -9px; right: -9px;
  background: #fbbf24; color: #0A0F1A;
  font-size: 9px; font-weight: 900; border-radius: 50%;
  min-width: 18px; height: 18px; padding: 0 3px;
  display: inline-flex; align-items: center; justify-content: center;
  line-height: 1; box-shadow: 0 1px 4px rgba(0,0,0,0.4);
}

#sidebar-msg-count.badge {
  background: var(--accent-cyan); color: #0A0F1A;
  font-size: 10px; padding: 2px 6px; border-radius: 8px; margin-left: 4px;
}

/* ROSE PAGE — stili spostati in cinghialupi-design.css (caricato dopo, nessun conflitto) */

/* nessun override mobile: l'app è desktop-only, grid a 2 colonne fisso */
