/**
 * Hope UI — Responsive Overwrite
 * Sovrascrittura per rendere il template completamente responsive.
 *
 * Carica questo file DOPO hope-ui.css / custom.css.
 * Breakpoints usati (Bootstrap 5):
 *   xs  < 576px
 *   sm  576px – 767px
 *   md  768px – 991px
 *   lg  992px – 1199px
 *   xl  ≥ 1200px  ← punto in cui la sidebar si rivela (default Hope UI)
 */

/* ============================================================
   1. VARIABILI GLOBALI — aggiornamenti responsivi
   ============================================================ */
:root {
  --sidebar-mobile-width: 280px;   /* larghezza sidebar nel drawer mobile */
  --topnav-height: 64px;           /* altezza navbar superiore (adattare se diversa) */
  --content-padding-mobile: 1rem;
  --content-padding-tablet: 1.25rem;
}

/* ============================================================
   2. LAYOUT PRINCIPALE — sidebar + main-content
   ============================================================ */

/**
 * Su ≥ 1200px Hope UI gestisce già il margin-left via --sidebar-width.
 * Qui resettiamo per breakpoint inferiori dove la sidebar diventa drawer.
 */
@media (max-width: 1199.98px) {
  /* Il main-content non deve avere più margine fisso a sinistra */
  .sidebar + .main-content {
    margin-left: 0 !important;
    width: 100%;
  }

  /* La sidebar diventa un drawer off-canvas */
  .sidebar {
    transform: translateX(-100%);
    z-index: 1050;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.18);
    /* manteniamo la transition già definita da Hope UI */
  }

  /* Classe da aggiungere via JS al .sidebar quando il menu è aperto */
  .sidebar.sidebar-show {
    transform: translateX(0);
  }

  /* Backdrop scuro quando la sidebar è aperta (da .screen-darken già in Hope UI) */
  .screen-darken.active {
    z-index: 1040;
    opacity: 1;
    width: 100%;
    visibility: visible;
    background-color: rgba(0, 0, 0, 0.45);
  }
}

/* Sidebar boxed: su mobile rimuove i margini extra */
@media (max-width: 1199.98px) {
  .sidebar.sidebar-boxed + .main-content {
    margin-left: 0 !important;
    margin: 0 !important;
  }
  .sidebar.sidebar-boxed.sidebar-mini + .main-content {
    margin-left: 0 !important;
    --sidebar-width: 0;
  }
}

/* ============================================================
   3. NAVBAR (.iq-navbar)
   ============================================================ */
@media (max-width: 1199.98px) {
  .iq-navbar {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  /* Mostra il toggle hamburger per aprire la sidebar */
  .nav .sidebar-toggle {
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    left: 1rem;
  }

  /* Testa la navbar brand centrata quando non c'è spazio per la sidebar */
  .iq-navbar .navbar-brand {
    margin-left: 0.5rem;
  }
}

@media (max-width: 767.98px) {
  .iq-navbar {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  /* Navbar list orizzontale: riduce spaziatura sulle icone */
  .iq-navbar .navbar-nav.navbar-list .nav-item {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }

  /* Dropdown sub-menu: larghezza piena su mobile */
  .iq-navbar .dropdown .dropdown-menu.sub-drop {
    width: 100vw;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    border-radius: 0;
  }
}

@media (max-width: 575.98px) {
  /* Nasconde label testuali nella navbar se troppo stretta */
  .iq-navbar .caption .caption-title,
  .iq-navbar .caption .caption-sub-title {
    display: none;
  }
}

/* ============================================================
   4. CONTENUTO PRINCIPALE — padding adattivo
   ============================================================ */
@media (max-width: 1199.98px) {
  .content-inner {
    padding: var(--content-padding-tablet);
  }
}

@media (max-width: 767.98px) {
  .content-inner {
    padding: var(--content-padding-mobile);
  }

  /* Rimuove il margine negativo top usato per la header banner */
  .conatiner-fluid.content-inner.mt-n5,
  .container-fluid.content-inner.mt-n5 {
    margin-top: 0 !important;
  }
}

/* ============================================================
   5. CARD E GRIGLIE
   ============================================================ */
@media (max-width: 767.98px) {
  .card {
    margin-bottom: 1rem;
  }

  .card-body {
    padding: 1rem;
  }

  .card-header {
    padding: 0.75rem 1rem;
  }

  /* Stack colonne di default su mobile */
  .row > [class*="col-"]:not([class*="col-xs"]) {
    /* Non forziamo col-12 qui per non rompere layout intenzionalmente stretti;
       usa .col-12 .col-sm-6 ecc. nel markup. Questo è un hint visivo. */
  }
}

/* ============================================================
   6. TABELLE — scroll orizzontale su schermi piccoli
   ============================================================ */
@media (max-width: 991.98px) {
  .table-responsive-override {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Se le tabelle non hanno già .table-responsive, aggiungi scroll */
  .card .table:not(.table-responsive *) {
    min-width: 600px;
  }

  .card .table-responsive {
    margin-bottom: 0;
  }
}

/* ============================================================
   7. DATATABLE (se presente)
   ============================================================ */
@media (max-width: 767.98px) {
  .dataTables_wrapper .dataTables_length,
  .dataTables_wrapper .dataTables_filter {
    text-align: left;
    float: none;
    margin-bottom: 0.5rem;
  }

  .dataTables_wrapper .dataTables_info,
  .dataTables_wrapper .dataTables_paginate {
    text-align: left;
    float: none;
    margin-top: 0.5rem;
  }

  .dataTables_wrapper .row {
    flex-direction: column;
  }
}

/* ============================================================
   8. CHARTS / WIDGET STATISTICHE
   ============================================================ */
@media (max-width: 575.98px) {
  /* Riduce altezza dei grafici su mobile */
  .apexcharts-canvas,
  canvas {
    max-width: 100% !important;
  }
}

/* ============================================================
   9. MODAL — fullscreen su mobile
   ============================================================ */
@media (max-width: 575.98px) {
  .modal-dialog {
    margin: 0;
    max-width: 100%;
    height: 100%;
  }

  .modal-dialog .modal-content {
    border-radius: 0;
    min-height: 100vh;
  }
}

/* ============================================================
   10. FORM
   ============================================================ */
@media (max-width: 767.98px) {
  /* Input e select full-width su mobile */
  .form-control,
  .form-select {
    font-size: 0.9rem;
  }

  /* Label e input su righe separate */
  .form-group,
  .mb-3 {
    margin-bottom: 0.75rem;
  }
}

/* ============================================================
   11. BOTTONI E AZIONI HEADER CARD
   ============================================================ */
@media (max-width: 575.98px) {
  /* Evita overflow nei card-header con titolo + azioni */
  .card-header {
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .card-header .card-header-toolbar {
    width: 100%;
    justify-content: flex-start !important;
  }
}

/* ============================================================
   12. AVATAR / MEDIA OBJECT
   ============================================================ */
@media (max-width: 575.98px) {
  .iq-media-group .iq-media {
    width: 32px;
    height: 32px;
  }
}

/* ============================================================
   13. HERO / HEADER BANNER (.iq-navbar-header)
   ============================================================ */
@media (max-width: 767.98px) {
  .iq-navbar-header .iq-container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .iq-banner:not(.hide) + .content-inner {
    padding-top: 1rem;
  }
}

/* ============================================================
   14. FOOTER
   ============================================================ */
@media (max-width: 767.98px) {
  .footer {
    text-align: center;
  }

  .footer .footer-body {
    flex-direction: column;
    gap: 0.5rem;
    align-items: center;
  }
}

/* ============================================================
   15. SIDEBAR MINI — disabilitata sotto lg (non ha senso)
   ============================================================ */
@media (max-width: 1199.98px) {
  /* Forziamo la sidebar-mini a comportarsi come sidebar normale
     quando è nel drawer mobile — mostrar le etichette */
  .sidebar.sidebar-mini .navbar-brand .logo-title {
    transform: translateX(0%) scale(1) !important;
    opacity: 1 !important;
  }

  .sidebar.sidebar-mini.sidebar-base .nav-item .nav-link:not(.static-item) span {
    transform: translateX(0%) scale(1) !important;
    opacity: 1 !important;
  }

  .sidebar.sidebar-mini.sidebar-base .nav-item .nav-link.static-item .default-icon {
    display: block !important;
  }

  .sidebar.sidebar-mini.sidebar-base .nav-item .nav-link.static-item .mini-icon {
    display: none !important;
  }
}

/* ============================================================
   16. STICKY NAVBAR — corregge l'offset quando la sidebar è drawer
   ============================================================ */
@media (max-width: 1199.98px) {
  .sidebar + .main-content .iq-navbar.navs-sticky.menu-sticky {
    left: 0 !important;
    width: 100% !important;
  }

  .sidebar.sidebar-mini + .main-content .iq-navbar.navs-sticky.menu-sticky {
    left: 0 !important;
    width: 100% !important;
  }
}

/* ============================================================
   17. UTILITY — classi helper aggiuntive
   ============================================================ */

/* Nasconde elementi solo su mobile */
@media (max-width: 767.98px) {
  .d-mobile-none { display: none !important; }
}

/* Visibile solo su mobile */
@media (min-width: 768px) {
  .d-mobile-only { display: none !important; }
}

/* Truncate testo lungo in tabelle/card su schermi piccoli */
@media (max-width: 575.98px) {
  .text-truncate-mobile {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 160px;
    display: inline-block;
    vertical-align: middle;
  }
}

/* ============================================================
   18. FIX OVERFLOW GLOBALE — previene scroll orizzontale
   ============================================================ */
@media (max-width: 1199.98px) {
  body {
    overflow-x: hidden;
  }

  .main-content {
    overflow-x: hidden;
  }
}
