/* ===========================================================
   WE AFIRM — architecture : MAGAZINE / REVUE
   Masthead, une éditoriale, colonnes, lettrines, dossier
   =========================================================== */
:root{
  --paper:#FBF6EC;
  --paper-2:#F3E9D6;
  --ink:#211D17;
  --ink-soft:#544c40;
  --coral:#D9402C;
  --ocean:#0F6E6A;
  --rule:#211D17;
  --line:#d8cbb2;
  --muted:#7a7060;
  --maxw:1220px; --measure:680px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.015em}
h1{font-size:clamp(2.8rem,7vw,6rem)}
h2{font-size:clamp(2rem,4.5vw,3.4rem)}
h3{font-size:1.5rem}
p{margin-bottom:1.1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.kicker{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;color:var(--coral)}
.rule{border:0;border-top:2px solid var(--rule)}
.rule-thin{border:0;border-top:1px solid var(--line)}
.muted{color:var(--muted)}

/* ---------- MASTHEAD ---------- */
.masthead{border-bottom:3px double var(--rule);background:var(--paper)}
.masthead .top{display:flex;justify-content:space-between;align-items:center;padding:10px 28px;max-width:var(--maxw);margin:0 auto;font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}
.masthead .title-row{text-align:center;padding:14px 28px 18px}
.masthead .logotype{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,6vw,4rem);letter-spacing:-.02em;line-height:.9}
.masthead .logotype span{color:var(--coral)}
.masthead .sub{font-family:var(--sans);text-transform:uppercase;letter-spacing:.3em;font-size:.7rem;color:var(--muted);margin-top:8px}
.navbar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;background:rgba(251,246,236,.95);backdrop-filter:blur(8px)}
.navbar .row{display:flex;align-items:center;justify-content:center;gap:6px;max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative}
.navbar a{padding:13px 16px;font-family:var(--sans);font-weight:600;font-size:.86rem;text-transform:uppercase;letter-spacing:.08em;border-bottom:3px solid transparent}
.navbar a:hover,.navbar a.active{border-color:var(--coral);color:var(--coral)}
.navbar .burger{display:none;position:absolute;right:20px;top:50%;transform:translateY(-50%);width:42px;height:38px;border:1px solid var(--line);background:transparent;cursor:pointer}
.navbar .burger span{display:block;width:18px;height:2px;background:var(--ink);margin:3px auto}

/* ---------- FEATURE / UNE ---------- */
.feature{padding:54px 0 30px}
.feature .head{max-width:1000px;margin:0 auto;text-align:center}
.feature h1{margin:14px 0}
.feature .lede{font-family:var(--serif);font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:400;font-style:italic;color:var(--ink-soft);max-width:46ch;margin:0 auto}
.feature .byline{font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin-top:18px}
.bleed{margin-top:34px}
.bleed figure{position:relative;max-width:1320px;margin:0 auto;padding:0 12px}
.bleed img{width:100%;height:clamp(320px,52vh,560px);object-fit:cover;filter:saturate(.92)}
.bleed figcaption{font-family:var(--sans);font-size:.76rem;color:var(--muted);padding:8px 4px;border-bottom:1px solid var(--line);max-width:1320px;margin:0 auto;text-align:right}

/* ---------- ARTICLE COLUMNS ---------- */
.article{padding:60px 0}
.article .grid{display:grid;grid-template-columns:1fr 2.4fr;gap:48px}
.article .sect-label{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--coral);border-top:2px solid var(--rule);padding-top:10px}
.article .sect-label small{display:block;color:var(--muted);font-weight:500;letter-spacing:.04em;margin-top:6px;text-transform:none;font-size:.86rem}
.cols{column-count:2;column-gap:38px;column-rule:1px solid var(--line)}
.cols p{margin:0 0 1.1rem}
.dropcap p:first-of-type::first-letter{font-family:var(--serif);font-weight:600;float:left;font-size:4.6rem;line-height:.74;padding:6px 10px 0 0;color:var(--coral)}
.h-lead{max-width:var(--measure)}

/* ---------- PULLQUOTE ---------- */
.pull{border-top:2px solid var(--rule);border-bottom:2px solid var(--rule);margin:8px 0;padding:46px 0}
.pull blockquote{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(1.7rem,4vw,3rem);line-height:1.16;text-align:center;max-width:18ch;margin:0 auto}
.pull .src{display:block;font-family:var(--sans);font-style:normal;font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--coral);margin-top:22px;text-align:center}

/* ---------- DOSSIER (numbered editorial entries) ---------- */
.dossier .entry{display:grid;grid-template-columns:120px 1fr;gap:30px;padding:30px 0;border-top:1px solid var(--line)}
.dossier .entry:first-of-type{border-top:2px solid var(--rule)}
.dossier .no{font-family:var(--serif);font-size:3.4rem;line-height:.8;color:var(--coral)}
.dossier .entry h3{font-size:1.7rem;margin-bottom:8px}
.dossier .entry .txt{max-width:60ch}
.dossier .entry p{color:var(--ink-soft);margin:0}

/* ---------- SOMMAIRE / index list ---------- */
.sommaire .it{display:flex;align-items:baseline;gap:14px;padding:16px 0;border-top:1px solid var(--line)}
.sommaire .it:first-child{border-top:2px solid var(--rule)}
.sommaire .no{font-family:var(--sans);font-weight:700;color:var(--coral);width:34px;flex:0 0 auto}
.sommaire .t{font-family:var(--serif);font-size:1.35rem}
.sommaire .lead-dots{flex:1;border-bottom:2px dotted var(--line);transform:translateY(-4px)}
.sommaire .pg{font-family:var(--sans);font-size:.86rem;color:var(--muted)}

/* ---------- GALLERY ---------- */
.gallery{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:14px}
.gallery figure{overflow:hidden}
.gallery figure:first-child{grid-row:1/3}
.gallery img{width:100%;height:100%;object-fit:cover;min-height:180px;filter:saturate(.92)}

/* ---------- aside note ---------- */
.note{background:var(--paper-2);border-left:4px solid var(--coral);padding:22px 24px;font-size:.96rem}
.note h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--coral);margin-bottom:8px}

/* ---------- forms / contact ---------- */
.measure{max-width:var(--measure)}
.field{margin-bottom:15px}
.field label{display:block;font-family:var(--sans);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:13px 14px;border:1px solid var(--rule);background:var(--paper);font:inherit;border-radius:0}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--coral);outline-offset:-2px}
.field textarea{min-height:130px;resize:vertical}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;padding:15px 26px;border:2px solid var(--rule);background:var(--ink);color:var(--paper);cursor:pointer;transition:.15s}
.btn:hover{background:var(--coral);border-color:var(--coral)}
.btn-out{background:transparent;color:var(--ink)}.btn-out:hover{background:var(--ink);color:var(--paper)}
.consent{display:flex;gap:9px;font-size:.82rem;color:var(--muted)}.consent input{width:auto;margin-top:4px}
.map{border:1px solid var(--rule);width:100%;height:300px;filter:grayscale(.3)}

/* legal ledger */
.ledger{border-top:2px solid var(--rule)}
.ledger .r{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.ledger .r span:first-child{color:var(--muted);font-family:var(--sans);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem}
.ledger .r span:last-child{font-weight:600;text-align:right}

/* prose */
.prose{max-width:var(--measure)}
.prose h2{font-size:1.8rem;margin:28px 0 10px}
.prose p,.prose li{color:var(--ink-soft)}
.prose ul{padding-left:18px;margin:8px 0;display:grid;gap:6px}

/* ---------- COLOPHON ---------- */
.colophon{border-top:3px double var(--rule);margin-top:40px;padding:46px 0 26px}
.colophon .grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:30px}
.colophon .logotype{font-family:var(--serif);font-size:2rem}.colophon .logotype span{color:var(--coral)}
.colophon h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--muted);margin-bottom:12px}
.colophon ul{list-style:none;display:grid;gap:7px}.colophon a,.colophon li{font-size:.9rem;color:var(--ink-soft)}.colophon a:hover{color:var(--coral)}
.colophon .end{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:34px;padding-top:16px;border-top:1px solid var(--line);font-size:.8rem;color:var(--muted)}

.section-pad{padding:60px 0}
.reveal{opacity:0;transform:translateY(16px);transition:.6s}.reveal.in{opacity:1;transform:none}

@media(max-width:860px){
  .article .grid{grid-template-columns:1fr;gap:22px}
  .cols{column-count:1}
  .gallery{grid-template-columns:1fr 1fr}.gallery figure:first-child{grid-row:auto;grid-column:1/3}
  .colophon .grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .navbar .row{justify-content:flex-start}
  .navbar a{display:none}
  .navbar.open a{display:block;width:100%;text-align:left;border-bottom:1px solid var(--line)}
  .navbar.open .row{flex-direction:column;align-items:stretch;padding-bottom:8px}
  .navbar .burger{display:block}
  .dossier .entry{grid-template-columns:1fr;gap:6px}
  .gallery{grid-template-columns:1fr}.gallery figure:first-child{grid-column:auto}
  .colophon .grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}.reveal{opacity:1;transform:none}}

/* emblème dans le masthead */
.masthead .title-row .seal{display:block;width:50px;height:50px;margin:0 auto 6px}
.colophon .seal{width:40px;height:40px;margin-bottom:8px}
