/* ===== NERLIYOU — Lady Liyou Blog · MOBILE-FIRST =======================
   Base = mobile. Les @media (min-width) ajoutent les écrans plus larges.
   Fraunces (titres) + Spectral (prose) + Space Grotesk (interface).
   ===================================================================== */
:root{
  --ink:#1C1320; --ink-soft:#4A3A48; --mute:#8A7686;
  --magenta:#E6007E; --magenta-deep:#B00062;
  --blush:#FCE9F2; --blush-2:#F8DDEC; --lightpink:#eccfcf;
  --paper:#FCFAFB; --line:#EAD9E3; --white:#fff;
  --good:#1FA971; --shadow:0 1px 2px rgba(28,19,32,.04),0 8px 30px rgba(176,0,98,.06);
  --shadow-lg:0 20px 60px rgba(28,19,32,.12); --r:18px;
  --display:"Fraunces",Georgia,serif; --prose:"Spectral",Georgia,serif;
  --ui:"Space Grotesk","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--paper);color-scheme:light}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--prose);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 18px}
.ui{font-family:var(--ui)}
::selection{background:var(--magenta);color:#fff}
button{font-family:var(--ui);cursor:pointer}

/* ---- Header (mobile) ------------------------------------------------- */
.site-head{position:sticky;top:0;z-index:60;background:rgba(252,250,251,.92);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
.head-row{display:flex;align-items:center;gap:14px;height:62px}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand img{height:26px;width:auto}
.head-cta{display:none}
.burger{margin-left:auto;background:none;border:0;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.2s;border-radius:2px}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav{display:none}
.nav.open{display:flex;flex-direction:column;position:absolute;top:62px;left:0;right:0;
  background:var(--white);border-bottom:1px solid var(--line);padding:10px;gap:2px;box-shadow:var(--shadow)}
.nav a,.nav .dd>button{font-family:var(--ui);font-size:15px;font-weight:500;color:var(--ink-soft);
  padding:13px 14px;border-radius:10px;width:100%;text-align:left;background:none;border:0;display:flex;align-items:center;gap:8px}
.nav a:hover,.nav a.active{color:var(--magenta);background:var(--blush)}
.dd{position:relative}
.dd>button::after{content:"▾";margin-left:auto;font-size:11px;opacity:.6}
.dd-menu{display:none;flex-direction:column;padding:2px 0 8px 12px}
.dd.open .dd-menu{display:flex}
.dd-menu a{font-size:14px;padding:10px 14px;color:var(--mute)}
.nav-cta{font-family:var(--ui);font-weight:600;color:#fff!important;background:var(--ink);
  border-radius:10px;margin-top:6px;justify-content:center}
.nav-cta:hover{background:var(--magenta)!important}

/* ---- Hero ------------------------------------------------------------ */
.hero{padding:38px 0 18px}
.hero-eyebrow{font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--magenta);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:"";width:26px;height:2px;background:var(--magenta)}
.hero h1{font-family:var(--display);font-weight:340;font-size:clamp(34px,9vw,86px);
  line-height:1;letter-spacing:-.02em;margin:0 0 16px;font-variation-settings:"SOFT" 30,"WONK" 1}
.hero h1 em{font-style:italic;color:var(--magenta);font-variation-settings:"SOFT" 60,"WONK" 1}
.hero-lede{font-size:18px;color:var(--ink-soft);max-width:54ch;margin:0}

/* ---- Featured -------------------------------------------------------- */
.featured{margin:26px 0 0;display:flex;flex-direction:column;background:var(--white);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);cursor:pointer}
.featured-img{min-height:200px;background:var(--blush);position:relative}
.featured-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.featured-body{padding:26px 22px}
.most-read{font-family:var(--ui);font-size:12px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--magenta);display:inline-flex;align-items:center;gap:8px;margin-bottom:14px}
.most-read .dot{width:7px;height:7px;border-radius:50%;background:var(--magenta);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(230,0,126,.45)}70%{box-shadow:0 0 0 9px rgba(230,0,126,0)}100%{box-shadow:0 0 0 0 rgba(230,0,126,0)}}
.featured-body h2{font-family:var(--display);font-weight:380;font-size:clamp(24px,6vw,40px);
  line-height:1.06;letter-spacing:-.015em;margin:0 0 14px}
.featured-body p{color:var(--ink-soft);margin:0 0 18px}
.meta-row{font-family:var(--ui);font-size:13px;color:var(--mute);display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.meta-row b{color:var(--ink);font-weight:600}

/* ---- Subscribe ------------------------------------------------------- */
.subscribe{margin:30px 0;background:linear-gradient(135deg,var(--ink),#3A2438);
  border-radius:var(--r);padding:30px 24px;color:#fff;text-align:center}
.subscribe h3{font-family:var(--display);font-weight:380;font-size:26px;margin:0 0 8px}
.subscribe p{color:#D9C4D0;margin:0 0 20px;font-size:15px}
.sub-form{display:flex;flex-direction:column;gap:10px;max-width:440px;margin:0 auto}
.sub-form input{font-family:var(--ui);font-size:15px;padding:14px 16px;border-radius:11px;border:0;width:100%}
.sub-form button{font-family:var(--ui);font-weight:600;font-size:15px;padding:14px;border-radius:11px;
  border:0;background:var(--magenta);color:#fff;transition:.15s}
.sub-form button:hover{background:var(--magenta-deep)}
.sub-msg{font-family:var(--ui);font-size:13.5px;margin-top:12px;min-height:18px}
.sub-msg.ok{color:#9DEBC8}.sub-msg.err{color:#FFB4C8}

/* ---- Category chips + sort ------------------------------------------ */
.list-head{padding:26px 0 14px}
.cat-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;font-family:var(--ui);margin-bottom:14px}
.cat-bar .label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);font-weight:600;width:100%}
.chip{font-family:var(--ui);font-size:13.5px;font-weight:500;padding:8px 15px;border-radius:999px;
  border:1px solid var(--line);background:var(--white);color:var(--ink-soft);transition:.16s}
.chip:hover{border-color:var(--magenta);color:var(--magenta)}
.chip.active{background:var(--ink);border-color:var(--ink);color:#fff}
.sort-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.section-title{font-family:var(--display);font-size:26px;font-weight:380;letter-spacing:-.01em;margin:0}
.sort-sel{font-family:var(--ui);font-size:14px;font-weight:500;padding:10px 14px;border-radius:11px;
  border:1px solid var(--line);background:var(--white);color:var(--ink)}
.sort-sel:focus{outline:none;border-color:var(--magenta)}

/* ---- Article grid ---------------------------------------------------- */
.grid{display:grid;grid-template-columns:1fr;gap:22px;padding:16px 0 50px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:.22s;cursor:pointer}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blush-2)}
.card-img{aspect-ratio:3/2;background:var(--blush);position:relative;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .card-img img{transform:scale(1.05)}
.card-cat{position:absolute;top:12px;left:12px;font-family:var(--ui);font-size:11px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;padding:6px 11px;border-radius:999px;
  background:rgba(252,250,251,.92);color:var(--magenta);backdrop-filter:blur(4px)}
.card-no-img{background:linear-gradient(135deg,var(--blush),var(--blush-2))}
.card-ph{display:none;position:absolute;inset:0;align-items:center;justify-content:center;
  font-family:var(--display);font-size:54px;color:var(--magenta);opacity:.5}
.card-no-img .card-ph{display:flex}
.card-body{padding:20px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-family:var(--display);font-weight:420;font-size:21px;line-height:1.12;margin:0 0 10px}
.card:hover .card-body h3{color:var(--magenta-deep)}
.card-body p{font-size:15px;color:var(--ink-soft);margin:0 0 16px;line-height:1.5;flex:1}
.card-meta{font-family:var(--ui);font-size:12.5px;color:var(--mute);display:flex;justify-content:space-between;
  align-items:center;border-top:1px solid var(--line);padding-top:13px}
.card-meta .mr{display:inline-flex;align-items:center;gap:12px}
.card-meta .views,.card-meta .likes{display:inline-flex;align-items:center;gap:5px}
.card-meta svg{width:14px;height:14px;opacity:.7}

/* ---- Reader ---------------------------------------------------------- */
.reader{max-width:720px;margin:0 auto;padding:34px 18px 50px}
.reader-back{font-family:var(--ui);font-size:13px;font-weight:600;color:var(--magenta);
  display:inline-flex;gap:7px;align-items:center;margin-bottom:24px}
.reader-cat{font-family:var(--ui);font-size:12px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--magenta);margin-bottom:14px}
.reader h1{font-family:var(--display);font-weight:360;font-size:clamp(30px,7vw,52px);
  line-height:1.06;letter-spacing:-.02em;margin:0 0 18px;font-variation-settings:"SOFT" 40}
.reader-meta{font-family:var(--ui);font-size:13px;color:var(--mute);display:flex;gap:14px;flex-wrap:wrap;
  padding-bottom:22px;margin-bottom:28px;border-bottom:1px solid var(--line)}
.reader-hero{border-radius:var(--r);overflow:hidden;margin:0 0 30px;background:var(--blush)}
.reader-hero img{width:100%;max-height:420px;object-fit:cover}
.prose{font-size:18px;line-height:1.8;color:var(--ink);text-align:justify;hyphens:auto}
.prose p{margin:0 0 1.3em}
.prose h2,.prose h3{font-family:var(--display);font-weight:420;line-height:1.15;margin:1.6em 0 .5em;text-align:left}
.prose h2{font-size:26px}.prose h3{font-size:22px}
.prose a{color:var(--magenta-deep);text-decoration:underline;text-underline-offset:3px}
.prose blockquote{margin:1.4em 0;padding:4px 0 4px 22px;border-left:3px solid var(--magenta);font-style:italic;color:var(--ink-soft);text-align:left}
.prose img{border-radius:12px;margin:1.4em auto}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.3em;text-align:left}
.prose figure{margin:1.4em 0}.prose figcaption{font-family:var(--ui);font-size:13px;color:var(--mute);text-align:center;margin-top:8px}

/* ---- Like bar -------------------------------------------------------- */
.like-bar{display:flex;align-items:center;gap:14px;margin:34px 0;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.like-btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--ui);font-weight:600;font-size:15px;
  padding:12px 22px;border-radius:999px;border:1.5px solid var(--magenta);background:var(--white);color:var(--magenta);transition:.18s}
.like-btn:hover{background:var(--blush)}
.like-btn.liked{background:var(--magenta);color:#fff}
.like-btn svg{width:19px;height:19px}
.like-btn.pop{animation:pop .35s}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.18)}100%{transform:scale(1)}}
.like-bar .hint{font-family:var(--ui);font-size:13.5px;color:var(--mute)}

/* ---- Comments -------------------------------------------------------- */
.comments{max-width:720px;margin:0 auto;padding:0 18px 60px}
.comments h3{font-family:var(--display);font-size:24px;font-weight:400;margin:0 0 20px;display:flex;align-items:baseline;gap:10px}
.comments h3 span{font-family:var(--ui);font-size:13.5px;color:var(--mute);font-weight:500}
.comment{display:flex;gap:12px;padding:18px 0;border-top:1px solid var(--line)}
.comment.reply{margin-left:28px}
.avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--ui);font-weight:700;color:#fff;font-size:15px}
.comment-body .c-head{font-family:var(--ui);font-size:13.5px;margin-bottom:4px}
.comment-body .c-head b{color:var(--ink);font-weight:600}
.comment-body .c-head time{color:var(--mute);margin-left:9px;font-size:12px}
.comment-body p{margin:0;font-size:15.5px;color:var(--ink-soft);line-height:1.55}
/* comment form */
.cform{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:24px 20px;margin:8px 0 30px}
.cform h4{font-family:var(--display);font-weight:420;font-size:20px;margin:0 0 4px}
.cform .note{font-family:var(--ui);font-size:12.5px;color:var(--mute);margin:0 0 18px}
.cfield{margin-bottom:14px}
.cfield label{font-family:var(--ui);font-size:12.5px;font-weight:600;color:var(--ink-soft);display:block;margin-bottom:6px}
.cfield label .req{color:var(--magenta)}
.cfield input,.cfield textarea{font-family:var(--prose);font-size:15.5px;width:100%;padding:12px 14px;
  border:1px solid var(--line);border-radius:11px;background:var(--paper);color:var(--ink)}
.cfield input:focus,.cfield textarea:focus{outline:none;border-color:var(--magenta);background:#fff}
.cfield .err-line{font-family:var(--ui);font-size:12px;color:#D11;margin-top:5px;display:none}
.cfield.invalid input,.cfield.invalid textarea{border-color:#E66}
.cfield.invalid .err-line{display:block}
.cform button{font-family:var(--ui);font-weight:600;font-size:15px;padding:13px 26px;border-radius:11px;border:0;background:var(--ink);color:#fff;transition:.15s}
.cform button:hover{background:var(--magenta)}
.cform-ok{font-family:var(--ui);font-size:14px;color:var(--good);margin-top:12px}

/* ---- Simple pages (gallery / contact / support) --------------------- */
.page{max-width:900px;margin:0 auto;padding:34px 18px 60px}
.page-hero{margin-bottom:30px}
.page-hero .eyebrow{font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--magenta);margin-bottom:12px}
.page-hero h1{font-family:var(--display);font-weight:350;font-size:clamp(32px,8vw,56px);line-height:1.02;margin:0 0 14px;letter-spacing:-.02em}
.page-hero p{font-size:18px;color:var(--ink-soft);max-width:60ch;margin:0}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.gallery a{display:block;aspect-ratio:1;border-radius:14px;overflow:hidden;background:var(--blush)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery a:hover img{transform:scale(1.06)}
.support-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:8px}
.support-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px}
.support-card .ico{font-size:30px;margin-bottom:12px}
.support-card h3{font-family:var(--display);font-weight:420;font-size:22px;margin:0 0 8px}
.support-card p{color:var(--ink-soft);font-size:15.5px;margin:0 0 16px}
.support-card a.btn-out{display:inline-block;font-family:var(--ui);font-weight:600;font-size:14px;
  padding:11px 20px;border-radius:11px;background:var(--magenta-deep);color:#fff}
.lightbox{position:fixed;inset:0;background:rgba(20,12,22,.88);display:none;align-items:center;justify-content:center;z-index:120;padding:20px}
.lightbox.show{display:flex}
.lightbox img{max-width:100%;max-height:90vh;border-radius:12px}
.lightbox button{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.15);border:0;color:#fff;width:42px;height:42px;border-radius:50%;font-size:20px}

/* ---- Footer ---------------------------------------------------------- */
.site-foot{background:var(--ink);color:#E8D9E3;padding:46px 0 28px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:30px}
.foot-brand h4{font-family:var(--display);font-size:28px;font-weight:400;color:#fff;margin:0 0 10px}
.foot-brand p{color:#C3A8B7;max-width:38ch;font-size:15px;margin:0}
.foot-col h5{font-family:var(--ui);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--magenta);margin:0 0 12px;font-weight:600}
.foot-col a{display:block;color:#D9C4D0;font-family:var(--ui);font-size:14.5px;padding:5px 0;transition:.15s}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:22px;font-family:var(--ui);
  font-size:12.5px;color:#9C8090;display:flex;flex-direction:column;gap:8px}
.foot-bottom a{color:var(--magenta)}

/* ---- utils ----------------------------------------------------------- */
.view{display:none}.view.active{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(14px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.empty{text-align:center;padding:50px 18px;color:var(--mute);font-family:var(--ui)}
.toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  font-family:var(--ui);font-size:14px;padding:13px 22px;border-radius:12px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:.3s;z-index:200}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== TABLET (min-width:680px) ====================================== */
@media(min-width:680px){
  body{font-size:18px}
  .wrap{padding:0 28px}
  .grid{grid-template-columns:repeat(2,1fr);gap:26px}
  .gallery{grid-template-columns:repeat(3,1fr);gap:14px}
  .support-grid{grid-template-columns:repeat(3,1fr)}
  .sub-form{flex-direction:row}
  .sub-form input{flex:1}
  .sub-form button{white-space:nowrap;padding:14px 26px}
  .foot-grid{grid-template-columns:1.6fr 1fr 1fr 1fr}
  .foot-bottom{flex-direction:row;justify-content:space-between}
}

/* ===== DESKTOP (min-width:960px) ===================================== */
@media(min-width:960px){
  .head-row{height:74px;gap:24px}
  .brand img{height:32px}
  .burger{display:none}
  .nav{display:flex!important;position:static;flex-direction:row;background:none;border:0;
    box-shadow:none;padding:0;margin-left:auto;gap:4px;align-items:center}
  .nav a,.nav .dd>button{width:auto;font-size:14px;padding:9px 14px;border-radius:999px}
  .dd-menu{position:absolute;top:calc(100% + 6px);left:0;background:var(--white);border:1px solid var(--line);
    border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;min-width:210px;z-index:70}
  .dd:hover .dd-menu{display:flex}
  .dd-menu a{border-radius:9px;padding:10px 14px;font-size:14px}
  .dd-menu a:hover{background:var(--blush);color:var(--magenta)}
  .nav .nav-cta{display:none}
  .head-cta{display:inline-flex;font-family:var(--ui);font-size:14px;font-weight:600;padding:10px 18px;
    border-radius:999px;background:var(--ink);color:#fff;transition:.18s}
  .head-cta:hover{background:var(--magenta)}
  .hero{padding:60px 0 24px}
  .hero h1{max-width:16ch}
  .featured{flex-direction:row;margin-top:34px}
  .featured-img{flex:1.15;min-height:420px}
  .featured-body{flex:1;padding:46px 44px;display:flex;flex-direction:column;justify-content:center}
  .grid{grid-template-columns:repeat(3,1fr);gap:30px}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .subscribe{padding:44px}
  .subscribe h3{font-size:30px}
  .reader,.comments{padding-left:28px;padding-right:28px}
  .prose{font-size:19.5px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}

/* ---- footer : réseaux sociaux + liens légaux ---- */
.foot-social{display:flex;gap:10px}
.foot-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  border-radius:11px;background:rgba(255,255,255,.07);color:#E8D9E3;transition:.18s}
.foot-social a:hover{background:var(--magenta);color:#fff;transform:translateY(-2px)}
.foot-social svg{width:19px;height:19px}
.foot-legal{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.foot-legal a{color:#C3A8B7}
.foot-legal a:hover{color:#fff}
.foot-legal .sepdot{color:#6E5868}

/* ---- pages légales ---- */
.legal{max-width:760px}
.legal-updated{font-family:var(--ui);font-size:13px;color:var(--mute);margin:-10px 0 26px}
.legal h2{font-family:var(--display);font-weight:420;font-size:22px;margin:30px 0 8px;color:var(--ink)}
.legal p,.legal li{font-size:16.5px;line-height:1.7;color:var(--ink-soft)}
.legal ul{padding-left:1.2em;margin:0 0 1em}
.legal li{margin-bottom:8px}
.legal a{color:var(--magenta-deep);text-decoration:underline;text-underline-offset:2px}
.legal-note{margin-top:34px;padding:14px 16px;background:var(--blush);border-radius:12px;
  font-size:13.5px;color:var(--ink-soft);font-family:var(--ui)}

/* ===== Section "À propos de l'auteure" (accueil) — mobile-first ===== */
.about{margin:34px 0;display:flex;flex-direction:column;gap:24px;background:var(--white);
  border:1px solid var(--line);border-radius:var(--r);padding:28px 22px;box-shadow:var(--shadow)}
.about-photos{display:flex;gap:14px;justify-content:center}
.about-photo{border-radius:16px;overflow:hidden;background:var(--blush);flex-shrink:0}
.about-photo.main{width:150px;height:190px}
.about-photo.sec{width:110px;height:190px;margin-top:18px}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo.ph{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blush),var(--blush-2))}
.about-photo.ph span{font-family:var(--display);font-size:64px;color:var(--magenta);opacity:.55}
.about-text{text-align:center}
.about-eyebrow{font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--magenta);margin-bottom:10px}
.about-text h2{font-family:var(--display);font-weight:380;font-size:30px;line-height:1.05;margin:0 0 4px}
.about-role{font-family:var(--ui);font-size:14px;color:var(--mute);margin-bottom:14px}
.about-text p{color:var(--ink-soft);font-size:16px;line-height:1.65;margin:0 0 18px}
.about-link{font-family:var(--ui);font-weight:600;font-size:14.5px;color:var(--magenta-deep)}
.about-link:hover{color:var(--magenta)}

@media(min-width:680px){
  .about{flex-direction:row;align-items:center;padding:34px;gap:34px}
  .about-photos{flex-shrink:0}
  .about-text{text-align:left;flex:1}
  .about-text h2{font-size:34px}
}

/* ===== Galerie : dispositions (mosaïque / grille / carrousel) ===== */
/* -- Mosaïque (masonry par colonnes) -- */
.gallery-masonry{column-count:2;column-gap:12px}
.masonry-item{break-inside:avoid;margin:0 0 12px;border-radius:14px;overflow:hidden;
  position:relative;cursor:pointer;background:var(--blush)}
.masonry-item img{width:100%;display:block;transition:.4s}
.masonry-item:hover img{transform:scale(1.04)}
.masonry-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 12px 10px;
  font-family:var(--ui);font-size:12.5px;color:#fff;
  background:linear-gradient(transparent,rgba(20,12,22,.82));opacity:0;transition:.25s}
.masonry-item:hover figcaption{opacity:1}

/* -- Carrousel -- */
.gal-carousel{position:relative;border-radius:var(--r);overflow:hidden}
.gal-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  gap:0;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gal-track::-webkit-scrollbar{display:none}
.gal-slide{flex:0 0 100%;scroll-snap-align:center;margin:0;position:relative;
  aspect-ratio:4/3;background:var(--blush);cursor:pointer}
.gal-slide img{width:100%;height:100%;object-fit:cover;display:block}
.gal-slide figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 18px 16px;
  font-family:var(--ui);font-size:14px;color:#fff;background:linear-gradient(transparent,rgba(20,12,22,.85))}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;
  border:0;background:rgba(252,250,251,.9);color:var(--ink);font-size:24px;line-height:1;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);z-index:2}
.gal-nav.prev{left:12px}.gal-nav.next{right:12px}
.gal-nav:hover{background:#fff;color:var(--magenta)}
.gal-dots{position:absolute;left:0;right:0;bottom:12px;display:flex;gap:7px;justify-content:center;z-index:2}
.gal-dots button{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.55);padding:0}
.gal-dots button.on{background:#fff;width:22px;border-radius:5px}

@media(min-width:680px){.gallery-masonry{column-count:3}.gal-slide{aspect-ratio:16/9}}
@media(min-width:960px){.gallery-masonry{column-count:4;column-gap:14px}.masonry-item{margin-bottom:14px}}
