/* ============================================================
   INTENDANCE PALACE — "LA REVUE"
   State-archive editorial. Parchment · Ink · Gold leaf.
   ============================================================ */

:root{
  --ink:#17130F;          /* warm espresso near-black */
  --ink-soft:#241C14;
  --ink-2:#2C2218;
  --parch:#EAE0CC;        /* parchment page */
  --parch-2:#F0E8D7;      /* lighter panel  */
  --bone:#FBF6EC;         /* brightest cream */
  --gold:#A87A40;         /* gold leaf       */
  --gold-bright:#C99A57;
  --gold-soft:#b8924f;
  --seal:#6E2B2B;         /* oxblood, rare   */
  --rule:rgba(23,19,15,.22);
  --rule-soft:rgba(23,19,15,.12);
  --rule-d:rgba(234,224,204,.20);
  --cream-txt:#EAE0CC;
  --display:'Fraunces', Georgia, serif;
  --body:'Spectral','Fraunces', Georgia, serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--parch);color:var(--ink);
  font-family:var(--body);font-weight:400;font-size:18px;line-height:1.62;
  font-optical-sizing:auto;text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"liga" 1,"dlig" 1,"onum" 1;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--bone)}

/* paper grain overlay */
.grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply}

/* reading progress (article pages) */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .1s linear}

.wrap{max-width:1280px;margin:0 auto;padding:0 40px}
.eyebrow{font-family:var(--display);font-weight:500;font-size:11px;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold);font-feature-settings:"smcp" 0}

/* ============================================================  HEADER  */
.site-head{position:fixed;top:0;left:0;right:0;width:100%;z-index:120;background:var(--ink);
  color:var(--cream-txt);border-bottom:1px solid var(--rule-d)}
/* header floats over the first dark band -> shrinking it never reflows content (no flicker) */
.head-top{display:flex;align-items:center;justify-content:space-between;
  padding:11px 40px;font-family:var(--display);font-size:10.5px;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(234,224,204,.62);border-bottom:1px solid var(--rule-d)}
.head-top .tools{display:flex;gap:22px;align-items:center}
.head-top .tools a:hover,.head-top .ico:hover{color:var(--gold-bright);cursor:pointer}

.masthead{text-align:center;padding:30px 40px 22px;position:relative;transition:padding .45s var(--ease)}
.masthead .rule-orn{display:flex;align-items:center;justify-content:center;gap:16px;margin:0 auto 14px;max-width:520px;color:var(--gold)}
.masthead .rule-orn::before,.masthead .rule-orn::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold))}
.masthead .rule-orn::after{background:linear-gradient(90deg,var(--gold),transparent)}
.masthead .diamond{width:5px;height:5px;background:var(--gold);transform:rotate(45deg)}
.wordmark{font-family:var(--display);font-weight:400;font-optical-sizing:auto;
  font-size:clamp(23px,4.1vw,46px);letter-spacing:.16em;line-height:1;margin:0;
  text-transform:uppercase;transition:font-size .45s var(--ease)}
.wordmark .amp{font-style:italic;color:var(--gold-bright)}
.masthead .tagline{font-style:italic;font-size:13.5px;letter-spacing:.04em;
  color:rgba(234,224,204,.7);margin:12px 0 0}

.mainnav{display:flex;justify-content:center;flex-wrap:nowrap;gap:0;
  border-top:1px solid var(--rule-d);padding:0 12px}
.mainnav a{font-family:var(--display);font-size:clamp(9.5px,.86vw,11.5px);letter-spacing:.12em;
  text-transform:uppercase;white-space:nowrap;
  color:rgba(234,224,204,.78);padding:14px 15px;position:relative;transition:color .3s}
.mainnav a + a::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:1px;height:12px;background:var(--rule-d)}
.mainnav a:hover{color:var(--bone)}
.mainnav a .uline{position:absolute;left:15px;right:15px;bottom:9px;height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.mainnav a:hover .uline,.mainnav a.active .uline{transform:scaleX(1)}
.mainnav a.active{color:var(--bone)}

/* slim condensed state on scroll */
.site-head.slim .head-top{display:none}
.site-head.slim .masthead{padding:12px 40px 10px}
.site-head.slim .masthead .rule-orn,.site-head.slim .masthead .tagline{display:none}
.site-head.slim .wordmark{font-size:22px;letter-spacing:.18em}

/* compact header on secondary pages (category / article / legal):
   the full masthead only makes sense on the home page */
body.subpage .masthead{padding:14px 40px 10px}
body.subpage .masthead .rule-orn,
body.subpage .masthead .tagline{display:none}
body.subpage .masthead .emblem{width:38px;margin-bottom:8px}
body.subpage .wordmark{font-size:clamp(20px,2.4vw,28px);letter-spacing:.18em}

.burger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:24px;height:1.5px;background:var(--cream-txt);display:block;transition:.3s}
.mobile-nav{display:none}

/* ============================================================  SEARCH  */
.ico.search-open{background:none;border:0;font:inherit;cursor:pointer;padding:0;
  font-family:var(--display);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(234,224,204,.62);transition:color .3s}
.ico.search-open:hover{color:var(--gold-bright)}
.search-modal{position:fixed;inset:0;z-index:300;display:none;
  background:rgba(15,12,9,.88);backdrop-filter:blur(4px);
  align-items:flex-start;justify-content:center;padding:13vh 24px 24px}
.search-modal.open{display:flex}
.search-panel{position:relative;width:min(680px,100%);background:var(--ink-2);
  border:1px solid var(--rule-d);box-shadow:0 40px 80px -30px rgba(0,0,0,.7);padding:42px 38px 30px}
.search-close{position:absolute;top:12px;right:18px;background:none;border:0;line-height:1;
  color:rgba(234,224,204,.6);font-size:26px;cursor:pointer;transition:color .3s}
.search-close:hover{color:var(--gold-bright)}
.search-eyebrow{display:block;font-family:var(--display);font-size:11px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.search-input{width:100%;background:transparent;border:0;border-bottom:1px solid var(--rule-d);
  color:var(--bone);font-family:var(--display);font-size:clamp(20px,3vw,30px);font-weight:400;
  padding:6px 0 14px;outline:none}
.search-input::placeholder{color:rgba(234,224,204,.38)}
.search-input:focus{border-bottom-color:var(--gold)}
.search-results{margin-top:6px;max-height:48vh;overflow:auto}
.search-result{display:block;padding:16px 2px;border-bottom:1px solid var(--rule-d);transition:padding .25s var(--ease)}
.search-result:last-child{border-bottom:0}
.search-result:hover{padding-left:10px}
.sr-cat{display:block;font-family:var(--display);font-size:10px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.sr-title{display:block;font-family:var(--display);font-size:18px;color:var(--bone);line-height:1.22}
.sr-dek{display:block;font-style:italic;font-size:13.5px;color:rgba(234,224,204,.6);margin-top:5px}
.search-empty{font-style:italic;color:rgba(234,224,204,.55);padding:18px 0}
body.search-open-body{overflow:hidden}
.mobile-search{display:none}

/* ============================================================  HERO / LA UNE  */
.laune{position:relative;background:var(--ink);color:var(--cream-txt);overflow:hidden;
  padding-top:clamp(150px,17vh,250px)}
.laune-grid{display:grid;grid-template-columns:1.05fr 1fr;min-height:clamp(520px,82vh,860px)}
.laune-media{position:relative;overflow:hidden}
.laune-media img{position:absolute;inset:-8% 0;width:100%;height:116%;object-fit:cover;
  filter:saturate(.92) contrast(1.02);will-change:transform}
.laune-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 55%,rgba(23,19,15,.85)),linear-gradient(0deg,rgba(23,19,15,.5),transparent 50%)}
.laune-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,86px);position:relative;z-index:2}
.laune-no{position:absolute;top:34px;right:clamp(40px,6vw,86px);font-family:var(--display);
  font-size:13px;letter-spacing:.3em;color:var(--gold);opacity:.8}
.laune-cat{margin-bottom:22px}
.laune-title{font-family:var(--display);font-weight:400;font-optical-sizing:auto;
  font-size:clamp(34px,4.6vw,68px);line-height:1.02;letter-spacing:.005em;margin:0 0 22px}
.laune-dek{font-style:italic;font-size:clamp(16px,1.4vw,21px);line-height:1.55;
  color:rgba(234,224,204,.82);max-width:30em;margin:0 0 30px}
.laune-meta{display:flex;align-items:center;gap:18px;font-family:var(--display);font-size:11px;
  letter-spacing:.24em;text-transform:uppercase;color:rgba(234,224,204,.6)}
.read-link{display:inline-flex;align-items:center;gap:12px;margin-top:6px;font-family:var(--display);
  font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-bright);width:fit-content}
.read-link .arrow{display:inline-block;width:34px;height:1px;background:var(--gold-bright);position:relative;transition:width .35s var(--ease)}
.read-link .arrow::after{content:"";position:absolute;right:0;top:-3px;width:7px;height:7px;border-top:1px solid var(--gold-bright);border-right:1px solid var(--gold-bright);transform:rotate(45deg)}
.read-link:hover .arrow{width:54px}

/* ============================================================  SOMMAIRE  */
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:30px;
  padding:78px 0 26px;border-bottom:1px solid var(--rule)}
.section-head h2{font-family:var(--display);font-weight:400;font-size:clamp(26px,3vw,40px);
  margin:0;letter-spacing:.01em}
.section-head .count{font-family:var(--display);font-size:12px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);white-space:nowrap}

.sommaire{display:grid;grid-template-columns:repeat(12,1fr);gap:0;
  border-top:1px solid var(--rule);margin-bottom:90px}
.entry{position:relative;padding:34px 30px 38px;border-bottom:1px solid var(--rule);
  display:flex;flex-direction:column;min-height:240px}
/* column rules */
.entry::before{content:"";position:absolute;top:0;bottom:0;left:0;width:1px;background:var(--rule-soft)}
.entry.s7{grid-column:span 7}
.entry.s5{grid-column:span 5}
.entry.s4{grid-column:span 4}
.entry.s6{grid-column:span 6}
.entry.s12{grid-column:span 12;flex-direction:row;align-items:center;gap:50px;min-height:340px}
.entry.s8{grid-column:span 8}

.entry-no{font-family:var(--display);font-size:12px;letter-spacing:.24em;color:var(--gold);
  margin-bottom:16px;display:flex;align-items:center;gap:12px}
.entry-no::after{content:"";height:1px;width:28px;background:var(--gold);opacity:.6}
.entry-cat{font-family:var(--display);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink);opacity:.55;margin-bottom:14px}
.entry-media{overflow:hidden;margin:0 0 22px;background:var(--ink)}
.entry-media img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform 1s var(--ease);
  filter:saturate(.94)}
.entry.s5 .entry-media img,.entry.s4 .entry-media img{aspect-ratio:4/5}
.entry:hover .entry-media img{transform:scale(1.06)}
.entry-title{font-family:var(--display);font-weight:400;font-optical-sizing:auto;
  line-height:1.08;letter-spacing:.005em;margin:0 auto 0 0}
.entry.s7 .entry-title,.entry.s8 .entry-title{font-size:clamp(24px,2.4vw,38px)}
.entry.s12 .entry-title{font-size:clamp(28px,3.2vw,50px)}
.entry.s5 .entry-title,.entry.s4 .entry-title,.entry.s6 .entry-title{font-size:clamp(21px,1.9vw,28px)}
.entry-title a{background-image:linear-gradient(var(--gold),var(--gold));background-size:0 1px;
  background-repeat:no-repeat;background-position:0 100%;transition:background-size .45s var(--ease),color .3s;padding-bottom:3px}
.entry:hover .entry-title a{background-size:100% 1px;color:var(--ink)}
.entry-date{font-family:var(--display);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);opacity:.5;margin-top:18px}
.entry.s12 .entry-media{flex:0 0 46%;margin:0;align-self:stretch;display:flex}
.entry.s12 .entry-media img{aspect-ratio:auto;height:100%}
.entry.s12 .entry-body{flex:1}
.entry.s12 .entry-no{margin-bottom:18px}

/* ============================================================  FIT (text-bearing images: never crop) */
.fit{position:relative;overflow:hidden}
.fit::before{content:"";position:absolute;inset:0;z-index:0;
  background:var(--bg) center/cover no-repeat;filter:blur(34px) brightness(.42) saturate(.85);
  transform:scale(1.18)}
.fit > img,.fit a > img{position:relative !important;z-index:1;inset:auto !important;
  width:100% !important;height:100% !important;object-fit:contain !important;transform:none !important}
.entry-media.fit > img{aspect-ratio:3/2}
.entry.s5 .entry-media.fit > img,.entry.s4 .entry-media.fit > img{aspect-ratio:4/5}
.entry:hover .entry-media.fit > img{transform:none !important}

/* ============================================================  LOGO / EMBLEM / CREDIT */
.masthead .emblem{display:block;width:64px;height:auto;margin:0 auto 14px;opacity:.92;
  transition:opacity .4s var(--ease),width .45s var(--ease),margin .45s var(--ease)}
.site-head.slim .masthead .emblem{width:0;margin:0;opacity:0;overflow:hidden}
.foot-logo{width:clamp(150px,16vw,210px);height:auto;margin:6px auto 0;opacity:.9}
.entry-media.pcard img{aspect-ratio:4/5}
.entry.s12 .entry-media.pcard img{aspect-ratio:3/2}
/* text/graphic cards: clean wide bottom-strip, no baked text shown -> nothing cut */
.entry-media.stripcard img{aspect-ratio:16/9}
.hero-credit{font-style:italic;text-transform:none;letter-spacing:.01em;opacity:.72}
.figwrap.doc-full img{border:1px solid rgba(168,122,64,.42)}
.figwrap.doc-full figcaption{margin-top:14px}

/* ============================================================  LANGUAGE SWITCHER */
.head-top .tools{position:relative}
.langsw{position:relative;display:inline-block;cursor:pointer;outline:none}
.langsw-cur{display:inline-flex;gap:6px;align-items:center;color:rgba(234,224,204,.62);
  font-family:var(--display);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;transition:color .3s}
.langsw:hover .langsw-cur,.langsw:focus .langsw-cur,.langsw:focus-within .langsw-cur{color:var(--gold-bright)}
.langsw .chev{font-size:9px;opacity:.8}
.langsw-cur{cursor:pointer;user-select:none}
.langsw-menu{position:absolute;right:0;top:100%;margin-top:10px;background:var(--ink-2);
  border:1px solid var(--rule-d);min-width:150px;padding:6px 0;display:none;z-index:140;
  box-shadow:0 20px 44px -18px rgba(0,0,0,.65)}
/* invisible bridge so the menu doesn't close when crossing the gap on hover */
.langsw-menu::before{content:"";position:absolute;left:0;right:0;top:-12px;height:12px}
.langsw.open .langsw-menu,.langsw:hover .langsw-menu,.langsw:focus-within .langsw-menu{display:block}
.langopt{display:block;padding:9px 18px;font-family:var(--display);font-size:12px;letter-spacing:.1em;
  color:rgba(234,224,204,.8);transition:.2s}
.langopt:hover{background:rgba(168,122,64,.16);color:var(--bone)}
.langopt.active{color:var(--gold-bright)}

/* ============================================================  PER-LANGUAGE FONTS */
html[lang="ar"]{--display:'Noto Naskh Arabic',serif;--body:'Noto Naskh Arabic',serif;--read:'Noto Naskh Arabic',serif}
html[lang="zh"]{--display:'Noto Serif SC',serif;--body:'Noto Serif SC',serif;--read:'Noto Serif SC',serif}
.wordmark,.foot-wordmark{font-family:'Fraunces',Georgia,serif}

/* ============================================================  RTL (Arabic) */
[dir="rtl"] .art-body{text-align:right}
[dir="rtl"] .art-body>p:first-of-type::first-letter{float:right;padding:8px 0 0 14px}
[dir="rtl"] .art-body .sub::before{margin-left:auto;margin-right:0}
[dir="rtl"] .entry::before{left:auto;right:0}
[dir="rtl"] .art-body figcaption{padding-left:0;padding-right:16px;border-left:0;border-right:1px solid var(--gold)}
[dir="rtl"] .langsw-menu{right:auto;left:0}
[dir="rtl"] .read-link .arrow{transform:scaleX(-1)}
[dir="rtl"] .entry-no::after{margin-left:0;margin-right:0}
[dir="rtl"] .laune-media::after{background:linear-gradient(-90deg,transparent 55%,rgba(23,19,15,.85)),linear-gradient(0deg,rgba(23,19,15,.5),transparent 50%)}

/* ============================================================  REVEAL ANIMS  */
[data-reveal]{opacity:0;transform:translateY(26px);
  clip-path:inset(0 0 8% 0);
  transition:opacity 1s var(--ease),transform 1s var(--ease),clip-path 1s var(--ease)}
[data-reveal].in{opacity:1;transform:none;clip-path:inset(0 0 0 0)}
.lline{opacity:0;transform:translateY(115%);display:inline-block}
.lline.in{opacity:1;transform:none;transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}

/* ============================================================  CATEGORY COVER  */
.cat-cover{background:var(--ink);color:var(--cream-txt);
  min-height:clamp(360px,48vh,540px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:clamp(170px,15vw,210px) 24px clamp(50px,6vw,80px);
  text-align:center;position:relative;overflow:hidden}
.cat-cover .eyebrow{margin-bottom:24px;display:block}
.cat-cover h1{font-family:var(--display);font-weight:400;font-optical-sizing:auto;
  font-size:clamp(40px,8vw,108px);line-height:.98;letter-spacing:.01em;margin:0}
.cat-cover .descr{font-style:italic;font-size:17px;color:rgba(234,224,204,.7);margin:22px auto 0;max-width:38em}
.cat-cover .ornament{margin:30px auto 0;width:60px;height:1px;background:var(--gold)}
.empty{text-align:center;font-style:italic;font-size:20px;color:var(--ink);opacity:.55;padding:80px 0 120px}
/* pagination */
.pager{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;padding:30px 0 110px;font-family:var(--display)}
.pager .pg-num,.pager .pg-arrow{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 8px;font-size:16px;color:var(--ink);text-decoration:none;border:1px solid var(--rule-soft);border-radius:2px;transition:color .25s,border-color .25s,background .25s}
.pager .pg-num:hover,.pager .pg-arrow:hover{border-color:var(--gold);color:var(--gold)}
.pager .pg-num.current{background:var(--ink);color:var(--parch);border-color:var(--ink)}
.pager .pg-arrow{font-size:20px;line-height:1}
.pager .disabled{opacity:.3;pointer-events:none}

/* ============================================================  ARTICLE  */
.article{background:var(--parch)}
/* flex + top padding so the (bottom-anchored) title can never slip under the
   fixed header on short viewports; the hero grows for long titles */
.art-hero{position:relative;min-height:clamp(440px,68vh,720px);display:flex;align-items:flex-end;
  overflow:hidden;background:var(--ink);padding-top:clamp(200px,22vh,240px)}
.art-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(.9) brightness(.82);will-change:transform}
.art-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(23,19,15,.92) 2%,rgba(23,19,15,.25) 45%,rgba(23,19,15,.55))}
.art-hero-inner{position:relative;z-index:2;width:100%;color:var(--cream-txt);
  padding:0 40px clamp(40px,6vw,80px)}
.art-hero-inner .wrap{max-width:1000px}
.art-cat{display:inline-block;margin-bottom:22px;font-family:var(--display);font-size:11px;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold-bright)}
.art-cat:hover{color:var(--bone)}
.art-title{font-family:var(--display);font-weight:400;font-optical-sizing:auto;
  font-size:clamp(32px,5.4vw,76px);line-height:1.02;letter-spacing:.004em;margin:0 0 22px;max-width:18em}
.art-byline{font-family:var(--display);font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(234,224,204,.66);display:flex;gap:16px;align-items:center}
.art-byline .dot{width:4px;height:4px;background:var(--gold);transform:rotate(45deg)}

.art-body{max-width:820px;margin:0 auto;padding:clamp(52px,6.5vw,88px) 40px 40px;
  font-family:var(--body);font-size:18px;line-height:1.72;color:var(--ink)}
.art-body > p{margin:0 0 24px;hyphens:auto;text-align:justify;text-justify:inter-word}
.art-body > p:first-of-type::first-letter{font-family:var(--display);font-weight:400;
  float:left;font-size:66px;line-height:.74;padding:7px 12px 0 0;color:var(--seal)}
.art-body .sub{font-family:var(--display);font-weight:400;font-size:clamp(22px,2.6vw,28px);
  line-height:1.15;margin:54px 0 22px;letter-spacing:.005em}
.art-body .sub::before{content:"";display:block;width:40px;height:1px;background:var(--gold);margin-bottom:22px}
.art-body figure{margin:46px 0;}
.art-body figure.wide{width:min(1100px,92vw);margin-left:50%;transform:translateX(-50%)}
.art-body figure img{width:100%}
.art-body figcaption{font-family:var(--display);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);margin-top:12px;line-height:1.5;
  padding-left:16px;border-left:1px solid var(--gold)}
.art-body blockquote{margin:46px 0;padding:0;font-family:var(--display);font-weight:400;
  font-size:clamp(24px,3vw,34px);line-height:1.25;color:var(--seal);font-style:italic;text-align:center}
.art-body blockquote::before{content:"“";display:block;font-size:64px;color:var(--gold);line-height:.4;margin-bottom:18px}
.art-body ul{margin:0 0 28px;padding-left:0;list-style:none}
.art-body li{position:relative;padding-left:28px;margin-bottom:14px}
.art-body li::before{content:"";position:absolute;left:2px;top:14px;width:6px;height:6px;background:var(--gold);transform:rotate(45deg)}
.art-end{text-align:center;padding:30px 0 10px}
.art-end .mark{display:inline-block;width:7px;height:7px;background:var(--seal);transform:rotate(45deg)}

.related{border-top:1px solid var(--rule);margin-top:60px}
.related .section-head{padding-top:60px}

/* ============================================================  LEGAL / PRIVACY PAGE */
.legal-cover{min-height:clamp(320px,40vh,460px);padding:clamp(165px,14vw,200px) 24px clamp(44px,5vw,68px)}
.art-body.legal{max-width:820px;font-size:17px;line-height:1.7}
.art-body.legal > p:first-of-type::first-letter{font-family:var(--body);font-weight:400;
  float:none;font-size:inherit;line-height:inherit;padding:0;color:inherit}
.art-body.legal .sub{font-size:clamp(20px,2.2vw,25px);margin:48px 0 18px}
.art-body.legal blockquote{font-family:var(--body);font-style:normal;text-align:left;
  font-size:16px;line-height:1.7;color:var(--ink);border-left:2px solid var(--gold);
  padding:4px 0 4px 20px;margin:28px 0}
.art-body.legal blockquote::before{display:none}
[dir="rtl"] .art-body.legal blockquote{text-align:right;border-left:0;border-right:2px solid var(--gold);padding:4px 20px 4px 0}

/* ============================================================  FOOTER  */
.site-foot{background:var(--ink);color:var(--cream-txt);margin-top:0}
.foot-mast{text-align:center;padding:clamp(60px,8vw,100px) 40px 50px;border-bottom:1px solid var(--rule-d)}
.foot-mast .rule-orn{display:flex;align-items:center;justify-content:center;gap:16px;margin:0 auto 20px;max-width:420px;color:var(--gold)}
.foot-mast .rule-orn::before,.foot-mast .rule-orn::after{content:"";height:1px;flex:1;background:var(--gold);opacity:.5}
.foot-wordmark{font-family:var(--display);font-weight:400;font-size:clamp(28px,5vw,54px);
  letter-spacing:.16em;text-transform:uppercase;margin:0}
.foot-wordmark .amp{font-style:italic;color:var(--gold-bright)}
.foot-grid{display:grid;grid-template-columns:1.2fr 1fr 1.4fr;gap:54px;
  max-width:1100px;margin:0 auto;padding:64px 40px 40px}
.foot-col h4{font-family:var(--display);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin:0 0 20px;font-weight:500}
.foot-col p{margin:0 0 9px;font-size:15px;color:rgba(234,224,204,.78)}
.foot-col a{color:rgba(234,224,204,.78);transition:color .3s}
.foot-col a:hover{color:var(--gold-bright)}
.foot-nav{display:flex;flex-direction:column;gap:11px;font-family:var(--display);font-size:12.5px;
  letter-spacing:.12em}
.foot-cta p{font-style:italic;font-size:16px;margin-bottom:22px;line-height:1.55}
.btn-don{display:inline-block;border:1px solid var(--gold);color:var(--gold-bright);
  padding:14px 34px;font-family:var(--display);font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  transition:.35s var(--ease);position:relative;overflow:hidden}
.btn-don span{position:relative;z-index:2}
.btn-don::before{content:"";position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .4s var(--ease)}
.btn-don:hover{color:var(--ink)}
.btn-don:hover::before{transform:translateY(0)}
.socials{margin-top:26px;display:flex;gap:22px;font-family:var(--display);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.socials a{color:rgba(234,224,204,.6)}.socials a:hover{color:var(--gold-bright)}
.colophon{border-top:1px solid var(--rule-d);text-align:center;padding:26px;
  font-family:var(--display);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:rgba(234,224,204,.45)}

/* ============================================================  RESPONSIVE  */
/* keep the 7-item nav on a single line on laptops / small desktops */
@media(min-width:861px) and (max-width:1180px){
  .mainnav{padding:0 6px}
  .mainnav a{padding:13px 10px;letter-spacing:.05em;font-size:clamp(9px,1vw,10.5px)}
  .mainnav a .uline{left:10px;right:10px}
}
@media(max-width:1080px){
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .mainnav{display:none}
  .head-top{display:none}
  .burger{display:flex;position:absolute;right:30px;top:22px}
  .mobile-search{display:block;width:100%;text-align:left;background:none;border:0;
    font-family:var(--display);padding:16px 30px;font-size:13px;letter-spacing:.18em;
    text-transform:uppercase;border-bottom:1px solid var(--rule-d);color:var(--gold-bright);cursor:pointer}
  .masthead{padding:26px 56px}
  .laune-grid{grid-template-columns:1fr}
  .laune-media{height:48vh;min-height:340px}
  .laune-media img{position:absolute}
  .laune-text{padding:42px 30px 56px}
  .laune-media::after{background:linear-gradient(0deg,var(--ink),rgba(23,19,15,.2))}
  .entry,.entry.s7,.entry.s5,.entry.s4,.entry.s6,.entry.s8,.entry.s12{grid-column:span 12 !important;flex-direction:column;gap:0;min-height:0}
  .entry.s12 .entry-media{flex:none;width:100%;margin-bottom:22px}
  .entry.s12 .entry-media img{height:auto;aspect-ratio:3/2}
  .site-head.slim .masthead{padding:12px 56px 10px}
  body.menu-open .mobile-nav{display:flex}
  .mobile-nav{flex-direction:column;background:var(--ink-soft);border-top:1px solid var(--rule-d)}
  .mobile-nav a{font-family:var(--display);padding:16px 30px;font-size:13px;letter-spacing:.18em;
    text-transform:uppercase;border-bottom:1px solid var(--rule-d);color:var(--cream-txt)}
  .foot-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:560px){
  .wrap{padding:0 24px}
  body{font-size:17px;overflow-x:hidden}
  .masthead{padding:24px 26px}
  .wordmark{font-size:clamp(14px,4.4vw,21px);letter-spacing:.05em}
  .laune-title{font-size:clamp(26px,7vw,34px)}
  .laune-text{padding:38px 24px 52px}
  .art-title{font-size:clamp(27px,7.4vw,34px)}
  .art-body{padding-left:24px;padding-right:24px}
  .art-body figure.wide{width:100vw}
}
/* phones: fixed sizes (no vw) so the wordmark/titles can never overflow the masthead */
@media(max-width:480px){
  .masthead{padding:22px 18px}
  .wordmark{font-size:16px;letter-spacing:.02em}
  .laune-title{font-size:25px}
  .art-title{font-size:26px}
  .cat-cover h1{font-size:30px;line-height:1.06}
  /* long French words (confidentialité, citadelle…) must wrap, never clip */
  .wordmark,.laune-title,.art-title,.cat-cover h1{overflow-wrap:break-word}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important}
  [data-reveal],.lline{opacity:1 !important;transform:none !important;clip-path:none !important}
  html{scroll-behavior:auto}
  .laune-media img,.art-hero img{position:absolute;inset:0;height:100%}
}
