/* POP LIVRE — refonte 2026-06 : app shell responsive (mobile-first → desktop),
   design éditorial « librairie », 3 ambiances (Clair / Sombre / Sépia). */

:root{
  --bg:#FFF8EF; --bg2:#FBEDDC; --card:#FFFFFF; --ink:#27243B; --muted:#857A8F;
  --accent:#E63956; --accent-ink:#FFFFFF; --gold:#FFC93F; --line:#F0DFC9;
  --shadow:0 10px 30px rgba(30,26,22,.08);
  --display:'Iowan Old Style','Palatino Linotype',Palatino,Georgia,serif;
  --body:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);line-height:1.5;
  min-height:100svh;display:flex;flex-direction:column;
  transition:background .3s ease,color .3s ease}

/* ---------------- top bar ---------------- */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;
  padding:12px clamp(14px,4vw,40px);background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--ink)}
.brand-ic{border-radius:8px;display:block}
.brand-mark{font-family:var(--display);font-weight:700;font-size:22px;color:var(--accent);letter-spacing:.02em}
.brand-name{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:.06em}
.topnav{display:none;gap:4px;margin-left:18px}
.topnav button{background:none;border:0;font:600 14px var(--body);color:var(--muted);
  padding:8px 12px;border-radius:10px;cursor:pointer;transition:.2s}
.topnav button:hover{color:var(--ink);background:var(--bg2)}
.topnav button.on{color:var(--accent)}
.pilecount{display:inline-block;min-width:18px;padding:0 5px;border-radius:9px;background:var(--accent);
  color:var(--accent-ink);font-size:11px;text-align:center;margin-left:2px}
.pilecount:empty{display:none}
.themebtn{margin-left:auto;background:var(--bg2);border:1px solid var(--line);border-radius:10px;
  width:38px;height:38px;display:grid;place-items:center;color:var(--muted);cursor:pointer}
.themebtn:hover{color:var(--accent)}

/* ---------------- layout ---------------- */
.app{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:0 clamp(14px,4vw,40px) 90px}
.view{display:none;padding-top:18px;animation:fade .25s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.h-sec{font-family:var(--display);font-weight:700;font-size:clamp(20px,2.6vw,26px);margin:30px 0 6px}
.h-sec.first{margin-top:10px}
.sub{color:var(--muted);font-size:14px;margin-bottom:14px}
.empty-state{text-align:center;color:var(--muted);padding:60px 20px;font-size:15px}
.linklike{background:none;border:none;color:var(--accent);font:inherit;cursor:pointer;text-decoration:underline}

/* ---------------- hero (accueil) ---------------- */
.hero{display:grid;gap:22px;align-items:center;padding:26px 0 8px}
.hero .kicker{font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.hero h1{font-family:var(--display);font-size:clamp(30px,5vw,52px);line-height:1.06;margin:8px 0 10px}
.hero p{color:var(--muted);max-width:520px;font-size:15px}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.hero-covers{display:none;position:relative;height:300px}
.hero-covers img{position:absolute;width:150px;border-radius:8px;box-shadow:var(--shadow);
  transition:transform .3s ease}
.hero-covers img:nth-child(1){left:6%;top:34px;transform:rotate(-7deg)}
.hero-covers img:nth-child(2){left:33%;top:0;transform:rotate(2deg);z-index:2}
.hero-covers img:nth-child(3){left:60%;top:40px;transform:rotate(8deg)}
.hero-covers img:hover{transform:scale(1.06) rotate(0);z-index:5}

/* ---------------- boutons ---------------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:14px;cursor:pointer;
  font:700 15px var(--body);padding:13px 22px;transition:.2s}
.btn.pri{background:var(--accent);color:var(--accent-ink);box-shadow:0 8px 20px color-mix(in srgb,var(--accent) 35%,transparent)}
.btn.pri:hover{transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink);margin-top:18px}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ---------------- recherche ---------------- */
.searchbar{display:flex;gap:8px;margin:18px 0 4px;max-width:560px}
.searchbar input{flex:1;border:1.5px solid var(--line);background:var(--card);color:var(--ink);
  border-radius:14px;padding:12px 16px;font:15px var(--body);outline:none}
.searchbar input:focus{border-color:var(--accent)}
.searchbar button{border:0;border-radius:14px;background:var(--ink);color:var(--bg);
  width:48px;display:grid;place-items:center;cursor:pointer}

/* ---------------- étagères & cartes ---------------- */
.shelfhd{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.more{font-size:13px;color:var(--accent);cursor:pointer;font-weight:600;white-space:nowrap}
.shelf{display:grid;grid-auto-flow:column;grid-auto-columns:128px;gap:14px;overflow-x:auto;
  padding:10px 2px 18px;scroll-snap-type:x mandatory;scrollbar-width:none}
.shelf::-webkit-scrollbar{display:none}
.shelf .bk{scroll-snap-align:start}
.grid-books{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:16px;padding:8px 0 14px}
.bk{cursor:pointer;transition:transform .18s ease}
.bk:hover{transform:translateY(-4px)}
.cvwrap{position:relative;border-radius:8px;overflow:hidden;background:var(--bg2);
  aspect-ratio:2/3;box-shadow:0 6px 16px rgba(30,26,22,.13)}
.cv{width:100%;height:100%;object-fit:cover;display:block}
.badge-aud{position:absolute;right:6px;bottom:6px;background:rgba(20,17,14,.78);border-radius:8px;
  padding:4px 5px;display:grid;place-items:center}
.badge-cnr{position:absolute;left:0;top:8px;background:var(--gold);color:#231a08;font-size:10px;
  font-weight:800;padding:3px 8px;border-radius:0 8px 8px 0;max-width:88%;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.bt{font-weight:700;font-size:13px;line-height:1.25;margin-top:8px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ba{font-size:12px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------------- quiz ---------------- */
.qhead{display:flex;align-items:center;gap:14px;padding:8px 0}
.qback{background:var(--bg2);border:1px solid var(--line);border-radius:10px;width:38px;height:38px;
  display:grid;place-items:center;color:var(--ink);cursor:pointer}
.progress{display:flex;gap:6px;flex:1;max-width:300px}
.progress span{height:5px;flex:1;border-radius:3px;background:var(--line);transition:.3s}
.progress span.on{background:var(--accent)}
.qbody{max-width:640px;margin:0 auto;padding:14px 0}
.qstep{font-weight:700;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.qtitle{font-family:var(--display);font-size:clamp(24px,4vw,36px);margin:8px 0 4px}
.qopts{display:grid;gap:12px;margin-top:22px}
@media(min-width:560px){.qopts{grid-template-columns:1fr 1fr}}
.qopt{display:flex;align-items:center;gap:14px;background:var(--card);border:1.5px solid var(--line);
  border-radius:16px;padding:16px;cursor:pointer;text-align:left;font:inherit;color:var(--ink);transition:.18s}
.qopt:hover{border-color:var(--accent);transform:translateY(-2px)}
.qopt.sel{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 7%,var(--card))}
.qopt .qic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none}
.qopt b{display:block;font-size:15px}
.qopt small{color:var(--muted);font-size:12.5px}

/* ---------------- résultat ---------------- */
.herocard{display:grid;grid-template-columns:130px 1fr;gap:18px;background:var(--card);
  border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow);cursor:pointer}
.herocard .cvwrap{aspect-ratio:2/3}
.herocard .why{font-size:13.5px;color:var(--muted);margin:8px 0}
.match{display:inline-block;background:var(--gold);color:#231a08;font-weight:800;font-size:12px;
  border-radius:9px;padding:3px 10px;margin-bottom:6px}
@media(min-width:700px){.herocard{grid-template-columns:170px 1fr;padding:24px}}

/* ---------------- tags & chips ---------------- */
.tags{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}
.tag{background:var(--bg2);border:1px solid var(--line);color:var(--muted);font-size:11.5px;
  font-weight:600;border-radius:8px;padding:3px 9px}

/* ---------------- fiche (overlay) ---------------- */
.ov{position:fixed;inset:0;z-index:60;display:none;background:rgba(20,17,14,.55);
  backdrop-filter:blur(4px);overflow-y:auto;overscroll-behavior:contain}
.ov.open{display:block}
.fiche-in{max-width:820px;margin:5vh auto 40px;background:var(--bg);border-radius:22px;
  overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:fade .25s ease}
.fi-head{position:relative;padding:30px 22px 22px;display:grid;grid-template-columns:138px 1fr;gap:20px;align-items:end;min-height:230px}
.fi-head .cvwrap{aspect-ratio:2/3;box-shadow:0 14px 30px rgba(0,0,0,.35)}
.fi-close{position:absolute;top:14px;right:14px;background:rgba(20,17,14,.5);color:#fff;border:0;
  width:36px;height:36px;border-radius:10px;display:grid;place-items:center;cursor:pointer;z-index:3}
.fi-title{font-family:var(--display);font-size:clamp(20px,3.4vw,32px);line-height:1.1}
.fi-author{font-size:14.5px;margin-top:4px}
.fi-body{background:var(--bg);padding:20px 22px 28px}
.fi-meta{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:13px;margin-bottom:12px}
.fi-meta b{color:var(--ink)}
.fi-pitch{font-size:15px;line-height:1.65;margin:10px 0}
.fi-resume{font-size:14px;line-height:1.7;color:var(--muted);margin:12px 0;white-space:pre-line}
.buy{margin-top:18px}
.buy .h-min{font-weight:800;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.buy-links{display:flex;gap:9px;flex-wrap:wrap}
.buy-link{flex:1;min-width:130px;display:flex;align-items:center;justify-content:center;gap:7px;
  background:var(--accent);color:var(--accent-ink);text-decoration:none;font-weight:700;font-size:13.5px;
  border-radius:12px;padding:12px 14px;transition:.18s}
.buy-link:hover{transform:translateY(-1px);filter:brightness(1.07)}
.buy-link.alt{background:var(--ink);color:var(--bg)}
.buy-link.ed{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.fi-actions{display:flex;gap:9px;margin-top:16px}
.fi-actions .btn{flex:1;justify-content:center;padding:12px;margin:0}
.fi-chap{margin-top:16px}
.fi-chap button{display:flex;width:100%;align-items:center;gap:10px;background:var(--card);
  border:1px solid var(--line);border-radius:11px;padding:10px 13px;margin-bottom:7px;cursor:pointer;
  font:600 13.5px var(--body);color:var(--ink);text-align:left}
.fi-chap button:hover{border-color:var(--accent)}

/* ---------------- tendances ---------------- */
.tcard{display:grid;grid-template-columns:auto 1fr;gap:14px;background:var(--card);
  border:1px solid var(--line);border-radius:18px;padding:15px;margin-bottom:13px;align-items:center}
.tava{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;
  font-weight:800;font-size:15px;flex:none}
.tname{font-weight:700;font-size:14.5px}
.tmeta{color:var(--muted);font-size:12.5px}
.tquote{grid-column:1/-1;font-family:var(--display);font-size:15.5px;font-style:italic;line-height:1.5}
.tbook{grid-column:1/-1;display:flex;align-items:center;gap:11px;background:var(--bg2);
  border-radius:12px;padding:9px 11px;cursor:pointer}
.tbook img{width:38px;border-radius:5px}
.tbook .bt{margin:0}
.vidgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin:14px 0}
.vid{border-radius:14px;overflow:hidden;background:var(--card);border:1px solid var(--line);
  cursor:pointer;text-decoration:none;color:var(--ink)}
.vid img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.vid .vt{font-weight:600;font-size:13px;padding:10px 12px;line-height:1.35}
.tdisclaimer{color:var(--muted);font-size:11.5px;margin:18px 0;line-height:1.5}

/* ---------------- audio ---------------- */
.audio-hero{background:linear-gradient(135deg,var(--ink),#3a2e24);color:#fff;border-radius:20px;
  padding:26px 22px;margin-bottom:8px}
.audio-hero .t{font-family:var(--display);font-size:24px}
.audio-hero .sub{color:rgba(255,255,255,.75)}
.trackrow{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);
  border-radius:13px;padding:11px 14px;margin-bottom:9px}
.trackrow button{background:var(--accent);color:#fff;border:0;border-radius:50%;width:38px;height:38px;
  display:grid;place-items:center;cursor:pointer;flex:none}
.trackrow .tt{font-weight:700;font-size:14px}
.trackrow .ta{color:var(--muted);font-size:12px}
.trackrow .lic{margin-left:auto;font-size:10.5px;color:var(--muted);border:1px solid var(--line);
  border-radius:7px;padding:2px 7px;white-space:nowrap}

/* ---------------- toast & nav basse ---------------- */
.toast{position:fixed;left:50%;bottom:86px;transform:translateX(-50%) translateY(20px);z-index:80;
  background:var(--ink);color:var(--bg);font-weight:600;font-size:13.5px;border-radius:12px;
  padding:11px 18px;opacity:0;pointer-events:none;transition:.25s}
.toast.show{opacity:1;transform:translateX(-50%)}
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;
  background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);padding:6px 4px calc(6px + env(safe-area-inset-bottom))}
.bottomnav button{flex:1;background:none;border:0;display:flex;flex-direction:column;align-items:center;
  gap:3px;font:600 10.5px var(--body);color:var(--muted);padding:6px 2px;cursor:pointer;border-radius:10px}
.bottomnav button.on{color:var(--accent)}

/* ---------------- footer ---------------- */
.foot{padding:26px clamp(14px,4vw,40px) 110px;border-top:1px solid var(--line);
  color:var(--muted);font-size:13px;text-align:center}
.foot-sub{margin-top:6px;font-size:12px}
.foot a{color:var(--muted)}

/* ---------------- desktop ---------------- */
@media(min-width:880px){
  .topnav{display:flex}
  .bottomnav{display:none}
  .app{padding-bottom:30px}
  .foot{padding-bottom:30px}
  .hero{grid-template-columns:1.1fr .9fr;padding:44px 0 14px}
  .hero-covers{display:block}
  .shelf{grid-auto-columns:150px}
  .grid-books{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .fi-head{grid-template-columns:264px 1fr;padding:44px 36px 32px;min-height:420px;gap:28px}
  .fi-body{padding:26px 36px 38px}
}

/* ---------------- découvrir (grille + modules) ---------------- */
.disco-chips{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 16px}
.dchip{border:1.5px solid var(--line);background:var(--card);color:var(--muted);font:600 13px var(--body);
  border-radius:999px;padding:8px 16px;cursor:pointer;transition:.15s}
.dchip:hover{border-color:var(--accent);color:var(--accent)}
.dchip.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.covgrid-front{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:14px}
.covgrid-front .bk:hover{transform:translateY(-4px) rotate(-1deg)}
@media(min-width:880px){.covgrid-front{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}

/* ---------------- à lire : liste ordonnable (drag & drop) ---------------- */
.pilerow{display:grid;grid-template-columns:26px 52px 1fr auto;gap:12px;align-items:center;
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin-bottom:9px;
  cursor:grab;transition:.15s}
.pilerow.dragging{opacity:.45}
.pilerow.dropover{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 30%,transparent)}
.pilerow .num{font-family:var(--display);font-weight:700;color:var(--muted);text-align:center}
.pilerow img{width:52px;border-radius:6px;display:block}
.pilerow .pt{font-weight:700;font-size:14.5px;line-height:1.25}
.pilerow .pa{font-size:12.5px;color:var(--muted)}
.pilerow .acts{display:flex;gap:5px}
.pilerow .acts button{background:var(--bg2);border:1px solid var(--line);border-radius:9px;width:32px;height:32px;
  display:grid;place-items:center;color:var(--muted);cursor:pointer;font-size:14px}
.pilerow .acts button:hover{color:var(--accent);border-color:var(--accent)}

/* ---------------- lus + profil ---------------- */
.verdict{position:absolute;left:0;top:8px;background:var(--accent);color:var(--accent-ink);font-size:10px;
  font-weight:800;padding:3px 8px;border-radius:0 8px 8px 0}
.profilcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px 18px;margin:6px 0 18px}
.profilcard .h-min{font-weight:800;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.profilbars span{display:inline-block;background:var(--bg2);border:1px solid var(--line);border-radius:9px;
  padding:4px 11px;font-size:12.5px;font-weight:600;margin:0 6px 6px 0}

/* ---------------- swipe ---------------- */
.swipe-stage{position:relative;max-width:380px;margin:10px auto;height:480px}
.swipe-card{position:absolute;inset:0;background:var(--card);border:1px solid var(--line);border-radius:22px;
  overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .25s ease,opacity .25s ease}
.swipe-card img{width:100%;height:62%;object-fit:cover}
.swipe-card .sc-body{padding:14px 16px;flex:1}
.swipe-card .sc-t{font-family:var(--display);font-weight:700;font-size:19px;line-height:1.15}
.swipe-card .sc-a{color:var(--muted);font-size:13px;margin:2px 0 6px}
.swipe-card .sc-p{font-size:13px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.swipe-card.gone-left{transform:translateX(-120%) rotate(-14deg);opacity:0}
.swipe-card.gone-right{transform:translateX(120%) rotate(14deg);opacity:0}
.swipe-card.gone-up{transform:translateY(-120%);opacity:0}
.swipe-btns{display:flex;gap:9px;justify-content:center;margin:16px 0;flex-wrap:wrap}
.swipe-btns button{border:1.5px solid var(--line);background:var(--card);color:var(--ink);font:700 13.5px var(--body);
  border-radius:14px;padding:12px 16px;cursor:pointer;transition:.15s}
.swipe-btns button:hover{transform:translateY(-2px)}
.swipe-btns .sb-ecarte{color:#b33}
.swipe-btns .sb-alire{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.swipe-progress{text-align:center;color:var(--muted);font-size:13px;margin-top:4px}

/* ---------------- compte ---------------- */
.authcard{max-width:430px;margin:14px auto;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px}
.authcard h3{font-family:var(--display);font-size:21px;margin-bottom:4px}
.authcard label{display:block;font-size:12.5px;color:var(--muted);margin:12px 0 4px;font-weight:600}
.authcard input{width:100%;border:1.5px solid var(--line);background:var(--bg);color:var(--ink);
  border-radius:11px;padding:11px 13px;font:14.5px var(--body);outline:none}
.authcard input:focus{border-color:var(--accent)}
.oauthrow{display:grid;gap:8px;margin-top:14px}
.oauthrow button{display:flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid var(--line);
  background:var(--bg);color:var(--ink);font:600 14px var(--body);border-radius:12px;padding:11px;cursor:pointer}
.oauthrow button:hover{border-color:var(--muted)}
.authswitch{text-align:center;margin-top:14px;font-size:13.5px;color:var(--muted)}
.statrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin:14px 0}
.statbox{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:12px;text-align:center}
.statbox .n{font-family:var(--display);font-weight:700;font-size:24px}
.statbox .l{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.danger{color:#b33}

/* ---------------- compteurs accueil ---------------- */
.counters{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px;margin:6px 0 4px}
.counter{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 8px;text-align:center}
.counter .cn{font-family:var(--display);font-weight:700;font-size:clamp(20px,3vw,28px);color:var(--accent)}
.counter .cl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

/* ---------------- carrousel accueil (5 couvertures, apparition aléatoire) ---------------- */
.hero-txt{min-width:0}
.hero-caro{display:flex;flex-direction:column;align-items:center;gap:12px;margin:6px auto 2px}
.hc-stage{position:relative;width:190px;height:285px}
.hc-cov{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:12px;
  box-shadow:var(--shadow);opacity:0;transform:scale(.9) translateY(10px) rotate(-2.5deg);
  transition:opacity .7s ease,transform .7s ease;cursor:pointer;will-change:opacity,transform}
.hc-cov.on{opacity:1;transform:scale(1) translateY(0) rotate(0);z-index:2}
.hc-cap{font-size:13px;color:var(--muted);text-align:center;max-width:240px;min-height:34px;line-height:1.3}
@media(min-width:880px){
  .hero-caro{margin:0}
  .hc-stage{width:240px;height:360px}
}

/* ---------------- suivi de lecture (À lire) ---------------- */
.bk.dragging{opacity:.4}
.bk.dropover{outline:2px dashed var(--accent);outline-offset:3px;border-radius:10px}

/* ---------------- bibliothèque (Lus) ---------------- */
.shelf-row{margin-bottom:6px}
/* ---------------- accueil éditorial (« une » + rayons) ---------------- */
.hero.solo{display:block;max-width:680px}
.une-k{font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:22px 0 10px}
.unecard{display:grid;grid-template-columns:118px 1fr;gap:18px;background:var(--card);border:1px solid var(--line);
  border-radius:18px;padding:18px;cursor:pointer;align-items:start;box-shadow:var(--shadow)}
.unecard .cvwrap{aspect-ratio:2/3;border-radius:8px;overflow:hidden}
.unecard img{width:100%;height:100%;object-fit:cover;display:block}
.une-t{font-family:var(--display);font-weight:700;font-size:clamp(22px,3.4vw,30px);line-height:1.1;margin:8px 0 2px}
.une-a{color:var(--muted);font-size:14px;margin-bottom:8px}
.une-pitch{font-weight:600;font-size:15px;line-height:1.4;margin:6px 0}
.une-txt{color:var(--muted);font-size:14px;line-height:1.6;margin:6px 0 14px}
.shelf-intro{color:var(--muted);font-size:13.5px;margin:0 0 8px}
.home-foot{display:flex;justify-content:center;margin:30px 0 8px}
/* « Le mot de POP LIVRE » — éclairage lecteur (jamais l'argumentaire interne) */
.fi-eclairage{border-left:3px solid var(--gold);background:color-mix(in srgb,var(--gold) 8%,transparent);
  border-radius:0 10px 10px 0;padding:12px 14px;margin:12px 0;font-size:14.5px;line-height:1.62}
.fi-eclairage-k{display:block;font:800 10.5px var(--body);letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);margin-bottom:6px}
@media(min-width:700px){.unecard{grid-template-columns:200px 1fr;gap:26px;padding:24px}}
.library-shelf{border-bottom:14px solid color-mix(in srgb,var(--accent) 22%,var(--bg2));
  border-radius:0 0 8px 8px;box-shadow:0 10px 14px -10px rgba(0,0,0,.25);padding-bottom:6px;margin-bottom:10px}
.shelfsel{width:100%;margin-top:4px;font:600 11.5px var(--body);border:1px solid var(--line);
  background:var(--bg2);color:var(--muted);border-radius:8px;padding:4px 6px}

/* ---------------- swipe immersif ---------------- */
.swipe-stage{position:relative;max-width:430px;margin:10px auto;height:680px}
.swipe-card{position:absolute;inset:0;border:1px solid var(--line);border-radius:24px;overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.22);display:flex;flex-direction:column;
  transition:transform .25s ease,opacity .25s ease}
.swipe-card .sc-cov{height:58%;flex:none;display:flex;align-items:center;justify-content:center;
  padding:16px 16px 6px;min-height:0}
.swipe-card .sc-cov img{height:100%;width:auto;max-width:94%;object-fit:contain;border-radius:8px;
  box-shadow:0 14px 30px rgba(0,0,0,.35)}
.swipe-card .sc-body{flex:1;min-height:0;display:flex;flex-direction:column;padding:6px 20px 16px}
.swipe-card .sc-t{font-family:var(--display);font-weight:700;font-size:21px;line-height:1.12}
.swipe-card .sc-a{color:var(--muted);font-size:13.5px;margin:3px 0}
.swipe-card .sc-txt{flex:1;min-height:0;overflow-y:auto;padding-right:6px;-webkit-overflow-scrolling:touch}
.swipe-card .sc-lead{font-family:var(--display);font-weight:700;font-size:15px;line-height:1.4;margin:4px 0 8px}
.swipe-card .sc-p{font-size:14px;line-height:1.6;color:var(--muted);white-space:pre-line}
.swipe-btns.big{display:flex;gap:8px;justify-content:center;margin:16px auto;max-width:520px;flex-wrap:wrap}
.swipe-btns.big button{flex:1;min-width:84px;display:flex;flex-direction:column;align-items:center;gap:4px;
  border:0;border-radius:18px;background:var(--card);box-shadow:var(--shadow);color:var(--ink);
  font:700 11.5px var(--body);padding:14px 8px;cursor:pointer;transition:.15s}
.swipe-btns.big button:hover{transform:translateY(-3px)}
.swipe-btns.big button span{line-height:1.1;text-align:center}
.swipe-btns.big .sb-ecarte{color:#c0392b}
.swipe-btns.big .sb-alire{background:var(--accent);color:var(--accent-ink)}
/* --- geste de swipe (carte glissable + pile de profondeur) --- */
.swipe-card{touch-action:none;will-change:transform}
.swipe-card .sc-txt{touch-action:pan-y}
.swipe-card.swipe-grab{cursor:grab}
.swipe-card.dragging{transition:none!important;cursor:grabbing;box-shadow:0 32px 80px rgba(0,0,0,.34)}
.swipe-card.behind{transform:scale(.94) translateY(16px);opacity:.9;pointer-events:none;
  filter:saturate(.92) brightness(.98);z-index:0}
.swipe-card#swipeCard{z-index:1}
.sc-hint{position:absolute;top:18px;z-index:3;font:800 15px var(--body);letter-spacing:.08em;
  text-transform:uppercase;padding:6px 12px;border-radius:10px;border:3px solid;opacity:0;
  transition:opacity .12s ease;pointer-events:none}
.sc-hint.like{right:16px;color:#159c64;border-color:#159c64;transform:rotate(11deg)}
.sc-hint.nope{left:16px;color:#c0392b;border-color:#c0392b;transform:rotate(-11deg)}
.sc-hint.read{left:50%;top:40%;transform:translateX(-50%);color:var(--accent);border-color:var(--accent)}
.swipe-hintline{text-align:center;color:var(--muted);font-size:12px;margin:10px auto 0;max-width:380px}
@media (prefers-reduced-motion:reduce){
  .swipe-card{transition:opacity .18s ease!important}
  .swipe-card.behind{transform:none;opacity:0}
}
/* --- swipe plein écran : couverture (moitié haute) + argumentaire (moitié basse), opaque --- */
.swipe-fs{position:fixed;inset:0;z-index:55;background:var(--bg);display:flex;flex-direction:column}
.swipe-topbar{flex:none;display:flex;align-items:center;justify-content:space-between;padding:10px 14px}
.swipe-close{display:inline-flex;align-items:center;gap:5px;border:1.5px solid var(--line);background:var(--card);
  color:var(--ink);font:700 13px var(--body);border-radius:12px;padding:8px 13px;cursor:pointer}
.swipe-fs .swipe-progress{margin:0;font-weight:700;color:var(--muted)}
.swipe-fs .swipe-stage{position:relative;flex:1;min-height:0;width:100%;max-width:none;height:auto;margin:0}
.swipe-fs .swipe-card{position:absolute;inset:0;border:0;border-radius:0;box-shadow:none;background:var(--card);
  display:flex;flex-direction:column;overflow:hidden}
.swipe-fs .swipe-card.behind{transform:none;opacity:1;filter:none;z-index:0}
.swipe-fs .swipe-card#swipeCard{z-index:1}
.swipe-fs .sc-cov{height:50%;flex:none;display:flex;align-items:center;justify-content:center;padding:14px}
.swipe-fs .sc-cov img{height:100%;width:auto;max-width:90%;object-fit:contain;border-radius:8px;
  box-shadow:0 18px 42px rgba(0,0,0,.42)}
.swipe-fs .sc-body{height:50%;flex:none;display:flex;flex-direction:column;padding:12px 22px 14px;min-height:0}
.swipe-fs .sc-tagline{display:flex;align-items:center;gap:8px;flex:none;overflow:hidden;white-space:nowrap;margin-bottom:6px}
.sc-mood{font:800 10.5px var(--body);letter-spacing:.05em;text-transform:uppercase;color:#fff;padding:3px 10px;border-radius:999px}
.sc-gtag{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:2px 9px;border-radius:999px;
  overflow:hidden;text-overflow:ellipsis;max-width:60%}
.swipe-fs .sc-t{font-family:var(--display);font-weight:700;font-size:clamp(19px,4.4vw,24px);line-height:1.12;flex:none}
.swipe-fs .sc-a{color:var(--muted);font-size:13.5px;margin:3px 0 8px;flex:none}
.swipe-fs .sc-txt{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding-right:8px}
.swipe-fs .sc-lead{font-family:var(--display);font-weight:700;font-size:15px;line-height:1.42;margin:0 0 8px;color:var(--ink)}
.swipe-fs .sc-p{font-size:14.5px;line-height:1.62;color:var(--ink);white-space:pre-line;margin:0}
.swipe-fs .swipe-btns.big{flex:none;margin:0;max-width:none;gap:7px;
  padding:9px 12px calc(9px + env(safe-area-inset-bottom));background:var(--bg);border-top:1px solid var(--line)}
.swipe-fs .swipe-btns.big button{min-width:0;padding:11px 6px;font-size:11px;border-radius:14px}
.swipe-fs .sc-hint.read{top:42%}
/* image non « draggable » nativement : elle ne doit jamais se détacher de la carte */
.swipe-card img{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;user-drag:none;user-select:none;pointer-events:none}
/* desktop (≥880px, là où l'app passe en topnav) : on garde l'aspect CARTE, pas de plein écran */
@media(min-width:880px){
  .swipe-fs{position:static;z-index:auto;background:transparent;display:block;max-width:430px;margin:2px auto 0}
  .swipe-topbar{padding:0 2px 12px}
  .swipe-fs .swipe-stage{flex:none;height:min(68vh,600px);width:100%}
  .swipe-fs .swipe-card{border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow)}
  .swipe-fs .swipe-card.behind{box-shadow:var(--shadow)}
  .swipe-fs .swipe-btns.big{border-top:0;background:transparent;padding:14px 0 0}
}

/* ---------------- découverte immersive ---------------- */
.discovery{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px 24px;color:#fff;position:relative}
.discovery .disc-kicker{font-size:12px;font-weight:800;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.discovery .disc-cov{max-height:46vh;border-radius:10px;box-shadow:0 30px 70px rgba(0,0,0,.55);margin:18px 0}
.discovery .disc-t{font-family:var(--display);font-weight:700;font-size:clamp(24px,5vw,38px);line-height:1.1;max-width:640px}
.discovery .disc-a{color:rgba(255,255,255,.85);margin:6px 0 14px}
.discovery .disc-p{max-width:560px;font-size:15px;line-height:1.6;color:rgba(255,255,255,.9)}
.discovery .disc-cta{display:flex;flex-direction:column;gap:10px;margin-top:24px;align-items:center}

/* ---------------- générateur social ---------------- */
.soc-pick{display:grid;grid-template-columns:repeat(auto-fill,minmax(66px,1fr));gap:8px;margin:8px 0}
.soc-pi{position:relative;cursor:pointer;border-radius:8px;overflow:hidden;border:2px solid transparent}
.soc-pi.on{border-color:var(--accent)}
.soc-pi img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}
.soc-pi span{position:absolute;left:0;bottom:0;right:0;background:rgba(0,0,0,.7);color:#fff;font-size:9.5px;text-align:center;padding:2px}
.soc-nets{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}
.soc-nets button{border:1.5px solid var(--line);background:var(--bg);color:var(--muted);
  border-radius:9px;padding:7px 12px;font:600 12px var(--body);cursor:pointer;text-transform:capitalize}
.soc-nets button:hover{border-color:var(--accent);color:var(--accent)}

/* ---------------- contrôles personnalisation (compte) ---------------- */
.ctrl-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.ctrl{border:1.5px solid var(--line);border-radius:10px;padding:8px 14px;font:600 13px var(--body);cursor:pointer}
.ctrl.on{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.swatch{width:34px;height:34px;border-radius:50%;border:2px solid var(--line);cursor:pointer}
.swatch.on{outline:2px solid var(--ink);outline-offset:2px}

/* ---------------- accessibilité ---------------- */
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
.ic{vertical-align:-3px}
img{color:transparent}

/* ---------------- responsive mobile (remise au propre) ---------------- */
@media(max-width:879px){
  .hero{padding:18px 0 6px}
  .hero h1{font-size:clamp(26px,7vw,34px)}
  .counters{grid-template-columns:repeat(3,1fr)}
  .app{padding-bottom:84px}
  .topnav{display:none}
  .swipe-stage{height:66svh;max-width:350px}
  .fi-head{grid-template-columns:104px 1fr}
}
