/* ============================================================
   PETIT BAC — Design System complet
   Mobile-first · CSS variables · Zéro couleur codée en dur
   ============================================================ */

:root {
  --primary:       #4A6CF7;
  --primary-dark:  #3B5CE0;
  --primary-light: #7B93FA;
  --primary-pale:  #EEF0FE;
  --primary-deep:  #2A4BC8;

  --jaune:         #FDE047;
  --jaune-dark:    #F59E0B;
  --jaune-pale:    #FEF9C3;

  --corail:        #FB7185;
  --corail-dark:   #E11D48;
  --corail-pale:   #FFE4E6;

  --menthe:        #34D399;
  --menthe-dark:   #059669;
  --menthe-pale:   #D1FAE5;

  --accent:        #F59E0B;
  --accent-pale:   #FEF3C7;
  --success:       #22c55e;
  --danger:        #ef4444;

  --dark:          #1E293B;
  --dark-deeper:   #0F172A;
  --text:          #1e293b;
  --text-light:    #64748b;
  --text-xlight:   #94a3b8;

  --bg:            #FAFBFF;
  --bg-alt:        #F1F5F9;
  --bg-white:      #ffffff;
  --border:        rgba(30,41,59,0.10);
  --shadow-sm:     0 1px 3px rgba(30,41,59,0.08);
  --shadow:        0 6px 20px rgba(30,41,59,0.10);
  --shadow-lg:     0 12px 40px rgba(30,41,59,0.16);

  --radius-sm:     8px;
  --radius-md:     12px;
  --radius:        16px;
  --radius-lg:     24px;

  --font-display:  'Fredoka', system-ui, sans-serif;
  --font-body:     'DM Sans', sans-serif;
  --container:     1180px;
  --nav-h:         72px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:clamp(16px,1.2vw + 14px,18px);scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--text);background:var(--bg);overflow-x:hidden}
img,picture,video,svg{display:block;max-width:100%}
input,button,textarea,select{font:inherit}
ul{list-style:none}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark)}
a:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:3px}

/* ── Typography ─────────────────────────────────────────────── */
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.15;color:var(--dark);letter-spacing:-.01em}
h4{font-family:var(--font-body);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);margin-bottom:.75rem}
h1{font-size:clamp(1.9rem,4.5vw,3rem);font-weight:700}
h2{font-size:clamp(1.45rem,2.8vw,2.1rem);margin-bottom:.75rem}
h3{font-size:clamp(1.1rem,2vw,1.35rem);margin-bottom:.5rem}
p{overflow-wrap:break-word}

/* ── Container ──────────────────────────────────────────────── */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 1.25rem}
@media(min-width:768px){.container{padding:0 2rem}}

/* ── Header ─────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:100;height:var(--nav-h);background:var(--bg-white);border-bottom:2px solid var(--border);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:1.5rem}
.site-logo{display:flex;align-items:center;gap:.6rem;color:var(--dark);flex-shrink:0;transition:transform .15s ease}
.site-logo:hover{color:var(--dark);transform:rotate(-3deg)}
.logo-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0}
.logo-icon svg{display:block}
.logo-text{font-family:var(--font-display);font-size:1.35rem;font-weight:500;letter-spacing:-.01em;line-height:1}
.logo-text strong{font-weight:700;color:var(--primary);font-size:1.05em}
.site-footer .site-logo:hover{transform:none}
.site-nav{display:none}
@media(min-width:768px){
  .site-nav{display:flex;align-items:center}
  .site-nav>ul{display:flex;align-items:center;gap:.25rem}
  .site-nav a,.nav-dropdown-toggle{display:flex;align-items:center;gap:.3rem;padding:.5rem .85rem;font-weight:500;font-size:.95rem;color:var(--text);border-radius:var(--radius-sm);transition:background .15s,color .15s;min-height:44px;background:none;border:none;cursor:pointer}
  .site-nav a:hover,.nav-dropdown-toggle:hover,.site-nav a[aria-current="page"]{background:var(--primary-pale);color:var(--primary)}
  .has-dropdown{position:relative}
  .nav-dropdown{display:none;position:absolute;top:100%;left:0;min-width:200px;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.5rem;z-index:200;padding-top:.75rem;margin-top:0}
  .nav-dropdown::before{content:'';position:absolute;top:0;left:0;right:0;height:.75rem;background:transparent}
  .has-dropdown:hover .nav-dropdown,.nav-dropdown-toggle[aria-expanded="true"]+.nav-dropdown{display:block}
  .nav-dropdown-toggle{padding-bottom:.75rem}
  .nav-dropdown li a{border-radius:var(--radius-sm);font-size:.9rem;padding:.45rem .75rem;min-height:auto}
}
.nav-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}
@media(min-width:768px){.nav-toggle{display:none}}
.hamburger,.hamburger::before,.hamburger::after{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:transform .2s,opacity .2s}
.hamburger{position:relative}
.hamburger::before,.hamburger::after{content:'';position:absolute;left:0}
.hamburger::before{top:-6px}
.hamburger::after{top:6px}
.nav-open .site-nav{display:flex;flex-direction:column;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--bg-white);padding:1.5rem;overflow-y:auto;z-index:99}
.nav-open .site-nav>ul{flex-direction:column;width:100%;gap:.25rem}
.nav-open .site-nav a,.nav-open .nav-dropdown-toggle{font-size:1.1rem;min-height:52px;width:100%}
.nav-open .nav-dropdown{display:block;position:static;box-shadow:none;border:none;background:var(--bg-alt);margin-top:.25rem}
.nav-open .nav-toggle .hamburger{background:transparent}
.nav-open .nav-toggle .hamburger::before{transform:rotate(45deg) translate(4px,4px)}
.nav-open .nav-toggle .hamburger::after{transform:rotate(-45deg) translate(4px,-4px)}

/* ── Breadcrumb ─────────────────────────────────────────────── */
.breadcrumb{padding:.85rem 0;font-size:.85rem;color:var(--text-light)}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.breadcrumb li:not(:last-child)::after{content:'/';margin-left:.4rem;color:var(--text-xlight)}
.breadcrumb a{color:var(--text-light)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb li:last-child{color:var(--text);font-weight:500}

/* ── Page Hero (pages SEO catégorie/lettre) ───────────────── */
.page-hero{position:relative;background:linear-gradient(135deg,#4F46E5 0%,var(--primary) 50%,#7C3AED 100%);color:#fff;padding:3rem 0 3.5rem;overflow:hidden;isolation:isolate}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 90% 20%,rgba(253,224,71,.22) 0%,transparent 60%),radial-gradient(ellipse at 10% 100%,rgba(251,113,133,.18) 0%,transparent 60%);pointer-events:none;z-index:0}
.page-hero::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.1) 1px,transparent 0);background-size:22px 22px;mask-image:radial-gradient(ellipse at center,#000 20%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,#000 20%,transparent 80%);opacity:.5;pointer-events:none;z-index:0}
.page-hero-content{position:relative;z-index:1}

.page-hero-lettres{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.page-hero-lettre{
  position:absolute;font-family:var(--font-display);font-weight:700;
  color:rgba(255,255,255,.13);user-select:none;line-height:1;
  animation:flotte 10s ease-in-out infinite;
}
.page-hero-lettre.lettre-1{top:15%;left:3%;font-size:3.5rem;animation-delay:0s}
.page-hero-lettre.lettre-2{bottom:12%;left:7%;font-size:2.8rem;animation-delay:1.5s;color:rgba(253,224,71,.28)}
.page-hero-lettre.lettre-3{top:18%;right:5%;font-size:3.2rem;animation-delay:3s;color:rgba(251,113,133,.22)}
.page-hero-lettre.lettre-4{bottom:10%;right:4%;font-size:4rem;animation-delay:4.5s}
.page-hero-lettre.lettre-5{top:8%;left:46%;font-size:2.2rem;animation-delay:6s;color:rgba(52,211,153,.26)}
.page-hero-lettre.lettre-6{bottom:22%;left:22%;font-size:2.4rem;animation-delay:7.5s;color:rgba(253,224,71,.20)}
@media(max-width:700px){
  .page-hero-lettre.lettre-3,.page-hero-lettre.lettre-5{display:none}
  .page-hero-lettre{font-size:2.2rem}
}
@media(prefers-reduced-motion:reduce){.page-hero-lettre{animation:none}}
.hero-eyebrow{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--jaune);margin-bottom:.85rem;padding:.25rem .75rem;background:rgba(253,224,71,.15);border:1px solid rgba(253,224,71,.35);border-radius:999px}
.page-hero h1{color:#fff;margin-bottom:1rem;text-shadow:0 3px 12px rgba(15,23,42,.25)}
.hero-intro{font-size:1.1rem;color:rgba(255,255,255,.88);max-width:640px;line-height:1.7}

/* ── Article layout ─────────────────────────────────────────── */
.article-layout{display:flex;flex-direction:column;gap:2rem;padding:2.5rem 0 4rem}
@media(min-width:1024px){
  .article-layout{flex-direction:row;align-items:flex-start}
  .article-body{flex:1;min-width:0}
  .sidebar{width:280px;flex-shrink:0;position:sticky;top:calc(var(--nav-h) + 1.5rem)}
}
.article-body{line-height:1.9}
.article-body p{margin-bottom:1.25rem;color:var(--text)}
.article-body h2{margin-top:2.5rem;margin-bottom:1rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.article-body h2:first-child{margin-top:0;padding-top:0;border-top:none}
.article-body h3{margin-top:1.75rem;margin-bottom:.75rem}

/* ── Word grid ──────────────────────────────────────────────── */
.word-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.6rem;margin:1.25rem 0 1.75rem}
.word-card{display:flex;align-items:center;gap:.6rem;padding:.6rem .9rem;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;color:var(--text);box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}
.word-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow)}
.letter-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--primary-pale);color:var(--primary-dark);border-radius:6px;font-weight:800;font-family:var(--font-display);font-size:.85rem;flex-shrink:0}

/* ── Info/highlight box ─────────────────────────────────────── */
.info-box{background:var(--primary-pale);border-left:4px solid var(--primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:1.1rem 1.25rem;margin:1.5rem 0}
.info-box h3{color:var(--primary-dark);margin-top:0}
.info-box p{margin-bottom:0}
.highlight-box{background:var(--accent-pale);border-left:4px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:1.1rem 1.25rem;margin:1.5rem 0}
.highlight-box h3{color:#c2410c;margin-top:0}
.highlight-box p{margin-bottom:0}

/* ── Sidebar ─────────────────────────────────────────────────── */
.sidebar-block{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem}
.sidebar-toc li,.sidebar-links li{margin-bottom:.4rem}
.sidebar-toc a,.sidebar-links a{font-size:.9rem;color:var(--text-light)}
.sidebar-toc a:hover,.sidebar-links a:hover{color:var(--primary)}
.sidebar-cta{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius);padding:1.5rem;color:#fff}
.sidebar-cta h4{color:rgba(255,255,255,.75)}
.sidebar-cta p{font-size:.95rem;font-weight:600;margin-bottom:1rem}
.sidebar-cta a{display:inline-flex;align-items:center;padding:.6rem 1.1rem;background:#fff;color:var(--primary-dark);font-weight:700;font-size:.9rem;border-radius:var(--radius-sm);transition:transform .15s,box-shadow .15s;min-height:44px}
.sidebar-cta a:hover{transform:translateY(-1px);box-shadow:var(--shadow)}

/* ── Navigation lettres ─────────────────────────────────────── */
.lettre-nav-wrap{background:var(--bg-white);border-bottom:1px solid var(--border);padding:.75rem 0}
.lettre-nav{display:flex;flex-wrap:wrap;gap:.35rem}
.lettre-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-family:var(--font-display);font-weight:700;font-size:.9rem;border-radius:var(--radius-sm);text-decoration:none;transition:background .15s,color .15s;color:var(--text);background:var(--bg-alt);border:1px solid var(--border)}
.lettre-btn:hover{background:var(--primary-pale);color:var(--primary);border-color:var(--primary-light)}
.lettre-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.lettre-btn.disabled{opacity:.35;cursor:not-allowed;pointer-events:none}

/* ── Prev/Next ──────────────────────────────────────────────── */
.page-prevnext{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.prevnext-btn{display:inline-flex;align-items:center;padding:.6rem 1.1rem;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);font-weight:600;font-size:.9rem;color:var(--text);transition:background .15s,border-color .15s;min-height:44px}
.prevnext-btn:hover{background:var(--primary-pale);border-color:var(--primary-light);color:var(--primary)}

/* ── CTA block ──────────────────────────────────────────────── */
.cta-block{background:var(--primary-pale);border-radius:var(--radius-lg);padding:2rem;margin:2.5rem 0;text-align:center}
.cta-block p{margin-bottom:1.25rem;font-size:1.05rem}
.cta-play{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.5rem;background:var(--primary);color:#fff;font-weight:600;font-family:var(--font-display);font-size:1rem;border-radius:var(--radius);box-shadow:0 5px 0 var(--primary-deep),0 7px 14px rgba(15,23,42,.18);transition:transform .12s,box-shadow .12s;min-height:48px}
.cta-play:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 7px 0 var(--primary-deep),0 10px 20px rgba(15,23,42,.22)}
.cta-play:active{transform:translateY(2px);box-shadow:0 2px 0 var(--primary-deep),0 3px 6px rgba(15,23,42,.12)}

/* ── Boutons relief arcade ──────────────────────────────────── */
.btn{
  --btn-bg:var(--primary);
  --btn-shadow:var(--primary-deep);
  --btn-fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.75rem;
  border:none;border-radius:18px;
  font-family:var(--font-display);font-weight:600;font-size:1rem;
  background:var(--btn-bg);color:var(--btn-fg);
  cursor:pointer;text-decoration:none;
  box-shadow:0 5px 0 var(--btn-shadow),0 7px 14px rgba(15,23,42,.18);
  transition:transform .12s ease,box-shadow .12s ease,filter .12s ease;
  min-height:52px;white-space:nowrap;position:relative;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 7px 0 var(--btn-shadow),0 10px 20px rgba(15,23,42,.22);color:var(--btn-fg);filter:brightness(1.05)}
.btn:active{transform:translateY(3px);box-shadow:0 2px 0 var(--btn-shadow),0 2px 4px rgba(15,23,42,.12)}
.btn:focus-visible{outline:3px solid var(--primary-light);outline-offset:3px}

.btn-primary   {--btn-bg:var(--primary);--btn-shadow:var(--primary-deep);--btn-fg:#fff}
.btn-jaune     {--btn-bg:var(--jaune);--btn-shadow:var(--jaune-dark);--btn-fg:#78350F}
.btn-corail    {--btn-bg:var(--corail);--btn-shadow:var(--corail-dark);--btn-fg:#fff}
.btn-menthe    {--btn-bg:var(--menthe);--btn-shadow:var(--menthe-dark);--btn-fg:#fff}
.btn-blanc     {--btn-bg:#fff;--btn-shadow:rgba(15,23,42,.25);--btn-fg:var(--primary-deep)}
.btn-secondary {--btn-bg:#fff;--btn-shadow:rgba(15,23,42,.15);--btn-fg:var(--text);border:1px solid var(--border)}

.btn-lg{padding:1rem 2.1rem;font-size:1.1rem;min-height:58px;border-radius:20px}
.btn-xl{padding:1.15rem 2.5rem;font-size:1.2rem;min-height:64px;border-radius:22px;box-shadow:0 6px 0 var(--btn-shadow),0 9px 18px rgba(15,23,42,.22)}
.btn-xl:hover{box-shadow:0 8px 0 var(--btn-shadow),0 12px 24px rgba(15,23,42,.28)}
.btn-xl:active{box-shadow:0 2px 0 var(--btn-shadow),0 3px 6px rgba(15,23,42,.12)}

/* ── Category cards (page d'accueil & piliers) ─────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin:1.5rem 0}
.cat-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;background:var(--bg-white);border:2px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;text-decoration:none;color:var(--text)}
.cat-card:hover,.cat-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-pale);transform:translateY(-2px);color:var(--text)}
.cat-card.selected{background:var(--primary-pale)}
.cat-card .cat-icon{font-size:1.75rem}
.cat-card .cat-name{font-weight:600;font-size:.9rem}

/* ── Footer ─────────────────────────────────────────────────── */
.site-footer{background:var(--dark-deeper);color:rgba(255,255,255,.7);padding-top:3rem}
.footer-inner{display:flex;flex-direction:column;gap:2.5rem;padding-bottom:2.5rem}
@media(min-width:768px){.footer-inner{flex-direction:row;align-items:flex-start}}
.footer-brand{flex-shrink:0;max-width:240px}
.footer-brand .site-logo{color:#fff;margin-bottom:.75rem}
.footer-brand .logo-text{color:#fff}
.footer-tagline{font-size:.875rem;line-height:1.6}
.footer-nav{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
@media(min-width:1024px){.footer-nav{grid-template-columns:repeat(4,1fr)}}
.footer-col h3{font-family:var(--font-body);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.45);margin-bottom:.85rem}
.footer-col li{margin-bottom:.45rem}
.footer-col a{font-size:.875rem;color:rgba(255,255,255,.65);transition:color .15s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1rem 0}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.35);text-align:center}

/* ── Utility ─────────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.text-center{text-align:center}
.section-title{font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:1rem;font-weight:700;color:var(--dark);position:relative;display:inline-block}
.section-title.text-center{display:block}
.section-title::after{content:'';display:block;width:64px;height:5px;background:var(--jaune);border-radius:4px;margin:.65rem auto 0;box-shadow:0 2px 0 var(--jaune-dark)}
.text-center .section-title::after,.section-title.text-center::after{margin-left:auto;margin-right:auto}
.section-intro{color:var(--text-light);font-size:1.05rem;margin-bottom:2rem;max-width:640px;line-height:1.7}

/* ── Reveal animation ───────────────────────────────────────── */
.will-reveal{opacity:0;transform:translateY(12px);transition:opacity .4s,transform .4s}
.revealed{opacity:1;transform:none}

/* ============================================================
   JEU — styles spécifiques
   ============================================================ */

/* ============================================================
   HOME — Bannière d'accueil (identité ludique + mascotte)
   ============================================================ */
.accueil-banniere{
  position:relative;
  background:linear-gradient(135deg,#6366F1 0%,var(--primary) 45%,#8B5CF6 100%);
  color:#fff;
  padding:4rem 0 6rem;
  overflow:hidden;
  isolation:isolate;
}
.accueil-banniere::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.12) 1px,transparent 0);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse at 50% 40%,#000 0%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 40%,#000 0%,transparent 80%);
  opacity:.5;pointer-events:none;z-index:0;
}

.banniere-formes{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.forme{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5}
.forme-1{width:360px;height:360px;background:#FDE047;top:-100px;left:-80px;opacity:.35}
.forme-2{width:280px;height:280px;background:#F472B6;bottom:-80px;right:-60px;opacity:.4}
.forme-3{width:220px;height:220px;background:#22D3EE;top:30%;right:30%;opacity:.25}

.banniere-lettre{
  position:absolute;font-family:var(--font-display);font-weight:700;
  color:rgba(255,255,255,.12);user-select:none;line-height:1;
  animation:flotte 10s ease-in-out infinite;
}
.lettre-flot-1{top:12%;left:4%;font-size:5rem;animation-delay:0s}
.lettre-flot-2{top:68%;left:6%;font-size:3.8rem;animation-delay:1.5s;color:rgba(253,224,71,.25)}
.lettre-flot-3{top:18%;right:7%;font-size:4.5rem;animation-delay:3s;color:rgba(251,113,133,.20)}
.lettre-flot-4{top:75%;right:4%;font-size:5.5rem;animation-delay:4.5s}
.lettre-flot-5{top:6%;left:48%;font-size:3rem;animation-delay:6s;color:rgba(52,211,153,.25)}
.lettre-flot-6{top:80%;left:42%;font-size:3.5rem;animation-delay:7.5s;color:rgba(253,224,71,.18)}

@keyframes flotte{
  0%,100%{transform:translate(0,0) rotate(0deg)}
  33%{transform:translate(10px,-12px) rotate(-4deg)}
  66%{transform:translate(-8px,8px) rotate(5deg)}
}
@media(prefers-reduced-motion:reduce){.banniere-lettre{animation:none}}

.banniere-grille{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:2rem;
  align-items:center;
}
@media(min-width:900px){
  .banniere-grille{grid-template-columns:1.1fr .9fr;gap:3rem}
}

.banniere-texte{text-align:center}
@media(min-width:900px){.banniere-texte{text-align:left}}

.banniere-badge{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem 1rem;
  background:rgba(255,255,255,.14);border:1.5px solid rgba(255,255,255,.22);
  border-radius:999px;
  color:#fff;font-size:.82rem;font-weight:500;margin-bottom:1.5rem;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.banniere-badge-dot{
  width:9px;height:9px;border-radius:50%;background:var(--menthe);
  box-shadow:0 0 0 4px rgba(52,211,153,.35);
  flex-shrink:0;animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 4px rgba(52,211,153,.35)}50%{box-shadow:0 0 0 8px rgba(52,211,153,.12)}}

#banniere-title{
  color:#fff;
  font-size:clamp(2.5rem,6vw,4.2rem);
  margin-bottom:1.25rem;
  letter-spacing:-.01em;
  line-height:1.05;
  text-shadow:0 4px 16px rgba(15,23,42,.2);
}
.banniere-titre-accent{
  color:var(--jaune);
  display:inline-block;position:relative;
  text-shadow:0 3px 0 rgba(245,158,11,.45),0 6px 20px rgba(15,23,42,.25);
  animation:wobble 4s ease-in-out infinite;
  transform-origin:center;
}
@keyframes wobble{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
@media(prefers-reduced-motion:reduce){.banniere-titre-accent{animation:none}}

.banniere-intro{
  color:rgba(255,255,255,.92);
  font-size:clamp(1.02rem,1.5vw,1.18rem);
  max-width:540px;margin:0 auto 2rem;
  line-height:1.65;
}
@media(min-width:900px){.banniere-intro{margin:0 0 2rem}}

.banniere-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
@media(min-width:900px){.banniere-ctas{justify-content:flex-start}}

.banniere-chiffres{
  display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;
  max-width:480px;margin:0 auto;
  padding:1.25rem 1rem;
  background:rgba(255,255,255,.12);
  border:1.5px solid rgba(255,255,255,.2);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
@media(min-width:900px){.banniere-chiffres{margin:0}}
.banniere-chiffres li{display:flex;flex-direction:column;align-items:center;gap:.1rem;position:relative}
.banniere-chiffres li:not(:last-child)::after{
  content:'';position:absolute;top:15%;right:-.25rem;
  height:70%;width:2px;background:rgba(255,255,255,.18);border-radius:2px;
}
.chiffre-valeur{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.6rem,3.5vw,2.2rem);
  color:var(--jaune);
  line-height:1.1;
  text-shadow:0 2px 0 rgba(245,158,11,.35);
}
.chiffre-label{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;
  color:rgba(255,255,255,.85);font-weight:500;text-align:center;
}

/* ── Mascotte ─────────────────────────────────────────────── */
.banniere-mascotte{
  position:relative;display:flex;justify-content:center;align-items:center;
  min-height:280px;
}
.mascotte-halo{
  position:absolute;
  width:360px;height:360px;
  background:radial-gradient(circle,rgba(253,224,71,.35) 0%,transparent 65%);
  border-radius:50%;
  animation:pulse-halo 4s ease-in-out infinite;
}
@keyframes pulse-halo{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:.9}}
@media(prefers-reduced-motion:reduce){.mascotte-halo{animation:none}}

.mascotte-img{
  position:relative;z-index:2;
  width:min(280px,70vw);height:auto;
  animation:bob 3s ease-in-out infinite;
  filter:drop-shadow(0 18px 30px rgba(15,23,42,.3));
}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-12px) rotate(2deg)}}
@media(prefers-reduced-motion:reduce){.mascotte-img{animation:none}}

.bulle-mascotte{
  position:absolute;top:6%;right:0%;
  display:inline-block;
  padding:.7rem 1.1rem;
  background:#fff;color:var(--primary-deep);
  font-family:var(--font-display);font-weight:600;font-size:.92rem;line-height:1.3;
  border-radius:18px 18px 18px 4px;
  box-shadow:0 6px 18px rgba(15,23,42,.2);
  z-index:3;
  animation:bob-bulle 3s ease-in-out infinite;
  max-width:190px;
  text-align:center;
}
.bulle-mascotte::after{
  content:'';position:absolute;bottom:-8px;left:20%;
  width:0;height:0;
  border-left:8px solid transparent;border-right:8px solid transparent;
  border-top:10px solid #fff;
}
@keyframes bob-bulle{0%,100%{transform:translateY(0) rotate(3deg)}50%{transform:translateY(-8px) rotate(-3deg)}}
@media(prefers-reduced-motion:reduce){.bulle-mascotte{animation:none}}
@media(max-width:899px){
  .bulle-mascotte{top:0;right:3%}
  .banniere-mascotte{min-height:240px;margin-top:1rem}
}
@media(max-width:480px){
  .mascotte-img{width:180px}
  .mascotte-halo{width:260px;height:260px}
  .bulle-mascotte{font-size:.8rem;padding:.55rem .85rem;max-width:160px}
}

/* ── Vague de transition vers la section suivante ─────────── */
.banniere-vague{position:absolute;bottom:-1px;left:0;right:0;z-index:1;line-height:0;pointer-events:none}
.banniere-vague svg{width:100%;height:60px;display:block}

/* ============================================================
   HOME — 3 étapes (style ludique cartoon)
   ============================================================ */
.bloc-etapes{padding:5rem 0 4.5rem;background:var(--bg);position:relative}
.bloc-etapes .section-title{margin-bottom:.75rem}
.etapes-liste{display:grid;grid-template-columns:1fr;gap:1.75rem;max-width:1100px;margin:0 auto;list-style:none;padding:0}
@media(min-width:900px){.etapes-liste{grid-template-columns:repeat(3,1fr);gap:1.5rem}}
.etape-carte{
  position:relative;
  display:flex;flex-direction:column;gap:1rem;
  padding:2.5rem 1.75rem 1.75rem;
  background:var(--bg-white);
  border:3px solid var(--dark);
  border-radius:24px;
  box-shadow:0 6px 0 var(--dark);
  transition:transform .2s ease,box-shadow .2s ease;
}
.etape-carte:hover{transform:translateY(-4px);box-shadow:0 10px 0 var(--dark)}
.etape-carte:nth-child(1){--etape-couleur:var(--primary);--etape-bg:var(--primary-pale)}
.etape-carte:nth-child(2){--etape-couleur:var(--corail);--etape-bg:var(--corail-pale)}
.etape-carte:nth-child(3){--etape-couleur:var(--menthe-dark);--etape-bg:var(--menthe-pale)}
.etape-numero{
  position:absolute;top:-22px;left:24px;
  display:flex;align-items:center;justify-content:center;
  width:54px;height:54px;
  background:var(--etape-couleur);color:#fff;
  border:3px solid var(--dark);border-radius:50%;
  font-family:var(--font-display);font-weight:700;font-size:1.5rem;
  box-shadow:0 4px 0 var(--dark);
  flex-shrink:0;
}
.etape-contenu h3{color:var(--dark);margin-bottom:.5rem;font-weight:600}
.etape-contenu p{color:var(--text-light);font-size:.95rem;line-height:1.65;margin:0}

/* ============================================================
   HOME — Grille catégories (cartes relief)
   ============================================================ */
.bloc-categories{padding:5rem 0 4.5rem;background:linear-gradient(180deg,var(--primary-pale) 0%,var(--bg) 100%);position:relative}
.bloc-categories .section-title{margin-bottom:.75rem}
.categorie-grille{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;max-width:1100px;margin:0 auto}
@media(max-width:560px){.categorie-grille{grid-template-columns:repeat(2,1fr);gap:.85rem}}
.categorie-carte{
  position:relative;
  display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;
  padding:1.5rem 1.35rem;
  background:var(--bg-white);
  border:3px solid var(--dark);
  border-radius:20px;
  box-shadow:0 5px 0 var(--dark);
  text-decoration:none;color:var(--text);
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  overflow:hidden;
}
.categorie-carte::before{
  content:'';position:absolute;inset:0;
  background:var(--cat-color,var(--primary));
  opacity:0;transition:opacity .2s;z-index:0;
}
.categorie-carte>*{position:relative;z-index:1}
.categorie-carte:hover{transform:translateY(-4px);box-shadow:0 9px 0 var(--dark);color:#fff}
.categorie-carte:hover::before{opacity:1}
.categorie-carte:hover .categorie-nom,
.categorie-carte:hover .categorie-compteur{color:#fff}
.categorie-carte:active{transform:translateY(2px);box-shadow:0 3px 0 var(--dark)}
.categorie-icone{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;
  background:var(--cat-color,var(--primary));
  border:2.5px solid var(--dark);border-radius:14px;
  font-size:1.75rem;line-height:1;margin-bottom:.5rem;
  box-shadow:0 3px 0 var(--dark);
  transition:background .2s;
}
.categorie-carte:hover .categorie-icone{background:#fff}
.categorie-nom{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--dark);transition:color .15s}
.categorie-compteur{font-size:.82rem;color:var(--text-light);line-height:1.4;transition:color .15s}
@media(max-width:480px){.categorie-nom{font-size:.95rem}.categorie-compteur{font-size:.72rem}.categorie-carte{padding:1.1rem .95rem}.categorie-icone{width:46px;height:46px;font-size:1.4rem}}

.categorie-pays       {--cat-color:#3B82F6}
.categorie-animaux    {--cat-color:#F59E0B}
.categorie-villes     {--cat-color:#8B5CF6}
.categorie-prenoms    {--cat-color:#EC4899}
.categorie-metiers    {--cat-color:#14B8A6}
.categorie-celebrites {--cat-color:#EAB308}
.categorie-fruits     {--cat-color:#22C55E}
.categorie-sports     {--cat-color:#F97316}
.categorie-objets     {--cat-color:#64748B}

/* ============================================================
   HOME — Pourquoi jouer (cartes pastel)
   ============================================================ */
.bloc-pourquoi{padding:5rem 0 4.5rem;background:var(--bg-white);position:relative}
.pourquoi-entete{text-align:center;max-width:720px;margin:0 auto 3rem}
.pourquoi-entete .section-title{margin-bottom:.75rem}
.pourquoi-entete .section-intro{margin:0 auto;max-width:640px}
.pourquoi-grille{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}
.pourquoi-carte{
  padding:2rem 1.5rem 1.5rem;
  background:var(--pourquoi-bg,var(--primary-pale));
  border:3px solid var(--dark);
  border-radius:22px;
  box-shadow:0 6px 0 var(--dark);
  transition:transform .2s ease,box-shadow .2s ease;
}
.pourquoi-carte:hover{transform:translateY(-4px) rotate(-.5deg);box-shadow:0 10px 0 var(--dark)}
.pourquoi-carte:nth-child(1){--pourquoi-bg:var(--primary-pale);--pourquoi-accent:var(--primary)}
.pourquoi-carte:nth-child(2){--pourquoi-bg:var(--corail-pale);--pourquoi-accent:var(--corail-dark)}
.pourquoi-carte:nth-child(3){--pourquoi-bg:var(--jaune-pale);--pourquoi-accent:var(--jaune-dark)}
.pourquoi-carte:nth-child(4){--pourquoi-bg:var(--menthe-pale);--pourquoi-accent:var(--menthe-dark)}
.pourquoi-carte:nth-child(5){--pourquoi-bg:#EDE9FE;--pourquoi-accent:#7C3AED}
.pourquoi-carte:nth-child(6){--pourquoi-bg:#CFFAFE;--pourquoi-accent:#0891B2}
.pourquoi-carte:nth-child(even):hover{transform:translateY(-4px) rotate(.5deg)}
.pourquoi-icone{
  display:inline-flex;align-items:center;justify-content:center;
  width:60px;height:60px;
  background:#fff;
  border:2.5px solid var(--dark);border-radius:16px;
  font-size:1.8rem;margin-bottom:1rem;
  box-shadow:0 3px 0 var(--dark);
}
.pourquoi-carte h3{color:var(--dark);margin-bottom:.5rem;font-size:1.15rem;font-weight:600}
.pourquoi-carte p{color:var(--text);font-size:.95rem;line-height:1.65;margin:0}
.pourquoi-carte p a{color:var(--pourquoi-accent,var(--primary));font-weight:700;border-bottom:2px solid currentColor;transition:opacity .15s}
.pourquoi-carte p a:hover{opacity:.7}

/* ============================================================
   HOME — Pages populaires (boutons relief)
   ============================================================ */
.bloc-populaires{padding:5rem 0 5.5rem;background:linear-gradient(180deg,var(--bg) 0%,var(--jaune-pale) 100%);position:relative}
.populaires-entete{text-align:center;max-width:720px;margin:0 auto 2.5rem}
.populaires-entete .section-title{margin-bottom:.75rem}
.populaires-entete .section-intro{margin:0 auto}
.populaires-grille{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.85rem;max-width:1100px;margin:0 auto}
.populaire-carte{
  display:flex;align-items:center;gap:.85rem;
  padding:.95rem 1.15rem;
  background:var(--bg-white);
  border:2.5px solid var(--dark);border-radius:14px;
  box-shadow:0 4px 0 var(--dark);
  text-decoration:none;color:var(--text);font-weight:500;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.populaire-carte:hover{transform:translateY(-3px);box-shadow:0 7px 0 var(--dark);background:var(--pop-color,var(--primary));color:#fff}
.populaire-carte:hover .populaire-label,
.populaire-carte:hover .populaire-fleche{color:#fff}
.populaire-carte:active{transform:translateY(1px);box-shadow:0 3px 0 var(--dark)}
.populaire-icone{font-size:1.35rem;line-height:1;flex-shrink:0}
.populaire-label{flex:1;font-family:var(--font-display);font-size:.95rem;font-weight:500;color:var(--dark);transition:color .15s}
.populaire-fleche{font-size:1.4rem;color:var(--pop-color,var(--primary));font-weight:700;line-height:1;transition:transform .15s,color .15s}
.populaire-carte:hover .populaire-fleche{transform:translateX(4px)}

.populaire-pays       {--pop-color:#3B82F6}
.populaire-animaux    {--pop-color:#F59E0B}
.populaire-villes     {--pop-color:#8B5CF6}
.populaire-prenoms    {--pop-color:#EC4899}
.populaire-metiers    {--pop-color:#14B8A6}
.populaire-celebrites {--pop-color:#EAB308}

/* Game container */
#game-app{background:var(--bg-white);border:3px solid var(--dark);border-radius:24px;box-shadow:0 8px 0 var(--dark),0 16px 40px rgba(15,23,42,.15);overflow:hidden;margin:2.5rem 0;position:relative;z-index:3}

/* Game screens */
.game-screen{display:none;padding:2rem}
.game-screen.active{display:block}

/* Setup screen */
.setup-section{margin-bottom:2rem}
.setup-section h2{font-size:1.25rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.setup-section h2 .step-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--primary);color:#fff;border-radius:50%;font-size:.85rem;font-weight:700;font-family:var(--font-display);flex-shrink:0}
.cat-toggle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.6rem}
.cat-toggle{display:flex;align-items:center;gap:.6rem;padding:.6rem .85rem;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg);font-size:.9rem;font-weight:500;user-select:none}
.cat-toggle input{display:none}
.cat-toggle.on{border-color:var(--primary);background:var(--primary-pale);color:var(--primary-dark)}
.cat-toggle .cat-check{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,background .15s;font-size:.7rem}
.cat-toggle.on .cat-check{border-color:var(--primary);background:var(--primary);color:#fff}

.rounds-select{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}
.round-btn,.timer-btn,.letter-mode-btn{padding:.5rem 1rem;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;font-weight:600;font-size:.9rem;color:var(--text);transition:border-color .15s,background .15s,color .15s;min-height:44px;font-family:inherit}
.round-btn:hover,.timer-btn:hover,.letter-mode-btn:hover{border-color:var(--primary-light);background:var(--primary-pale);color:var(--primary-dark)}
.round-btn.active,.timer-btn.active,.letter-mode-btn.active{border-color:var(--primary);background:var(--primary-pale);color:var(--primary-dark)}

.mode-select{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}
.mode-card{flex:1;min-width:140px;padding:1rem;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg)}
.mode-card.active{border-color:var(--primary);background:var(--primary-pale)}
.mode-card .mode-icon{font-size:1.5rem;margin-bottom:.35rem}
.mode-card .mode-name{font-weight:700;font-size:.95rem}
.mode-card .mode-desc{font-size:.8rem;color:var(--text-light);margin-top:.25rem}

.players-setup{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}
.player-row{display:flex;gap:.5rem;align-items:center}
.player-input{flex:1;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;background:var(--bg-white)}
.player-input:focus{outline:2px solid var(--primary);border-color:transparent}
.btn-remove-player{width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:none;cursor:pointer;color:var(--text-light);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.btn-remove-player:hover{background:var(--danger);color:#fff;border-color:var(--danger)}

.start-bar{background:var(--bg-alt);border-top:1px solid var(--border);padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.selected-summary{font-size:.9rem;color:var(--text-light)}
.selected-summary strong{color:var(--primary);font-weight:700}

/* Playing screen */
.game-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--dark);color:#fff;gap:1rem;flex-wrap:wrap}
.game-meta{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.game-meta-item{display:flex;flex-direction:column;align-items:center}
.game-meta-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5)}
.game-meta-value{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:#fff}
.game-letter-display{font-family:var(--font-display);font-weight:800;font-size:2.5rem;color:var(--primary-light);line-height:1}

.timer-bar-wrap{height:5px;background:rgba(255,255,255,.15)}
.timer-bar{height:100%;background:var(--primary-light);transition:width 1s linear;width:100%}
.timer-bar.urgent{background:var(--accent)}

.game-fields{padding:1.5rem 2rem;display:grid;gap:1rem}
@media(min-width:768px){.game-fields{grid-template-columns:repeat(2,1fr)}}
.field-group{display:flex;flex-direction:column;gap:.35rem}
.field-label{font-weight:600;font-size:.9rem;color:var(--text)}
.field-input{padding:.7rem 1rem;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;background:var(--bg-white);transition:border-color .15s;width:100%}
.field-input:focus{outline:none;border-color:var(--primary)}
.field-input.filled{border-color:var(--success)}
.field-input:disabled{background:var(--bg-alt);color:var(--text-light)}

.stop-bar{padding:1.25rem 2rem;background:var(--bg-alt);border-top:1px solid var(--border);display:flex;justify-content:center}
.btn-stop{background:var(--corail);color:#fff;font-size:1.3rem;padding:1rem 3rem;border-radius:20px;font-family:var(--font-display);font-weight:700;border:none;cursor:pointer;min-height:60px;box-shadow:0 6px 0 var(--corail-dark),0 10px 20px rgba(15,23,42,.22);transition:transform .12s,box-shadow .12s;letter-spacing:.02em}
.btn-stop:hover{transform:translateY(-2px);box-shadow:0 8px 0 var(--corail-dark),0 12px 24px rgba(15,23,42,.28)}
.btn-stop:active{transform:translateY(3px);box-shadow:0 2px 0 var(--corail-dark),0 3px 6px rgba(15,23,42,.15)}

/* Validation screen */
.validation-header{padding:1.25rem 2rem;background:var(--bg-alt);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.validation-title{font-family:var(--font-display);font-weight:700;font-size:1.1rem}
.validation-letter{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--primary);color:#fff;border-radius:8px;font-family:var(--font-display);font-weight:800;font-size:1.1rem}

.validation-table{width:100%;border-collapse:collapse;font-size:.9rem}
.validation-table th{background:var(--bg-alt);padding:.6rem .85rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);border-bottom:1px solid var(--border)}
.validation-table td{padding:.6rem .85rem;border-bottom:1px solid var(--border);vertical-align:middle}
.validation-table tr:last-child td{border-bottom:none}
.answer-cell{display:flex;align-items:center;gap:.5rem}
.answer-text{font-weight:500}
.answer-text.empty{color:var(--text-xlight);font-style:italic}
.validate-toggle{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;padding:.45rem .9rem;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg);font-size:.82rem;font-weight:700;transition:all .18s;user-select:none;white-space:nowrap;line-height:1.2}
.validate-toggle:not([disabled]):hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(0,0,0,.18);filter:brightness(.92)}
.validate-toggle:not([disabled]):active{transform:translateY(0);box-shadow:none;filter:brightness(.85)}
.validate-toggle.valid{border-color:var(--success);background:#f0fdf4;color:#15803d}
.validate-toggle.valid::after{content:" ↺";opacity:.45;font-size:.75em}
.validate-toggle.pending{border-color:#f97316;background:#fff3e8;color:#c2410c;font-weight:700}
.validate-toggle.invalid{border-color:var(--danger);background:#fef2f2;color:#b91c1c;border-width:2px}
.validate-toggle.invalid::after{content:" — Accepter ?";font-size:.78em;font-weight:600;opacity:.75}
.points-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;border-radius:12px;font-size:.75rem;font-weight:700;font-family:var(--font-display);padding:0 6px}
.points-badge.double{background:#fef9c3;color:#854d0e}
.points-badge.single{background:#f0fdf4;color:#15803d}
.points-badge.zero{background:var(--bg-alt);color:var(--text-xlight)}

.validation-actions{padding:1.25rem 2rem;display:flex;justify-content:flex-end;gap:.75rem;border-top:1px solid var(--border)}

/* Scores screen */
.scores-podium{display:flex;align-items:flex-end;justify-content:center;gap:1rem;padding:2rem;flex-wrap:wrap}
.podium-slot{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.podium-rank{font-size:1.5rem}
.podium-name{font-weight:700;font-size:.95rem;text-align:center}
.podium-score{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--primary)}
.podium-bar{width:80px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:var(--primary-pale);border:2px solid var(--primary-light)}
.podium-slot.first .podium-bar{background:var(--primary);border-color:var(--primary-dark)}

.scores-table-wrap{padding:0 2rem 2rem;overflow-x:auto}
.scores-table{width:100%;border-collapse:collapse;font-size:.9rem}
.scores-table th{background:var(--bg-alt);padding:.6rem .85rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);border-bottom:1px solid var(--border)}
.scores-table td{padding:.7rem .85rem;border-bottom:1px solid var(--border);font-weight:500}
.scores-table tr:first-child td{font-weight:700;background:#fef9c3}
.score-total{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:var(--primary)}

.scores-actions{padding:1.25rem 2rem;display:flex;justify-content:center;gap:1rem;border-top:1px solid var(--border);flex-wrap:wrap}

/* Robot indicator */
.robot-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;background:var(--bg-alt);border-radius:999px;font-size:.75rem;color:var(--text-light);border:1px solid var(--border)}
