/* Mobile overrides — Gleeye ERP
 * Trasversale fix mobile per modal, form, tabelle. Caricato in coda agli altri CSS.
 * Pattern: tutto sotto 768px diventa "mobile-first reasonable".
 */

@media (max-width: 768px) {

    /* ─── Modal: niente overflow, scroll interno ──────────────────── */
    .modal {
        padding: 8px !important;
        align-items: flex-start !important;
    }
    .modal-content {
        max-width: 100% !important;
        width: 100% !important;
        max-height: 92vh !important;
        overflow-y: auto !important;
        margin: 0 auto !important;
        border-radius: 16px !important;
        -webkit-overflow-scrolling: touch;
    }
    .glass-card.modal-content {
        max-width: 100% !important;
    }

    /* ─── Form input: 16px = no zoom su iOS Safari ──────────────── */
    .modal-input,
    .modal input[type="text"],
    .modal input[type="email"],
    .modal input[type="tel"],
    .modal input[type="number"],
    .modal input[type="date"],
    .modal input[type="time"],
    .modal input[type="search"],
    .modal input[type="url"],
    .modal select,
    .modal textarea,
    input.modal-input {
        font-size: 16px !important;
        padding: 12px 14px !important;
        min-height: 44px;
        border-radius: 10px !important;
    }

    /* ─── Form grid: 1 colonna sempre su mobile ──────────────────── */
    .form-grid,
    .modal .form-grid {
        grid-template-columns: 1fr !important;
        gap: 0.85rem !important;
    }

    /* Anche le grid inline-style dei modal */
    .modal [style*="grid-template-columns"],
    .modal-content [style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
    }
    /* …tranne le grid che esplicitamente mantengono 2 colonne tramite class dedicate */
    .modal .form-grid-keep-cols {
        grid-template-columns: 1fr 1fr !important;
    }

    /* ─── Bottoni: pieno width nei form, comoda touch area ──────── */
    .modal .form-actions,
    .modal-content .form-actions {
        flex-direction: column-reverse !important;
        gap: 0.6rem !important;
        align-items: stretch !important;
    }
    .modal .primary-btn,
    .modal-content .primary-btn,
    .form-actions .primary-btn {
        width: 100% !important;
        min-height: 46px !important;
        font-size: 15px !important;
        padding: 12px 18px !important;
    }

    /* ─── Tabelle: scroll orizzontale invece di rompere il layout ── */
    .table-container,
    .glass-card > div[style*="overflow-x"] {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }
    .table-container table,
    .glass-card table {
        min-width: 540px;
        font-size: 0.82rem !important;
    }
    .table-container th,
    .table-container td {
        white-space: nowrap;
        padding: 0.55rem 0.75rem !important;
    }

    /* ─── Tab bar: scrollable orizzontale ──────────────────────── */
    .tabs-container {
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        -webkit-overflow-scrolling: touch;
        gap: 0.5rem !important;
    }
    .tabs-container .tab-btn {
        flex-shrink: 0;
        padding: 0.5rem 0.85rem !important;
        font-size: 0.85rem !important;
    }

    /* ─── Cards che escono dalla viewport ──────────────────────── */
    .glass-card {
        max-width: 100% !important;
        overflow: hidden;
    }

    /* ─── Padding generale ridotto su content area ─────────────── */
    .content-area {
        padding: 1rem !important;
    }
    .animate-fade-in[style*="padding: 2rem"] {
        padding: 1rem !important;
    }

    /* ─── Cmd+K palette: width 100% mobile ────────────────────── */
    #cmdk-panel {
        max-width: 100% !important;
        width: 95% !important;
    }

    /* ─── Help AI panel: width 95% mobile ─────────────────────── */
    .gl-help-ai-panel {
        max-width: calc(100vw - 16px) !important;
    }

    /* ─── Header detail pages: stack verticale ────────────────── */
    .glass-card[style*="display: flex"][style*="gap: 2.5rem"],
    .glass-card[style*="display: flex"][style*="gap: 2rem"] {
        flex-direction: column !important;
        gap: 1.25rem !important;
        text-align: center;
        padding: 1.5rem !important;
    }

    /* ─── KPI grid 4 cols → 2 cols → 1 col ─────────────────────── */
    .card-grid,
    .bank-kpi-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.75rem !important;
    }
}

/* ─── Smartphone piccoli (sotto 380px) ──────────────────────────── */
@media (max-width: 380px) {
    .card-grid,
    .bank-kpi-grid {
        grid-template-columns: 1fr !important;
    }
    .modal-content {
        padding: 1rem !important;
    }
}
