/* ============================================================
   VARIABLES ET BASES
   ============================================================ */
:root {
    --bg-color: #0f1115;
    --card-bg: #1a1d24;
    --text-main: #f1f1f1;
    --text-muted: #8b92a5;
    --accent: #7c5fe8;
    --accent-hover: #9178ed;
    --sidebar-width: 250px;
    --border-color: #2a2d35;
    --header-height: 70px;
}

* { box-sizing: border-box; margin: 0; padding: 0; font-family: 'Segoe UI', system-ui, sans-serif; }
html, body { height: 100%; background-color: var(--bg-color); color: var(--text-main); }
body { display: flex; flex-direction: column; }

/* ============================================================
   HEADER & NAVIGATION
   ============================================================ */
.header { 
    background-color: var(--card-bg); height: var(--header-height);
    padding: 0 20px; border-bottom: 1px solid var(--border-color);
    display: flex; justify-content: space-between; align-items: center;
    position: sticky; top: 0; z-index: 100;
}
.logo-container { display: flex; align-items: center; gap: 15px; }
.logo-wrapper { background: #fff; padding: 5px; border-radius: 8px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; }
.site-logo { max-width: 100%; height: auto; }
.header h1 { font-size: 1.2rem; color: var(--accent); font-weight: 800; }

.main-container { display: flex; flex: 1; }

.sidebar { 
    width: var(--sidebar-width); background-color: var(--card-bg);
    padding: 25px 15px; border-right: 1px solid var(--border-color);
    flex-shrink: 0;
}
.sidebar h3 { color: var(--text-muted); text-transform: uppercase; font-size: 0.8rem; margin-bottom: 20px; }
.sidebar li { padding: 12px 15px; margin-bottom: 8px; cursor: pointer; border-radius: 8px; list-style: none; transition: 0.2s; }
.sidebar li:hover { background: rgba(124, 95, 232, 0.1); }
.sidebar li.active { background: var(--accent); color: #fff; }

/* ============================================================
   GRILLE DE CONTENU (INDEX)
   ============================================================ */
.grid-container { 
    flex: 1; padding: 30px; display: grid; 
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); 
    gap: 30px; align-content: flex-start;
}
@media (min-width: 1600px) { .grid-container { grid-template-columns: repeat(4, 1fr); } }

.mat-card { background: var(--card-bg); border-radius: 12px; overflow: hidden; border: 1px solid var(--border-color); }
.video-wrapper { position: relative; padding-top: 56.25%; background: #000; }
.video-wrapper iframe, .mat-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }
.mat-overlay { z-index: 10; cursor: pointer; }
.mat-info { padding: 15px; text-align: center; font-weight: 600; background: #1e222a; }

/* ============================================================
   ADMINISTRATION
   ============================================================ */
.admin-body { flex: 1; padding: 30px; display: block; }

.stream-item {
    display: flex; justify-content: space-between; align-items: center; 
    background: rgba(0,0,0,0.2); padding: 15px 20px; 
    border-radius: 10px; margin-bottom: 12px; border: 1px solid var(--border-color);
}
.stream-info { display: flex; flex-direction: column; gap: 5px; }
.stream-info strong { color: var(--accent); font-size: 1rem; }
.stream-info span { color: var(--text-muted); font-size: 0.85rem; }

.form-group { margin-bottom: 20px; }
.form-group label { display: block; margin-bottom: 8px; color: var(--text-muted); font-weight: 600; }
.form-group input, .form-group textarea { 
    width: 100%; background: #0f1115; border: 1px solid #333; color: #fff; 
    padding: 15px; border-radius: 8px; font-size: 1rem;
}

/* --- BOUTONS --- */
.btn-save { 
    background: var(--accent); color: white; padding: 12px 25px; border: none; 
    border-radius: 8px; cursor: pointer; font-weight: bold; 
    font-size: 1rem; text-transform: uppercase; transition: 0.3s;
}
.btn-save:hover { background: var(--accent-hover); transform: translateY(-2px); }

button.btn-retirer { 
    background: #ff4757; color: white; border: none; 
    padding: 10px 18px; border-radius: 6px; cursor: pointer; 
    font-weight: bold; transition: 0.2s;
}
button.btn-retirer:hover { background: #ff6b81; }

/* ============================================================
   SYSTÈME DE MODALES (VIDÉO & ANNONCE)
   ============================================================ */
.modal { 
    display: none; /* Contrôlé par JS */
    position: fixed; top: 0; left: 0; 
    width: 100%; height: 100%; 
    background: rgba(0,0,0,0.92); 
    z-index: 2000; 
    justify-content: center; align-items: center; 
}

/* Quand la modale est active (via JS ou classe) */
.modal.active { display: flex !important; }

.modal-content { 
    width: 90%; max-width: 1000px; 
    position: relative; 
}

/* Style spécifique pour la boîte d'annonce */
.announcement-box {
    max-width: 550px;
    background: var(--card-bg);
    padding: 40px;
    border-radius: 20px;
    border: 1px solid var(--accent);
    text-align: center;
    box-shadow: 0 0 30px rgba(124, 95, 232, 0.3);
}

.close-btn { 
    position: absolute; top: -45px; right: 0; 
    color: #fff; font-size: 35px; cursor: pointer; 
    transition: 0.3s;
}
.close-btn:hover { color: var(--accent); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: var(--card-bg); padding: 20px; text-align: center; border-top: 1px solid var(--border-color); color: var(--text-muted); font-size: 0.8rem; margin-top: auto; }
.footer-links a { color: var(--text-muted); text-decoration: none; margin: 0 10px; }

/* BANDEAU COOKIES */
.cookie-banner {
    display: none; /* Masqué par défaut */
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 600px;
    background: rgba(26, 29, 36, 0.95);
    border: 1px solid var(--accent);
    padding: 15px 25px;
    border-radius: 12px;
    z-index: 10000;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    backdrop-filter: blur(10px);
}

.cookie-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}

.cookie-content p {
    color: var(--text-main);
    font-size: 0.9rem;
    line-height: 1.4;
}

@media (max-width: 600px) {
    .cookie-content { flex-direction: column; text-align: center; }
}

/* popup */

.popup-image-container {
    width: 100%;
    max-height: 300px; /* Hauteur max pour ne pas manger tout l'écran */
    margin-bottom: 15px;
    display: flex;
    justify-content: center;
    overflow: hidden;
    border-radius: 8px;
    background: rgba(0,0,0,0.2);
}

.popup-image-container img {
    max-width: 100%;
    max-height: 300px;
    object-fit: contain; /* Garde les proportions sans déformer ni couper */
    display: block;
}

/* --- OPTIMISATION MOBILE (Écrans < 768px) --- */
@media (max-width: 768px) {
    /* 1. On passe la structure en colonne (Sidebar au dessus ou cachée) */
    .admin-body, .main-container {
        display: flex !important;
        flex-direction: column !important;
        padding: 10px !important;
    }

    .sidebar {
        width: 100% !important;
        margin-bottom: 20px;
    }

    /* 2. La grille de MATs passe à 1 seule colonne pour que la vidéo soit large */
    .grid-container {
        grid-template-columns: 1fr !important; 
        gap: 15px !important;
    }

    /* 3. On ajuste le Header pour gagner de la place */
    .header {
        height: auto !important;
        padding: 10px !important;
        flex-direction: column;
        gap: 10px;
    }

    .logo-container h1 {
        font-size: 1rem;
    }

    /* 4. On agrandit les zones cliquables (boutons/liens) pour les pouces */
    .event-list-item, li {
        padding: 15px !important;
        font-size: 1rem;
    }

    /* 5. Optimisation de la vidéo pour qu'elle utilise toute la largeur */
    .video-wrapper {
        border-radius: 0; /* Plus propre sur mobile de bord à bord */
    }

    .mat-card {
        margin-bottom: 10px;
    }
}
/* --- STYLE DU HAMBURGER --- */
.hamburger {
    display: none; /* Caché sur PC */
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 10px;
    z-index: 1001;
}

.hamburger span {
    display: block;
    width: 25px;
    height: 3px;
    background-color: var(--accent);
    border-radius: 3px;
    transition: 0.3s;
}

/* --- RESPONSIVE MOBILE --- */
@media (max-width: 768px) {
    .hamburger { display: flex; }

    .sidebar {
        position: fixed;
        top: 0;
        left: -100%; /* Caché à gauche par défaut */
        width: 80% !important;
        height: 100%;
        background: var(--card-bg);
        z-index: 1000;
        transition: 0.4s;
        padding-top: 80px !important;
        box-shadow: 10px 0 30px rgba(0,0,0,0.5);
    }

    /* Classe qui sera ajoutée en JS pour ouvrir le menu */
    .sidebar.open {
        left: 0;
    }

    /* Animation du bouton X quand ouvert */
    .hamburger.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
    .hamburger.open span:nth-child(2) { opacity: 0; }
    .hamburger.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

    .main-container {
        flex-direction: column;
    }
}/* Voile sombre derrière le menu */
.menu-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    z-index: 999; /* Juste en dessous de la sidebar */
}

/* Affichage de l'overlay quand le menu est ouvert */
.menu-overlay.active {
    display: block;
}

@media (max-width: 768px) {
    /* On s'assure que le hamburger reste au dessus de tout pour servir de bouton de fermeture */
    .hamburger {
        position: relative;
        z-index: 1002; 
    }
    
    /* Animation pour transformer les barres en croix */
    .hamburger.open span:nth-child(1) {
        transform: translateY(8px) rotate(45deg);
        background-color: #fff; /* La croix devient blanche pour mieux la voir */
    }
    .hamburger.open span:nth-child(2) {
        opacity: 0;
    }
    .hamburger.open span:nth-child(3) {
        transform: translateY(-8px) rotate(-45deg);
        background-color: #fff;
    }
}