/* ════════════════════════════════════════════════════════════════════
   CARO — Caroline Gross, Biographe familiale
   Direction artistique : éditoriale, chaleureuse & contemporaine.
   Palette « papier & lumière du Berry » : ivoire, or patiné, terracotta.
   ════════════════════════════════════════════════════════════════════ */

:root{
    --ivory:#FCF8EF;
    --cream:#F4EBDA;
    --sand:#EADFC9;
    --paper:#FFFFFF;
    --ink:#2c2218;
    --ink-soft:#62584a;
    --ink-faint:#978c77;
    --gold:#B5894C;
    --gold-light:#d9b67f;
    --gold-deep:#8a6533;
    --terra:#BD6A4A;
    --terra-deep:#9d5236;
    --cocoa:#3a2b21;
    --cocoa-2:#281c14;
    --line:rgba(44,34,24,.13);
    --shadow:0 28px 64px rgba(74,52,24,.18);
    --shadow-soft:0 14px 38px rgba(74,52,24,.10);
    --serif:'Cormorant Garamond',Georgia,serif;
    --body:'EB Garamond',Georgia,serif;
    --ui:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
    --maxw:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:var(--body);font-size:19px;line-height:1.75;color:var(--ink);background:var(--ivory);-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100%}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 30px}
.narrow{max-width:820px}
.center{text-align:center}

/* ── Boutons ──────────────────────────────────────────── */
.btn{display:inline-block;font-family:var(--ui);font-size:13.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
    padding:16px 34px;border-radius:40px;cursor:pointer;border:1.5px solid transparent;
    transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, background .35s, color .35s, border-color .35s}
.btn--gold{background:var(--gold);color:#fff;box-shadow:0 12px 28px rgba(181,137,76,.34)}
.btn--gold:hover{transform:translateY(-3px);box-shadow:0 20px 40px rgba(181,137,76,.46);background:var(--gold-deep)}
.btn--outline{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn--outline:hover{background:var(--ink);color:#fff;transform:translateY(-3px)}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-3px)}
.btn--light{background:var(--ivory);color:var(--ink)}
.btn--light:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(0,0,0,.18)}
.btn--lg{padding:18px 44px;font-size:14.5px}

/* ── Bouton téléphone (cliquable, moderne) ─────────────── */
.tel-group{display:flex;flex-wrap:wrap;gap:12px}
.tel-btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--ui);font-weight:600;font-size:15.5px;letter-spacing:.01em;
    color:#fff;padding:7px 22px 7px 7px;border-radius:40px;
    background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
    box-shadow:0 10px 24px rgba(181,137,76,.32);transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s}
.tel-btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(181,137,76,.46);color:#fff}
.tel-btn__ic{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;
    background:rgba(255,255,255,.22);flex:0 0 auto}
.tel-btn__ic svg{display:block}
.tel-btn__num{white-space:nowrap}
.footer__mail{align-self:flex-start}

/* ── Apparition au défilement ─────────────────────────── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}html{scroll-behavior:auto}}

/* ── Sections communes ────────────────────────────────── */
.section{padding:112px 0;position:relative}
.section--dark{background:radial-gradient(130% 150% at 50% 0%, var(--cocoa), var(--cocoa-2));color:#f2e9d9}
.section--dark .section__title{color:#fff}
.section--dark .prose p{color:rgba(242,233,217,.84)}
.eyebrow{display:inline-block;font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:18px}
.eyebrow--light{color:var(--gold-light)}
.eyebrow--terra{color:var(--terra-deep)}
.section__title{font-family:var(--serif);font-weight:600;font-size:clamp(34px,5vw,54px);line-height:1.04;margin:0}
.section__title--xl{font-size:clamp(40px,6vw,70px)}
.section__head{margin-bottom:58px}
.section__intro{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,27px);color:var(--ink-soft);max-width:680px;margin:22px auto 0}
.prose p{margin:0 0 22px;color:var(--ink-soft)}
.prose p:last-child{margin-bottom:0}
.prose--center{max-width:720px;margin:0 auto}
.prose--lead p:first-child{font-size:1.14em;color:var(--ink)}
.signature{font-family:var(--serif);font-style:italic;font-size:27px;color:var(--gold-deep)!important;margin-top:30px!important}

/* ════════════════ NAVIGATION (claire) ════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;transition:padding .35s, box-shadow .35s, background .35s;
    background:rgba(252,248,239,.85);backdrop-filter:blur(12px);border-bottom:1px solid rgba(44,34,24,.07)}
.nav.is-scrolled{padding:11px 0;background:rgba(252,248,239,.96);box-shadow:0 8px 30px rgba(74,52,24,.10)}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:0 30px;display:flex;align-items:center;justify-content:space-between}
.nav__brand{display:flex;flex-direction:column;line-height:1.04;color:var(--ink)}
.nav__brand-name{font-family:var(--serif);font-size:26px;font-weight:600;letter-spacing:.01em}
.nav__brand-sub{font-family:var(--ui);font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);margin-top:3px}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-family:var(--ui);font-size:13px;font-weight:500;letter-spacing:.06em;color:var(--ink);opacity:.86;position:relative;padding:6px 0;transition:opacity .3s,color .3s}
.nav__links a:hover{opacity:1}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--terra);transition:width .35s}
.nav__links a:not(.nav__cta):hover::after,.nav__links a.is-active:not(.nav__cta)::after{width:100%}
.nav__links a.is-active:not(.nav__cta){opacity:1;color:var(--terra-deep)}
.nav__cta{background:var(--gold);color:#fff!important;padding:10px 22px!important;border-radius:30px;opacity:1!important;transition:background .3s,transform .3s}
.nav__cta:hover{background:var(--gold-deep);transform:translateY(-2px)}
.nav__cta::after{display:none}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ════════════════ HERO ÉDITORIAL ════════════════ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
    background:linear-gradient(165deg, #fdfaf3 0%, var(--cream) 60%, var(--sand) 100%)}
.hero__halo{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;pointer-events:none}
.hero__halo--1{width:520px;height:520px;background:radial-gradient(circle,rgba(217,182,127,.65),transparent 70%);top:-120px;right:-80px}
.hero__halo--2{width:460px;height:460px;background:radial-gradient(circle,rgba(189,106,74,.32),transparent 70%);bottom:-160px;left:-120px}
.hero__inner{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;text-align:center;max-width:860px;margin:0 auto;padding-top:132px;padding-bottom:92px}
.hero__kicker{display:flex;align-items:center;justify-content:center;gap:14px;font-family:var(--ui);font-size:12.5px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--terra-deep);margin:0 0 6px}
.hero__kicker span{width:46px;height:1.5px;background:var(--terra)}
.hero__portrait{margin:26px auto 10px;width:194px;height:194px;border-radius:50%;overflow:hidden;border:4px solid #fff;
    box-shadow:0 0 0 2px var(--gold-light), 0 24px 52px rgba(58,33,12,.26)}
.hero__portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;display:block}
.hero__title{font-family:var(--serif);font-weight:600;font-size:clamp(46px,6.4vw,86px);line-height:1.0;margin:0;letter-spacing:.005em;color:var(--ink)}
.hero__accroche{font-size:clamp(19px,2vw,23px);color:var(--ink-soft);margin:24px auto 0;max-width:560px;line-height:1.7}
.hero__actions{margin-top:36px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.hero__meta{margin:30px 0 0;font-family:var(--ui);font-size:13.5px;color:var(--ink-faint);letter-spacing:.01em}
.hero__meta strong{color:var(--gold-deep);font-size:16px}
/* Mise en scène des couvertures */
.hero__gallery{position:relative;display:flex;justify-content:center;align-items:center;perspective:1400px}
.hero__book{width:212px;flex:0 0 auto;aspect-ratio:1/1.42;border-radius:5px;overflow:hidden;background:var(--cocoa);
    box-shadow:0 30px 60px rgba(58,33,12,.35);transition:transform .6s cubic-bezier(.2,.8,.2,1), box-shadow .6s}
.hero__book img{width:100%;height:100%;object-fit:cover}
.hero__book--1{transform:rotate(-9deg);margin-right:-58px;z-index:1;opacity:.96}
.hero__book--2{z-index:3;transform:translateY(-14px) scale(1.1);box-shadow:0 40px 80px rgba(58,33,12,.42)}
.hero__book--3{transform:rotate(9deg);margin-left:-58px;z-index:1;opacity:.96}
.hero:hover .hero__book--1{transform:rotate(-12deg) translateX(-10px)}
.hero:hover .hero__book--3{transform:rotate(12deg) translateX(10px)}
.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;width:26px;height:42px;border:1.5px solid rgba(44,34,24,.3);border-radius:14px;display:flex;justify-content:center;padding-top:8px}
.hero__scroll span{width:3px;height:8px;background:var(--terra);border-radius:2px;animation:scroll 1.8s infinite}
@keyframes scroll{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(13px)}100%{opacity:0}}

/* ════════════════ ATOUTS ════════════════ */
.args{background:var(--ivory);padding:112px 0}
.args-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px}
.arg{background:var(--paper);border:1px solid rgba(44,34,24,.05);border-radius:18px;padding:42px 34px;
    box-shadow:var(--shadow-soft);transition:transform .4s, box-shadow .4s;position:relative;overflow:hidden}
.arg::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(to right,var(--gold),var(--terra));transform:scaleX(0);transform-origin:left;transition:transform .5s}
.arg:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.arg:hover::before{transform:scaleX(1)}
.arg__num{font-family:var(--serif);font-size:38px;color:var(--terra);display:block;margin-bottom:12px;line-height:1}
.arg__title{font-family:var(--serif);font-size:29px;font-weight:600;margin:0 0 12px;color:var(--ink)}
.arg__text{margin:0;color:var(--ink-soft);font-size:18px;line-height:1.65}
/* Dégradés pastel — une teinte par carte (chic & doux) */
.arg--1{background:linear-gradient(155deg,#fdf6e8 0%,#f4e3c4 100%)}
.arg--1 .arg__num{color:var(--gold-deep)}
.arg--1::before{background:linear-gradient(to right,var(--gold-light),var(--gold))}
.arg--2{background:linear-gradient(155deg,#fcece2 0%,#f3d3bf 100%)}
.arg--2 .arg__num{color:var(--terra-deep)}
.arg--2::before{background:linear-gradient(to right,#e7a98a,var(--terra))}
.arg--3{background:linear-gradient(155deg,#eef1de 0%,#dde4c6 100%)}
.arg--3 .arg__num{color:#6f7a3f}
.arg--3::before{background:linear-gradient(to right,#aab87a,#7f8c4c)}

/* ════════════════ VIDÉO (entièrement visible) ════════════════ */
.video-section{background:linear-gradient(180deg,var(--cream),var(--ivory));padding:104px 0}
.video-stage{max-width:920px;margin:26px auto 0;border-radius:14px;overflow:hidden;background:#000;
    box-shadow:0 44px 90px rgba(58,33,12,.34);border:1px solid rgba(255,255,255,.1);padding:0;position:relative}
.video-stage::after{content:"";position:absolute;inset:0;border-radius:14px;border:1px solid rgba(181,137,76,.4);pointer-events:none}
.video-stage video{width:100%;height:auto;max-height:80vh;display:block;background:#000}
.video-legend{font-family:var(--serif);font-style:italic;font-size:23px;color:var(--ink-soft);margin:26px auto 0;max-width:620px}

/* ════════════════ LIVRES À LA UNE ════════════════ */
.featured{background:var(--ivory);padding:112px 0}
.featured__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:54px;flex-wrap:wrap}
.featured__intro{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-soft);max-width:380px;margin:0}
.vedettes{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-bottom:54px}
.vedette{text-align:center}
.vedette__cover{position:relative;aspect-ratio:1/1.42;border-radius:8px;overflow:hidden;background:var(--cocoa);box-shadow:var(--shadow-soft);transition:transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .5s}
.vedette__cover img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.vedette:hover .vedette__cover{transform:translateY(-8px);box-shadow:var(--shadow)}
.vedette:hover .vedette__cover img{transform:scale(1.06)}
.vedette__veil{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:0 0 24px;background:linear-gradient(to top,rgba(40,28,20,.8),transparent 55%);opacity:0;transition:opacity .4s}
.vedette__veil span{font-family:var(--ui);font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:#fff}
.vedette:hover .vedette__veil{opacity:1}
.vedette__title{font-family:var(--serif);font-size:26px;font-weight:600;margin:20px 0 4px;line-height:1.12}
.vedette__author{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink-faint);margin:0}

/* ════════════════ TÉMOIGNAGES (bande chaude sombre) ════════════════ */
.temoignages{background:radial-gradient(130% 150% at 50% 0%, var(--cocoa), var(--cocoa-2));color:#f2e9d9;padding:112px 0}
.temoignages .section__title{color:#fff}
.temoins{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:28px}
.temoin{margin:0;background:rgba(255,255,255,.035);border:1px solid rgba(217,182,127,.22);border-radius:16px;padding:38px 34px;position:relative}
.temoin__mark{position:absolute;top:8px;left:24px;font-family:var(--serif);font-size:84px;color:rgba(217,182,127,.26);line-height:1}
.temoin__text{font-family:var(--serif);font-style:italic;font-size:21px;line-height:1.55;color:#f5eedf;margin:18px 0 22px;position:relative;z-index:2}
.temoin__by{font-family:var(--ui);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-light);display:flex;flex-direction:column;gap:4px}
.temoin__by span{color:rgba(242,233,217,.5);font-size:13px;letter-spacing:.02em;text-transform:none;font-style:italic;font-family:var(--serif);font-weight:400}

/* ════════════════ BANDE D'APPEL À L'ACTION (colorée) ════════════════ */
.cta-band{position:relative;overflow:hidden;padding:128px 0;color:#fff5e9;
    background:linear-gradient(125deg, var(--terra) 0%, var(--terra-deep) 45%, var(--gold-deep) 100%)}
.cta-band__halo{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);top:-220px;right:-120px;filter:blur(30px)}
.cta-band__quote{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3vw,30px);color:rgba(255,245,233,.9);margin:0 0 14px;position:relative}
.cta-band__title{font-family:var(--serif);font-weight:600;font-size:clamp(34px,5vw,56px);margin:0 0 16px;line-height:1.06;color:#fff;position:relative}
.cta-band__text{font-size:20px;color:rgba(255,245,233,.88);max-width:600px;margin:0 auto 34px;position:relative}

/* ════════════════ APPEL À L'ACTION (pages internes, clair) ════════════════ */
.home-cta{background:var(--cream);padding:116px 0}
.home-cta--slim{padding:90px 0}
.home-cta__quote{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3vw,30px);color:var(--gold-deep);margin:0 0 14px}
.home-cta__title{font-family:var(--serif);font-weight:600;font-size:clamp(32px,5vw,52px);margin:0 0 16px;line-height:1.08}
.home-cta__text{font-size:20px;color:var(--ink-soft);max-width:620px;margin:0 auto 34px}

/* ════════════════ EN-TÊTE DE PAGE (claire) ════════════════ */
.page-head{position:relative;padding:170px 0 80px;overflow:hidden;text-align:center;
    background:linear-gradient(165deg,#fdfaf3,var(--cream) 60%,var(--sand))}
.page-head__bg{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(70px);opacity:.5;
    background:radial-gradient(circle,rgba(217,182,127,.6),transparent 70%);top:-150px;right:-60px}
.page-head__title{font-family:var(--serif);font-weight:600;font-size:clamp(42px,7vw,82px);margin:0;line-height:1.02;color:var(--ink);position:relative}
.page-head__title::after{content:"";display:block;width:64px;height:2px;background:var(--terra);margin:22px auto 0}
.page-head__intro{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,27px);color:var(--ink-soft);max-width:680px;margin:24px auto 0;position:relative}

/* ════════════════ COLLECTION (page livres) ════════════════ */
.collection{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:56px 40px}
.oeuvre{display:block}
.oeuvre__cover{position:relative;aspect-ratio:1/1.42;border-radius:8px;overflow:hidden;background:var(--cocoa);box-shadow:var(--shadow-soft);transition:transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .5s}
.oeuvre__cover img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.oeuvre:hover .oeuvre__cover{transform:translateY(-8px);box-shadow:var(--shadow)}
.oeuvre:hover .oeuvre__cover img{transform:scale(1.06)}
.oeuvre__veil{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:0 0 26px;background:linear-gradient(to top,rgba(40,28,20,.82),transparent 55%);opacity:0;transition:opacity .4s}
.oeuvre__veil span{font-family:var(--ui);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:#fff}
.oeuvre:hover .oeuvre__veil{opacity:1}
.oeuvre__fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 24px;color:#f0e6d2;gap:14px}
.oeuvre__fallback::before{content:"";position:absolute;inset:16px;border:1px solid rgba(240,230,210,.3)}
.oeuvre__fb-line{font-size:18px;color:var(--gold-light);letter-spacing:.3em}
.oeuvre__fb-title{font-family:var(--serif);font-size:30px;line-height:1.12;font-weight:600}
.oeuvre__fb-author{font-family:var(--serif);font-style:italic;font-size:20px;color:rgba(240,230,210,.85)}
.oeuvre__fb-mark{font-family:var(--ui);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(240,230,210,.6);margin-top:6px;line-height:1.6}
.oeuvre__cover--ocre{background:linear-gradient(150deg,#7a5526,#41301a)}
.oeuvre__cover--sepia{background:linear-gradient(150deg,#6a4f3c,#33251c)}
.oeuvre__cover--foret{background:linear-gradient(150deg,#42513b,#222c1f)}
.oeuvre__cover--prune{background:linear-gradient(150deg,#5a3543,#2c1a22)}
.oeuvre__cover--nuit{background:linear-gradient(150deg,#314556,#19232e)}
.oeuvre__cover--ardoise{background:linear-gradient(150deg,#474745,#262626)}
.oeuvre__cover--brique{background:linear-gradient(150deg,#7c4232,#3c1f17)}
.oeuvre__meta{padding:22px 4px 0;text-align:center}
.oeuvre__title{font-family:var(--serif);font-size:28px;font-weight:600;line-height:1.12;margin:0}
.oeuvre__sub{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--terra-deep);margin:8px 0 0}
.oeuvre__author{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink-faint);margin:6px 0 0}

/* ════════════════ DÉTAIL D'UN LIVRE ════════════════ */
.ld-hero{position:relative;padding:150px 0 90px;overflow:hidden;background:linear-gradient(165deg,#fdfaf3,var(--cream) 60%,var(--sand))}
.ld-hero__bg{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(70px);opacity:.5;background:radial-gradient(circle,rgba(217,182,127,.6),transparent 70%);top:-120px;right:-40px}
.ld-hero__inner{position:relative;z-index:3;display:grid;grid-template-columns:300px 1fr;gap:60px;align-items:center}
.ld-hero__cover{aspect-ratio:1/1.42;border-radius:8px;overflow:hidden;box-shadow:0 44px 90px rgba(58,33,12,.34);background:var(--cocoa);position:relative}
.ld-hero__cover img{width:100%;height:100%;object-fit:cover}
.ld-cover-fallback{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;gap:12px;color:#f0e6d2}
.ld-cover-fallback::before{content:"";position:absolute;inset:16px;border:1px solid rgba(240,230,210,.3)}
.ld-cf-title{font-family:var(--serif);font-size:32px;font-weight:600;line-height:1.1}
.ld-cf-author{font-family:var(--serif);font-style:italic;font-size:21px;color:rgba(240,230,210,.85)}
.ld-back{display:inline-block;font-family:var(--ui);font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--terra-deep);margin-bottom:22px}
.ld-hero__sub{font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 12px}
.ld-hero__title{font-family:var(--serif);font-weight:600;font-size:clamp(40px,6vw,74px);line-height:1.0;margin:0;color:var(--ink)}
.ld-hero__author{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3vw,30px);color:var(--ink-soft);margin:14px 0 0}
.ld-hero__signature{font-family:var(--ui);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin:18px 0 0}
.ld-body{background:var(--ivory)}
.ld-block{margin:0 0 54px}
.ld-block:last-child{margin-bottom:0}
.ld-label{display:block;font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--terra-deep);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.ld-extraits p{font-family:var(--serif);font-style:italic;font-size:clamp(21px,2.6vw,27px);line-height:1.5;color:var(--ink);margin:0 0 20px}
.ld-temoignage{background:var(--cream);border-left:3px solid var(--terra);padding:30px 34px;border-radius:0 10px 10px 0}
.ld-temoignage p{font-family:var(--serif);font-style:italic;font-size:21px;color:var(--ink-soft);margin:0 0 14px}
.ld-temoignage p:last-child{margin-bottom:0}
.ld-nav{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ld-nav__inner{display:flex;justify-content:space-between;gap:24px;padding:36px 30px}
.ld-nav__link{display:flex;flex-direction:column;gap:6px;max-width:46%}
.ld-nav__link span{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--terra-deep)}
.ld-nav__link strong{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);transition:color .3s}
.ld-nav__link:hover strong{color:var(--terra-deep)}
.ld-nav__link--next{text-align:right;align-items:flex-end;margin-left:auto}

/* ════════════════ CONTACT ════════════════ */
.contact-layout{display:grid;grid-template-columns:.82fr 1.18fr;gap:54px;align-items:start}
.contact-info__title{font-family:var(--serif);font-size:31px;font-weight:600;margin:0 0 26px}
.contact-line{display:flex;gap:16px;align-items:flex-start;margin-bottom:26px}
.contact-line__ic{font-size:22px;color:var(--terra);flex:0 0 auto;width:30px;text-align:center}
.contact-line__lbl{display:block;font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:4px}
.contact-line__val{display:block;font-family:var(--serif);font-size:22px;color:var(--ink);line-height:1.45}
a.contact-line__val:hover{color:var(--terra-deep)}
.contact-form-wrap{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:44px 42px;box-shadow:var(--shadow-soft)}
.contact-form__title{font-family:var(--serif);font-size:33px;font-weight:600;margin:0 0 24px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cf-field{display:block;margin-bottom:18px}
.cf-field>span{display:block;font-family:var(--ui);font-size:13px;font-weight:600;margin-bottom:8px;color:var(--ink-soft)}
.cf-field input,.cf-field textarea{width:100%;font-family:var(--body);font-size:18px;color:var(--ink);padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fffdf9;transition:border-color .2s, box-shadow .2s}
.cf-field input:focus,.cf-field textarea:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 4px rgba(189,106,74,.12)}
.cf-field textarea{resize:vertical;line-height:1.6}
.cf-note{font-size:14px;color:var(--ink-faint);margin:14px 0 0}
.cf-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact-alert{background:#fbe9e7;color:#b3261e;border:1px solid #f0c4bf;border-radius:12px;padding:14px 18px;margin-bottom:18px;font-size:16px}
.contact-merci{text-align:center;padding:30px 10px}
.contact-merci__ic{font-size:40px;color:var(--terra);display:block;margin-bottom:14px}
.contact-merci h2{font-family:var(--serif);font-size:35px;font-weight:600;margin:0 0 10px}
.contact-merci p{color:var(--ink-soft);margin:0 0 26px}

/* ════════════════ CITATION (a-propos) ════════════════ */
.citation{margin-top:60px}
.citation__text{font-family:var(--serif);font-style:italic;font-size:clamp(26px,4vw,44px);line-height:1.2;color:#fff;margin:0}
.citation__author{font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-light);margin:22px 0 0}
.citation__suite{margin-top:30px}
.citation__suite p{font-family:var(--serif);font-size:23px;color:rgba(242,233,217,.92);margin:0}

/* ════════════════ PIED DE PAGE ════════════════ */
.footer{background:radial-gradient(140% 160% at 50% 0%, var(--cocoa), var(--cocoa-2));color:#ecdfca;padding:74px 0 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:50px}
.footer__name{font-family:var(--serif);font-size:31px;font-weight:600;margin:0}
.footer__sub{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-light);margin:8px 0 0}
.footer__quote{font-family:var(--serif);font-style:italic;font-size:20px;color:rgba(236,223,202,.62);margin:22px 0 0;max-width:340px}
.footer__col{display:flex;flex-direction:column;gap:10px}
.footer__label{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-light);margin-bottom:6px}
.footer__col a{color:rgba(236,223,202,.82);font-size:17px;transition:color .3s}
.footer__col a:hover{color:#fff}
.footer__addr{color:rgba(236,223,202,.6);font-size:16px;line-height:1.5;margin-top:4px}
.footer__bottom{border-top:1px solid rgba(236,223,202,.14);padding:22px 30px;display:flex;justify-content:space-between;align-items:center;max-width:var(--maxw);margin:0 auto;flex-wrap:wrap;gap:10px}
.footer__bottom span{font-family:var(--ui);font-size:13px;color:rgba(236,223,202,.5)}
.footer__admin{font-family:var(--ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(236,223,202,.4);transition:color .3s}
.footer__admin:hover{color:var(--gold-light)}

/* ════════════════ FAISONS CONNAISSANCE (accueil) ════════════════ */
.apercu{background:var(--cream);padding:108px 0}
.apercu__inner{display:grid;grid-template-columns:.82fr 1.18fr;gap:64px;align-items:center}
.apercu__inner--solo{grid-template-columns:1fr;max-width:760px;margin:0 auto;text-align:center}
.apercu__photo{position:relative;justify-self:center;max-width:380px;width:100%}
.apercu__photo img{width:100%;border-radius:14px;box-shadow:var(--shadow);position:relative;z-index:2;display:block}
.apercu__frame{position:absolute;inset:20px -20px -20px 20px;border:2px solid var(--gold);border-radius:14px;z-index:1}
.apercu__badge{position:absolute;left:50%;bottom:-16px;transform:translateX(-50%);z-index:3;background:var(--gold);color:#fff;font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:9px 24px;border-radius:30px;box-shadow:0 12px 26px rgba(181,137,76,.42);white-space:nowrap}
.apercu__lead{font-size:20px;color:var(--ink-soft);line-height:1.72;margin:20px 0 0}
.apercu__sign{font-family:var(--serif);font-style:italic;font-size:25px;color:var(--gold-deep);margin:16px 0 26px}

/* ════════════════ BIOGRAPHIE (page Mon histoire) ════════════════ */
.bio{display:grid;grid-template-columns:.8fr 1.2fr;gap:60px;align-items:start;max-width:1040px;margin:0 auto}
.bio--solo{grid-template-columns:1fr;max-width:820px}
.bio__photo{position:relative;max-width:360px;width:100%;justify-self:center;position:sticky;top:110px}
.bio__photo img{width:100%;border-radius:14px;box-shadow:var(--shadow);position:relative;z-index:2;display:block}
.bio__frame{position:absolute;inset:20px -20px -20px 20px;border:2px solid var(--terra);border-radius:14px;z-index:1}

/* ════════════════ RESPONSIVE ════════════════ */

/* ── Tablette / petit portable (≤ 980px) ───────────────── */
@media (max-width:980px){
    .hero{min-height:auto}
    .hero__inner{gap:0;text-align:center;padding-top:120px;padding-bottom:64px}
    .hero__kicker{justify-content:center}
    .hero__accroche{margin-left:auto;margin-right:auto}
    .hero__actions{justify-content:center}
    .hero__scroll{display:none}
    .ld-hero__inner{grid-template-columns:230px 1fr;gap:40px}
    .contact-layout{grid-template-columns:1fr;gap:40px}
    .apercu__inner{grid-template-columns:1fr;gap:48px;text-align:center;justify-items:center}
    .apercu__inner .eyebrow{margin-top:0}
    .apercu__photo{margin:0 auto}
    .bio{grid-template-columns:1fr;gap:44px}
    .bio__photo{position:static;margin:0 auto}
    .footer__grid{grid-template-columns:1fr 1fr;gap:34px}
}

/* ── Mobile (≤ 760px) ──────────────────────────────────── */
@media (max-width:760px){
    body{font-size:17.5px}
    .container,.nav__inner{padding-left:22px;padding-right:22px}

    /* Espacements verticaux harmonisés (plus d'espaces vides) */
    .section,.args,.video-section,.featured,.temoignages,.apercu,.home-cta{padding:66px 0}
    .cta-band{padding:78px 0}
    .section__head{margin-bottom:36px}
    .video-stage{margin-top:22px}
    .video-legend{margin-top:20px;font-size:20px}

    /* Navigation mobile : menu plein écran */
    .nav__links{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:82%;max-width:330px;background:var(--cocoa);
        flex-direction:column;justify-content:center;gap:24px;transform:translateX(100%);
        transition:transform .45s cubic-bezier(.2,.8,.2,1);padding:40px;z-index:110}
    .nav__links.is-open{transform:none}
    .nav__links a{color:#fff;font-size:18px;opacity:.92}
    .nav__links a:not(.nav__cta)::after{display:none}
    .nav__links a.is-active:not(.nav__cta){color:var(--gold-light)}
    .nav__cta{margin-top:6px}
    .nav__burger{display:flex;z-index:120}
    .nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
    .nav__burger.is-open span:nth-child(2){opacity:0}
    .nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

    /* Hero : portrait + actions */
    .hero__portrait{width:158px;height:158px;margin:22px auto 8px}
    .hero__actions{flex-direction:column;align-items:stretch;width:100%;max-width:340px}
    .hero__actions .btn{width:100%}

    /* Toutes les grilles repassent en 1 colonne */
    .args-grid,.vedettes,.temoins,.collection{grid-template-columns:1fr;gap:24px}
    .vedettes{max-width:340px;margin-left:auto;margin-right:auto}
    .collection{max-width:360px;margin-left:auto;margin-right:auto}
    .featured__head{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:34px}
    .featured__intro{max-width:none}

    /* Cartes & blocs : padding réduit */
    .arg{padding:32px 26px}
    .temoin{padding:30px 26px}
    .contact-form-wrap{padding:30px 22px}
    .cf-row{grid-template-columns:1fr;gap:0}

    /* Photos encadrées : cadre maintenu dans l'écran */
    .apercu__photo,.bio__photo{max-width:280px}
    .apercu__frame,.bio__frame{inset:14px -14px -14px 14px}
    .apercu__lead{font-size:18px}

    /* En-têtes de pages internes (moins d'espace sous la nav) */
    .page-head{padding:118px 0 56px}
    .home-cta--slim{padding:60px 0}

    /* Détail livre */
    .ld-hero{padding:118px 0 64px}
    .ld-hero__inner{grid-template-columns:1fr;justify-items:center;text-align:center;gap:30px}
    .ld-hero__cover{width:210px}
    .ld-block{margin-bottom:40px}
    .ld-temoignage{padding:24px 24px}
    .ld-nav__inner{flex-direction:column;gap:18px;padding:30px 22px}
    .ld-nav__link,.ld-nav__link--next{max-width:none;text-align:left;align-items:flex-start;margin-left:0}

    /* Pied de page */
    .footer{padding-top:58px}
    .footer__grid{grid-template-columns:1fr;gap:28px}
    .footer__quote{max-width:none}
    .footer__bottom{flex-direction:column;text-align:center;gap:8px;padding:20px 22px}
}

/* ── Petit mobile (≤ 430px) ────────────────────────────── */
@media (max-width:430px){
    .container,.nav__inner{padding-left:18px;padding-right:18px}
    .section,.args,.video-section,.featured,.temoignages,.apercu,.home-cta{padding:54px 0}
    .hero__inner{padding-top:112px;padding-bottom:48px}
    .hero__portrait{width:132px;height:132px}
    .nav__brand-name{font-size:22px}
    .nav__brand-sub{font-size:8.5px;letter-spacing:.24em}
    .btn{padding:14px 26px;font-size:12.5px}
    .btn--lg{padding:15px 30px;font-size:13px}
    .arg{padding:28px 22px}
    .temoin{padding:26px 22px}
    .temoin__text{font-size:19px}
    .apercu__photo,.bio__photo{max-width:240px}
    .video-legend{font-size:18px}
    .contact-line__val{font-size:19px}
}
