/* ============================================================
   LTRG — Editorial Premium Magazine
   Crème · Encre · Brique · Serif chic · Asymétrique
   ============================================================ */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg,video{display:block;max-width:100%;height:auto}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
a{color:inherit;text-decoration:none}
input,textarea,select{font:inherit;color:inherit}
ul,ol{list-style:none}

/* ---------- TOKENS ---------- */
:root{
  --cream:   #F6F1E7;
  --paper:   #FFFFFF;
  --sand:    #EDE6D5;
  --ink:     #0F0E0C;
  --ink-2:   #4A4641;
  --ink-3:   #8A8580;
  --rule:    rgba(15,14,12,.14);
  --rule-2:  rgba(15,14,12,.28);
  --brick:   #C8421C;
  --brick-2: #A8350F;
  --gold:    #A88B3D;
  --olive:   #6B6740;
  --green:   #3E6B3A;

  --serif: "Fraunces", "Times New Roman", Georgia, serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;

  --max:   1320px;
  --pad:   28px;
  --r:     2px;
  --r-md:  6px;
}

/* ---------- BASE ---------- */
html,body{background:var(--cream);color:var(--ink);font-family:var(--sans);font-size:16px}
::selection{background:var(--ink);color:var(--cream)}

/* ---------- LAYOUT WRAPPERS ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.spread{padding:110px 0;position:relative}
.spread + .spread{border-top:1px solid var(--rule)}
.spread--cover{padding:80px 0 100px}
.spread--quiet{padding:80px 0}

@media(max-width:880px){
  .spread{padding:72px 0}
  .spread--cover{padding:48px 0 64px}
}

/* ---------- TYPOGRAPHY ---------- */
.kicker{
  font-family:var(--sans);
  font-size:12px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--brick);display:inline-flex;align-items:center;gap:14px;
  margin-bottom:28px;
}
.kicker::before{
  content:"";display:inline-block;width:36px;height:1px;background:var(--brick);
}

.roman{
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--ink-3);
  display:block;margin-bottom:18px;
  font-feature-settings:"liga","kern";
}

h1,h2,h3,h4{
  font-family:var(--serif);font-weight:400;
  color:var(--ink);line-height:1.05;letter-spacing:-.015em;
  font-feature-settings:"liga","kern","ss01";
}
h1{font-size:clamp(48px,7vw,108px);font-weight:300;line-height:.98}
h1 em{font-style:italic;font-weight:300;color:var(--brick)}
h2{font-size:clamp(32px,4.4vw,56px);font-weight:400}
h2 em{font-style:italic;font-weight:400;color:var(--brick)}
h3{font-size:clamp(22px,2.3vw,30px);font-weight:500}
h4{font-size:20px;font-weight:500}

p{color:var(--ink-2);font-size:17px;line-height:1.65;max-width:64ch}
.lede{font-size:clamp(19px,1.9vw,24px);color:var(--ink-2);line-height:1.45;max-width:54ch;font-family:var(--sans);font-weight:400}
.caption{font-family:var(--serif);font-style:italic;color:var(--ink-3);font-size:14px;line-height:1.5}

/* drop cap pour ledes éditoriales */
.dropcap::first-letter{
  font-family:var(--serif);
  font-size:5em;line-height:.85;
  float:left;margin:8px 14px 0 -2px;
  color:var(--brick);font-weight:400;
}

.smallcaps{font-variant:small-caps;letter-spacing:.06em}

/* underline éditorial */
a.read{color:var(--ink);background-image:linear-gradient(var(--brick),var(--brick));background-position:0 100%;background-repeat:no-repeat;background-size:100% 1px;padding-bottom:2px;transition:background-size .3s ease}
a.read:hover{background-size:100% 2px}

/* ---------- BUTTONS / CTA ---------- */
.cta{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 26px;font-size:15px;font-weight:500;
  border-radius:100px;letter-spacing:-.005em;
  transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease;
  white-space:nowrap;
}
.cta--ink{background:var(--ink);color:var(--cream)}
.cta--ink:hover{background:var(--brick);transform:translateY(-1px)}
.cta--brick{background:var(--brick);color:var(--cream)}
.cta--brick:hover{background:var(--brick-2)}
.cta--outline{border:1px solid var(--ink);color:var(--ink)}
.cta--outline:hover{background:var(--ink);color:var(--cream)}
.cta--ghost{border:1px solid var(--rule-2);color:var(--ink-2)}
.cta--ghost:hover{border-color:var(--ink);color:var(--ink)}
.cta--sm{padding:10px 18px;font-size:13px}
.cta--block{width:100%;justify-content:center}
.cta__arr{transition:transform .25s ease}
.cta:hover .cta__arr{transform:translateX(4px)}

/* ---------- MASTHEAD ---------- */
.masthead{
  background:var(--cream);
  border-bottom:1px solid var(--rule);
  position:sticky;top:0;z-index:50;
}
.masthead__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;height:88px}
.masthead__logo{display:flex;align-items:baseline;gap:10px;color:var(--ink)}
.masthead__logo .mark{font-family:var(--serif);font-style:italic;font-size:32px;font-weight:300;letter-spacing:-.04em;line-height:1}
.masthead__logo .mark em{color:var(--brick);font-style:italic;font-weight:400}
.masthead__logo small{font-family:var(--sans);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.masthead__nav{display:flex;justify-content:center;gap:30px}
.masthead__nav a{font-size:14px;color:var(--ink-2);font-weight:500;position:relative;padding:6px 0;transition:color .2s}
.masthead__nav a:hover{color:var(--ink)}
.masthead__nav a.nav__item--current{color:var(--ink)}
.masthead__nav a.nav__item--current::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:6px;background:var(--brick);clip-path:polygon(0 0,100% 0,90% 100%,10% 100%);opacity:.4}
.masthead__actions{display:flex;align-items:center;gap:14px}
.masthead__plan{position:relative;padding:10px;border:1px solid var(--rule-2);border-radius:100px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);transition:border-color .2s,color .2s}
.masthead__plan:hover{border-color:var(--ink);color:var(--ink)}
.masthead__plan-count{background:var(--brick);color:var(--cream);font-size:11px;font-weight:600;border-radius:100px;padding:2px 7px}
.masthead__menu{display:none;padding:8px}
@media(max-width:920px){
  .masthead__inner{grid-template-columns:auto 1fr auto;height:72px;gap:16px}
  .masthead__nav{display:none;position:absolute;top:72px;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--rule);flex-direction:column;align-items:stretch;padding:8px 0;gap:0}
  .masthead__nav.is-open{display:flex}
  .masthead__nav a{padding:18px 28px;border-bottom:1px solid var(--rule);font-size:16px}
  .masthead__nav a:last-child{border-bottom:0}
  .masthead__menu{display:flex}
}

/* ---------- COVER (hero) ---------- */
.cover{position:relative;overflow:hidden}
.cover__rule{height:1px;background:var(--ink);margin:0 0 50px;position:relative}
.cover__rule::before,.cover__rule::after{content:"";position:absolute;top:-3px;width:7px;height:7px;background:var(--brick);border-radius:50%}
.cover__rule::before{left:0}
.cover__rule::after{right:0}
.cover__date{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3);display:flex;justify-content:space-between;margin-bottom:8px}
.cover__title{margin-bottom:36px;max-width:18ch}
.cover__lede{max-width:48ch;margin-bottom:48px;font-size:21px;color:var(--ink-2);line-height:1.5}
.cover__actions{display:flex;flex-wrap:wrap;gap:16px}

/* ---------- MARQUEE ---------- */
.marquee{
  overflow:hidden;background:var(--ink);color:var(--cream);
  padding:18px 0;font-family:var(--serif);font-style:italic;font-size:22px;
  position:relative;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
}
.marquee__inner{
  display:flex;gap:60px;white-space:nowrap;width:max-content;
  animation:scroll 38s linear infinite;
}
.marquee span{display:inline-flex;align-items:center;gap:60px}
.marquee span::after{content:"◆";color:var(--brick);font-style:normal;font-size:18px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- COLUMNS ---------- */
.cols{display:grid;gap:48px}
.cols--2{grid-template-columns:repeat(2,1fr)}
.cols--3{grid-template-columns:repeat(3,1fr)}
.cols--4{grid-template-columns:repeat(4,1fr)}
.cols--7-5{grid-template-columns:7fr 5fr}
.cols--5-7{grid-template-columns:5fr 7fr}
.cols--editorial{grid-template-columns:1fr 2fr;gap:80px}
@media(max-width:880px){
  .cols--2,.cols--3,.cols--4,.cols--7-5,.cols--5-7,.cols--editorial{grid-template-columns:1fr;gap:40px}
}

/* ---------- TILES ---------- */
.tile{
  background:var(--paper);border:1px solid var(--rule);
  padding:36px;border-radius:var(--r-md);
  transition:transform .3s ease,box-shadow .3s ease;
}
.tile:hover{transform:translateY(-2px);box-shadow:0 18px 40px -28px rgba(15,14,12,.3)}
.tile__roman{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--brick);margin-bottom:18px;display:block}
.tile h3{margin-bottom:14px}
.tile p{font-size:15px}

/* ---------- INVENTORY CARD (formats) ---------- */
.fmt{
  background:var(--paper);border:1px solid var(--rule);
  border-radius:var(--r-md);padding:0;overflow:hidden;
  display:flex;flex-direction:column;position:relative;
  transition:transform .3s ease,border-color .3s ease;
}
.fmt:hover{transform:translateY(-3px);border-color:var(--ink)}
.fmt__head{padding:28px 28px 0;border-bottom:1px solid var(--rule);padding-bottom:24px}
.fmt__kick{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.fmt__name{font-family:var(--serif);font-size:26px;line-height:1.1;color:var(--ink);font-weight:500}
.fmt__body{padding:24px 28px;flex:1;display:flex;flex-direction:column;gap:18px}
.fmt__lede{font-size:14px;color:var(--ink-2);line-height:1.55}
.fmt__rate{font-family:var(--serif);font-size:34px;color:var(--ink);font-weight:400;letter-spacing:-.02em;margin-top:auto}
.fmt__rate small{font-family:var(--sans);font-size:13px;color:var(--ink-3);margin-left:6px;font-weight:400}
.fmt__actions{padding:0 28px 28px;display:flex;gap:10px}
.fmt__badge{
  position:absolute;top:24px;right:24px;
  font-family:var(--serif);font-style:italic;font-size:12px;
  background:var(--brick);color:var(--cream);
  padding:5px 12px;border-radius:100px;
}

/* ---------- LISTS ---------- */
.bullets{display:flex;flex-direction:column;gap:12px}
.bullets li{
  display:flex;align-items:flex-start;gap:14px;
  font-size:15px;color:var(--ink-2);line-height:1.55;
  padding:6px 0;border-bottom:1px solid var(--rule);
}
.bullets li:last-child{border-bottom:0}
.bullets li::before{
  content:"";flex-shrink:0;width:8px;height:8px;background:var(--brick);
  border-radius:50%;margin-top:9px;
}

/* ---------- PUBLISHERS GRID ---------- */
.pubs{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--r-md);overflow:hidden}
.pub{background:var(--paper);padding:32px;display:flex;flex-direction:column;gap:8px;transition:background .25s}
.pub:hover{background:var(--sand)}
.pub__name{font-family:var(--serif);font-size:24px;color:var(--ink);font-weight:500}
.pub__cat{font-size:13px;color:var(--brick);letter-spacing:.04em;font-weight:500}
.pub__reach{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3);margin-top:6px}
@media(max-width:760px){.pubs{grid-template-columns:1fr}}

/* ---------- FORMS ---------- */
.form{display:flex;flex-direction:column;gap:24px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:700px){.form__row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px;position:relative}
.field label{
  font-family:var(--serif);font-style:italic;font-size:14px;
  color:var(--ink);letter-spacing:0;
}
.field input,.field textarea,.field select{
  background:transparent;
  border:0;border-bottom:1px solid var(--rule-2);
  padding:10px 0 12px;font-size:17px;color:var(--ink);
  font-family:var(--sans);
  transition:border-color .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:0;border-color:var(--brick);
}
.field textarea{resize:vertical;min-height:120px;font-family:var(--sans)}
.field--check{flex-direction:row;align-items:flex-start;gap:12px}
.field--check input{width:auto;margin-top:6px}
.field--check label{font-family:var(--sans);font-style:normal;font-size:14px;color:var(--ink-2);line-height:1.5}

/* ---------- ALERTS ---------- */
.note{padding:16px 20px;border-radius:var(--r-md);font-size:14px;border:1px solid;line-height:1.5}
.note--ok{border-color:var(--green);background:rgba(62,107,58,.08);color:var(--green)}
.note--ko{border-color:var(--brick);background:rgba(200,66,28,.08);color:var(--brick-2)}
.note--info{border-color:var(--rule-2);background:var(--paper);color:var(--ink-2)}

/* ---------- PLAN (PANIER) ---------- */
.plan-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
@media(max-width:920px){.plan-layout{grid-template-columns:1fr}}
.plan-table{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);overflow:hidden}
.plan-row{display:grid;grid-template-columns:1fr auto auto;gap:32px;align-items:center;padding:28px 32px;border-bottom:1px solid var(--rule)}
.plan-row:last-child{border-bottom:0}
.plan-row__title{font-family:var(--serif);font-size:21px;color:var(--ink);margin-bottom:4px}
.plan-row__meta{font-size:13px;color:var(--ink-3)}
.plan-row__remove{color:var(--ink-3);font-size:13px;text-decoration:underline;text-underline-offset:3px;margin-top:6px;display:inline-block}
.plan-row__remove:hover{color:var(--brick)}
.plan-qty{display:flex;align-items:center;border:1px solid var(--rule-2);border-radius:100px;overflow:hidden}
.plan-qty button{padding:8px 14px;color:var(--ink-2);transition:color .2s,background .2s}
.plan-qty button:hover{color:var(--brick);background:var(--sand)}
.plan-qty input{width:44px;text-align:center;background:transparent;border:0;font-family:var(--serif);color:var(--ink);font-size:16px}
.plan-row__sum{font-family:var(--serif);font-size:22px;color:var(--ink);text-align:right;min-width:140px}

.plan-aside{background:var(--ink);color:var(--cream);border-radius:var(--r-md);padding:36px;position:sticky;top:108px}
.plan-aside h3{color:var(--cream);font-family:var(--serif);margin-bottom:24px}
.plan-aside__row{display:flex;justify-content:space-between;padding:14px 0;font-size:15px;color:rgba(246,241,231,.7);border-bottom:1px solid rgba(246,241,231,.12)}
.plan-aside__row:last-child{border-bottom:0}
.plan-aside__row--total{font-family:var(--serif);font-size:24px;color:var(--cream);padding-top:24px;border-top:1px solid rgba(246,241,231,.3)}
.plan-aside .cta{margin-top:24px}

/* ---------- COLOPHON (FOOTER) ---------- */
.colophon{background:var(--ink);color:var(--cream);padding:96px 0 36px;margin-top:80px;border-top:6px solid var(--brick)}
.colophon a{color:rgba(246,241,231,.75);transition:color .2s}
.colophon a:hover{color:var(--brick)}
.colophon__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;margin-bottom:64px}
@media(max-width:880px){.colophon__grid{grid-template-columns:1fr 1fr;gap:40px}}
.colophon__logo{font-family:var(--serif);font-style:italic;font-size:36px;color:var(--cream);margin-bottom:18px;font-weight:300;letter-spacing:-.04em}
.colophon__logo em{color:var(--brick);font-weight:400}
.colophon__body{font-size:14px;color:rgba(246,241,231,.6);line-height:1.7;max-width:36ch;margin-bottom:24px}
.colophon h5{font-family:var(--serif);font-style:italic;color:var(--cream);font-size:17px;margin-bottom:20px;font-weight:400}
.colophon ul{display:flex;flex-direction:column;gap:10px}
.colophon ul a{font-size:14px}
.colophon__contact p{color:rgba(246,241,231,.7);font-size:14px;margin-bottom:6px;max-width:none}
.colophon__bottom{border-top:1px solid rgba(246,241,231,.18);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-family:var(--serif);font-style:italic;font-size:13px;color:rgba(246,241,231,.5)}

/* ---------- COOKIE BANNER ---------- */
.consent{
  position:fixed;bottom:24px;left:24px;right:24px;max-width:560px;margin:0 auto;
  background:var(--paper);border:1px solid var(--rule-2);
  border-radius:var(--r-md);padding:24px;display:none;z-index:100;
  box-shadow:0 28px 60px -20px rgba(15,14,12,.25);
}
.consent.is-open{display:block;animation:rise .4s ease}
.consent p{font-size:14px;margin-bottom:20px;color:var(--ink-2)}
.consent__row{display:flex;gap:10px;flex-wrap:wrap}
@keyframes rise{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ---------- LEGAL ARTICLES ---------- */
.legal-article{max-width:780px;margin:0 auto}
.legal-article h2{font-family:var(--serif);font-size:28px;margin:48px 0 18px;font-weight:500}
.legal-article h3{font-family:var(--serif);font-size:21px;margin:32px 0 12px;color:var(--ink);font-weight:500;font-style:italic}
.legal-article p,.legal-article li{font-size:16px;line-height:1.75;margin-bottom:14px;color:var(--ink-2)}
.legal-article ul{padding-left:24px;list-style:disc;margin-bottom:14px}
.legal-article strong{color:var(--ink);font-weight:600}
.legal-article a{color:var(--brick);text-decoration:underline;text-underline-offset:2px}
.legal-meta{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3);margin-bottom:48px;padding-bottom:24px;border-bottom:1px solid var(--rule)}
.legal-article table{margin:20px 0;border:1px solid var(--rule);border-radius:var(--r-md);overflow:hidden}
.legal-article table th,.legal-article table td{padding:12px 16px;text-align:left}
.legal-article table thead{background:var(--sand)}
.legal-article table th{font-family:var(--serif);font-style:italic;font-weight:500;font-size:14px;color:var(--ink)}
.legal-article table td{border-top:1px solid var(--rule);font-size:14px}

/* ---------- UTILS ---------- */
.center{text-align:center}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mt-32{margin-top:32px}.mt-48{margin-top:48px}.mt-64{margin-top:64px}
.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.mb-32{margin-bottom:32px}.mb-48{margin-bottom:48px}
.row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}

/* Section title (alternative to h2) */
.title-block{display:flex;align-items:baseline;justify-content:space-between;gap:32px;margin-bottom:56px;padding-bottom:24px;border-bottom:1px solid var(--rule)}
.title-block h2{max-width:18ch}
.title-block__meta{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-3);white-space:nowrap}
@media(max-width:760px){.title-block{flex-direction:column;align-items:flex-start;gap:12px}}

/* Big stat */
.stat{display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--ink);padding-top:24px}
.stat b{font-family:var(--serif);font-size:64px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-.03em}
.stat span{font-size:13px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;font-weight:500}

/* ---------- Page entrance ---------- */
.fade-in{animation:fade .8s ease both}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
