/* ============================================================
   READ THE SETTER — feuille de style intégrée (V2)
   Chrome éditorial sobre + overlay « découpage V1 » peu occultant.
   ============================================================ */
:root{
  --bg:#F6F4EF; --ink:#1A1714; --surface:#FFFFFF;
  --hairline:rgba(26,23,20,.12); --hairline-strong:rgba(26,23,20,.26);
  --accent:#B5613F;
  --green:#2F7D5B; --green-tint:rgba(70,211,155,.16);
  --red:#9A3B2E;   --red-tint:rgba(255,107,107,.16);
  --muted:rgba(26,23,20,.58); --faint:rgba(26,23,20,.40);

  /* overlay (sur vidéo : texte clair, fonds translucides sombres) */
  --chalk-soft:rgba(255,255,255,.20);
  --hover:rgba(255,255,255,.07);
  --hover-line:rgba(255,255,255,.92);
  --o-green:#46d39b; --o-green-tint:rgba(70,211,155,.14);
  --o-red:#ff6b6b;   --o-red-tint:rgba(255,107,107,.14);
  --label-bg:rgba(9,12,19,.72); --label-bd:rgba(255,255,255,.42);
  --o-text:#f6f8ff;

  --serif:'Fraunces',Georgia,serif;
  --grotesk:'Mulish',system-ui,sans-serif;
  --r:14px;
  --shadow:0 1px 2px rgba(26,23,20,.04),0 22px 50px -34px rgba(26,23,20,.32);
  --ease:cubic-bezier(0.23,1,0.32,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg)}
body{
  font-family:var(--grotesk); color:var(--ink); line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  padding:clamp(16px,4vw,40px) clamp(12px,3.5vw,36px) 56px;
}
.tabular{font-variant-numeric:tabular-nums}
.wrap{max-width:1120px;margin:0 auto}
.hidden{display:none!important}

.rise{opacity:0;transform:translateY(8px);animation:rise .5s var(--ease) forwards}
@keyframes rise{to{opacity:1;transform:translateY(0)}}

/* ===== SCOREBOARD — ligne fine au-dessus du player ===== */
.scorebar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:0 2px 12px;border-bottom:1px solid var(--hairline);margin-bottom:14px;
}
.wordmark{
  font-family:var(--serif);font-style:italic;font-weight:500;font-size:19px;
  letter-spacing:-.01em;color:var(--ink);display:inline-flex;align-items:center;gap:9px;
}
.wordmark .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none}
.metrics{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--muted)}
.metric{display:inline-flex;align-items:baseline;gap:6px;white-space:nowrap}
.metric .k{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);font-weight:600}
.metric .v{font-weight:700;color:var(--ink);font-size:14px}
.metric .v small{font-weight:600;color:var(--muted)}
.metrics .sep{width:1px;height:14px;background:var(--hairline)}

/* ===== PLAYER — pleine largeur, dominant ===== */
.player{
  position:relative;width:100%;aspect-ratio:16/9;
  background:#0b0d12;border:1px solid var(--hairline);border-radius:var(--r);
  box-shadow:var(--shadow);overflow:hidden;
}
.player:fullscreen{border-radius:0;border:0}
#player{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}

/* voile qui masque la vidéo hors jeu (seek, attente) */
.hider{position:absolute;inset:0;z-index:3;background:#0b0d12;
  opacity:1;transition:opacity 300ms var(--ease);pointer-events:none}

/* frame anti-clic : intercepte tous les clics vers l'iframe YouTube
   (pas de pause/lecture manuelle, pas de clic sur le logo/seekbar).
   Sous les zones de jeu (z5) qui restent cliquables. */
.shield{position:absolute;inset:0;z-index:4;background:transparent;cursor:default}

/* ===== OVERLAY : découpage V1, peu occultant ===== */
.overlay{position:absolute;inset:0;z-index:5}
.zone{
  position:absolute;border:0;padding:0;background:transparent;cursor:pointer;
  color:var(--o-text);font-family:var(--grotesk);
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
  transition:background-color 180ms var(--ease);
}
/* géométrie REPRISE DE LA V1 (clip-path identiques) */
.z4{    left:0;     top:0; width:33.34%; height:100%; clip-path:polygon(0 0,100% 0,100% 70%,0 100%);}
.zquick{left:33.33%; top:0; width:33.34%; height:70%;  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);}
.z2{    right:0;    top:0; width:33.34%; height:100%; clip-path:polygon(0 0,100% 0,100% 100%,0 70%);}
.zpipe{ left:0; bottom:0; width:100%; height:30%; z-index:2; clip-path:polygon(0 100%,33.4% 0,66.6% 0,100% 100%);}

.zone::before{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--chalk-soft);
  clip-path:inherit;transition:box-shadow 180ms var(--ease);pointer-events:none}

@media (hover:hover) and (pointer:fine){
  .zone:hover{background-color:var(--hover)}
  .zone:hover::before{box-shadow:inset 0 0 0 1.5px var(--hover-line)}
  .zone:hover .chip{opacity:1;transform:translateY(0) scale(1)}
  .zone:hover .arrow{opacity:1}
}
.zone:focus-visible{outline:none}
.zone:focus-visible::before{box-shadow:inset 0 0 0 2px var(--hover-line)}
.zone:focus-visible .chip{opacity:1;transform:translateY(0) scale(1)}
.zone:active .chip{transform:scale(.97)}

.chip{
  position:absolute;display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;
  background:var(--label-bg);border:1px solid var(--label-bd);
  backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);
  box-shadow:0 2px 12px rgba(0,0,0,.4);
  font-size:13.5px;font-weight:600;white-space:nowrap;
  opacity:.95;transform:translateY(2px) scale(.98);
  transition:opacity 180ms var(--ease),transform 180ms var(--ease);
}
.chip .name{font-family:var(--serif);font-style:italic;font-weight:500;font-size:15px;line-height:1}
.chip .key{font-size:10px;font-weight:700;color:rgba(246,248,255,.85);
  min-width:18px;height:18px;display:grid;place-items:center;padding:0 4px;
  border:1px solid rgba(255,255,255,.28);border-bottom-width:2px;border-radius:5px;background:rgba(255,255,255,.06)}
.arrow{width:16px;height:11px;opacity:.85;transition:opacity 180ms var(--ease)}
.arrow line,.arrow path{stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round}

/* placement des pastilles — excentrées vers la cible réelle de chaque passe */
.c4{left:7%;top:24%}
.cquick{left:50%;top:13%;translate:-50% 0}
.c2{right:7%;top:24%}
.cpipe{left:50%;bottom:8%;translate:-50% 0}

/* feedback */
.zone.correct{background-color:var(--o-green-tint)!important}
.zone.correct::before{box-shadow:inset 0 0 0 2px var(--o-green)!important}
.zone.correct .chip{opacity:1;border-color:var(--o-green);color:var(--o-green)}
.zone.wrong{background-color:var(--o-red-tint)!important}
.zone.wrong::before{box-shadow:inset 0 0 0 2px var(--o-red)!important}
.zone.wrong .chip{opacity:1;border-color:var(--o-red);color:var(--o-red)}
.zone.reveal::before{box-shadow:inset 0 0 0 2px var(--o-green)!important}
.zone.reveal .chip{opacity:1;border-color:var(--o-green);color:var(--o-green)}

/* ===== chrome flottant : caption, fullscreen, verdict, start, result ===== */
.caption{position:absolute;left:14px;bottom:12px;z-index:6;display:inline-flex;align-items:center;gap:7px;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(246,248,255,.8);
  background:rgba(12,15,22,.5);border:1px solid rgba(255,255,255,.16);padding:5px 10px;border-radius:999px;
  backdrop-filter:blur(6px);transition:opacity 200ms var(--ease)}
.caption .dot{width:5px;height:5px;border-radius:50%;background:var(--o-green)}

.fs-btn{position:absolute;top:12px;right:12px;z-index:6;width:38px;height:38px;display:grid;place-items:center;
  background:rgba(12,15,22,.5);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);border-radius:10px;
  color:#f6f8ff;cursor:pointer;transition:transform 160ms var(--ease),border-color 160ms ease}
.fs-btn:active{transform:scale(.96)}
.fs-btn:focus-visible{outline:2px solid #fff;outline-offset:2px}
.fs-btn svg{width:16px;height:16px}
@media (hover:hover) and (pointer:fine){.fs-btn:hover{border-color:rgba(255,255,255,.4)}}

.verdict{position:absolute;left:50%;top:14px;z-index:8;translate:-50% 0;display:inline-flex;align-items:center;gap:8px;
  padding:9px 15px;border-radius:999px;background:rgba(12,15,22,.74);border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(8px);font-weight:600;font-size:13.5px;opacity:0;transform:translateY(-6px) scale(.98);
  transition:opacity 200ms var(--ease),transform 200ms var(--ease);pointer-events:none}
.verdict.show{opacity:1;transform:translateY(0) scale(1)}
.verdict.ok{color:var(--o-green)} .verdict.no{color:var(--o-red)}
.verdict svg{width:15px;height:15px}

.start,.result{position:absolute;inset:0;z-index:9;display:grid;place-items:center;text-align:center;
  background:radial-gradient(120% 130% at 50% 0%,rgba(246,244,239,.92),rgba(246,244,239,.86));
  transition:opacity 240ms var(--ease)}
.start-btn{font-family:var(--grotesk);font-weight:600;font-size:15px;color:var(--surface);background:var(--ink);
  border:0;padding:14px 26px;border-radius:999px;cursor:pointer;min-height:48px;display:inline-flex;align-items:center;
  gap:10px;transition:transform 160ms var(--ease)}
.start-btn:active{transform:scale(.98)}
.start-btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.start-btn svg{width:15px;height:15px}
.start-cap{margin-top:14px;font-size:12.5px;color:var(--muted);max-width:42ch}
.start-cap em{font-family:var(--serif);font-style:italic;color:var(--ink)}

/* écran de résultat */
.result{gap:0;flex-direction:column}
.result-inner{display:flex;flex-direction:column;align-items:center;gap:6px}
.result .big{font-family:var(--serif);font-weight:500;font-size:clamp(40px,8vw,68px);line-height:.9;letter-spacing:-.02em}
.result .big small{font-size:.42em;color:var(--muted);font-family:var(--grotesk);font-weight:600}
.result .sub{font-size:14px;color:var(--muted);display:flex;gap:14px;align-items:center;margin-top:6px}
.result .sub .sep{width:1px;height:13px;background:var(--hairline)}
.result .replay{margin-top:18px}

/* ===== pied : recap des raccourcis + aide ===== */
.foot{margin-top:14px;display:flex;flex-direction:column;gap:11px;font-size:12.5px;color:var(--faint)}
.foot .hint{display:inline-flex;align-items:center;gap:7px}
.foot .hint svg{width:13px;height:13px;flex:none}

.legend{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media (max-width:680px){.legend{grid-template-columns:repeat(2,1fr)}}
.lg{display:inline-flex;align-items:center;gap:10px;padding:9px 12px;
  border:1px solid var(--hairline);border-radius:10px;background:var(--surface);font-size:13px;min-height:44px}
.lg b{font-weight:700;color:var(--muted);min-width:24px;height:24px;display:inline-grid;place-items:center;flex:none;
  border:1px solid var(--hairline);border-bottom-width:2px;border-radius:6px;background:var(--bg);font-size:12px}
.lg .lg-t{display:flex;flex-direction:column;line-height:1.2;color:var(--faint);font-size:11.5px;min-width:0}
.lg .lg-n{font-family:var(--serif);font-style:italic;font-weight:500;font-size:16px;color:var(--ink);letter-spacing:-.01em}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.001ms!important;animation-duration:.001ms!important}
  .rise{opacity:1;transform:none}
}
@media (max-width:560px){
  .chip{padding:5px 8px;font-size:12px}.chip .name{font-size:14px}
  .metrics{gap:10px}
}
