/* =========================================================
   MAJMAʿ · feuille de style partagée
   Direction « Grille savante » : blanc, grotesque + serif,
   une seule couleur d'accent. Changez --accent pour tout reteinter.
   ========================================================= */

@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,400&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;1,6..72,400;1,6..72,500&family=Amiri:ital,wght@0,400;0,700;1,400&display=swap");

:root{
  /* · palette · */
  --paper:#f5f4ef;
  --paper-deep:#ece9e1;
  --card:#fcfbf8;
  --ink:#15110c;
  --ink-soft:#574f45;
  --ink-faint:#8a8276;
  --rule:#e3dfd6;

  /* · accent unique · */
  --accent:#0e6b60;          /* vert pétrole */
  --gold:var(--accent);
  /* les rubriques partagent l'accent (différenciées par le mot, pas la couleur) */
  --philo:#0e6b60;
  --psycho:#0e6b60;
  --religion:#0e6b60;

  /* · polices · */
  --display:"Fraunces",Georgia,serif;
  --body:"Newsreader",Georgia,serif;

  --measure:40rem;
  --measure-wide:64rem;
}

/* === mode sombre automatique (respecte le réglage du système) === */


/* === thèmes forcés par le bouton (priment sur le système) === */
:root[data-theme="dark"]{
  --paper:#141210; --paper-deep:#1c1915; --card:#1c1813;
  --ink:#ece6db; --ink-soft:#b6ab9a; --ink-faint:#8b8273; --rule:#332e26;
  --accent:#34a596; --gold:#34a596; --philo:#34a596; --psycho:#34a596; --religion:#34a596;
}
:root[data-theme="light"]{
  --paper:#f5f4ef; --paper-deep:#ece9e1; --card:#fcfbf8;
  --ink:#15110c; --ink-soft:#574f45; --ink-faint:#8a8276; --rule:#e3dfd6;
  --accent:#0e6b60; --gold:#0e6b60; --philo:#0e6b60; --psycho:#0e6b60; --religion:#0e6b60;
}
.theme-toggle{background:none;border:1px solid var(--rule);color:var(--ink-soft);font-family:var(--display);font-weight:500;font-size:1rem;line-height:1;padding:.26rem .54rem;border-radius:5px;cursor:pointer;flex:0 0 auto;}
.theme-toggle:hover{color:var(--accent);border-color:var(--accent);}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:1.18rem;
  line-height:1.66;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:var(--accent);text-decoration:none;transition:color .15s,opacity .15s;}
a:hover{color:var(--accent);opacity:.78;}

#progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:60;transition:width .12s linear;}

/* ---------------- EN-TÊTE / NAVIGATION ---------------- */
.site-header{
  position:sticky;top:0;z-index:40;border-bottom:1px solid transparent;
  background:color-mix(in srgb,var(--paper) 78%,transparent);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  transition:border-color .25s,box-shadow .25s,background .25s;
}
.site-header.scrolled{border-bottom-color:var(--rule);box-shadow:0 8px 30px -22px rgba(20,15,10,.6);}
.site-header .bar{
  max-width:var(--measure-wide);margin:0 auto;padding:1.1rem 1.6rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
}
.brand{display:flex;align-items:baseline;gap:.6rem;text-decoration:none;color:var(--ink);}
.brand .mark{font-family:"Amiri",serif;font-size:1.55rem;color:var(--accent);line-height:1;}
.brand .name{font-family:var(--display);font-weight:800;font-size:1.4rem;letter-spacing:-.01em;}
.brand:hover{text-decoration:none;}
.site-nav{display:flex;gap:1.3rem;flex-wrap:wrap;font-family:var(--display);font-weight:500;font-size:1rem;}
.site-nav a{color:var(--ink-soft);letter-spacing:.005em;white-space:nowrap;flex:0 0 auto;}
.header-icon{background:none;border:1px solid var(--rule);color:var(--ink-soft);font-family:var(--display);font-size:1.05rem;line-height:1;padding:.3rem .55rem;border-radius:5px;cursor:pointer;flex:0 0 auto;transition:color .15s,border-color .15s;}
.header-icon:hover{color:var(--accent);border-color:var(--accent);}
.site-nav a:hover{color:var(--accent);text-decoration:none;}
.site-nav a[data-r]:hover{color:var(--accent);}

/* ---------------- CONTENEURS ---------------- */
.wrap{position:relative;z-index:1;max-width:var(--measure-wide);margin:0 auto;padding:0 1.6rem;}
.reading{position:relative;z-index:1;max-width:var(--measure);margin:0 auto;padding:0 1.7rem;}

/* ---------------- HÉRO (accueil) ---------------- */
.hero{text-align:center;padding:4.5rem 1.6rem 3rem;position:relative;}
.hero .ar{font-family:"Amiri",serif;font-size:2rem;color:var(--accent);direction:rtl;margin:0 0 1.1rem;}
.hero h1{font-family:var(--display);font-weight:800;font-size:3.3rem;line-height:.98;letter-spacing:-.025em;margin:0 0 1rem;}
.hero .lede{font-family:var(--body);font-style:italic;font-size:1.4rem;color:var(--ink-soft);max-width:34rem;margin:0 auto;}
.hero .orn{display:block;width:46px;height:3px;background:#b8923f;margin:.5rem auto 1.6rem;}

/* ---------------- RUBRIQUES (cartes) ---------------- */
.section-title{font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-.01em;text-align:center;margin:3.5rem 0 .3rem;}
.section-sub{text-align:center;color:var(--ink-faint);font-style:italic;font-family:var(--body);font-size:1.12rem;margin-bottom:2rem;}

.rubriques{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:2rem 0 1rem;}
.rub{
  display:block;padding:1.7rem 1.4rem;border:1px solid var(--rule);background:var(--card);
  border-top:3px solid var(--accent);text-decoration:none;color:var(--ink);transition:transform .18s,box-shadow .18s;
}
.rub:hover{transform:translateY(-3px);box-shadow:0 12px 26px -18px rgba(20,15,10,.4);text-decoration:none;}
.rub .label{font-family:var(--display);font-size:1.3rem;font-weight:700;color:var(--ink);}
.rub .ar{font-family:"Amiri",serif;color:var(--accent);font-size:1.1rem;float:right;}
.rub p{margin:.5rem 0 0;color:var(--ink-soft);font-size:1.02rem;line-height:1.55;}

/* ---------------- LISTE D'ARTICLES ---------------- */
.articles{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));gap:1.4rem;margin:1.5rem 0 3rem;}
.entry{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--rule);padding:1.5rem 1.4rem;text-decoration:none;color:var(--ink);transition:transform .18s,box-shadow .18s;}
.entry:hover{transform:translateY(-3px);box-shadow:0 14px 28px -20px rgba(20,15,10,.45);text-decoration:none;}
.tag{display:inline-block;font-family:var(--display);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--accent);padding:.22rem .6rem;border-radius:2px;margin-bottom:.9rem;align-self:flex-start;}
.tag[data-r]{background:var(--accent);}
.entry h3{font-family:var(--display);font-weight:700;font-size:1.4rem;line-height:1.12;letter-spacing:-.01em;margin:0 0 .5rem;}
.entry .dek{color:var(--ink-soft);font-size:1.02rem;line-height:1.5;margin:0 0 1rem;flex:1;}
.entry .meta{font-family:var(--body);font-style:italic;color:var(--ink-faint);font-size:1rem;}

/* ---------------- PAGE D'ARTICLE ---------------- */
.article-head{text-align:left;padding:3.2rem 1.7rem 1rem;max-width:var(--measure);margin:0 auto;}
.article-head .kicker{font-family:var(--display);font-weight:700;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:#b8923f;}
.article-head h1{font-family:var(--display);font-weight:800;font-size:2.7rem;line-height:1.0;letter-spacing:-.025em;margin:.5rem 0 .5rem;}
.article-head .sub{font-family:var(--body);font-style:italic;font-size:1.35rem;color:var(--ink-soft);margin:0;}
.article-head .byline{font-family:var(--display);font-weight:500;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-top:1.3rem;}
.article-head .rule{font-size:0;line-height:0;margin-top:1.2rem;}
.article-head .rule::before{content:"";display:block;width:46px;height:3px;background:var(--accent);}

.prose{padding-top:1.4rem;padding-bottom:2rem;}
.prose p{margin:0 0 1.15rem;text-align:justify;text-justify:inter-word;hyphens:auto;overflow-wrap:break-word;}
.prose .lead{text-indent:0;}
.prose .lead::first-letter{
  font-family:var(--body);font-weight:600;color:#b8923f;
  float:left;font-size:3.8rem;line-height:.72;padding:.34rem .12rem 0 0;margin-right:.04em;
}
.prose h2{
  font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.01em;color:var(--ink);
  margin:2.7rem 0 1.1rem;text-align:left;display:inline-block;
  border-bottom:2px solid #b8923f;padding-bottom:.25rem;
}
.prose strong{font-weight:700;color:var(--accent);}
.prose em{font-style:italic;}

.ar-inline{font-family:"Amiri",serif;font-size:1.15em;direction:rtl;unicode-bidi:isolate;}
.verse{font-family:"Amiri",serif;direction:rtl;text-align:center;font-size:1.5rem;line-height:2;color:var(--ink);margin:1.8rem auto !important;padding:.8rem 0;border-top:1px solid #b8923f;border-bottom:1px solid #b8923f;max-width:30rem !important;width:auto;}
.verse .ref{display:block;direction:ltr;font-family:var(--body);font-style:italic;font-size:.95rem;color:var(--ink-faint);margin-top:.5rem;}
.pull{font-family:var(--body);font-style:italic;font-size:1.5rem;line-height:1.38;color:var(--ink);border-left:3px solid var(--accent);padding-left:1.1rem;margin:2.2rem 0;max-width:32rem;text-align:left;}
.divider{text-align:center;color:#b8923f;margin:2.6rem 0;letter-spacing:.4em;}
.divider::after{content:"◆";font-size:.9rem;}

.note{background:var(--paper-deep);border-left:3px solid var(--accent);padding:1.1rem 1.3rem;margin:2rem 0;font-size:1.02rem;line-height:1.55;}
.note .label{font-family:var(--display);font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:.4rem;}

.further{border-top:1px solid var(--rule);margin-top:2.5rem;padding-top:1.4rem;font-size:1rem;color:var(--ink-soft);}
.further h3{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.1rem;letter-spacing:.02em;margin:0 0 .6rem;}
.further ul{margin:0;padding-left:1.1rem;}
.further li{margin:.3rem 0;}

.backlink{display:inline-block;margin:1rem 0 0;font-family:var(--body);font-style:italic;color:var(--ink-faint);}

/* ---------------- PIED DE PAGE ---------------- */
.site-footer{position:relative;z-index:1;border-top:1px solid var(--rule);margin-top:4rem;padding:3rem 1.6rem 4rem;text-align:center;color:var(--ink-faint);}
.site-footer .mark{font-family:"Amiri",serif;font-size:1.5rem;color:var(--accent);}
.site-footer p{font-family:var(--body);font-size:1.02rem;max-width:28rem;margin:.6rem auto 0;}
.site-footer .foot-nav{display:flex;flex-wrap:wrap;gap:1.1rem;justify-content:center;margin:1.1rem 0 .7rem;font-family:var(--display);font-weight:500;font-size:1rem;}
.site-footer .foot-nav a{color:var(--ink-soft);}
.site-footer .foot-nav a:hover{color:var(--accent);text-decoration:none;}
.site-footer a{color:var(--ink-soft);}
.site-footer .copy{font-size:.92rem;color:var(--ink-faint);margin-top:.5rem;}

/* ---------------- FILTRE DES ESSAIS ---------------- */
.filterbar{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1.4rem auto 2.4rem;}
.filter-pill{
  font-family:var(--display);font-weight:500;font-size:.98rem;letter-spacing:.01em;
  color:var(--ink-soft);background:transparent;border:1px solid var(--rule);
  border-radius:2rem;padding:.4rem 1.15rem;cursor:pointer;transition:all .18s;
}
.filter-pill:hover{color:var(--ink);border-color:var(--ink-faint);}
.filter-pill.active{color:#fff;background:var(--accent);border-color:var(--accent);}
.filter-pill.active[data-f]{background:var(--accent);border-color:var(--accent);}
.entry.hidden{display:none;}

/* ---------------- SCHÉMAS / FIGURES ---------------- */
figure.diagram{margin:2.4rem auto;max-width:33rem;}
figure.diagram svg{width:100%;height:auto;display:block;}
figure.diagram figcaption{font-family:var(--body);font-style:italic;font-size:1.02rem;color:var(--ink-faint);text-align:center;margin-top:.7rem;line-height:1.4;}
.diagram svg text{font-family:var(--display);font-weight:500;}
.diagram .d-ar{font-family:"Amiri",serif;}
.diagram .d-ink{fill:var(--ink);}
.diagram .d-soft{fill:var(--ink-soft);}
.diagram .d-gold{fill:var(--gold);}
.diagram .d-accent{fill:var(--accent);}
.diagram .s-accent{stroke:var(--accent);}
.diagram .s-ink{stroke:var(--ink);}
.diagram .s-rule{stroke:var(--rule);}
.diagram .s-gold{stroke:var(--gold);}

/* ---------------- RESPONSIVE ---------------- */
@media (max-width:720px){
  .rubriques{grid-template-columns:1fr;}
}
@media (max-width:560px){
  body{font-size:1.1rem;}
  .hero h1{font-size:2.4rem;}
  .hero .lede{font-size:1.22rem;}
  .article-head{padding:2rem 1.4rem .6rem;}
  .article-head h1{font-size:2.05rem;}
  .verse{font-size:1.3rem;}
  .site-header .bar{flex-direction:row;align-items:center;gap:.6rem;padding:.65rem 1rem;}
  .brand .name{font-size:1.25rem;}
  .brand .mark{font-size:1.35rem;}
  .site-nav{width:100%;flex-wrap:nowrap;gap:.3rem .7rem;font-size:.82rem;justify-content:center;align-items:center;}
  .reading{padding:0 1.4rem;}
}

/* ----- en-têtes illustrés ----- */
.article-head .band{margin:0 0 1.15rem;height:50px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#000 0,#000 60%,transparent);mask-image:linear-gradient(90deg,#000 0,#000 60%,transparent);}
.article-head .band .band-svg{height:50px;width:100%;display:block;}
.emblem-rule{display:flex;align-items:center;gap:0 1rem;margin:1.3rem auto 0;width:fit-content;}
.emblem-rule .ln{height:1px;background:#b8923f;opacity:.55;width:180px;}
.emblem-rule .emblem{flex:0 0 auto;}


/* === accueil C+D === */
.parc-intro{max-width:880px;margin:0 auto;padding:0 22px;}
.parc{max-width:880px;margin:0 auto;padding:14px 22px 4px;display:grid;gap:18px;grid-template-columns:1fr;}
@media(min-width:680px){.parc{grid-template-columns:1fr 1fr;}}
.parc-card{background:var(--card);border:1px solid var(--rule);border-radius:14px;padding:22px;border-top:3px solid #b8923f;}
.parc-card h3{font-family:var(--display);font-size:1.25rem;color:var(--ink);margin:0;}
.parc-why{color:var(--ink-soft);font-size:.9rem;margin:6px 0 10px;}
.parc-steps{list-style:none;margin:0;padding:0;counter-reset:s;}
.parc-steps li{counter-increment:s;border-top:1px solid var(--rule);}
.parc-steps a{display:block;padding:10px 0;text-decoration:none;color:var(--ink);font-family:var(--display);font-size:1.02rem;}
.parc-steps a:before{content:counter(s)".";color:#b8923f;margin-right:8px;font-weight:700;}
.parc-steps a:hover{color:var(--accent);}
.idx-head{max-width:1000px;margin:34px auto 0;padding:0 22px;text-align:center;}
.fbar{max-width:1000px;margin:0 auto;padding:14px 22px 6px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
.fbtn{font-family:var(--display);font-size:.9rem;border:1px solid var(--rule);background:var(--card);color:var(--ink-soft);padding:8px 16px;border-radius:999px;cursor:pointer;}
.fbtn.active{background:var(--bc,var(--accent));border-color:var(--bc,var(--accent));color:#fff;}
.fgrid{max-width:1000px;margin:0 auto;padding:14px 22px 0;display:grid;gap:16px;grid-template-columns:1fr;}
@media(min-width:620px){.fgrid{grid-template-columns:1fr 1fr;}}
@media(min-width:940px){.fgrid{grid-template-columns:1fr 1fr 1fr;}}
.fcard{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:18px;text-decoration:none;display:flex;flex-direction:column;gap:6px;border-top:3px solid var(--tc,var(--accent));}
.fcard .tg{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--tc,var(--accent));font-family:var(--display);}
.fcard h3{font-family:var(--display);font-size:1.1rem;color:var(--ink);margin:0;}
.fcard .dk{color:var(--ink-soft);font-size:.88rem;}
.fcard .mt{color:var(--ink-faint);font-size:.76rem;margin-top:auto;padding-top:6px;}
.fcard.hide{display:none;}


/* === polish · identité de confluence + respiration === */
.manifeste{max-width:600px;margin:14px auto 0;font-family:var(--display);font-size:1.12rem;line-height:1.55;color:var(--ink-soft);}
.site-header::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:12px;background:center/170px 12px no-repeat url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%20170%2012%27%3E%3Cg%20fill%3D%27none%27%20stroke%3D%27%23b8b1a3%27%20stroke-width%3D%271%27%3E%3Cpath%20d%3D%27M2%203%20C%2045%203%2060%209%2085%209%27%2F%3E%3Cpath%20d%3D%27M168%203%20C%20125%203%20110%209%2085%209%27%2F%3E%3C%2Fg%3E%3Ccircle%20cx%3D%2785%27%20cy%3D%279%27%20r%3D%271.6%27%20fill%3D%27%23b8b1a3%27%2F%3E%3C%2Fsvg%3E");opacity:.5;pointer-events:none;}
@media(min-width:760px){
  .manifeste{font-size:1.2rem;}
  .hero{padding-top:60px;padding-bottom:6px;}
  .reading.prose p{line-height:1.85;}
  .reading.prose h2{margin-top:2.3em;}
}

.hero-mark{display:block;width:148px;height:auto;margin:0 0 1.3rem;}
@media(max-width:640px){.hero-mark{width:120px;}}

.brand-logo{height:68px;width:auto;display:block;}
@media(max-width:640px){.brand-logo{height:58px;}}
@media(max-width:380px){.brand-logo{height:52px;}}

.foot-logo{height:76px;width:auto;display:block;margin:0 auto .7rem;}

/*hamburger-header*/
.site-header .bar{display:flex !important;flex-direction:row !important;align-items:center !important;justify-content:space-between !important;gap:1rem;padding:.7rem 1.3rem;max-width:960px;margin:0 auto;}
.site-header .brand{align-self:center;display:flex;align-items:center;gap:.6rem;text-decoration:none;}
.brand-logo{height:54px !important;width:auto !important;}
.brand-name{font-family:var(--display);font-weight:800;font-size:1.45rem;color:var(--ink);letter-spacing:-.01em;line-height:1;}
.menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:1px solid var(--rule);border-radius:8px;background:var(--card);cursor:pointer;font-size:1.25rem;color:var(--ink-soft);transition:border-color .15s,color .15s;flex:0 0 auto;}
.menu-toggle:hover{border-color:var(--accent);color:var(--accent);}
.site-header .site-nav{display:none !important;}
@media(max-width:480px){.brand-logo{height:48px !important;}.brand-name{font-size:1.3rem;}}


.engage{text-align:center;font-size:.92rem;color:var(--ink-faint);margin:1.1rem 0 0;}
.engage a{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--rule);}
.engage a:hover{border-color:var(--accent);}






/*arabesque-bg*/
body{background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%22200%22%20height%3D%22200%22%20viewBox%3D%220%200%20200%20200%22%3E%0A%3Cg%20fill%3D%22none%22%20stroke%3D%22%230e6b60%22%20stroke-width%3D%220.6%22%20opacity%3D%220.07%22%3E%0A%3Ccircle%20cx%3D%22100%22%20cy%3D%22100%22%20r%3D%2228%22/%3E%0A%3Ccircle%20cx%3D%22128.0%22%20cy%3D%22100.0%22%20r%3D%2228%22/%3E%0A%3Ccircle%20cx%3D%22114.0%22%20cy%3D%22124.2%22%20r%3D%2228%22/%3E%0A%3Ccircle%20cx%3D%2286.0%22%20cy%3D%22124.2%22%20r%3D%2228%22/%3E%0A%3Ccircle%20cx%3D%2272.0%22%20cy%3D%22100.0%22%20r%3D%2228%22/%3E%0A%3Ccircle%20cx%3D%2286.0%22%20cy%3D%2275.8%22%20r%3D%2228%22/%3E%0A%3Ccircle%20cx%3D%22114.0%22%20cy%3D%2275.8%22%20r%3D%2228%22/%3E%0A%3C/g%3E%0A%3C/svg%3E");background-repeat:repeat;background-size:200px 200px;}

.ar-tr{text-align:center;font-family:var(--body);font-style:italic;color:var(--ink-faint);font-size:.95rem;margin:-0.6rem 0 1.1rem;}

/*section-break*/
.prose h2{position:relative;margin-top:3.4rem;display:block;width:100%;text-align:left;}
.prose h2::before{
  content:"";display:block;width:100%;text-align:center;height:1px;margin:0 auto 1.6rem;
}
.prose h2 .sep{display:flex;align-items:center;gap:.7rem;width:100%;margin-bottom:1.7rem;}
.prose h2 .sep::before,.prose h2 .sep::after{content:"";flex:1;height:1px;background:#b8923f;opacity:.45;}
.prose h2 .sep .mark{color:#b8923f;font-size:.85rem;flex:0 0 auto;}
.reading.prose > h2:first-of-type{margin-top:2.7rem;}

/*glossary-tooltip*/
.gt{background:rgba(184,146,63,.16);border-bottom:1px solid #b8923f;border-radius:3px;padding:.05em .15em;cursor:help;}
.gt:hover,.gt:focus{background:rgba(184,146,63,.30);}
.gt-tip{position:absolute;width:max-content;max-width:min(300px,calc(100vw - 24px));background:var(--ink);color:var(--paper);
  font-family:var(--body);font-size:.88rem;line-height:1.4;padding:.6rem .8rem;border-radius:8px;
  box-shadow:0 6px 20px rgba(0,0,0,.18);opacity:0;visibility:hidden;transform:translateY(4px);
  transition:opacity .15s,transform .15s;z-index:60;pointer-events:none;}
.gt-tip.show{opacity:1;visibility:visible;transform:translateY(0);}

/*toc-brief*/
.brief{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:1.1rem 1.3rem;margin:1.6rem 0 2rem;}
.brief h4{margin:0 0 .6rem;font-family:var(--display);font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:#b8923f;}
.brief ul{margin:0 0 1rem;padding-left:1.2rem;}
.brief li{margin-bottom:.35rem;font-size:.96rem;}
.brief .toc{margin:0;padding:0;list-style:none;border-top:1px solid var(--rule);padding-top:.9rem;
  display:flex;flex-direction:column;gap:.5rem;}
.brief .toc li{margin:0;font-size:.94rem;}
.brief .toc a{display:flex;align-items:baseline;gap:.6rem;color:var(--ink-soft);text-decoration:none;
  transition:color .15s;}
.brief .toc a:hover{color:var(--accent);}
.brief .toc .tn{font-family:var(--display);font-weight:700;color:#b8923f;font-size:1.05rem;
  flex:0 0 auto;min-width:1.4em;}
.brief .toc .tm{color:#b8923f;opacity:.6;flex:0 0 auto;font-size:.8rem;}
.brief .toc .tt{flex:1 1 auto;}
.brief .toc-label{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:.5rem;}



}







/* Bottom footer nav */
.essay-footer-nav{
  display:flex;justify-content:space-between;align-items:baseline;
  flex-wrap:wrap;gap:.5rem;
  border-top:1px solid var(--rule);padding-top:1rem;margin-top:2rem;
  font-family:var(--display);font-size:.92rem;
}
.essay-footer-nav .backlink{
  color:var(--ink-faint);font-style:italic;text-decoration:none;
  position:static;margin:0;padding:0;font-size:.92rem;
}
.essay-footer-nav .backlink:hover{color:var(--ink-soft);}
.essay-next{color:var(--ink);text-decoration:none;font-weight:500;}
.essay-next:hover{color:var(--accent);text-decoration:none;}
.essay-next em{font-style:italic;color:var(--accent);}

/* Bottom footer nav */
.essay-footer-nav{
  display:block;
  border-top:1px solid var(--rule);padding-top:1rem;margin-top:2rem;
  font-family:var(--display);font-size:.92rem;line-height:1.9;
}
.essay-footer-nav .backlink{
  color:var(--ink-faint);font-style:italic;text-decoration:none;
  position:static;margin:0;padding:0;font-size:.92rem;display:block;
}
.essay-footer-nav .backlink:hover{color:var(--ink-soft);}
.essay-next{color:var(--ink);text-decoration:none;font-weight:500;display:block;text-align:right;}
.essay-next:hover{color:var(--accent);text-decoration:none;}
.essay-next em{font-style:italic;color:var(--accent);}

/* ── ESSAY NAVIGATION ── */
.essay-chapeau,
.essay-footer-nav{
  display:flex;justify-content:space-between;align-items:baseline;
  flex-wrap:wrap;gap:.5rem 1.2rem;
  font-family:var(--display);font-size:.92rem;
}
.essay-chapeau{
  margin:0 0 1.8rem;padding-bottom:1rem;border-bottom:1px solid var(--rule);
}
.essay-footer-nav{
  border-top:1px solid var(--rule);padding-top:1rem;margin-top:2rem;
}
.nav-prev,
.essay-footer-nav .backlink{
  color:var(--ink-faint);font-style:italic;text-decoration:none;
  position:static;margin:0;padding:0;font-size:.92rem;
}
.nav-prev:hover,
.essay-footer-nav .backlink:hover{color:var(--ink-soft);}
.nav-next,
.essay-next{
  color:var(--ink);text-decoration:none;font-weight:500;font-size:.92rem;
}
.nav-next:hover,
.essay-next:hover{color:var(--accent);text-decoration:none;}
.nav-next em,
.essay-next em{font-style:italic;color:var(--accent);}


.lang-switch{text-decoration:none;font-weight:600;}


/* ── Index page styles ── */
/* ── NEW INDEX STYLES ── */

/* Search */
.search-wrap {position:relative;max-width:36rem;margin:0 auto 2.4rem;}
.search-input {
  width:100%;padding:.85rem 1.2rem .85rem 3rem;
  border:1px solid var(--rule);border-radius:8px;
  background:var(--card);color:var(--ink);
  font-family:var(--body);font-size:1.1rem;
  transition:border-color .2s;outline:none;
}
.search-input:focus{border-color:var(--accent);}
.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--ink-faint);pointer-events:none;font-size:1.1rem;}
.search-results{display:none;flex-direction:column;gap:.5rem;margin-top:1rem;}
.search-results.show{display:flex;}
.sr-item{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.7rem 1rem;background:var(--card);border:1px solid var(--rule);border-radius:6px;text-decoration:none;color:var(--ink);transition:border-color .15s;}
.sr-item:hover{border-color:var(--accent);text-decoration:none;}
.sr-title{font-family:var(--display);font-weight:600;font-size:1.05rem;}
.sr-meta{color:var(--ink-faint);font-size:.9rem;white-space:nowrap;}
.no-results{text-align:center;color:var(--ink-faint);font-style:italic;padding:1.5rem;}

/* Hero */
.hero2{
  text-align:center;padding:2.2rem 1.6rem 1.8rem;
  border-bottom:1px solid var(--rule);
}
.hero2 h1{font-family:var(--display);font-weight:800;font-size:2.2rem;line-height:.98;letter-spacing:-.025em;margin:0 0 .7rem;}
.hero2 .lede{font-family:var(--body);font-style:italic;font-size:1.2rem;color:var(--ink-soft);max-width:32rem;margin:0 auto 1.2rem;}
.hero2-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.btn-prim{display:inline-block;padding:.7rem 1.6rem;background:var(--accent);color:#fff;font-family:var(--display);font-weight:600;font-size:1rem;border-radius:6px;text-decoration:none;transition:opacity .15s;}
.btn-prim:hover{opacity:.88;text-decoration:none;color:#fff;}
.btn-sec{display:inline-block;padding:.7rem 1.6rem;border:1px solid var(--rule);color:var(--ink-soft);font-family:var(--display);font-weight:500;font-size:1rem;border-radius:6px;text-decoration:none;transition:border-color .15s,color .15s;}
.btn-sec:hover{border-color:var(--accent);color:var(--accent);text-decoration:none;}

/* Featured cards */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin:1.2rem 0;}
.feat-card{
  display:flex;flex-direction:column;gap:.4rem;
  padding:1.1rem 1.2rem 1rem;
  background:var(--card);border:1px solid var(--rule);
  border-top:2px solid #b8923f;
  border-radius:10px;text-decoration:none;color:var(--ink);
  transition:border-color .18s,box-shadow .18s;
}
.feat-card:hover{border-color:var(--accent);box-shadow:0 4px 18px rgba(14,107,96,.10);text-decoration:none;color:var(--ink);}
.feat-tag{font-family:var(--display);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.feat-title{font-family:var(--display);font-weight:700;font-size:1.25rem;margin:0;line-height:1.2;}
.feat-desc{font-family:var(--body);font-size:.98rem;color:var(--ink-soft);margin:0;line-height:1.5;flex:1;}
.feat-cta{font-family:var(--display);font-size:.88rem;color:var(--accent);font-weight:600;margin-top:.4rem;}
.feat-read{font-family:var(--display);font-size:.84rem;color:var(--accent);font-weight:600;margin-top:.3rem;}

/* Chapters accordion */
.ch-panel{
  border:1px solid var(--rule);border-radius:8px;
  margin-bottom:.4rem;overflow:hidden;
  background:var(--card);
}
.ch-head{
  display:flex;align-items:center;gap:1.2rem;
  padding:1.1rem 1.4rem;cursor:pointer;list-style:none;
  user-select:none;
}
.ch-head::-webkit-details-marker{display:none;}
.ch-head::marker{display:none;}
.ch-num{font-family:var(--display);font-weight:800;font-size:1.7rem;line-height:1;flex:0 0 auto;min-width:1.6rem;color:var(--accent);}
.ch-info{flex:1;}
.ch-title{display:block;font-family:var(--display);font-weight:700;font-size:1.12rem;}
.ch-why{display:block;font-family:var(--body);font-size:.9rem;color:var(--ink-soft);font-style:italic;margin-top:.15rem;}
.ch-count{font-family:var(--display);font-size:.82rem;color:var(--ink-faint);white-space:nowrap;flex:0 0 auto;}
details[open] .ch-head{border-bottom:1px solid var(--rule);}
.ch-body{padding:.8rem .4rem .8rem 1rem;display:flex;flex-direction:column;gap:0;}

/* Essay rows inside chapters */
.erow{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:1rem;padding:.85rem .8rem;border-radius:5px;
  text-decoration:none;color:var(--ink);
  border-bottom:1px solid var(--rule);
  transition:background .12s;
}
.erow:last-child{border-bottom:none;}
.erow:hover{background:var(--paper-deep);text-decoration:none;}
.erow-title{font-family:var(--body);font-size:1rem;}
.erow-meta{font-family:var(--display);font-size:.8rem;color:var(--ink-faint);white-space:nowrap;flex:0 0 auto;}



/* Section headers */
.idx-section{max-width:var(--measure-wide);margin:0 auto;padding:2.8rem 1.6rem 0;}
.idx-section + .idx-section{
  border-top:1px solid var(--rule);
  padding-top:2.8rem;margin-top:1.6rem;
}
.idx-label{
  font-family:var(--display);font-weight:800;font-size:1.5rem;
  letter-spacing:-.01em;color:var(--ink);
  margin-bottom:1.1rem;
}
.idx-label::after{
  content:"";display:block;width:2.4rem;height:3px;
  background:#b8923f;margin-top:.5rem;border-radius:2px;
}

/* Mobile */
@media(max-width:600px){
  .hero2 h1{font-size:2rem;}
  .feat-grid{grid-template-columns:1fr;}
  .tracks-grid{grid-template-columns:1fr;}
  .ch-head{padding:.9rem 1rem;}
  .ch-num{font-size:1.6rem;min-width:1.4rem;}
  .ch-why{display:none;}
}

.apropos-links{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:.9rem;margin-top:1.6rem;
}
.apropos-links a{
  display:flex;flex-direction:column;gap:.2rem;
  padding:1rem 1.1rem;
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
  text-decoration:none;color:var(--ink);
  transition:border-color .18s;
}
.apropos-links a:hover{border-color:#b8923f;text-decoration:none;color:var(--ink);}
.al-title{font-family:var(--display);font-weight:700;font-size:1.05rem;margin-top:.1rem;}
.al-desc{font-family:var(--body);font-style:italic;font-size:.85rem;color:var(--ink-faint);}

/* Gold touch on hero rule */


.apropos-blurb{
  font-family:var(--body);font-size:1.05rem;line-height:1.7;
  color:var(--ink-soft);max-width:42rem;
  text-align:justify;text-justify:inter-word;hyphens:auto;
  margin:0 0 1.6rem;
}
.apropos-blurb em{font-style:italic;color:var(--ink);}
.apropos-blurb a{color:var(--accent);font-weight:500;}

/* Parcours intro */
.idx-intro{font-family:var(--body);font-style:italic;color:var(--ink-soft);font-size:1rem;margin:0 0 1.6rem;}

/* Track accordion (parcours) */
.track2{
  border:1px solid var(--rule);border-radius:8px;
  margin-bottom:.7rem;overflow:hidden;background:var(--card);
}
.track2-head{
  display:flex;align-items:baseline;gap:.9rem;
  padding:1rem 1.3rem;cursor:pointer;list-style:none;user-select:none;
}
.track2-head::-webkit-details-marker{display:none;}
.track2-head::marker{display:none;}
.track2-icon{color:var(--accent);font-size:1.1rem;flex:0 0 auto;}
.track2-name{font-family:var(--display);font-weight:700;font-size:1.05rem;flex:1;}
.track2-name small{
  display:block;font-weight:400;font-size:.82rem;color:var(--ink-faint);
  margin-top:.15rem;
}
.track2[open] .track2-head{border-bottom:1px solid var(--rule);}
.track2-desc{
  font-family:var(--body);font-style:italic;font-size:.92rem;
  color:var(--ink-soft);margin:1rem 1.3rem .8rem;
}
.track2-list{list-style:none;margin:0;padding:0 .6rem .6rem;}
.track2-list li{margin:0;}
.track2-list a{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:1rem;padding:.6rem .8rem;border-radius:5px;
  text-decoration:none;color:var(--ink);font-family:var(--body);font-size:.98rem;
  transition:background .12s;
}
.track2-list a:hover{background:var(--paper-deep);text-decoration:none;}
.track2-list a span{
  font-family:var(--display);font-size:.82rem;color:var(--ink-faint);
  white-space:nowrap;flex:0 0 auto;
}

/* Header icons (search + theme) */
/* === Recherche dépliable (loupe) — toutes pages === */
.search-panel{max-height:0;overflow:hidden;opacity:0;padding:0 1.6rem;transition:max-height .28s ease,opacity .2s ease,padding .28s ease;border-top:1px solid transparent;}
.search-panel.open{max-height:70vh;opacity:1;padding:.9rem 1.6rem;border-top-color:var(--rule);}
.search-wrap{position:relative;max-width:36rem;margin:0 auto;}

/* === Lien de nav actif === */
.site-nav a.is-active{color:var(--accent);position:relative;font-weight:600;}
.site-nav a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--accent);border-radius:2px;}
.site-nav a.header-icon.is-active::after{display:none;}

/* === Menu hamburger sobre à icônes (toutes pages) === */
.menu-drawer{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--paper);box-shadow:-14px 0 50px -24px rgba(20,15,10,.55);transform:translateX(100%);visibility:hidden;transition:transform .32s cubic-bezier(.4,0,.2,1),visibility 0s linear .32s;z-index:300;overflow-y:auto;padding:0!important;display:block!important;}
.menu-drawer.open{transform:translateX(0);visibility:visible;transition:transform .32s cubic-bezier(.4,0,.2,1),visibility 0s;}
.menu-close{position:absolute;top:1.1rem;right:1.4rem;font-size:1.7rem;line-height:1;background:none;border:none;cursor:pointer;color:var(--ink-soft);z-index:2;padding:0;}
.menu-back{position:fixed;inset:0;background:rgba(20,15,10,.4);opacity:0;pointer-events:none;transition:opacity .28s;z-index:250;}
.menu-back.open{opacity:1;pointer-events:auto;}
.menu-head{display:flex;align-items:center;gap:.6rem;padding:1.5rem 1.7rem 1.1rem;border-bottom:1px solid var(--rule);}
.menu-head img{height:42px;width:auto;}
.menu-head .mh-name{font-family:var(--display);font-weight:800;font-size:1.25rem;color:var(--ink);}
.menu-list{padding:.8rem 1rem 1.5rem;display:flex;flex-direction:column;gap:.1rem;}
.menu-list a{display:flex;align-items:center;gap:.85rem;font-family:var(--display);font-size:1.12rem;color:var(--ink);padding:.7rem .7rem;border-radius:9px;text-decoration:none;border-bottom:none!important;opacity:1!important;transform:none!important;transition:background .15s,color .15s;}
.menu-list a:hover{background:color-mix(in srgb,var(--mc,var(--accent)) 10%,transparent);color:var(--mc,var(--accent));}
.menu-list a.is-active{color:var(--mc,var(--accent));font-weight:700;}
.menu-ic{width:1.9rem;height:1.9rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.menu-ic svg{width:1.9rem;height:1.9rem;}
.menu-sep{height:1px;background:var(--rule);margin:.6rem .7rem;}
.menu-list a.sec{font-size:1rem;color:var(--ink-soft);}
.menu-list a.sec:hover{color:var(--accent);}
