:root{
  --paper:#faf7f2;
  --paper-2:#fffdf8;
  --ink:#1c1c1c;
  --muted:#6b7280;
  --line:#ded7ca;
  --line-soft:rgba(28,28,28,.09);
  --rust:#c25a2e;
  --rust-2:#e85d04;
  --navy:#31455a;
  --blue:#1e88e5;
  --sand:#d7d2c7;
  --card:#fffaf1;
  --shadow:0 18px 44px rgba(28,28,28,.08);
  --soft-shadow:0 4px 14px rgba(28,28,28,.06);
  --radius:18px;
  --serif: Georgia, 'Times New Roman', serif;
  --sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
[data-theme="dark"]{
  --paper:#101113;
  --paper-2:#15171a;
  --ink:#f4efe6;
  --muted:#a7adb7;
  --line:#2d3136;
  --line-soft:rgba(244,239,230,.10);
  --card:#181a1e;
  --shadow:0 22px 54px rgba(0,0,0,.38);
  --soft-shadow:0 4px 14px rgba(0,0,0,.24);
  --sand:#262a30;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:
    radial-gradient(circle at 20% 0%, rgba(194,90,46,.05), transparent 26rem),
    linear-gradient(180deg,var(--paper),var(--paper-2));
  min-height:100vh;
}
body.lite *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
body.lite .ornament, body.lite .soft-bg{display:none!important}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}
a{color:inherit}
::selection{background:rgba(194,90,46,.18)}
.wrap{width:min(1180px,calc(100% - 34px));margin:0 auto}
.topbar{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(120%) blur(18px);
  background:color-mix(in srgb,var(--paper) 82%, transparent);
  border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:22px;padding:15px 0}
.brand{display:flex;align-items:baseline;gap:10px;text-decoration:none;white-space:nowrap}
.brand strong{font-family:var(--serif);font-size:21px;letter-spacing:-.02em}
.brand span{font-size:13px;color:var(--rust);font-weight:700}
.navlinks{display:flex;align-items:center;gap:15px;font-size:12.5px;color:var(--muted);flex-wrap:wrap}
@media (max-width:1180px){.navlinks{gap:11px;font-size:12px}}
.navlinks a{text-decoration:none;position:relative;transition:color .2s ease}
.navlinks a:after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--rust);transition:width .25s ease}
.navlinks a:hover:after,.navlinks a.active:after{width:100%}
.navlinks a.active{color:var(--rust);font-weight:700}
.actions{display:flex;gap:9px;align-items:center}
.btn{
  border:1px solid var(--line);
  background:var(--paper-2);
  color:var(--ink);
  padding:11px 16px;
  border-radius:10px;
  font-weight:700;
  font-size:14px;
  box-shadow:var(--soft-shadow);
}
.btn.primary{background:var(--rust-2);border-color:var(--rust-2);color:white}
.btn.dark{background:var(--navy);border-color:var(--navy);color:white}
.btn.ghost{background:transparent;box-shadow:none}
.btn.small{padding:8px 11px;font-size:12px;border-radius:9px}
.btn:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid color-mix(in srgb,var(--rust) 40%, transparent);outline-offset:2px}
.theme-toggle{width:38px;height:38px;border-radius:999px;border:1px solid var(--line);background:var(--paper-2);box-shadow:var(--soft-shadow);display:grid;place-items:center;position:relative;transition:background .25s ease,color .25s ease,border-color .25s ease}
.progressRail{height:3px;background:var(--line-soft)}
.progressBar{height:100%;width:0%;background:linear-gradient(90deg,var(--rust),var(--rust-2));transition:width .35s ease}
.hero{padding:68px 0 34px}
.heroGrid{display:grid;grid-template-columns:1.02fr .98fr;gap:46px;align-items:center}
.kicker{font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--rust);margin:0 0 16px;display:flex;align-items:center;gap:0}
.actBadge{display:inline-flex;align-items:center;gap:7px;margin-right:11px;flex-shrink:0;cursor:help;text-transform:none;letter-spacing:0}
.actDieSvg{width:22px;height:22px;display:block;filter:drop-shadow(0 1px 2px rgba(28,28,28,.12))}
.actDieSvg .dieBody{fill:var(--card);stroke:var(--ink);stroke-width:1.4;opacity:.9}
.actDieSvg .pip{fill:var(--rust)}
[data-theme="dark"] .actDieSvg .dieBody{fill:var(--paper-2);stroke:var(--muted);opacity:.7}
[data-theme="dark"] .actDieSvg .pip{fill:var(--rust-2)}
.actStep{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--rust);line-height:1;display:inline-flex;align-items:center}
.actStep::before{content:"";display:inline-block;width:1px;height:13px;background:var(--line);margin-right:7px}
[data-theme="dark"] .actStep{color:var(--rust-2)}
[data-theme="dark"] .actStep::before{background:var(--muted);opacity:.4}
@media print{.actBadge{display:none}}
/* Badge "dé" numéroté générique (paradoxes, cartographie, questionnaire…) */
.numDie{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 5px;border-radius:6px;background:var(--card);border:1.4px solid var(--ink);box-shadow:0 1px 2px rgba(28,28,28,.12);font-family:var(--serif);font-size:13px;font-weight:700;color:var(--rust);line-height:1;flex-shrink:0;vertical-align:-3px;letter-spacing:normal;text-transform:none}
[data-theme="dark"] .numDie{background:var(--paper-2);border-color:var(--muted);color:var(--rust-2);box-shadow:0 1px 2px rgba(0,0,0,.3)}
.numDie.lg{min-width:30px;height:30px;font-size:15px;border-radius:7px}
@media print{.numDie{border-color:#999;color:#7c3a18;box-shadow:none;background:#fff}}
h1,h2,h3{margin:0;letter-spacing:-.03em;line-height:1.04}
h1{font-family:var(--serif);font-size:clamp(52px,8vw,106px);font-weight:500;max-width:650px}
h2{font-family:var(--serif);font-size:clamp(36px,5vw,68px);font-weight:500}
h3{font-family:var(--serif);font-size:30px;font-weight:500}
.lead{font-size:18px;line-height:1.72;color:var(--navy);max-width:620px;margin:22px 0 26px}
[data-theme="dark"] .lead{color:#d6dde8}
.heroButtons{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.trust{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:12px;margin-top:26px}
.trust span{display:flex;gap:7px;align-items:center}.trust i{font-style:normal;color:var(--rust)}
.illustrationPanel{position:relative;min-height:430px;border:1px solid var(--line-soft);background:linear-gradient(180deg,color-mix(in srgb,var(--paper-2) 94%, white),color-mix(in srgb,var(--card) 92%, white));border-radius:28px;box-shadow:var(--shadow);overflow:hidden;padding:22px}
.captionBox{position:absolute;left:28px;bottom:24px;width:min(355px,calc(100% - 56px));padding:18px 20px;border:1px solid var(--line-soft);border-radius:18px;background:color-mix(in srgb,var(--paper-2) 84%, transparent);backdrop-filter:blur(10px)}
.captionBox p{margin:0;color:var(--muted);line-height:1.55;font-size:14px}.captionBox strong{display:block;color:var(--ink);font-size:15px;margin-bottom:5px}
.soft-bg{position:absolute;inset:-20%;background:radial-gradient(circle at 55% 36%, rgba(194,90,46,.10), transparent 21%),radial-gradient(circle at 62% 55%, rgba(49,69,90,.07), transparent 18%);pointer-events:none}
.butterflySvg{position:absolute;right:32px;top:18px;width:min(520px,76%);height:auto;filter:drop-shadow(0 16px 20px rgba(28,28,28,.08))}
.rule{height:1px;background:var(--line);margin:34px 0}
.section{padding:44px 0}.section.tight{padding:24px 0}
.sectionHead{display:flex;align-items:end;justify-content:space-between;gap:22px;margin-bottom:20px}
.sectionHead p{max-width:620px;line-height:1.7;color:var(--muted);margin:8px 0 0}
.paperCard{border:1px solid var(--line-soft);background:var(--card);border-radius:var(--radius);box-shadow:var(--soft-shadow);padding:24px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.conceptCard{min-height:170px;position:relative;overflow:hidden;transition:transform .22s ease, box-shadow .22s ease}
.conceptCard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.conceptCard .num{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:900;color:var(--rust);letter-spacing:.12em;text-transform:uppercase}
.conceptCard h3{font-size:28px;margin:10px 0}.conceptCard p{color:var(--muted);line-height:1.6;margin:0}
.conceptCard svg{position:absolute;right:12px;bottom:8px;width:96px;height:96px;opacity:.28}
.oracleLayout{display:grid;grid-template-columns:310px 1fr 330px;gap:18px;align-items:stretch}
.formGroup{display:grid;gap:8px;margin-bottom:14px}.label{font-size:12px;font-weight:800;color:var(--navy)}
input[type="text"],input[type="date"],textarea{width:100%;border:1px solid var(--line);background:var(--paper-2);border-radius:11px;padding:12px 13px;color:var(--ink)}
.helper{font-size:12px;color:var(--muted);line-height:1.55}.oracleText{font-family:var(--serif);font-size:25px;line-height:1.55;margin:0;color:var(--ink)}
.readingIntro{font-size:13px;color:var(--muted);margin-bottom:12px}.readingIntro strong{color:var(--rust)}
.sliderWrap{margin-top:16px}.rangeLine{display:flex;justify-content:space-between;color:var(--muted);font-size:11px;margin-top:6px}
input[type="range"]{width:100%;accent-color:var(--rust-2)}
.bigScore{font-family:var(--serif);font-size:62px;color:var(--rust-2);line-height:1;margin:14px 0 0}
.revealBox{border-left:3px solid var(--rust);padding:14px 0 14px 18px;margin-top:16px;color:var(--muted);line-height:1.62}
.revealBox strong{color:var(--ink)}
.labCard{display:flex;flex-direction:column;gap:12px;min-height:292px}.labArt{height:116px;border-radius:16px;background:linear-gradient(145deg,color-mix(in srgb,var(--paper-2) 80%, white),color-mix(in srgb,var(--sand) 45%, transparent));display:grid;place-items:center;overflow:hidden;border:1px solid var(--line-soft)}
.labCard h3{font-size:25px}.labCard p{color:var(--muted);line-height:1.55;margin:0;flex:1}.meta{display:flex;gap:10px;flex-wrap:wrap;font-size:11px;color:var(--muted)}.meta span{border:1px solid var(--line-soft);border-radius:999px;padding:5px 8px;background:var(--paper-2)}
.labStage{margin-top:22px;border:1px solid var(--line-soft);border-radius:24px;background:var(--paper-2);box-shadow:var(--shadow);padding:24px;display:none}.labStage.active{display:block;animation:rise .35s ease both}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.stageHead{display:flex;align-items:start;justify-content:space-between;gap:20px;border-bottom:1px solid var(--line-soft);padding-bottom:15px;margin-bottom:18px}.stageHead p{margin:5px 0 0;color:var(--muted);line-height:1.55}
.diceRow{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0}.die{width:74px;height:74px;border:1px solid var(--line);border-radius:16px;background:var(--card);box-shadow:var(--soft-shadow);font-size:34px;display:grid;place-items:center;font-weight:900;color:var(--navy)}
.resultPanel{border:1px solid var(--line-soft);border-radius:16px;background:var(--card);padding:18px;margin-top:14px}.resultPanel h4{margin:0 0 8px;font-size:16px;color:var(--rust)}.resultPanel p{margin:0;color:var(--muted);line-height:1.62}
.numGrid{display:grid;grid-template-columns:repeat(10,1fr);gap:8px;margin-top:14px}.numGrid button{border:1px solid var(--line);background:var(--card);border-radius:10px;min-height:43px;font-weight:800}.numGrid button:hover,.numGrid button.selected{border-color:var(--rust);background:rgba(194,90,46,.08);color:var(--rust)}
.butterflyBtn{border:0;background:transparent;padding:0;display:block;margin:10px auto}.cascade{display:grid;gap:8px;margin-top:12px}.cascade div{border:1px solid var(--line-soft);background:var(--card);border-radius:12px;padding:11px 13px;animation:rise .28s ease both;color:var(--navy)}
.cardChoiceGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}.revealCard{min-height:176px;border:1px solid var(--line);background:linear-gradient(160deg,var(--navy),#1f2d3a);color:white;border-radius:16px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--soft-shadow);text-align:left}.revealCard .sigil{font-size:34px;color:#f4cdb6}.revealCard .tiny{font-size:11px;opacity:.75;letter-spacing:.12em;text-transform:uppercase}.revealCard:hover{transform:translateY(-3px)}
.synthesisGrid{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:18px}.metric{font-family:var(--serif);font-size:74px;color:var(--rust-2);line-height:1}.trend{height:80px;width:100%;margin-top:10px}.barRows{display:grid;gap:13px}.barRow{display:grid;grid-template-columns:130px 1fr 38px;gap:10px;align-items:center;font-size:13px}.barTrack{height:8px;background:var(--line-soft);border-radius:999px;overflow:hidden}.barFill{height:100%;width:0%;background:linear-gradient(90deg,var(--rust),var(--rust-2));border-radius:999px;transition:width .6s ease}.tips{display:grid;gap:10px}.tip{display:flex;gap:10px;align-items:flex-start;color:var(--muted);line-height:1.5}.tip b{color:var(--rust)}
.paradoxGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.paradox{position:relative;cursor:pointer;transition:transform .22s ease,box-shadow .22s ease;display:flex;flex-direction:column}.paradox:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.paradox h3{font-size:24px;margin:6px 0 6px}.paradox p{color:var(--muted);line-height:1.55;margin:0 0 8px}.paradox .paradoxDice{display:inline-flex;align-items:center;gap:5px;align-self:flex-start;margin-bottom:8px}.actDieSvg.paradoxDie{width:27px;height:27px}.paradox .pAnswer{display:none;margin-top:10px;border-left:3px solid var(--rust-2);padding:10px 0 4px 14px;color:var(--ink);line-height:1.6;font-size:14px}.paradox.open .pAnswer{display:block;animation:rise .28s ease both}.paradox .pToggle{margin-top:auto;align-self:flex-start;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--rust);background:none;border:0;padding:6px 0;display:flex;gap:6px;align-items:center}.paradox .pToggle:after{content:"+";font-size:18px;line-height:1;transition:transform .25s ease}.paradox.open .pToggle:after{transform:rotate(45deg)}
.paradoxFooter{margin-top:18px;text-align:center;color:var(--muted);font-size:13px}.paradoxFooter b{color:var(--rust)}
.bf-wrap{margin-top:10px}.bf-controls{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:12px}.bf-slider-label{display:flex;flex-direction:column;gap:4px;flex:1 1 280px;font-size:13px;color:var(--muted)}.bf-slider-label input[type="range"]{width:100%}.bf-slider-hint{font-size:11px;color:var(--muted);opacity:.78}#bf-delta-value{color:var(--rust-2);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700}.bf-stats{display:flex;gap:12px;margin:10px 0;flex-wrap:wrap}.bf-stat{background:var(--card);border:1px solid var(--line-soft);padding:8px 14px;border-radius:10px;min-width:120px}.bf-stat-label{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);margin-bottom:2px;font-weight:700}.bf-stat span:last-child{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:15px;color:var(--ink);font-weight:700}#bf-canvas{display:block;width:100%;max-width:760px;height:auto;aspect-ratio:3/2;background:#07090d;border-radius:12px;border:1px solid var(--line-soft)}[data-theme="dark"] #bf-canvas{border-color:var(--line)}.bf-legend{display:flex;gap:22px;margin-top:10px;font-size:12.5px;color:var(--muted);flex-wrap:wrap}.bf-dot{display:inline-block;width:11px;height:11px;border-radius:50%;vertical-align:middle;margin-right:6px}.bf-dot-a{background:#4aa3ff;box-shadow:0 0 8px #4aa3ff}.bf-dot-b{background:#ff9b3d;box-shadow:0 0 8px #ff9b3d}.bf-toast{margin-top:14px;padding:14px 18px;border-radius:12px;background:linear-gradient(135deg,color-mix(in srgb,var(--rust) 12%, var(--card)),var(--card));border-left:3px solid var(--rust-2);color:var(--ink);font-size:14px;line-height:1.55;opacity:0;transform:translateY(-6px);transition:opacity .4s,transform .4s;pointer-events:none}.bf-toast.visible{opacity:1;transform:translateY(0)}
.radarBlock{margin-top:16px;position:relative}.radarSvg{width:100%;height:auto;max-width:280px;display:block;margin:0 auto;overflow:visible}.radarSvg .axis{stroke:var(--line);stroke-width:1}.radarSvg .ring{fill:none;stroke:var(--line-soft);stroke-width:1}.radarSvg .label{fill:var(--muted);font-size:9px;font-weight:700;text-anchor:middle;letter-spacing:.04em}.radarSvg .shape{fill:var(--rust-2);fill-opacity:.18;stroke:var(--rust-2);stroke-width:2;transition:fill-opacity .55s ease}.radarSvg .point{fill:var(--rust);transition:transform .35s cubic-bezier(.5,1.6,.4,1)}.radarSvg .point.pulse{animation:radarPulse .9s ease-out}
@keyframes radarPulse{0%{r:5;fill:var(--rust-2);filter:drop-shadow(0 0 6px var(--rust-2))}60%{r:3.5;filter:none}100%{r:3;fill:var(--rust);filter:none}}
.heroAccent{font-style:italic;color:var(--rust)}
.testimonyGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:18px}.testimony{position:relative;display:flex;flex-direction:column;gap:12px;border-left:3px solid var(--rust-2);padding:18px 18px 18px 22px;background:linear-gradient(160deg,color-mix(in srgb,var(--paper-2) 96%, transparent),var(--card));border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--soft-shadow);transition:transform .25s ease,box-shadow .25s ease}.testimony:hover{transform:translateX(2px);box-shadow:var(--shadow)}.testimony .quoteMark{font-family:var(--serif);font-size:46px;color:var(--rust-2);opacity:.5;line-height:.6;margin-bottom:-8px}.testimony blockquote{margin:0;font-family:var(--serif);font-size:18px;line-height:1.55;color:var(--ink)}.testimony .who{display:flex;align-items:flex-start;gap:10px;margin-top:auto;font-size:13px;color:var(--muted);border-top:1px dashed var(--line-soft);padding-top:10px}.testimony .who > span{flex:1;line-height:1.45}.testimony .who strong{color:var(--rust);font-weight:800}.testimony .who em.muted{display:block;font-size:11.5px;color:var(--muted);margin-top:3px;font-style:italic;line-height:1.4}.testimony .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,var(--rust),var(--navy));display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:15px;font-weight:700;flex-shrink:0;margin-top:1px}
.testimonySubhead{font-family:var(--serif);font-size:22px;color:var(--navy);margin:8px 0 14px;font-weight:400;letter-spacing:-.01em;border-left:3px solid var(--rust-2);padding-left:14px;line-height:1.35}
[data-theme="dark"] .testimonySubhead{color:var(--ink)}
/* ===== Section "Trois histoires qui semblent écrites" ===== */
.storiesGrid{display:grid;gap:20px;margin-top:18px}
.storyCard{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--card);box-shadow:var(--soft-shadow);overflow:hidden;transition:box-shadow .25s ease}
.storyCard:hover{box-shadow:var(--shadow)}
.storyCard .storyImg.themed-art{border:0;box-shadow:none;border-radius:var(--radius) var(--radius) 0 0;margin:0;background:var(--paper-2);overflow:hidden;width:auto;max-width:none}
.storyCard .storyImg.themed-art img{width:auto;max-width:100%;height:auto;max-height:520px;margin:0 auto;border-radius:var(--radius) var(--radius) 0 0}

.storyCard .storyHead{padding:22px 24px}
.storyCard .storyTag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;color:var(--rust);background:rgba(194,90,46,.12);padding:4px 10px;border-radius:999px;margin-bottom:10px}
.storyCard h3{font-family:var(--serif);font-size:25px;margin:0 0 10px;color:var(--ink);line-height:1.2}
.storyCard .storyBrut{color:var(--ink);line-height:1.65;font-size:15.5px;margin:0 0 6px}
.storyCard .storyClaim{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--rust);border-left:3px solid var(--rust-2);padding-left:16px;margin:16px 0 18px;line-height:1.5}
.storyToggle{border:1px solid var(--rust-2);background:transparent;color:var(--rust);padding:9px 16px;border-radius:10px;font-weight:700;font-size:13.5px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}
.storyToggle:hover{background:color-mix(in srgb,var(--rust-2) 10%, transparent)}
.storyToggle::after{content:"↓";font-size:14px;transition:transform .25s ease}
.storyCard.open .storyToggle::after{transform:rotate(180deg)}
.storyCard.open .storyToggle{background:var(--rust-2);color:#fff;border-color:var(--rust-2)}
.storyDecorticage{display:none;padding:0 24px 24px;border-top:1px solid var(--line-soft);margin-top:4px}
.storyCard.open .storyDecorticage{display:block;animation:rise .4s ease both}
.storyDecorticage h4{font-size:12.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);margin:22px 0 8px}
[data-theme="dark"] .storyDecorticage h4{color:var(--blue)}
.storyDecorticage ul{margin:0 0 4px;padding-left:20px;line-height:1.7;color:var(--muted);font-size:14.5px}
.storyDecorticage ul li{margin-bottom:7px}
.storyDecorticage ul li strong{color:var(--ink)}
.storyProba{margin:16px 0;padding:14px 18px;border-radius:14px;background:color-mix(in srgb,var(--navy) 7%, var(--paper-2));border:1px solid var(--line-soft)}
.storyProba .probaBig{font-family:var(--serif);font-size:28px;color:var(--rust);font-weight:700;display:block;margin-bottom:4px}
.storyProba p{margin:0;color:var(--muted);font-size:13.5px;line-height:1.6}
.storyProba p strong{color:var(--ink)}
.storyTest{margin-top:16px;padding:14px 18px;border-left:3px solid var(--navy);background:color-mix(in srgb,var(--paper-2) 88%, transparent);border-radius:0 12px 12px 0}
.storyTest p{margin:0;color:var(--muted);font-size:14px;line-height:1.6}
.storyTest strong{color:var(--ink)}
.storiesFooter{margin-top:22px;padding:18px 22px;border-radius:var(--radius);background:linear-gradient(160deg,color-mix(in srgb,var(--rust) 6%, var(--paper-2)),var(--card));border:1px solid var(--line-soft);color:var(--muted);line-height:1.65;font-size:14.5px}
.storiesFooter strong{color:var(--ink)}
.compatBlock{margin-top:24px;padding:24px;border-radius:var(--radius);background:linear-gradient(160deg,color-mix(in srgb,var(--navy) 8%, var(--paper-2)),var(--card));border:1px solid var(--line-soft);box-shadow:var(--soft-shadow)}.compatBlock h3{margin:0 0 8px;font-family:var(--serif);font-size:26px;color:var(--navy)}.compatBlock p{color:var(--muted);line-height:1.65;margin:0 0 12px}.compatBlock p strong{color:var(--ink)}.compatBlock .pull{font-family:var(--serif);font-size:22px;line-height:1.45;color:var(--rust);border-left:3px solid var(--rust-2);padding-left:18px;margin:18px 0;font-style:italic}
.agencyMeter{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;margin-top:18px}.agencyArc{width:120px;height:120px;flex-shrink:0;position:relative}.agencyArc svg{width:100%;height:100%;transform:rotate(-90deg)}.agencyArc .agencyTrack{fill:none;stroke:var(--line-soft);stroke-width:10}.agencyArc .agencyFill{fill:none;stroke:url(#agencyGrad);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.5,.05,.2,1)}.agencyArc .agencyText{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-size:32px;color:var(--rust);font-weight:700}.agencyArc .agencyText small{font-size:13px;color:var(--muted);font-family:var(--sans);font-weight:600;display:block;text-align:center;margin-top:2px}.agencyText{flex-direction:column}.agencyDesc{color:var(--muted);line-height:1.6}.agencyDesc strong{color:var(--ink)}.agencyTag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;color:var(--rust);background:rgba(194,90,46,.12);padding:5px 10px;border-radius:999px;margin-bottom:8px}
.theme-toggle#soundBtn[aria-pressed="true"]{background:var(--rust);color:#fff;border-color:var(--rust)}
.theme-toggle#soundBtn[aria-pressed="true"]::after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 6px #fff;top:7px;right:7px;animation:sndPing 1.6s ease-in-out infinite}
@keyframes sndPing{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.bf-toast strong{color:var(--rust)}
.bf-toast.visible{animation:toastIn .55s cubic-bezier(.2,.8,.2,1.05) both}
@keyframes toastIn{0%{opacity:0;transform:translateY(-12px) scale(.97)}60%{opacity:1;transform:translateY(2px) scale(1.01)}100%{opacity:1;transform:translateY(0) scale(1)}}
.paradox.open .pAnswer{animation:rise .35s cubic-bezier(.2,.85,.3,1) both}
.heroAccent{display:inline-block;background:linear-gradient(120deg,var(--rust),var(--rust-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.challengeOptions{display:grid;gap:10px;margin-top:12px}.challengeOptions label{display:flex;gap:10px;align-items:flex-start;border:1px solid var(--line-soft);padding:13px;border-radius:12px;background:var(--card);line-height:1.45}.challengeOptions input{margin-top:2px}
.drawer{display:grid;grid-template-columns:270px 1fr;gap:18px}.toc{position:sticky;top:82px;align-self:start;border:1px solid var(--line-soft);border-radius:18px;background:var(--card);padding:14px}.toc a{display:block;padding:10px 12px;border-radius:10px;text-decoration:none;font-size:13px;color:var(--muted)}.toc a:hover{background:rgba(194,90,46,.08);color:var(--rust)}
.footer{padding:50px 0 70px;color:var(--muted);border-top:1px solid var(--line-soft);margin-top:40px}.footer p{line-height:1.7}.quote{border-left:3px solid var(--rust);padding-left:20px;font-family:var(--serif);font-style:italic;font-size:24px;color:var(--navy);line-height:1.45}.quote small{display:block;font-family:var(--sans);font-style:normal;color:var(--muted);font-size:13px;margin-top:10px}
.hidden{display:none!important}.center{text-align:center}.mt{margin-top:18px}.muted{color:var(--muted)}.rust{color:var(--rust)}
.printOnly{display:none}
@media (max-width: 960px){
  .navlinks{display:none}.heroGrid,.oracleLayout,.grid2,.grid3,.grid4,.synthesisGrid,.drawer{grid-template-columns:1fr}.illustrationPanel{min-height:360px}.butterflySvg{right:0;width:100%;opacity:.9}.captionBox{position:relative;left:auto;bottom:auto;margin-top:250px;width:100%}.numGrid{grid-template-columns:repeat(5,1fr)}.cardChoiceGrid{grid-template-columns:1fr 1fr}.sectionHead{align-items:start;flex-direction:column}.toc{position:static}.hero{padding-top:40px}
}
@media (max-width: 620px){
  .wrap{width:min(100% - 24px,1180px)}.brand span{display:none}h1{font-size:48px}h2{font-size:38px}.lead{font-size:16px}.heroButtons .btn{width:100%}.actions .btn.small{display:none}.paperCard{padding:18px}.stageHead{flex-direction:column}.die{width:60px;height:60px;font-size:28px}.cardChoiceGrid{grid-template-columns:1fr}.barRow{grid-template-columns:1fr}.metric{font-size:60px}.oracleText{font-size:22px}
}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
@media print{
  @page{size:A4;margin:18mm 16mm 20mm}
  body{background:white;color:#111;font-size:11pt}
  .topbar,.heroButtons,.actions,.btn,.toc,.labStage,.challengeOptions input,#bf-canvas,.bf-controls,.bf-stats,.bf-legend,.bf-toast,.theme-toggle,.printHide{display:none!important}
  .printOnly{display:block!important}
  .wrap{width:100%;max-width:none;margin:0}
  .section{break-inside:avoid;page-break-inside:avoid;padding:14px 0;border-bottom:1px solid #ccc}
  .section:last-of-type{border-bottom:0}
  .sectionHead{margin-bottom:14px}
  .sectionHead h2{font-size:18pt;margin:0 0 4px;color:#111}
  .kicker{color:#7c3a18;font-size:9pt;letter-spacing:.10em;text-transform:uppercase;font-weight:700}
  .paperCard{box-shadow:none;border:1px solid #ddd;background:#fff;padding:12px;break-inside:avoid;page-break-inside:avoid}
  .hero{padding:0 0 12px 0;border:none}
  .heroGrid,.grid2,.grid3,.grid4,.synthesisGrid,.oracleLayout,.testimonyGrid,.paradoxGrid{display:block}
  .heroGrid > div + div, .synthesisGrid > article + article{margin-top:12px}
  .illustrationPanel,.butterflySvg{display:none}
  h1{font-size:24pt;line-height:1.1;margin:0 0 6px;color:#111}
  .heroAccent{color:#c25a2e!important;-webkit-text-fill-color:#c25a2e}
  .lead{font-size:11pt;color:#333}
  .printHeader{display:flex!important;justify-content:space-between;align-items:flex-end;border-bottom:2px solid #c25a2e;padding-bottom:8px;margin-bottom:18px}
  .printHeader h2{font-family:Georgia,serif;font-size:20pt;margin:0;color:#c25a2e;font-style:italic}
  .printHeader .meta{font-size:9pt;color:#555;text-align:right;line-height:1.4}
  .printHeader .meta strong{color:#111}
  .printSummary{display:grid!important;grid-template-columns:1.1fr 1fr;gap:18px;margin:0 0 18px;padding:14px;border:1px solid #ddd;background:#faf7f2;break-inside:avoid;page-break-inside:avoid}
  .printSummary .printScore{font-family:Georgia,serif;font-size:42pt;line-height:1;color:#c25a2e;margin:0}
  .printSummary .printScore small{display:block;font-size:9pt;color:#555;font-family:sans-serif;margin-top:4px;letter-spacing:.06em;text-transform:uppercase}
  .printSummary .printAgency{display:flex;align-items:center;gap:14px}
  .printSummary .printAgency strong{font-family:Georgia,serif;font-size:30pt;color:#1e88e5}
  .printSummary .printRadarBox{text-align:center}
  .printSummary .radarSvg{max-width:200px;margin:0 auto}
  .printSummary .radarSvg .label{fill:#555;font-size:8px}
  .printSummary .radarSvg .shape{fill:#c25a2e!important;fill-opacity:.22;stroke:#c25a2e!important}
  .testimony{break-inside:avoid;page-break-inside:avoid;border-left:2px solid #c25a2e;background:#fff;box-shadow:none}
  .testimony blockquote{font-size:10.5pt}
  .compatBlock{background:#fff;border:1px solid #ddd;break-inside:avoid;page-break-inside:avoid}
  .compatBlock .pull{font-size:12pt;color:#c25a2e;border-left-color:#c25a2e}
  .agencyMeter{break-inside:avoid;page-break-inside:avoid}
  .agencyArc svg circle{stroke-width:8}
  .paradoxGrid{display:grid!important;grid-template-columns:1fr 1fr;gap:10px}
  .paradox{background:#fff;border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}
  .paradox .pToggle{display:none}
  .paradox .pAnswer{display:block!important;border-left:2px solid #c25a2e;color:#333;font-size:10pt}
  .quote{border-left:3px solid #c25a2e;color:#1e88e5}
  .footer{border-top:2px solid #c25a2e;color:#555;font-size:9pt;margin-top:18px;padding:10px 0}
  .printOnly p, .printFooter{font-size:9pt;color:#666}
}

.heroPicture,.sectionVisual{
  margin:24px auto 0;
  width:fit-content;
  max-width:100%;
}
.illustrationPanel{display:flex;flex-direction:column;justify-content:center}
.illustrationPanel .heroPicture{margin:0 auto}
.themed-art{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:var(--shadow);
  width:fit-content;
  max-width:100%;
  margin:0 auto;
}
/* Illustrations de section : taille naturelle, centrées, hauteur plafonnée (comme les autres sites de la constellation) */
.themed-art img{
  display:block;
  width:auto;
  max-width:100%;
  max-height:500px;
  height:auto;
}
@media(max-width:720px){.themed-art img{max-height:360px}}
.themed-art .art-dark{display:none}
body[data-theme="dark"] .themed-art .art-light{display:none}
body[data-theme="dark"] .themed-art .art-dark{display:block}
.sectionVisual figcaption,.heroVisual figcaption,.heroPicture figcaption{
  padding:12px 14px 13px;
  font-size:12px;
  color:var(--muted);
  border-top:1px solid var(--line-soft);
  background:color-mix(in srgb,var(--paper-2) 90%, transparent);
  line-height:1.5;
}
.quickPath{
  margin-top:18px;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid var(--line);
  background:color-mix(in srgb,var(--paper-2) 92%, transparent);
  box-shadow:var(--soft-shadow);
}
.quickPath strong{display:block;margin-bottom:6px;font-size:13px;letter-spacing:.02em;text-transform:uppercase;color:var(--rust)}
.quickPath p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.sourceList{
  margin-top:18px;
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:14px;
  background:color-mix(in srgb,var(--paper-2) 92%, transparent);
}
.sourceList h3{margin:0 0 8px}
.sourceList ul{margin:10px 0 0 18px;padding:0;color:var(--muted);line-height:1.7}
@media (max-width: 860px){
  .heroPicture .themed-art{min-height:0}
}
/* ===== Test psychométrique 6 dimensions ===== */
.testIntro{margin-bottom:18px;padding:18px;border-left:3px solid var(--rust-2);background:color-mix(in srgb,var(--rust) 6%, var(--paper-2));border-radius:0 var(--radius) var(--radius) 0}
.testIntro h3{margin:0 0 6px;font-family:var(--serif);font-size:22px;color:var(--navy)}
.testIntro p{margin:0;color:var(--muted);line-height:1.6;font-size:14px}
.testIntro p+p{margin-top:8px}
.testStartBtn{margin-top:14px}
.testList{display:none;margin-top:14px;gap:12px;grid-template-columns:1fr}
.testList.active{display:grid}
.testItem{padding:16px 18px;border:1px solid var(--line-soft);background:var(--card);border-radius:var(--radius);box-shadow:var(--soft-shadow);transition:border-color .25s ease,box-shadow .25s ease}
.testItem.answered{border-color:color-mix(in srgb,var(--rust-2) 35%, var(--line-soft));box-shadow:0 4px 14px rgba(194,90,46,.10)}
.testItem .num{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--rust);margin-right:6px;letter-spacing:.04em}
.testItem .stem{font-size:15.5px;line-height:1.5;color:var(--ink);margin:0 0 12px;display:flex;gap:10px;align-items:flex-start}.testItem .stem .numDie{margin-top:1px}.testItem .stem .numDice{margin-top:0;flex-shrink:0}.testItem .stem > span:last-child{flex:1}
.numDice{display:inline-flex;align-items:center;gap:4px;vertical-align:middle}.actDieSvg.numDieSvg{width:22px;height:22px}
.testLikert{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:6px}
.testLikert input{position:absolute;opacity:0;pointer-events:none}
.testLikert label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;padding:9px 4px;border:1px solid var(--line);border-radius:10px;background:var(--paper-2);text-align:center;font-size:11px;color:var(--muted);transition:all .18s ease;line-height:1.25;min-height:54px;justify-content:center}
.testLikert label:hover{border-color:var(--rust);color:var(--rust);background:color-mix(in srgb,var(--rust) 5%, var(--paper-2))}
.testLikert label .dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--line);background:transparent;transition:all .18s ease}
.testLikert label:hover .dot{border-color:var(--rust)}
.testLikert input:checked + label{border-color:var(--rust-2);background:color-mix(in srgb,var(--rust-2) 12%, var(--paper-2));color:var(--rust);font-weight:700}
.testLikert input:checked + label .dot{background:var(--rust-2);border-color:var(--rust-2);box-shadow:0 0 0 2px color-mix(in srgb,var(--rust-2) 30%, transparent)}
.testProgress{display:flex;justify-content:space-between;align-items:center;margin:14px 0 6px;padding:12px 16px;border:1px solid var(--line-soft);border-radius:14px;background:var(--paper-2);font-size:13px;color:var(--muted)}
.testProgress strong{color:var(--rust);font-family:var(--serif);font-size:18px;margin-right:4px}
.testProgressBar{flex:1;height:6px;border-radius:999px;background:var(--line-soft);margin:0 14px;overflow:hidden}
.testProgressBar > div{height:100%;background:linear-gradient(90deg,var(--rust),var(--rust-2));width:0%;transition:width .35s cubic-bezier(.5,.05,.2,1);border-radius:999px}
.testFooter{margin-top:14px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.testResult{display:none;margin-top:18px;padding:18px;border:1px solid var(--line-soft);border-radius:var(--radius);background:linear-gradient(160deg,color-mix(in srgb,var(--rust-2) 8%, var(--paper-2)),var(--card));box-shadow:var(--soft-shadow)}
.testResult.active{display:block;animation:rise .4s ease both}
.testResult h3{margin:0 0 6px;font-family:var(--serif);font-size:22px;color:var(--rust)}
.testResult p{margin:0 0 10px;color:var(--muted);line-height:1.6;font-size:14px}
.testResult .reliability{display:inline-block;padding:4px 10px;background:color-mix(in srgb,var(--navy) 8%, var(--paper-2));border-radius:999px;color:var(--navy);font-size:12px;font-weight:700;margin-top:4px}
@media (max-width:620px){.testLikert{grid-template-columns:repeat(5,1fr);gap:4px}.testLikert label{font-size:9.5px;padding:6px 2px;min-height:50px}}
/* Bibliothèque : figure hors du drawer, glossaire en pleine 2e colonne (1fr) */
#bibliotheque .drawer{align-items:start;gap:22px}
#bibliotheque .drawer > .paperCard{min-width:0}
/* Session : bandeau de reprise */
.sessionBanner{display:none;position:sticky;top:0;z-index:60;background:linear-gradient(135deg,color-mix(in srgb,var(--rust-2) 12%, var(--paper-2)),var(--card));border-bottom:1px solid var(--line-soft);padding:10px 16px;font-size:13.5px;color:var(--ink);box-shadow:0 4px 14px rgba(28,28,28,.06);backdrop-filter:blur(10px)}
.sessionBanner.visible{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center;animation:rise .35s ease both}
.sessionBanner b{color:var(--rust)}
.sessionBanner .sessionBtn{background:var(--rust-2);color:#fff;border:0;padding:6px 14px;border-radius:8px;font-weight:700;font-size:12px;cursor:pointer;transition:background .2s ease}
.sessionBanner .sessionBtn:hover{background:var(--rust)}
.sessionBanner .sessionBtnGhost{background:transparent;color:var(--muted);border:1px solid var(--line);padding:6px 14px;border-radius:8px;font-weight:600;font-size:12px;cursor:pointer}
.sessionBanner .sessionBtnGhost:hover{border-color:var(--rust);color:var(--rust)}
.sessionClearBtn{margin-top:8px;font-size:12px;background:transparent;border:1px dashed var(--line);color:var(--muted);padding:6px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease}
.sessionClearBtn:hover{border-color:var(--rust);color:var(--rust);border-style:solid}
/* Modal "fonctionnalité à venir" habillé d'un dé */
.modalOverlay{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:24px;background:color-mix(in srgb,var(--ink) 55%, transparent);backdrop-filter:blur(4px)}
.modalOverlay.open{display:flex;animation:modalFade .25s ease both}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modalCard{position:relative;max-width:430px;width:100%;background:var(--paper-2);border:1px solid var(--line);border-radius:24px;box-shadow:0 30px 80px rgba(0,0,0,.35);padding:36px 32px 30px;text-align:center;animation:modalPop .35s cubic-bezier(.2,.9,.3,1.05) both}
@keyframes modalPop{0%{opacity:0;transform:translateY(14px) scale(.96)}100%{opacity:1;transform:translateY(0) scale(1)}}
.modalClose{position:absolute;top:12px;right:14px;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:var(--card);font-size:18px;line-height:1;color:var(--muted);cursor:pointer;transition:all .2s ease}
.modalClose:hover{color:var(--rust);border-color:var(--rust)}
.modalDie{width:84px;height:84px;display:block;margin:0 auto 18px;filter:drop-shadow(0 6px 14px rgba(28,28,28,.18));animation:dieRoll 1.1s cubic-bezier(.3,.8,.3,1) both}
.modalDie .dieBody{fill:var(--card);stroke:var(--ink);stroke-width:2;opacity:.92}
.modalDie .pip{fill:var(--rust)}
[data-theme="dark"] .modalDie .dieBody{fill:var(--paper-2);stroke:var(--muted);opacity:.8}
[data-theme="dark"] .modalDie .pip{fill:var(--rust-2)}
@keyframes dieRoll{0%{transform:rotate(-230deg) scale(.35);opacity:0}55%{transform:rotate(20deg) scale(1.1);opacity:1}75%{transform:rotate(-7deg) scale(.97)}100%{transform:rotate(0) scale(1);opacity:1}}
.modalCard h3{font-family:var(--serif);font-size:24px;margin:0 0 10px;color:var(--ink)}
.modalCard p{color:var(--muted);line-height:1.6;font-size:14.5px;margin:0 0 20px}
.modalCard p a{color:var(--rust);text-decoration:underline}
.modalCard .modalSoonTag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--rust);background:rgba(194,90,46,.12);padding:4px 12px;border-radius:999px;margin-bottom:14px}
@media print{.modalOverlay{display:none!important}}
@media (prefers-reduced-motion: reduce){.modalDie,.modalCard,.modalOverlay.open{animation:none!important}}
/* ===== Mentions légales ===== */
#mentions-legales .legalIntro{color:var(--muted);line-height:1.7;font-size:15px;margin:0 0 20px}
#mentions-legales .legalCard{border:1px solid var(--line-soft);background:var(--card);border-radius:var(--radius);box-shadow:var(--soft-shadow);padding:18px 22px;margin-bottom:14px}
#mentions-legales .legalCard h3{font-family:var(--serif);font-size:20px;color:var(--navy);margin:6px 0 8px}
#mentions-legales .legalCard p{color:var(--muted);line-height:1.65;font-size:14.5px;margin:0 0 8px}
#mentions-legales .legalCard p:last-child{margin-bottom:0}
#mentions-legales .legalCard p strong{color:var(--ink)}
#mentions-legales .legalCard ul{color:var(--muted);line-height:1.8;font-size:14px;padding-left:20px;margin:6px 0 8px}
#mentions-legales .legalCard a{color:var(--rust);text-decoration:underline}
#mentions-legales .legalCard code{font-size:.85em;background:rgba(194,90,46,.08);padding:1px 5px;border-radius:4px;color:var(--rust)}
#mentions-legales .legalTag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;color:var(--rust);background:rgba(194,90,46,.12);padding:4px 10px;border-radius:999px;margin-bottom:4px}
#mentions-legales .legalWarn{border-left:3px solid #d97706;background:rgba(217,119,6,.08);padding:14px 18px;border-radius:0 12px 12px 0;margin-bottom:14px}
#mentions-legales .legalWarn strong{color:var(--ink)}
#mentions-legales .legalWarn p{color:var(--muted);line-height:1.65;font-size:14.5px;margin:0}
#mentions-legales .legalCard small{font-size:12.5px;line-height:1.55;display:inline-block}
[data-theme="dark"] #mentions-legales .legalCard h3{color:var(--blue)}
[data-theme="dark"] #mentions-legales .legalTag{color:var(--rust-2)}
#mentions-legales .legalCopy{text-align:center;font-size:13px;color:var(--muted);margin-top:18px}
/* ===== Constellation parallèle (calé sur le style des autres sites de la constellation) ===== */
#constellation.section{padding:5rem 0 4rem;border-top:1px solid var(--line-soft);background:radial-gradient(ellipse at 20% 0%,rgba(194,90,46,.04),transparent 55%),radial-gradient(ellipse at 80% 100%,rgba(49,69,90,.04),transparent 55%)}
#constellation .wrap{width:min(1100px,calc(100% - 34px))}
#constellation .constHead{text-align:center;margin-bottom:26px}
#constellation .constKicker{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--rust);margin-bottom:.7rem}
#constellation .constTitle{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:500;color:var(--ink);line-height:1.25;margin:0 0 1rem}
#constellation .constTitle em{color:var(--rust);font-style:italic}
#constellation .constIntro{max-width:600px;margin:0 auto;color:var(--muted);line-height:1.7;font-size:.95rem;font-style:italic}
.constGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin-top:2rem}
@media(max-width:600px){.constGrid{gap:.9rem}}
.constCard{display:flex;flex-direction:column;padding:0;background:var(--card);border:1px solid var(--line-soft);border-radius:14px;text-decoration:none;color:inherit;overflow:hidden;box-shadow:var(--soft-shadow);transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s,border-color .35s}
.constCard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--rust) 32%, var(--line-soft))}
.constThumb{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;background:rgba(0,0,0,.04);border-bottom:1px solid var(--line-soft)}
.constThumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .6s ease,filter .4s ease;filter:saturate(.95) brightness(.97)}
.constCard:hover .constThumb img{transform:scale(1.05);filter:saturate(1) brightness(1)}
.constIcon{font-size:1.8rem;color:var(--rust);margin:1rem 1.5rem .5rem;line-height:1;opacity:.9}
.constName{font-family:var(--serif);font-size:1.2rem;font-weight:600;color:var(--ink);margin:0 1.5rem .6rem;line-height:1.3}
.constDesc{color:var(--muted);font-size:.85rem;line-height:1.6;margin:0 1.5rem 1.1rem;flex-grow:1}
.constUrl{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;letter-spacing:.04em;color:var(--blue);margin:0 1.5rem 1.1rem;padding-top:.8rem;border-top:1px dashed var(--line-soft);transition:color .25s}
.constCard:hover .constUrl{color:var(--rust)}
.constFootnote{margin:30px auto 0;max-width:520px;text-align:center;font-family:var(--serif);font-style:italic;font-size:16px;color:var(--muted);line-height:1.6;padding-top:22px;border-top:1px dashed var(--line-soft)}
.shareInvite{max-width:760px;margin:34px auto 0;padding:28px 24px;text-align:center;border-radius:var(--radius);background:linear-gradient(160deg,color-mix(in srgb,var(--rust) 7%, var(--paper-2)),var(--card));border:1px solid color-mix(in srgb,var(--rust) 22%, var(--line-soft));box-shadow:var(--soft-shadow)}
.shareEyebrow{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--rust);margin-bottom:8px}
.shareTitle{font-family:var(--serif);font-size:clamp(20px,2.6vw,26px);color:var(--ink);line-height:1.35;margin:0 0 12px}
.shareTitle em{color:var(--rust);font-style:italic}
.shareBody{color:var(--muted);font-size:14.5px;line-height:1.65;max-width:580px;margin:0 auto 20px}
.shareActions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:10px}
.shareBtn{padding:9px 16px;border-radius:9px;font-size:13px;font-weight:700;text-decoration:none;cursor:pointer;transition:all .2s;border:1px solid var(--line);background:var(--paper-2);color:var(--ink)}
.shareBtn:hover{border-color:var(--rust);color:var(--rust)}
.shareBtn.primary{background:var(--rust-2);border-color:var(--rust-2);color:#fff}
.shareBtn.primary:hover{background:var(--rust);color:#fff}
.shareFeedback{min-height:1.3rem;font-size:13px;color:#15803d;font-weight:600;opacity:0;transition:opacity .3s;margin-top:8px}
.shareFeedback.visible{opacity:1}
@media(max-width:620px){.constIcon,.constName,.constDesc,.constUrl{margin-left:14px;margin-right:14px}.shareInvite{padding:22px 16px}}
/* ===== Footer ===== */
.siteFooter{border-top:1px solid var(--line-soft);padding:28px clamp(16px,4vw,32px);text-align:center;color:var(--muted);font-size:14px;margin-top:20px}
.siteFooter p{margin:0 0 8px;line-height:1.6}
.siteFooter a{color:var(--rust);text-decoration:none}
.siteFooter a:hover{text-decoration:underline}
.siteFooter .sep{margin:0 7px;opacity:.5}
@media print{#constellation,.shareInvite{display:none}.siteFooter{border-top:1px solid #ccc}}
