
:root{--bg:#080808;--surface:#141414;--surface2:#1c1c1c;--border:#2a2a2a;--purple:#7c3aed;--purple2:#6d28d9;--purple-light:#a78bfa;--purple-dim:#4c1d95;--text:#f0ede8;--text-muted:#6b6560;--red:#ff3232;--green:#3ddc84;--font-display:'Bebas Neue',sans-serif;--font-body:'Syne',sans-serif;--font-mono:'DM Mono',monospace;}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:0.6;}
nav{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:64px;background:rgba(8,8,8,0.9);backdrop-filter:blur(20px);border-bottom:1px solid rgba(124,58,237,0.2);}
.nav-logo{font-family:var(--font-display);font-size:2rem;letter-spacing:0.1em;background:linear-gradient(135deg,var(--purple),var(--purple-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;}

.nav-links a{color:var(--text-muted);text-decoration:none;font-size:0.8rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;transition:color 0.2s;}
.nav-links a:hover,.nav-links a.active{color:var(--purple-light);}
.nav-back{color:var(--text-muted);background:none;border:none;font-family:var(--font-mono);font-size:0.76rem;cursor:pointer;letter-spacing:0.1em;transition:color 0.2s;display:none;padding:0;}
.nav-back:hover{color:var(--purple-light);}

/* ── SELECTION ── */
#selScreen{padding-top:64px;min-height:100vh;}
.sel-header{text-align:center;padding:56px 40px 44px;border-bottom:1px solid var(--border);}
.sel-eyebrow{font-family:var(--font-mono);font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--purple-light);margin-bottom:10px;}
.sel-label{font-family:var(--font-mono);font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--purple);margin-bottom:10px;display:block;}
.sel-title{font-family:var(--font-display);font-size:clamp(3.5rem,9vw,8rem);letter-spacing:0.02em;line-height:0.94;background:linear-gradient(160deg,#fff 0%,var(--purple-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.sel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:3px;padding:3px;max-width:1200px;margin:0 auto;}
.sel-card{position:relative;min-height:280px;cursor:pointer;overflow:hidden;border-radius:2px;display:flex;flex-direction:column;justify-content:flex-end;padding:36px 32px;transition:transform 0.22s,box-shadow 0.22s;}
.sel-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,0.5);}
/* Au hover : fond plus intense (saturation + luminosité) + léger zoom +
   overlay assombrissant allégé. Cohérent avec les GameCard accueil/blindtest. */
.sel-card-bg{position:absolute;inset:0;z-index:0;transition:filter 0.35s ease,transform 0.5s ease;}
.sel-card:hover .sel-card-bg{filter:saturate(1.25) brightness(1.18);transform:scale(1.04);}
.sel-card-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(8,8,8,0) 0%,rgba(8,8,8,0.9) 65%);z-index:1;transition:opacity 0.35s ease;}
.sel-card:hover .sel-card-overlay{opacity:0.55;}
.sel-card-content{position:relative;z-index:2;}
.sel-card-num{font-family:var(--font-display);font-size:5rem;position:absolute;top:16px;right:22px;opacity:0.12;line-height:1;z-index:2;transition:opacity 0.3s;}
.sel-card:hover .sel-card-num{opacity:0.22;}
.sel-card-tag{display:inline-block;font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.6);background:rgba(255,255,255,0.1);padding:3px 8px;border-radius:2px;margin-bottom:8px;}
.sel-card-title{font-family:var(--font-display);font-size:1.9rem;letter-spacing:0.04em;margin-bottom:7px;line-height:1.1;}
.sel-card-desc{font-size:0.78rem;color:rgba(255,255,255,0.55);line-height:1.55;margin-bottom:14px;}
.sel-card-meta{display:flex;align-items:center;justify-content:space-between;}
.sel-card-count{font-family:var(--font-mono);font-size:0.65rem;color:rgba(255,255,255,0.4);}
.sel-card-arrow{font-size:1.1rem;color:rgba(255,255,255,0.35);transition:transform 0.3s,color 0.3s;}
.sel-card:hover .sel-card-arrow{transform:translateX(5px);color:#fff;}
/* Card color themes */
.card-ia .sel-card-bg{background:linear-gradient(135deg,#1a0a2e,#2d1260,#4c28a0);}
.card-vf .sel-card-bg{background:linear-gradient(135deg,#0d0d22,#142a5a,#1e4d9a);}
.card-ocm .sel-card-bg{background:linear-gradient(135deg,#1a1004,#3d2406,#6b4010);}
.card-ordre .sel-card-bg{background:linear-gradient(135deg,#041a0e,#08381e,#0f6035);}
.card-custom .sel-card-bg{background:linear-gradient(135deg,#1a0620,#340850,#5a0e82);}
.card-lettres .sel-card-bg{background:linear-gradient(135deg,#1a0414,#3a0828,#7a1a4a);}
.card-mots .sel-card-bg{background:linear-gradient(135deg,#180a04,#2e1808,#5e3818);}
.card-construction{opacity:0.5;cursor:default;}
.card-construction:hover{transform:none;box-shadow:none;}

/* ── ALBUM SELECTION ── */
#albumSelScreen{display:none;padding-top:64px;min-height:100vh;}
.album-sel-header{padding:56px 40px 44px;border-bottom:1px solid var(--border);}
.album-sel-title{font-family:var(--font-display);font-size:clamp(2.5rem,7vw,6rem);letter-spacing:0.02em;line-height:0.94;background:linear-gradient(160deg,#fff,var(--purple-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:32px 40px;}
.album-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:pointer;transition:all 0.2s;position:relative;}
.album-card:hover{border-color:var(--purple);transform:scale(1.03);box-shadow:0 8px 30px rgba(124,58,237,0.3);}
.album-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.album-card-ph{width:100%;aspect-ratio:1;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text-muted);}
.album-card-name{padding:12px 14px 4px;font-weight:700;font-size:0.85rem;line-height:1.3;}
.album-card-artist{padding:0 14px 12px;font-family:var(--font-mono);font-size:0.7rem;color:var(--text-muted);letter-spacing:0.04em;}

/* Barre de filtres par artiste sur la sélection d'album */
.album-filter-bar{grid-column:1/-1;padding:0 0 12px;}
.album-filter-select{width:100%;max-width:320px;padding:9px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.06em;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b6560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;}
.album-filter-select:focus{border-color:var(--purple);}
.album-filter-select option{background:var(--surface);color:var(--text);}

/* ── SETUP ── */
#setupScreen{display:none;padding-top:64px;min-height:100vh;align-items:center;justify-content:center;}
.setup-box{max-width:460px;width:100%;margin:0 auto;padding:56px 40px;}
.setup-name{font-family:var(--font-display);font-size:2.8rem;letter-spacing:0.05em;background:linear-gradient(160deg,#fff,var(--purple-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px;}
.setup-sub{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.2em;color:var(--text-muted);margin-bottom:32px;text-transform:uppercase;}
.setup-section{font-family:var(--font-mono);font-size:0.66rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;}
.qcount-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:32px;}
.qc-btn{padding:16px 6px;border:2px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text-muted);font-family:var(--font-display);font-size:1.5rem;letter-spacing:0.05em;cursor:pointer;transition:all 0.18s;text-align:center;}
.qc-btn:hover{border-color:var(--purple-dim);color:var(--text);}
.qc-btn.sel{border-color:var(--purple);color:var(--purple-light);background:rgba(124,58,237,0.08);}
.setup-warn{font-family:var(--font-mono);font-size:0.7rem;color:#ff9800;margin-bottom:18px;line-height:1.5;display:none;background:rgba(255,152,0,0.07);padding:10px 12px;border-radius:4px;border:1px solid rgba(255,152,0,0.2);}
.setup-btns{display:flex;gap:10px;}

/* ── GAME ── */
#gameScreen{display:none;padding-top:64px;min-height:100vh;}
.game-inner{max-width:860px;margin:0 auto;padding:44px 40px;}
/* Ordre d'album : on élargit pour laisser la place au layout 2-col (slots + pool) */
body.ordre-playing .game-inner{max-width:1080px;}
/* Si la barre fixe d'ordre-album est active (mobile uniquement), on laisse la place en bas au contenu */
@media(max-width:900px){
  body.has-fixed-pool .game-inner{padding-bottom:160px;}
  body.ordre-playing .game-inner{max-width:860px;}
}
@media(max-width:600px){
  body.has-fixed-pool .game-inner{padding-bottom:110px;}
}
.top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding:16px 22px;background:var(--surface);border:1px solid var(--border);border-radius:8px;position:relative;overflow:hidden;gap:16px;}
.top-bar-bg{position:absolute;inset:0;opacity:0.18;pointer-events:none;}
.top-bar-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0;position:relative;}
.top-bar-emoji{font-size:2rem;line-height:1;flex-shrink:0;}
.top-game-name{font-family:var(--font-display);font-size:1.6rem;letter-spacing:0.05em;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.top-bar-right{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;position:relative;}
.top-game-name{font-family:var(--font-display);font-size:1rem;letter-spacing:0.08em;color:var(--text-muted);}
.top-score{font-family:var(--font-display);font-size:1.7rem;letter-spacing:0.04em;color:var(--purple-light);}
.top-score span{color:var(--text-muted);font-size:0.95rem;}
.prog-text{font-family:var(--font-mono);font-size:0.68rem;color:var(--text-muted);text-align:right;margin-bottom:4px;}
.prog-track{width:120px;height:3px;background:var(--border);border-radius:2px;}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--purple-light));border-radius:2px;transition:width 0.4s ease;}
.feedback{text-align:center;padding:13px;border-radius:4px;margin:16px auto 8px;max-width:600px;font-family:var(--font-display);font-size:1.25rem;letter-spacing:0.06em;opacity:0;transform:translateY(-6px);transition:all 0.3s;}
.feedback.show{opacity:1;transform:translateY(0);}
.feedback.correct{background:rgba(61,220,132,0.1);color:var(--green);border:1px solid var(--green);}
.feedback.wrong{background:rgba(255,50,50,0.08);color:var(--red);border:1px solid var(--red);}
.next-btn-wrap{text-align:center;margin-top:12px;opacity:0;transform:translateY(6px);transition:all 0.3s;}
.next-btn-wrap.show{opacity:1;transform:translateY(0);}

/* IA — bigger image */
.ia-cover{max-width:800px;width:100%;margin:0 auto 28px;aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--surface2);}
.ia-cover img{width:100%;height:100%;object-fit:cover;display:block;}
.ia-hint{text-align:center;font-family:var(--font-body);font-size:0.78rem;color:var(--text-muted);letter-spacing:0.15em;text-transform:uppercase;margin-bottom:6px;}
.game-watermark{text-align:center;font-family:var(--font-mono);font-size:0.6rem;letter-spacing:0.22em;color:var(--purple-light);margin-bottom:18px;text-transform:uppercase;}
.ia-btns{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:800px;margin:0 auto;}
.ia-compare{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:800px;margin:0 auto 20px;}
.ia-compare-box{border-radius:6px;overflow:hidden;border:1px solid var(--border);}
.ia-compare-box img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.ia-compare-lbl{padding:8px;font-family:var(--font-mono);font-size:0.65rem;letter-spacing:0.15em;text-align:center;text-transform:uppercase;}
.ia-compare-lbl.is-ia{color:var(--red);}
.ia-compare-lbl.is-real{color:var(--green);}
.choice-btn{padding:22px;border-radius:4px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-family:var(--font-display);font-size:1.4rem;letter-spacing:0.08em;cursor:pointer;transition:all 0.18s;text-align:center;}
.choice-btn:hover{border-color:var(--purple);background:var(--surface2);color:var(--purple-light);}
.choice-btn.correct{border-color:var(--green)!important;background:rgba(61,220,132,0.08)!important;color:var(--green)!important;}
.choice-btn.wrong{border-color:var(--red)!important;background:rgba(255,50,50,0.07)!important;color:var(--red)!important;}
.choice-btn:disabled{cursor:default;}

/* VF — bigger images */
.vf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.vf-opt{border-radius:6px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:all 0.2s;position:relative;background:var(--surface2);}
.vf-opt:hover{border-color:var(--purple);transform:scale(1.02);}
.vf-opt-img{width:100%;height:0;padding-bottom:100%;position:relative;overflow:hidden;}
.vf-opt-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;}
.vf-opt-lbl{padding:12px;background:var(--surface);font-family:var(--font-display);font-size:1.3rem;letter-spacing:0.08em;text-align:center;border-top:1px solid var(--border);}
.vf-opt.correct{border-color:var(--green)!important;box-shadow:0 0 24px rgba(61,220,132,0.22);}
.vf-opt.correct .vf-opt-lbl{background:rgba(61,220,132,0.1);color:var(--green);}
.vf-opt.wrong{border-color:var(--red)!important;opacity:0.5;}
.vf-opt.disabled{pointer-events:none;}

/* OCM */
.ocm-clues{display:flex;gap:clamp(8px,2vw,24px);align-items:center;justify-content:center;margin-bottom:32px;flex-wrap:nowrap;padding:4px;}
.ocm-clue{display:flex;flex-direction:column;align-items:center;gap:7px;}
.ocm-clue-lbl{font-family:var(--font-mono);font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);}
.ocm-img-box{width:clamp(100px,22vw,250px);height:clamp(100px,22vw,250px);border-radius:6px;overflow:hidden;border:1px solid var(--border);flex-shrink:0;}
.ocm-img-box img{width:100%;height:100%;object-fit:cover;}
.ocm-color-box{width:clamp(100px,22vw,250px);height:clamp(100px,22vw,250px);border-radius:6px;border:1px solid var(--border);flex-shrink:0;}
.ocm-word-box{font-family:var(--font-display);font-size:clamp(1.1rem,3vw,2.5rem);letter-spacing:0.06em;padding:0 12px;height:clamp(100px,22vw,250px);display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:6px;width:clamp(100px,22vw,250px);flex-shrink:0;}
.ocm-sep{font-family:var(--font-display);font-size:1.7rem;color:var(--purple-dim);}
.ocm-row{width:100%;margin:0 auto 0;display:flex;gap:10px;align-items:stretch;}
.ocm-input{flex:1;min-width:0;width:100%;padding:14px 16px;background:var(--surface);border:2px solid var(--border);border-radius:4px;color:var(--text);font-family:var(--font-body);font-size:0.95rem;outline:none;transition:border-color 0.2s;}
.ocm-input:focus{border-color:var(--purple);}
.ocm-input.correct{border-color:var(--green);background:rgba(61,220,132,0.04);}
.ocm-input.wrong{border-color:var(--red);animation:shake 0.4s ease;}
@keyframes shake{0%,100%{transform:translateX(0);}25%{transform:translateX(-8px);}75%{transform:translateX(8px);}}
.answer-hint{text-align:center;font-family:var(--font-mono);font-size:0.72rem;color:var(--purple-light);letter-spacing:0.1em;margin-bottom:14px;padding:8px 16px;background:rgba(124,58,237,0.07);border:1px solid var(--purple-dim);border-radius:4px;max-width:480px;margin-left:auto;margin-right:auto;}
.mb-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--purple-dim);border-top:none;border-radius:0 0 4px 4px;z-index:100;max-height:200px;overflow-y:auto;}
.mb-suggestion{padding:10px 14px;cursor:pointer;font-size:0.85rem;transition:background 0.15s;border-bottom:1px solid var(--border);}
.mb-suggestion:hover,.mb-suggestion.active{background:rgba(124,58,237,0.12);color:var(--purple-light);}
.mb-suggestion:last-child{border-bottom:none;}
.mb-input-wrap{position:relative;}

/* QCM */
.qcm-image{max-width:480px;margin:0 auto 28px;aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--surface2);}
.qcm-image img{width:100%;height:100%;object-fit:cover;display:block;}
.qcm-hint{text-align:center;font-family:var(--font-mono);font-size:0.7rem;color:var(--text-muted);letter-spacing:0.12em;margin-bottom:24px;}
.qcm-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:560px;margin:0 auto;}
.qcm-btn{padding:14px 16px;border-radius:4px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-family:var(--font-body);font-size:0.88rem;font-weight:600;cursor:pointer;transition:all 0.18s;text-align:center;}
.qcm-btn:hover{border-color:var(--purple);background:var(--surface2);}
.qcm-btn.correct{border-color:var(--green)!important;background:rgba(61,220,132,0.08)!important;color:var(--green)!important;}
.qcm-btn.wrong{border-color:var(--red)!important;background:rgba(255,50,50,0.07)!important;color:var(--red)!important;}
.qcm-btn:disabled{cursor:default;}
.text-display{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:22px 26px;margin-bottom:24px;}
.text-display p{color:var(--text);font-size:0.95rem;line-height:1.7;}
.text-display ul{padding-left:20px;}
.text-display li{color:var(--text-muted);font-size:0.9rem;line-height:1.7;margin-bottom:4px;}

/* DUEL */
.duel-hint{text-align:center;font-family:var(--font-mono);font-size:0.7rem;color:var(--text-muted);letter-spacing:0.12em;margin-bottom:18px;}
.duel-grid{display:grid;gap:14px;margin-bottom:14px;}
.duel-grid.c2{grid-template-columns:1fr 1fr;}
.duel-grid.c3{grid-template-columns:1fr 1fr 1fr;}
.duel-grid.c4{grid-template-columns:1fr 1fr 1fr 1fr;}
.duel-opt{aspect-ratio:1;border-radius:6px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:all 0.2s;position:relative;background:var(--surface2);}
.duel-opt:hover{border-color:var(--purple);transform:scale(1.02);}
.duel-opt img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;}
.duel-opt-lbl{position:absolute;bottom:0;left:0;right:0;padding:6px;background:rgba(0,0,0,0.75);font-family:var(--font-display);font-size:1rem;text-align:center;}
.duel-opt.correct{border-color:var(--green)!important;box-shadow:0 0 20px rgba(61,220,132,0.2);}
.duel-opt.wrong{border-color:var(--red)!important;opacity:0.5;}

/* ORDRE ALBUM */
.ordre-album-cover{max-width:160px;margin:0 auto 18px;aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--surface2);}
.ordre-album-cover img{width:100%;height:100%;object-fit:cover;display:block;}
.ordre-album-cover-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text-muted);}
.ordre-hint{text-align:center;font-family:var(--font-body);font-size:0.78rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:0.12em;margin-bottom:6px;}
.ordre-col-label{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:9px;padding-bottom:6px;border-bottom:1px solid var(--border);}

/* ── Layout PC : 2 colonnes (slots à gauche, pool à droite) ── */
/* Layout vertical : la tracklist en haut, le pool des morceaux à placer juste
   en dessous (au lieu de côte-à-côte). Plus naturel à lire / à comprendre. */
.ordre-play-layout{display:flex;flex-direction:column;gap:18px;align-items:stretch;margin-bottom:12px;}
.ordre-slots-col{min-width:0;}
.ordre-pool-col{min-width:0;}

/* Slots numérotés */
.ordre-slots{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;}
/* 2 colonnes pour les albums de 10+ morceaux : gauche = 1ère moitié, droite = 2ème moitié */
.ordre-slots.ordre-slots-2col{display:flex;flex-direction:row;gap:10px;}
.ordre-slots-half{display:flex;flex-direction:column;gap:5px;flex:1;min-width:0;}
.ordre-slot{display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--surface);border:2px dashed var(--border);border-radius:4px;min-height:44px;transition:all 0.15s;}
.ordre-slot.filled{border-style:solid;border-color:var(--border);background:var(--surface2);cursor:grab;touch-action:pan-y;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none;}
.ordre-slot.filled:active{cursor:grabbing;}
.ordre-slot.filled.dragging{opacity:0.3;}
.ordre-slot.drag-over{border-color:var(--purple);background:rgba(124,58,237,0.06);}
/* ── Tap-to-place (mobile) ── */
/* Item sélectionné */
.ordre-pool-item.tap-sel{border-color:var(--purple)!important;background:rgba(124,58,237,0.18)!important;box-shadow:0 0 0 2px var(--purple);animation:tapSelPulse 1s ease-in-out infinite alternate;}
.ordre-slot.tap-sel{border-color:var(--purple)!important;border-style:solid!important;background:rgba(124,58,237,0.13)!important;box-shadow:0 0 0 2px var(--purple);}
@keyframes tapSelPulse{from{box-shadow:0 0 0 2px var(--purple);}to{box-shadow:0 0 0 4px rgba(124,58,237,0.4);}}
/* Cases vides cliquables quand un item est sélectionné : légère mise en avant */
.ordre-slot:not(.filled){cursor:pointer;}
.ordre-slot-num{font-family:var(--font-display);font-size:1.1rem;color:var(--purple-dim);width:26px;flex-shrink:0;text-align:center;}
.ordre-slot-content{flex:1;font-size:0.85rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ordre-slot-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:0.8rem;padding:2px 4px;transition:color 0.15s;}
.ordre-slot-remove:hover{color:var(--red);}
.ordre-slot.r-correct{border-color:var(--green)!important;background:rgba(61,220,132,0.07)!important;}
.ordre-slot.r-wrong{border-color:var(--red)!important;background:rgba(255,50,50,0.06)!important;}
.ordre-slot.r-correct .ordre-slot-num{color:var(--green);}
.ordre-slot.r-wrong .ordre-slot-num{color:var(--red);}

/* Pool inline (PC) — colonne de droite, type Tierlist */
/* Pool inline (PC) : maintenant placé sous la tracklist → plus de position:sticky
   ni de max-height (les morceaux se laissent voir naturellement en scrollant). */
.ordre-pool-inline{display:flex;flex-wrap:wrap;gap:8px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;min-height:120px;align-content:flex-start;transition:border-color 0.15s,background 0.15s;}
.ordre-pool-inline.drag-over{border-color:var(--purple);background:rgba(124,58,237,0.06);}

/* Styles communs des items pool (inline + fixe) */
.ordre-pool-item{padding:9px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;cursor:grab;user-select:none;-webkit-user-select:none;font-size:0.85rem;font-weight:600;transition:all 0.15s;touch-action:pan-y;-webkit-touch-callout:none;}
.ordre-pool-item:hover{border-color:var(--purple);background:rgba(124,58,237,0.06);}
.ordre-pool-item.dragging{opacity:0.3;cursor:grabbing;}
.ordre-pool-empty{color:var(--green);font-family:var(--font-mono);font-size:0.72rem;letter-spacing:0.1em;padding:10px 4px;}

/* ── Barre fixe en bas (MOBILE uniquement) ── */
.ordre-pool-fixed{position:fixed;left:0;right:0;bottom:0;z-index:800;background:rgba(20,20,20,0.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--border);box-shadow:0 -8px 28px rgba(0,0,0,0.45);padding:12px 20px 14px;display:none;}
.ordre-pool-fixed .ordre-pool-label{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;}
.ordre-pool-fixed .ordre-pool{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:8px;min-height:44px;padding-bottom:4px;scrollbar-width:thin;}
.ordre-pool-fixed .ordre-pool::-webkit-scrollbar{height:4px;}
.ordre-pool-fixed .ordre-pool::-webkit-scrollbar-thumb{background:var(--purple-dim);border-radius:2px;}
/* Dans la barre fixe horizontale, les items scrollent latéralement → pan-x */
.ordre-pool-fixed .ordre-pool .ordre-pool-item{flex-shrink:0;padding:8px 12px;font-size:0.8rem;white-space:nowrap;touch-action:pan-x;}
.ordre-pool-fixed.drag-over{background:rgba(40,30,70,0.95);}
/* La barre fixe n'apparaît QUE sur mobile ET quand on joue à l'ordre-album */
@media(max-width:900px){
  body.has-fixed-pool.ordre-playing .ordre-pool-fixed.show{display:block;}
  /* Mobile : pool inline caché (la barre fixe en bas prend le relai) */
  .ordre-play-layout{gap:0;}
  .ordre-pool-col{display:none;}
  /* Les slots passent toujours en 1 colonne sur mobile, même avec 10+ morceaux */
  .ordre-slots.ordre-slots-2col{flex-direction:column;gap:5px;}
  .ordre-slots-half{flex:none;}
  /* Texte du slot : pas de troncature sur mobile (on a de la place verticale) */
  .ordre-slot-content{white-space:normal;overflow:visible;text-overflow:clip;}
}
.ordre-validate-row{text-align:center;margin-top:16px;}
.ordre-result-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:14px;}
.ordre-track{display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--surface);border:1px solid var(--border);border-radius:4px;}
.ordre-track-num{font-family:var(--font-display);font-size:1.1rem;color:var(--purple-dim);width:26px;flex-shrink:0;text-align:center;}
.ordre-track-name{font-size:0.85rem;font-weight:600;flex:1;}
.ordre-track.r-correct{border-color:var(--green)!important;background:rgba(61,220,132,0.07)!important;}
.ordre-track.r-wrong{border-color:var(--red)!important;background:rgba(255,50,50,0.06)!important;}
.ordre-track.r-correct .ordre-track-num{color:var(--green);}
.ordre-track.r-wrong .ordre-track-num{color:var(--red);}

/* SCORE */
#scoreScreen{display:none;padding-top:64px;min-height:100vh;align-items:center;justify-content:center;}
.score-box{max-width:500px;margin:0 auto;padding:56px 40px;text-align:center;}
.score-big{font-family:var(--font-display);font-size:9rem;line-height:1;background:linear-gradient(160deg,#fff,var(--purple-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.score-over{font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.2em;color:var(--text-muted);text-transform:uppercase;margin:6px 0 24px;}
.score-msg{font-size:0.95rem;color:var(--text-muted);line-height:1.7;margin-bottom:36px;}
.score-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* EMPTY / construction */
.empty{text-align:center;padding:70px 20px;}
.empty-icon{font-size:2.8rem;margin-bottom:14px;}
.empty-title{font-family:var(--font-display);font-size:1.8rem;color:var(--text-muted);margin-bottom:8px;}
.empty-sub{font-family:var(--font-mono);font-size:0.72rem;color:var(--text-muted);letter-spacing:0.1em;line-height:1.6;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:12px 22px;border-radius:4px;font-family:var(--font-body);font-size:0.8rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;border:none;transition:all 0.18s;text-decoration:none;}
.btn-purple{background:linear-gradient(135deg,var(--purple),var(--purple2));color:#fff;}
.btn-purple:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(124,58,237,0.45);}
.btn-outline{background:transparent;color:var(--purple-light);border:1px solid var(--purple-dim);}
.btn-outline:hover{border-color:var(--purple);background:rgba(124,58,237,0.08);}
.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);}
.btn-ghost:hover{color:var(--text);border-color:#555;}

@media(max-width:600px){
  nav{padding:0 16px;}
  .nav-links{display:none !important;}
  /* Game screens */
  .game-inner,.setup-box,.score-box{padding:20px 14px;}
  .sel-header,.album-sel-header{padding:28px 16px 20px;}
  .sel-title,.album-sel-title{font-size:3.5rem;}
  /* Grids */
  .album-grid{padding:12px;grid-template-columns:repeat(2,1fr);gap:8px;}
  .sel-grid{grid-template-columns:1fr;gap:8px;padding:0 12px;}
  .sel-card{min-height:180px;}
  /* Jeu VF */
  .vf-grid{gap:6px;flex-direction:column;}
  .vf-img-wrap{max-width:100%;}
  /* OCM */
  .ocm-clues{gap:8px;}
  .ocm-row{flex-direction:row;}
  /* QCM */
  .qcm-options{grid-template-columns:1fr;}
  /* Ordre album */
  .ordre-cols{grid-template-columns:1fr;}
  /* IA */
  .ia-cover{max-width:min(300px,90vw);}
  .ia-btns{grid-template-columns:1fr 1fr;gap:8px;}
  /* Top bar */
  .top-bar{flex-direction:row;gap:6px;padding:8px 14px;flex-wrap:wrap;}
  .top-name{font-size:0.8rem;}
  /* Score */
  .score-big{font-size:4rem;}
  .score-actions{flex-direction:column;gap:8px;}
  .score-actions .btn{width:100%;justify-content:center;}
  /* Setup */
  .qcount-grid{grid-template-columns:repeat(4,1fr);}

  .ocm-input,.ti-ans,.bt-input,input[type="text"]{font-size:16px !important;}
}
@media(max-width:380px){
  .album-grid{grid-template-columns:1fr;}
}
/* Bloc d'overrides mobile : avant, `.nav-links{display:none;}` et les autres
   règles étaient au niveau global (orphelines en dehors de toute media query),
   ce qui cachait le menu nav même sur PC pendant les jeux. Replacé proprement. */
@media(max-width:720px){
  .game-inner,.setup-box,.score-box{padding:32px 18px;}
  .sel-header,.album-sel-header{padding:40px 18px 30px;}
  .album-grid{padding:20px 18px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));}
  .vf-grid{gap:8px;}
  .qcm-options{grid-template-columns:1fr;}
  .ordre-cols{grid-template-columns:1fr;}
}


/* ══ LA TIMELINE ══ */
#tlGameScreen{max-width:860px;margin:0 auto;padding:20px 20px 120px;}

/* ── Timeline slots row ── */
.tl-slots-wrap{position:relative;display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:48px;padding:0 20px;}
.tl-line{position:absolute;top:50%;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--purple-dim),var(--purple));z-index:0;pointer-events:none;}
.tl-line-arrow{position:absolute;right:-2px;top:50%;transform:translateY(-50%);color:var(--purple);font-size:1rem;line-height:1;}
.tl-slot{
  width:150px;height:150px;
  background:var(--surface2);
  border:2px dashed var(--border);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  flex-shrink:0;
  z-index:1;
  transition:border-color 0.2s,background 0.2s,box-shadow 0.2s;
  margin:0 30px;
}
.tl-slot{cursor:pointer;}
.tl-slot.has-card{border-style:solid;border-color:transparent;}
.tl-slot.drag-over{border-color:var(--purple);background:rgba(124,58,237,0.12);box-shadow:0 0 0 2px var(--purple);}
/* Tap-to-place : carte sélectionnée */
.tl-pool-card.tap-sel,.tl-card.tap-sel{box-shadow:0 0 0 3px var(--purple)!important;border-color:var(--purple)!important;animation:tapSelPulse 1s ease-in-out infinite alternate;}
.tl-slot-num{
  position:absolute;top:-22px;left:50%;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.1em;
  color:var(--text-muted);
}

/* ── Card in slot (same as pool card) ── */
.tl-card{
  width:140px;height:140px;
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  cursor:grab;
  user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;
  /* pan-y : le scroll vertical de page est géré nativement. Le drag est
     activé après 150ms de maintien (hold timer), comme dans la Tierlist. */
  touch-action:pan-y;
  transition:border-color 0.15s,box-shadow 0.15s;
  position:relative;
  flex-shrink:0;
}
.tl-card img.tl-cover{width:100%;height:100%;object-fit:cover;display:block;}
.tl-card .tl-name{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(0,0,0,0.75);
  font-size:0.52rem;font-family:var(--font-mono);letter-spacing:0.02em;
  padding:2px 4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.tl-card .tl-date{
  position:absolute;top:0;left:0;right:0;
  background:rgba(124,58,237,0.85);
  font-family:var(--font-body);font-size:0.62rem;font-weight:600;letter-spacing:0.02em;
  padding:3px 5px;text-align:center;
  display:none;z-index:2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.tl-card:active{cursor:grabbing;}
.tl-card.dragging{opacity:0.25;transform:scale(0.9);}
.tl-card.correct{border-color:#4caf50;box-shadow:0 0 0 2px #4caf50;}
.tl-card.wrong{border-color:#f44336;box-shadow:0 0 0 2px #f44336;}

/* ── Pool cards (bigger, with title + play btn below cover) ── */
#tlPool{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:28px;}
.tl-pool-card{
  width:175px;
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  cursor:grab;
  user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;
  /* pan-y : même logique que .tl-card (hold timer 150ms + releasePointerCapture). */
  touch-action:pan-y;
  transition:border-color 0.15s,box-shadow 0.15s;
  position:relative;
  flex-shrink:0;
}
/* Le bouton "play preview" reste tappable (touch-action:manipulation =
   pas de drag, juste click). Sinon il hérite du touch-action:pan-y parent. */
.tl-pool-card .tl-preview-btn{touch-action:manipulation;}
.tl-pool-card img.tl-cover{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.tl-pool-card .tl-pool-info{padding:8px 10px 6px;}
/* Titres + artistes en Syne (font-body) — cohérent avec le reste du site */
.tl-pool-card .tl-pool-title{font-family:var(--font-body);font-size:0.78rem;font-weight:700;letter-spacing:0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px;color:#fff;}
.tl-pool-card .tl-pool-artist{font-family:var(--font-body);font-size:0.7rem;font-weight:500;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
/* Bouton "Écouter" : violet, bien visible, sous titre/artiste */
.tl-pool-card .tl-preview-btn{
  width:100%;padding:7px 0;
  background:linear-gradient(135deg,var(--purple),var(--purple2));
  border:none;color:#fff;
  font-family:var(--font-body);font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;
  transition:filter 0.15s;
}
.tl-pool-card .tl-preview-btn:hover{filter:brightness(1.15);}
.tl-pool-card .tl-preview-btn-disabled{
  background:var(--surface2);color:var(--text-muted);
  cursor:not-allowed;opacity:0.6;
}
.tl-pool-card .tl-preview-btn-disabled:hover{filter:none;}
/* Date révélée : petite + discrète + Syne */
.tl-pool-card .tl-date{
  font-family:var(--font-body);font-size:0.68rem;font-weight:600;letter-spacing:0.02em;
  color:var(--purple-light);padding:4px 8px 6px;text-align:center;opacity:0.85;
  display:none;
}
.tl-pool-card:active{cursor:grabbing;}
.tl-pool-card.dragging{opacity:0.25;}
.tl-pool-card.correct{border-color:#4caf50;box-shadow:0 0 0 2px #4caf50;}
.tl-pool-card.wrong{border-color:#f44336;box-shadow:0 0 0 2px #f44336;}

/* ── Result correct timeline ── */
/* 4 cartes sur une seule ligne, covers compactes. */
#tlCorrectTimeline{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:24px;}
.tl-correct-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  display:flex;flex-direction:column;
  min-width:0;
}
.tl-correct-card img.tl-cover{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.tl-correct-card .tl-pool-info{padding:5px 6px 3px;}
.tl-correct-card .tl-pool-title{font-family:var(--font-body);font-size:0.68rem;font-weight:700;letter-spacing:0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px;color:#fff;}
.tl-correct-card .tl-pool-artist{font-family:var(--font-body);font-size:0.6rem;font-weight:500;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tl-correct-card .tl-date{
  font-family:var(--font-body);font-size:0.64rem;font-weight:600;letter-spacing:0.02em;
  color:var(--purple-light);padding:3px 6px 6px;text-align:center;opacity:0.85;
}
@media(max-width:600px){
  #tlCorrectTimeline{gap:4px;}
  .tl-correct-card .tl-pool-info{padding:4px 4px 2px;}
  .tl-correct-card .tl-pool-title{font-size:0.52rem;}
  .tl-correct-card .tl-pool-artist{font-size:0.5rem;}
  .tl-correct-card .tl-date{font-size:0.68rem;padding:2px 4px 5px;}
}

@media(max-width:600px){
  .tl-slot{width:72px;height:72px;margin:0 10px;}
  .tl-card{width:68px;height:68px;}
  .tl-pool-card{width:calc(50% - 6px);}
}

/* ══════════════════════════════════════════════════
   LETTRES DANS LE DÉSORDRE
   ══════════════════════════════════════════════════ */

/* Boutons de difficulté : centrer le texte (emoji + libellé) sur une ligne */
.qc-btn[data-diff],.qc-btn[data-motsdiff]{font-family:var(--font-body);font-size:0.92rem;font-weight:600;letter-spacing:0.04em;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 6px;white-space:nowrap;}

.lettres-hint{text-align:center;font-family:var(--font-body);font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin:0 0 6px;}
.lettres-tiles-wrap{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin:0 auto 22px;max-width:780px;padding:24px 14px;background:rgba(124,58,237,0.04);border:1px solid var(--border);border-radius:8px;}
.lettres-tile{display:inline-flex;align-items:center;justify-content:center;width:42px;height:50px;background:linear-gradient(180deg,#2a1248,#180624);border:1px solid var(--purple-dim);border-radius:5px;color:#fff;font-family:var(--font-display);font-size:1.6rem;letter-spacing:0;box-shadow:0 2px 0 rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.06);}
.lettres-tile-hidden{background:repeating-linear-gradient(45deg,#1a0a2a,#1a0a2a 6px,#220e36 6px,#220e36 12px);border:1px dashed rgba(255,140,200,0.5);color:rgba(255,140,200,0.55);font-size:1.4rem;}
.lettres-sep{font-family:var(--font-display);font-size:1.6rem;color:var(--text-muted);padding:0 6px;user-select:none;align-self:center;}
.lettres-space{display:inline-block;width:24px;}
.lettres-hard-note{text-align:center;font-family:var(--font-mono);font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:#ff88c8;margin:0 0 16px;}

/* Timer : texte centré au-dessus, barre en dessous */
.lettres-timer-wrap{max-width:520px;margin:0 auto 18px;}
.lettres-timer-text{text-align:center;font-family:var(--font-mono);font-size:0.85rem;color:var(--text);margin-bottom:6px;letter-spacing:0.08em;font-weight:600;}
.lettres-timer{position:relative;height:8px;background:rgba(255,255,255,0.05);border-radius:99px;overflow:hidden;}
.lettres-timer-bar{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#7c3aed,#ec4899);border-radius:99px;transition:width 0.1s linear;}

.lettres-row{display:flex;gap:10px;max-width:520px;margin:0 auto;}
/* Scroll-margin sur l'input : si iOS doit le faire défiler dans la vue (ex
   apparition clavier), il garde 100px de marge au-dessus pour qu'on voit
   encore les lettres au-dessus. Combiné avec interactive-widget=resizes-content
   sur le viewport meta, le scroll est très réduit voire inexistant. */
#lettresIn{scroll-margin-top:100px;scroll-margin-bottom:80px;}
@media(max-width:600px){
  .lettres-tile{width:34px;height:42px;font-size:1.3rem;}
  .lettres-tile-hidden{font-size:1.1rem;}
  .lettres-tiles-wrap{gap:6px;padding:16px 8px;}
  .lettres-space{width:16px;}
}

/* ══════════════════════════════════════════════════
   MOTS-MÊLÉS
   ══════════════════════════════════════════════════ */
.mots-hint{text-align:center;font-family:var(--font-body);font-size:0.75rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);margin:0 0 6px;}
.mots-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;max-width:480px;margin:0 auto 24px;padding:10px;background:rgba(255,180,40,0.04);border:1px solid rgba(255,180,40,0.18);border-radius:8px;}
/* touch-action:manipulation = supprime le double-tap-to-zoom sur mobile.
   Indispensable pour que les clics rapides sur plusieurs cases ne déclenchent
   pas le zoom du navigateur. */
/* La lettre vit directement comme textContent du bouton — jamais touché par JS.
   Transition sur background/border/box-shadow uniquement : PAS sur color, pour
   éviter un flash intermédiaire quand l'état change. font-weight reste à 400 car
   Bebas Neue n'a pas de variante bold : forcer 700 déclenche un FOUT sur iOS. */
.mots-cell{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,180,40,0.25);background:linear-gradient(180deg,#1a1004,#2a1808);color:#ffd070;font-family:var(--font-display);font-size:1.3rem;letter-spacing:0;cursor:pointer;border-radius:4px;transition:background 0.18s ease,border-color 0.18s ease,box-shadow 0.18s ease;padding:0;outline:none;overflow:visible;touch-action:manipulation;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;-webkit-appearance:none;appearance:none;}
.mots-cell:hover{background:linear-gradient(180deg,#2a1808,#3d2406);border-color:rgba(255,180,40,0.5);}
.mots-cell.correct{background:linear-gradient(180deg,#0d6024,#168a3c) !important;border-color:#3ddc84 !important;color:#fff !important;box-shadow:0 0 8px rgba(61,220,132,0.5);}
.mots-cell.reveal{background:linear-gradient(180deg,#0d6024,#168a3c) !important;border-color:#3ddc84 !important;color:#fff !important;box-shadow:0 0 12px rgba(61,220,132,0.55);}
.mots-cell.wrong{background:linear-gradient(180deg,#7a1a1a,#a02828) !important;border-color:#ff5555 !important;color:#fff !important;}
.mots-cell.correct,.mots-cell.wrong,.mots-cell.reveal{cursor:default;}
/* Indication "Nombre de lettres : X" — entre la grille et les tuiles de progression */
.mots-letter-count{text-align:center;font-family:var(--font-mono);font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);margin:14px 0 10px;}
.mots-letter-count strong{color:var(--purple-light);font-weight:700;}
/* ══════════════════════════════════════════════════
   LIGHTBOX (zoom image) — IA pas IA + Vraie VS Fausse
   ══════════════════════════════════════════════════ */
.img-lightbox{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,0.92);align-items:center;justify-content:center;padding:24px 16px;}
.img-lightbox.open{display:flex;}
/* Inner pleine largeur viewport, l'image s'étire au max tout en restant carrée
   (aspect-ratio:1) et sans dépasser la hauteur disponible. */
.img-lightbox-inner{position:relative;max-width:min(90vh,920px);width:100%;display:flex;flex-direction:column;align-items:center;gap:18px;}
.img-lightbox img{width:100%;aspect-ratio:1;max-height:80vh;object-fit:cover;border-radius:10px;border:1px solid rgba(255,255,255,0.08);box-shadow:0 16px 64px rgba(0,0,0,0.6);}
.img-lightbox-question{font-family:var(--font-display);font-size:1.4rem;letter-spacing:0.04em;text-align:center;color:#fff;}
.img-lightbox-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}
.img-lightbox-actions .btn{min-width:130px;}
.img-lightbox-close{position:absolute;top:-44px;right:0;background:transparent;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:6px 10px;line-height:1;}
@media(max-width:600px){
  .img-lightbox{padding:16px 12px;}
  .img-lightbox-question{font-size:1.15rem;}
  .img-lightbox-close{top:-38px;}
}

/* Conteneur des actions (Passer / Indice) sous la grille Mots-Mêlés */
.mots-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin:14px auto 0;max-width:480px;}
/* Case éliminée par l'indice : faible opacité + non-cliquable. */
.mots-cell-eliminated{opacity:0.15 !important;filter:grayscale(1);pointer-events:none !important;cursor:default !important;}

/* ── Indices (Lettres dans le désordre + Mots-mêlés) ── */
.hint-row{display:flex;justify-content:center;margin:14px auto 0;max-width:520px;min-height:42px;}
.hint-btn{font-size:0.78rem;padding:9px 16px;letter-spacing:0.06em;}
.hint-btn[disabled]{opacity:0.55;cursor:not-allowed;background:transparent;color:var(--text-muted);border:1px solid var(--border);}
.hint-revealed{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:0.85rem;letter-spacing:0.06em;color:#f59e0b;background:rgba(245,158,11,0.08);border:1px solid rgba(245,158,11,0.3);border-radius:6px;padding:8px 14px;}
/* Tuile mini (dans le texte de l'indice) — même style que les tuiles de la question mais plus compacte */
.lettres-tile.lettres-tile-mini{width:32px;height:38px;font-size:1.2rem;margin-left:2px;}
/* Tuile verte : surlignage de la lettre révélée par l'indice (dans la question + dans le texte) */
.lettres-tile.lettres-tile-hint{background:linear-gradient(180deg,#0d6024,#168a3c);border-color:#3ddc84;color:#fff;box-shadow:0 2px 0 rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.1),0 0 12px rgba(61,220,132,0.45);}
.mots-progress{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin:0 auto 18px;max-width:480px;}
.mots-prog-tile{display:inline-flex;align-items:center;justify-content:center;width:34px;height:40px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-family:var(--font-display);font-size:1.2rem;}
.mots-prog-tile.filled{background:rgba(61,220,132,0.08);border-color:var(--green);color:#aaffcc;}
.mots-prog-tile.reveal{background:rgba(170,255,100,0.05);border-color:rgba(170,255,100,0.4);color:#ddffaa;}
@keyframes motsPop{0%{transform:scale(1);}50%{transform:scale(1.18);}100%{transform:scale(1);}}
@media(max-width:600px){
  .mots-grid{max-width:360px;gap:3px;padding:6px;}
  .mots-cell{font-size:1.05rem;}
  .mots-prog-tile{width:28px;height:34px;font-size:1rem;}
}

/* ══════════════════════════════════════════════════
   FACESWAP
   ══════════════════════════════════════════════════ */
/* PC : artist1 — merged — artist2 sur une ligne */
.fs-layout{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:24px;margin-bottom:24px;flex-wrap:wrap;}
.fs-merged-wrap{flex-shrink:0;width:min(400px,60vw);}
.fs-merged-img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:10px;border:2px solid var(--border);display:block;transition:box-shadow 0.3s,border-color 0.3s;}
.fs-merged-ph{width:100%;aspect-ratio:1/1;background:var(--surface2);border-radius:10px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:4rem;}
.fs-merged-img.fs-correct{border-color:#3ddc84;box-shadow:0 0 20px rgba(61,220,132,0.45);}
.fs-merged-img.fs-wrong{border-color:#ff5555;box-shadow:0 0 20px rgba(255,85,85,0.4);}
/* Artistes : cachés jusqu'au reveal, affichés en flex-column */
.fs-artist-side{display:none;flex-direction:column;align-items:center;gap:8px;flex-shrink:0;}
.fs-artist-img{width:min(130px,20vw);aspect-ratio:1/1;object-fit:cover;border-radius:8px;border:1px solid var(--border);}
.fs-artist-ph{width:min(130px,20vw);aspect-ratio:1/1;background:var(--surface2);border-radius:8px;border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:2.5rem;}
.fs-artist-label{font-family:var(--font-display);font-size:1.3rem;letter-spacing:0.04em;color:var(--text);text-align:center;}
.fs-inputs{display:flex;flex-direction:column;gap:12px;width:100%;max-width:420px;margin:0 auto 16px;}
/* Mobile : merged en haut (order:1, pleine largeur), artistes côte à côte en dessous (order:2) */
@media(max-width:600px){
  .fs-layout{flex-wrap:wrap;gap:16px;align-items:flex-start;}
  .fs-merged-wrap{order:1;flex:0 0 100%;width:min(260px,80vw);margin:0 auto;}
  .fs-artist-side{order:2;flex:1;min-width:0;}
  .fs-artist-img,.fs-artist-ph{width:100%;min-width:0;}
}
