/* ─────────────── PROGRESS BAR ─────────────── */
.prog-wrap{display:flex;align-items:center;gap:10px}
.prog-track{width:120px;height:2px;background:var(--surface);border-radius:2px;overflow:hidden}
.prog-fill{height:100%;background:var(--dark);border-radius:2px;transition:width .5s ease;width:0%}
.prog-txt{font-size:12px;color:var(--dim);white-space:nowrap}

/* ─────────────── DIFFICULTY COLORS ─────────────── */
:root {
  --diff-essentiel: #3D7A5F;
  --diff-intermediaire: #C98930;
  --diff-avance: #B44040;
}
.diff-essentiel { color: var(--diff-essentiel); }
.diff-intermediaire { color: var(--diff-intermediaire); }
.diff-avance { color: var(--diff-avance); }

/* ─────────────── MODULE BADGES (top of each module) ─────────────── */
.module-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px;font-size:12px;color:var(--muted)}
.mod-difficulty{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 9px;border-radius:4px}
.mod-difficulty.diff-essentiel{background:rgba(61,122,95,.1);color:var(--diff-essentiel)}
.mod-difficulty.diff-intermediaire{background:rgba(201,137,48,.1);color:var(--diff-intermediaire)}
.mod-difficulty.diff-avance{background:rgba(180,64,64,.1);color:var(--diff-avance)}
.mod-duration,.mod-prereq{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--dim)}
.mod-duration .inline-icon{color:var(--muted)}
.inline-icon{display:inline-flex;vertical-align:-2px;margin-right:2px}

/* ─────────────── SIDEBAR — Anthropic Academy Style ─────────────── */
.sidebar{position:fixed;top:var(--hdr-h);left:0;width:var(--sidebar-w);height:calc(100vh - var(--hdr-h));background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:24px 0 60px;z-index:100}
.sidebar::-webkit-scrollbar{width:0}
.sb-section{padding:24px 24px 8px;font-size:13px;font-weight:600;color:var(--text);letter-spacing:0;text-transform:none}
.sb-section.sb-group{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:18px 24px 6px}
.sb-section.diff-essentiel{color:var(--diff-essentiel)}
.sb-section.diff-intermediaire{color:var(--diff-intermediaire)}
.sb-section.diff-avance{color:var(--diff-avance)}
.nav-item{position:relative;display:flex;align-items:center;gap:12px;padding:8px 24px;cursor:pointer;transition:all .12s;border-left:none}
.nav-item:hover{background:rgba(0,0,0,.03)}
.nav-item.active{background:rgba(0,0,0,.05)}
.nav-item.done .nav-badge{background:var(--dark);border-color:var(--dark);color:#fff}
.nav-badge{width:20px;height:20px;border-radius:50%;background:transparent;border:1.5px solid var(--dim);display:flex;align-items:center;justify-content:center;font-size:0;flex-shrink:0;transition:all .15s}
.nav-item.active .nav-badge{border-color:var(--dark);background:var(--dark);box-shadow:0 0 0 2px var(--surface),0 0 0 3.5px var(--dark)}
.nav-item.active .nav-badge::after{content:'';width:6px;height:6px;border-radius:50%;background:#fff}
/* Visited (non-active) modules: filled black circle */
.nav-item.visited:not(.active) .nav-badge{border-color:var(--dark);background:var(--dark)}
.nav-item.visited:not(.active) .nav-badge::after{content:'';width:0;height:0;display:none}
.nav-item.done .nav-badge::after{content:'';display:none}
.nav-label{font-size:14px;color:var(--muted);line-height:1.4;transition:color .12s;flex:1}
.nav-item.active .nav-label{color:var(--text);font-weight:500}
.nav-item:hover .nav-label{color:var(--text)}
.nav-diff{display:inline-flex;gap:2px;flex-shrink:0;align-items:center;padding:0 2px}
.diff-dot{width:4px;height:4px;border-radius:50%;display:inline-block;background:transparent;transition:background .12s}
.diff-dot-on.diff-essentiel{background:var(--diff-essentiel)}
.diff-dot-on.diff-intermediaire{background:var(--diff-intermediaire)}
.diff-dot-on.diff-avance{background:var(--diff-avance)}
.diff-dot-off{background:rgba(0,0,0,.08)}
.nav-check{width:12px;height:12px;flex-shrink:0;color:#fff;opacity:0;transition:opacity .15s}
.nav-item.done .nav-check{opacity:1}
.nav-divider{height:1px;background:var(--border);margin:16px 24px}

/* ─────────────── MAIN ─────────────── */
.main{margin-left:var(--sidebar-w);margin-top:var(--hdr-h);min-height:calc(100vh - var(--hdr-h));padding:48px 64px 100px}

/* ─────────────── SIDEBAR — DRAWER MOBILE ─────────────── */
/* Bouton hamburger : caché en desktop, visible sous 1024px */
.sidebar-toggle{display:none;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border2);border-radius:8px;cursor:pointer;color:var(--text);padding:8px;margin-right:12px;font-family:var(--sans);transition:background .15s,border-color .15s}
.sidebar-toggle:hover{background:var(--surface);border-color:var(--text)}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99;animation:fadeIn .18s ease both}
body.sidebar-open .sidebar-backdrop{display:block}

@media(max-width:1024px){
  .sidebar-toggle{display:inline-flex}
  /* La sidebar devient un drawer escamotable */
  .sidebar{transform:translateX(-100%);transition:transform .22s ease;box-shadow:none;width:min(320px,86vw);z-index:101}
  body.sidebar-open .sidebar{transform:translateX(0);box-shadow:0 8px 30px rgba(0,0,0,.18)}
  .main{margin-left:0;padding:32px 24px 80px}
  /* En drawer ouvert, empêcher le scroll du fond */
  body.sidebar-open{overflow:hidden}
}

.course-hdr .hdr-logo{width:auto}

/* ─────────────── PAGE ─────────────── */
.page{display:none;max-width:780px;margin:0 auto;animation:pgIn .25s ease both}
.page.active{display:block}

/* ─────────────── COURSE LANDING ─────────────── */
.hero{text-align:center;padding:48px 0 40px}
.hero-eyebrow{display:inline-block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:24px}
.hero-title{font-family:var(--serif);font-size:clamp(36px,5vw,56px);line-height:1.08;margin-bottom:18px;letter-spacing:-1.2px;color:var(--text);font-weight:600}
.hero-title em{font-style:italic}
.hero-sub{font-size:17px;color:var(--muted);max-width:460px;margin:0 auto 32px;line-height:1.65}
.hero-cta{display:inline-flex;align-items:center;gap:10px;background:var(--dark);color:#fff;padding:12px 28px;border-radius:var(--radius);font-weight:500;font-size:15px;cursor:pointer;border:none;transition:all .15s;font-family:var(--sans)}
.hero-cta:hover{background:var(--dark-l)}
.grid-hd{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:16px;letter-spacing:0;text-transform:none}
.mods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:720px){.mods-grid{grid-template-columns:1fr}}
.mod-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;cursor:pointer;transition:all .15s;text-align:left;display:flex;flex-direction:column}
.mod-card:hover{background:var(--surface2);border-color:var(--border2)}
.mc-num{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-bottom:6px}
.mc-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:10px;flex:1}
.mc-desc{font-size:13px;color:var(--muted);line-height:1.5}
.mc-meta{display:flex;gap:10px;font-size:11px;color:var(--dim);margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}
.mod-duration-small{display:inline-flex;align-items:center;gap:4px}
.mod-group{margin-bottom:40px}
.grid-hd{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.grid-hd.diff-essentiel{color:var(--diff-essentiel)}
.grid-hd.diff-intermediaire{color:var(--diff-intermediaire)}
.grid-hd.diff-avance{color:var(--diff-avance)}

/* ─────────────── MODULE HEADER ─────────────── */
.mod-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.mod-tag{font-size:13px;font-weight:500;color:var(--dim)}
.mod-tag-line{flex:1;height:1px;background:var(--border)}
.module-title{font-family:var(--serif);font-size:clamp(32px,4vw,48px);line-height:1.1;color:var(--text);margin-bottom:28px;letter-spacing:-1px;font-weight:600}
.module-intro{font-size:17px;color:var(--muted);line-height:1.8;margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid var(--border)}

/* ─────────────── CONTENT TYPOGRAPHY — Serif body like Anthropic ─────────────── */
.section-title{font-family:var(--serif);font-size:28px;font-weight:600;color:var(--text);margin:48px 0 16px;letter-spacing:-.3px;position:relative;padding-left:0}
.section-title::before{display:none}
.section-title-sm{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--text);margin:32px 0 12px}
.section-title-xs{font-size:12px;font-weight:600;color:var(--muted);margin:24px 0 8px;letter-spacing:1px;text-transform:uppercase}
.content-p{color:var(--muted);line-height:1.85;margin-bottom:16px;font-size:17px;font-family:var(--serif);font-weight:400}
.content-p strong{color:var(--text);font-weight:600}
.content-p em{color:var(--text);font-style:italic}
.content-list{list-style:none;margin:16px 0 24px;padding:0;display:flex;flex-direction:column;gap:0}
.content-list li{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);color:var(--muted);font-size:16px;line-height:1.7;align-items:flex-start;font-family:var(--serif)}
.content-list li:last-child{border-bottom:none}
.content-list li::before{content:'\2022';color:var(--dim);flex-shrink:0;margin-top:2px;font-size:12px}
.content-list li strong{color:var(--text)}

/* ─────────────── ASSET CARDS (Module 9 — 7 classes d'actifs) ─────────────── */
.asset-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:22px 26px;margin:20px 0}
.asset-card .asset-title{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--text);margin:0 0 14px;padding-bottom:12px;border-bottom:1px solid var(--border);letter-spacing:-.2px}
.asset-card .asset-row{display:grid;grid-template-columns:200px 1fr;gap:20px;padding:12px 0;font-family:var(--serif);font-size:16px;line-height:1.75;color:var(--muted)}
.asset-card .asset-row + .asset-row{border-top:1px dashed var(--border)}
.asset-card .asset-label{font-family:var(--sans);font-size:11px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:1.2px;padding-top:4px}
.asset-card .asset-body strong{color:var(--text);font-weight:600}
.asset-card .asset-body em{color:var(--text);font-style:italic}
.asset-card .asset-body .glossary-term{overflow:visible}
@media(max-width:720px){
  .asset-card{padding:18px 20px}
  .asset-card .asset-title{font-size:19px}
  .asset-card .asset-row{grid-template-columns:1fr;gap:4px;padding:10px 0}
  .asset-card .asset-label{font-size:10.5px}
}

/* ─────────────── LANDING DISCLAIMER ─────────────── */
.landing-disclaimer{
  display:flex;align-items:flex-start;gap:12px;
  background:var(--surface);border:1px solid var(--border);
  border-left:3px solid var(--diff-intermediaire);
  border-radius:var(--radius);padding:14px 18px;
  margin:32px 0 40px;font-size:13px;color:var(--muted);line-height:1.55;
}
.landing-disclaimer > svg,
.landing-disclaimer > .inline-icon > svg{color:var(--diff-intermediaire);flex-shrink:0;margin-top:2px}
.landing-disclaimer strong{color:var(--text);font-weight:600}
.landing-disclaimer a{display:inline-block;margin-top:6px}
.landing-date{
  margin-left:auto;font-size:11px;color:var(--dim);
  white-space:nowrap;padding-left:12px;font-weight:500;
  letter-spacing:.3px;
}
@media(max-width:720px){
  .landing-disclaimer{flex-direction:column}
  .landing-date{margin-left:0;margin-top:8px}
}

/* ─────────────── LEGAL PAGE ─────────────── */
.legal-page .content-p{font-size:14.5px;line-height:1.75}
.legal-page .section-title{font-size:22px;margin:36px 0 14px}
.legal-sources{display:flex;flex-direction:column;gap:10px;margin:16px 0 20px}
.legal-source{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 18px;
}
.legal-source-title{font-weight:600;font-size:14px;color:var(--text);margin-bottom:4px}
.legal-source-desc{font-size:13px;color:var(--muted);line-height:1.6}

/* ─────────────── CRASH 2020 CHART (Module 03) ─────────────── */
.crash-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 22px 16px;margin:24px 0}
.crash-chart-header{margin-bottom:10px}
.crash-chart-title{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--text)}
.crash-chart-subtitle{font-size:12px;color:var(--muted);margin-top:3px}
.crash-chart-svg{width:100%;height:auto;display:block;max-height:420px}
.crash-chart-legend{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;font-size:12px;color:var(--muted);margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.crash-chart-legend > span{display:inline-flex;align-items:center;gap:6px}
.crash-legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block}
.crash-legend-dot.red{background:var(--red)}
.crash-legend-dot.green{background:var(--green)}

/* ─────────────── BOND BAR CHART (Module 06) ─────────────── */
.bond-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;margin:28px 0}
.bond-chart-title{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--text);margin-bottom:20px;text-align:center}
.bond-chart-bars{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;align-items:end;min-height:220px;padding:0 8px}
.bond-bar{display:flex;flex-direction:column;align-items:center;gap:6px;height:200px;justify-content:flex-end}
.bond-bar-val{font-family:var(--serif);font-size:13px;font-weight:600;color:var(--text)}
.bond-bar-fill{width:100%;display:flex;flex-direction:column;justify-content:flex-end;border-radius:4px 4px 0 0;overflow:hidden;background:var(--surface2);height:12%}
.bond-bar-fill.tall{height:100% !important}
.bond-bar-cap{display:block;width:100%;flex-shrink:0}
.bond-bar-cap.coupon{background:var(--diff-intermediaire);height:16px}
.bond-bar-cap.principal{background:var(--diff-essentiel);flex:1;min-height:160px}
.bond-bar-year{font-size:11px;font-weight:500;color:var(--muted);letter-spacing:.3px}
.bond-chart-legend{display:flex;gap:20px;justify-content:center;margin-top:18px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.bond-legend-item{display:flex;align-items:center;gap:6px}
.bond-legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block}
.bond-legend-dot.coupon{background:var(--diff-intermediaire)}
.bond-legend-dot.principal{background:var(--diff-essentiel)}
.bond-chart-total{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);font-size:13px;color:var(--muted);text-align:center}
.bond-chart-total strong{color:var(--text)}
@media(max-width:600px){
  .bond-chart-bars{grid-template-columns:repeat(5,1fr);gap:6px;min-height:180px}
  .bond-bar{height:160px}
  .bond-bar-val{font-size:10px}
  .bond-bar-year{font-size:9px}
}

/* ─────────────── GLOSSARY TERMS (inline tooltip) ─────────────── */
.glossary-term{position:relative;display:inline-block;cursor:help}
.glossary-word{border-bottom:1px dotted var(--diff-intermediaire);color:inherit;transition:color .15s}
.glossary-term:hover .glossary-word,.glossary-term:focus .glossary-word{color:var(--diff-intermediaire);border-bottom-style:solid}
.glossary-tooltip{
  --tip-shift:0px;
  visibility:hidden;opacity:0;pointer-events:none;
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(calc(-50% + var(--tip-shift)));
  min-width:240px;max-width:min(340px, calc(100vw - 24px));
  background:#141413;color:#F0EEE6;
  padding:12px 14px;border-radius:8px;
  font-family:var(--sans);font-size:13px;line-height:1.55;font-weight:400;font-style:normal;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
  transition:opacity .15s,visibility .15s;
  z-index:500;white-space:normal;text-align:left;
}
.glossary-tooltip::after{
  content:'';position:absolute;top:100%;left:50%;
  transform:translateX(calc(-50% - var(--tip-shift)));
  border:6px solid transparent;border-top-color:#141413;
}
.glossary-term:hover .glossary-tooltip,.glossary-term:focus .glossary-tooltip,.glossary-term:focus-within .glossary-tooltip{
  visibility:visible;opacity:1;
}
@media(max-width:720px){
  .glossary-tooltip{min-width:200px;max-width:260px;font-size:12px}
}

/* ─────────────── GLOSSARY PAGE ─────────────── */
.glossary-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.glossary-print-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--text);border:1px solid var(--border2);padding:8px 14px;border-radius:var(--radius);font-weight:500;font-size:13px;cursor:pointer;transition:all .15s;font-family:var(--sans);flex-shrink:0}
.glossary-print-btn:hover{border-color:var(--text);background:var(--surface)}
.glossary-print-btn svg{flex-shrink:0}
.glossary-search-wrap{position:relative;margin:18px 0 24px;max-width:480px}
.glossary-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;display:flex;align-items:center}
.glossary-search{width:100%;padding:11px 40px 11px 42px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--bg);font-family:var(--sans);font-size:14.5px;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.glossary-search:focus{border-color:var(--diff-intermediaire);box-shadow:0 0 0 3px rgba(60,90,150,.1)}
.glossary-search::-webkit-search-cancel-button{display:none}
.glossary-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:24px;height:24px;border:none;background:rgba(0,0,0,.05);border-radius:50%;cursor:pointer;font-size:16px;line-height:1;color:var(--muted);display:flex;align-items:center;justify-content:center;padding:0;font-family:inherit;transition:background .15s,color .15s}
.glossary-search-clear:hover{background:rgba(0,0,0,.12);color:var(--text)}
.glossary-empty{margin:24px 0;padding:24px;text-align:center;color:var(--muted);background:var(--surface);border:1px dashed var(--border2);border-radius:var(--radius);font-size:14px}
.glossary-page{margin-top:24px}
.glossary-group{margin-bottom:32px}
.glossary-letter{
  font-family:var(--serif);font-size:40px;font-weight:600;
  color:var(--diff-intermediaire);line-height:1;
  padding-bottom:12px;margin-bottom:16px;border-bottom:1px solid var(--border);
}
.glossary-entries{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:720px){.glossary-entries{grid-template-columns:1fr}}
.glossary-entry{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;
}
.glossary-entry-term{
  font-family:var(--serif);font-size:16px;font-weight:600;color:var(--text);
  margin-bottom:6px;
}
.glossary-entry-def{
  font-size:13.5px;color:var(--muted);line-height:1.55;
}
.glossary-entry-subdef{margin-bottom:8px}
.glossary-entry-subdef:last-child{margin-bottom:0}
.glossary-entry-sublabel{
  font-weight:600;color:var(--text);font-style:italic;
  margin-right:4px;letter-spacing:.2px;
}
.glossary-entry-sublabel::after{content:" —";color:var(--muted);font-style:normal;font-weight:400}

/* ─────────────── FINISH ACTIONS ─────────────── */
.finish-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.finish-dl-ghost{background:transparent!important;color:var(--text)!important;border:1px solid var(--border2)}
.finish-dl-ghost:hover{background:var(--surface)!important;border-color:var(--text)}

/* ─────────────── CALLOUTS ─────────────── */
.highlight-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin:24px 0;position:relative;overflow:hidden}
.highlight-box::before{display:none}
.highlight-box .content-p{margin:0;color:var(--text)}
.highlight-box .section-title-sm{margin:0 0 10px;color:var(--text)}

/* ─────────────── TABLES ─────────────── */
.table-wrap{overflow-x:auto;margin:24px 0;border-radius:var(--radius);border:1px solid var(--border)}
.data-table{width:100%;border-collapse:collapse}
.data-table thead tr th{background:var(--surface);padding:12px 16px;text-align:left;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
.data-table tbody tr td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:15px;color:var(--muted);vertical-align:top;transition:background .12s;font-family:var(--serif);white-space:normal}
/* Keep numeric/amount columns on one line; the last column (long explanation) still wraps */
.data-table tbody tr td:nth-child(n+2){white-space:nowrap}
.data-table tbody tr td:last-child{white-space:normal}
.data-table tbody tr td.num, .data-table tbody tr td:has(> .nowrap){white-space:nowrap}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover td{background:var(--surface)}
.data-table strong{color:var(--text);font-weight:600}

/* ─────────────── SIMULATORS ─────────────── */
.simulator-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px;margin:40px 0;position:relative;overflow:hidden}
.simulator-wrap::before{display:none}
.sim-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px}
.sim-icon{width:40px;height:40px;background:var(--dark-d);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sim-title{font-family:var(--serif);font-size:21px;color:var(--text);font-weight:600}
.sim-sub{font-size:13px;color:var(--muted);margin-top:2px}
.sim-inputs{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}
@media(max-width:600px){.sim-inputs{grid-template-columns:1fr}}
.sim-field label{display:block;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.sim-field input[type=range]{width:100%;accent-color:var(--dark);height:3px;cursor:pointer;border-radius:2px}
.sim-value{font-family:var(--serif);font-size:22px;color:var(--text);margin-top:4px;font-weight:600}
.sim-results{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
@media(max-width:600px){.sim-results{grid-template-columns:1fr}}
.sim-result-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:14px;text-align:center}
.src-label{font-size:10px;color:var(--dim);font-weight:600;letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px}
.src-value{font-family:var(--serif);font-size:22px;color:var(--text);font-weight:600}
.src-value.gold{color:var(--text)}
.src-value.green{color:var(--green)}
.chart-container{position:relative;height:220px}

/* ─────────────── QUIZ ─────────────── */
.quiz-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px;margin:48px 0 0;position:relative;overflow:hidden}
.quiz-wrap::before{display:none}
.quiz-header{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.quiz-icon{width:36px;height:36px;background:var(--dark-d);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.quiz-title{font-family:var(--serif);font-size:21px;color:var(--text);font-weight:600}
.quiz-intro{font-size:14px;color:var(--muted);margin:8px 0 24px;padding-bottom:18px;border-bottom:1px solid var(--border);line-height:1.55}
.quiz-q{margin-bottom:24px}
.q-num{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--dim);margin-bottom:8px}
.q-text{font-size:16px;font-weight:500;color:var(--text);margin-bottom:12px;line-height:1.5}
.q-options{display:grid;gap:6px}
.q-option{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:11px 14px;cursor:pointer;font-size:14px;color:var(--muted);transition:all .12s;text-align:left;width:100%;line-height:1.4;font-family:var(--sans)}
.q-option:hover:not([disabled]){border-color:var(--border2);color:var(--text);background:var(--surface2)}
.q-option.selected{border-color:var(--dark);color:var(--text);background:var(--dark-d)}
.q-option.correct{border-color:var(--green)!important;color:var(--green)!important;background:var(--green-d)!important}
.q-option.wrong{border-color:var(--red)!important;color:var(--red)!important;background:var(--red-d)!important}
.q-explanation{margin-top:8px;padding:10px 14px;background:var(--green-d);border-radius:6px;font-size:13px;color:var(--muted);display:none;line-height:1.6;border-left:2px solid var(--green)}

/* ─────────────── QUIZ FEEDBACK (post-submit) ─────────────── */
.q-feedback{
  display:none;gap:10px;margin-top:12px;padding:12px 16px;border-radius:var(--radius);
  font-size:13.5px;line-height:1.6;align-items:flex-start;
  animation:pgIn .3s ease;
}
.q-feedback-icon{flex-shrink:0;margin-top:1px}
.q-feedback-body{flex:1}
.q-feedback-prefix{font-weight:600;margin-bottom:4px}
.q-feedback-explanation{color:var(--muted);font-size:13px;line-height:1.65}
.q-feedback-correct{
  background:rgba(61,122,95,.08);border:1px solid rgba(61,122,95,.2);
}
.q-feedback-correct .q-feedback-icon,.q-feedback-correct .q-feedback-prefix{color:var(--green)}
.q-feedback-wrong{
  background:rgba(201,137,48,.08);border:1px solid rgba(201,137,48,.2);
}
.q-feedback-wrong .q-feedback-icon,.q-feedback-wrong .q-feedback-prefix{color:var(--diff-intermediaire)}
.q-feedback-skipped{
  background:rgba(154,151,136,.08);border:1px solid rgba(154,151,136,.2);
}
.q-feedback-skipped .q-feedback-icon,.q-feedback-skipped .q-feedback-prefix{color:var(--muted)}
.quiz-actions{margin-top:24px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.quiz-score{display:none;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:24px;margin-top:20px;text-align:center}
.score-num{font-family:var(--serif);font-size:48px;color:var(--text);font-weight:600}
.score-sub{font-size:11px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.score-msg{font-size:15px;color:var(--muted);margin-top:12px;font-weight:400}

/* ─────────────── MODULE NAV — "Prev" + "Next" buttons ─────────────── */
.mod-nav{display:flex;justify-content:space-between;align-items:center;margin-top:60px;padding-top:24px;border-top:1px solid var(--border);gap:10px}
.nav-arrow{display:inline-flex;align-items:center;gap:8px;background:var(--dark);color:#fff;padding:10px 24px;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s;border:none;font-family:var(--sans)}
.nav-arrow:hover:not(.disabled){background:var(--dark-l)}
.nav-arrow.disabled{opacity:0.15;cursor:not-allowed;pointer-events:none;background:var(--dim);color:#fff}
.nav-arrow-prev{background:transparent;color:var(--muted);border:1px solid var(--border2)}
.nav-arrow-prev:hover:not(.disabled){background:var(--surface);color:var(--text);border-color:var(--text)}
.nav-arrow-prev.disabled{background:transparent;color:var(--dim);border-color:var(--border)}
.nav-arrow-finish{background:var(--green)}
.nav-arrow-finish:hover{background:#2E5F49}
/* Bouton "Module suivant" placé sous le bloc nav (après Terminer la formation) */
.mod-nav-bonus{display:flex;justify-content:flex-end;margin-top:12px}
.nav-arrow-bonus{background:transparent;color:var(--muted);border:1px solid var(--border2)}
.nav-arrow-bonus:hover{background:var(--surface);color:var(--text);border-color:var(--text)}

/* ─────────────── FINISH CARD ─────────────── */
.finish-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;margin-top:40px;text-align:center}
.finish-icon{display:inline-block;width:64px;height:64px;background:rgba(61,122,95,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--green)}
.finish-title{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--text);margin-bottom:8px}
.finish-desc{font-size:14px;color:var(--muted);margin-bottom:20px;line-height:1.65;max-width:450px;margin-left:auto;margin-right:auto}
.finish-dl{display:inline-flex;align-items:center;gap:8px;background:var(--dark);color:#fff;padding:12px 28px;border-radius:var(--radius);font-weight:500;font-size:14px;text-decoration:none;font-family:var(--sans);transition:all .15s}
.finish-dl:hover{background:var(--dark-l)}

/* ─────────────── STAT BOXES ─────────────── */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:24px 0}
.stat-row.two{grid-template-columns:repeat(2,1fr)}
.stat-row.four{grid-template-columns:repeat(4,1fr)}
.stat-row.three{grid-template-columns:repeat(3,1fr)}
.stat-row:has(> .stat-box:only-child){grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
@media(max-width:600px){.stat-row,.stat-row.two,.stat-row.four,.stat-row.three{grid-template-columns:repeat(2,1fr)}}
.stat-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 14px;text-align:center;transition:background .15s}
.stat-box:hover{background:var(--surface2)}
.stat-box .stat-num{font-family:var(--serif);font-size:32px;line-height:1;margin-bottom:6px;font-weight:600}
.stat-box .stat-lbl{font-size:11px;font-weight:500;color:var(--muted);line-height:1.4}
.stat-box.gold{border-color:rgba(139,115,64,.2);background:rgba(139,115,64,.05)}.stat-box.gold .stat-num{color:var(--gold)}
.stat-box.green{border-color:rgba(61,122,95,.2);background:rgba(61,122,95,.05)}.stat-box.green .stat-num{color:var(--green)}
.stat-box.red{border-color:rgba(180,64,64,.2);background:rgba(180,64,64,.05)}.stat-box.red .stat-num{color:var(--red)}
.stat-box.blue{border-color:rgba(91,127,164,.2);background:rgba(91,127,164,.05)}.stat-box.blue .stat-num{color:var(--blue)}

.feature-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:24px 0}
.feature-cards.three{grid-template-columns:repeat(3,1fr)}.feature-cards.four{grid-template-columns:repeat(2,1fr)}
@media(max-width:720px){.feature-cards,.feature-cards.three,.feature-cards.four{grid-template-columns:1fr}}
.feat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;gap:12px;align-items:flex-start;transition:background .12s}
.feat-card:hover{background:var(--surface2)}
.feat-icon{font-size:22px;line-height:1;flex-shrink:0;margin-top:1px}
.feat-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.feat-desc{font-size:13px;color:var(--muted);line-height:1.55}

.process-steps{display:flex;flex-direction:column;gap:0;margin:24px 0}
.proc-step{display:flex;gap:16px;align-items:flex-start;position:relative;padding-bottom:20px}
.proc-step:last-child{padding-bottom:0}
.proc-step::before{content:'';position:absolute;left:15px;top:36px;bottom:0;width:1px;background:var(--border)}
.proc-step:last-child::before{display:none}
.proc-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;font-weight:600;flex-shrink:0;position:relative;z-index:1}
.proc-num.gold{background:rgba(139,115,64,.1);color:var(--gold);border:1.5px solid rgba(139,115,64,.25)}
.proc-num.green{background:rgba(61,122,95,.1);color:var(--green);border:1.5px solid rgba(61,122,95,.25)}
.proc-num.blue{background:rgba(91,127,164,.1);color:var(--blue);border:1.5px solid rgba(91,127,164,.25)}
.proc-body{flex:1;padding-top:5px}
.proc-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}
.proc-desc{font-size:13px;color:var(--muted);line-height:1.6}

.tip-box{border-radius:var(--radius);padding:16px 18px;margin:20px 0;display:flex;gap:12px;align-items:flex-start}
.tip-box.warn{background:rgba(180,64,64,.05);border:1px solid rgba(180,64,64,.12)}
.tip-box.ok{background:rgba(61,122,95,.05);border:1px solid rgba(61,122,95,.12)}
.tip-box.info{background:rgba(91,127,164,.05);border:1px solid rgba(91,127,164,.12)}
.tip-box.gold{background:rgba(139,115,64,.05);border:1px solid rgba(139,115,64,.12)}
.tip-icon{font-size:20px;flex-shrink:0;line-height:1;margin-top:1px}
.tip-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.tip-box.warn .tip-title{color:var(--red)}.tip-box.ok .tip-title{color:var(--green)}.tip-box.info .tip-title{color:var(--blue)}.tip-box.gold .tip-title{color:var(--gold)}
.tip-text{font-size:14px;color:var(--muted);line-height:1.65}
.tip-text strong{color:var(--text)}

.compare-wrap{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:20px 0}
@media(max-width:600px){.compare-wrap{grid-template-columns:1fr}}
.cmp-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.cmp-col.good{border-color:rgba(61,122,95,.2);background:rgba(61,122,95,.04)}
.cmp-col.bad{border-color:rgba(180,64,64,.2);background:rgba(180,64,64,.04)}
.cmp-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:13px;font-weight:600}
.cmp-col.good .cmp-header{color:var(--green)}.cmp-col.bad .cmp-header{color:var(--red)}
.cmp-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.cmp-list li{font-size:13px;color:var(--muted);padding-left:18px;position:relative;line-height:1.5}
.cmp-list li::before{position:absolute;left:0}
.cmp-col.good .cmp-list li::before{content:'\2713';color:var(--green)}.cmp-col.bad .cmp-list li::before{content:'\2717';color:var(--red)}

.pull-number{text-align:center;padding:28px 20px;margin:28px 0;background:var(--surface);border-radius:12px;border:1px solid var(--border);position:relative;overflow:hidden}
.pull-number::before{display:none}
.pull-num{font-family:var(--serif);font-size:64px;line-height:1;font-weight:600}
.pull-number.gold .pull-num{color:var(--gold)}.pull-number.green .pull-num{color:var(--green)}.pull-number.red .pull-num{color:var(--red)}
.pull-desc{font-size:15px;color:var(--muted);margin-top:8px;line-height:1.5}
.pull-sub{font-size:11px;color:var(--dim);margin-top:6px;text-transform:uppercase;letter-spacing:1px}

.section-sep{display:flex;align-items:center;gap:14px;margin:36px 0}
.section-sep span{font-size:12px;font-weight:600;color:var(--dim);white-space:nowrap}
.section-sep::before,.section-sep::after{content:'';flex:1;height:1px;background:var(--border)}

/* ─────────────── HISTORICAL CHARTS ─────────────── */
.hchart-wrap{margin:28px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.hchart-header{padding:16px 20px 8px;display:flex;justify-content:space-between;align-items:flex-start}
.hchart-title{font-size:14px;font-weight:600;color:var(--text)}
.hchart-subtitle{font-size:12px;color:var(--muted);margin-top:2px}
.hchart-badge{font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:3px 8px;border-radius:4px;flex-shrink:0}
.hchart-badge.up{background:rgba(61,122,95,.1);color:var(--green)}
.hchart-badge.volatile{background:var(--red-d);color:var(--red)}
.hchart-canvas-wrap{padding:0 4px 6px;position:relative}
.hchart-crisis .hchart-canvas-wrap{height:220px}

/* ─────────────── GAVE QUADRANT ─────────────── */
.gave-wrap{margin:32px 0;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px}
.gave-title{font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:24px;text-align:center}
.gave-axes-wrapper{display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:12px}
.gave-y-axis{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding:10px 8px 10px 0;min-width:90px}
.gave-y-axis .gave-axis-label{white-space:nowrap;text-align:right}
.gave-x-axis{grid-column:2;display:flex;justify-content:space-between;padding:0 10px;margin-top:6px}
.gave-axis-label{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.3px}
.gave-grid{grid-column:2;display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:720px){.gave-grid{grid-template-columns:1fr}.gave-y-axis{display:none}.gave-x-axis{display:none}}
.gave-quadrant{border-radius:var(--radius);padding:16px;transition:background .12s;cursor:default}
.gave-quadrant:hover{opacity:.9}
.gq-num{font-family:var(--serif);font-size:28px;opacity:0.1;float:right;line-height:1;margin-top:-4px}
.gq-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.gq-name{font-family:var(--serif);font-size:16px;color:var(--text);margin-bottom:8px;line-height:1.25;clear:both;font-weight:600}
.gq-condition{font-size:11px;color:var(--dim);margin-bottom:8px;font-weight:500}
.gq-assets{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.gq-asset{font-size:10px;font-weight:500;padding:2px 7px;border-radius:4px;white-space:nowrap}
.gq-example{font-size:11px;color:var(--dim);font-style:italic;margin-top:8px;border-top:1px solid rgba(0,0,0,.06);padding-top:8px}
.gq1{background:rgba(91,127,164,.08);border:1px solid rgba(91,127,164,.15)}.gq1 .gq-label,.gq1 .gq-num{color:var(--blue)}.gq1 .gq-asset{background:rgba(91,127,164,.1);color:var(--blue)}
.gq2{background:rgba(139,115,64,.08);border:1px solid rgba(139,115,64,.15)}.gq2 .gq-label,.gq2 .gq-num{color:var(--gold)}.gq2 .gq-asset{background:rgba(139,115,64,.1);color:var(--gold)}
.gq3{background:rgba(180,64,64,.08);border:1px solid rgba(180,64,64,.15)}.gq3 .gq-label,.gq3 .gq-num{color:var(--red)}.gq3 .gq-asset{background:rgba(180,64,64,.1);color:var(--red)}
.gq4{background:rgba(61,122,95,.08);border:1px solid rgba(61,122,95,.15)}.gq4 .gq-label,.gq4 .gq-num{color:var(--green)}.gq4 .gq-asset{background:rgba(61,122,95,.1);color:var(--green)}

/* ─────────────── COUNTRY SELECTOR ─────────────── */
.country-sel-label{font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--dim);margin-bottom:14px}
.country-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px}
@media(max-width:600px){.country-grid{grid-template-columns:repeat(3,1fr)}}
.country-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 8px;cursor:pointer;transition:all .12s;display:flex;flex-direction:column;align-items:center;gap:4px}
.country-btn:hover{background:var(--surface2);border-color:var(--border2)}
.country-btn.active{border-color:var(--dark);background:var(--dark-d)}
.country-flag{font-size:20px;line-height:1}
.country-name-short{font-size:11px;font-weight:500;color:var(--muted);text-align:center;line-height:1.2}
.country-btn.active .country-name-short{color:var(--text)}
.country-section-title{display:flex;align-items:center;gap:10px;font-size:24px !important;padding-left:0 !important;margin-top:24px !important}
.country-section-title::before{display:none !important}
.country-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:1px dashed var(--border);border-radius:var(--radius);text-align:center;gap:10px}
.placeholder-icon{font-size:32px}
.placeholder-text{font-size:14px;color:var(--dim);max-width:300px;line-height:1.55}
.country-section-content{animation:pgIn .25s ease}

/* ─────────────── PORTFOLIO SIMULATOR ─────────────── */
.port-row{display:flex;flex-direction:column;gap:5px;padding:9px 0;border-bottom:1px solid var(--border)}
.port-row:last-child{border-bottom:none}
.port-asset-info{display:flex;align-items:center;gap:8px}
.port-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.port-asset-name{font-size:13px;font-weight:500;color:var(--text);flex:1}
.port-asset-ret{font-size:11px;font-weight:600}
.port-slider-wrap{display:flex;align-items:center;gap:10px}
.port-slider{flex:1;height:3px;cursor:pointer;border-radius:2px}
.port-pct{font-family:var(--serif);font-size:18px;color:var(--text);min-width:36px;text-align:right;font-weight:600}

/* ─────────────── ILLUS ─────────────── */
.illus-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin:24px 0}
.illus-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-bottom:14px}
.illus-note{font-size:12px;color:var(--dim);margin-top:10px;font-style:italic;text-align:center}
.illus-bar-chart{display:flex;align-items:flex-end;gap:14px;height:160px;justify-content:center}
.illus-bar-group{display:flex;flex-direction:column;align-items:center;gap:4px}
.illus-bar{width:40px;border-radius:3px 3px 0 0}
.illus-bar-val{font-family:var(--serif);font-size:12px;color:var(--muted)}
.illus-bar-yr{font-size:11px;color:var(--dim);font-weight:600}
.illus-compare{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center}
.illus-vs{font-family:var(--serif);font-size:28px;color:var(--dim);text-align:center}
.illus-person{background:var(--bg);border-radius:8px;padding:14px}
.illus-person-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid}
.illus-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;font-family:var(--serif)}
.illus-person-name{font-weight:600;font-size:14px;color:var(--text)}
.illus-person-sub{font-size:11px;color:var(--muted)}
.illus-stat{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border)}
.illus-stat:last-of-type{border-bottom:none}
.illus-stat-label{font-size:11px;color:var(--dim);font-weight:500}
.illus-stat-val{font-family:var(--serif);font-size:17px;font-weight:600}
.illus-win-badge{margin-top:8px;background:rgba(61,122,95,.07);border:1px solid rgba(61,122,95,.15);border-radius:4px;padding:5px 8px;font-size:12px;color:var(--green);font-weight:500;text-align:center}
.risk-bubble{position:absolute;padding:6px 8px;border:1px solid;border-radius:6px;font-size:11px;font-weight:600;text-align:center;line-height:1.2}
.risk-bubble small{font-size:10px;font-weight:400;opacity:.8;display:block}
.risk-bubble.large{padding:8px 10px;font-size:12px}
.cycle-wrap{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:4px;align-items:center}
@media(max-width:720px){.cycle-wrap{grid-template-columns:1fr}.cycle-arrow{text-align:center}}
.cycle-phase{background:var(--surface);border:1px solid;border-radius:8px;padding:12px;text-align:center}
.cycle-num{font-family:var(--serif);font-size:26px;line-height:1;font-weight:600}
.cycle-name{font-weight:600;font-size:13px;margin:3px 0}
.cycle-desc{font-size:11px;color:var(--muted);line-height:1.4;margin-bottom:5px}
.cycle-best{font-size:11px;color:var(--dim);font-weight:500}
.cycle-arrow{font-size:18px;color:var(--dim);padding:0 4px;text-align:center}
.bias-pill{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}
.bias-emoji{font-size:22px}
.bias-name{font-size:12px;font-weight:500;color:var(--muted);line-height:1.3}

/* ─────────────── TRANSLATION BANNER ─────────────── */
.trans-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);margin-bottom:20px;font-size:13px}
.trans-banner.loading{background:var(--dark-d);border:1px solid var(--border);color:var(--muted)}
.trans-banner.error{background:var(--red-d);border:1px solid rgba(180,64,64,.12);color:var(--red)}
.trans-spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--dark);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}

/* ─────────────── EXPRESS TRACK TOGGLE ─────────────── */
.express-toggle{display:flex;align-items:center;gap:10px;margin:8px 16px;padding:10px 12px;border-radius:8px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .15s;user-select:none}
.express-toggle:hover{background:var(--dark-d);border-color:var(--dark)}
.express-toggle.active{background:linear-gradient(135deg,#FFD96B 0%,#F4B942 100%);border-color:#D89F2C;color:#3a2a06}
.express-toggle.active .express-toggle-label{color:#3a2a06}
.express-toggle.active .express-toggle-sub{color:#3a2a06;opacity:.85}
.express-toggle-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.06)}
.express-toggle.active .express-toggle-icon{background:rgba(255,255,255,.4)}
.express-toggle-text{flex:1;line-height:1.2}
.express-toggle-label{font-size:12px;font-weight:600;color:var(--text)}
.express-toggle-sub{font-size:11px;color:var(--muted);margin-top:2px}

/* Optional modules — visual dimming when express is OFF and module is non-essential */
.nav-item.optional{opacity:.65}
.nav-item.optional:hover{opacity:1}
.nav-item.optional .nav-label{font-style:italic}
.opt-badge{display:inline-block;margin-left:6px;font-size:10px;font-weight:700;color:var(--diff-avance);background:rgba(180,90,40,.1);border:1px solid rgba(180,90,40,.18);border-radius:4px;padding:1px 5px;vertical-align:middle;line-height:1.2}

/* ─────────────── OBJECTIVES BOX (A1) ─────────────── */
.objectives-box{margin:24px 0 32px;padding:18px 22px;background:linear-gradient(135deg,rgba(60,90,150,.04) 0%,rgba(60,90,150,.07) 100%);border:1px solid rgba(60,90,150,.15);border-radius:10px;border-left:3px solid #3C5A96}
.objectives-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.objectives-icon{flex-shrink:0;color:#3C5A96}
.objectives-title{font-size:13px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:#3C5A96}
.objectives-list{margin:0;padding-left:22px;list-style:none}
.objectives-list li{position:relative;padding:6px 0 6px 22px;font-size:14.5px;line-height:1.5;color:var(--text)}
.objectives-list li::before{content:"";position:absolute;left:0;top:13px;width:11px;height:7px;border-left:2px solid #3C5A96;border-bottom:2px solid #3C5A96;transform:rotate(-45deg)}

/* ─────────────── RECAP BOX (post-quiz) ─────────────── */
.recap-box{margin:32px 0;padding:18px 22px;background:linear-gradient(135deg,rgba(61,122,95,.04) 0%,rgba(61,122,95,.07) 100%);border:1px solid rgba(61,122,95,.18);border-radius:10px;border-left:3px solid #3D7A5F}
.recap-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.recap-icon{flex-shrink:0;color:#3D7A5F}
.recap-title{font-size:13px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:#3D7A5F}
.recap-list{margin:0;padding-left:22px;list-style:none}
.recap-list li{position:relative;padding:6px 0 6px 22px;font-size:14.5px;line-height:1.55;color:var(--text)}
.recap-list li::before{content:"";position:absolute;left:0;top:14px;width:6px;height:6px;background:#3D7A5F;border-radius:50%}

/* ─────────────── INLINE MINI-QUIZ (A3) ─────────────── */
.mini-quiz{margin:28px 0;padding:18px 22px;background:rgba(244,185,66,.06);border:1px solid rgba(244,185,66,.2);border-left:3px solid #F4B942;border-radius:10px}
.mini-quiz-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.mini-quiz-icon{color:#9A6F00;flex-shrink:0}
.mini-quiz-tag{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#9A6F00}
.mini-quiz-q{font-size:15px;font-weight:500;margin-bottom:14px;color:var(--text);line-height:1.5}
.mini-quiz-opts{display:flex;flex-direction:column;gap:8px}
.mini-quiz-opt{padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;text-align:left;font-size:14px;transition:all .12s;font-family:inherit;color:var(--text)}
.mini-quiz-opt:hover{border-color:var(--dark);background:var(--dark-d)}
.mini-quiz-opt.correct{background:rgba(61,122,95,.1);border-color:#3D7A5F;color:#2A5C46}
.mini-quiz-opt.wrong{background:rgba(180,64,64,.07);border-color:#B44040;color:#7A2828}
.mini-quiz-feedback{margin-top:12px;padding:12px;background:var(--surface);border-radius:6px;font-size:13.5px;line-height:1.55;display:none}
.mini-quiz-feedback.show{display:block}
.mini-quiz-feedback.correct{border-left:3px solid #3D7A5F}
.mini-quiz-feedback.wrong{border-left:3px solid #B44040}

/* ─────────────── ACADEMIC REFERENCES (A7) ─────────────── */
.academic-ref{position:relative;display:inline-block;font-size:11px;color:#3C5A96;background:rgba(60,90,150,.06);border:1px solid rgba(60,90,150,.15);border-radius:3px;padding:0 5px;margin:0 2px;font-style:italic;font-family:var(--sans);font-weight:500;line-height:1.5;vertical-align:baseline;cursor:help}
.academic-ref::before{content:"§ "}
.academic-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);min-width:280px;max-width:380px;background:#1F2937;color:#F4F1E8;font-style:normal;font-weight:400;font-size:12.5px;line-height:1.5;padding:12px 14px;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.18);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s ease;z-index:1000;text-align:left;white-space:normal}
.academic-tooltip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:#1F2937}
.academic-ref:hover .academic-tooltip,.academic-ref:focus .academic-tooltip{opacity:1;visibility:visible}
.academic-tooltip-work{display:block;font-weight:600;color:#FFF;margin-bottom:3px;font-size:13px}
.academic-tooltip-meta{display:block;color:#A4B0BC;font-size:11.5px;margin-bottom:8px;letter-spacing:.2px}
.academic-tooltip-summary{display:block;color:#E5E2D3;font-size:12px;line-height:1.55}
@media(max-width:720px){.academic-tooltip{min-width:240px;max-width:calc(100vw - 40px);left:0;transform:none}.academic-tooltip::after{left:24px;transform:none}}

/* ─────────────── AMF WARNING BOX (A6) ─────────────── */
.amf-warning{margin:28px 0;padding:18px 22px;background:rgba(180,64,64,.04);border:1px solid rgba(180,64,64,.2);border-left:3px solid #B44040;border-radius:10px}
.amf-warning-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.amf-warning-icon{flex-shrink:0;color:#B44040}
.amf-warning-title{font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#B44040}
.amf-warning-body{font-size:14px;line-height:1.6;color:var(--text)}
.amf-warning-body strong{color:#7A2828}

/* ─────────────── ABOUT PAGE — Hugo De Moura (legacy, page is now standalone) ─────────────── */
.about-page{max-width:840px;margin:0 auto;padding:48px 32px}
.about-hero{display:grid;grid-template-columns:200px 1fr;gap:36px;margin:36px 0 48px;align-items:start}
@media(max-width:720px){.about-hero{grid-template-columns:1fr;text-align:center}}
.about-photo-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}
.about-photo-placeholder{width:160px;height:160px;border-radius:50%;background:linear-gradient(135deg,#3D7A5F 0%,#2A5C46 100%);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px rgba(61,122,95,.2)}
.about-credentials{padding:10px 14px;background:linear-gradient(135deg,#FAF9F5 0%,#F0EDE5 100%);border:1px solid var(--border);border-radius:10px;text-align:center}
.about-cred-line{display:flex;flex-direction:column;gap:2px}
.about-cred-label{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--text);letter-spacing:1px}
.about-cred-text{font-size:11px;color:var(--muted);line-height:1.3}
.about-bio{display:flex;flex-direction:column;gap:14px}
.about-name{font-family:var(--serif);font-size:34px;font-weight:600;color:var(--text);margin:0;line-height:1.1}
.about-tagline{font-size:16px;color:var(--green);font-weight:500;margin:0;font-style:italic}
.about-paragraph{font-size:15.5px;line-height:1.7;color:var(--text);margin:0}
.about-cta{margin-top:48px;padding:36px;background:linear-gradient(135deg,#FAF9F5 0%,#F0EDE5 100%);border-radius:14px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.about-cta-title{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--text);margin:0}
.about-cta-text{font-size:14.5px;color:var(--muted);margin:0;max-width:480px;line-height:1.5}
.about-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--text);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .12s}
.about-cta-btn:hover{transform:scale(1.02)}

/* sb-section bonus — section header for bonus modules */
.sb-section.sb-bonus{display:flex;align-items:center;gap:6px;color:var(--green)}
.nav-item.bonus .nav-badge{background:rgba(61,122,95,.08);border-color:rgba(61,122,95,.2);color:var(--green)}

/* ─────────────── LANGUAGE TOGGLE BUTTON ─────────────── */
.course-hdr .lang-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--muted);transition:border-color .15s,background .15s;letter-spacing:.5px;margin-left:14px}
.course-hdr .lang-toggle-btn:hover{background:var(--dark-d);border-color:var(--dark)}
.course-hdr .lang-toggle-btn .lang-fr,
.course-hdr .lang-toggle-btn .lang-en{padding:2px 4px;border-radius:4px;transition:color .15s,background .15s}
.course-hdr .lang-toggle-btn .active{color:var(--text);background:var(--dark-d)}
.course-hdr .lang-toggle-btn .lang-sep{color:var(--dim);opacity:.5}

/* ─────────────── BONUS MODULES SECTION (landing) ─────────────── */
.mod-group-bonus{margin-top:32px}
.grid-hd.diff-bonus{
  display:flex;align-items:center;gap:8px;
  color:#7D8E70;
  border-color:#A8B89C;
}
.mod-card-bonus{
  border-color:rgba(168,184,156,.35);
  background:linear-gradient(180deg,rgba(168,184,156,.04) 0%,transparent 100%);
}
.mod-card-bonus:hover{border-color:rgba(168,184,156,.6)}
.mc-bonus-badge{
  display:inline-block;
  margin-left:8px;
  padding:2px 7px;
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.5px;
  border-radius:4px;
  background:rgba(168,184,156,.18);
  color:#5C6E50;
  vertical-align:middle;
  text-transform:uppercase;
}

/* ─────────────── PULL-QUOTE — phrases marquantes dans le contenu ─────────────── */
.pull-quote{
  margin:48px auto 44px;
  max-width:720px;
  padding:0 20px;
  text-align:center;
  font-family:var(--serif);
  font-size:32px;
  font-weight:600;
  line-height:1.25;
  letter-spacing:-0.4px;
  color:var(--text);
}
.pull-quote::after{
  content:"";
  display:block;
  width:48px;
  height:2px;
  background:var(--gold);
  margin:24px auto 0;
  border-radius:2px;
}
@media(max-width:720px){
  .pull-quote{font-size:24px;margin:32px 0;padding:0 8px}
  .pull-quote::after{width:36px;margin-top:20px}
}

/* ─────────────── INFLATION TABLE — dégradé de "fonte" sur la colonne valeur réelle ─────────────── */
/* Adoucit le côté anxiogène en remplaçant le rouge frontal par un dégradé ambré progressif. */
.inflation-table th:nth-child(3),
.inflation-table td:nth-child(3){
  font-weight:600;
  font-family:var(--serif);
  font-size:16px;
}
.inflation-table th:nth-child(3){
  color:var(--gold);
}
/* Erosion cell variants — color drifts from neutral to warm amber as the value drops */
.erosion-cell{transition:background .2s}
.erosion-cell.erosion-100{background:rgba(61,122,95,.06);color:var(--green)}
.erosion-cell.erosion-90 {background:rgba(139,115,64,.04);color:var(--text)}
.erosion-cell.erosion-82 {background:rgba(139,115,64,.08);color:#7A6332}
.erosion-cell.erosion-67 {background:rgba(180,108,40,.10);color:#9A5F1F}
.erosion-cell.erosion-55 {background:rgba(180,108,40,.16);color:#7E4814;font-weight:700}

/* ─────────────── EROSION CALLOUT — alternative plus douce au stat-box rouge ─────────────── */
.erosion-callout{
  display:flex;
  align-items:center;
  gap:24px;
  margin:24px 0 28px;
  padding:22px 26px;
  background:linear-gradient(135deg, rgba(139,115,64,.08) 0%, rgba(180,108,40,.05) 100%);
  border:1px solid rgba(139,115,64,.18);
  border-left:4px solid var(--gold);
  border-radius:12px;
}
.erosion-callout-num{
  font-family:var(--serif);
  font-size:46px;
  font-weight:600;
  line-height:1;
  color:var(--gold);
  letter-spacing:-1px;
  flex-shrink:0;
}
.erosion-callout-text{
  font-family:var(--sans);
  font-size:15px;
  line-height:1.55;
  color:var(--text);
}
@media (max-width: 600px){
  .erosion-callout{flex-direction:column;align-items:flex-start;gap:10px;padding:18px 20px}
  .erosion-callout-num{font-size:38px}
}

/* ─────────────── STORY CARDS — Marie/Thomas type comparison ─────────────── */
.story-card-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin:28px 0;
}
.story-card{
  padding:24px 22px;
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:14px;
  transition:transform .18s,box-shadow .18s;
}
.story-card:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.06)}
.story-card-marie{border-top:3px solid var(--gold)}
.story-card-thomas{border-top:3px solid var(--green)}

.story-card-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.story-card-avatar{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  font-family:var(--serif);font-size:20px;font-weight:600;
  color:#fff;flex-shrink:0;
}
.story-avatar-marie{background:var(--gold)}
.story-avatar-thomas{background:var(--green)}
.story-card-name{
  font-family:var(--serif);font-size:22px;font-weight:600;color:var(--text);
  letter-spacing:-0.2px;line-height:1.1;
}
.story-card-tag{
  font-family:var(--sans);font-size:12px;color:var(--muted);
  margin-top:3px;letter-spacing:.1px;
}

.story-card-timeline{margin-bottom:14px}
.story-tl-track{
  position:relative;
  height:8px;background:var(--surface);border-radius:4px;overflow:hidden;
}
.story-tl-fill{
  position:absolute;top:0;bottom:0;border-radius:4px;
}
.story-tl-fill-marie{background:linear-gradient(90deg, var(--gold), #B59450)}
.story-tl-fill-thomas{background:linear-gradient(90deg, var(--green), #5BA482)}
.story-tl-labels{
  display:flex;justify-content:space-between;
  margin-top:6px;
  font-family:var(--sans);font-size:11px;color:var(--dim);
}
.story-tl-labels span:nth-child(2){opacity:.7}

.story-card-note{
  font-family:var(--sans);font-size:13.5px;
  color:var(--muted);line-height:1.5;
  padding:12px 14px;
  background:var(--surface);
  border-radius:8px;
  margin-bottom:16px;
}
.story-card-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
  padding-top:16px;border-top:1px solid var(--border);
}
.story-stat-lbl{
  font-family:var(--sans);font-size:11px;font-weight:500;
  color:var(--dim);text-transform:uppercase;letter-spacing:.6px;
  margin-bottom:4px;
}
.story-stat-val{
  font-family:var(--serif);font-size:20px;font-weight:600;
  color:var(--text);line-height:1;letter-spacing:-0.3px;
}
.story-stat-final-val{font-size:24px}
.story-card-marie .story-stat-final-val{color:var(--gold)}
.story-card-thomas .story-stat-final-val{color:var(--green)}

/* ─────────────── STORY CHART — comparative SVG curves ─────────────── */
.story-chart-wrap{
  margin:20px 0 28px;
  padding:24px 24px 18px;
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:14px;
}
.story-chart-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:16px;flex-wrap:wrap;gap:10px;
}
.story-chart-title{
  font-family:var(--sans);font-size:14px;font-weight:600;
  color:var(--text);letter-spacing:.1px;
}
.story-chart-legend{display:flex;gap:18px}
.story-legend-item{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--sans);font-size:12.5px;color:var(--muted);font-weight:500;
}
.story-legend-dot{
  display:inline-block;width:10px;height:10px;border-radius:50%;
}
.story-legend-marie{background:var(--gold)}
.story-legend-thomas{background:var(--green)}
.story-chart-svg{width:100%;height:auto;display:block;max-height:320px}

/* ─────────────── STORY CONCLUSION — punch line under the comparison ─────────────── */
.story-conclusion{
  display:flex;align-items:center;gap:24px;
  margin:24px 0 32px;
  padding:24px 28px;
  background:linear-gradient(135deg, rgba(139,115,64,.06), rgba(61,122,95,.06));
  border:1px solid var(--border);
  border-radius:14px;
}
.story-conclusion-num{
  font-family:var(--serif);
  font-size:54px;font-weight:600;line-height:1;
  color:var(--text);letter-spacing:-2px;
  flex-shrink:0;
}
.story-conclusion-text{
  font-family:var(--sans);font-size:15.5px;line-height:1.6;
  color:var(--text);
}

/* Mobile: stack the comparison cards */
@media(max-width:720px){
  .story-card-row{grid-template-columns:1fr;gap:16px}
  .story-card{padding:20px 18px}
  .story-conclusion{flex-direction:column;align-items:flex-start;gap:12px;padding:20px 22px}
  .story-conclusion-num{font-size:42px}
  .story-chart-wrap{padding:18px 14px}
  .story-chart-svg{max-height:260px}
}

/* ─────────────── DOODLES — illustrations style "carnet de notes" ─────────────── */
/* Petits dessins minimalistes (bonhommes bâton, billets, etc.) pour aérer le contenu */

.doodle{
  color:var(--muted);
  display:block;
}
.doodle svg{display:block;width:100%;height:auto}

/* En marge à droite : flotte à droite, le texte continue à gauche */
.doodle-margin-right{
  float:right;
  width:90px;
  margin:8px 0 18px 24px;
  shape-outside:margin-box;
}
/* En marge à gauche : flotte à gauche */
.doodle-margin-left{
  float:left;
  width:90px;
  margin:8px 24px 18px 0;
  shape-outside:margin-box;
}
/* Petit doodle inline dans le flux du texte */
.doodle-inline{
  display:inline-block;
  width:28px;
  vertical-align:middle;
  margin:0 4px;
  color:var(--gold);
}
/* Section illustrée : doodle en grand, centré, comme un séparateur visuel */
.doodle-section{
  margin:36px auto;
  width:140px;
  text-align:center;
  color:var(--gold);
  opacity:.85;
}
.doodle-section svg{margin:0 auto}

/* Variante avec accent couleur */
.doodle-gold{color:var(--gold)}
.doodle-green{color:var(--green)}
.doodle-blue{color:#5B7FA4}
.doodle-text{color:var(--text)}

/* Mobile: les doodles en marge passent en pleine largeur centrée */
@media(max-width:720px){
  .doodle-margin-right,
  .doodle-margin-left{
    float:none;
    width:80px;
    margin:18px auto 14px;
  }
  .doodle-section{width:110px;margin:28px auto}
}

/* Les blocs structurés ne doivent jamais chevaucher un doodle flottant.
   On les force à descendre sous le float pour préserver la mise en forme. */
.table-wrap,
.hchart-wrap,
.gave-wrap,
.stat-row,
.asset-card,
.bond-chart-wrap,
.crash-legend,
.mini-quiz,
.tip-box,
.amf-warning,
.pull-quote,
.section-sep,
.mod-nav{clear:both}
/* ─────────────── PAYWALL — sidebar locks + inline cards ─────────────── */

/* Lock badge in sidebar nav items */
.lock-badge{
  display:inline-flex;align-items:center;justify-content:center;
  margin-left:6px;
  width:16px;height:16px;
  border-radius:4px;
  background:var(--dark-d);
  color:var(--dim);
  vertical-align:middle;
}
.lock-badge svg{display:block}

/* Locked nav items: subtle dim but still clickable (they show paywall when clicked) */
.nav-item.locked .nav-label{color:var(--dim)}
.nav-item.locked .nav-badge{background:var(--surface2);color:var(--dim);border-color:var(--border)}
.nav-item.locked:hover .nav-label{color:var(--text)}
.nav-item.locked:hover .lock-badge{background:var(--gold-d);color:var(--gold)}

/* ─────────────── PAYWALL CARD — used inline in modules ─────────────── */
.paywall-card{
  margin:28px auto;
  max-width:680px;
  padding:36px 36px 32px;
  background:linear-gradient(180deg, #FFFFFF 0%, #FAF9F5 100%);
  border:1px solid var(--border2);
  border-radius:14px;
  box-shadow:var(--shadow-md);
  text-align:center;
  animation:slideUp .35s ease both;
}
.paywall-card .pw-mod-tag{
  display:inline-block;
  font-family:var(--sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--dim);
  margin-bottom:18px;
  padding:5px 12px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:999px;
}
.paywall-card .pw-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;
  margin-bottom:18px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--gold-d), var(--surface));
  color:var(--gold);
  border:1px solid rgba(139,115,64,.25);
}
.paywall-card .pw-title{
  font-family:var(--serif);
  font-size:28px;
  font-weight:600;
  line-height:1.25;
  color:var(--text);
  margin:0 0 12px;
  letter-spacing:-0.3px;
}
.paywall-card .pw-body{
  font-family:var(--sans);
  font-size:15.5px;
  line-height:1.65;
  color:var(--muted);
  max-width:540px;
  margin:0 auto 24px;
}
.paywall-card .pw-cta-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:12px;
  margin-bottom:18px;
}
.paywall-card .pw-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;
  background:var(--dark);
  color:#fff;
  font-family:var(--sans);
  font-weight:600;
  font-size:14.5px;
  letter-spacing:.2px;
  border-radius:8px;
  border:none;
  cursor:pointer;
  text-decoration:none;
  transition:all .18s;
}
.paywall-card .pw-primary:hover{
  background:var(--dark-l);
  box-shadow:0 6px 20px rgba(20,20,19,.18);
  transform:translateY(-1px);
}
.paywall-card .pw-secondary{
  display:inline-flex;align-items:center;gap:6px;
  padding:14px 22px;
  background:transparent;
  color:var(--text);
  font-family:var(--sans);
  font-weight:500;
  font-size:14px;
  border:1px solid var(--border2);
  border-radius:8px;
  cursor:pointer;
  text-decoration:none;
  transition:all .15s;
}
.paywall-card .pw-secondary:hover{
  border-color:var(--text);
  background:var(--dark-d);
}
.paywall-card .pw-footer{
  font-family:var(--sans);
  font-size:12.5px;
  color:var(--dim);
  letter-spacing:.1px;
}

/* Larger card when used as the entire content (locked module) */
.paywall-locked_module{
  margin-top:48px;
  margin-bottom:48px;
  padding:48px 40px 40px;
}
.paywall-locked_module .pw-title{font-size:32px}

/* ─────────────── HEADER USER STATE (course.html) ─────────────── */
.hdr-user-slot{
  display:flex;align-items:center;gap:12px;
}
.hdr-user-slot .hdr-link{
  font-size:13.5px;
  font-family:var(--sans);
  color:var(--text);
  text-decoration:none;
  font-weight:500;
  padding:8px 14px;
  border-radius:6px;
  transition:background .12s;
}
.hdr-user-slot .hdr-link:hover{background:rgba(0,0,0,.05)}
.hdr-user-slot .hdr-unlock{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  border-radius:999px;
  background:var(--gold-d);
  color:var(--gold);
  font-weight:600;
  border:1px solid rgba(139,115,64,.2);
}
.hdr-user-slot .hdr-unlock:hover{
  background:var(--gold);color:#fff;border-color:var(--gold);
}
.hdr-user-slot .btn-primary.btn-sm{
  font-family:var(--sans);
  font-size:13.5px;
  font-weight:500;
  padding:9px 18px;
  border-radius:8px;
  text-decoration:none;
}

.hdr-user{
  position:relative;
  display:flex;align-items:center;gap:8px;
  padding:5px 10px 5px 5px;
  border-radius:999px;
  border:1px solid var(--border2);
  cursor:pointer;
  transition:background .15s,border-color .15s;
}
.hdr-user:hover{background:var(--dark-d);border-color:var(--text)}
.hdr-user-avatar{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--dark);color:#fff;
  font-family:var(--sans);font-weight:600;font-size:13px;
}
.hdr-user-name{
  font-family:var(--sans);
  font-size:13.5px;
  color:var(--text);
  font-weight:500;
  max-width:120px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hdr-user-caret{font-size:10px;color:var(--dim)}

.hdr-user-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  min-width:240px;
  background:#fff;
  border:1px solid var(--border2);
  border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  padding:6px;
  display:none;
  z-index:300;
}
.hdr-user-menu.open{display:block;animation:fadeIn .15s ease both}
.hdr-user-menu-info{
  padding:12px 14px 10px;
  border-bottom:1px solid var(--border);
  margin-bottom:4px;
}
.hdr-user-menu-name{font-family:var(--sans);font-weight:600;font-size:14px;color:var(--text);margin-bottom:2px}
.hdr-user-menu-email{font-family:var(--sans);font-size:12.5px;color:var(--dim);overflow:hidden;text-overflow:ellipsis}
.hdr-user-menu-item{
  display:flex;align-items:center;gap:10px;
  width:100%;
  padding:10px 14px;
  background:transparent;
  border:none;
  font-family:var(--sans);
  font-size:13.5px;
  color:var(--text);
  text-align:left;
  text-decoration:none;
  cursor:pointer;
  border-radius:6px;
  transition:background .12s;
}
.hdr-user-menu-item:hover{background:var(--surface)}
.hdr-user-menu-item.primary{
  color:var(--gold);
  font-weight:600;
}
.hdr-user-menu-item.primary:hover{background:var(--gold-d)}

/* Mobile adjustments */
@media (max-width: 760px) {
  .paywall-card{padding:28px 22px 22px;margin:20px 12px}
  .paywall-card .pw-title{font-size:22px}
  .paywall-card .pw-body{font-size:14.5px}
  .paywall-card .pw-primary, .paywall-card .pw-secondary{width:100%;justify-content:center}
  .hdr-user-name{display:none}
  .hdr-user-slot .hdr-link{font-size:12.5px}
}

/* ── Anti-FOUC : masque main pendant le rendu initial JS ── */
.main { opacity: 0; transition: opacity 0.15s ease-out; }
.main.ready { opacity: 1; }
