:root {
            /* --- VARIABLES DE BASE (Transition) --- */
            --transition-speed: 0.6s;
            
            /* --- SYSTÈME D'ÉCHELLE (Responsive) --- */
            --space-xs: 0.25rem;   /* 4px */
            --space-sm: 0.5rem;    /* 8px */
            --space-md: 1rem;      /* 16px */
            --space-lg: 1.5rem;    /* 24px */
            --space-xl: 2rem;      /* 32px */
            
            --font-sm: 0.75rem;
            --font-base: 1rem;
            --font-md: 1.125rem;   /* 1.125x */
            --font-lg: 1.25rem;    /* 1.25x */
            --font-xl: 1.5rem;     /* 1.5x */
            --font-xxl: 2.2rem;    /* 2.2x */
            
            /* --- RATIOS DE LAYOUT --- */
            --roster-min-width: 190px;        /* Cartes encore plus grandes */
            --card-padding-ratio: 1.25rem;    /* Padding des cartes augmenté */
            --gap-ratio: 1rem;
            
            /* Ratio vote section (réduit) */
            --vote-padding: 0.75rem;          /* Réduit */
            --vote-gap: 0.5rem;               /* Réduit */
            --vote-title-size: 1.7rem;        /* Titre encore plus gros */
            
            /* --- THÈME: CELESTARS (Défaut - Terre/Or/Feu) --- */
            --bg-world: #1a1b1e;
            --bg-gradient: radial-gradient(circle at 50% 0%, #2c2e33 0%, #1a1b1e 80%);
            --bg-panel: #25262b;
            --bg-input: #141517;
            
            --accent-main: #c2a370;   /* Or vieilli */
            --accent-hover: #e6c895;
            --accent-secondary: #5c5f66;
            
            --text-main: #e4e5e7;
            --text-muted: #909296;
            
            --border-color: #444;
            --btn-primary-bg: linear-gradient(180deg, #373a40 0%, #25262b 100%);
            --btn-primary-border: #c2a370;
            
            --world-icon: "🏔️"; /* Montagne/Terre */
            
            /* Couleurs de vote (fixes) */
            --vote-pour: #2f9e44;
            --vote-contre: #e03131;
            --vote-abs: #868e96;
            --success: #40c057;

            --font-heading: 'Cinzel', serif;
            --font-body: 'Inter', sans-serif;
            --radius: 4px;
        }

        /* --- THÈME: LIGNÉES (Espace/Argent/Divin) - ADOUCI --- */
        body.theme-lignees {
            --bg-world: #0a0b10;
            --bg-gradient: radial-gradient(circle at 50% 0%, #1c1e26 0%, #0a0b10 90%);
            --bg-panel: #14151a;
            --bg-input: #0e0f12;
            
            --accent-main: #c0c2ce;   
            --accent-hover: #e2e8f0;
            --accent-secondary: #475569;
            
            --text-main: #f1f5f9;
            --text-muted: #64748b;
            
            --border-color: #2d2f38;
            --btn-primary-bg: linear-gradient(180deg, #1e2029 0%, #14151a 100%);
            --btn-primary-border: #475569;
            
            --world-icon: "🌌"; /* Espace/Galaxie */
        }

        * { box-sizing: border-box; margin: 0; padding: 0; }

        body {
            font-family: var(--font-body);
            background-color: var(--bg-world);
            background-image: url('cordee_background.png');
            background-size: cover;
            background-position: center;
            background-attachment: scroll;
            color: var(--text-main);
            min-height: 100vh;
            display: flex;
            flex-direction: column;
            transition: background var(--transition-speed), color var(--transition-speed);
        }

        body.theme-lignees {
            background-image: url('celestars_background.png');
        }

        /* --- UTILS --- */
        .hidden { display: none !important; }
        .container { max-width: 600px; margin: 0 auto; padding: 20px; width: 100%; position: relative; z-index: 10; }
        
        /* Hero section d'accueil */
        .hero {
            text-align: center; margin: 60px 0 50px 0; animation: fadeIn 0.5s ease-out;
        }
        .hero h1 { font-size: 3.5rem; margin-bottom: var(--space-md); letter-spacing: 3px; font-weight: 700; }
        .hero p { font-size: 1.3rem; color: var(--text-muted); letter-spacing: 1px; }
        
        h1, h2, h3 { 
            font-family: var(--font-heading); 
            color: var(--accent-main); 
            letter-spacing: 1px;
            font-weight: 700;
            transition: color var(--transition-speed);
        }

        /* BOUTONS */
        .btn {
            background: linear-gradient(180deg, #373a40 0%, #25262b 100%);
            color: var(--accent-main);
            border: 1px solid var(--border-color);
            padding: 14px 20px;
            border-radius: var(--radius);
            font-size: 1rem;
            font-family: var(--font-heading);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s ease;
            width: 100%;
            margin-bottom: 12px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
            position: relative;
        }
        .btn:hover, .btn:active { 
            background: rgba(194, 163, 112, 0.15);
            color: var(--accent-main);
            border-color: var(--accent-main);
            box-shadow: 0 4px 15px rgba(194, 163, 112, 0.2);
            transform: translateY(-2px);
        }

        .btn-primary {
            background: linear-gradient(180deg, #373a40 0%, #25262b 100%);
            border: 1px solid var(--border-color);
            color: var(--accent-main);
        }
        .btn-primary:hover, .btn-primary:active {
            color: var(--accent-main);
            border-color: var(--accent-main);
            background: rgba(194, 163, 112, 0.15);
            box-shadow: 0 4px 15px rgba(194, 163, 112, 0.2);
            transform: translateY(-2px);
        }
        
        .btn-action {
            background: #7f1d1d; color: white; border: 1px solid #991b1b;
        }
        .btn-action:hover { background: #991b1b; }
        .btn-action:active {
            background: rgba(194, 163, 112, 0.15);
            border-color: var(--accent-main);
            color: var(--accent-main);
        }

        /* INPUTS & CHECKBOXES */
        input[type="text"], input[type="number"] {
            width: 100%; padding: 14px; border-radius: var(--radius);
            border: 1px solid var(--border-color); background: var(--bg-input); color: var(--text-main);
            margin-bottom: 15px; font-size: 1rem; font-family: var(--font-body);
            transition: all var(--transition-speed);
            /* Éviter le zoom automatique sur iOS */
            font-size: 16px;
        }
        input:focus { outline: none; border-color: var(--accent-main); }
        
        /* Désactiver le style d'autocomplete par défaut du navigateur */
        input:-webkit-autofill,
        input:-webkit-autofill:hover,
        input:-webkit-autofill:focus,
        input:-webkit-autofill:active {
            -webkit-box-shadow: 0 0 0 30px var(--bg-input) inset !important;
            -webkit-text-fill-color: var(--text-main) !important;
            transition: background-color 5000s ease-in-out 0s;
        }

        .checkbox-wrapper {
            display: flex; align-items: center; 
            gap: 8px; cursor: pointer;
        }
        input[type="checkbox"] {
            appearance: none; -webkit-appearance: none;
            width: 24px; height: 24px; border: 1px solid var(--border-color); 
            background: var(--bg-input); border-radius: 3px; cursor: pointer;
            display: grid; place-content: center; margin: 0;
            flex-shrink: 0;
        }
        input[type="checkbox"]::before {
            content: ""; width: 10px; height: 10px; transform: scale(0);
            background-color: var(--accent-main); transform-origin: center;
            transition: 120ms transform ease-in-out; 
            clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
        }
        input[type="checkbox"]:checked::before { transform: scale(1); }
        input[type="checkbox"]:checked { border-color: var(--accent-main); }
        .checkbox-label { font-size: 1.2rem; color: var(--text-muted); user-select: none; font-weight: 600; }

        /* Input avec label flottant doré */
        .input-floating-group {
            position: relative;
            margin-bottom: 0;
        }
        
        .input-floating {
            width: 100%;
            padding: 12px 14px;
            border-radius: var(--radius);
            border: 2px solid var(--accent-main);
            background: var(--bg-input);
            color: var(--text-main);
            font-size: 15px;
            font-family: var(--font-body);
            transition: all 0.3s;
            margin-bottom: 0;
            height: 48px;
            box-sizing: border-box;
        }
        
        .input-floating:focus {
            outline: none;
            border-color: var(--accent-hover);
            box-shadow: 0 0 8px rgba(194, 163, 112, 0.3);
        }
        
        .label-floating {
            position: absolute;
            left: 12px;
            top: -10px;
            background: var(--bg-panel);
            padding: 0 6px;
            color: var(--accent-main);
            font-size: 0.75rem;
            font-weight: 700;
            letter-spacing: 1px;
            text-transform: uppercase;
            pointer-events: none;
            transition: all 0.3s;
        }
        
        .label-floating-small {
            display: block;
            color: var(--accent-main);
            font-size: 0.7rem;
            font-weight: 700;
            letter-spacing: 1px;
            text-transform: uppercase;
            margin-bottom: 4px;
            text-align: center;
        }
        
        /* Label au-dessus des champs */
        .input-label-top {
            display: block;
            color: var(--accent-main);
            font-size: 0.75rem;
            font-weight: 700;
            letter-spacing: 1px;
            text-transform: uppercase;
            margin-bottom: 8px;
            font-family: var(--font-heading);
        }
        
        /* Bouton toggle spectateur avec SVG */
        .spectator-btn {
            width: 48px;
            height: 48px;
            background: var(--bg-input);
            border: 1px solid var(--border-color);
            border-radius: var(--radius);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.2s;
            color: var(--text-muted);
        }
        
        .spectator-btn:hover {
            border-color: var(--text-main);
            color: var(--text-main);
        }
        
        .spectator-btn.active {
            border-color: var(--accent-main);
            color: var(--accent-main);
            background: rgba(194, 163, 112, 0.1);
            box-shadow: 0 0 15px rgba(194, 163, 112, 0.1);
        }
        
        .spectator-btn svg {
            width: 24px;
            height: 24px;
            fill: none;
            stroke: currentColor;
            stroke-width: 2;
            stroke-linecap: round;
            stroke-linejoin: round;
        }

        /* Styles spécifiques pour le layout d'accueil */
        .join-options {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 20px;
            margin-bottom: 0;
            margin-top: 28px;
        }
        
        .join-options .checkbox-wrapper {
            flex: 0 1 auto;
            font-size: 1rem;
            gap: 10px;
        }
        
        .join-options .btn {
            flex: 0 0 auto;
            margin-bottom: 0;
            padding: 14px 24px;
            min-width: 150px;
        }
        
        input[type="text"], input[type="number"] {
            margin-bottom: 20px;
        }
        
        .sep {
            margin: 28px 0;
        }


        /* --- HEADER --- */
        header {
            padding: 0 20px; height: 50px; background: rgba(0,0,0, 0.3);
            backdrop-filter: blur(10px);
            border-bottom: 1px solid var(--border-color); display: flex;
            justify-content: space-between; align-items: center;
            position: sticky; top: 0; z-index: 100;
            transition: border-color var(--transition-speed);
            gap: 10px;
        }
        .brand { font-family: var(--font-heading); font-weight: 700; font-size: 1.2rem; color: var(--text-main); white-space: nowrap; }
        
        /* Par défaut, cacher le brand et montrer le world indicator (sauf sur home) */
        #header-brand { display: none; }
        #header-world-badge { display: flex !important; visibility: visible; }
        
        /* Sur home seulement, montrer le brand et cacher le world indicator */
        #app-header.in-home #header-brand { display: block; }
        #app-header.in-home #header-world-badge { display: none !important; }
        
        .header-info-group {
            display: flex;
            align-items: center;
            gap: 12px;
            flex-wrap: wrap;
            justify-content: flex-end;
            flex: 1;
        }

        .user-display-inline {
            font-size: 1rem;
            font-weight: 600; 
            color: var(--text-main);
            border-right: 1px solid var(--border-color);
            padding-right: 12px;
            font-family: var(--font-heading);
        }
        
        .header-avatar-mini {
            width: 32px; height: 32px; border-radius: 50%;
            background: var(--bg-panel); border: 1px solid var(--border-color);
            overflow: hidden; flex-shrink: 0;
            background-size: cover; background-position: center; background-repeat: no-repeat;
            transition: all var(--transition-speed);
        }
        
        /* Appliquer les images au mini-avatar selon le thème */
        .theme-celestars .header-avatar-mini[data-perso="1"] { background-image: url('images_personnages/perso_1.png'); }
        .theme-celestars .header-avatar-mini[data-perso="2"] { background-image: url('images_personnages/perso_2.png'); }
        .theme-celestars .header-avatar-mini[data-perso="3"] { background-image: url('images_personnages/perso_3.png'); }
        .theme-celestars .header-avatar-mini[data-perso="4"] { background-image: url('images_personnages/perso_4.png'); }
        .theme-celestars .header-avatar-mini[data-perso="5"] { background-image: url('images_personnages/perso_5.png'); }
        .theme-celestars .header-avatar-mini[data-perso="6"] { background-image: url('images_personnages/perso_6.png'); }
        .theme-celestars .header-avatar-mini[data-perso="7"] { background-image: url('images_personnages/perso_7.png'); }
        .theme-celestars .header-avatar-mini[data-perso="8"] { background-image: url('images_personnages/perso_8.png'); }
        .theme-celestars .header-avatar-mini[data-perso="9"] { background-image: url('images_personnages/perso_9.png'); }
        
        .theme-lignees .header-avatar-mini[data-perso="1"] { background-image: url('images_personnages/perso_1_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="2"] { background-image: url('images_personnages/perso_2_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="3"] { background-image: url('images_personnages/perso_3_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="4"] { background-image: url('images_personnages/perso_4_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="5"] { background-image: url('images_personnages/perso_5_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="6"] { background-image: url('images_personnages/perso_6_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="7"] { background-image: url('images_personnages/perso_7_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="8"] { background-image: url('images_personnages/perso_8_sombre.png'); }
        .theme-lignees .header-avatar-mini[data-perso="9"] { background-image: url('images_personnages/perso_9_sombre.png'); }

        .room-badge { 
            background: var(--bg-input); border: 1px solid var(--border-color);
            padding: 4px 10px; border-radius: var(--radius); 
            font-family: monospace; color: var(--accent-main); font-size: 0.9rem;
            transition: all var(--transition-speed);
            letter-spacing: 1px;
            cursor: pointer;
        }
        .room-badge:hover {
            background: var(--accent-main);
            color: var(--bg-world);
            box-shadow: 0 0 8px rgba(194, 163, 112, 0.3);
        }

        .btn-mini {
            padding: 0; font-size: 0.8rem; margin: 0; height: 28px; width: 28px;
            border: 1px solid var(--border-color); background: transparent; color: var(--text-muted);
            border-radius: var(--radius); cursor: pointer;
            transition: all 0.2s; display: flex; align-items: center; justify-content: center;
        }
        .btn-mini:hover,
        .btn-mini:active {
            color: var(--text-main);
            background: var(--accent-main) !important;
            transform: scale(1.1);
            box-shadow: 0 0 8px rgba(194, 163, 112, 0.4);
        }
        .btn-mini:active {
            transform: scale(0.95);
        }

        /* Masquer le header complet sur lobby */
        body.view-lobby #app-header {
            display: none !important;
        }
        
        /* Row pour le bandeau + croix sur lobby */
        .lobby-header-row {
            position: relative;
            padding: 0;
        }
        
        .lobby-header-row .room-banner {
            width: 100%;
            margin: 0;
        }
        
        .lobby-close-btn {
            position: absolute;
            top: 5px;
            right: 8px;
            width: 28px !important;
            height: 28px !important;
            font-size: 0.9rem !important;
            background: rgba(0, 0, 0, 0.5) !important;
            border: 1px solid var(--border-color) !important;
            z-index: 100;
            transition: all 0.2s ease;
            cursor: pointer;
            -webkit-tap-highlight-color: transparent;
        }
        
        .lobby-close-btn:hover,
        .lobby-close-btn:active {
            background: var(--accent-main) !important;
            transform: scale(1.1);
            box-shadow: 0 0 8px rgba(194, 163, 112, 0.4);
        }
        
        .lobby-close-btn:active {
            transform: scale(0.95);
        }

        /* --- VIEWS --- */
        .screen { animation: fadeUp 0.4s ease-out; }
        @keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

        /* PANEL */
        .panel {
            background: var(--bg-panel); border: 1px solid var(--border-color); padding: var(--space-xl) var(--space-lg);
            border-radius: 6px; box-shadow: 0 10px 30px rgba(0,0,0,0.5); position: relative;
            transition: background var(--transition-speed), border-color var(--transition-speed);
            min-height: auto;
        }
        .panel.disabled {
            opacity: 0.5;
            pointer-events: none;
            cursor: not-allowed;
        }
        .panel::after {
            content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
            background: linear-gradient(90deg, transparent, var(--accent-main), transparent); opacity: 0.5;
            transition: background var(--transition-speed);
        }

        /* WORLD TOGGLE SWITCH - COMPACT */
        .world-toggle-container {
            display: flex; align-items: center; justify-content: space-between;
            padding: 0 0 20px 0; border-bottom: 2px solid var(--border-color); 
            margin-bottom: 25px; gap: 20px;
        }
        
        .switch-wrapper {
            display: flex; align-items: center; cursor: pointer;
            background: var(--bg-input); border: 2px solid var(--border-color);
            border-radius: 24px; padding: 3px; position: relative;
            height: 40px; width: 160px; transition: all 0.3s;
        }
        .switch-wrapper:hover { border-color: var(--accent-main); }
        
        .switch-label {
            flex: 1; text-align: center; z-index: 2; font-size: 0.65rem; font-weight: bold;
            font-family: var(--font-heading); color: var(--text-muted); transition: color 0.3s;
            text-transform: uppercase; line-height: 1;
        }
        .switch-label.active { color: var(--bg-world); }
        
        .switch-bg {
            position: absolute; top: 3px; bottom: 3px; width: 50%;
            background: var(--accent-main); border-radius: 20px;
            transition: left 0.3s cubic-bezier(0.4, 0.0, 0.2, 1);
            z-index: 1;
        }
        .switch-wrapper[data-world="celestars"] .switch-bg { left: 3px; }
        .switch-wrapper[data-world="lignees"] .switch-bg { left: calc(50% - 3px); }
        
        .switch-wrapper[data-world="celestars"] .lbl-left { color: var(--bg-world); }
        .switch-wrapper[data-world="lignees"] .lbl-right { color: var(--bg-world); }

        /* ROSTER */
        .roster-grid {
            display: grid; grid-template-columns: repeat(auto-fill, minmax(var(--roster-min-width), 1fr));
            gap: var(--gap-ratio); margin: var(--space-xl) 0;
        }
        .player-card {
            background: var(--bg-input); padding: var(--card-padding-ratio); border-radius: var(--radius);
            text-align: center; border: 1px solid var(--border-color); position: relative; 
            transition: all var(--transition-speed);
            overflow: hidden;
        }
        .player-card.has-voted { border-color: var(--success); background: rgba(64, 192, 87, 0.05); }
        .player-card.is-me { border-color: var(--accent-main); cursor: pointer; }
        .player-card.is-spectator { opacity: 0.7; border-style: dashed; }
        
        .avatar { 
            width: 85%; 
            aspect-ratio: 1 / 1;
            max-width: 120px;
            border-radius: 4px; 
            margin: 0 auto 10px; 
            background: var(--bg-panel); border: 1px solid var(--border-color); overflow: visible; 
            display: block;
            transition: all var(--transition-speed); position: relative;
            flex-shrink: 0;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
        }
        .avatar svg, .avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
        .avatar-img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; max-width: 100% !important; max-height: 100% !important; }
        
        /* Images de personnages selon le thème */
        .theme-celestars .avatar[data-perso="1"] { background-image: url('images_personnages/perso_1.png'); }
        .theme-celestars .avatar[data-perso="2"] { background-image: url('images_personnages/perso_2.png'); }
        .theme-celestars .avatar[data-perso="3"] { background-image: url('images_personnages/perso_3.png'); }
        .theme-celestars .avatar[data-perso="4"] { background-image: url('images_personnages/perso_4.png'); }
        .theme-celestars .avatar[data-perso="5"] { background-image: url('images_personnages/perso_5.png'); }
        .theme-celestars .avatar[data-perso="6"] { background-image: url('images_personnages/perso_6.png'); }
        .theme-celestars .avatar[data-perso="7"] { background-image: url('images_personnages/perso_7.png'); }
        .theme-celestars .avatar[data-perso="8"] { background-image: url('images_personnages/perso_8.png'); }
        .theme-celestars .avatar[data-perso="9"] { background-image: url('images_personnages/perso_9.png'); }
        
        .theme-lignees .avatar[data-perso="1"] { background-image: url('images_personnages/perso_1_sombre.png'); }
        .theme-lignees .avatar[data-perso="2"] { background-image: url('images_personnages/perso_2_sombre.png'); }
        .theme-lignees .avatar[data-perso="3"] { background-image: url('images_personnages/perso_3_sombre.png'); }
        .theme-lignees .avatar[data-perso="4"] { background-image: url('images_personnages/perso_4_sombre.png'); }
        .theme-lignees .avatar[data-perso="5"] { background-image: url('images_personnages/perso_5_sombre.png'); }
        .theme-lignees .avatar[data-perso="6"] { background-image: url('images_personnages/perso_6_sombre.png'); }
        .theme-lignees .avatar[data-perso="7"] { background-image: url('images_personnages/perso_7_sombre.png'); }
        .theme-lignees .avatar[data-perso="8"] { background-image: url('images_personnages/perso_8_sombre.png'); }
        .theme-lignees .avatar[data-perso="9"] { background-image: url('images_personnages/perso_9_sombre.png'); }
        .player-name { font-size: 0.85rem; color: var(--text-main); font-weight: 600; overflow: hidden; text-overflow: ellipsis; font-family: var(--font-heading); }
        
        .status-badge {
            position: absolute; top: 5px; right: 5px; width: 10px; height: 10px; 
            border-radius: 50%; background: #333; transition: background 0.3s;
        }
        .player-card.has-voted .status-badge { background: var(--success); box-shadow: 0 0 5px var(--success); }
        
        .spectator-icon {
            position: absolute; bottom: -5px; right: -5px;
            background: var(--bg-panel); border: 1px solid var(--border-color);
            border-radius: 50%; padding: 2px; font-size: 12px;
        }
        
        /* Badge d'édition pour mon profil */
        .edit-badge {
            position: absolute; top: 5px; left: 5px;
            background: var(--accent-main); color: var(--bg-world);
            width: 20px; height: 20px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 12px; opacity: 0.7; transition: opacity 0.2s, transform 0.2s;
            z-index: 2; box-shadow: 0 2px 5px rgba(0,0,0,0.5);
            cursor: pointer;
            transform: scaleX(-1);
        }
        .player-card.is-me .edit-badge { opacity: 0.7; }
        .player-card.is-me:hover { transform: translateY(-3px); }
        .player-card.is-me:hover .edit-badge { opacity: 1; transform: scaleX(-1) scale(1.1); }

        /* Badge Hôte Médaillon (Bas Centre Avatar) */
        .host-badge-medallion {
            position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%);
            background: var(--bg-panel); border: 1px solid var(--accent-main); color: var(--accent-main);
            width: 20px; height: 20px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 12px; z-index: 3; box-shadow: 0 2px 4px rgba(0,0,0,0.8);
        }

        /* VOTING UI */
        .vote-section { 
            background: var(--bg-panel); border: 1px solid var(--border-color);
            padding: var(--vote-padding); border-radius: 6px; margin-bottom: var(--space-md); text-align: center;
            transition: all var(--transition-speed);
        }
        .vote-title { 
            margin-bottom: var(--space-xs); color: var(--accent-main); text-transform: uppercase; 
            font-family: var(--font-heading); font-size: var(--vote-title-size); letter-spacing: 1px;
        }
        
        /* STANDARD VOTE BUTTONS */
        .standard-options { display: flex; flex-direction: column; gap: var(--vote-gap); }
        .btn-vote {
            padding: 0.75rem; font-size: var(--font-base); border-radius: var(--radius);
            border: 2px solid var(--border-color); background: var(--bg-input); color: var(--text-muted);
            cursor: pointer; transition: all 0.2s; font-family: var(--font-heading); font-weight: bold;
            display: flex; align-items: center; justify-content: center; gap: var(--space-sm);
        }
        .btn-vote:hover { transform: translateY(-2px); }
        
        .btn-vote.pour:hover, .btn-vote.pour.selected { border-color: var(--vote-pour); color: var(--vote-pour); background: rgba(47, 158, 68, 0.1); }
        .btn-vote.contre:hover, .btn-vote.contre.selected { border-color: var(--vote-contre); color: var(--vote-contre); background: rgba(224, 49, 49, 0.1); }
        .btn-vote.abs:hover, .btn-vote.abs.selected { border-color: var(--vote-abs); color: var(--vote-abs); background: rgba(134, 142, 150, 0.1); }
        
        .btn-vote.selected { box-shadow: 0 0 15px rgba(0,0,0,0.5); transform: scale(1.02); border-width: 2px; }

        /* IDL SLIDERS */
        .idl-row { 
            margin-bottom: var(--vote-gap); display: flex; align-items: center; gap: 0.75rem;
            background: var(--bg-input); padding: var(--vote-gap); border-radius: 4px; 
            border: 1px solid var(--border-color); transition: all var(--transition-speed);
        }
        .idl-label-inline {
            font-weight: bold; color: var(--accent-main); font-family: var(--font-heading);
            font-size: 1.1rem; min-width: 1.5rem; text-align: center;
        }
        .idl-row input[type="range"] { flex: 1; }
        .idl-val-inline {
            font-weight: bold; color: var(--text-main); font-family: var(--font-heading);
            font-size: 1.1rem; min-width: 1.5rem; text-align: center;
        }
        .idl-label { display: flex; justify-content: space-between; margin-bottom: 6px; font-family: var(--font-body); color: var(--text-muted); font-size: 0.8rem; }
        .idl-val { color: var(--accent-main); font-weight: bold; font-family: var(--font-heading); font-size: 1.1rem; }
        
        input[type="range"] { width: 100%; -webkit-appearance: none; background: transparent; }
        input[type="range"]::-webkit-slider-thumb {
            -webkit-appearance: none; height: 20px; width: 20px; background: var(--accent-main); 
            border-radius: 2px; cursor: pointer; margin-top: -8px; transition: transform 0.1s;
        }
        input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.2); }
        input[type="range"]::-webkit-slider-runnable-track {
            width: 100%; height: 4px; cursor: pointer; background: var(--border-color); border-radius: 2px;
        }

        /* RESULTS */
        /* RESULTS STYLING */
        .results-glass-panel {
            background: var(--bg-panel);
            backdrop-filter: blur(8px);
            border: 1px solid var(--border-color);
            border-radius: 8px;
            padding: 20px;
            margin-bottom: 20px;
            box-shadow: 0 8px 32px rgba(0,0,0,0.5);
        }

        .verdict-container {
            text-align: center; margin-bottom: 25px;
            animation: fadeIn 0.5s ease-out;
        }
        .verdict-title {
            font-size: 2.2rem; font-family: var(--font-heading); font-weight: bold;
            margin-bottom: 15px; letter-spacing: 2px; text-shadow: 0 2px 10px rgba(0,0,0,0.5);
            text-align: center;
        }
        .verdict-sub { font-size: 0.9rem; color: var(--text-muted); }

        .consensus-gauge {
            height: 12px; background: #222; border-radius: 6px; overflow: hidden;
            display: flex; margin-bottom: 25px; border: 1px solid var(--border-color);
        }
        .gauge-part { height: 100%; transition: width 1s ease-in-out; }

        .result-cards-row {
            display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
        }
        .result-card-mini {
            background: rgba(15, 15, 20, 0.85); border: 1px solid var(--border-color);
            border-radius: var(--radius); padding: 15px 5px; text-align: center;
            position: relative; overflow: hidden; display: flex; flex-direction: column; align-items: center; justify-content: center;
        }
        .result-card-mini::before {
            content:''; position: absolute; top:0; left:0; width: 4px; height: 100%;
            background: currentColor; opacity: 0.8;
        }
        .rc-val { font-size: 1.5rem; font-weight: bold; font-family: var(--font-heading); margin-bottom: 4px; }
        .rc-label { font-size: 0.75rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }

        .color-pour { color: var(--vote-pour); }
        .color-contre { color: var(--vote-contre); }
        .color-abs { color: var(--vote-abs); }

        /* Stats IDL cards */
        .stat-card {
            background: var(--bg-input); padding: 15px; margin-bottom: 10px; border-radius: 4px; 
            display: flex; justify-content: space-between; align-items: center; border-left: 3px solid var(--accent-main);
            transition: all var(--transition-speed);
            border: 1px solid var(--border-color);
            border-left: 3px solid var(--accent-main);
        }
        .score-box {
            text-align: center; margin-top: 20px; padding: 15px; background: var(--bg-input); 
            border: 1px solid var(--accent-main); border-radius: 4px;
        }

        /* NEXT ACTIONS STYLING */
        .next-actions-sep {
            display: flex; align-items: center; gap: 15px; margin: 30px 0 20px;
        }
        .next-actions-sep::before, .next-actions-sep::after {
            content: ''; height: 1px; background: var(--border-color); flex: 1;
        }
        .next-actions-text {
            font-family: var(--font-heading); color: var(--accent-main); 
            text-transform: uppercase; letter-spacing: 2px; font-weight: bold; font-size: 0.9rem;
        }
        .next-actions-grid {
            display: grid; grid-template-columns: 1fr 1fr; gap: 15px;
        }
        .next-actions-grid .btn {
            height: auto; padding: 20px 10px; margin-bottom: 0;
            display: flex; flex-direction: column; align-items: center; justify-content: center;
            gap: 8px; font-size: 0.9rem;
            transition: border-color 0.3s ease, box-shadow 0.3s ease, color 0.3s ease;
        }
        .next-actions-grid .btn:hover {
            background: linear-gradient(180deg, rgba(194, 163, 112, 0.15) 0%, rgba(194, 163, 112, 0.15) 100%), linear-gradient(180deg, #373a40 0%, #25262b 100%);
            border-color: var(--accent-main);
            color: var(--accent-main);
            box-shadow: 0 4px 15px rgba(194, 163, 112, 0.2);
            transform: translateY(-2px);
        }
        .next-actions-grid .btn:active {
            background: linear-gradient(180deg, rgba(194, 163, 112, 0.15) 0%, rgba(194, 163, 112, 0.15) 100%), linear-gradient(180deg, #373a40 0%, #25262b 100%);
            border-color: var(--accent-main);
            color: var(--accent-main);
            box-shadow: 0 4px 15px rgba(194, 163, 112, 0.2);
            transform: translateY(-2px);
        }
        .next-actions-grid .btn.disabled {
            opacity: 0.5;
            cursor: not-allowed;
            pointer-events: none;
        }
        
        /* Host controls disabled pour non-hôtes */
        #host-controls.disabled {
            opacity: 0.6;
        }
        #host-controls.disabled .btn {
            pointer-events: none;
            cursor: not-allowed;
            opacity: 0.7;
        }
        #host-controls.disabled .next-actions-text {
            opacity: 0.7;
        }
        
        /* Médaillon non-hôte (visible mais non cliquable, aspect grisé) */
        .world-medallion:not(.is-host) {
            opacity: 0.5;
            cursor: not-allowed;
            filter: grayscale(30%);
        }
        
        .btn-icon { font-size: 1.5rem; display: block; line-height: 1; color: var(--accent-main); }

        /* SESSION INFO FOOTER */
        .session-footer {
            margin-top: 30px; 
            border-top: 1px solid var(--border-color);
            padding-top: 20px;
            display: flex; align-items: center; justify-content: space-between;
            gap: 15px; animation: fadeIn 0.5s ease-out;
        }
        
        /* World Info Block */
        .current-world-info {
            display: flex; align-items: center; gap: 12px;
            background: var(--bg-input); border: 1px solid var(--border-color);
            padding: 10px 15px; border-radius: var(--radius); flex: 1;
            transition: all 0.3s;
        }
        .footer-icon { font-size: 1.8rem; }
        .footer-title { font-family: var(--font-heading); color: var(--accent-main); font-weight: bold; font-size: 0.9rem; text-transform: uppercase; margin-bottom: 2px; }
        .footer-desc { color: var(--text-muted); font-size: 0.7rem; font-style: italic; }

        /* Room Code Box (Styled like a Stone Tablet) */
        .session-code-box {
            background: linear-gradient(145deg, #2a2a30, #1f1f24);
            border: 2px solid var(--border-color);
            border-radius: var(--radius);
            padding: 8px 20px; text-align: center;
            cursor: pointer; transition: all 0.2s;
            box-shadow: inset 0 2px 5px rgba(0,0,0,0.5);
            min-width: 100px; display: flex; flex-direction: column; justify-content: center;
        }
        .session-code-box:hover {
            border-color: var(--accent-main);
            box-shadow: inset 0 2px 5px rgba(0,0,0,0.5), 0 0 10px rgba(194, 163, 112, 0.3);
        }
        .session-code-box:active { transform: scale(0.95); }
        .code-label { font-size: 0.65rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 2px; }

        /* WORLD MEDALLION */
        .world-artifact-container {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 25px 0 15px 0;
            position: relative;
            perspective: 800px;
        }
        
        .world-medallion {
            width: 90px;
            height: 90px;
            min-width: 90px;
            min-height: 90px;
            border-radius: 50%;
            background: radial-gradient(circle at 30% 30%, var(--bg-panel), #080808);
            border: 3px solid var(--accent-main);
            box-shadow: 0 0 25px rgba(0,0,0,0.8), 0 0 10px var(--accent-main);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 2.5rem;
            position: relative;
            z-index: 2;
            transform-style: preserve-3d;
        }
        
        .medallion-content {
            display: block;
            backface-visibility: hidden;
            -webkit-backface-visibility: hidden;
        }
        
        .world-medallion.is-host {
            cursor: pointer;
        }
        
        .world-medallion.is-host:hover {
            box-shadow: 0 0 30px var(--accent-main);
        }
        
        .world-medallion.is-host:active {
            transform: scale(0.95);
        }
        
        .world-medallion.flipping {
            animation: magicFlip 0.7s ease-in-out forwards;
        }
        
        .world-medallion.flipping .medallion-content {
            animation: hideEmoji 0.7s ease-in-out forwards;
        }
        
        @keyframes magicFlip {
            0% { transform: rotateY(0deg) scale(1); }
            50% { transform: rotateY(90deg) scale(1); }
            100% { transform: rotateY(0deg) scale(1); }
        }
        
        @keyframes hideEmoji {
            0% { opacity: 1; }
            45% { opacity: 0; }
            55% { opacity: 0; }
            100% { opacity: 1; }
        }
        
        .world-name-label {
            margin-top: 15px;
            font-family: var(--font-heading);
            font-size: 1.2rem;
            font-weight: bold;
            color: var(--accent-main);
            text-transform: uppercase;
            letter-spacing: 2px;
            text-shadow: 0 2px 10px rgba(0,0,0,0.5);
            transition: color var(--transition-speed);
        }
        
        .world-hint {
            font-size: 0.75rem;
            color: var(--text-muted);
            margin-top: 5px;
            font-style: italic;
        }

        /* ROOM CODE BANNER */
        .room-banner {
            text-align: center;
            margin: 0;
            background: linear-gradient(90deg, transparent, rgba(0,0,0,0.4), transparent);
            padding: 8px;
            border-bottom: 1px solid var(--border-color);
            transition: all 0.2s;
        }
        .room-banner:hover {
            background: linear-gradient(90deg, transparent, rgba(0,0,0,0.6), transparent);
            border-bottom-color: var(--accent-main);
        }
        .room-banner-label {
            font-size: 0.65rem;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 2px;
        }
        .room-banner-code {
            font-family: var(--font-heading);
            font-size: 1.4rem;
            font-weight: bold;
            color: var(--text-main);
            letter-spacing: 3px;
            transition: color 0.2s;
        }
        .room-banner:hover .room-banner-code {
            color: var(--accent-main);
        }
        .code-val { font-family: var(--font-heading); font-size: 1.4rem; color: var(--text-main); font-weight: bold; letter-spacing: 2px; }

        /* MODAL QUIT */
        .modal-quit-content {
            width: 90%;
            max-width: 400px;
            text-align: center;
        }
        .modal-quit-content > div {
            display: flex;
            gap: 10px;
            align-items: center;
        }
        .modal-quit-content .btn {
            flex: 1;
            margin-bottom: 0 !important;
            padding: 14px 20px !important;
            height: 48px;
            display: flex;
            align-items: center;
            justify-content: center;
            box-sizing: border-box;
        }
        @media (min-width: 768px) {
            .modal-quit-content {
                width: auto;
                min-width: 450px;
                padding: 30px 40px;
                min-height: auto !important;
            }
            .modal-quit-content h3 {
                font-size: 1.6rem !important;
                margin-bottom: 15px !important;
            }
            .modal-quit-content p {
                font-size: 1.1rem !important;
                margin-bottom: 25px !important;
            }
            .modal-quit-content .btn {
                font-size: 1.1rem;
                padding: 16px 24px !important;
                height: 56px;
            }
        }

        /* TOAST */
        #toast {
            position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%);
            background: var(--bg-panel); border: 1px solid var(--accent-main); color: var(--text-main);
            padding: 12px 24px; border-radius: 4px; font-family: var(--font-body); font-weight: 500;
            opacity: 0; pointer-events: none; transition: opacity 0.3s, transform 0.3s;
            box-shadow: 0 4px 15px rgba(0,0,0,0.5); z-index: 200;
        }
        #toast.show { opacity: 1; transform: translateX(-50%) translateY(-10px); }

        .sep { display: flex; align-items: center; gap: 15px; margin: 25px 0; }
        .sep-line { height: 1px; background: var(--border-color); flex: 1; transition: background var(--transition-speed); }
        .sep-text { color: var(--text-muted); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; }

        /* Header World Indicator */
        .world-indicator {
            font-size: 0.8rem; text-transform: uppercase; letter-spacing: 1px;
            color: var(--accent-main); border: 1px solid var(--border-color);
            padding: 4px 8px; border-radius: 4px; margin-left: 10px;
            display: inline-flex; align-items: center; gap: 5px;
            background: var(--bg-input);
        }
        
        /* AVATAR SELECTOR MODAL */
        .modal-overlay {
            position: fixed; top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0, 0, 0, 0.7); z-index: 1000;
            display: flex; align-items: center; justify-content: center;
            backdrop-filter: blur(5px); animation: fadeIn 0.2s;
        }
        .modal-content {
            width: 90%; max-width: 450px; text-align: center;
            border: 2px solid var(--accent-main); background: var(--bg-panel);
            max-height: 90vh; display: flex; flex-direction: column;
            padding: 20px; border-radius: var(--radius);
        }
        
        .avatar-grid {
            display: grid; grid-template-columns: repeat(3, 1fr);
            gap: 15px; padding: 10px 0;
        }
        .avatar-option {
            aspect-ratio: 1; border: 2px solid var(--border-color);
            border-radius: 4px; cursor: pointer; opacity: 0.7;
            transition: all 0.3s;
            background-size: cover; background-position: center;
            background-repeat: no-repeat;
        }
        .avatar-option:hover {
            opacity: 1; transform: scale(1.05);
        }
        .avatar-option.selected {
            border-color: var(--accent-main); opacity: 1;
            box-shadow: 0 0 10px rgba(194, 163, 112, 0.3);
        }
        
        /* Images des options d'avatar selon le thème */
        .theme-celestars .avatar-option[data-perso="1"] { background-image: url('images_personnages/perso_1.png'); }
        .theme-celestars .avatar-option[data-perso="2"] { background-image: url('images_personnages/perso_2.png'); }
        .theme-celestars .avatar-option[data-perso="3"] { background-image: url('images_personnages/perso_3.png'); }
        .theme-celestars .avatar-option[data-perso="4"] { background-image: url('images_personnages/perso_4.png'); }
        .theme-celestars .avatar-option[data-perso="5"] { background-image: url('images_personnages/perso_5.png'); }
        .theme-celestars .avatar-option[data-perso="6"] { background-image: url('images_personnages/perso_6.png'); }
        .theme-celestars .avatar-option[data-perso="7"] { background-image: url('images_personnages/perso_7.png'); }
        .theme-celestars .avatar-option[data-perso="8"] { background-image: url('images_personnages/perso_8.png'); }
        .theme-celestars .avatar-option[data-perso="9"] { background-image: url('images_personnages/perso_9.png'); }
        
        .theme-lignees .avatar-option[data-perso="1"] { background-image: url('images_personnages/perso_1_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="2"] { background-image: url('images_personnages/perso_2_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="3"] { background-image: url('images_personnages/perso_3_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="4"] { background-image: url('images_personnages/perso_4_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="5"] { background-image: url('images_personnages/perso_5_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="6"] { background-image: url('images_personnages/perso_6_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="7"] { background-image: url('images_personnages/perso_7_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="8"] { background-image: url('images_personnages/perso_8_sombre.png'); }
        .theme-lignees .avatar-option[data-perso="9"] { background-image: url('images_personnages/perso_9_sombre.png'); }

        /* =====================================================
           RESPONSIVE DESIGN - MOBILE FIRST
           ===================================================== */

        /* PETIT MOBILE (< 480px) */
        @media (max-width: 479px) {
            * {
                -webkit-tap-highlight-color: transparent;
            }
            
            .container { 
                padding: 15px; 
                margin-top: 20px;
            }
            
            .hero { margin: 30px 0 25px 0; }
            .hero h1 { font-size: 2.2rem; margin-bottom: 8px; letter-spacing: 1px; }
            .hero p { font-size: 1rem; }
            
            .world-indicator {
                padding: 3px 5px;
                font-size: 0.65rem;
            }
            #header-world-icon { font-size: 1.2rem; }
            
            header { padding: 0 10px; height: 40px; gap: 6px; }
            .brand { font-size: 0.9rem; }
            
            .header-info-group { gap: 6px; }
            .user-display-inline { font-size: 0.8rem; padding-right: 6px; border-right: 1px solid var(--border-color); max-width: 110px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
            .room-badge { font-size: 0.72rem; padding: 5px 8px; min-width: 50px; height: 28px; display: flex; align-items: center; justify-content: center; }
            
            .btn-mini { padding: 0; font-size: 0.8rem; height: 28px; width: 28px; display: flex; align-items: center; justify-content: center; }
            
            /* Réduire le bouton spectateur sur mobile */
            .spectator-btn {
                width: 42px;
                height: 42px;
            }
            .spectator-btn svg {
                width: 20px;
                height: 20px;
            }
            .input-label {
                font-size: 0.6rem;
            }
            /* Ajuster l'input flottant sur mobile */
            .input-floating {
                height: 42px;
                padding: 12px 10px;
                font-size: 14px;
            }
            .label-floating {
                font-size: 0.65rem;
                top: -8px;
            }
            
            h1, h2 { font-size: 1.3rem; }
            h3 { font-size: 1rem; }
            
            .panel { padding: 12px 10px; min-height: auto; border-radius: 3px; }
            .panel::after { height: 1px; }
            
            /* Zone identité */
            .panel > div:first-child {
                margin-bottom: 8px;
            }
            .panel > div:first-child label {
                margin-bottom: 4px;
                font-size: 0.7rem;
            }
            
            input[type="text"], input[type="number"] {
                padding: 8px;
                font-size: 16px;
                margin-bottom: 8px;
                border-radius: 2px;
            }
            
            .panel .btn:first-of-type {
                padding: 9px 12px;
                font-size: 0.8rem;
                margin-bottom: 8px;
            }
            
            .sep {
                margin: 8px 0;
                gap: 8px;
            }
            .sep-line { height: 1px; }
            .sep-text { font-size: 0.6rem; }
            
            .join-options {
                flex-direction: column;
                align-items: stretch;
                gap: 12px;
                margin-top: 6px;
            }
            .join-options .checkbox-wrapper {
                justify-content: center;
                gap: 10px;
            }
            .checkbox-label { font-size: 0.85rem; font-weight: 500; }
            input[type="checkbox"] { width: 16px; height: 16px; }
            
            .join-options .btn {
                padding: 9px 14px;
                font-size: 0.8rem;
                min-width: auto;
                margin-bottom: 0;
            }
            
            .world-toggle-container { padding: 0 0 10px 0; margin-bottom: 15px; }
            .world-toggle-container > span { font-size: 0.75rem !important; }
            .switch-wrapper { width: 140px; height: 34px; }
            .switch-label { font-size: 0.55rem; line-height: 1; }
            
            /* Lobby title mobile */
            #lobby-title { font-size: 1.6rem !important; letter-spacing: 1px !important; }
            #view-lobby > div:first-child p { font-size: 0.85rem !important; }
            #view-lobby > div:first-child { margin-bottom: 5px !important; }
            
            /* Host controls panel mobile */
            #host-controls { padding: 10px 12px !important; margin-top: 0 !important; }
            #host-controls p { font-size: 0.85rem !important; margin-bottom: 12px !important; }
            #host-controls .btn { font-size: 0.85rem !important; padding: 12px !important; }
            
            /* Session footer mobile - sur la même ligne */
            .session-footer { margin-top: 20px; padding-top: 15px; gap: 10px; flex-direction: row; }
            .current-world-info { padding: 8px 10px; flex: 1; }
            .footer-icon { font-size: 1.3rem; }
            .footer-title { font-size: 0.7rem; }
            .footer-desc { font-size: 0.6rem; }
            .session-code-box { padding: 6px 12px; min-width: 70px; flex: 0 0 auto; }
            .code-label { font-size: 0.55rem; }
            .code-val { font-size: 1rem; letter-spacing: 1px; }
            
            .roster-grid {
                grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
                gap: 10px;
                margin: 10px 0 0 0;
            }
            
            /* Cartes et avatars sur mobile */
            .player-card {
                padding: 8px 7px !important;
            }
            .avatar {
                width: 100% !important;
                max-width: none !important;
                margin-bottom: 6px !important;
            }
            .player-name {
                font-size: 0.72rem !important;
            }
            
            /* Badge couronne hôte plus petit */
            .host-badge-medallion {
                width: 16px !important;
                height: 16px !important;
                font-size: 10px !important;
                bottom: -8px !important;
            }
            
            /* Badge édition plus petit et mieux placé */
            .edit-badge {
                width: 16px !important;
                height: 16px !important;
                font-size: 10px !important;
                top: 3px !important;
                left: 3px !important;
            }
            
            /* Avatar header plus petit */
            .header-avatar-mini {
                width: 26px !important;
                height: 26px !important;
            }
            
            /* Écran de vote mobile */
            .vote-title {
                font-size: 1.1rem !important;
            }
            #view-vote h3 {
                font-size: 0.75rem !important;
            }
            #roster-vote-list.roster-grid {
                grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)) !important;
                gap: 12px !important;
            }
            #roster-vote-list .player-card {
                padding: 10px 8px !important;
            }
            #roster-vote-list .avatar {
                width: 100% !important;
            }
            
            /* Sliders IDL mobile */
            .vote-section {
                padding: 15px 12px !important;
                margin-bottom: 20px !important;
            }
            #ui-vote-idl .vote-title {
                font-size: 1.25rem !important;
                margin-bottom: 8px !important;
            }
            #ui-vote-idl {
                margin-top: 25px !important;
            }
            .idl-row {
                padding: 10px 8px !important;
                margin-bottom: 16px !important;
                gap: 0.5rem !important;
            }
            .idl-label-inline {
                font-size: 0.95rem !important;
                min-width: 1.2rem !important;
            }
            .idl-val-inline {
                font-size: 0.95rem !important;
                min-width: 1.2rem !important;
            }
            input[type="range"]::-webkit-slider-thumb {
                height: 16px !important;
                width: 16px !important;
                margin-top: -6px !important;
            }
            #ui-vote-idl .btn-action {
                padding: 10px !important;
                font-size: 0.85rem !important;
                margin-top: 18px !important;
            }
            
            /* Boutons next-actions plus petits sur mobile */
            .next-actions-grid .btn {
                padding: 12px 8px !important;
                font-size: 0.8rem !important;
                gap: 6px !important;
            }
            .btn-icon {
                font-size: 1rem !important;
            }
            
            .roster-card { padding: 10px 6px; }
            .player-avatar { width: 35px; height: 35px; font-size: 1.1rem; }
            .player-name { font-size: 0.7rem; }
            .status-badge { width: 8px; height: 8px; top: 3px; right: 3px; }
            
            #view-lobby { padding-top: 0; margin-top: -20px; }
            #view-vote { padding-top: 15px; }
            #view-results { padding-top: 25px; }
            
            .vote-section { padding: 12px 10px; margin-bottom: 12px; }
            .vote-title { font-size: var(--vote-title-size); margin-bottom: 10px; }
            
            .standard-options { gap: 11px; }
            .btn-vote {
                padding: 14px;
                font-size: 0.95rem;
                gap: 8px;
            }
            
            .idl-row { padding: 8px; margin-bottom: 8px; }
            .idl-label { font-size: 0.7rem; }
            .idl-val { font-size: 0.85rem; }
            
            input[type="range"] { height: 6px; }
            
            .verdict-title { font-size: 1.6rem; }
            .verdict-sub { font-size: 0.75rem; }
            
            .consensus-gauge { height: 10px; margin-bottom: 18px; }
            
            .result-cards-row { gap: 6px; }
            .result-card-mini { padding: 10px 3px; }
            .rc-val { font-size: 1.1rem; }
            .rc-label { font-size: 0.65rem; }
            
            .stat-card { padding: 10px; margin-bottom: 6px; font-size: 0.8rem; }
            .score-box { padding: 10px; margin-top: 12px; }
            
            #toast { bottom: 15px; padding: 8px 16px; font-size: 0.8rem; }
        }

        /* MOBILE STANDARD (480px - 768px) */
        @media (min-width: 480px) and (max-width: 768px) {
            * {
                -webkit-tap-highlight-color: transparent;
            }
            
            .container { padding: 18px; max-width: 100%; margin-top: 25px; }
            
            .hero { margin: 35px 0 25px 0; }
            .hero h1 { font-size: 1.7rem; margin-bottom: 3px; letter-spacing: 1px; }
            .hero p { font-size: 0.75rem; }
            
            .world-indicator { padding: 3px 5px; font-size: 0.65rem; }
            #header-world-icon { font-size: 1.2rem; }
            
            header { padding: 0 12px; height: 42px; gap: 8px; }
            .brand { font-size: 0.95rem; }
            
            .header-info-group { gap: 8px; }
            .user-display-inline { font-size: 0.9rem; padding-right: 10px; max-width: 120px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
            .room-badge { font-size: 0.75rem; padding: 5px 8px; min-width: 50px; height: 30px; display: flex; align-items: center; justify-content: center; }
            .btn-mini { padding: 0; font-size: 0.8rem; height: 30px; width: 30px; display: flex; align-items: center; justify-content: center; }
            
            h1, h2 { font-size: 1.5rem; }
            h3 { font-size: 1.1rem; }
            
            .panel { padding: 16px 14px; min-height: auto; border-radius: 3px; }
            
            .btn {
                padding: 10px 15px;
                font-size: 0.85rem;
                margin-bottom: 8px;
            }
            
            input[type="text"], input[type="number"] {
                padding: 10px;
                font-size: 16px;
                margin-bottom: 10px;
            }
            
            .checkbox-wrapper { gap: 6px; }
            input[type="checkbox"] { width: 17px; height: 17px; }
            .checkbox-label { font-size: 0.9rem; }
            
            .join-options {
                flex-direction: row;
                gap: 12px;
                margin-top: 8px;
            }
            
            .sep { margin: 10px 0; }
            .sep-text { font-size: 0.62rem; }
            
            .roster-grid {
                grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
                gap: 10px;
                margin: 10px 0 0 0;
            }
            .player-card { padding: 8px 7px; overflow: hidden; }
            .avatar { margin-bottom: 6px; }
            .player-name { font-size: 0.72rem; }
            
            #view-lobby { padding-top: 0; }
            #view-vote { padding-top: 20px; }
            #view-results { padding-top: 30px; }
            
            .vote-section { padding: 16px 14px; margin-bottom: 15px; }
            .vote-title { font-size: var(--vote-title-size); margin-bottom: 15px; }
            
            .standard-options { gap: 13px; }
            .btn-vote { padding: 17px; font-size: 1.03rem; }
            
            .idl-row { padding: 10px; margin-bottom: 12px; }
            .idl-label { font-size: 0.78rem; }
            
            input[type="range"] { height: 7px; }
            
            .verdict-title { font-size: 1.95rem; }
            .result-cards-row { gap: 8px; }
            .result-card-mini { padding: 12px 4px; }
            .rc-val { font-size: 1.35rem; }
            .rc-label { font-size: 0.71rem; }
        }

        /* TABLETTE & PC (> 768px) */
        @media (min-width: 769px) {
            body { background-attachment: fixed; }
            
            .container { padding: 20px; max-width: 600px; }
            
            .hero { margin: 50px 0 50px 0; }
            .hero h1 { font-size: 3rem; margin-bottom: 12px; }
            .hero p { font-size: 1.15rem; }
            
            header { padding: 0 20px; height: 50px; gap: 12px; }
            .brand { font-size: 1.3rem; }
            
            .header-info-group { gap: 12px; }
            
            h1, h2 { font-size: 2rem; }
            h3 { font-size: 1.3rem; }
            
            .panel { padding: 40px 35px; min-height: 350px; }
            
            .join-options { margin-top: 22px; }
            
            .btn { padding: 14px 20px; font-size: 1rem; }
            
            input[type="text"], input[type="number"] { padding: 14px; font-size: 1rem; }
            
            .roster-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
            .player-card { padding: 15px 10px; }
            .roster-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
            .player-card { padding: 12px 8px; overflow: hidden; }
            .player-name { font-size: 0.9rem; }
            
            .vote-section { padding: 35px 25px; }
            .vote-title { font-size: var(--vote-title-size); margin-bottom: 28px; }
            
            .btn-vote { padding: 20px; font-size: 1.2rem; }
            
            .idl-row { padding: 15px; margin-bottom: 28px; }
            
            .verdict-title { font-size: 2.4rem; margin-bottom: 8px; }
            .result-cards-row { gap: 12px; }
            .result-card-mini { padding: 16px 6px; }
            .rc-val { font-size: 1.6rem; }
        }

        /* GRANDS ÉCRANS (> 1024px) */
        @media (min-width: 1025px) {
            .container { max-width: 800px; padding: 25px; }
            
            .roster-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 16px; }
            .player-card { padding: 16px 12px; }
            .avatar { margin-bottom: 10px; }
            
            .vote-section { padding: 35px 25px; }
            
            .result-cards-row { gap: 15px; }
            .result-card-mini { padding: 18px 8px; }
        }

        /* OPTIMISATIONS TACTILES */
        @media (hover: none) and (pointer: coarse) {
            /* Augmenter les zones cliquables sur mobile */
            .btn { min-height: 48px; }
            .btn-vote { min-height: 50px; }
            .player-card { cursor: pointer; }
            input[type="range"]::-webkit-slider-thumb {
                height: 24px;
                width: 24px;
                margin-top: -10px;
            }
        }

        /* ORIENTATION PAYSAGE MOBILE */
        @media (max-height: 600px) and (orientation: landscape) {
            .container { padding: 10px; }
            header { padding: 0 10px; height: 40px; }
            .btn-mini { padding: 3px 8px; height: 28px; }
            .panel { padding: 15px; }
            .vote-section { padding: 15px; margin-bottom: 15px; }
            .btn-vote { padding: 12px; font-size: 0.95rem; }
        }
