﻿/* ========================================
   Panini Express - NOUVEAU THEME
   ======================================== */

:root {
    --panini-primary: #e65100;      /* Orange poivron/chaud */
    --panini-primary-hover: #cc4800;
    --panini-dark: #3e2723;         /* Marron chocolat/pain toasté */
    --panini-light: #fff8e1;        /* Crème très clair */
}

/* --- TYPOGRAPHIE --- */
body {
    font-family: 'Inter', sans-serif;
    color: #333333;
    background-color: #f4f6f8;
}

h1, h2, h3, h4, h5, h6, .navbar-brand {
    font-family: 'Nunito', sans-serif;
}

/* Surcharge Bootstrap Colors */
.text-danger { color: var(--panini-primary) !important; }
.bg-danger { background-color: var(--panini-primary) !important; }
.border-danger { border-color: var(--panini-primary) !important; }

/* Conteneurs et Boxes - Amélioration du contraste (blanc sur blanc) */
.bg-white {
    background-color: #ffffff !important;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08) !important; /* Ombre plus marquée pour bien détacher du fond blanc/clair */
    border: 1px solid rgba(230, 81, 0, 0.1); /* Liseré subtilement orangé rappelant le thème principal */
}

/* Surcharge spécifique pour toutes les "cartes" sur le fond de page */
.card {
    background-color: #ffffff;
    box-shadow: 0 6px 20px rgba(62, 39, 35, 0.08) !important; /* Ombre douce mais visible */
    border: 1px solid rgba(230, 81, 0, 0.15) !important; /* Liseré orangé */
}

.card.bg-white {
    box-shadow: 0 8px 25px rgba(230, 81, 0, 0.12) !important; /* L'ombre orangée est accentuée pour donner du relief */
}

/* Fond alternatif plus esthétique pour les sections claires */
.bg-light {
    background-color: var(--panini-light) !important; /* Utilisation de la couleur crème */
}

/* Boutons +/- du panier (orange transparent) */
.btn-panier-qty {
    color: var(--panini-primary);
    border-color: var(--panini-primary);
    background-color: transparent;
    transition: all 0.2s ease-in-out;
}

.btn-panier-qty:hover, .btn-panier-qty:focus {
    background-color: var(--panini-primary);
    color: white !important;
}

/* Ajustement contraste cartes sur fond blanc pur (liste paninis) */
.product-card {
    border-radius: 15px !important;
    overflow: hidden;
    background-color: #ffffff !important; /* Blanc pur */
    border: 1px solid #dee2e6 !important; /* Bordure gris clair standard Bootstrap */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); /* Ombre douce neutre */
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.product-card:hover {
    transform: translateY(-8px);
    border-color: #adb5bd !important; /* Gris légèrement plus foncé au survol */
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12) !important;
}

/* Navbar Customization */
.navbar {
    background-color: #ffffff !important;
    border-bottom: 2px solid var(--panini-light);
}

.navbar-brand {
    font-weight: 900;
    font-size: 1.8rem !important;
    color: var(--panini-dark) !important;
    letter-spacing: -0.5px;
}

.navbar-brand span {
    color: var(--panini-primary);
}

.nav-link {
    font-weight: 600;
    font-size: 1.1rem;
    color: #555 !important;
    transition: color 0.2s;
}

.nav-link:hover, .nav-link.active {
    color: var(--panini-primary) !important;
}

/* Icon Box & Reassurance Cards */
.reassurance-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid #dee2e6 !important;
}

[data-bs-theme="dark"] .reassurance-card {
    border-color: #424242 !important;
}

.reassurance-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.08) !important;
}

.icon-box {
    width: 70px;
    height: 70px;
    background: linear-gradient(135deg, var(--panini-primary), #ff8a65);
    color: white;
    font-size: 1.8rem;
    margin-bottom: 1.2rem;
    animation: fadeIn 0.5s ease-in;
}

/* Hero Section */
.hero-section {
    background: linear-gradient(rgba(62, 39, 35, 0.7), rgba(62, 39, 35, 0.7)), url('https://images.unsplash.com/photo-1481070414801-51fd732d7184?q=80&w=1920&auto=format&fit=crop') center/cover;
    color: white;
    padding: 100px 0;
}

/* Category Cards */
.category-card {
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.4s ease;
    border-radius: 16px;
    overflow: hidden;
    border: none;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.category-card:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 15px 30px rgba(0,0,0,0.15) !important;
}

/* Button overrides */
.btn-danger {
    background-color: var(--panini-primary) !important;
    border-color: var(--panini-primary) !important;
    color: white !important;
    font-weight: 700;
    box-shadow: 0 4px 6px rgba(230, 81, 0, 0.2);
    transition: all 0.3s ease;
}

.btn-danger:hover {
    background-color: #ffffff !important;
    color: var(--panini-primary) !important;
    border-color: var(--panini-primary) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(230, 81, 0, 0.3);
}

.btn-outline-danger {
    color: var(--panini-primary) !important;
    border-color: var(--panini-primary) !important;
    font-weight: 700;
    border-width: 2px;
}

.btn-outline-danger:hover {
    background-color: var(--panini-primary) !important;
    color: white !important;
}

/* Price Section */
.price-section {
    background-color: var(--panini-light) !important;
    border-radius: 10px;
    padding: 12px;
    border-left: 4px solid var(--panini-primary);
}

/* Footer overrides */
.bg-dark {
    background-color: var(--panini-dark) !important;
}
footer {
    border-top: 5px solid var(--panini-primary);
}

.text-white a:hover {
    color: var(--panini-primary) !important;
    opacity: 1;
    text-decoration: none !important;
}

/* Liens rapides du footer specifiques */
.hover-orange {
    display: inline-block;
    transition: all 0.3s ease;
}

.hover-orange:hover {
    color: var(--panini-primary) !important;
    transform: scale(1.05) translateX(5px);
    text-decoration: none !important;
}

/* Animations */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Menu déroulant */
.dropdown-item:hover, .dropdown-item:focus {
    background-color: var(--panini-primary) !important;
    color: white !important;
}

.dropdown-item:active {
    background-color: var(--panini-primary) !important;
    color: white !important;
}

@media (max-width: 768px) {
    .hero-section { padding: 60px 0; }
    .hero-section .container {
        display: flex;
        flex-direction: column;
        gap: 0.8rem;
        align-items: center;
    }
    .hero-section .container a.btn {
        width: 100%;
        max-width: 320px;
        margin: 0 !important;
    }
    .hero-section .container a.btn + a.btn {
        margin-top: 0.5rem !important;
    }
    .display-3 { font-size: 2.2rem; }
    .icon-box { font-size: 2.5rem; }

    /* Newsletter mobile form : champ et bouton empilés */
    #newsletter form {
        flex-direction: column !important;
        align-items: stretch;
    }
    #newsletter form .form-control,
    #newsletter form .btn {
        width: 100%;
    }
    #newsletter form .btn {
        margin-top: 0.75rem;
    }
}

.btn-zoom-hover { transition: transform 0.2s ease-in-out; display: inline-block; }
.btn-zoom-hover:hover { transform: scale(1.1); }

/* --- Formulaires (spécifique contact & divers) --- */
.form-card { border-radius: 1rem; }
.form-control:focus {
    border-color: var(--panini-primary, #e65100);
    box-shadow: 0 0 0 0.25rem rgba(230, 81, 0, 0.25);
}

/* Product image wrapper hover (zoom) */
.product-image-wrapper img {
    transition: transform 0.3s ease;
}
.product-image-wrapper img:hover {
    transform: scale(1.05);
}

/* Style pour masquer les flèches du champ number par défaut */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Corriger le chevauchement du texte dans les selects */
.form-select {
    padding-right: 2.5rem !important;
    text-overflow: ellipsis;
}

html, body {
    min-height: 100%;
    height: 100%;
}

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main {
    flex: 1 0 auto;
}

/* ========================================
   MODE SOMBRE (Dark Mode) overrides
   ======================================== */
[data-bs-theme="dark"] body {
    background-color: #121212 !important;
    color: #f8f9fa !important;
}

[data-bs-theme="dark"] .bg-white,
[data-bs-theme="dark"] .card,
[data-bs-theme="dark"] .navbar {
    background-color: #1e1e1e !important;
    border-color: rgba(255,255,255,0.1) !important;
}

[data-bs-theme="dark"] .product-card {
    border: 1px solid #424242 !important;
}

[data-bs-theme="dark"] .product-card:hover {
    border-color: #616161 !important;
}

[data-bs-theme="dark"] .navbar-brand {
    color: #f8f9fa !important;
}

[data-bs-theme="dark"] .nav-link,
[data-bs-theme="dark"] .text-dark:not(.btn-warning) {
    color: #e0e0e0 !important;
}

[data-bs-theme="dark"] .btn-warning.text-dark {
    color: #212529 !important; /* Garder le texte foncé sur les boutons jaunes, même en mode sombre */
}

[data-bs-theme="dark"] .text-muted {
    color: #a0a0a0 !important;
}

[data-bs-theme="dark"] .bg-light,
[data-bs-theme="dark"] .price-section {
    background-color: #2c2c2c !important;
}

[data-bs-theme="dark"] .dropdown-menu {
    background-color: #1e1e1e !important;
    border-color: rgba(255,255,255,0.1);
}

[data-bs-theme="dark"] .dropdown-item {
    color: #e0e0e0;
}

[data-bs-theme="dark"] .dropdown-item:hover,
[data-bs-theme="dark"] .dropdown-item:focus {
    color: white !important;
}

[data-bs-theme="dark"] .list-group-item {
    background-color: transparent;
    color: #e0e0e0;
    border-color: rgba(255,255,255,0.1);
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: #2c2c2c;
    color: #f8f9fa;
    border-color: rgba(255,255,255,0.2);
}

[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    background-color: #333;
    color: #f8f9fa;
}

/* Boutons outline-secondary : amélioration visibilité en mode sombre */
[data-bs-theme="dark"] .btn-outline-secondary {
    color: #ffffff !important; /* texte blanc par défaut */
    background-color: #2c2c2c !important; /* même gris que les boxes sombres */
    border-color: #ffffff !important; /* bordure blanche */
    border-width: 2px !important;
    transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

[data-bs-theme="dark"] .btn-outline-secondary:hover,
[data-bs-theme="dark"] .btn-outline-secondary:focus {
    background-color: #ffffff !important; /* fond blanc au survol */
    color: #2c2c2c !important; /* texte gris déjà utilisé pour text-muted */
    border-color: #ffffff !important;
}
