/* ============================================================
   w — x · une page personnelle.
   Pas un portfolio. Pas un template. Une succession de pavés,
   chacun avec sa propre humeur.
   ============================================================ */

/* ---- 1. Polices ------------------------------------------ */

@font-face {
  font-family: "Fraunces";
  src: url("assets/fonts/fraunces.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Fraunces";
  src: url("assets/fonts/fraunces-italic.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("assets/fonts/jetbrains-mono.woff2") format("woff2-variations");
  font-weight: 100 800;
  font-style: normal;
  font-display: swap;
}

/* ---- 2. Variables ---------------------------------------- */

/* Défaut = CLAIR. Papier crème, encre noire, monochrome (zéro orange). */
:root {
  --ink:        #15130f;
  --paper:      #f4f1ea;
  --muted:      rgba(21, 19, 15, 0.60);
  --hairline:   rgba(21, 19, 15, 0.30);
  --accent:     #15130f;
  --accent-soft:#15130f;
  --shade:      rgba(21, 19, 15, 0.045);
  --bed-alpha:  0;

  --serif: "Fraunces", "Hoefler Text", "Times New Roman", serif;
  --mono:  "JetBrains Mono", "SF Mono", ui-monospace, monospace;

  --gutter: clamp(1.25rem, 4vw, 3rem);
  --col:    72rem;

  --t-base: 380ms cubic-bezier(.2, .7, .15, 1);
}

/* Bascule SOMBRE (toujours dispo) — sombre raffiné, monochrome. */
[data-theme="dark"] {
  --ink:        #f4f1ea;
  --paper:      #100f0d;
  --muted:      rgba(244, 241, 234, 0.62);
  --hairline:   rgba(244, 241, 234, 0.26);
  --accent:     #f4f1ea;
  --accent-soft:#f4f1ea;
  --shade:      rgba(244, 241, 234, 0.05);
  --bed-alpha:  0;
}

/* ---- 3. Reset -------------------------------------------- */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img, svg, canvas { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; margin: 0; }
:focus-visible { outline: 1.5px solid var(--accent); outline-offset: 3px; }
::selection { background: var(--accent); color: var(--paper); }

/* ---- 4. Page --------------------------------------------- */

html {
  background: var(--paper);
  color: var(--ink);
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

body {
  font-family: var(--serif);
  font-feature-settings: "kern", "liga", "calt", "ss01", "onum";
  font-variant-numeric: oldstyle-nums;
  font-size: 1.0625rem;
  line-height: 1.55;
  background: var(--paper);
  color: var(--ink);
  min-height: 100dvh;
  position: relative;
  transition: background var(--t-base), color var(--t-base);
}

.skip {
  position: absolute; top: -100px; left: 0;
  background: var(--ink); color: var(--paper);
  padding: 0.5rem 1rem;
  font-family: var(--mono); font-size: 0.78rem;
  z-index: 100;
}
.skip:focus { top: 0; }

.muted { color: var(--muted); }
.mono  { font-family: var(--mono); font-size: 0.86em; letter-spacing: 0.01em; }

/* ---- 5. Lit génératif (canvas plein cadre) ---------------- */

.bed {
  position: fixed; inset: 0;
  width: 100vw; height: 100vh; height: 100dvh;
  pointer-events: auto;
  z-index: 0;
  opacity: var(--bed-alpha);
  mix-blend-mode: screen;
  transition: opacity var(--t-base);
}
[data-theme="light"] .bed { mix-blend-mode: multiply; }

.grain {
  position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  opacity: 0.035;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
}
.vignette {
  position: fixed; inset: 0;
  pointer-events: none; z-index: 2;
  background: radial-gradient(120% 80% at 50% 40%, transparent 60%, rgba(0,0,0,0.26) 100%);
}
[data-theme="light"] .vignette {
  background: radial-gradient(120% 80% at 50% 40%, transparent 60%, rgba(140,120,90,0.18) 100%);
}

/* ---- 6. Topbar ------------------------------------------- */

.topbar {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem var(--gutter);
  pointer-events: none;
  background: linear-gradient(to bottom, var(--paper) 30%, transparent 100%);
}
.topbar > * { pointer-events: auto; }
/* Logo : sceau d'atelier — chop carré façon timbre humide */
.logomark {
  display: inline-flex;
  align-items: center;
  width: 2.4rem;
  height: 2.4rem;
  color: var(--accent);
  transition: color var(--t-base), transform var(--t-base);
}
.logomark:hover { color: var(--ink); transform: rotate(-1.5deg); }
[data-theme="light"] .logomark { color: var(--accent); }
.sceau {
  width: 100%;
  height: 100%;
}
.sceau-glyph {
  font-family: "Fraunces", serif;
  font-size: 78px;
  font-style: italic;
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
}
.theme-toggle {
  display: inline-flex; gap: 4px;
  padding: 6px 8px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  transition: border-color var(--t-base);
}
.theme-toggle:hover { border-color: var(--ink); }
.theme-toggle .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--muted);
  transition: background var(--t-base);
}
[data-theme="dark"]  .theme-toggle .dot:first-child { background: var(--ink); }
[data-theme="light"] .theme-toggle .dot:last-child  { background: var(--ink); }

/* ---- 7. Main ---------------------------------------------- */

main {
  position: relative; z-index: 5;
  max-width: var(--col);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.bloc {
  padding: clamp(4rem, 12vh, 10rem) 0;
  position: relative;
}
.bloc:first-child { padding-top: clamp(7rem, 18dvh, 12rem); }


/* ============================================================
   PAVÉ 1 — Entrée
   Phrase d'ouverture, asymétrique. Décalée vers la droite,
   pleine de blanc. Pas de "Bienvenue dans mon portfolio".
   ============================================================ */

.bloc-entree {
  text-align: right;
  padding-bottom: clamp(2rem, 6vh, 4rem);
}
.entree {
  font-family: var(--serif);
  font-size: clamp(1.6rem, 3.4vw, 2.6rem);
  line-height: 1.32;
  font-weight: 400;
  margin: 0 0 0 auto;
  max-width: 30em;
  letter-spacing: -0.005em;
  font-variation-settings: "opsz" 96;
  text-wrap: balance;
}
.entree em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 1;
  color: var(--accent-soft);
}


/* ============================================================
   PAVÉ 2 — Maintenant
   Un cartouche, comme une horloge de gare. Étroit, mono.
   ============================================================ */

.bloc-maintenant {
  display: flex; flex-direction: column; align-items: center;
  padding: clamp(3rem, 8vh, 6rem) 0;
}
.maintenant {
  display: flex; align-items: center;
  width: 100%;
  max-width: 36rem;
  gap: 1rem;
  margin-bottom: 1.4rem;
  font-family: var(--mono);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
}
.mant-rule { flex: 1; height: 1px; background: var(--hairline); }
.mant-lab  { white-space: nowrap; }

.maintenant-grid {
  display: flex;
  justify-content: center;
  gap: clamp(2rem, 6vw, 4.5rem);
  margin: 0;
  font-family: var(--mono);
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  flex-wrap: wrap;
}
.maintenant-grid > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}
.maintenant-grid dt {
  color: var(--muted);
  text-transform: lowercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
}
.maintenant-grid dd {
  margin: 0; color: var(--ink);
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum" 1;
}


/* ============================================================
   Casquettes (qui je suis, en quatre lignes nues)
   Liste italique mid-size, gauche-alignée, line-height généreux.
   ============================================================ */

.bloc-casquettes {
  padding: clamp(4rem, 10vh, 8rem) 0;
}
.casquettes {
  font-family: var(--serif);
  font-size: clamp(1.3rem, 2.4vw, 1.85rem);
  line-height: 1.5;
  font-weight: 400;
  color: var(--ink);
  max-width: 32em;
}
.casquettes li {
  padding: 0.35rem 0;
  text-wrap: balance;
}
.casquettes li em {
  font-style: italic;
  color: var(--accent-soft);
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
}


/* ============================================================
   PAVÉ 4 — Atelier (trois lignes vagues, en escalier)
   Ce qu'il fait, vu de loin. Indents progressifs : la lecture
   tombe vers la droite comme une pensée qui s'éloigne.
   ============================================================ */

.bloc-atelier {
  padding: clamp(5rem, 12vh, 9rem) 0;
}
.atelier {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  line-height: 1.45;
  font-weight: 400;
  letter-spacing: -0.005em;
  font-variation-settings: "opsz" 96, "SOFT" 50;
  margin: 0;
  max-width: 32em;
  text-wrap: balance;
  color: var(--ink);
}
.atelier span { display: block; }
.atelier em {
  font-style: italic;
  color: var(--accent-soft);
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
}
.atelier .atl-l1 { margin-left: 0; }
.atelier .atl-l2 { margin-left: clamp(1.5rem, 8vw, 6rem); }
.atelier .atl-l3 { margin-left: clamp(3rem, 16vw, 12rem); }


/* ============================================================
   Terrain (pratiques + langues, en mots-clés)
   Une ligne mono qui s'enroule, séparateurs en accent,
   bordée d'un filet en haut et en bas. Comme un sommaire.
   ============================================================ */

.bloc-terrain {
  padding: clamp(3rem, 8vh, 6rem) 0;
}
.terrain-titre {
  font-family: var(--mono);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  text-align: center;
  margin: 0 0 1.4rem;
  color: var(--ink);
}
.terrain {
  font-family: var(--mono);
  font-size: clamp(0.85rem, 1.2vw, 1rem);
  line-height: 2.2;
  letter-spacing: 0.04em;
  text-align: center;
  margin: 0;
  padding: 1rem 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  text-wrap: balance;
}
.terrain > span {
  display: inline-block;
  white-space: nowrap;
  margin: 0 0.1em;
  color: var(--ink);
}
.terrain .sep {
  color: var(--accent-soft);
  margin: 0 0.5em;
  font-weight: 600;
}
.terrain .terrain-langue {
  font-style: italic;
  font-family: var(--serif);
  font-size: 1.1em;
  font-variation-settings: "opsz" 96, "SOFT" 50;
}
.terrain .muted {
  font-size: 0.85em;
}


/* ============================================================
   PAVÉ 5 — Planche (spécimen large, comme un dessin scientifique)
   ============================================================ */

.bloc-planche {
  padding: clamp(2rem, 6vh, 5rem) 0;
}
.planche {
  margin: 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding: 1.5rem 0;
}
.planche-canvas {
  width: 100%;
  aspect-ratio: 14 / 5;
  height: auto;
  background: transparent;
  filter: contrast(1.1);
}
.planche figcaption {
  margin-top: 1.2rem;
  font-family: var(--serif);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--ink);
  max-width: 42em;
  font-style: italic;
  font-variation-settings: "opsz" 36;
  font-weight: 360;
}
.planche figcaption .muted {
  font-family: var(--mono);
  font-style: normal;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-right: 0.85em;
}
.planche figcaption em { font-style: italic; color: var(--accent-soft); }


/* ============================================================
   Annuaire (colophon étoffé)
   Mince et dense. Comme la marque d'imprimeur en fin de livre.
   ============================================================ */

.bloc-annuaire {
  padding: clamp(4rem, 10vh, 8rem) 0;
}
.annu-titre {
  font-family: var(--mono);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  margin: 0 0 1.8rem;
  color: var(--ink);
}
.annu {
  font-family: var(--mono);
  font-size: 0.86rem;
  line-height: 1.6;
  letter-spacing: 0.01em;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: clamp(2rem, 5vw, 4rem);
  row-gap: 0;
  margin: 0;
  border-top: 1px dashed var(--hairline);
}
.annu > div {
  display: grid;
  grid-template-columns: minmax(0, 9.5em) 1fr;
  gap: 1rem;
  padding: 0.65rem 0;
  border-bottom: 1px dashed var(--hairline);
  align-items: baseline;
}
.annu dt {
  color: var(--muted);
  text-transform: lowercase;
}
.annu dd {
  margin: 0;
  color: var(--ink);
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em;
}
.annu .swatch {
  display: inline-block;
  width: 0.85em; height: 0.85em;
  border: 1px solid var(--hairline);
  vertical-align: middle;
  flex-shrink: 0;
}
.swatch-ink   { background: #15130f; }
.swatch-paper { background: #f4f1ea; }
.swatch-acc   { background: #15130f; }
.annu .mono { font-size: 0.96em; }


/* ============================================================
   PAVÉ 7 — Lettre (signoff, à droite, comme un mot manuscrit)
   ============================================================ */

.bloc-lettre {
  padding: clamp(4rem, 12vh, 9rem) 0 clamp(2rem, 6vh, 5rem);
  display: flex;
  justify-content: flex-end;
}
.lettre {
  max-width: 32rem;
  width: 100%;
}
.lettre-date {
  font-family: var(--mono);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  margin: 0 0 1.5rem;
}
.lettre-corps {
  font-family: var(--serif);
  font-size: 1.15rem;
  line-height: 1.65;
  font-weight: 420;
  margin: 0 0 2.5rem;
  text-wrap: pretty;
}
.lettre-mail {
  position: relative;
  font-style: normal;
  color: var(--accent-soft);
  transition: color var(--t-base);
  white-space: nowrap;
}
.lettre-mail::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: currentColor;
  opacity: 0.4;
  transition: opacity var(--t-base);
}
.lettre-mail:hover::after { opacity: 1; }
.lettre-sign {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 320;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  color: var(--accent-soft);
  margin: 0;
  text-align: right;
}


/* ============================================================
   Pied — pas de footer, juste une dernière ligne en gris.
   ============================================================ */

.dernier-mot {
  margin: clamp(4rem, 10vh, 7rem) 0 clamp(3rem, 6vh, 5rem);
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  line-height: 1.6;
  text-align: center;
  max-width: 42em;
  margin-left: auto;
  margin-right: auto;
  font-variation-settings: "opsz" 36;
  font-weight: 400;
}


/* ---- Apparitions ----------------------------------------- */

[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 1100ms cubic-bezier(.2, .7, .15, 1),
    transform 1100ms cubic-bezier(.2, .7, .15, 1);
}
[data-reveal].in { opacity: 1; transform: none; }


/* ---- Responsive ------------------------------------------ */

@media (max-width: 880px) {
  .bloc-entree { text-align: left; }
  .entree { margin-left: 0; }
  .maintenant-grid { gap: 1.5rem 2.5rem; }
  .bloc-lettre { justify-content: flex-start; }
  .lettre-sign { text-align: left; }
  .planche-canvas { aspect-ratio: 6 / 5; }
  .atelier .atl-l1,
  .atelier .atl-l2,
  .atelier .atl-l3 { margin-left: 0; }
  .atelier .atl-l2 { margin-left: clamp(0.5rem, 4vw, 2rem); }
  .atelier .atl-l3 { margin-left: clamp(1rem, 8vw, 4rem); }
  .annu { grid-template-columns: 1fr; column-gap: 0; }
  .annu > div { grid-template-columns: minmax(0, 9em) 1fr; }
}

@media (max-width: 480px) {
  .entree { font-size: clamp(1.4rem, 6vw, 2rem); }
}

/* SLOT-A-TIRAGE — agent A insère ici */
.tirage {
  color: var(--accent-soft);
  font-feature-settings: "tnum" 1;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

/* SLOT-B-SCEAU — agent B insère ici */
.logomark { transition: opacity 180ms ease; }
.logomark:hover { opacity: 0.78; }
.logomark:active { opacity: 0.6; }
.sceau.stamping {
  animation: stamp-press 280ms cubic-bezier(.3, 1.4, .5, 1);
}
@keyframes stamp-press {
  0%   { transform: scale(1)    rotate(0); }
  30%  { transform: scale(0.94) rotate(-1.5deg); }
  60%  { transform: scale(1.02) rotate(0.5deg); }
  100% { transform: scale(1)    rotate(0); }
}

/* SLOT-D-PRINT — agent D insère ici */
@page { size: A4; margin: 2.2cm 1.8cm 2.5cm 1.8cm; }

@media print {
  :root, [data-theme] {
    --paper: #fff !important;
    --ink: #111 !important;
    --accent: #000 !important;
    --accent-soft: #444 !important;
    --muted: #666 !important;
    --hairline: #ccc !important;
  }

  * {
    animation: none !important;
    transition: none !important;
    box-shadow: none !important;
  }

  body {
    background: #fff !important;
    color: #111 !important;
    font-size: 11pt;
    line-height: 1.5;
  }

  .bed,
  .grain,
  .vignette,
  .theme-toggle,
  .skip,
  .planche-canvas,
  .topbar .theme-toggle {
    display: none !important;
  }

  .topbar {
    background: transparent !important;
    border: none !important;
  }

  .logomark {
    background: transparent !important;
  }

  main {
    display: block !important;
    background: transparent !important;
  }

  .bloc {
    break-inside: avoid;
    page-break-inside: avoid;
    background: transparent !important;
    border-color: #ccc !important;
  }

  .entree,
  .entree p {
    font-family: "Fraunces", Georgia, serif;
    font-style: italic;
    font-size: 22pt;
    line-height: 1.25;
    color: #111 !important;
  }

  .maintenant {
    font-size: 11pt;
    color: #111 !important;
  }

  .casquettes {
    font-style: italic;
    font-size: 12pt;
    color: #111 !important;
  }

  .casquettes li {
    color: #111 !important;
  }

  .atelier {
    font-family: "Fraunces", Georgia, serif;
    font-size: 13pt;
    line-height: 1.5;
    color: #111 !important;
  }

  .terrain,
  .terrain li {
    font-family: "JetBrains Mono", monospace;
    font-size: 10pt;
    color: #111 !important;
  }

  .annu {
    color: #111 !important;
  }

  .annu > div {
    border-bottom: 1px solid #ccc !important;
    color: #111 !important;
  }

  .annu dt {
    color: #444 !important;
  }

  .annu dd {
    color: #111 !important;
  }

  a,
  a:link,
  a:visited {
    color: #111 !important;
    text-decoration: underline;
  }

  .lettre-mail::after {
    content: none !important;
  }

  .dernier-mot {
    font-style: italic;
    text-align: center;
    font-size: 10pt;
    color: #666 !important;
    margin-top: 1.5rem;
  }

  .print-mark {
    display: block !important;
    text-align: center;
    margin-top: 2rem;
    font-size: 9pt;
    font-style: italic;
    color: #666;
  }
}
.print-mark { display: none; }

/* SLOT-E-ECLAIR — agent E (lettre-éclair) insère ici */
.eclair {
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--serif);
  font-style: italic;
  font-weight: 200;
  font-size: 48vmin;
  line-height: 1;
  color: var(--accent-soft);
  opacity: 0;
  pointer-events: none;
  z-index: 90;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  mix-blend-mode: difference;
  animation: eclair-flash 700ms cubic-bezier(.2, .8, .3, 1) forwards;
  text-shadow: 0 0 30px rgba(244, 168, 122, 0.4);
  user-select: none;
}
@keyframes eclair-flash {
  0%   { opacity: 0; transform: translate(-50%, -50%) scale(0.7); filter: blur(20px); }
  18%  { opacity: 0.88; transform: translate(-50%, -50%) scale(1.0); filter: blur(0); }
  55%  { opacity: 0.55; transform: translate(-50%, -50%) scale(1.06); filter: blur(0.5px); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.18); filter: blur(8px); }
}

/* SLOT-F-FOLIO — agent F (folios marge) insère ici */
.folio {
  position: fixed;
  left: clamp(0.8rem, 1.6vw, 2rem);
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--muted);
  z-index: 15;
  pointer-events: none;
  opacity: 0.7;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transition: color var(--t-base);
}
.folio span[data-folio] {
  display: inline-block;
  transition: opacity 200ms ease;
}
@media (max-width: 720px) {
  .folio { display: none; }
}
@media print {
  .folio { display: none !important; }
}

/* SLOT-G-AXES — agent G (Fraunces axes vivants) insère ici */
.fraunces-name {
  font-style: italic;
  font-feature-settings: "ss01";
  cursor: pointer;
  color: var(--accent-soft);
  font-variation-settings: "opsz" 36, "SOFT" 50, "WONK" 0;
  transition: color 200ms ease;
  border-bottom: 1px dashed transparent;
  padding-bottom: 1px;
}
.fraunces-name:hover,
.fraunces-name:focus-visible,
.fraunces-name.alive {
  animation: fraunces-axes 5s ease-in-out infinite alternate;
  border-bottom-color: var(--hairline);
}
@keyframes fraunces-axes {
  0%   { font-variation-settings: "opsz" 9,   "SOFT" 0,   "WONK" 0; }
  25%  { font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1; }
  50%  { font-variation-settings: "opsz" 36,  "SOFT" 30,  "WONK" 0; }
  75%  { font-variation-settings: "opsz" 96,  "SOFT" 75,  "WONK" 1; }
  100% { font-variation-settings: "opsz" 14,  "SOFT" 50,  "WONK" 0; }
}

/* SLOT-H-CELLS-CYCLE — agent H (cellules + cycle Paris) insère ici */

/* SLOT-I-GEANT — agent I (spécimen géant flottant) insère ici */
.geant {
  position: fixed;
  right: clamp(-3vw, -1vw, 0);
  bottom: -6vh;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(28rem, 60vmin, 56rem);
  line-height: 0.78;
  color: var(--accent-soft);
  opacity: 0.085;
  z-index: 3;
  pointer-events: none;
  user-select: none;
  font-variation-settings: "opsz" 144, "SOFT" 80, "WONK" 1;
  animation: geant-axes 14s ease-in-out infinite alternate;
  transition: opacity 400ms ease, transform 400ms ease;
}
.geant.changing {
  opacity: 0.02;
  transform: scale(0.92) rotate(-3deg);
}
[data-theme="light"] .geant { opacity: 0.07; }
@keyframes geant-axes {
  0%   { font-variation-settings: "opsz"  36, "SOFT"   0, "WONK" 0; }
  33%  { font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1; }
  66%  { font-variation-settings: "opsz"  96, "SOFT"  40, "WONK" 0; }
  100% { font-variation-settings: "opsz"  72, "SOFT"  70, "WONK" 1; }
}
@media (max-width: 700px) {
  .geant {
    font-size: clamp(20rem, 80vmin, 36rem);
    right: -8vw;
    bottom: -8vh;
  }
}
@media print { .geant { display: none !important; } }

/* SLOT-J-TRAIL — agent J (curseur ink trail) insère ici */
.trail-dot {
  position: fixed;
  border-radius: 50%;
  background: var(--accent-soft);
  pointer-events: none;
  z-index: 18;
  transform: translate(-50%, -50%);
  opacity: 0.6;
  animation: trail-fade 1s ease-out forwards;
  mix-blend-mode: screen;
  filter: blur(0.5px);
}
[data-theme="light"] .trail-dot {
  mix-blend-mode: multiply;
  background: var(--accent);
  opacity: 0.5;
}
@keyframes trail-fade {
  0%   { opacity: 0.6; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0;   transform: translate(-50%, -50%) scale(0.4); }
}
@media print { .trail-dot { display: none !important; } }

/* SLOT-K-CERVEAU — agent K (second canvas génératif) insère ici */
.bloc-cerveau {
  padding: clamp(4rem, 12vh, 10rem) 0;
}
.cerveau {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
.cerveau-canvas {
  width: 100%;
  aspect-ratio: 21 / 9;
  background: var(--shade);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  display: block;
}
.cerveau figcaption {
  font-family: var(--serif);
  font-size: clamp(0.95rem, 1.5vw, 1.1rem);
  line-height: 1.55;
  max-width: 42em;
  display: grid;
  gap: 0.4rem;
}
.cerveau figcaption em {
  font-style: italic;
  font-variation-settings: "opsz" 36, "SOFT" 50;
  color: var(--accent-soft);
}
@media (max-width: 640px) {
  .cerveau-canvas { aspect-ratio: 4 / 3; }
}
.cells {
  color: var(--accent-soft);
  font-feature-settings: "tnum" 1;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

/* SLOT-L-LANG — sélecteur de langue (FR / EN / 中) */

.topbar-tools {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 1px;
  padding: 3px 6px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  transition: border-color var(--t-base);
}
.lang-switch:hover { border-color: var(--ink); }
.lang-btn {
  padding: 2px 7px;
  color: var(--muted);
  background: none;
  border: 0;
  cursor: pointer;
  font: inherit;
  letter-spacing: inherit;
  line-height: 1.1;
  border-radius: 999px;
  transition: color var(--t-base);
}
.lang-btn:hover { color: var(--ink); }
.lang-btn[aria-pressed="true"] {
  color: var(--accent-soft);
  font-feature-settings: "ss01";
}
.lang-btn-zh {
  font-family: var(--serif);
  font-size: 1.05em;
  font-weight: 400;
  letter-spacing: 0;
}
@media print { .lang-switch, .topbar-tools .theme-toggle { display: none !important; } }
@media (max-width: 480px) {
  .lang-switch { font-size: 0.62rem; padding: 2px 4px; }
  .lang-btn { padding: 2px 4px; }
}

/* ============================================================
   REFONTE ÉDITORIALE  (v3)
   Papier crème / encre noire, monochrome, fond uni, zéro
   mouvement. Fraunces assumée, hiérarchie tranchée.
   Bloc volontairement séparé : facile à relire / annuler.
   ============================================================ */

/* — Fond uni : on retire tout l'arrière-plan animé & décoratif — */
.bed,
.grain,
.vignette,
.geant,
.eclair,
.trail-dot { display: none !important; }

body { background: var(--paper); }

/* — Calme : plus d'animations infinies/parasites — */
.fraunces-name,
.fraunces-name:hover,
.fraunces-name:focus-visible,
.fraunces-name.alive,
.sceau,
.sceau.stamping { animation: none !important; }
.fraunces-name {
  color: var(--ink);
  border-bottom: 1px dotted var(--hairline);
}
[data-reveal] { transform: translateY(14px); }

/* — Échelle typographique forte, contraste maximal — */
body {
  font-size: clamp(1.0625rem, 1.02rem + 0.42vw, 1.22rem);
  line-height: 1.62;
}

.entree {
  font-size: clamp(2rem, 5.4vw, 3.7rem);
  line-height: 1.16;
  font-weight: 480;
  color: var(--ink);
  letter-spacing: -0.015em;
}
.entree em { color: var(--ink); font-weight: 480; }

.casquettes {
  font-size: clamp(1.45rem, 3vw, 2.25rem);
  line-height: 1.42;
  font-weight: 440;
}
.casquettes li em { color: var(--ink); }

.atelier {
  font-size: clamp(1.8rem, 4.2vw, 3.1rem);
  line-height: 1.3;
  font-weight: 480;
  color: var(--ink);
}
.atelier em { color: var(--ink); }

/* Eyebrows (libellés mono) : nets, encre pleine, structurés */
.maintenant,
.terrain-titre,
.annu-titre {
  color: var(--ink);
  font-weight: 600;
}
.terrain-titre,
.annu-titre { font-size: 0.8rem; letter-spacing: 0.26em; }
.maintenant { font-size: 0.8rem; letter-spacing: 0.2em; }
.maintenant-grid { font-size: 1.02rem; }
.maintenant-grid dd { font-weight: 520; }

.terrain { font-size: clamp(0.92rem, 1.2vw, 1.05rem); }
.terrain > span,
.terrain .sep { color: var(--ink); }
.terrain .sep { font-weight: 700; opacity: 0.45; }
.terrain .terrain-langue { font-style: italic; }

.planche figcaption,
.cerveau figcaption { color: var(--ink); }
.planche figcaption em,
.cerveau figcaption em { color: var(--ink); }

/* Colophon : dense mais lisible */
.annu { font-size: 0.9rem; line-height: 1.62; }
.annu dd { color: var(--ink); }

/* Lettre / signature : encre, pas de couleur */
.lettre-corps {
  font-size: clamp(1.15rem, 1.7vw, 1.42rem);
  font-weight: 440;
}
.lettre-mail {
  color: var(--ink);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.lettre-mail::after { content: none; }
.lettre-sign { color: var(--ink); }

.dernier-mot { font-size: 1rem; font-weight: 420; }

/* Logo-sceau : monochrome encre */
.logomark,
.logomark:hover,
[data-theme="dark"] .logomark { color: var(--ink); }

/* Sélection & focus : contraste franc */
::selection { background: var(--ink); color: var(--paper); }
:focus-visible { outline: 2px solid var(--ink); outline-offset: 3px; }

/* Filets de section plus francs */
.planche,
.terrain,
.annu,
.annu > div { border-color: var(--hairline); }

/* Réduction de mouvement : tout fige */
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { transform: none; }
}

/* — Éphémérides : petit registre sous le cartouche « à l'instant » — */
.ephem-grid {
  margin: 2.4rem auto 0;
  max-width: 52rem;
  width: 100%;
  font-family: var(--mono);
  font-size: 0.84rem;
  line-height: 1.5;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  column-gap: 2.5rem;
  border-top: 1px solid var(--hairline);
}
.ephem-grid > div {
  display: grid;
  grid-template-columns: minmax(0, 8.5em) 1fr;
  gap: 1rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--hairline);
  align-items: baseline;
}
.ephem-grid dt {
  color: var(--muted);
  text-transform: lowercase;
  letter-spacing: 0.06em;
}
.ephem-grid dd {
  margin: 0;
  color: var(--ink);
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum" 1;
}
@media (max-width: 480px) {
  .ephem-grid { font-size: 0.78rem; }
  .ephem-grid > div { grid-template-columns: minmax(0, 7em) 1fr; gap: 0.6rem; }
}
@media print { .ephem-grid { display: none !important; } }

/* ---- marchés & fuseaux ---- */
.marches-grid,
.fuseaux-grid {
  margin: 1.8rem auto 0;
  max-width: 52rem;
  width: 100%;
  display: grid;
  font-family: var(--mono);
  font-size: 0.82rem;
  line-height: 1.45;
  border-top: 1px solid var(--hairline);
}
.marches-grid { grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr)); column-gap: 2.5rem; }
.fuseaux-grid { grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr)); column-gap: 2rem; }
.marches-grid > div,
.fuseaux-grid > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.8rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--hairline);
}
.marches-grid dt,
.fuseaux-grid dt {
  color: var(--muted);
  letter-spacing: 0.04em;
}
.marches-grid dd,
.fuseaux-grid dd {
  margin: 0;
  color: var(--ink);
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum" 1;
  white-space: nowrap;
}
@media (max-width: 480px) {
  .marches-grid, .fuseaux-grid { font-size: 0.78rem; }
}
@media print { .marches-grid, .fuseaux-grid { display: none !important; } }

/* — Ligne contact (page-instrument) — */
.contact {
  margin: 2.6rem auto 0;
  font-family: var(--mono);
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  color: var(--muted);
  text-align: center;
}
.contact a {
  color: var(--ink);
  border-bottom: 1px solid var(--hairline);
  padding-bottom: 1px;
  margin-left: 0.4em;
  transition: border-color .25s ease;
}
.contact a:hover,
.contact a:focus-visible { border-bottom-color: var(--ink); outline: none; }

/* ============================================================
   PASSAGE — vers portfolio.w-x.fr
   Une porte discrète : filet + libellé mono (écho du cartouche
   « à l'instant »), puis un lien serif italique. Le soulignement
   se trace, la flèche glisse — transition unique (--t-base),
   pour que ça se confonde avec le reste de la page.
   Bloc volontairement séparé : facile à relire / annuler.
   ============================================================ */
.vers {
  margin: 3.6rem auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.15rem;
  text-align: center;
}
.vers-rule {
  width: 100%;
  max-width: 36rem;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 1rem;
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
}
.vers-rule::before,
.vers-rule::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--hairline);
}
.vers-rule > span { white-space: nowrap; }

.vers-lien {
  position: relative;
  display: inline-flex;
  align-items: baseline;
  gap: 0.5em;
  padding-bottom: 5px;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.35rem, 2.6vw, 1.95rem);
  font-weight: 440;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variation-settings: "opsz" 96, "SOFT" 50, "WONK" 1;
  transition: color var(--t-base);
}
.vers-lien::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: currentColor;
  opacity: 0.45;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--t-base), opacity var(--t-base);
}
.vers-lien:hover::after,
.vers-lien:focus-visible::after {
  transform: scaleX(1);
  opacity: 1;
}
.vers-lien:focus-visible { outline: none; }
.vers-fleche {
  font-family: var(--mono);
  font-style: normal;
  font-size: 0.66em;
  transform: translateX(0);
  transition: transform var(--t-base);
}
.vers-lien:hover .vers-fleche,
.vers-lien:focus-visible .vers-fleche { transform: translateX(0.4em); }

@media (prefers-reduced-motion: reduce) {
  .vers-lien::after { transition: opacity var(--t-base); }
  .vers-fleche { transition: none; }
}
@media print { .vers { display: none !important; } }


/* ============================================================
   Animations — légères, GPU (transform / opacity / color), zéro JS.
   Le garde global prefers-reduced-motion (haut du fichier) les
   neutralise toutes pour qui le demande. Rien n'anime layout/paint
   en continu : coût mémoire négligeable.
   ============================================================ */

/* — Les filets « à l'instant » / « marchés » se dessinent vers le label — */
.maintenant .mant-rule {
  transform: scaleX(0);
  transition: transform 900ms cubic-bezier(.2, .7, .15, 1) 180ms;
}
.maintenant .mant-rule:first-child { transform-origin: left center; }
.maintenant .mant-rule:last-child  { transform-origin: right center; }
.bloc.in .maintenant .mant-rule { transform: scaleX(1); }

/* — Point « live » qui respire à côté des labels temps-réel — */
.bloc-maintenant .mant-lab::after,
.bloc-marches .mant-lab::after {
  content: "";
  display: inline-block;
  width: 5px; height: 5px;
  margin-left: 0.7em;
  border-radius: 50%;
  background: var(--accent);
  vertical-align: middle;
  animation: live-pulse 2.6s ease-in-out infinite;
}
@keyframes live-pulse {
  0%, 100% { opacity: 0.2; transform: scale(0.7); }
  50%      { opacity: 1;   transform: scale(1); }
}

/* — Survol des grilles : le terme s'accentue, le filet s'allume — */
.ephem-grid > div,
.marches-grid > div,
.fuseaux-grid > div { transition: border-bottom-color var(--t-base); }
.ephem-grid dt,
.marches-grid dt,
.fuseaux-grid dt { transition: color var(--t-base), letter-spacing var(--t-base); }
.ephem-grid > div:hover,
.marches-grid > div:hover,
.fuseaux-grid > div:hover { border-bottom-color: var(--accent-soft); }
.ephem-grid > div:hover dt,
.marches-grid > div:hover dt,
.fuseaux-grid > div:hover dt {
  color: var(--accent);
  letter-spacing: 0.1em;
}

/* — Casquettes : légère poussée à droite au survol — */
.casquettes li { transition: transform var(--t-base), color var(--t-base); }
.casquettes li:hover { transform: translateX(6px); }
.casquettes li:hover em { color: var(--accent); }

/* — Terrain : chaque mot s'allume au survol — */
.terrain > span:not(.sep) { transition: color var(--t-base); }
.terrain > span:not(.sep):hover { color: var(--accent); }

/* — Adresse de contact : soulignement qui se dessine au survol — */
.lettre-mail {
  position: relative;
  text-decoration: none;
  transition: color var(--t-base);
}
.lettre-mail::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--t-base);
}
.lettre-mail:hover { color: var(--accent); }
.lettre-mail:hover::after,
.lettre-mail:focus-visible::after { transform: scaleX(1); }


/* ============================================================
   Indicateurs cliquables + mise en avant + fiche détail
   ============================================================ */

/* — Affordance de clic : curseur, focus, et chevron permanent — */
[data-topic] { cursor: pointer; }
[data-topic]:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 2px;
}
.ephem-grid > [data-topic],
.marches-grid > [data-topic],
.fuseaux-grid > [data-topic] { position: relative; padding-right: 1.15rem; }
.ephem-grid > [data-topic]::after,
.marches-grid > [data-topic]::after,
.fuseaux-grid > [data-topic]::after {
  content: "›";
  position: absolute; right: 0.15rem; top: 50%;
  transform: translateY(-50%);
  color: var(--accent); font-family: var(--mono); font-size: 1rem; line-height: 1;
  opacity: 0.32; transition: opacity var(--t-base), transform var(--t-base);
}
.ephem-grid > [data-topic]:hover::after,
.marches-grid > [data-topic]:hover::after,
.fuseaux-grid > [data-topic]:hover::after,
.ephem-grid > [data-topic]:focus-visible::after,
.marches-grid > [data-topic]:focus-visible::after,
.fuseaux-grid > [data-topic]:focus-visible::after { opacity: 1; transform: translateY(-50%) translateX(2px); }

/* — Mini-lune dessinée dans « à l'instant » — */
.mini-moon { display: inline-block; width: 1.05em; height: 1.05em; vertical-align: -0.16em; margin-right: 0.45em; }
.mini-moon svg { width: 100%; height: 100%; display: block; }
.mini-moon .moon-lit { filter: none; }

/* — Invite « cliquez pour le détail » — */
.tap-hint {
  margin: 1.4rem auto 0;
  text-align: center;
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.05em;
}

/* — Mise en avant : filet d'accent à gauche, valeur en accent — */
.ephem-grid > .featured,
.marches-grid > .featured {
  border-left: 2px solid var(--accent);
  padding-left: 0.7rem;
}
.ephem-grid > .featured dd,
.marches-grid > .featured dd { color: var(--accent); }
.maintenant-grid > .featured dt { color: var(--accent); }

/* — Fiche détail (#/sujet) — */
.detail { display: none; }
.detail.open {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 40rem;
  margin: 0 auto;
  padding: clamp(2rem, 6vh, 4rem) 0;
  animation: detail-in 380ms cubic-bezier(.2, .7, .15, 1);
}
body.detail-open main > *:not(#detail) { display: none !important; }
@keyframes detail-in {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: none; }
}
.detail-back {
  align-self: flex-start;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--mono);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  color: var(--muted);
  padding: 0.3rem 0;
  margin-bottom: 1.6rem;
  transition: color var(--t-base), transform var(--t-base);
}
.detail-back:hover,
.detail-back:focus-visible { color: var(--accent); transform: translateX(-3px); }
.detail-titre {
  align-self: flex-start;
  margin: 0 0 0.6rem;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 460;
  font-size: clamp(1.9rem, 5vw, 2.9rem);
  letter-spacing: -0.01em;
  color: var(--ink);
}
.detail-intro {
  align-self: flex-start;
  max-width: 34rem;
  margin: 0 0 2.2rem;
  font-size: 1rem;
  line-height: 1.55;
}
.detail-grid {
  width: 100%;
  margin: 0;
  font-family: var(--mono);
  font-size: 0.9rem;
  line-height: 1.5;
  border-top: 1px solid var(--hairline);
}
.detail-grid > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1.2rem;
  padding: 0.7rem 0;
  border-bottom: 1px solid var(--hairline);
}
.detail-grid dt { color: var(--muted); letter-spacing: 0.04em; }
.detail-grid dd {
  margin: 0;
  text-align: right;
  color: var(--ink);
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum" 1;
}

/* — Composition par blocs — */
.detail-body { width: 100%; display: flex; flex-direction: column; gap: 2.4rem; }
.d-hero { display: flex; flex-direction: column; align-items: center; gap: 0.7rem; text-align: center; }
.d-hero-big {
  font-family: var(--serif); font-style: italic; font-weight: 460;
  font-size: clamp(1.8rem, 6vw, 2.7rem); letter-spacing: -0.01em; color: var(--ink);
}
.d-hero-sub { font-family: var(--mono); font-size: 0.82rem; letter-spacing: 0.04em; }
.d-h3 {
  font-family: var(--mono); font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.18em; color: var(--muted); margin: 0 0 0.7rem;
}
.d-viz { display: flex; justify-content: center; margin: 0.2rem 0 0.4rem; }

/* — Lune dessinée (encre sur papier) — */
.moon { width: clamp(108px, 33vw, 148px); height: auto; animation: moon-float 7s ease-in-out infinite; }
.moon-disc { fill: #1b1915; }                 /* face nocturne — sombre, indépendant du thème */
.moon-lit { fill: #efe9d8; filter: drop-shadow(0 0 5px rgba(239, 233, 216, 0.45)); } /* face éclairée — clair */
.moon-rim { fill: none; stroke: #7a7468; stroke-width: 1.2; opacity: 0.8; }
@keyframes moon-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-5px); } }

/* — Arc solaire — */
.suncast { width: clamp(220px, 74vw, 300px); height: auto; }
.sun-arc { fill: none; stroke: var(--hairline); stroke-width: 1.5; stroke-dasharray: 3 6; }
.sun-horizon { stroke: var(--hairline); stroke-width: 1.5; }
.sun-core { fill: var(--accent); filter: drop-shadow(0 0 5px var(--accent)); animation: sun-pulse 3.4s ease-in-out infinite; }
.sun-night { fill: var(--muted); filter: none; opacity: 0.5; animation: none; }
@keyframes sun-pulse { 0%, 100% { opacity: 0.85; } 50% { opacity: 1; } }

/* — Ruban des saisons (précédent · actuel · suivant) — */
.rib { display: grid; grid-template-columns: 1fr 1.35fr 1fr; gap: 0.5rem; width: 100%; }
.rib-cell {
  display: flex; flex-direction: column; align-items: center; gap: 0.25rem;
  padding: 1rem 0.5rem; border: 1px solid var(--hairline); border-radius: 3px; text-align: center;
}
.rib-prev, .rib-next { opacity: 0.55; }
.rib-now { border-color: var(--accent); }
.rib-emo { font-size: 1.5rem; line-height: 1; }
.rib-name { font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--ink); }
.rib-date { font-family: var(--mono); font-size: 0.72rem; }
.rib-prog { width: 100%; height: 3px; margin-top: 0.5rem; background: var(--hairline); border-radius: 2px; overflow: hidden; }
.rib-fill { height: 100%; background: var(--accent); transform-origin: left center; animation: grow-x 800ms cubic-bezier(.2, .7, .15, 1); }
@keyframes grow-x { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* — Diagramme de sessions 24 h — */
.gantt { width: 100%; font-family: var(--mono); }
.g-grid { position: relative; display: flex; flex-direction: column; gap: 0.5rem; }
.g-track { position: relative; height: 18px; background: var(--hairline); border-radius: 3px; overflow: hidden; }
.g-bar { position: absolute; top: 0; bottom: 0; background: var(--accent-soft); opacity: 0.45; animation: grow-x 600ms ease; transform-origin: left center; }
.g-bar.g-on { background: var(--accent); opacity: 1; }
.g-label { position: absolute; left: 0.5rem; top: 50%; transform: translateY(-50%); font-size: 0.66rem; color: var(--ink); mix-blend-mode: difference; letter-spacing: 0.04em; }
.g-now { position: absolute; top: -3px; bottom: -3px; width: 2px; background: var(--ink); }
.g-now::after { content: ""; position: absolute; top: -3px; left: -3px; width: 8px; height: 8px; border-radius: 50%; background: var(--ink); }
.g-axis { display: flex; justify-content: space-between; margin-top: 0.5rem; font-size: 0.66rem; }

/* — Roue du zodiaque (fiche année) — */
.zwheel { width: clamp(150px, 44vw, 188px); height: auto; }
.zw-ring { fill: none; stroke: var(--hairline); stroke-width: 1; }
.zw-ring2 { opacity: 0.6; }
.zw-tick { stroke: var(--hairline); stroke-width: 1; }
.zw-tick.zw-on { stroke: var(--accent); stroke-width: 1.6; }
.zw-sym { fill: var(--muted); font-size: 11px; font-family: var(--mono); cursor: default; transition: fill var(--t-base); }
.zw-sym.zw-on { fill: var(--accent); font-size: 15px; }
.zw-sym:hover { fill: var(--ink); }
.zw-sym.zw-on:hover { fill: var(--accent); }
.zw-hand { stroke: var(--accent); stroke-width: 1.6; animation: zw-sweep 4s ease-in-out infinite; transform-origin: 80px 80px; }
.zw-hub { fill: var(--accent); }
@keyframes zw-sweep { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }

/* — Horloge analogique (fiche temps) — */
.ckface { width: clamp(150px, 44vw, 188px); height: auto; }
.ck-rim { fill: none; stroke: var(--hairline); stroke-width: 1.4; }
.ck-tick { stroke: var(--hairline); stroke-width: 1; }
.ck-tick.ck-maj { stroke: var(--ink); stroke-width: 1.8; }
.ck-h { stroke: var(--ink); stroke-width: 3; stroke-linecap: round; }
.ck-m { stroke: var(--ink); stroke-width: 2; stroke-linecap: round; }
.ck-s { stroke: var(--accent); stroke-width: 1; stroke-linecap: round; transform-origin: 80px 80px; animation: ck-spin 60s steps(60, end) infinite; }
.ck-hub { fill: var(--accent); }
@keyframes ck-spin { to { transform: rotate(360deg); } }

/* — Globe terrestre (fiche terre) : jour/nuit, Soleil, Lune, villes, bourses — */
.earth { width: clamp(192px, 62vw, 244px); height: auto; }
.e-orbit { fill: none; stroke: var(--hairline); stroke-width: 1; stroke-dasharray: 2 7; opacity: 0.6; transform-origin: 110px 110px; animation: e-rot 40s linear infinite; }
.e-d0 { stop-color: var(--accent-soft); stop-opacity: 0.30; }
.e-d1 { stop-color: var(--hairline); stop-opacity: 0.16; }
.e-d2 { stop-color: var(--ink); stop-opacity: 0.34; }
.e-grid { fill: none; stroke: var(--hairline); stroke-width: 0.8; opacity: 0.7; }
.e-rim { fill: none; stroke: var(--ink); stroke-width: 1.4; }
.e-sun { fill: var(--accent); filter: drop-shadow(0 0 6px var(--accent)); animation: sun-pulse 3.4s ease-in-out infinite; }
.e-moon { fill: var(--ink); opacity: 0.55; }
.e-city { fill: var(--ink); }
.e-city.e-open { fill: var(--accent); filter: drop-shadow(0 0 3px var(--accent)); }
@keyframes e-rot { to { transform: rotate(360deg); } }

@media print { .detail { display: none !important; } }
