/* =========================================================
   Capitole · Prépa CRFPA
   Esthétique : revue de droit / éditorial premium
   ========================================================= */

:root{
  /* palette claire (ivoire chaud + oxblood) */
  --paper:        #faf6ee;
  --paper-2:      #f3ebde;
  --surface:      #fffdf8;
  --surface-2:    #f6efe2;
  --ink:          #211c16;
  --ink-soft:     #4a4034;
  --ink-faint:    #8c8070;
  --line:         #e3d8c4;
  --line-soft:    #ece3d3;

  --wine:         #1f3f63;   /* accent principal (bleu nuit / encre) */
  --wine-deep:    #142a45;
  --wine-tint:    #e7edf4;
  --gold:         #9a6b1e;
  --gold-tint:    #f5ebd6;
  --navy:         #28415e;
  --navy-tint:    #e6ecf3;
  --forest:       #355c43;
  --forest-tint:  #e6efe6;

  /* catégories de cartes */
  --c-def:        #28415e;   --c-def-bg:   #e8eef5;
  --c-cond:       #355c43;   --c-cond-bg:  #e7f0e8;
  --c-reg:        #5a4a86;   --c-reg-bg:   #ece8f5;
  --c-sanc:       #9b2c2c;   --c-sanc-bg:  #f7e6e3;
  --c-jp:         #8a5a12;   --c-jp-bg:    #f6ecd5;
  --c-piege:      #b4530a;   --c-piege-bg: #fce9d8;

  --radius:       14px;
  --radius-sm:    9px;
  --shadow-sm:    0 1px 2px rgba(40,30,20,.05), 0 1px 3px rgba(40,30,20,.05);
  --shadow:       0 4px 14px rgba(60,40,25,.08), 0 1px 3px rgba(60,40,25,.06);
  --shadow-lg:    0 18px 50px rgba(50,30,20,.16);

  --serif:   "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --display: "Playfair Display", Georgia, serif;
  --mono:    "IBM Plex Mono", ui-monospace, monospace;

  --sidebar-w: 312px;
  --maxw: 1040px;
}

[data-theme="dark"]{
  --paper:     #0d0f14;   /* noir-ardoise froid */
  --paper-2:   #11141b;
  --surface:   #161a22;
  --surface-2: #1d222c;
  --ink:       #eef1f6;
  --ink-soft:  #b6bdca;
  --ink-faint: #7c8595;
  --line:      #29303c;
  --line-soft: #1f2530;

  --wine:      #7aa8de;   /* bleu clair, ressort sur le sombre */
  --wine-deep: #a3c6ee;
  --wine-tint: #18283c;
  --gold:      #e0b667;
  --gold-tint: #2a2417;
  --navy:      #8fb8e6;
  --navy-tint: #15202e;
  --forest:    #74cf9a;
  --forest-tint:#13231b;

  --c-def:#8fb8e6;  --c-def-bg:#14202e;
  --c-cond:#74cf9a; --c-cond-bg:#12231a;
  --c-reg:#b6a6ec;  --c-reg-bg:#1e1a2c;
  --c-sanc:#f08b97; --c-sanc-bg:#2a1820;
  --c-jp:#e0b667;   --c-jp-bg:#272014;
  --c-piege:#f0a06a; --c-piege-bg:#2a1d12;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.45);
  --shadow:    0 8px 26px rgba(0,0,0,.5);
  --shadow-lg: 0 28px 70px rgba(0,0,0,.6);
}

[data-theme="white"]{
  /* papier blanc net : fond blanc, neutres froids, mêmes accents */
  --paper:     #ffffff;
  --paper-2:   #f4f6f9;
  --surface:   #ffffff;
  --surface-2: #f6f8fb;
  --ink:       #1a1e26;
  --ink-soft:  #454c59;
  --ink-faint: #8a93a3;
  --line:      #e5e9f0;
  --line-soft: #eef1f6;

  --wine-tint: #e9eef5;
  --gold-tint: #f4ecdb;
  --navy-tint: #e9eef6;
  --forest-tint:#e8f1ea;

  --shadow-sm: 0 1px 2px rgba(24,33,54,.05), 0 1px 3px rgba(24,33,54,.05);
  --shadow:    0 4px 16px rgba(24,33,54,.07), 0 1px 3px rgba(24,33,54,.06);
  --shadow-lg: 0 18px 50px rgba(24,33,54,.13);
}
[data-theme="white"] body::before{
  background:
    radial-gradient(1200px 600px at 78% -10%, var(--navy-tint), transparent 62%),
    radial-gradient(900px 500px at 0% 100%, #eef1f6, transparent 55%);
  opacity:.5;
}

[data-theme="dark"] body::before{
  opacity:.55;
  background:
    radial-gradient(1100px 620px at 82% -12%, #18253c, transparent 60%),
    radial-gradient(880px 520px at -6% 106%, #221a2c, transparent 55%);
}
/* en sombre, la sidebar passe en bleu nuit profond */
[data-theme="dark"] .sidebar{ background:linear-gradient(180deg, #12151c, #0d0f14); }
[data-theme="dark"] .brand-mark img{ filter:drop-shadow(0 4px 14px rgba(0,0,0,.5)); }

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:18px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* contrôles de formulaire : hériter de la police du corps (sinon Arial par défaut du navigateur) */
button, input, select, textarea{ font-family:inherit; }

/* ============================================================
   TITRES · police d'affichage (Playfair Display)
   Serif éditoriale nette et homogène pour tous les titres.
   ============================================================ */
.brand-title, .gami-level, .hero h1, .home-card h3, .tool-card strong,
.content h2.section-title, .h-rule h3, .notion-head h4, .flash-q,
.arrets-head h4, .table-block .tb-title, .quiz-head h3, .checklist-head h4,
.cheat-card h4, .m-body h4, .proto-card h4, .case-head h3, .cor-q h5,
.section-nav .sn-title{
  font-variant-ligatures:no-discretionary-ligatures;
}
/* texture subtile en fond */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(1200px 600px at 78% -10%, var(--wine-tint), transparent 60%),
    radial-gradient(900px 500px at 0% 100%, var(--gold-tint), transparent 55%);
  opacity:.5;
}
[data-theme="dark"] body::before{ opacity:.35; }

a{ color:var(--wine); text-decoration:none; }
a:hover{ text-decoration:underline; }

/* ===================== LAYOUT ===================== */
.layout{ display:flex; min-height:100vh; }

/* ===================== SIDEBAR ===================== */
.sidebar{
  width:var(--sidebar-w); flex:0 0 var(--sidebar-w);
  position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column;
  background:linear-gradient(180deg, var(--surface), var(--paper));
  border-right:1px solid var(--line);
  z-index:60;
}
.brand{
  display:flex; align-items:center; gap:14px;
  padding:22px 22px 16px;
  border-bottom:1px solid var(--line-soft);
}
.brand-mark{
  width:50px; height:50px; flex:0 0 50px;
  display:grid; place-items:center;
}
.brand-mark img{ width:100%; height:100%; display:block; filter:drop-shadow(0 5px 14px rgba(20,42,69,.30)); }
.brand-title{ font-family:var(--display); font-weight:600; font-size:20px; letter-spacing:-.01em; line-height:1.08; }
.brand-sub{ font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-faint); margin-top:3px; }
/* Logo + nom de la bannière = lien vers l'accueil (le bouton × mobile reste hors du lien) */
.brand-home{ display:flex; align-items:center; gap:14px; min-width:0; flex:1 1 auto; text-decoration:none; color:inherit; border-radius:10px; transition:opacity .14s; }
.brand-home:hover{ opacity:.82; text-decoration:none; }
.brand-home:hover .brand-title{ color:var(--wine); }

.side-search{ padding:14px 16px 8px; }
.side-search input{
  width:100%; padding:10px 13px; font-family:var(--serif); font-size:14px;
  color:var(--ink); background:var(--surface-2);
  border:1px solid var(--line); border-radius:10px; outline:none;
  transition:border-color .15s, box-shadow .15s;
}
.side-search input:focus{ border-color:var(--wine); box-shadow:0 0 0 3px var(--wine-tint); }
/* Accessibilité : focus clavier visible sur tous les éléments interactifs (a11y) */
:focus-visible{ outline:2px solid var(--wine); outline-offset:2px; }
/* Texte réservé aux lecteurs d'écran (ex. état « verrouillé ») */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
/* Respect de la préférence « animations réduites » */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ transition:none !important; animation:none !important; scroll-behavior:auto !important; }
}
/* Fil d'Ariane */
#crumb a{ color:inherit; text-decoration:none; }
#crumb a:hover{ color:var(--wine); text-decoration:underline; text-underline-offset:2px; }
.crumb-sep{ margin:0 7px; opacity:.5; }
.crumb-cur{ color:var(--ink); }
.side-search input::placeholder{ color:var(--ink-faint); }

.nav{ flex:1; overflow-y:auto; padding:6px 10px 18px; scrollbar-width:thin; }
.nav::-webkit-scrollbar{ width:8px; }
.nav::-webkit-scrollbar-thumb{ background:var(--line); border-radius:8px; }

.nav-chap{ margin:3px 0; }
.nav-chap > button{
  display:flex; align-items:center; gap:9px; width:100%;
  padding:9px 11px; border:none; background:none; cursor:pointer;
  font-family:var(--serif); font-size:14.5px; font-weight:600; color:var(--ink);
  text-align:left; border-radius:9px; transition:background .14s;
}
.nav-chap > button:hover{ background:var(--surface-2); }
.nav-chap-num{
  font-family:var(--mono); font-size:10px; font-weight:600;
  width:22px; height:22px; flex:0 0 22px; display:grid; place-items:center;
  border-radius:7px; background:var(--wine-tint); color:var(--wine);
}
.nav-chap-title{ flex:1; line-height:1.25; }
.nav-caret{ color:var(--ink-faint); transition:transform .2s; font-size:11px; }
.nav-chap.open .nav-caret{ transform:rotate(90deg); }

.nav-sections{ overflow:hidden; max-height:0; transition:max-height .28s ease; }
.nav-chap.open .nav-sections{ max-height:3000px; }
.nav-sections a{
  position:relative; display:flex; align-items:center; gap:9px;
  padding:7px 11px 7px 38px; font-size:13.5px; color:var(--ink-soft);
  border-radius:8px; margin:1px 0; line-height:1.3; transition:background .12s, color .12s;
}
.nav-sections a:hover{ background:var(--surface-2); color:var(--ink); text-decoration:none; }
.nav-sections a.active{ background:var(--wine-tint); color:var(--wine); font-weight:600; }
.nav-sec-t{ flex:1; }
.nav-dot{ position:absolute; left:20px; top:50%; transform:translateY(-50%); width:6px; height:6px; flex:0 0 6px;
  border-radius:50%; border:1.5px solid var(--line); background:transparent; transition:all .2s; }
.nav-dot.done{ background:var(--forest); border-color:var(--forest); box-shadow:0 0 0 3px color-mix(in srgb, var(--forest) 22%, transparent); }
.nav-synth{ margin-top:3px !important; }
.nav-synth .nav-sec-t{ font-style:italic; color:var(--gold); font-size:13px; }
.nav-synth.active .nav-sec-t{ color:var(--wine); }

/* ===== Verrou contenu (compte requis hors chapitre d'intro) ===== */
.nav-lock{ font-size:11px; line-height:1; opacity:.75; flex:0 0 auto; }
.nav-sections a.locked{ opacity:.6; }
.nav-sections a.locked .nav-sec-t{ color:var(--ink-faint); font-weight:400; }
.nav-sections a.locked:hover{ opacity:.85; background:var(--surface-2); }
/* Teaser façon paywall : début réel de la section, fondu + flou, puis carte CTA */
.locked-teaser{ position:relative; min-height:200px; max-height:320px; overflow:hidden; }
.locked-teaser::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:170px; pointer-events:none;
  background:linear-gradient(to bottom, transparent, var(--paper) 92%);
  -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px);
  -webkit-mask-image:linear-gradient(to bottom, transparent, #000 55%); mask-image:linear-gradient(to bottom, transparent, #000 55%); }
.locked-gate{ position:relative; z-index:1; margin:-52px auto 28px; max-width:540px; text-align:center;
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:30px 28px 26px; box-shadow:var(--shadow-lg); }
.locked-gate .locked-ico{ font-size:34px; line-height:1; margin-bottom:12px; }
.locked-gate h3{ font-family:var(--display); font-weight:600; font-size:23px; letter-spacing:-.01em; margin:0 0 10px; color:var(--ink); }
.locked-gate-msg{ font-size:14.5px; color:var(--ink-soft); line-height:1.6; margin:0 auto 20px; max-width:46ch; }
.locked-cta{ font-family:var(--mono); font-size:13px; font-weight:600; letter-spacing:.02em; cursor:pointer; color:#fff; background:linear-gradient(var(--wine),var(--wine-deep)); border:none; border-radius:999px; padding:13px 28px; box-shadow:var(--shadow); transition:transform .15s ease, box-shadow .15s ease; }
.locked-cta:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.locked-alt{ font-size:13px; color:var(--ink-faint); margin:14px 0 0; }
.locked-alt a{ color:var(--wine); text-decoration:underline; text-underline-offset:2px; cursor:pointer; }
.locked-loading{ max-width:540px; margin:14vh auto; text-align:center; color:var(--ink-soft); }
.locked-loading .locked-ico{ font-size:30px; line-height:1; margin-bottom:10px; opacity:.75; }
.locked-loading p{ font-family:var(--mono); font-size:13px; letter-spacing:.02em; margin:0; }

.side-foot{ padding:12px 16px 16px; border-top:1px solid var(--line-soft); }
.gami{ background:var(--surface-2); border:1px solid var(--line); border-radius:12px; padding:12px 14px; }
.gami-top{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; margin-bottom:9px; }
.gami-level{ font-family:var(--display); font-weight:600; font-size:15px; color:var(--ink); letter-spacing:-.01em; }
.gami-xp{ font-family:var(--mono); font-size:11px; font-weight:600; color:var(--wine); }
.gami-bar{ height:7px; background:color-mix(in srgb, var(--ink-faint) 18%, transparent); border-radius:7px; overflow:hidden; }
.gami-bar span{ display:block; height:100%; width:0; border-radius:7px; background:linear-gradient(90deg, var(--gold), var(--wine)); transition:width .5s cubic-bezier(.2,.8,.2,1); }
.gami-sub{ font-family:var(--mono); font-size:9.5px; letter-spacing:.02em; color:var(--ink-faint); margin-top:7px; line-height:1.3; }

/* ===================== MAIN ===================== */
.main{ flex:1; min-width:0; display:flex; flex-direction:column; }
.topbar{
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:13px 32px;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.kicker{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }
.topbar-left{ display:flex; align-items:center; gap:14px; min-width:0; }
.home-back{ flex:0 0 auto; font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink); text-decoration:none; background:var(--surface); border:1px solid color-mix(in srgb, var(--ink) 26%, transparent); border-radius:999px; padding:6px 12px; box-shadow:var(--shadow-sm); transition:all .15s; white-space:nowrap; }
.home-back:hover{ color:var(--wine); border-color:var(--wine); background:var(--wine-tint); text-decoration:none; }
.topbar-actions{ display:flex; align-items:center; gap:9px; }
.pill{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:500;
  padding:8px 14px; border-radius:999px; cursor:pointer;
  color:var(--wine); background:var(--wine-tint); border:1px solid color-mix(in srgb, var(--wine) 42%, transparent);
  box-shadow:var(--shadow-sm); transition:all .15s;
}
.pill:hover{ color:#fff; background:var(--wine); border-color:var(--wine); }
.pill.on{ background:var(--wine); color:#fff; border-color:var(--wine); }
.icon-btn{
  width:38px; height:38px; display:grid; place-items:center; cursor:pointer;
  border-radius:10px; color:var(--ink); background:var(--surface); border:1px solid color-mix(in srgb, var(--ink) 26%, transparent);
  box-shadow:var(--shadow-sm); transition:all .15s;
}
.icon-btn:hover{ color:var(--wine); border-color:var(--wine); background:var(--wine-tint); }
.icon-btn .moon{ display:none; }
[data-theme="dark"] .icon-btn .sun{ display:none; }
[data-theme="dark"] .icon-btn .moon{ display:block; }

/* ---- sélecteur de thème (3 coloris : beige · blanc · nuit) ---- */
.theme-pick{ display:inline-flex; align-items:center; gap:5px; padding:4px 5px;
  border-radius:11px; background:var(--surface); border:1px solid var(--line);
  box-shadow:var(--shadow-sm); }
.theme-pick .sw{ width:19px; height:19px; padding:0; border-radius:6px; cursor:pointer;
  border:1px solid color-mix(in srgb, var(--ink) 20%, transparent);
  transition:transform .12s ease, box-shadow .12s ease; }
.theme-pick .sw:hover{ transform:translateY(-1px); }
.theme-pick .sw[data-th="light"]{ background:linear-gradient(135deg,#f7f1e6,#ecdfc8); }
.theme-pick .sw[data-th="white"]{ background:#ffffff; }
.theme-pick .sw[data-th="dark"]{ background:linear-gradient(135deg,#222834,#11141b); }
.theme-pick .sw.active{ box-shadow:0 0 0 2px var(--surface), 0 0 0 3.5px var(--wine); }

/* ===== Header de site (pages autonomes : légales, classement), repris du portail ===== */
.site-header{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:22px clamp(20px,5vw,56px); }
.site-header .brand{ display:flex; align-items:center; gap:14px; padding:0; border:none; text-decoration:none; }
.site-header .brand-mark{ width:50px; height:50px; flex:0 0 50px; display:grid; place-items:center; }
.site-header .brand-mark img{ width:100%; height:100%; display:block; filter:drop-shadow(0 5px 14px rgba(20,42,69,.30)); }
[data-theme="dark"] .site-header .brand-mark img{ filter:drop-shadow(0 5px 16px rgba(0,0,0,.55)); }
.site-header .brand-txt{ font-family:var(--display); font-weight:600; font-size:27px; line-height:1; letter-spacing:-.015em; color:var(--ink); }
.site-header .theme-btn{ width:40px; height:40px; display:grid; place-items:center; cursor:pointer; border-radius:10px; color:var(--ink); background:var(--surface); border:1px solid color-mix(in srgb, var(--ink) 26%, transparent); box-shadow:var(--shadow-sm); transition:all .15s; }
.site-header .theme-btn:hover{ color:var(--wine); border-color:var(--wine); background:var(--wine-tint); }
.site-header .theme-btn .moon{ display:none; }
[data-theme="dark"] .site-header .theme-btn .sun{ display:none; }
[data-theme="dark"] .site-header .theme-btn .moon{ display:block; }
@media (max-width:600px){ .site-header{ flex-direction:column; align-items:flex-start; gap:14px; padding:16px 20px; } .site-header .brand-txt{ font-size:22px; } .site-header .crfpa-topbar-right{ flex-wrap:wrap; } }

/* Pages autonomes (légales, classement) : footer collé en bas, l'espace vide va dans le main */
body.site-page{ display:flex; flex-direction:column; min-height:100vh; }
body.site-page > main{ flex:1; }

.content{ width:100%; max-width:var(--maxw); margin:0 auto; padding:42px 32px 40px; flex:1; }

/* ===================== HERO / HOME ===================== */
.hero{ margin-bottom:34px; }
.hero-eyebrow{ font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--wine); margin-bottom:14px; }
.hero h1{ font-family:var(--display); font-weight:600; font-size:clamp(38px,6vw,62px); line-height:1.02; letter-spacing:-.02em; margin:0 0 16px; }
.hero h1 em{ font-style:italic; color:var(--wine); }
.hero-lead{ font-size:21px; color:var(--ink-soft); max-width:60ch; line-height:1.5; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.hero-meta span{ font-family:var(--mono); font-size:11px; padding:6px 12px; border:1px solid color-mix(in srgb, var(--ink) 26%, transparent); border-radius:999px; color:var(--ink-soft); background:var(--surface); box-shadow:var(--shadow-sm); }

.home-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(225px,1fr)); gap:16px; margin-top:18px; }
.home-card{
  display:block; padding:22px 20px; border-radius:var(--radius);
  background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow-sm);
  transition:transform .16s, box-shadow .16s, border-color .16s; cursor:pointer; text-align:left;
}
.home-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--wine); text-decoration:none; }
.home-card .hc-num{ font-family:var(--mono); font-size:11px; color:var(--wine); letter-spacing:.08em; }
.home-card h3{ font-family:var(--display); font-weight:600; font-size:20px; margin:8px 0 7px; line-height:1.15; color:var(--ink); }
.home-card p{ margin:0; font-size:14.5px; color:var(--ink-soft); line-height:1.45; }

.home-tools{ display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:13px; margin-top:16px; }
.tool-card{ padding:16px 18px; border-radius:12px; border:1px dashed var(--line); background:var(--surface); cursor:pointer; transition:all .15s; }
.tool-card:hover{ border-style:solid; border-color:var(--gold); transform:translateY(-2px); }
.tool-card strong{ font-family:var(--display); font-size:16px; display:block; margin-bottom:3px; }
.tool-card span{ font-size:13px; color:var(--ink-soft); }

/* ===================== TYPO CONTENU ===================== */
.section-head{ margin:0 0 26px; }
.section-head .kicker{ display:block; margin-bottom:9px; color:var(--wine); }
.content h2.section-title{
  font-family:var(--display); font-weight:600; font-size:clamp(28px,4.4vw,42px);
  line-height:1.06; letter-spacing:-.018em; margin:0 0 12px;
}
.section-lead{ font-size:19px; color:var(--ink-soft); line-height:1.55; max-width:64ch; }

.block{ margin:26px 0; }
.prose p{ margin:0 0 15px; }
.prose p:last-child{ margin-bottom:0; }
.prose strong{ font-weight:600; color:var(--ink); }
.prose em{ font-style:italic; }
.prose ul{ margin:12px 0; padding-left:0; list-style:none; }
.prose ul li{ position:relative; padding-left:24px; margin:8px 0; }
.prose ul li::before{ content:""; position:absolute; left:0; top:.62em; width:13px; height:2px; background:var(--wine); border-radius:1px; }

.h-rule{ display:flex; align-items:center; gap:14px; margin:38px 0 22px; }
.h-rule h3{ font-family:var(--display); font-weight:600; font-size:23px; margin:0; letter-spacing:-.01em; white-space:nowrap; }
.h-rule::after{ content:""; flex:1; height:1px; background:var(--line); }

/* référence article inline */
.art{ font-family:var(--mono); font-size:.82em; font-weight:500; color:var(--wine);
  background:var(--wine-tint); padding:1px 6px; border-radius:5px; white-space:nowrap; }
[data-theme="dark"] .art{ background:var(--wine-tint); }

/* ===================== NOTION (def/cond/régime/sanction/piège) ===================== */
.notion{
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  background:var(--surface); box-shadow:var(--shadow-sm);
}
.notion-head{
  padding:16px 20px; border-bottom:1px solid var(--line-soft);
  background:linear-gradient(180deg, var(--surface-2), var(--surface));
  display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;
}
.notion-head h4{ font-family:var(--display); font-weight:600; font-size:21px; margin:0; letter-spacing:-.01em; }
.notion-head .tag{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--wine); background:var(--wine-tint); border:1px solid color-mix(in srgb, var(--wine) 22%, transparent); border-radius:6px; padding:3px 9px; white-space:nowrap; }
.notion-head .tag.art{ cursor:pointer; font-size:11px; }
.facet-all{ margin-left:auto; align-self:center; font-family:var(--mono); font-size:11px; letter-spacing:.03em; color:var(--ink-soft); background:transparent; border:1px solid var(--line); border-radius:7px; padding:4px 10px; cursor:pointer; transition:background .12s, color .12s; }
.facet-all:hover{ background:var(--surface-2); color:var(--ink); }
.facets{ display:flex; flex-direction:column; }
.facet{ border-top:1px solid var(--line-soft); }
.facet:first-child{ border-top:none; }
.facet-btn{
  width:100%; display:flex; align-items:center; gap:12px; padding:13px 20px;
  border:none; background:none; cursor:pointer; text-align:left;
  font-family:var(--serif); transition:background .12s;
}
.facet-btn:hover{ background:var(--surface-2); }
.facet-label{ display:flex; align-items:center; gap:9px; font-weight:600; font-size:15px; flex:1; }
.facet-chip{
  font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase;
  padding:3px 8px; border-radius:6px; font-weight:600;
}
.facet-toggle{ font-family:var(--mono); font-size:11px; color:var(--ink-faint); border:1px solid var(--line); padding:3px 9px; border-radius:999px; transition:all .14s; }
.facet.open .facet-toggle{ color:var(--wine); border-color:var(--wine); }
.facet-body{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.facet.open .facet-body{ max-height:1600px; }
.facet-inner{ padding:2px 20px 18px 20px; font-size:16px; color:var(--ink-soft); line-height:1.55; }
.facet-inner ul{ margin:6px 0 0; padding-left:0; list-style:none; }
.facet-inner ul li{ position:relative; padding-left:22px; margin:7px 0; }
.facet-inner ul li::before{ content:""; position:absolute; left:2px; top:11px; width:7px; height:7px; border-radius:50%; background:currentColor; opacity:.5; }
.facet-inner strong{ color:var(--ink); font-weight:600; }

/* couleurs par facette */
.f-def  .facet-chip{ color:var(--c-def);  background:var(--c-def-bg); }
.f-cond .facet-chip{ color:var(--c-cond); background:var(--c-cond-bg); }
.f-reg  .facet-chip{ color:var(--c-reg);  background:var(--c-reg-bg); }
.f-sanc .facet-chip{ color:var(--c-sanc); background:var(--c-sanc-bg); }
.f-piege .facet-chip{ color:var(--c-piege); background:var(--c-piege-bg); }
.f-def.open  { box-shadow:inset 3px 0 0 var(--c-def); }
.f-cond.open { box-shadow:inset 3px 0 0 var(--c-cond); }
.f-reg.open  { box-shadow:inset 3px 0 0 var(--c-reg); }
.f-sanc.open { box-shadow:inset 3px 0 0 var(--c-sanc); }
.f-piege.open{ box-shadow:inset 3px 0 0 var(--c-piege); }

/* ===================== FLASH CARDS (cartes à révéler) ===================== */
.flash-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.flash{
  border:1px solid var(--line); border-radius:var(--radius); padding:18px;
  background:var(--surface); cursor:pointer; position:relative;
  box-shadow:var(--shadow-sm); transition:transform .15s, box-shadow .15s, border-color .15s;
  min-height:118px; display:flex; flex-direction:column;
}
.flash:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.flash-cat{ font-family:var(--mono); font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; font-weight:600; margin-bottom:9px; }
.flash-q{ font-family:var(--display); font-size:18px; font-weight:600; line-height:1.25; color:var(--ink); }
.flash-a{ margin-top:12px; font-size:15px; color:var(--ink-soft); line-height:1.5;
  max-height:0; overflow:hidden; opacity:0; transition:max-height .3s, opacity .25s; }
.flash.open .flash-a{ max-height:600px; opacity:1; }
.flash-hint{ margin-top:auto; padding-top:12px; font-family:var(--mono); font-size:10px; color:var(--ink-faint); display:flex; align-items:center; gap:6px; }
.flash.open .flash-hint{ color:var(--wine); }
.flash strong{ color:var(--ink); font-weight:600; }
.flash-a .art{ font-size:12px; }

.cat-def{ border-top:3px solid var(--c-def); } .cat-def .flash-cat{ color:var(--c-def); }
.cat-cond{ border-top:3px solid var(--c-cond); } .cat-cond .flash-cat{ color:var(--c-cond); }
.cat-jp{ border-top:3px solid var(--c-jp); } .cat-jp .flash-cat{ color:var(--c-jp); }
.cat-sanc{ border-top:3px solid var(--c-sanc); } .cat-sanc .flash-cat{ color:var(--c-sanc); }
.cat-piege{ border-top:3px solid var(--c-piege); } .cat-piege .flash-cat{ color:var(--c-piege); }

/* ===================== ARRÊTS ===================== */
.arrets{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--surface); }
.arrets-head{ padding:13px 18px; background:var(--c-jp-bg); display:flex; align-items:center; gap:9px; }
.arrets-head h4{ margin:0; font-family:var(--display); font-size:18px; font-weight:600; color:var(--c-jp); }
.arrets-head .ico{ color:var(--c-jp); }
.arrets ul{ margin:0; padding:6px 0; list-style:none; }
.arrets li{ border-top:1px solid var(--line-soft); display:grid; grid-template-columns:240px 1fr; }
.arrets li:first-child{ border-top:none; }
.arr-ref{ font-family:var(--mono); font-size:12.5px; line-height:1.5; font-weight:600; color:var(--wine); padding:11px 16px 11px 18px; border-right:1px solid var(--line-soft); }
.arr-txt{ font-size:15px; color:var(--ink-soft); line-height:1.5; padding:11px 18px; }
.arr-txt strong{ color:var(--ink); }
@media (max-width:620px){ .arrets li{ grid-template-columns:1fr; } .arr-ref{ border-right:none; border-bottom:1px solid var(--line-soft); padding:10px 18px 7px; } .arr-txt{ padding-top:8px; } }

/* localisation de la JP dans le Code Dalloz (« sous art. X · C° Y ») */
.jp-loc{ display:inline-block; font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.01em; white-space:nowrap; color:var(--gold); background:var(--gold-tint); border:1px solid color-mix(in srgb, var(--gold) 34%, transparent); border-radius:5px; padding:1px 6px; margin-left:3px; vertical-align:baseline; }
@media print{ .jp-loc{ background:none; border:1px solid #bbb; color:#000; } }

/* ===================== TABLEAUX COMPARATIFS ===================== */
.table-block{ margin:26px 0; }
.table-block .tb-title{ font-family:var(--display); font-weight:600; font-size:21px; margin:0 0 12px; letter-spacing:-.01em; }
.tb-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); }
table.cmp{ width:100%; border-collapse:collapse; font-size:15px; background:var(--surface); }
table.cmp th, table.cmp td{ padding:12px 15px; text-align:left; vertical-align:top; border-bottom:1px solid var(--line-soft); line-height:1.45; }
table.cmp thead th{ background:linear-gradient(180deg,var(--surface-2),var(--surface)); font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); font-weight:600; position:sticky; top:0; }
table.cmp tbody th{ font-family:var(--serif); font-weight:600; color:var(--wine); background:var(--surface-2); font-size:14px; width:1%; white-space:nowrap; }
table.cmp tr:last-child td, table.cmp tr:last-child th{ border-bottom:none; }
table.cmp td strong{ color:var(--ink); font-weight:600; }
table.cmp .art{ font-size:11.5px; }
/* Séparateur entre groupes (paires de catégories) : trait plus marqué */
table.cmp tr.tb-grp > th, table.cmp tr.tb-grp > td{ border-top:3px solid color-mix(in srgb, var(--wine) 38%, transparent); }
.tb-note{ font-size:14.5px; color:var(--ink-soft); line-height:1.55; margin-top:14px; padding:12px 16px; background:var(--surface-2); border:1px solid var(--line); border-left:3px solid var(--wine); border-radius:10px; }
.tb-note strong{ color:var(--ink); font-weight:600; }

/* ===================== CALLOUTS ===================== */
.callout{ border-radius:var(--radius); padding:16px 18px 16px 20px; margin:22px 0; position:relative; border:1px solid; font-size:16px; line-height:1.55; }
.callout .co-label{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; font-weight:600; display:flex; align-items:center; gap:7px; margin-bottom:7px; }
.callout p{ margin:0; }
.callout strong{ font-weight:600; }
.co-piege{ background:var(--c-piege-bg); border-color:color-mix(in srgb,var(--c-piege) 35%, transparent); color:var(--ink); }
.co-piege .co-label{ color:var(--c-piege); }
.co-astuce{ background:var(--forest-tint); border-color:color-mix(in srgb,var(--forest) 35%, transparent); }
.co-astuce .co-label{ color:var(--forest); }
.co-note{ background:var(--navy-tint); border-color:color-mix(in srgb,var(--navy) 30%, transparent); }
.co-note .co-label{ color:var(--navy); }
.co-reforme{ background:var(--c-jp-bg); border-color:color-mix(in srgb,var(--c-jp) 42%, transparent); color:var(--ink); }
.co-reforme .co-label{ color:var(--c-jp); }

/* bloc articles-clés */
.art-box{ border:1px solid var(--line); border-left:3px solid var(--wine); border-radius:var(--radius-sm); background:var(--surface); padding:16px 18px; }
.art-box .ab-head{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--wine); margin-bottom:11px; }
.art-box ul{ margin:0; padding:0; list-style:none; display:grid; gap:9px; }
.art-box li{ display:flex; gap:12px; align-items:baseline; font-size:15px; }
.art-box .ab-n{ font-family:var(--mono); font-size:12.5px; font-weight:600; color:var(--wine); flex:0 0 auto; min-width:108px; }
.art-box .ab-t{ color:var(--ink-soft); line-height:1.4; }

/* ===================== QUIZ ===================== */
.quiz{ border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); padding:24px; box-shadow:var(--shadow-sm); margin-top:14px; }
.quiz-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:18px; flex-wrap:wrap; }
.quiz-head h3{ font-family:var(--display); font-size:23px; font-weight:600; margin:0; }
.quiz-score{ font-family:var(--mono); font-size:13px; font-weight:600; color:var(--ink); background:var(--surface-2); padding:6px 13px; border:1px solid var(--line); border-radius:999px; }
.quiz-q{ margin:0 0 22px; border-left:3px solid transparent; border-radius:4px; transition:border-color .3s ease, padding-left .25s ease; }
.quiz-q.q-correct{ border-left-color:var(--forest); padding-left:14px; }
.quiz-q.q-wrong{ border-left-color:var(--c-sanc); padding-left:14px; }
.quiz-q.q-pulse.q-correct{ animation:q-pulse-ok .7s ease; }
.quiz-q.q-pulse.q-wrong{ animation:q-pulse-bad .7s ease; }
@keyframes q-pulse-ok{ 0%,100%{ background:transparent; } 35%{ background:var(--forest-tint); } }
@keyframes q-pulse-bad{ 0%,100%{ background:transparent; } 35%{ background:var(--c-sanc-bg); } }
.quiz-q:last-of-type{ margin-bottom:0; }
.quiz-q .qq{ font-weight:600; font-size:17px; margin-bottom:12px; display:flex; gap:10px; }
.quiz-q .qq .qn{ font-family:var(--mono); font-size:13px; color:var(--wine); }
.quiz-opts{ display:grid; gap:8px; }
.quiz-opt{ display:flex; align-items:flex-start; gap:11px; padding:11px 14px; border:1px solid var(--line); border-radius:10px; cursor:pointer; font-size:15.5px; transition:all .13s; background:var(--surface); color:var(--ink); text-align:left; }
.quiz-opt > span:not(.qm){ flex:1 1 auto; min-width:0; }
.quiz-opt .qm{ margin-top:1px; }
.quiz-opt:hover{ border-color:var(--wine); background:var(--surface-2); }
.quiz-opt .qm{ font-family:var(--mono); font-size:12px; width:20px; height:20px; flex:0 0 20px; display:grid; place-items:center; border:1px solid var(--line); border-radius:6px; color:var(--ink-faint); }
.quiz-opt.correct{ border-color:var(--forest); background:var(--forest-tint); }
.quiz-opt.correct .qm{ background:var(--forest); color:#fff; border-color:var(--forest); }
.quiz-opt.wrong{ border-color:var(--c-sanc); background:var(--c-sanc-bg); }
.quiz-opt.wrong .qm{ background:var(--c-sanc); color:#fff; border-color:var(--c-sanc); }
.quiz-opt.lock{ cursor:default; opacity:.82; }
.quiz-opt.lock:hover{ border-color:var(--line); background:var(--surface); }
.quiz-opt.correct.lock, .quiz-opt.wrong.lock, .quiz-opt.missed.lock{ opacity:1; }
/* Réponse correcte NON cochée (multi-réponses) : rouge en pointillé = « tu l'as ratée » */
.quiz-opt.missed{ border-color:var(--c-sanc); border-style:dashed; background:var(--c-sanc-bg); }
.quiz-opt.missed .qm{ background:var(--c-sanc); color:#fff; border-color:var(--c-sanc); }
.quiz-exp{ margin-top:11px; font-size:14.5px; color:var(--ink-soft); padding:11px 14px; background:var(--surface-2); border-radius:9px; border-left:3px solid var(--gold); line-height:1.5;
  max-height:0; overflow:hidden; padding-top:0; padding-bottom:0; transition:all .25s; }
.quiz-exp.show{ max-height:400px; padding-top:11px; padding-bottom:11px; margin-top:11px; }
.quiz-exp strong{ color:var(--ink); }

.quiz-head-r{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.quiz-reset{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:var(--wine); background:var(--wine-tint); border:1px solid var(--wine); border-radius:999px; padding:6px 14px; cursor:pointer; transition:all .14s; }
.quiz-reset:hover{ color:var(--paper); background:var(--wine); border-color:var(--wine); }
.quiz-badge{ font-family:var(--mono); font-size:10px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:var(--forest); background:var(--forest-tint); border:1px solid color-mix(in srgb,var(--forest) 40%,transparent);
  padding:4px 10px; border-radius:999px; }

/* toast XP */
.xp-toast{ position:fixed; right:24px; bottom:84px; z-index:80; display:flex; flex-direction:column; gap:8px; align-items:flex-end; pointer-events:none; }
.xp-pop{ display:flex; flex-direction:column; align-items:flex-end; gap:1px; padding:9px 15px; border-radius:12px;
  background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow-lg);
  transform:translateX(40px) scale(.9); opacity:0; transition:all .35s cubic-bezier(.2,.9,.2,1); }
.xp-pop.show{ transform:translateX(0) scale(1); opacity:1; }
.xp-pop strong{ font-family:var(--mono); font-size:14px; font-weight:600; color:var(--wine); }
.xp-pop span{ font-size:11.5px; color:var(--ink-soft); }
.xp-pop.gold{ border-color:var(--gold); background:linear-gradient(180deg, var(--gold-tint), var(--surface)); }
.xp-pop.gold strong{ color:var(--gold); }

/* QCM à réponses multiples */
.q-multi{ font-family:var(--mono); font-size:9.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:var(--gold); background:var(--gold-tint); padding:2px 8px; border-radius:999px; vertical-align:middle; margin-left:6px; white-space:nowrap; }
.quiz-q.multi .qm{ border-radius:6px; } /* cases à cocher */
.quiz-opt.sel{ border-color:var(--wine); background:var(--wine-tint); }
.quiz-opt.sel .qm{ background:var(--wine); color:#fff; border-color:var(--wine); }
.quiz-valider{ margin-top:12px; padding:9px 18px; cursor:pointer; font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:#fff; background:linear-gradient(150deg,var(--wine),var(--wine-deep)); border:none; border-radius:9px; transition:filter .15s; }
.quiz-valider:hover{ filter:brightness(1.08); }

/* nav : lien vue d'ensemble · aligné sur les autres sous-sections (pastille incluse) */
.nav-apercu .nav-sec-t{ color:var(--ink-soft); }
.nav-apercu.active .nav-sec-t{ color:var(--wine); }

/* page Vue d'ensemble */
.apercu{ font-size:18px; line-height:1.65; }
.apercu p{ margin:0 0 16px; color:var(--ink-soft); }
.apercu p strong{ color:var(--ink); font-weight:600; }
.apercu .callout{ margin-top:6px; }

/* ===================== CHECKLISTS ===================== */
.checklist{ border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); overflow:hidden; box-shadow:var(--shadow-sm); }
.checklist-head{ padding:16px 20px; background:linear-gradient(180deg,var(--surface-2),var(--surface)); border-bottom:1px solid var(--line-soft); }
.checklist-head h4{ font-family:var(--display); font-size:20px; font-weight:600; margin:0; }
.checklist-head p{ margin:5px 0 0; font-size:14px; color:var(--ink-faint); }
.checklist ol{ margin:0; padding:8px 0; list-style:none; counter-reset:ck; }
.checklist li{ padding:12px 20px 12px 18px; border-top:1px solid var(--line-soft); display:flex; gap:13px; align-items:flex-start; cursor:pointer; transition:background .12s; }
.checklist li:first-child{ border-top:none; }
.checklist li:hover{ background:var(--surface-2); }
.ck-box{ width:22px; height:22px; flex:0 0 22px; border:1.8px solid var(--line); border-radius:7px; display:grid; place-items:center; margin-top:1px; transition:all .15s; color:transparent; font-size:13px; }
.checklist li.done .ck-box{ background:var(--forest); border-color:var(--forest); color:#fff; }
.ck-text{ font-size:16px; line-height:1.45; }
.ck-text strong{ font-weight:600; color:var(--ink); }
.checklist li.done .ck-text{ color:var(--ink-faint); text-decoration:line-through; text-decoration-color:var(--line); }
/* Mini-protocoles statiques : étapes numérotées, non cliquables (sans cases à cocher). */
.checklist.static ol{ counter-reset:ck; }
.checklist.static li{ cursor:default; counter-increment:ck; }
.checklist.static li:hover{ background:transparent; }
.ck-num{ width:24px; height:24px; flex:0 0 24px; border-radius:50%; display:grid; place-items:center; margin-top:1px; background:var(--surface-2); color:var(--wine); font-weight:700; font-size:13px; }
.ck-num::before{ content:counter(ck); }

/* ===================== CHEAT SHEET ===================== */
.cheat-head{ margin-bottom:26px; }
.cheat-cols{ columns:2; column-gap:24px; }
@media (max-width:760px){ .cheat-cols{ columns:1; } }
.cheat-card{ break-inside:avoid; border:1px solid var(--line); border-radius:12px; background:var(--surface); padding:16px 18px; margin:0 0 16px; box-shadow:var(--shadow-sm); }
.cheat-card h4{ font-family:var(--display); font-size:18px; font-weight:600; margin:0 0 11px; padding-bottom:9px; border-bottom:1px solid var(--line-soft); display:flex; align-items:center; gap:8px; }
.cheat-card h4 .cc-dot{ width:8px; height:8px; border-radius:50%; background:var(--wine); }
.cheat-row{ display:flex; gap:11px; padding:5px 0; font-size:14px; align-items:baseline; line-height:1.4; }
.cheat-row .ck{ font-family:var(--mono); font-size:11.5px; font-weight:600; color:var(--wine); flex:0 0 92px; }
.cheat-row .cv{ color:var(--ink-soft); flex:1; }
.cheat-row .cv strong{ color:var(--ink); font-weight:600; }

/* --- arbres de décision --- */
.cheat-hint{ font-size:14.5px; color:var(--ink-soft); margin:-4px 0 18px; max-width:70ch; }
.trees{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:18px; margin-bottom:8px; }
.tree{ break-inside:avoid; border:1px solid var(--line); border-radius:14px; background:var(--surface); padding:18px 20px 16px; box-shadow:var(--shadow-sm); }
.tree-q{ font-family:var(--display); font-weight:600; font-size:18px; color:var(--wine); margin:0 0 12px; padding-bottom:11px; border-bottom:1px solid var(--line-soft); line-height:1.2; display:flex; align-items:baseline; gap:10px; }
.tree-q-t{ flex:1; }
.tree-mask{ flex:0 0 auto; font-family:var(--mono); font-size:9.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:600; color:var(--wine); background:var(--wine-tint); border:1px solid color-mix(in srgb, var(--wine) 38%, transparent); border-radius:999px; padding:3px 9px; cursor:pointer; transition:all .15s; align-self:flex-start; }
.tree-mask:hover{ color:#fff; background:var(--wine); border-color:var(--wine); }
.tree.masked .tnode{ cursor:pointer; }
.tree.masked .tnode-note{ filter:blur(5px); -webkit-user-select:none; user-select:none; transition:filter .18s; }
.tree.masked .tnode:hover .tnode-note{ filter:blur(3px); }
.tree.masked .tnode.peek .tnode-note{ filter:none; }
.tree .branch{ list-style:none; margin:0; padding:0; }
.tree .tree-root{ padding-left:2px; }
.tree .branch .branch{ padding-left:20px; }
.tree li{ position:relative; }
.tree .branch .branch > li{ padding-left:16px; }
/* trait vertical reliant les enfants */
.tree .branch .branch > li::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:1px; background:var(--line); }
.tree .branch .branch > li:last-child::before{ bottom:auto; height:15px; }
/* connecteur horizontal */
.tree .branch .branch > li::after{ content:""; position:absolute; left:0; top:15px; width:11px; height:1px; background:var(--line); }
.tnode{ display:flex; flex-wrap:wrap; align-items:baseline; gap:4px 9px; padding:5px 0; }
.tnode-label{ font-weight:600; color:var(--ink); font-size:15px; }
.tnode-note{ color:var(--ink-soft); font-size:13.5px; line-height:1.4; }
.tree-root > li > .tnode .tnode-label{ color:var(--ink); }
.tree .art{ font-size:.78em; }

/* --- à apprendre par cœur --- */
.memo-cols{ display:grid; grid-template-columns:repeat(auto-fill,minmax(310px,1fr)); gap:16px; }
.memo-card{ break-inside:avoid; border:1px solid var(--line); border-radius:14px; background:var(--surface); padding:16px 18px; box-shadow:var(--shadow-sm); }
.memo-card h4{ font-family:var(--display); font-size:17px; font-weight:600; margin:0 0 11px; padding-bottom:9px; border-bottom:1px solid var(--line-soft); display:flex; align-items:center; gap:8px; }
.memo-card h4 .cc-dot{ width:8px; height:8px; border-radius:50%; background:var(--wine); flex:0 0 8px; }
.memo-title{ flex:1; }
/* mode récitation : boutons masquer */
.memo-mask{ flex:0 0 auto; font-family:var(--mono); font-size:9.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:600; color:var(--wine); background:var(--wine-tint); border:1px solid color-mix(in srgb, var(--wine) 38%, transparent); border-radius:999px; padding:3px 9px; cursor:pointer; transition:all .15s; }
.memo-mask:hover{ color:#fff; background:var(--wine); border-color:var(--wine); }
.memo-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; margin:-4px 0 16px; }
.memo-toolbar .cheat-hint{ margin:0; }
.memo-mask-all{ flex:0 0 auto; font-family:var(--mono); font-size:11px; letter-spacing:.04em; text-transform:uppercase; font-weight:600; color:var(--wine); background:var(--wine-tint); border:1px solid color-mix(in srgb, var(--wine) 42%, transparent); border-radius:999px; padding:7px 14px; cursor:pointer; box-shadow:var(--shadow-sm); transition:all .15s; }
.memo-mask-all:hover{ color:#fff; background:var(--wine); border-color:var(--wine); }
/* valeur masquée : floutée + cliquable pour révéler */
.memo-card.masked .memo-row{ cursor:pointer; }
.memo-card.masked .mv{ filter:blur(5px); -webkit-user-select:none; user-select:none; transition:filter .18s; }
.memo-card.masked .memo-row:hover .mv{ filter:blur(3px); }
.memo-card.masked .memo-row.peek .mv{ filter:none; }
@media print{ .memo-mask, .memo-mask-all, .tree-mask{ display:none !important; } .memo-card.masked .mv, .tree.masked .tnode-note{ filter:none !important; } }
.memo-row{ display:flex; gap:11px; padding:7px 0; border-top:1px solid var(--line-soft); align-items:baseline; }
.memo-row:first-of-type{ border-top:none; padding-top:0; }
.memo-row .mk{ font-family:var(--mono); font-size:11px; font-weight:600; color:var(--wine); flex:0 0 116px; line-height:1.45; }
.memo-row .mv{ color:var(--ink-soft); flex:1; font-size:14px; line-height:1.45; }
.memo-row .mv strong{ color:var(--ink); font-weight:600; }
@media (max-width:560px){
  .memo-row{ flex-direction:column; gap:2px; }
  .memo-row .mk{ flex-basis:auto; }
}

/* ===================== MÉTHODE (protocole) ===================== */
.m-steps{ display:flex; flex-direction:column; gap:14px; }
.m-step{ display:flex; gap:16px; align-items:flex-start; padding:18px 20px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); box-shadow:var(--shadow-sm); }
.m-num{ flex:0 0 38px; width:38px; height:38px; display:grid; place-items:center; border-radius:11px;
  font-family:var(--display); font-weight:600; font-size:18px; color:#fff; background:linear-gradient(150deg,var(--wine),var(--wine-deep)); }
.m-body h4{ font-family:var(--display); font-weight:600; font-size:19px; margin:2px 0 6px; }
.m-body p{ margin:0; font-size:15.5px; color:var(--ink-soft); line-height:1.55; }

/* syllogisme */
.syllo{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.syllo-row{ display:flex; gap:14px; align-items:flex-start; padding:14px 18px; border-top:1px solid var(--line-soft); background:var(--surface); }
.syllo-row:first-child{ border-top:none; }
.syllo-row p{ margin:0; font-size:15.5px; color:var(--ink-soft); line-height:1.55; flex:1; }
.sy-tag{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; font-weight:600;
  padding:4px 10px; border-radius:7px; flex:0 0 auto; min-width:96px; text-align:center; }
.sy-maj{ box-shadow:inset 3px 0 0 var(--c-def); } .sy-maj .sy-tag{ color:var(--c-def); background:var(--c-def-bg); }
.sy-min{ box-shadow:inset 3px 0 0 var(--c-cond); } .sy-min .sy-tag{ color:var(--c-cond); background:var(--c-cond-bg); }
.sy-con{ box-shadow:inset 3px 0 0 var(--c-sanc); } .sy-con .sy-tag{ color:var(--c-sanc); background:var(--c-sanc-bg); }
.syllo-row strong{ color:var(--ink); font-weight:600; }
.syllo .art{ font-size:12px; }

/* protocoles par notion */
.proto-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:16px; }
.proto-card{ border:1px solid var(--line); border-top:3px solid var(--gold); border-radius:var(--radius); background:var(--surface); padding:18px 20px; box-shadow:var(--shadow-sm); }
.proto-card h4{ font-family:var(--display); font-weight:600; font-size:18px; margin:0 0 12px; line-height:1.2; }
.proto-card ol{ margin:0; padding-left:0; list-style:none; counter-reset:p; display:grid; gap:9px; }
.proto-card li{ position:relative; padding-left:30px; font-size:14.5px; color:var(--ink-soft); line-height:1.5; counter-increment:p; }
.proto-card li::before{ content:counter(p); position:absolute; left:0; top:1px; width:20px; height:20px; display:grid; place-items:center;
  font-family:var(--mono); font-size:10.5px; font-weight:600; color:var(--wine); background:var(--wine-tint); border-radius:6px; }
.proto-card li strong{ color:var(--ink); font-weight:600; }
.proto-card .art{ font-size:11.5px; }

/* ===================== CONSULTATIONS ===================== */
.cases{ display:flex; flex-direction:column; gap:24px; }
.case{ border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); box-shadow:var(--shadow-sm); overflow:hidden; }
.case-head{ padding:20px 22px 4px; }
.case-meta{ display:flex; gap:10px; align-items:center; margin-bottom:8px; flex-wrap:wrap; }
.case-chap{ font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--wine); background:var(--wine-tint); padding:4px 10px; border-radius:999px; }
.case-pts{ font-family:var(--mono); font-size:10.5px; color:var(--ink-faint); border:1px solid var(--line); padding:4px 10px; border-radius:999px; }
.case-head h3{ font-family:var(--display); font-weight:600; font-size:24px; margin:0; letter-spacing:-.01em; }
.case-enonce{ padding:8px 22px 18px; }
.ce-label{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:8px; }
.case-enonce p{ margin:0 0 11px; font-size:15.5px; color:var(--ink-soft); line-height:1.6; }
.case-enonce p:last-child{ margin-bottom:0; }
.case-enonce strong{ color:var(--ink); font-weight:600; }
.case-toggle{ display:block; width:calc(100% - 44px); margin:0 22px 22px; padding:12px; cursor:pointer;
  font-family:var(--mono); font-size:12px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:#fff; background:linear-gradient(150deg,var(--wine),var(--wine-deep)); border:none; border-radius:10px; transition:filter .15s; }
.case-toggle:hover{ filter:brightness(1.08); }
.case-cor{ max-height:0; overflow:hidden; transition:max-height .4s ease; background:var(--surface-2); border-top:1px solid var(--line-soft); }
.case.open .case-cor{ max-height:6000px; }
.case-cor > *{ margin:0; }
.cor-block{ padding:16px 22px; border-bottom:1px solid var(--line-soft); }
.cor-lab{ display:block; font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; font-weight:600; color:var(--ink-faint); margin-bottom:6px; }
.cor-block p{ margin:0; font-size:15.5px; color:var(--ink-soft); line-height:1.55; }
.cor-block strong{ color:var(--ink); font-weight:600; }
.cor-pb{ background:var(--navy-tint); } .cor-pb .cor-lab{ color:var(--navy); }
.cor-dr .cor-lab{ color:var(--gold); }
.cor-cs{ background:var(--forest-tint); border-bottom:none; } .cor-cs .cor-lab{ color:var(--forest); }
.cor-q{ padding:16px 22px; border-bottom:1px solid var(--line-soft); }
.cor-q h5{ font-family:var(--display); font-weight:600; font-size:18px; margin:0 0 12px; color:var(--ink); }
.cor-q .syllo{ box-shadow:none; }
.case-cor-foot{ padding:16px 22px 20px; }
.case-reset{ font-family:var(--mono); font-size:11px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:var(--ink-soft); background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:8px 16px; cursor:pointer; transition:all .15s; }
.case-reset:hover{ color:var(--wine); border-color:var(--wine); }
/* barre du cas final */
.final-bar{ display:flex; align-items:center; gap:14px; margin-top:18px; flex-wrap:wrap; }
.final-new{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; text-transform:uppercase; font-weight:600;
  color:#fff; background:linear-gradient(150deg,var(--gold),#7a5512); border:none; border-radius:999px; padding:11px 20px; cursor:pointer; transition:filter .15s; }
[data-theme="dark"] .final-new{ color:#231a08; background:linear-gradient(150deg,var(--gold),#b88a3a); }
.final-new:hover{ filter:brightness(1.08); }
.final-count{ font-family:var(--mono); font-size:11.5px; color:var(--ink-faint); }
.cor-block .art, .cor-q .art{ font-size:12px; }
@media (max-width:620px){
  .syllo-row{ flex-direction:column; gap:6px; } .sy-tag{ min-width:0; }
  .case-toggle{ width:calc(100% - 32px); margin-left:16px; margin-right:16px; }
}

/* ===================== DIVERS ===================== */
.menu-btn{ display:none; position:fixed; top:14px; left:14px; z-index:70; width:44px; height:44px; border-radius:11px;
  background:var(--surface); border:1px solid var(--line); cursor:pointer; flex-direction:column; gap:4px; align-items:center; justify-content:center; box-shadow:var(--shadow); }
.menu-btn span{ width:20px; height:2px; background:var(--ink); border-radius:2px; }
.sidebar-scrim{ display:none; position:fixed; inset:0; background:rgba(20,12,8,.45); z-index:55; backdrop-filter:blur(2px); }
/* Bouton fermer le tiroir (mobile only) : injecté par app.js dans .sidebar .brand */
.nav-close{ display:none; margin-left:auto; width:36px; height:36px; place-items:center; border-radius:9px; border:1px solid var(--line); background:var(--surface); color:var(--ink); font-size:20px; line-height:1; cursor:pointer; flex:0 0 auto; }
.nav-close:hover{ color:var(--wine); border-color:var(--wine); }

/* ===== Bandeau latéral repliable (bureau) =====
   Bouton injecté par JS dans .topbar-left. Caché sur mobile où le menu
   est déjà en off-canvas (hamburger). Replié → la sidebar se rétracte à
   0 et .content reste centré (max-width) : lecture plein écran. */
.sidebar-toggle{ display:none; }
@media (min-width:861px){
  .sidebar-toggle{
    display:inline-flex; align-items:center; justify-content:center;
    flex:0 0 auto; width:34px; height:34px; padding:0;
    border-radius:9px; background:var(--surface); border:1px solid var(--line);
    color:var(--ink-soft); cursor:pointer; transition:color .15s, border-color .15s, background .15s;
  }
  .sidebar-toggle:hover{ color:var(--wine); border-color:var(--wine); background:var(--wine-tint); }
  .sidebar-toggle svg{ width:18px; height:18px; display:block; }
  /* Animation seulement après le 1er rendu (classe posée par JS) → pas de flash au chargement. */
  body.sidebar-anim .sidebar{ transition:flex-basis .26s ease, width .26s ease, opacity .2s ease, border-right-color .2s ease; }
  body.sidebar-collapsed .sidebar{
    flex-basis:0; width:0; min-width:0; opacity:0; overflow:hidden;
    border-right-width:0; pointer-events:none;
  }
}

.top-btn{ position:fixed; right:24px; bottom:24px; z-index:45; width:44px; height:44px; border-radius:50%;
  background:var(--wine); color:var(--paper); border:none; cursor:pointer; font-size:18px; box-shadow:var(--shadow);
  opacity:0; pointer-events:none; transition:opacity .25s, transform .15s; }
.top-btn.show{ opacity:1; pointer-events:auto; }
.top-btn:hover{ transform:translateY(-3px); }

/* Footer unifié, repris du portail (bande teintée + citation + liens en pastilles) */
.page-foot{ border-top:1px solid var(--line); background:color-mix(in srgb, var(--surface) 55%, transparent); margin-top:36px; }
.page-foot .foot-inner{ width:100%; max-width:min(1600px,92vw); margin:0 auto; padding:28px clamp(20px,5vw,56px) 40px; display:flex; align-items:center; justify-content:space-between; gap:18px 40px; flex-wrap:wrap; }
.page-foot .foot-note{ font-family:var(--display); font-style:italic; font-size:15.5px; color:var(--ink-soft); margin:0; max-width:52ch; line-height:1.5; }
.page-foot .foot-links{ display:flex; gap:10px; flex-wrap:wrap; }
.page-foot .foot-links a{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11.5px; letter-spacing:.02em; color:var(--ink-soft); text-decoration:none; background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:8px 15px; box-shadow:var(--shadow-sm); white-space:nowrap; transition:color .15s ease, border-color .15s ease, background .15s ease, transform .15s ease; }
.page-foot .foot-links a::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--wine); flex:0 0 auto; }
.page-foot .foot-links a:hover{ color:var(--wine); border-color:var(--wine); background:var(--wine-tint); transform:translateY(-1px); }
@media (max-width:760px){ .page-foot .foot-inner{ flex-direction:column; align-items:flex-start; gap:18px; padding-bottom:42px; } }

.section-nav{ display:flex; justify-content:space-between; gap:14px; margin-top:48px; padding-top:24px; border-top:1px solid var(--line); }
.section-nav a{ flex:1; padding:16px 20px; border:1.5px solid color-mix(in srgb, var(--wine) 22%, var(--line)); border-radius:12px; background:var(--surface); box-shadow:var(--shadow-sm); transition:all .15s; max-width:48%; }
.section-nav a:hover{ border-color:var(--wine); text-decoration:none; transform:translateY(-2px); box-shadow:var(--shadow); }
.section-nav .sn-dir{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--wine); font-weight:600; }
.section-nav .sn-title{ font-family:var(--display); font-weight:600; font-size:16px; color:var(--ink); margin-top:4px; display:block; line-height:1.2; }
.section-nav .next{ text-align:right; margin-left:auto; }

.empty{ text-align:center; padding:60px 20px; color:var(--ink-faint); }

/* ===================== RESPONSIVE ===================== */
@media (max-width:1080px){ :root{ --sidebar-w:280px; } .content{ padding:36px 26px; } .topbar{ padding:13px 24px; } }
@media (max-width:860px){
  .menu-btn{ display:flex; }
  .sidebar{ position:fixed; left:0; top:0; transform:translateX(-104%); transition:transform .28s ease; box-shadow:var(--shadow-lg); width:300px; flex-basis:300px; }
  .sidebar.open{ transform:translateX(0); }
  body.nav-open .sidebar-scrim{ display:block; }
  .main{ width:100%; }
  /* Header empilé : ligne 1 = hamburger + retour matières, ligne 2 = catégories */
  .topbar{ flex-direction:column; align-items:stretch; justify-content:flex-start; gap:10px; padding:12px 20px; }
  .topbar-left{ padding-left:54px; }
  .topbar-actions{ flex-wrap:wrap; }
  body.nav-open .menu-btn{ display:none; }
  .nav-close{ display:grid; }
  .content{ padding:30px 20px; }
  .topbar-actions .pill{ padding:7px 11px; font-size:10.5px; }
  body{ font-size:17px; }
  .hero h1{ font-size:clamp(32px,9vw,44px); }
}
@media (max-width:520px){
  .topbar-actions{ gap:6px; }
  .content{ padding:24px 16px; }
}

/* ===================== POPOVER ARTICLE (Légifrance) ===================== */
.art{ cursor:pointer; transition:background .12s, color .12s, box-shadow .12s; }
.art:hover{
  background:color-mix(in srgb, var(--wine) 18%, var(--wine-tint));
  box-shadow:0 0 0 2px color-mix(in srgb, var(--wine) 22%, transparent);
}
/* Badge "X s." · renvoie à la SECTION/CHAPITRE Légifrance, pas à un article unique.
   On change la couleur du badge entier (navy au lieu de wine) · visuel uni, pas
   de rectangle imbriqué. Le contraste navy/wine signale d'un coup d'œil qu'il
   s'agit d'une plage d'articles. */
.art.art-section{
  color:var(--navy);
  background:var(--navy-tint);
  border:1px solid color-mix(in srgb, var(--navy) 18%, transparent);
}
.art.art-section:hover{
  background:color-mix(in srgb, var(--navy) 18%, var(--navy-tint));
  box-shadow:0 0 0 2px color-mix(in srgb, var(--navy) 22%, transparent);
}
[data-theme="dark"] .art.art-section{
  background:var(--navy-tint);
  color:var(--navy);
}
.art-popover{
  position:absolute; z-index:9999;
  width:min(380px, calc(100vw - 24px));
  max-height:min(60vh, 480px);
  background:var(--paper); color:var(--ink);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  font-family:var(--serif); font-size:13.5px; line-height:1.6;
  overflow:auto;
  pointer-events:auto;
  opacity:1;
  transition:opacity .14s ease-out, transform .14s ease-out;
}
.art-popover.art-pop-anim{
  animation:none; /* on s'appuie sur la transition pour éviter les bugs de animation pausée en headless */
}
@keyframes art-pop-in{
  from{ opacity:0; transform:translateY(-4px); }
  to{ opacity:1; transform:translateY(0); }
}
.art-popover .art-pop-head{
  display:flex; align-items:baseline; justify-content:space-between; gap:10px;
  padding:10px 14px;
  background:var(--surface-2);
  border-bottom:1px solid var(--line);
  border-radius:var(--radius) var(--radius) 0 0;
}
.art-popover .art-pop-code{
  font-family:var(--display); font-size:13px; font-weight:600;
  color:var(--wine);
}
.art-popover .art-pop-num{
  font-family:var(--mono); font-size:11.5px; font-weight:500;
  color:var(--ink-soft);
  letter-spacing:.3px;
}
.art-popover .art-pop-body{
  padding:12px 14px;
}
.art-popover .art-pop-body p{
  margin:0 0 8px;
  color:var(--ink);
  white-space:pre-wrap;
}
.art-popover .art-pop-body p:last-child{ margin-bottom:0; }
.art-popover .art-pop-body strong{ color:var(--ink); font-weight:600; }
.art-popover .art-pop-al{
  background:var(--gold-tint);
  border-left:3px solid var(--gold);
  padding:4px 8px;
  display:block;
  border-radius:4px;
  color:var(--ink);
}
.art-popover .art-pop-meta{
  color:var(--ink-faint);
  font-style:italic;
}
.art-popover .art-pop-date{
  margin-top:8px; padding-top:8px;
  border-top:1px dashed var(--line);
  font-size:11px; color:var(--ink-faint);
  font-family:var(--mono); letter-spacing:.4px;
}
.art-popover .art-pop-foot{
  padding:8px 14px 10px;
  border-top:1px solid var(--line);
  background:var(--surface);
  border-radius:0 0 var(--radius) var(--radius);
}
.art-popover .art-pop-link{
  display:inline-flex; align-items:center; gap:6px;
  color:var(--wine); font-weight:600; font-size:12.5px;
  text-decoration:none;
  padding:4px 8px; border-radius:6px;
  background:var(--wine-tint);
  border:1px solid color-mix(in srgb, var(--wine) 32%, transparent);
}
.art-popover .art-pop-link:hover{
  background:color-mix(in srgb, var(--wine) 22%, var(--wine-tint));
}
.art-popover .art-pop-arrow{
  font-size:14px; font-family:var(--mono);
}
@media (max-width:740px){
  .art-popover{ font-size:13px; }
}
/* impression : masquer les popovers résiduels */
@media print{
  .art-popover{ display:none !important; }
  .art{ cursor:text; background:none !important; box-shadow:none !important; }
}

/* ===================== SCHÉMAS (SVG inline) ===================== */
.schema{
  margin:18px 0; padding:18px 18px 14px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  position:relative;
}
.schema .sch-title{
  font-family:var(--display);
  font-size:18px; font-weight:600;
  color:var(--ink); margin:0 0 6px;
  display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;
}
.schema .sch-num{
  font-family:var(--mono); font-size:11px; font-weight:500;
  color:var(--wine); background:var(--wine-tint);
  padding:2px 7px; border-radius:4px; border:1px solid color-mix(in srgb, var(--wine) 26%, transparent);
  letter-spacing:.4px; text-transform:uppercase;
}
.schema .sch-intro{
  margin:6px 0 12px;
  font-size:13.5px; color:var(--ink-soft);
  line-height:1.5;
}
.schema .sch-caption{
  margin:10px 0 0; padding-top:10px;
  border-top:1px dashed var(--line);
  font-size:13px; color:var(--ink-soft);
  font-style:italic; line-height:1.55;
}

.sch-canvas{
  background:var(--paper);
  border-radius:var(--radius-sm);
  border:1px solid var(--line-soft);
  padding:14px 10px;
  overflow-x:auto;
}
.sch-svg{
  width:100%; height:auto; max-height:340px;
  display:block;
  color:var(--ink);
  font-family:var(--serif);
}
.sch-svg .sch-actor{
  font-family:var(--serif); font-size:13px; font-weight:600;
  fill:var(--ink);
}
.sch-svg .sch-value{
  font-family:var(--mono); font-size:12px; font-weight:500;
  fill:var(--ink-soft);
}
.sch-svg .sch-value .sch-old,
.sch-svg .sch-arrow-label .sch-old{ fill:var(--ink-faint); }
.sch-svg .sch-value .sch-old.struck,
.sch-svg .sch-arrow-label .sch-old.struck{ text-decoration:line-through; }
.sch-svg .sch-value .sch-new,
.sch-svg .sch-arrow-label .sch-new{ fill:var(--wine); font-weight:600; }
.sch-svg .sch-arrow{
  stroke:var(--navy);
  stroke-width:1.8;
  fill:none;
}
.sch-svg .sch-arrow.sch-red{ stroke:var(--wine); stroke-width:2.2; }
.sch-svg .sch-arrow.sch-green{ stroke:var(--forest); }
.sch-svg .sch-arrow.sch-gold{ stroke:var(--gold); }
.sch-svg .sch-arrow-head-fill{ fill:var(--navy); }
.sch-svg .sch-arrow-head-red-fill{ fill:var(--wine); }
.sch-svg .sch-arrow-head-green-fill{ fill:var(--forest); }
.sch-svg .sch-arrow-head-gold-fill{ fill:var(--gold); }
.sch-svg .sch-arrow-label{
  font-family:var(--mono); font-size:11.5px; font-weight:500;
  fill:var(--ink-soft);
}
.sch-svg .sch-arrow-label.sch-red{ fill:var(--wine); }
.sch-svg .sch-arrow-label.sch-green{ fill:var(--forest); }
.sch-svg .sch-arrow-label.sch-gold{ fill:var(--gold); }
.sch-svg .sch-phase{
  font-family:var(--serif); font-size:11px; font-weight:600;
  fill:var(--ink-faint); text-transform:uppercase; letter-spacing:1px;
}
.sch-svg .sch-badge{
  font-family:var(--mono); font-size:10.5px; font-weight:600;
  fill:var(--wine); text-transform:uppercase; letter-spacing:1.4px;
}
.sch-svg .sch-cross{ stroke:var(--ink); stroke-width:2.4; }
.sch-svg .sch-actor-note{
  font-family:var(--serif); font-size:11.5px; color:var(--ink-soft);
  text-align:center; line-height:1.4; padding:4px 6px;
  background:var(--surface); border:1px solid var(--line);
  border-radius:6px;
}

/* before/after */
.schema .sch-pair{
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
}
.schema .sch-phase-block{
  background:var(--paper); padding:10px 8px 6px;
  border:1px solid var(--line-soft); border-radius:var(--radius-sm);
}
.schema .sch-phase-block .sch-phase{
  font-family:var(--serif); font-size:11px; font-weight:700;
  color:var(--ink-faint); text-transform:uppercase; letter-spacing:1.2px;
  text-align:center; margin-bottom:4px;
}
.schema .sch-phase-block .sch-canvas{
  background:transparent; border:0; padding:6px 0 0;
}
@media (max-width:740px){
  .schema .sch-pair{ grid-template-columns:1fr; }
  .sch-svg{ max-height:none; }
}

/* tree-canvas (arbre de décision en HTML) */
.sch-tree-canvas{
  padding:18px 14px 14px;
}
.sch-tbranch{
  list-style:none; margin:0; padding-left:18px;
  position:relative;
}
.sch-tbranch-root{ padding-left:0; }
.sch-tbranch > li{ position:relative; margin:6px 0; padding-left:18px; }
.sch-tbranch > li::before{
  content:""; position:absolute; left:0; top:14px;
  width:14px; height:1.5px; background:var(--line);
}
.sch-tbranch-root > li{ padding-left:0; }
.sch-tbranch-root > li::before{ display:none; }
.sch-tbranch > li:not(:last-child)::after{
  content:""; position:absolute; left:0; top:14px;
  width:1.5px; height:calc(100% - 14px); background:var(--line);
}
.sch-tnode{
  display:inline-flex; flex-direction:column; gap:2px;
  background:var(--surface-2); border:1px solid var(--line);
  border-radius:6px; padding:5px 10px;
  font-family:var(--serif); font-size:13px; font-weight:600;
  color:var(--ink);
}
.sch-tnode .sch-tnode-note{
  font-weight:400; color:var(--ink-faint); font-size:12px;
}
.sch-tnode-possible{ background:var(--forest-tint); border-color:color-mix(in srgb, var(--forest) 32%, transparent); color:var(--forest); }
.sch-tnode-impossible{ background:var(--wine-tint); border-color:color-mix(in srgb, var(--wine) 32%, transparent); color:var(--wine); }

/* ===================== PAGE « SCHÉMAS » (galerie) ===================== */
.schemas-page{
  display:flex; flex-direction:column; gap:14px;
}
.schemas-page .sch-group-head{
  font-family:var(--display); font-size:20px; font-weight:600;
  margin:14px 0 6px;
  display:flex; align-items:baseline; gap:10px;
}
.schemas-page .sch-group-head .sch-group-num{
  font-family:var(--mono); font-size:11px; color:var(--wine);
  background:var(--wine-tint); border-radius:4px; padding:2px 8px;
  letter-spacing:.5px; text-transform:uppercase;
  border:1px solid color-mix(in srgb, var(--wine) 26%, transparent);
}
.schemas-page .schema{ margin:0; }
.schemas-page .sch-group{
  display:grid; gap:14px;
}

/* ===================== PAGE ACTUALITÉ ===================== */
.actu-filter{
  display:flex; flex-direction:column; gap:10px;
  background:var(--surface); border:1px solid var(--line); border-radius:12px;
  padding:14px 16px; margin-bottom:22px;
}
.af-row{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.af-lab{
  font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--muted); min-width:88px;
}
.af-chips{ display:flex; gap:8px; flex-wrap:wrap; }
.af-chip{
  font:inherit; font-size:13.5px; line-height:1; cursor:pointer;
  padding:7px 13px; border-radius:999px;
  border:1px solid var(--line); background:var(--bg); color:var(--ink);
  transition:background .15s, border-color .15s, color .15s;
}
.af-chip:hover{ border-color:var(--wine); }
.af-chip.on{ background:var(--wine); border-color:var(--wine); color:#fff; }
.actu-empty{ color:var(--muted); font-style:italic; padding:8px 2px; }
.actu-page{ display:flex; flex-direction:column; gap:24px; }
.actu-group{ display:flex; flex-direction:column; gap:12px; }
.actu-group[hidden]{ display:none; }
.actu-group-head{
  font-family:var(--display); font-size:21px; font-weight:600;
  margin:8px 0 2px; padding-bottom:6px; border-bottom:1px solid var(--line);
}
.actu-item{
  background:var(--surface); border:1px solid var(--line);
  border-left:3px solid var(--line); border-radius:var(--radius-sm);
  padding:13px 16px; box-shadow:var(--shadow-sm);
}
.actu-item.actu-bd3{ border-left-color:var(--c-sanc); }
.actu-item.actu-bd2{ border-left-color:var(--gold); }
.actu-item.actu-bd1{ border-left-color:var(--wine); }
.actu-item-head{ display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; margin-bottom:3px; }
.actu-ref{ font-family:var(--mono); font-size:12.5px; font-weight:600; color:var(--wine); letter-spacing:.01em; }
.actu-stars{ font-size:12px; letter-spacing:1.5px; flex:none; white-space:nowrap; }
.actu-stars.actu-s3{ color:var(--c-sanc); }
.actu-stars.actu-s2{ color:var(--gold); }
.actu-stars.actu-s1{ color:var(--ink-faint); }
.actu-theme{ font-weight:600; font-size:15px; color:var(--ink); margin:2px 0 4px; }
.actu-txt{ font-size:15px; line-height:1.6; color:var(--ink-soft); margin:0; }
.section-lead .actu-stars{ font-size:11px; letter-spacing:1px; }

/* ===================== IMPRESSION / PDF ===================== */
@media print{
  :root{ --maxw:100%; }
  body{ background:#fff; color:#000; font-size:11.5pt; }
  body::before{ display:none; }
  .sidebar, .topbar, .menu-btn, .sidebar-scrim, .top-btn, .section-nav, #search, .quiz-score, .facet-toggle, .flash-hint, .case-toggle, .quiz-reset, .final-bar, .case-reset{ display:none !important; }
  .layout{ display:block; }
  .main{ display:block; }
  .content{ max-width:100%; padding:0; }
  .home-card, .tool-card{ box-shadow:none; }
  /* tout révéler à l'impression */
  .facet-body, .flash-a, .case-cor{ max-height:none !important; opacity:1 !important; overflow:visible !important; }
  .facet .facet-body, .flash .flash-a{ display:block !important; }
  .quiz-exp{ max-height:none !important; padding:8px 12px !important; }
  .notion, .flash, .arrets, .checklist, .quiz, .table-block, .callout, .art-box, .cheat-card, .tree, .memo-card, .m-step, .proto-card, .cor-q, .syllo-row, .schema{ break-inside:avoid; box-shadow:none; }
  .sch-svg{ max-height:none !important; }
  .schema .sch-pair{ grid-template-columns:1fr 1fr !important; }
  .case{ box-shadow:none; }
  .block, .h-rule{ break-inside:avoid; }
  a{ color:#000; text-decoration:none; }
  .art{ background:none; color:#000; border:1px solid #ccc; }
  .section-head{ break-after:avoid; }
  h2.section-title, .h-rule h3, .notion-head h4{ break-after:avoid; }
  .cheat-cols{ columns:2; }
  .trees, .memo-cols{ grid-template-columns:1fr 1fr; }
  .tree .branch .branch > li::before, .tree .branch .branch > li::after{ background:#bbb; }
}

/* ===================== FICHE À TROUS ===================== */
.fiche-bar{ display:flex; flex-wrap:wrap; align-items:center; gap:10px 14px; margin:0 0 18px; padding:11px 14px; background:var(--surface-2); border:1px solid var(--line); border-radius:12px; }
.fiche-seg{ display:inline-flex; border:1px solid var(--line); border-radius:9px; overflow:hidden; background:var(--surface); }
.fiche-seg button{ font-family:var(--mono); font-size:12px; padding:6px 13px; border:none; background:transparent; color:var(--ink-soft); cursor:pointer; }
.fiche-seg button.on{ background:var(--wine); color:#fff; }
.fiche-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-left:auto; }
.fiche-act{ font-family:var(--mono); font-size:12px; padding:6px 11px; border:1px solid var(--line); border-radius:8px; background:var(--surface); color:var(--ink); cursor:pointer; }
.fiche-act:hover{ background:var(--surface-2); }
.fiche-score{ font-family:var(--mono); font-size:13px; font-weight:600; color:var(--wine); padding:0 4px; }
.fiche-sec{ margin:0 0 18px; }
.fiche-sec-t{ font-family:var(--display); font-size:18px; font-weight:600; color:var(--wine); margin:0 0 6px; }
.fiche-lines{ list-style:none; margin:0; padding:0; }
.fiche-lines li{ position:relative; padding:7px 0 7px 20px; border-top:1px solid var(--line-soft); font-size:16px; line-height:1.6; color:var(--ink-soft); }
.fiche-lines li:first-child{ border-top:none; }
.fiche-lines li::before{ content:""; position:absolute; left:3px; top:16px; width:6px; height:6px; border-radius:50%; background:var(--wine); opacity:.45; }
.fiche-lines strong{ color:var(--ink); font-weight:600; }
/* termes masquables */
.fb-a{ font-weight:600; color:var(--wine); }
.fb-in{ display:none; font-family:var(--mono); font-size:14px; padding:1px 6px; border:none; border-bottom:2px solid color-mix(in srgb, var(--wine) 45%, transparent); background:var(--wine-tint); border-radius:5px 5px 0 0; color:var(--ink); vertical-align:baseline; }
.fb-in:focus{ outline:2px solid var(--wine); outline-offset:1px; }
.fiche.trous .fb .fb-a{ display:none; }
.fiche.trous .fb .fb-in{ display:inline-block; }
.fb-in.fb-ok{ background:var(--forest-tint); border-bottom-color:var(--forest); color:var(--forest); font-weight:600; }
.fb-in.fb-ko{ background:var(--c-sanc-bg); border-bottom-color:var(--c-sanc); }
/* Niveaux : au niveau 1, les trous Fx restent en clair et les lignes N2 sont masquées. */
.fiche.n1 .fb-x .fb-in{ display:none !important; }
.fiche.n1 .fb-x .fb-a{ display:inline !important; }
.fiche.n1 .ln-n2{ display:none; }
@media (max-width:620px){ .fiche-actions{ margin-left:0; width:100%; } }
@media print{
  .sidebar, .topbar, .fiche-bar, .nav-lock{ display:none !important; }
  .content, .main, body{ margin:0 !important; }
  .fb-in{ background:none !important; border:none; border-bottom:1px solid #555; border-radius:0; min-width:110px; color:#000; }
  .fiche-lines li{ break-inside:avoid; }
}
