/* ============================================================================
   RESPONSIVE & MOBILE OPTIMIZATIONS - SpendIA
   Mobile-first, performances optimisées, touch-friendly
   ============================================================================ */

/* ============================================================================
   MOBILE - Styles de base (< 768px)
   ============================================================================ */

@media (max-width: 768px) {
    /* Désactiver Aurora background pour performances */
    .aurora-background {
        display: none;
    }

    /* Réduire le blur pour performances */
    .card,
    dialog,
    .glass {
        backdrop-filter: blur(var(--blur-sm)) !important;
        -webkit-backdrop-filter: blur(var(--blur-sm)) !important;
    }

    /* Container & Shell */
    .app-shell {
        padding: var(--spacing-4) var(--spacing-4);
        padding-top: max(var(--spacing-4), env(safe-area-inset-top));
        padding-bottom: max(var(--spacing-4), env(safe-area-inset-bottom));
        padding-left: max(var(--spacing-4), env(safe-area-inset-left));
        padding-right: max(var(--spacing-4), env(safe-area-inset-right));
    }

    /* Header responsive */
    header {
        flex-direction: column;
        gap: var(--spacing-4);
        padding-bottom: var(--spacing-6);
        margin-bottom: var(--spacing-6);
    }

    .hero h1 {
        font-size: clamp(1.75rem, 6vw, 2rem);
        text-align: center;
    }

    .welcome-message {
        font-size: var(--font-size-sm);
        text-align: center;
    }

    .actions {
        flex-wrap: wrap;
        gap: var(--spacing-2);
        width: 100%;
        justify-content: center;
    }

    /* Boutons responsive */
    button,
    .btn {
        min-height: 44px;
        min-width: 44px;
        padding: var(--spacing-3) var(--spacing-4);
        font-size: var(--font-size-base);
    }


    /* Inputs responsive */
    input,
    select,
    textarea {
        font-size: 16px !important; /* Évite le zoom sur iOS */
        min-height: 44px;
        padding: var(--spacing-3) var(--spacing-4);
    }

    /* Cards responsive */
    .card {
        padding: var(--spacing-5);
        border-radius: var(--radius);
    }

    /* Grids responsive */
    .main-grid,
    .finances-grid,
    .projects-grid,
    .recurring-grid,
    .categories-grid,
    .pricing-grid,
    .charts-stack,
    .trends-grid,
    .analysis-grid {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-4);
    }

    .form-grid,
    .form-grid-expense {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-4);
    }

    /* Tables responsive */
    .table-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        margin-left: 0;
        margin-right: 0;
        border-radius: var(--radius);
        max-width: 100%;
        width: 100%;
    }

    table {
        font-size: var(--font-size-sm);
        min-width: 100%;
        width: 100%;
    }

    table th,
    table td {
        padding: var(--spacing-3) var(--spacing-4);
        white-space: nowrap;
    }

    table th:first-child,
    table td:first-child {
        padding-left: var(--spacing-4);
        white-space: normal;
        min-width: 100px;
        max-width: 140px;
    }

    table th:last-child,
    table td:last-child {
        padding-right: var(--spacing-4);
    }

    /* Boutons d'actions dans les tables */
    td .table-actions {
        flex-wrap: nowrap;
        gap: var(--spacing-1);
    }

    td .table-actions button {
        font-size: var(--font-size-xs);
        padding: var(--spacing-2) var(--spacing-3);
    }

    /* Catégories grid responsive - CORRECTION DÉBORDEMENT */
    .categories-grid {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-4);
        width: 100%;
        max-width: 100%;
        overflow: hidden;
    }

    .category-card {
        padding: var(--spacing-4);
        gap: var(--spacing-3);
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        display: flex;
        align-items: center;
        overflow: hidden;
    }

    .category-card-info {
        flex: 1;
        min-width: 0;
        overflow: hidden;
        display: flex;
        align-items: center;
        gap: var(--spacing-2);
    }

    .category-card-info span {
        font-size: var(--font-size-sm);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .category-card-actions {
        flex-shrink: 0;
        display: flex;
        gap: var(--spacing-1);
        margin-left: var(--spacing-2);
    }

    .category-card-actions .icon-btn {
        min-width: 44px !important;
        min-height: 44px !important;
        width: 44px;
        height: 44px;
        padding: var(--spacing-2) !important;
    }

    .category-color {
        flex-shrink: 0;
    }

    /* Graphiques responsive */
    .chart-card {
        padding: var(--spacing-4);
    }

    .chart-card canvas {
        max-height: 250px;
    }

    /* Dialogs responsive */
    dialog {
        width: calc(100% - 2rem);
        max-width: calc(100% - 2rem);
        margin: var(--spacing-4);
        padding: var(--spacing-6);
        max-height: calc(100vh - 4rem);
    }

    .dialog-actions {
        flex-direction: column-reverse;
        gap: var(--spacing-3);
    }

    .dialog-actions button {
        width: 100%;
    }

    /* Section headers */
    .section-header {
        flex-direction: row;
        gap: var(--spacing-3);
        align-items: center;
        justify-content: space-between;
    }

    .section-header h2 {
        font-size: var(--font-size-lg);
        flex: 1;
        min-width: 0;
    }

    .section-header > div {
        flex: 1;
        min-width: 0;
    }

    .section-header button,
    .section-header .header-actions {
        flex-shrink: 0;
    }

    .header-actions {
        display: flex;
        gap: var(--spacing-2);
    }

    /* Main content */
    main {
        gap: var(--spacing-5);
    }

    /* Footer */
    #app-footer {
        padding: var(--spacing-6) var(--spacing-4);
        font-size: var(--font-size-xs);
    }

    #app-footer p {
        flex-direction: column;
        text-align: center;
        gap: var(--spacing-2);
    }

    /* Snackbar */
    .snackbar {
        min-width: auto;
        width: calc(100% - 2rem);
        left: var(--spacing-4);
        right: var(--spacing-4);
    }

    /* Premium badge */
    #premium-badge {
        font-size: var(--font-size-xs);
        padding: var(--spacing-1) var(--spacing-3);
    }

    /* Désactiver les animations coûteuses sur mobile */
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    /* Sauf pour les transitions essentielles */
    button,
    .btn,
    a,
    input,
    select,
    textarea,
    .card,
    dialog {
        animation-duration: 0.2s !important;
        transition-duration: 0.2s !important;
    }
}

/* ============================================================================
   TRÈS PETITS ÉCRANS (< 375px)
   ============================================================================ */

@media (max-width: 374px) {
    .app-shell {
        padding: var(--spacing-3);
        padding-top: max(var(--spacing-3), env(safe-area-inset-top));
        padding-bottom: max(var(--spacing-3), env(safe-area-inset-bottom));
        padding-left: max(var(--spacing-3), env(safe-area-inset-left));
        padding-right: max(var(--spacing-3), env(safe-area-inset-right));
    }

    .card {
        padding: var(--spacing-4);
    }

    header h1 {
        font-size: var(--font-size-2xl);
    }

    .section-header h2 {
        font-size: var(--font-size-lg);
    }

    table {
        font-size: var(--font-size-xs);
    }

    table th,
    table td {
        padding: var(--spacing-2) var(--spacing-2);
    }

    button,
    .btn {
        padding: var(--spacing-3) var(--spacing-4);
        font-size: var(--font-size-sm);
    }
}

/* ============================================================================
   TABLETTES (768px - 1024px)
   ============================================================================ */

@media (min-width: 769px) and (max-width: 1024px) {
    .app-shell {
        max-width: 100%;
        padding: var(--spacing-6);
    }

    .main-grid {
        grid-template-columns: 1fr;
    }

    .finances-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .pricing-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ============================================================================
   DESKTOP LARGE (> 1440px)
   ============================================================================ */

@media (min-width: 1441px) {
    .app-shell {
        max-width: 1600px;
        margin: 0 auto;
    }

    .container {
        max-width: 1600px;
    }
}

/* ============================================================================
   OPTIMISATIONS iOS / TOUCH DEVICES
   ============================================================================ */

/* Désactiver tap highlight */
* {
    -webkit-tap-highlight-color: transparent;
    -webkit-touch-callout: none;
}

/* Permettre sélection pour inputs et textes */
input,
textarea,
[contenteditable],
.selectable {
    -webkit-user-select: text;
    user-select: text;
}

/* Autres éléments non sélectionnables */
button,
.btn,
.card,
label {
    -webkit-user-select: none;
    user-select: none;
}

/* Optimisations scroll iOS */
body {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: none;
    overscroll-behavior-y: contain;
}

/* Désactiver zoom double-tap */
button,
a,
input,
select,
textarea {
    touch-action: manipulation;
}

/* Active state pour iOS */
button:active,
.btn:active,
a:active {
    opacity: 0.8;
    transform: scale(0.98);
}

/* Désactiver highlight bleu iOS sur liens */
a {
    -webkit-tap-highlight-color: transparent;
}

/* Optimiser inputs pour iOS */
input,
select,
textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/* Scroll tableaux iOS */
.table-wrapper {
    -webkit-overflow-scrolling: touch;
}

/* Safe area pour notch iPhone */
@supports (padding: env(safe-area-inset-top)) {
    body {
        padding-bottom: env(safe-area-inset-bottom);
    }

    #app-footer {
        padding-bottom: max(var(--spacing-6), env(safe-area-inset-bottom));
    }
}

/* Dialogs iOS */
dialog {
    -webkit-overflow-scrolling: touch;
}

/* Boutons touch-friendly */
@media (hover: none) and (pointer: coarse) {
    button,
    .btn,
    a[role="button"] {
        min-height: 44px;
        min-width: 44px;
        padding: var(--spacing-3) var(--spacing-5);
    }

    button:active,
    .btn:active {
        transform: scale(0.95);
        transition: transform 0.1s ease;
    }
}

/* Sélecteur date iOS */
input[type="date"],
input[type="month"],
input[type="time"],
input[type="datetime-local"] {
    min-height: 44px;
}

/* Textarea non redimensionnable sur mobile */
@media (max-width: 768px) {
    textarea {
        resize: none;
    }
}

/* Focus visible sur iOS */
input:focus,
select:focus,
textarea:focus,
button:focus {
    outline: 2px solid var(--accent-primary);
    outline-offset: 2px;
}

/* Empêcher double-tap zoom */
.section-header,
.actions,
.dialog-actions,
.table-actions {
    touch-action: manipulation;
}

/* Graphiques touch */
canvas {
    touch-action: pan-y;
}

/* ============================================================================
   PRÉFÉRENCE MOUVEMENT RÉDUIT (Accessibilité)
   ============================================================================ */

@media (prefers-reduced-motion: reduce) {
    *:not(.ai-action),
    *:not(.ai-action)::before,
    *:not(.ai-action)::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .aurora-shape {
        animation: none !important;
    }

    /* Garder l'animation des boutons IA même en mode reduced-motion */
    .ai-action,
    button.ai-action {
        animation-duration: 4s !important;
        animation-iteration-count: infinite !important;
    }
}

/* ============================================================================
   DARK MODE PRÉFÉRENCE
   ============================================================================ */

@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
        /* Appliquer le thème sombre par défaut si pas de préférence définie */
        color-scheme: dark;
    }
}

/* ============================================================================
   PRINT STYLES
   ============================================================================ */

@media print {
    /* Cacher les éléments non essentiels */
    .aurora-background,
    .premium-badge,
    .premium-overlay,
    .btn-premium,
    .ai-tokens-indicator,
    button,
    .actions,
    #theme-switcher-btn,
    #logout-btn {
        display: none !important;
    }

    /* Optimiser pour l'impression */
    body {
        background: white;
        color: black;
    }

    .card {
        border: 1px solid #ccc;
        box-shadow: none;
        page-break-inside: avoid;
    }

    table {
        page-break-inside: auto;
    }

    tr {
        page-break-inside: avoid;
        page-break-after: auto;
    }
}

/* ============================================================================
   HIGH CONTRAST MODE (Accessibilité)
   ============================================================================ */

@media (prefers-contrast: more) {
    :root {
        --border-color: currentColor;
        --border-hover: currentColor;
    }

    button,
    input,
    select,
    textarea {
        border-width: 2px;
    }
}
