/* Mobile CSS - Specifique telephone */

@media (max-width: 768px) {
  /* Layout */
  .sidebar { transform: translateX(-100%); }
  .sidebar.open { transform: translateX(0); z-index: 200; }
  .main { margin-left: 0; }
  .mobile-nav { display: flex; }
  .menu-btn { display: block; }
  .page { padding: 10px 8px 75px; }

  /* Topbar compact */
  .topbar { padding: 0 8px; gap: 6px; height: 48px; }
  .page-title { font-size: 14px; }
  .month-selector { gap: 2px; }
  .month-display { font-size: 11px; min-width: 80px; }
  .btn-icon { width: 28px; height: 28px; }

  /* Cards */
  .cards-row { grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 12px; }
  .stat-card { padding: 10px; }
  .stat-card .label { font-size: 9px; margin-bottom: 4px; }
  .stat-card .value { font-size: 16px; }
  .stat-card .sub { font-size: 9px; }

  /* Calendrier - forcer 7 colonnes visibles */
  .calendar-grid {
    gap: 1px;
    grid-template-columns: repeat(7, 1fr) !important;
    width: 100%;
    overflow: hidden;
  }
  .cal-day-name { font-size: 7px; padding: 3px 0; letter-spacing: -0.5px; }
  .cal-day { min-height: 44px; padding: 1px 2px; overflow: hidden; }
  .cal-day .day-num { font-size: 9px; }
  .cal-day.empty { min-height: 20px; }
  .mission-chip {
    font-size: 6px; padding: 1px 2px; margin-top: 1px;
    line-height: 1.2; white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis;
    max-width: 100%;
    border-left-width: 2px !important;
  }
  .mission-chip span[style*="border-radius"] { width: 4px !important; height: 4px !important; margin-right: 1px !important; }
  .mission-chip .chip-hours { font-size: 6px; }
  .ferie-label { font-size: 5px; }

  /* Boutons */
  .btn-print { padding: 5px 8px; font-size: 9px; }
  .btn-print svg { width: 12px; height: 12px; }
  .btn { padding: 8px 14px; font-size: 12px; }
  .btn-sm { padding: 5px 10px; font-size: 10px; }
  .btn svg { width: 14px; height: 14px; }
  .section-header { margin-bottom: 10px; }
  .section-title { font-size: 13px; }

  /* Tableaux */
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 0 -8px; padding: 0 8px; }
  table { min-width: 450px; }
  th { padding: 6px 5px !important; font-size: 8px !important; }
  td { padding: 6px 5px !important; font-size: 10px !important; }

  /* Modal fullscreen */
  .modal-overlay { padding: 0; }
  .modal { max-width: 100%; max-height: 100vh; height: 100vh; border-radius: 0; }
  .modal-header { padding: 14px 14px 0; }
  .modal-title { font-size: 16px; }
  .modal-body { padding: 14px; }
  .modal-footer { padding: 12px 14px; }
  .form-label { font-size: 11px; }
  .form-input, .form-select { font-size: 13px; padding: 8px 10px; }

  /* Bottom nav - 6 items */
  .mobile-nav { height: 56px; padding: 0 2px; }
  .mob-item { padding: 4px 2px; font-size: 8px; gap: 2px; }
  .mob-item svg { width: 18px; height: 18px; }

  /* Impots */
  .impot-grid { grid-template-columns: 1fr; gap: 10px; }
  .impot-card { padding: 12px; }
  .impot-card h3 { font-size: 13px; }
  .resume-card div[style*="grid-template-columns: 1fr 1fr 1fr"] { grid-template-columns: 1fr !important; gap: 10px !important; }

  /* Etablissements */
  .etab-grid { grid-template-columns: 1fr; gap: 8px; }
  .etab-card { padding: 12px; }
  .etab-card .etab-name { font-size: 13px; }

  /* Notifications */
  #notificationsBox { font-size: 11px; }

  /* Form rows single column on mobile */
  .form-row { grid-template-columns: 1fr; gap: 8px; }

  /* Offline banner */
  #offlineBanner { font-size: 11px; padding: 6px; }
}

  /* Mode compact calendrier - masquer texte, juste couleur */
  .calendar-grid.compact .mission-chip {
    font-size: 0;
    height: 4px;
    padding: 0;
    margin: 1px 0;
    border-radius: 2px;
    min-height: 4px;
  }
  .calendar-grid.compact .mission-chip span { display: none !important; }
  .calendar-grid.compact .cal-day { min-height: 32px; }
  .calendar-grid.compact .ferie-label { display: none; }
}

/* Petit telephone (< 380px) */
@media (max-width: 380px) {
  .cards-row { grid-template-columns: 1fr; gap: 6px; }
  .cal-day { min-height: 42px; }
  .mission-chip { font-size: 6px; }
  .cal-day .day-num { font-size: 9px; }
  table { min-width: 350px; }
  .mob-item { font-size: 7px; }
  .mob-item svg { width: 16px; height: 16px; }
  .topbar { height: 44px; }
  .page-title { font-size: 13px; }
}
