
/* ==========================================================
   VERSION TELEPHONE FINALE - ne touche pas aux fonctions PHP
   ========================================================== */
@media (max-width: 900px) {
  html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    background: #eef3f8 !important;
    font-size: 14px !important;
  }

  .app-shell { display: block !important; width: 100% !important; min-height: 100vh !important; }

  .mobile-menu-open-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    position: fixed !important;
    top: 10px !important;
    left: 10px !important;
    z-index: 20050 !important;
    height: 42px !important;
    padding: 0 14px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: #0b1f3a !important;
    color: #fff !important;
    font-weight: 800 !important;
    box-shadow: 0 10px 25px rgba(15,23,42,.25) !important;
  }
  .mobile-menu-open-btn i { font-size: 20px !important; }

  .mobile-menu-backdrop {
    display: none !important;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(2,8,23,.55) !important;
    z-index: 20000 !important;
  }
  body.mobile-menu-open .mobile-menu-backdrop { display: block !important; }

  .sidebar, body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: min(84vw, 330px) !important;
    min-width: 0 !important;
    max-width: 330px !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    padding: 16px 14px !important;
    border-radius: 0 24px 24px 0 !important;
    background: linear-gradient(180deg,#071426,#0b2b5c) !important;
    z-index: 20010 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    transform: translateX(-105%) !important;
    transition: transform .22s ease !important;
    box-shadow: 20px 0 50px rgba(0,0,0,.30) !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  body.mobile-menu-open .sidebar { transform: translateX(0) !important; }

  .sidebar-toggle {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.14) !important;
    color: #fff !important;
    display: grid !important;
    place-items: center !important;
  }
  .sidebar-toggle i:before { content: "\\F659" !important; }

  .brand { margin: 0 50px 18px 0 !important; gap: 10px !important; font-size: 16px !important; line-height: 1.2 !important; }
  .brand-icon { width: 46px !important; height: 46px !important; border-radius: 12px !important; background: #fff !important; box-shadow: none !important; }
  .brand-icon img { max-width: 44px !important; max-height: 44px !important; object-fit: contain !important; }

  .sidebar .nav, body.sidebar-collapsed .sidebar .nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    width: 100% !important;
  }
  .sidebar .nav-link, body.sidebar-collapsed .sidebar .nav-link {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 46px !important;
    padding: 11px 12px !important;
    margin: 0 !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.09) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 750 !important;
    text-align: left !important;
    white-space: normal !important;
    transform: none !important;
  }
  .sidebar .nav-link.active { background: #1d9bf0 !important; }
  .sidebar .nav-link i { width: 22px !important; min-width: 22px !important; text-align: center !important; font-size: 17px !important; }

  .user-card {
    margin-top: 14px !important;
    padding: 12px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
  }

  .content, body.sidebar-collapsed .content, main {
    margin-left: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 64px 12px 18px !important;
    min-height: 100vh !important;
    background: #eef3f8 !important;
  }

  .topbar {
    margin: 0 0 12px !important;
    padding: 14px 14px !important;
    border-radius: 18px !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.07) !important;
  }
  .topbar .mini-muted { font-size: 12px !important; }
  .topbar .fw-bold.fs-5 { font-size: 17px !important; line-height: 1.25 !important; }
  .topbar .btn { width: 100% !important; min-height: 42px !important; font-size: 14px !important; }

  .hero {
    border-radius: 22px !important;
    padding: 20px 18px !important;
    margin-bottom: 14px !important;
    min-height: auto !important;
  }
  .hero h1 { font-size: 28px !important; line-height: 1.08 !important; margin-bottom: 8px !important; }
  .hero p { font-size: 15px !important; line-height: 1.35 !important; }
  .hero .badge { font-size: 12px !important; margin-bottom: 10px !important; }
  .hero .btn { width: 100% !important; margin: 8px 0 0 !important; min-height: 42px !important; }

  .row { --bs-gutter-x: 0 !important; --bs-gutter-y: 12px !important; margin-left: 0 !important; margin-right: 0 !important; }
  .row > * { padding-left: 0 !important; padding-right: 0 !important; }

  .card, .stat-card {
    border-radius: 20px !important;
    box-shadow: 0 10px 26px rgba(15,23,42,.07) !important;
    min-height: auto !important;
    margin-bottom: 0 !important;
    overflow: hidden !important;
  }
  .card.p-4, .stat-card.p-4 { padding: 18px !important; }
  .stat-card .stat-icon { width: 46px !important; height: 46px !important; border-radius: 14px !important; margin-bottom: 10px !important; }
  .stat-card .display-5 { font-size: 34px !important; line-height: 1 !important; margin: 6px 0 !important; }
  .mini-muted { font-size: 14px !important; }

  .section-title, h4.section-title { font-size: 22px !important; line-height: 1.2 !important; margin-bottom: 8px !important; }
  .text-muted, p, li { font-size: 15px !important; line-height: 1.45 !important; }
  ul { padding-left: 18px !important; }

  .btn, a.btn, button.btn {
    width: 100% !important;
    min-height: 44px !important;
    padding: 10px 12px !important;
    font-size: 14px !important;
    line-height: 1.2 !important;
    border-radius: 14px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    white-space: normal !important;
  }
  .d-flex.flex-wrap.gap-2 { display: grid !important; grid-template-columns: 1fr !important; gap: 10px !important; }

  .form-control, .form-select { min-height: 44px !important; font-size: 15px !important; border-radius: 14px !important; }
  label { font-size: 14px !important; }

  .table-responsive { overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; }
  table, .table { font-size: 13px !important; }

  .fc .fc-toolbar { display: grid !important; grid-template-columns: 1fr !important; gap: 8px !important; }
  .fc .fc-toolbar-title { font-size: 18px !important; text-align: center !important; }
  .fc .fc-button { padding: 7px 9px !important; font-size: 12px !important; width: auto !important; min-height: 36px !important; }
}

@media (min-width: 901px) {
  .mobile-menu-open-btn, .mobile-menu-backdrop { display: none !important; }
}
