/* ================================================================
   GGESTIONALE CALCIO CLUB — Premium Light Theme
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600;700&display=swap');

:root {
  /* Premium Colors */
  --pk-primary: #E60000;
  --pk-primary-hover: #CC0000;
  --pk-primary-light: rgba(230, 0, 0, 0.08);

  --pk-accent: #007AFF;
  --pk-accent-hover: #0056b3;

  --pk-success: #34C759;
  --pk-warning: #FF9500;
  --pk-danger: #FF3B30;

  /* Neutrals & Backgrounds */
  --pk-bg-page: #F3F4F6;
  --pk-bg-card: #FFFFFF;
  --pk-bg-hover: #F9FAFB;
  --pk-border: #E5E7EB;

  /* Text Colors */
  --pk-text-main: #1F2937;
  --pk-text-muted: #6B7280;

  /* Typography */
  --font-heading: 'Bebas Neue', display;
  --font-body: 'Inter', sans-serif;

  /* Effects */
  --pk-radius-sm: 8px;
  --pk-radius: 16px;
  --pk-radius-lg: 24px;
  
  --pk-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --pk-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --pk-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  
  --pk-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── DARK MODE ─────────────────────────────────────────── */
:root[data-theme="dark"] {
  --pk-primary: #FF2D2D;
  --pk-primary-hover: #FF4444;
  --pk-primary-light: rgba(255, 45, 45, 0.12);

  --pk-accent: #4DA3FF;
  --pk-accent-hover: #7ABBFF;

  --pk-success: #4ADE80;
  --pk-warning: #FFB347;
  --pk-danger: #FF6B6B;

  --pk-bg-page: #0F1219;
  --pk-bg-card: #1A1F2E;
  --pk-bg-hover: #242B3D;
  --pk-border: #2D3548;

  --pk-text-main: #E2E8F0;
  --pk-text-muted: #8896AB;

  --pk-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
  --pk-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
  --pk-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.2);

  color-scheme: dark;
}
:root[data-theme="dark"] body { background: #0F1219 !important; color: #E2E8F0 !important; }
:root[data-theme="dark"] .navbar, :root[data-theme="dark"] #sitenav { background: #1A1F2E !important; border-bottom-color: #FF2D2D !important; }
:root[data-theme="dark"] .form-control, :root[data-theme="dark"] .form-select { background: #242B3D !important; border-color: #2D3548 !important; color: #E2E8F0 !important; }
:root[data-theme="dark"] .table { background: #1A1F2E !important; color: #E2E8F0 !important; }
:root[data-theme="dark"] .table th { background: #242B3D !important; color: #8896AB !important; }
:root[data-theme="dark"] .table td { color: #E2E8F0 !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] .modal-content { background: #1A1F2E !important; color: #E2E8F0 !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] .dropdown-menu { background: #1A1F2E !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] .dropdown-item { color: #E2E8F0 !important; }
:root[data-theme="dark"] .dropdown-item:hover { background: #242B3D !important; }
:root[data-theme="dark"] .nv-sub { background: #1A1F2E !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] .ndd-item { color: #8896AB !important; }
:root[data-theme="dark"] .ndd-item:hover { color: #FF2D2D !important; background: rgba(255,45,45,.08) !important; }
:root[data-theme="dark"] .nv-search-input { background: #242B3D !important; border-color: #2D3548 !important; color: #E2E8F0 !important; }
:root[data-theme="dark"] .nv-search-results { background: #1A1F2E !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] .nv-notif-panel { background: #1A1F2E !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] .nv-brand { color: #E2E8F0 !important; }
:root[data-theme="dark"] .alert { background: rgba(255,255,255,.03) !important; }
:root[data-theme="dark"] .footer { background: #1A1F2E !important; border-color: #2D3548 !important; }
:root[data-theme="dark"] h1,:root[data-theme="dark"] h2,:root[data-theme="dark"] h3,:root[data-theme="dark"] h4,:root[data-theme="dark"] h5,:root[data-theme="dark"] h6 { color: #E2E8F0 !important; }

/* ── MICRO-ANIMATIONS ──────────────────────────────────── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes countUp {
  from { opacity: 0; transform: scale(0.5); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.animate-fade-in-up {
  animation: fadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.animate-fade-in { animation: fadeIn 0.4s ease both; }
.animate-count   { animation: countUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) both; }
.stagger-1 { animation-delay: 0.05s; }
.stagger-2 { animation-delay: 0.1s; }
.stagger-3 { animation-delay: 0.15s; }
.stagger-4 { animation-delay: 0.2s; }
.stagger-5 { animation-delay: 0.25s; }
.stagger-6 { animation-delay: 0.3s; }

/* Skeleton loading placeholder */
.skeleton {
  background: linear-gradient(90deg, var(--pk-bg-hover) 25%, var(--pk-border) 50%, var(--pk-bg-hover) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--pk-radius-sm);
}

* { scroll-behavior: smooth; }

/* Custom Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--pk-bg-page); }
::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 10px; border: 2px solid var(--pk-bg-page); }
::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* Base Override */
body {
  font-family: var(--font-body) !important;
  background-color: var(--pk-bg-page) !important;
  color: var(--pk-text-main) !important;
  -webkit-font-smoothing: antialiased;
  font-size: clamp(0.9rem, 1vw + 0.5rem, 1rem) !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading) !important;
  letter-spacing: 0.03em;
  color: var(--pk-text-main) !important;
  margin-bottom: 0.75rem;
}

h1 { font-size: clamp(2rem, 5vw, 3rem) !important; }
h2 { font-size: clamp(1.5rem, 4vw, 2.2rem) !important; }
h3 { font-size: clamp(1.2rem, 3vw, 1.8rem) !important; }

a {
  color: var(--pk-primary);
  text-decoration: none;
  transition: var(--pk-transition);
}
a:hover {
  color: var(--pk-primary-hover);
}

/* Typography specifics */
.text-muted { color: var(--pk-text-muted) !important; }
.text-danger { color: var(--pk-danger) !important; }
.text-success { color: var(--pk-success) !important; }

/* ── NAVBAR ─────────────────────────────────────────── */
.navbar {
  background: var(--pk-bg-card) !important;
  border-bottom: 1px solid var(--pk-border) !important;
  box-shadow: var(--pk-shadow-sm) !important;
  padding: 0.75rem 0 !important;
}
.navbar-brand {
  font-family: var(--font-heading) !important;
  font-size: 1.5rem !important;
  letter-spacing: 0.05em !important;
  color: var(--pk-primary) !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem;
}
.navbar-brand img {
  height: 36px !important;
  width: auto !important;
  border-radius: 6px;
}
.navbar-nav .nav-link {
  font-family: var(--font-body) !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  color: var(--pk-text-muted) !important;
  padding: 0.5rem 1rem !important;
  border-radius: var(--pk-radius-sm);
  transition: var(--pk-transition);
  text-transform: none !important;
  letter-spacing: normal !important;
}
.navbar-nav .nav-link:hover, .navbar-nav .nav-link.active {
  color: var(--pk-primary) !important;
  background: var(--pk-primary-light);
}

/* ── PAGE HEADER ────────────────────────────────────── */
.page-header {
  background: transparent !important;
  padding: 2.5rem 0 1.5rem !important;
  border: none !important;
  box-shadow: none !important;
}
.page-header h1 {
  font-size: 2.5rem !important;
  color: var(--pk-text-main) !important;
  margin-bottom: 0.25rem !important;
}
.page-header p, .page-header span {
  font-family: var(--font-body) !important;
  color: var(--pk-text-muted) !important;
  font-size: 1.05rem !important;
}

/* Header Sections/Containers used in old code */
.header-section, .header-container {
  padding: 2.5rem 0 1.5rem !important;
}
.header-section h1 i, .header-container h1 i {
  color: var(--pk-primary) !important;
}

/* ── CARDS ──────────────────────────────────────────── */
.card, .form-card, .main-container {
  background: var(--pk-bg-card) !important;
  border: 1px solid var(--pk-border) !important;
  border-radius: var(--pk-radius) !important;
  box-shadow: var(--pk-shadow) !important;
  transition: var(--pk-transition) !important;
  overflow: hidden;
  margin-bottom: 1.5rem;
}
.card:hover {
  box-shadow: var(--pk-shadow-lg) !important;
  transform: translateY(-2px);
}
.form-card { padding: 1.5rem; }
.card-header {
  background: transparent !important;
  border-bottom: 1px solid var(--pk-border) !important;
  padding: 1.25rem 1.5rem !important;
}
.card-header h1, .card-header h2, .card-header h3, .card-header h4, .card-header h5 {
  margin: 0 !important;
  color: var(--pk-text-main) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  font-size: 1.1rem !important;
  letter-spacing: normal !important;
  text-transform: none !important;
}
.card-body {
  padding: 1.5rem !important;
}

/* Colored Header Overrides */
.card-header[class*="bg-"] {
  border-bottom: none !important;
}
.card-header.bg-primary { background: var(--pk-primary-light) !important; }
.card-header.bg-primary *, .card-header.bg-danger *, .card-header.bg-success *, .card-header.bg-warning *, .card-header.bg-info * { 
  color: var(--pk-text-main) !important; 
}
.card-header.bg-danger { border-left: 4px solid var(--pk-danger); background: var(--pk-bg-hover) !important; }
.card-header.bg-success { border-left: 4px solid var(--pk-success); background: var(--pk-bg-hover) !important; }
.card-header.bg-warning { border-left: 4px solid var(--pk-warning); background: var(--pk-bg-hover) !important; }
.card-header.bg-info { border-left: 4px solid var(--pk-accent); background: var(--pk-bg-hover) !important; }

/* ── BUTTONS ────────────────────────────────────────── */
.btn {
  font-family: var(--font-body) !important;
  font-weight: 500 !important;
  border-radius: var(--pk-radius-sm) !important;
  padding: 0.6rem 1.25rem !important;
  font-size: 0.95rem !important;
  transition: var(--pk-transition) !important;
  border: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.btn-sm { padding: 0.4rem 0.8rem !important; font-size: 0.85rem !important; }
.btn-primary {
  background: var(--pk-primary) !important;
  color: white !important;
}
.btn-primary:hover {
  background: var(--pk-primary-hover) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(230, 0, 0, 0.2) !important;
}
.btn-success { background: var(--pk-success) !important; color: white !important; }
.btn-warning { background: var(--pk-warning) !important; color: white !important; }
.btn-danger { background: var(--pk-danger) !important; color: white !important; }
.btn-info { background: var(--pk-accent) !important; color: white !important; }

.btn-outline-primary {
  background: transparent !important;
  border: 1.5px solid var(--pk-primary) !important;
  color: var(--pk-primary) !important;
}
.btn-outline-primary:hover {
  background: var(--pk-primary-light) !important;
  color: var(--pk-primary) !important;
}
.btn-outline-danger { background: transparent !important; border: 1.5px solid var(--pk-danger) !important; color: var(--pk-danger) !important; }
.btn-outline-danger:hover { background: rgba(255, 59, 48, 0.1) !important; }
.btn-outline-success { background: transparent !important; border: 1.5px solid var(--pk-success) !important; color: var(--pk-success) !important; }
.btn-outline-success:hover { background: rgba(52, 199, 89, 0.1) !important; }
.btn-outline-secondary { background: transparent !important; border: 1.5px solid var(--pk-text-muted) !important; color: var(--pk-text-muted) !important; }
.btn-outline-secondary:hover { background: var(--pk-bg-page) !important; color: var(--pk-text-main) !important; }

/* Custom Overrides from Old System */
.btn-modern, .btn-primary-modern, .btn-secondary-modern, .btn-danger-modern, .btn-success-modern {
  border-radius: var(--pk-radius-sm) !important;
  font-family: var(--font-body) !important;
}
.btn-primary-modern { background: var(--pk-primary) !important; color: white !important; }
.btn-secondary-modern { background: #FFFFFF !important; border: 1px solid var(--pk-border) !important; color: var(--pk-text-main) !important; }
.btn-secondary-modern:hover { background: var(--pk-bg-page) !important; }
.btn-danger-modern { background: var(--pk-danger) !important; color: white !important; }
.btn-success-modern { background: var(--pk-success) !important; color: white !important; }

/* ── FORMS ──────────────────────────────────────────── */
.form-control, .form-select {
  border: 1.5px solid var(--pk-border) !important;
  border-radius: var(--pk-radius-sm) !important;
  padding: 0.6rem 1rem !important;
  font-size: 0.95rem !important;
  color: var(--pk-text-main) !important;
  background: #FFFFFF !important;
  transition: var(--pk-transition) !important;
  box-shadow: none !important;
  min-height: 44px;
}
.form-control:focus, .form-select:focus {
  border-color: var(--pk-primary) !important;
  box-shadow: 0 0 0 3px var(--pk-primary-light) !important;
  outline: none !important;
}
.form-label, label, .form-text {
  font-family: var(--font-body) !important;
  font-weight: 500 !important;
  font-size: 0.9rem !important;
  color: var(--pk-text-muted) !important;
  margin-bottom: 0.4rem !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.form-text { font-size: 0.8rem !important; margin-top: 0.25rem !important; }

/* ── TABLES ─────────────────────────────────────────── */
.table-responsive {
  border-radius: var(--pk-radius) !important;
  border: 1px solid var(--pk-border) !important;
  background: var(--pk-bg-card) !important;
  overflow: hidden;
  box-shadow: var(--pk-shadow-sm);
  margin-bottom: 1rem;
}
.table {
  margin-bottom: 0 !important;
  color: var(--pk-text-main) !important;
  background: var(--pk-bg-card) !important;
}
.table th, .table thead th {
  background: var(--pk-bg-hover) !important;
  color: var(--pk-text-muted) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: 1rem 1.25rem !important;
  border-bottom: 1px solid var(--pk-border) !important;
  border-top: none !important;
}
.table td {
  padding: 1rem 1.25rem !important;
  vertical-align: middle !important;
  border-bottom: 1px solid var(--pk-border) !important;
  color: var(--pk-text-main) !important;
  font-size: 0.95rem !important;
}
.table tbody tr:last-child td {
  border-bottom: none !important;
}
.table tbody tr:hover {
  background-color: var(--pk-bg-hover) !important;
}

/* ── BADGES & ALERTS ─────────────────────────────────── */
.badge {
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  padding: 0.4em 0.8em !important;
  border-radius: 6px !important;
  font-size: 0.75rem !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.badge.bg-success { background: rgba(52, 199, 89, 0.15) !important; color: #1E7E34 !important; }
.badge.bg-danger { background: rgba(255, 59, 48, 0.15) !important; color: #B22922 !important; }
.badge.bg-primary { background: var(--pk-primary-light) !important; color: var(--pk-primary) !important; }
.badge.bg-warning { background: rgba(255, 149, 0, 0.15) !important; color: #CC7A00 !important; }
.badge.bg-secondary { background: var(--pk-border) !important; color: var(--pk-text-main) !important; }
.badge.bg-info { background: rgba(0, 122, 255, 0.15) !important; color: #0056b3 !important; }

.alert {
  border: 1px solid var(--pk-border) !important;
  border-radius: var(--pk-radius-sm) !important;
  padding: 1rem 1.25rem !important;
  font-family: var(--font-body) !important;
  border-left-width: 4px !important;
}
.alert-success { background: rgba(52, 199, 89, 0.05) !important; border-left-color: var(--pk-success) !important; color: #1E7E34 !important; }
.alert-danger { background: rgba(255, 59, 48, 0.05) !important; border-left-color: var(--pk-danger) !important; color: #B22922 !important; }
.alert-warning { background: rgba(255, 149, 0, 0.05) !important; border-left-color: var(--pk-warning) !important; color: #B26800 !important; }

/* ── RESPONSIVE MOBILE TABLES ────────────────────────── */
@media (max-width: 768px) {
  .table thead { display: none !important; }
  .table tr {
    display: block !important;
    border-bottom: 3px solid var(--pk-border) !important;
    margin-bottom: 0.5rem;
  }
  .table td {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    text-align: right !important;
    padding: 0.75rem 1rem !important;
    border-bottom: 1px solid var(--pk-bg-hover) !important;
  }
  .table td::before {
    content: attr(data-label) !important;
    font-weight: 600 !important;
    color: var(--pk-text-muted) !important;
    font-size: 0.85rem !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    text-align: left !important;
    margin-right: 1rem !important;
  }
}

/* ── RADIO PILLS (For Trainings & Forms) ───────────────── */
.pill-group {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.pill-radio {
    display: none;
}
.pill-label {
    cursor: pointer;
    padding: 0.5rem 1.25rem;
    border-radius: 50px;
    font-size: 0.9rem;
    font-weight: 600;
    transition: var(--pk-transition);
    border: 1.5px solid var(--pk-border);
    background: var(--pk-bg-card);
    color: var(--pk-text-muted);
    user-select: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
}
.pill-radio:checked + .pill-label {
    border-color: transparent;
}
.pill-radio[value="presente"]:checked + .pill-label { background: rgba(52, 199, 89, 0.15); color: #1E7E34; border-color: rgba(52, 199, 89, 0.4); }
.pill-radio[value="assente"]:checked + .pill-label { background: rgba(255, 59, 48, 0.15); color: #B22922; border-color: rgba(255, 59, 48, 0.4); }
.pill-radio[value="under16"]:checked + .pill-label { background: rgba(0, 122, 255, 0.15); color: #0056b3; border-color: rgba(0, 122, 255, 0.4); }
.pill-radio[value="under15"]:checked + .pill-label { background: rgba(175, 82, 222, 0.15); color: #7B2FBE; border-color: rgba(175, 82, 222, 0.4); }

/* Dashboard Cards (admin_home, stats) */
.stat-box, .stats-card {
  background: var(--pk-bg-card) !important;
  border: 1px solid var(--pk-border) !important;
  border-radius: var(--pk-radius) !important;
  padding: 1.5rem !important;
  box-shadow: var(--pk-shadow-sm) !important;
  margin-bottom: 1.5rem;
  transition: var(--pk-transition);
}
.stat-box:hover, .stats-card:hover {
  box-shadow: var(--pk-shadow) !important;
  transform: translateY(-2px);
}
.stat-box i, .stats-card i { color: var(--pk-primary) !important; }

/* -- PRINT STYLES --------------------------------------- */
@page {
  size: A4 portrait;
  margin: 8mm 10mm;
}

@media print {
  * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }

  body {
    background: white !important;
    color: #111 !important;
    font-size: 9.5pt !important;
    font-family: Arial, sans-serif !important;
    margin: 0 !important;
  }

  /* Hide all non-essential elements */
  .navbar, nav.navbar, .simple-nav,
  .page-header, .no-print, .pagination,
  .footer, footer, .btn, .alert-dismissible .btn-close,
  canvas, .chart-container, .print-chart-hidder,
  form:not(.print-allowed), .modal, .sidebar-col { display: none !important; }

  /* Container: full width, no padding */
  .container, .container-fluid, .container-lg, .container-md {
    max-width: 100% !important;
    padding: 0 4px !important;
    margin: 0 !important;
    width: 100% !important;
  }

  /* Cards: tight & border only */
  .card, .form-card, .main-container, .bil-card, .stat-box, .stats-card {
    background: white !important;
    border: 1px solid #bbb !important;
    box-shadow: none !important;
    border-radius: 3px !important;
    page-break-inside: avoid;
    break-inside: avoid;
    margin-bottom: 6px !important;
  }
  .card:hover { transform: none !important; }
  .card-header, .header-section {
    background: #f0f0f0 !important;
    color: #111 !important;
    border-bottom: 1.5px solid #888 !important;
    padding: 4px 8px !important;
    font-size: 9pt !important;
  }
  .card-header *, .header-section * { color: #111 !important; }
  .card-body { padding: 6px 8px !important; }

  /* Tables: ultra-compact */
  .table-responsive {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    overflow: visible !important;
  }
  .table {
    background: white !important;
    color: #111 !important;
    border: 1px solid #999 !important;
    font-size: 8.5pt !important;
    width: 100% !important;
    margin-bottom: 4px !important;
  }
  .table th, .table thead th {
    background: #eeeeee !important;
    color: #111 !important;
    border-bottom: 1.5px solid #555 !important;
    padding: 3px 5px !important;
    font-size: 8pt !important;
    text-transform: uppercase !important;
  }
  .table td {
    color: #111 !important;
    border-bottom: 1px solid #ddd !important;
    padding: 2px 5px !important;
    font-size: 8.5pt !important;
    vertical-align: middle !important;
  }
  .table tbody tr:last-child td { border-bottom: none !important; }
  .table tbody tr:hover { background: transparent !important; }

  /* Reset mobile responsive tables for print */
  .table thead { display: table-header-group !important; }
  .table tbody { display: table-row-group !important; }
  .table tr { display: table-row !important; border-bottom: none !important; margin: 0 !important; }
  .table td { display: table-cell !important; text-align: left !important; justify-content: unset !important; }
  .table td::before { display: none !important; }

  /* Headings: compact */
  h1 { font-size: 16pt !important; margin-bottom: 4px !important; letter-spacing: 0.03em !important; }
  h2 { font-size: 13pt !important; margin-bottom: 3px !important; }
  h3 { font-size: 11pt !important; margin-bottom: 3px !important; }
  h4 { font-size: 10pt !important; margin-bottom: 2px !important; }
  h5, h6 { font-size: 9pt !important; margin-bottom: 2px !important; }

  /* Badges: black border only */
  .badge {
    border: 1px solid #666 !important;
    background: transparent !important;
    color: #111 !important;
    padding: 1px 4px !important;
    font-size: 7.5pt !important;
  }

  /* Rows and grid: keep side-by-side layout */
  .row { display: flex !important; flex-wrap: wrap !important; margin: 0 !important; }
  .col-md-6, .col-lg-6 { flex: 0 0 50% !important; max-width: 50% !important; padding: 0 3px !important; }
  .col-md-3, .col-md-4, .col-lg-4 { flex: 0 0 25% !important; max-width: 25% !important; padding: 0 3px !important; }
  .col-md-8, .col-lg-8 { flex: 0 0 75% !important; max-width: 75% !important; padding: 0 3px !important; }
  .col-12 { flex: 0 0 100% !important; max-width: 100% !important; }

  /* Print-only visible elements */
  .print-only { display: block !important; }

  /* Alerts: simple border only */
  .alert { border: 1px solid #aaa !important; background: transparent !important; color: #111 !important; padding: 4px 8px !important; font-size: 9pt !important; }

  /* Utility */
  a { color: #111 !important; text-decoration: none !important; }
  img { max-width: 100% !important; page-break-inside: avoid; }
  .mb-4, .mb-5 { margin-bottom: 6px !important; }
  .pb-5 { padding-bottom: 0 !important; }
}

/* -- MOBILE OPTIMIZATIONS ----------------------------- */
@media (max-width: 768px) {
    :root {
        --pk-radius: 12px;
    }

    /* iPhone Input Zoom Fix: ensure font-size is at least 16px to prevent auto-zoom */
    input[type="text"], input[type="number"], input[type="email"], input[type="password"], 
    input[type="date"], input[type="search"], select, textarea {
        font-size: 16px !important;
    }

 /* Touch optimization: larger tap targets */
 .btn, .nav-link, .dropdown-item, .pill-label, .list-group-item {
 min-height: 44px;
 display: flex;
 align-items: center;
 justify-content: center;
 }
 
 .card { margin-bottom: 1rem; }
 .page-header { padding: 1.5rem 0 1rem !important; }
 .page-header h1 { font-size: 2rem !important; }
}

/* Custom Gradient Widgets */
.bg-dark-gradient { background: linear-gradient(135deg, #0D1B2E, #1a3a5c) !important; color: white !important; }
.bg-danger-gradient { background: linear-gradient(135deg, #e74c3c, #c0392b) !important; color: white !important; }
.bg-dark-gradient *, .bg-danger-gradient * { color: inherit !important; }

/* ================================================================
   SCUOLA CALCIO UI COMPONENTS
   ================================================================ */
.page-title {
  font-family: var(--font-heading);
  letter-spacing: 0.05em;
  color: var(--pk-text-main);
  font-size: clamp(1.8rem, 4vw, 2.5rem);
}

.bg-sc-header {
  background: linear-gradient(135deg, rgba(0,200,100,0.1) 0%, rgba(0,168,132,0.1) 100%);
  border-radius: 12px;
  padding: 2rem;
  border: 1px solid rgba(0,200,100,0.2);
}
:root[data-theme="dark"] .bg-sc-header {
  background: linear-gradient(135deg, rgba(0,200,100,0.05) 0%, rgba(0,168,132,0.05) 100%);
  border-color: rgba(0,200,100,0.1);
}

.sc-card, .group-card {
  border: 1px solid var(--pk-border);
  border-radius: 12px;
  background: var(--pk-bg-card);
  box-shadow: var(--pk-shadow-sm);
  padding: 1.5rem;
  height: 100%;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
  text-decoration: none;
  color: inherit;
  display: block;
}
.group-card {
  border-radius: 8px;
}
.sc-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--pk-shadow);
  color: inherit;
  border-color: var(--pk-primary);
}
.group-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--pk-shadow-sm);
  border-color: var(--pk-primary);
}

.sc-icon {
  font-size: 2.5rem;
  color: var(--pk-primary);
  margin-bottom: 1rem;
}

.sc-value {
  font-size: 1.8rem;
  font-weight: bold;
  font-family: var(--font-heading);
  margin-bottom: 0;
}

.sc-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pk-text-main);
}

.sc-desc {
  font-size: 0.9rem;
  color: var(--pk-text-muted);
  margin-bottom: 0;
}

.score-circle {
  width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: bold; color: white; margin: 0 auto 5px auto;
}
.bg-score-1 { background-color: #dc3545; }
.bg-score-2 { background-color: #fd7e14; }
.bg-score-3 { background-color: #ffc107; color: #000; }
.bg-score-4 { background-color: #20c997; }
.bg-score-5 { background-color: #198754; }

.quote-item {
  border-left: 4px solid var(--pk-primary);
  background: var(--pk-bg-card);
  padding: 1rem;
  margin-bottom: 1rem;
  border-radius: 0 8px 8px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: var(--pk-shadow-sm);
}
.quote-item.paid {
  border-left-color: var(--pk-success);
  background: rgba(52, 199, 89, 0.05);
}

@media (max-width: 768px) {
  .bg-sc-header {
    padding: 1.5rem;
  }
}

/* --- EXTRA HOME.PHP DASHBOARD --- */
.kpi-card {
  border: 1px solid var(--pk-border); border-radius: 16px; background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(10px); transition: all 0.3s ease; padding: 1.25rem; position: relative; overflow: hidden;
}
.kpi-card:hover {
  transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0,0,0,0.08) !important;
}
.kpi-label {
  font-family: var(--font-body); font-weight: 700; font-size: 0.75rem; letter-spacing: 0.05em;
  color: var(--pk-text-muted); text-transform: uppercase; margin-bottom: 0.5rem;
}
.kpi-value {
  font-family: var(--font-heading); font-size: clamp(2rem, 4vw, 2.5rem); line-height: 1;
  color: var(--pk-text-main); margin-bottom: 0.25rem;
}
.kpi-sub { font-size: 0.75rem; color: var(--pk-text-muted); margin: 0; }
.kpi-icon { position: absolute; top: -15px; right: -10px; font-size: 5rem; opacity: 0.05; z-index: 0; }

.skeleton .kpi-value {
  color: transparent; background: linear-gradient(90deg, #e2e8f0 25%, #cbd5e1 50%, #e2e8f0 75%);
  background-size: 200% 100%; animation: skeleton-loading 1.5s infinite; border-radius: 8px; display: inline-block; min-width: 80px;
}
@keyframes skeleton-loading { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

.stat-box{background:var(--pk-bg-card);border:1px solid var(--pk-border);border-radius:var(--pk-radius);box-shadow:var(--pk-shadow-sm);border-top:3px solid var(--pk-accent);height:100%; padding: 1.25rem; }
.stat-title{font-family:var(--font-body);font-weight:700;font-size:.7rem;letter-spacing:.08em;color:var(--pk-text-muted);border-bottom:1px solid var(--pk-border);padding-bottom:10px;margin-bottom:14px;text-transform:uppercase;}
.stat-value{font-family:var(--font-heading);font-size:clamp(1.1rem, 2.5vw, 2.2rem);color:var(--pk-text-main);line-height:1;word-break:break-word}
.stat-label{font-family:var(--font-body);font-size:clamp(.55rem, 1.2vw, .7rem);color:var(--pk-text-muted)}

.top-athlete-item{background:var(--pk-bg-page);border-radius:var(--pk-radius-sm);border-left:4px solid var(--pk-accent);margin-bottom:8px;padding:10px 14px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--pk-border);border-left-width:4px; transition: var(--pk-transition); }
.top-athlete-item:hover{background:white; box-shadow: var(--pk-shadow-sm); transform: translateX(3px); }
.top-athlete-name{color:var(--pk-text-main);font-weight:600;font-size:0.9rem;}

.presenze-count{background:var(--pk-success);color:#fff;padding:3px 10px;border-radius:12px;font-size:0.8rem;font-weight:bold;}
.assenze-count{background:var(--pk-danger);color:#fff;padding:3px 10px;border-radius:12px;font-size:0.8rem;font-weight:bold;}
.minuti-piu-count{background:var(--pk-accent);color:#fff;padding:3px 10px;border-radius:12px;font-size:0.8rem;font-weight:bold;}
.minuti-meno-count{background:var(--pk-warning);color:#fff;padding:3px 10px;border-radius:12px;font-size:0.8rem;font-weight:bold;}

.progress-custom{background:var(--pk-border);height:8px;border-radius:50px}
.progress-custom .progress-bar{border-radius:50px}

.quick-action-card { transition: all 0.2s ease !important; cursor: pointer; }
.quick-action-card:hover { transform: translateY(-4px) !important; box-shadow: var(--pk-shadow-lg) !important; }
.quick-action-card:active { transform: translateY(0) !important; }

/* --- EXTRA ATHLETES.PHP --- */
.search-container { position: relative; width: 100%; }
.search-container i { 
    position: absolute; left: 18px; top: 50%; transform: translateY(-50%); 
    color: var(--pk-text-main); opacity: 0.7; font-size: 1.1rem; z-index: 5;
}
.search-container .form-control { 
    padding-left: 52px !important; background: white; border-radius: 12px; 
    border: 1.5px solid var(--pk-border); box-shadow: var(--pk-shadow-sm);
}
.search-container .form-control:focus { border-color: var(--pk-primary); box-shadow: 0 0 0 4px var(--pk-primary-light); }

.compact-table th { font-family: var(--font-heading); font-size: 0.9rem; color: var(--pk-text-muted); text-transform: uppercase; padding: 1rem; border: none; background: var(--pk-bg-page); letter-spacing: 0.05em; }
.compact-table td { padding: 0.85rem 1rem; border-color: var(--pk-border); }
.player-name-main { font-weight: 700; color: var(--pk-text-main); text-decoration: none; font-size: 1.05rem; }
.player-name-main:hover { color: var(--pk-primary); }
.lnd-badge { font-size: 0.7rem; padding: 3px 10px; border-radius: 50px; background: var(--pk-primary-light); color: var(--pk-primary); font-weight: 700; border: 1px solid rgba(230,0,0,0.15); }

.athlete-card { display: none; background: var(--pk-bg-card); border-bottom: 1px solid var(--pk-border); padding: 1.25rem; transition: var(--pk-transition); }
.athlete-card:active { background: var(--pk-bg-page); }
.athlete-card:last-child { border-bottom: none; }

@media (max-width: 1024px) {
  .stat-value { font-size: 1.4rem; }
  .stat-label { font-size: 0.6rem; }
  .stat-box .row.mt-3 .col-4 { padding-left: 4px; padding-right: 4px; }
}

@media (max-width: 768px) {
  .menu-icon { font-size: 2.2rem; margin-bottom: 10px; }
  .stats-card { padding: 1rem; }
  .stats-card h3 { font-size: 2.2rem; }
  .stat-box { padding: 1rem; }
  .stat-value { font-size: 1.3rem; }
  .stat-label { font-size: 0.55rem; }

  .compact-table { display: none; }
  .athlete-card { display: block; }
  .desktop-actions { display: none; }
  .athlete-actions-mobile { display: flex; gap: 8px; margin-top: 12px; }
  .btn-action-sm { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; background: var(--pk-bg-page); color: var(--pk-text-muted); border: 1px solid var(--pk-border); font-size: 1.1rem; }
}

/* --- EXTRA TRAININGS.PHP --- */
/* Pannello Selezione (Top) */
.config-panel {
  background: var(--pk-bg-card); border: 1px solid var(--pk-border); border-radius: var(--pk-radius); padding: 24px; box-shadow: var(--pk-shadow-sm); margin-bottom: 32px; position: relative; overflow: hidden;
}
.config-panel::before {
  content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 4px; background: var(--pk-primary);
}

/* Azioni Rapide */
.action-bar {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; justify-content: space-between; align-items: center;
}

/* Griglia Atleti */
.athlete-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin-bottom: 100px;
}
.training-card {
  background: var(--pk-bg-card); border: 1px solid var(--pk-border); border-radius: var(--pk-radius); padding: 20px; box-shadow: var(--pk-shadow-sm); display: flex; flex-direction: column; gap: 16px; transition: var(--pk-transition);
}
.training-card:hover { box-shadow: var(--pk-shadow); transform: translateY(-3px); }

.training-card-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.training-card-left { display: flex; align-items: center; gap: 14px; }

.athlete-avatar {
  width: 48px; height: 48px; border-radius: 14px; background: var(--pk-primary-light); color: var(--pk-primary); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.2rem; flex-shrink: 0; font-family: var(--font-heading);
}

.athlete-info h6 {
  margin: 0 0 4px 0; font-family: var(--font-body) !important; font-size: 1.1rem; font-weight: 700; color: var(--pk-text-main);
}
.status-indicator {
  font-size: 0.75rem; color: var(--pk-text-muted); display: flex; align-items: center; gap: 6px; text-transform: uppercase; letter-spacing: 0.05em;
}

/* Utilities Status */
.status-badge {
  display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: var(--pk-border);
}
.status-badge.presente { background: var(--pk-success); box-shadow: 0 0 8px var(--pk-success); }
.status-badge.assente { background: var(--pk-danger); box-shadow: 0 0 8px var(--pk-danger); }
.status-badge.under16 { background: var(--pk-accent); box-shadow: 0 0 8px var(--pk-accent); }
.status-badge.under15 { background: #AF52DE; box-shadow: 0 0 8px #AF52DE; }

/* Pill per Mobile (Full Width e Tappabili) */
.pill-group { display: flex; gap: 10px; width: 100%; }
.pill-label {
  flex: 1; text-align: center; padding: 12px 10px; font-size: 0.8rem; font-weight: 700; margin: 0; border-radius: 12px; border: 2px solid var(--pk-bg-page); background: var(--pk-bg-page); color: var(--pk-text-muted); cursor: pointer; transition: all 0.2s ease; white-space: nowrap; user-select: none; display: flex; align-items: center; justify-content: center; text-transform: uppercase; letter-spacing: 0.02em;
}
.pill-radio:checked + .pill-label { border-color: transparent; scale: 1.05; box-shadow: var(--pk-shadow-sm); }
.pill-radio:checked[value="presente"] + .pill-label { background: var(--pk-success); color: white; }
.pill-radio:checked[value="assente"] + .pill-label { background: var(--pk-danger); color: white; }
.pill-radio:checked[value="under16"] + .pill-label { background: var(--pk-accent); color: white; }
.pill-radio:checked[value="under15"] + .pill-label { background: #AF52DE; color: white; }

.pill-radio { display: none !important; }

/* Sticky Save Bar */
.sticky-save-bar {
  position: fixed; bottom: 0; left: 0; right: 0; background: rgba(255, 255, 255, 0.85); backdrop-filter: blur(15px); padding: 16px 20px; border-top: 1px solid var(--pk-border); box-shadow: 0 -10px 30px rgba(0,0,0,0.08); z-index: 1040; display: flex; justify-content: space-between; align-items: center;
}
.sticky-save-bar .btn {
  border-radius: 12px; padding: 12px 32px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
}

@media(min-width: 768px) {
  .sticky-save-bar {
      padding: 16px 32px;
  }
}

/* ================================================================
/* --- AGONISTICA UI COMPONENTS --- */
.logo-header img {
  max-width:80px; border-radius:50%; background:transparent; padding:0;
  box-shadow:0 0 0 3px var(--pk-primary-light),0 0 20px rgba(0,0,0,0.05);
  position:relative; z-index:1;
}
.admin-badge {
  background:var(--pk-primary-light); color:var(--pk-primary);
  font-family:var(--font-heading); letter-spacing:.05em;
  border-radius:50px; font-size:.85rem; padding:6px 16px; display:inline-block;
}
.menu-icon {
  font-size: clamp(2.5rem, 5vw, 3rem); display:block; margin-bottom:14px;
}
.menu-card { transition: var(--pk-transition); min-height: 100%; }
.menu-card:hover { transform: translateY(-5px); box-shadow: var(--pk-shadow-lg) !important; }
.menu-card .card-title { font-family:var(--font-heading); letter-spacing:.03em; font-size:1.25rem; color:var(--pk-text-main); }
.menu-card .card-text { color:var(--pk-text-muted); font-size:.85rem; line-height:1.4; }

/* Athletes & Forms (Pills) */
.btn-pill {
  border-radius: 50px; font-family: var(--font-heading); letter-spacing: 0.05em; font-size: 1.1rem;
  transition: var(--pk-transition); padding: 0.5rem 1.5rem !important; display: inline-flex; align-items: center; justify-content: center;
}
.btn-pill-orange { background-color: var(--pk-primary); color: white; border: none; }
.btn-pill-orange:hover { background-color: var(--pk-primary-hover); transform: translateY(-2px); box-shadow: var(--pk-shadow-sm); color: white; }
.btn-pill-outline { background-color: transparent; color: var(--pk-text-muted); border: 2px solid var(--pk-border); font-family: var(--font-body); font-weight: 600; font-size: 0.9rem; }
.btn-pill-outline:hover { background: var(--pk-bg-page); border-color: var(--pk-text-muted); color: var(--pk-text-main); }
