/* livre.css — Livre photo souvenir (expérience in-app). DA « Été Pop » (handoff Claude Design),
   portée À L'IDENTIQUE depuis editeur/theme.css [data-theme="pop"] + editeur/app.css, et SCOPÉE
   sous #livre-pop pour ne pas polluer le reste de l'app. Polices auto-hébergées (woff2 base64,
   zéro Google Fonts) importées depuis livre-fonts.css : Bricolage Grotesque (titres 800),
   Hanken Grotesk (texte), Caveat (manuscrit). Aperçu des pages = vraies images du worker, sinon
   placeholder « aperçu bientôt » tant que le rendu PDF n'est pas branché.
   ⚠️ livre-fonts.css (woff2 base64, ~760 Ko) n'est PAS importé ici : il est injecté paresseusement par
   livre.js (ensureShell) à la 1re ouverture du livre, pour ne pas alourdir le démarrage de l'app. */

#livre-pop{
  /* ----- tokens Été Pop (theme.css [data-theme="pop"]) ----- */
  --bg:#FBF6EE; --bg2:#FBEAD0; --surface:#FFFDF8; --surface2:#F6EEDD;
  --ink:#293A41; --ink70:rgba(41,58,65,.7); --ink50:rgba(41,58,65,.5); --ink20:rgba(41,58,65,.2);
  --line:#E7DECB; --line2:#EFE8DA;
  --accent:#FF8A4C; --accent2:#FFB15E; --accentDeep:#E8642A; --accentInk:#3a1a08;
  --eau:#46C7DA; --eauDeep:#0E7C8E; --eauPale:#E2F4F7;
  --vert:#4FB477; --vertDeep:#2F8D57; --amber:#E0A21C;
  --paper:#FFFFFF; --paperInk:#293A41; --paperEdge:#EADFC8;
  --canvas:#EFE6D4;
  --shadow:0 1px 2px rgba(41,58,65,.06),0 10px 26px -14px rgba(41,58,65,.3);
  --shadowLg:0 26px 60px -22px rgba(41,58,65,.4);
  --ft:'Bricolage Grotesque','Segoe UI',system-ui,sans-serif;
  --fb:'Hanken Grotesk','Segoe UI',system-ui,sans-serif;
  --fh:'Caveat','Segoe UI',cursive;
  --fdisplay:var(--ft); --titleScript:var(--fh);

  position:fixed; inset:0; z-index:1800; display:none; background:var(--bg); color:var(--ink);
  font-family:var(--fb); -webkit-tap-highlight-color:transparent; -webkit-font-smoothing:antialiased;
}
#livre-pop.show{display:block}
#livre-pop *{box-sizing:border-box}
#livre-pop button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
#livre-pop img{display:block;max-width:100%}
#livre-pop h1,#livre-pop h2,#livre-pop h3,#livre-pop h4{font-family:var(--fdisplay);font-weight:800;letter-spacing:-.02em;line-height:1.04}
#livre-pop .hand{font-family:var(--titleScript);font-weight:700}

/* ----- container scroll + transition d'écran ----- */
#livre-pop .app-scroll{position:absolute;inset:0;display:flex;flex-direction:column;overflow:hidden;opacity:0;transition:opacity .3s ease}
#livre-pop .app-scroll.shown{opacity:1}
/* écrans « plein cadre » (aperçu/liseuse) : pas de scroll vertical, ils gèrent leur propre layout */
#livre-pop .scr{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}
/* écrans « page » (accueil, reliure, retouches, commande, confirm) : scrollables */
#livre-pop.scrollable-screen .app-scroll,
#livre-pop .app-scroll.scrolls{overflow-y:auto}
#livre-pop .app-scroll{scrollbar-width:none}
#livre-pop .app-scroll::-webkit-scrollbar{display:none}

/* ----- boutons (app.css) ----- */
#livre-pop .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--fdisplay);font-weight:800;font-size:15px;border-radius:14px;padding:13px 20px;transition:.14s;min-height:48px;letter-spacing:-.01em}
#livre-pop .btn:active{transform:translateY(1px)}
#livre-pop .btn-block{width:100%}
#livre-pop .btn-sm{padding:9px 14px;min-height:40px;font-size:13.5px;border-radius:11px}
#livre-pop .btn-primary{width:100%;background:var(--accent);color:var(--accentInk);font-family:var(--fdisplay);font-weight:800;font-size:16px;padding:16px;border-radius:14px;box-shadow:0 12px 26px -12px var(--accentDeep);transition:.14s;min-height:52px}
#livre-pop .btn-primary:active{transform:translateY(1px)}
#livre-pop .btn-ghost{width:100%;background:var(--surface2);color:var(--ink);font-family:var(--fdisplay);font-weight:800;font-size:14px;padding:13px;border-radius:14px;border:1px solid var(--line)}
#livre-pop .cta-note{text-align:center;font-size:11.5px;font-weight:600;color:var(--ink50)}

/* ----- barre ancrée (dock) hors scroll ----- */
#livre-pop .scr-cta{flex-shrink:0;padding:14px 16px calc(14px + env(safe-area-inset-bottom));background:var(--bg);border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px;z-index:20}

/* ----- back / icon buttons (appbar look) ----- */
#livre-pop .iconbtn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--surface2);transition:.14s;flex-shrink:0;border:1px solid var(--line)}
#livre-pop .iconbtn svg{width:21px;height:21px;stroke:var(--ink);fill:none;stroke-width:1.9}
#livre-pop .nav-back{width:42px;height:42px;border-radius:12px;background:var(--surface2);border:1px solid var(--line);display:grid;place-items:center;font-size:20px;color:var(--ink);flex-shrink:0}
#livre-pop .entry-hero .nav-back{background:rgba(255,255,255,.85);backdrop-filter:blur(6px);border:none;box-shadow:var(--shadow)}

/* ============ ACCUEIL (home) ============ */
#livre-pop .scr-entry{overflow:hidden}
#livre-pop .entry-scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-width:none}
#livre-pop .entry-scroll::-webkit-scrollbar{display:none}
#livre-pop .entry-hero{position:relative;height:300px;flex-shrink:0;overflow:hidden;border-bottom:1px solid var(--line)}
#livre-pop .eh-photo{position:absolute;inset:0;background:linear-gradient(160deg,#46C7DA,#0E7C8E);background-size:cover;background-position:center}
#livre-pop .eh-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,23,27,0) 30%,rgba(20,23,27,.66) 100%)}
#livre-pop .entry-hero .nav-back{position:absolute;top:calc(14px + env(safe-area-inset-top));left:16px;z-index:3}
#livre-pop .eh-tag{position:absolute;top:calc(20px + env(safe-area-inset-top));right:16px;z-index:3;font-family:var(--fb);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:rgba(41,58,65,.4);backdrop-filter:blur(6px);padding:6px 12px;border-radius:30px}
#livre-pop .eh-cap{position:absolute;left:20px;right:20px;bottom:18px;z-index:3;color:#fff}
#livre-pop .eh-kick{font-family:var(--fb);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.85}
#livre-pop .eh-title{font-family:var(--fdisplay);font-weight:800;font-size:32px;line-height:1.04;color:#fff;margin-top:6px;text-shadow:0 2px 18px rgba(0,0,0,.4)}
#livre-pop .eh-dates{font-family:var(--titleScript);font-weight:700;font-size:22px;margin-top:2px;color:#fff;opacity:.95}

#livre-pop .home-body{padding:16px 16px 24px}

/* bandeau « modifié → régénérer » (regen-banner du design) */
#livre-pop .pv-regen{display:flex;align-items:center;gap:12px;padding:11px 14px;margin:0 0 16px;border-radius:14px;background:var(--eauPale);border:1px solid rgba(14,124,142,.3);color:var(--ink)}
#livre-pop .pv-regen .rb-dot{width:9px;height:9px;border-radius:50%;background:var(--amber);flex-shrink:0;box-shadow:0 0 0 4px rgba(224,162,28,.28)}
#livre-pop .pv-regen .rb-tx{font-size:12.5px;font-weight:700;line-height:1.3}
#livre-pop .pv-regen .rb-tx small{display:block;color:var(--ink50);font-weight:600;font-size:11px}
#livre-pop .pv-regen button{margin-left:auto;flex:0 0 auto;background:var(--accent);color:var(--accentInk);font-family:var(--fdisplay);font-weight:800;font-size:13px;border-radius:11px;padding:9px 14px;min-height:40px}

#livre-pop .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
#livre-pop .stat{background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:14px 6px;text-align:center}
#livre-pop .stat .v{font-family:var(--fdisplay);font-weight:800;font-size:23px;line-height:1;font-variant-numeric:tabular-nums}
#livre-pop .stat .k{font-size:10px;color:var(--ink50);font-weight:700;margin-top:5px;text-transform:uppercase;letter-spacing:.03em}

#livre-pop .sec-h{display:flex;align-items:center;gap:10px;margin:24px 2px 12px}
#livre-pop .sec-h h3{font-size:17px}
#livre-pop .sec-h .spacer{flex:1}
#livre-pop .sec-h .lnk{font-family:var(--fdisplay);font-weight:800;font-size:13px;color:var(--accentDeep)}

#livre-pop .tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px}
#livre-pop .tiles.tiles-1{grid-template-columns:1fr}
#livre-pop .tile{display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:14px;transition:.14s}
#livre-pop .tile:active{transform:scale(.99)}
#livre-pop .tile .ti{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--surface2);border:1px solid var(--line)}
#livre-pop .tile .ti svg{width:21px;height:21px;stroke:var(--ink);fill:none;stroke-width:1.9}
#livre-pop .tile .nm{font-family:var(--fdisplay);font-weight:800;font-size:15px;display:block}
#livre-pop .tile .mt{font-size:12px;color:var(--ink50);font-weight:600;display:block;margin-top:2px}

#livre-pop .stage-row{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:10px;margin-bottom:9px}
#livre-pop .stage-row .th{width:58px;height:58px;border-radius:11px;overflow:hidden;flex-shrink:0;background:var(--surface2);background-size:cover;background-position:center}
#livre-pop .stage-row .info{min-width:0;flex:1}
#livre-pop .stage-row .nm{font-family:var(--fdisplay);font-weight:800;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#livre-pop .stage-row .mt{font-size:12px;color:var(--ink50);font-weight:600;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#livre-pop .stage-row .ct{margin-left:auto;font-size:11px;color:var(--ink50);font-weight:700;flex-shrink:0}

#livre-pop .fmt-summary{display:flex;align-items:center;gap:13px;background:var(--surface);border:1.5px solid var(--accent);box-shadow:0 0 0 1px var(--accent);border-radius:15px;padding:13px}
#livre-pop .fmt-summary .ic{width:46px;height:46px;border-radius:11px;background:var(--surface2);display:grid;place-items:center;flex-shrink:0}
#livre-pop .fmt-summary .ic svg{width:24px;height:24px;stroke:var(--ink);fill:none;stroke-width:1.8}
#livre-pop .fmt-summary .nm{font-family:var(--fdisplay);font-weight:800;font-size:15px}
#livre-pop .fmt-summary .ds{font-size:11.5px;color:var(--ink50);font-weight:600;margin-top:2px}
#livre-pop .fmt-summary .amt{margin-left:auto;text-align:right;font-family:var(--fdisplay);font-weight:800;font-size:20px}

/* dock à 2 boutons (Composer / Commander) */
#livre-pop .scr-cta.dock{flex-direction:row;gap:10px}
#livre-pop .scr-cta.dock .btn-ghost,#livre-pop .scr-cta.dock .btn-primary{flex:1;width:auto}

/* ============ COMPOSITION (compose) ============ */
#livre-pop .scr-gen{align-items:center;justify-content:center;text-align:center;padding:30px;background:radial-gradient(120% 80% at 50% 0%,var(--bg2),var(--bg))}
#livre-pop .gen-book3d{width:150px;height:190px;position:relative;perspective:900px;margin-bottom:30px}
#livre-pop .gen-book3d .bk-cover{position:absolute;inset:0;border-radius:6px 12px 12px 6px;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:var(--shadowLg);transform-origin:left center;animation:l-bkflip 2.6s ease-in-out infinite}
#livre-pop .gen-book3d .bk-page{position:absolute;inset:0;border-radius:6px 10px 10px 6px;background:var(--paper);box-shadow:0 8px 20px -10px rgba(0,0,0,.4)}
#livre-pop .gen-book3d .bk-page:nth-child(2){animation:l-bkpage 2.6s ease-in-out .1s infinite}
#livre-pop .gen-book3d .bk-page:nth-child(3){animation:l-bkpage 2.6s ease-in-out .25s infinite}
@keyframes l-bkflip{0%,100%{transform:rotateY(0deg)}50%{transform:rotateY(-150deg)}}
@keyframes l-bkpage{0%,100%{transform:rotateY(0deg)}50%{transform:rotateY(-110deg)}}
#livre-pop .gen-title{font-size:26px}
#livre-pop .gen-lead{color:var(--ink70);font-weight:600;font-size:14.5px;margin-top:12px;max-width:34ch;line-height:1.55}
#livre-pop .gen-bar{width:min(280px,80%);height:9px;border-radius:20px;background:var(--surface2);border:1px solid var(--line);overflow:hidden;margin:26px 0 10px}
#livre-pop .gen-bar i{display:block;height:100%;width:6%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:20px;transition:width .5s ease;animation:l-genbar 2.4s ease-in-out infinite}
@keyframes l-genbar{0%{width:8%}50%{width:64%}100%{width:90%}}
#livre-pop .gen-step{font-size:12.5px;color:var(--ink50);font-weight:700;min-height:18px}
#livre-pop .gen-leave{margin-top:28px}
/* écran « se prépare » / erreur (réutilise scr-gen) */
#livre-pop .scr-generr{justify-content:center;text-align:center}
#livre-pop .ge-ic{font-size:46px}
#livre-pop .gen-note{font-size:13.5px;font-weight:600;color:var(--ink70);text-align:center;max-width:32ch;margin:12px auto 0;line-height:1.55}

/* ============ TOP BAR partagée (aperçu / liseuse / reliure / commande / retouches) ============ */
#livre-pop .pv-top{display:flex;align-items:center;gap:10px;padding:calc(14px + env(safe-area-inset-top)) 14px 12px;min-height:60px;background:var(--surface);border-bottom:1px solid var(--line);flex-shrink:0;z-index:20}
#livre-pop .pv-titlewrap{min-width:0;flex:1}
#livre-pop .pv-ttl{font-family:var(--fdisplay);font-weight:800;font-size:18px;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#livre-pop .pv-sub{font-size:11.5px;color:var(--ink50);font-weight:600;margin-top:1px}
#livre-pop .pv-edit{font-family:var(--fdisplay);font-weight:800;font-size:13px;color:var(--accentInk);background:var(--accent);padding:9px 14px;border-radius:11px;min-height:40px}

/* ============ APERÇU (flipbook + rail) ============ */
#livre-pop .scr-preview{overflow:hidden}
#livre-pop .preview-wrap{flex:1;min-height:0;display:flex;flex-direction:column}
#livre-pop .flip-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;background:var(--canvas);position:relative;overflow:hidden;padding:22px}
#livre-pop .pv-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow);z-index:12;opacity:.94;font-size:20px;color:var(--ink)}
#livre-pop .pv-arrow.l{left:10px} #livre-pop .pv-arrow.r{right:10px}
#livre-pop .pv-arrow:disabled{opacity:.3}
#livre-pop .pv-book{background:var(--paper);box-shadow:var(--shadowLg);overflow:hidden;border-radius:3px;width:100%;max-width:100%;max-height:100%;aspect-ratio:297/210}
/* double-page (carte) en feuilleter : plein écran panoramique (pleine largeur, sans padding latéral) */
#livre-pop .flip-stage.nopad{padding-left:4px;padding-right:4px}
#livre-pop .pv-book.spread{width:100%;max-height:100%}
#livre-pop .pv-book.flip{animation:l-pageflip .4s cubic-bezier(.2,.7,.2,1)}
@keyframes l-pageflip{0%{opacity:.35;transform:rotateY(-22deg) translateX(12px);transform-origin:left center}100%{opacity:1;transform:none}}
#livre-pop .pv-cap{flex-shrink:0;text-align:center;font-size:12px;font-weight:700;color:var(--ink50);padding:8px 16px 0}
#livre-pop .pv-cap b{color:var(--ink)}
#livre-pop .pv-rail{flex-shrink:0;background:var(--surface);border-top:1px solid var(--line);padding:10px;display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}
#livre-pop .pv-rail::-webkit-scrollbar{display:none}
#livre-pop .pv-rail .rl{flex:0 0 auto;width:48px;aspect-ratio:297/210;border-radius:6px;overflow:hidden;border:2px solid transparent;background:var(--paper);position:relative;transition:.14s}
#livre-pop .pv-rail .rl.on{border-color:var(--accent)}
#livre-pop .pv-rail .rl .n{position:absolute;bottom:0;left:0;right:0;font-size:8px;text-align:center;font-weight:800;background:rgba(20,23,27,.4);color:#fff;z-index:3}
#livre-pop .pv-meta{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:8px 16px;font-size:12px;color:var(--ink50);font-weight:600;background:var(--surface);border-top:1px solid var(--line)}
#livre-pop .pv-meta b{color:var(--ink)} #livre-pop .pv-sel{color:var(--vertDeep);font-weight:700}

/* ====== placeholder de page (en attendant le rendu PDF réel) ====== */
#livre-pop .bk-ph{position:relative;width:100%;height:100%;background:var(--paper);overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6%;text-align:center;padding:8%}
#livre-pop .bk-ph.cover{background:linear-gradient(135deg,var(--accent),var(--accent2))}
#livre-pop .bk-ph.cover .bkp-lab,#livre-pop .bk-ph.cover .bkp-ic{color:#fff}
#livre-pop .bk-ph.map{background:radial-gradient(120% 90% at 80% 8%,#CDEBB2,transparent 50%),var(--eauPale)}
#livre-pop .bk-ph.pale{background:var(--surface2)}
#livre-pop .bkp-ic{font-size:9%;line-height:1;opacity:.5;color:var(--ink50)}
#livre-pop .bkp-lab{font-family:var(--fdisplay);font-weight:800;font-size:7%;line-height:1.1;color:var(--ink)}
#livre-pop .bkp-soon{font-size:4.5%;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink50)}
#livre-pop .bk-ph.cover .bkp-soon{color:rgba(255,255,255,.85)}
#livre-pop .pv-rail .bkp-lab{font-size:7px} #livre-pop .pv-rail .bkp-ic{font-size:12px} #livre-pop .pv-rail .bkp-soon{display:none}

/* ============ PAGES RÉELLES (images servies par le worker) ============ */
#livre-pop .bk-pg{position:relative;width:100%;height:100%;overflow:hidden;background:var(--surface2);display:block}
#livre-pop .bk-pg img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;transition:opacity .35s}
#livre-pop .bk-pg.loaded img{opacity:1}
#livre-pop .bk-pg .bkp-sk{position:absolute;inset:0;background:linear-gradient(110deg,var(--surface) 30%,var(--surface2) 50%,var(--surface) 70%);background-size:220% 100%;animation:l-sk 1.15s linear infinite}
#livre-pop .bk-pg.loaded .bkp-sk{display:none}
@keyframes l-sk{from{background-position:120% 0}to{background-position:-120% 0}}

/* ====== APERÇU HTML VIVANT (P-B) : cadre iframe net + vectoriel, mis à l'échelle en JS ====== */
#livre-pop .bk-fr{position:relative;width:100%;height:100%;overflow:hidden;background:var(--paper);display:block}
#livre-pop .bk-fr .bk-frame{position:absolute;top:0;left:0;border:0;background:transparent;display:block;pointer-events:none}
/* aperçu flipbook éditable (P-C) : le cadre reçoit les taps -> édition de texte in-place dans l'iframe */
#livre-pop .bk-fr.editable .bk-frame{pointer-events:auto}
#livre-pop .bk-fr .bkp-sk{position:absolute;inset:0;background:linear-gradient(110deg,var(--surface) 30%,var(--surface2) 50%,var(--surface) 70%);background-size:220% 100%;animation:l-sk 1.15s linear infinite}
#livre-pop .bk-fr.loaded .bkp-sk{display:none}
/* en liseuse (spread / feuille qui tourne), le cadre HTML remplit toujours sa moitié (offset géré en JS) */
#livre-pop .bk-open .leaf .bk-fr,#livre-pop .rd-turn .rt-face .bk-fr{position:absolute!important;inset:0;width:100%!important;height:100%!important;left:0!important}

/* ============ LISEUSE (double-page + tourne-page courbure 3D + zoom) ============ */
#livre-pop .scr-reader{overflow:hidden}
#livre-pop .reader{flex:1;min-height:0;background:var(--canvas);display:flex;flex-direction:column}
#livre-pop .reader-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;touch-action:none;perspective:2000px}
#livre-pop .bk-open{position:relative;display:flex;box-shadow:var(--shadowLg);background:var(--paper);transform-origin:center;will-change:transform;--leafAR:297/210}
#livre-pop .bk-open .leaf{position:relative;background:var(--paper);overflow:hidden;width:50%;aspect-ratio:var(--leafAR)}
#livre-pop .bk-open .leaf.empty{background:transparent;box-shadow:none}
#livre-pop .rd-spine{position:absolute;top:0;bottom:0;left:50%;width:24px;transform:translateX(-50%);pointer-events:none;z-index:5;
  background:linear-gradient(90deg,rgba(0,0,0,0),rgba(0,0,0,.16) 46%,rgba(0,0,0,.05) 50%,rgba(0,0,0,.16) 54%,rgba(0,0,0,0))}
#livre-pop .bk-open.cover .rd-spine,#livre-pop .bk-open.pair .rd-spine{background:linear-gradient(90deg,rgba(0,0,0,0),rgba(0,0,0,.06) 50%,rgba(0,0,0,0))}
/* spread (double-page) découpé en deux moitiés */
#livre-pop .bk-open.wide .leaf .bk-ph,#livre-pop .bk-open.wide .leaf .bk-pg{position:absolute;top:0;height:100%;width:200%}
#livre-pop .bk-open.wide .leaf .bk-pg img{object-fit:cover}
#livre-pop .bk-open.wide .wide-l .bk-ph,#livre-pop .bk-open.wide .wide-l .bk-pg{left:0}
#livre-pop .bk-open.wide .wide-r .bk-ph,#livre-pop .bk-open.wide .wide-r .bk-pg{left:-100%}
/* carte en Édition : un seul cadre plein largeur (pas de découpe l/r) -> drag d'étiquettes dans un repère unique */
#livre-pop .bk-open.wide-edit .leaf.wide-full{width:100%;height:100%;aspect-ratio:auto}
/* feuille qui tourne — courbure 3D (variante curl du design) */
#livre-pop .rd-turn{position:absolute;top:0;bottom:0;width:50%;transform-style:preserve-3d;transition:transform .62s cubic-bezier(.2,.7,.2,1);z-index:8;will-change:transform}
#livre-pop .rd-turn.fwd{left:50%;transform-origin:left center}
#livre-pop .rd-turn.bwd{left:0;transform-origin:right center}
#livre-pop .rd-turn .rt-face{position:absolute;inset:0;backface-visibility:hidden;overflow:hidden;background:var(--paper)}
#livre-pop .rd-turn .rt-face .bk-ph,#livre-pop .rd-turn .rt-face .bk-pg{position:absolute!important;inset:0;width:100%!important;height:100%!important;left:0!important}
#livre-pop .rd-turn .rt-sheen{position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,.35),rgba(255,255,255,0) 40%);opacity:0;transition:opacity .3s}
#livre-pop .rd-turn.bwd .rt-sheen{background:linear-gradient(270deg,rgba(255,255,255,.35),rgba(255,255,255,0) 40%)}
/* navigation + zoom (liseuse) */
#livre-pop .rd-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow);z-index:12;opacity:.92;font-size:20px;color:var(--ink)}
#livre-pop .rd-arrow.l{left:10px} #livre-pop .rd-arrow.r{right:10px}
#livre-pop .rd-arrow:disabled{opacity:.3}
#livre-pop .zoomctl{position:absolute;right:10px;bottom:10px;display:flex;flex-direction:column;gap:6px;z-index:12}
#livre-pop .zoomctl button{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow);font-family:var(--fdisplay);font-weight:800;font-size:20px;color:var(--ink)}
/* barre de zoom (slider) — pilote le zoom sans gestes tactiles (zéro conflit avec l'édition).
   Intégrée dans la barre du bas (book-bottom), ne superpose plus l'album. */
#livre-pop .zoombar{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
#livre-pop .zoombar .zb-ic{font-family:var(--fdisplay);font-weight:800;font-size:16px;color:var(--ink70);width:14px;text-align:center;flex-shrink:0}
#livre-pop .zb-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:4px;background:var(--line);outline:none;margin:0}
#livre-pop .zb-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:var(--shadow);cursor:pointer}
#livre-pop .zb-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:var(--shadow);cursor:pointer}

/* ====== ÉCRAN « MON LIVRE » : bandes slim (album ~80%), marges sûres barre Android (paysage) ====== */
/* haut : back · format au centre · toggle Lecture/Édition. Plus court que pv-top + safe-area latérale. */
#livre-pop .book-top{min-height:0;gap:8px;padding-top:calc(6px + env(safe-area-inset-top));padding-bottom:6px;padding-left:calc(12px + env(safe-area-inset-left));padding-right:calc(12px + env(safe-area-inset-right))}
#livre-pop .book-top .nav-back{width:38px;height:38px}
#livre-pop .book-top .rdo{padding:6px 12px}
#livre-pop .book-fmt{flex:1;min-width:0;text-align:center;font-family:var(--fb);font-size:12px;font-weight:700;color:var(--ink70);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* bas : slider de zoom (gauche, intégré) + numéro de page calé à droite. Slim + safe-area. */
#livre-pop .book-bottom{flex-shrink:0;display:flex;align-items:center;gap:14px;background:var(--surface);border-top:1px solid var(--line);padding:8px calc(14px + env(safe-area-inset-right)) calc(8px + env(safe-area-inset-bottom)) calc(14px + env(safe-area-inset-left))}
#livre-pop .book-bottom .pageno{flex-shrink:0;margin-left:auto;font-family:var(--fdisplay);font-weight:800;font-size:12px;font-variant-numeric:tabular-nums;color:var(--ink);text-align:right;white-space:nowrap}
#livre-pop .book-bottom .pageno b{color:var(--ink)}
/* flèches de navigation : décalées vers l'intérieur pour ne pas passer sous la barre Android (paysage) */
#livre-pop .scr-book .rd-arrow.l{left:calc(10px + env(safe-area-inset-left))}
#livre-pop .scr-book .rd-arrow.r{right:calc(10px + env(safe-area-inset-right))}
/* la scène respecte les marges sûres -> l'album se centre dans la zone VISIBLE, pas sous la barre Android */
#livre-pop .scr-book .reader-stage{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
#livre-pop .book-gear{width:38px;height:38px;flex-shrink:0}
#livre-pop .book-gear svg{width:20px;height:20px;stroke:var(--ink);fill:none;stroke-width:1.7}

/* ====== FEUILLE DE RÉGLAGES (bottom-sheet) — remplace l'écran Retouches ====== */
#livre-pop .lsheet{position:absolute;inset:0;z-index:50;pointer-events:none}
#livre-pop .lsheet-back{position:absolute;inset:0;background:rgba(20,23,27,.42);opacity:0;transition:.22s;pointer-events:auto}
#livre-pop .lsheet.show .lsheet-back{opacity:1}
#livre-pop .lsheet-panel{position:absolute;left:0;right:0;bottom:0;max-height:88%;display:flex;flex-direction:column;background:var(--bg);border-radius:20px 20px 0 0;box-shadow:var(--shadowLg);transform:translateY(100%);transition:transform .24s cubic-bezier(.2,.7,.2,1);pointer-events:auto}
#livre-pop .lsheet.show .lsheet-panel{transform:translateY(0)}
#livre-pop .lsheet-head{position:relative;display:flex;align-items:center;gap:10px;padding:12px 16px 10px;border-bottom:1px solid var(--line);flex-shrink:0}
#livre-pop .lsheet-grab{position:absolute;top:6px;left:50%;transform:translateX(-50%);width:38px;height:4px;border-radius:4px;background:var(--line)}
#livre-pop .lsheet-ttl{flex:1;font-family:var(--fdisplay);font-weight:800;font-size:16px;color:var(--ink);margin-top:3px}
#livre-pop .lsheet-x{font-family:var(--fdisplay);font-weight:800;font-size:13px;color:var(--accentInk);background:var(--accent);padding:9px 16px;border-radius:11px;min-height:40px;margin-top:3px;flex-shrink:0}
#livre-pop .lsheet-body{flex:1;min-height:0;overflow-y:auto;scrollbar-width:none;padding:0 env(safe-area-inset-right) calc(16px + env(safe-area-inset-bottom)) env(safe-area-inset-left)}
#livre-pop .lsheet-body::-webkit-scrollbar{display:none}
#livre-pop .dblpage-flag{position:absolute;left:50%;top:10px;transform:translateX(-50%);z-index:12;font-family:var(--fdisplay);font-weight:800;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;background:var(--eauDeep);color:#fff;padding:5px 11px;border-radius:20px;opacity:.94}
#livre-pop .reader-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--surface);border-top:1px solid var(--line)}
#livre-pop .reader-bar .pageno{font-family:var(--fdisplay);font-weight:800;font-size:13px;font-variant-numeric:tabular-nums;text-align:center;flex:1;min-width:0}
#livre-pop .reader-bar .rd-note{font-size:11px;font-weight:700;color:var(--eauDeep)}
#livre-pop .rd-orient{display:flex;gap:4px;background:var(--surface2);border-radius:11px;padding:3px;border:1px solid var(--line)}
#livre-pop .rdo{font-family:var(--fdisplay);font-weight:800;font-size:12px;color:var(--ink70);padding:7px 11px;border-radius:8px;transition:.12s}
#livre-pop .rdo.on{background:var(--accent);color:var(--accentInk)}

/* zone scrollable interne (reliure / retouches / commande) — la barre CTA reste ancrée */
#livre-pop .body-scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-width:none}
#livre-pop .body-scroll::-webkit-scrollbar{display:none}

/* ============ RELIURE (binding) ============ */
#livre-pop .scr-binding{overflow:hidden}
#livre-pop .bind-intro{padding:14px 16px 0;font-size:13px;color:var(--ink70);font-weight:600;text-align:center}
#livre-pop .bind-cards{display:flex;flex-direction:column;gap:12px;padding:14px 16px 0}
#livre-pop .bind-card{position:relative;text-align:left;background:var(--surface);border:1.5px solid var(--line);border-radius:16px;padding:15px;transition:.14s;width:100%}
#livre-pop .bind-card.sel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
#livre-pop .bind-pop{position:absolute;top:-9px;left:15px;font-family:var(--fdisplay);font-size:10px;font-weight:800;color:var(--accentInk);background:var(--accent);padding:4px 10px;border-radius:20px;box-shadow:var(--shadow)}
#livre-pop .bind-vis{height:74px;border-radius:12px;margin-bottom:12px;display:grid;place-items:center;background:var(--canvas);overflow:hidden;perspective:300px}
#livre-pop .bv-book{width:88px;height:56px;border-radius:3px 6px 6px 3px;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:var(--shadowLg);position:relative}
#livre-pop .bind-vis.hardcover .bv-book{transform:rotateY(-22deg);border-left:5px solid rgba(0,0,0,.18)}
#livre-pop .bind-vis.layflat .bv-book{width:104px;height:50px;background:linear-gradient(90deg,var(--accent2),var(--accent) 49%,var(--accentDeep) 51%,var(--accent))}
#livre-pop .bind-vis.layflat .bv-book::after{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:rgba(255,255,255,.4)}
#livre-pop .bind-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
#livre-pop .bind-nom{font-family:var(--fdisplay);font-weight:800;font-size:17px;color:var(--ink)}
#livre-pop .bind-price{font-family:var(--fdisplay);font-weight:800;font-size:20px;color:var(--accentDeep)}
#livre-pop .bind-tag{font-size:12.5px;font-weight:700;color:var(--ink70);margin-top:2px}
#livre-pop .bind-desc{font-size:12.5px;color:var(--ink70);font-weight:500;line-height:1.5;margin-top:8px}
#livre-pop .bind-pros{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
#livre-pop .bind-pros li{font-size:12px;font-weight:600;color:var(--ink);padding-left:18px;position:relative}
#livre-pop .bind-pros li::before{content:"✓";position:absolute;left:0;color:var(--vertDeep);font-weight:800}
#livre-pop .bind-pages{font-size:11px;color:var(--ink50);font-weight:600;margin-top:10px;padding-top:9px;border-top:1px solid var(--line2)}
#livre-pop .bind-check{position:absolute;top:15px;right:15px;width:24px;height:24px;border-radius:50%;border:2px solid var(--ink20);display:grid;place-items:center;color:var(--accentInk);font-size:12px;font-weight:800;transition:.14s}
#livre-pop .bind-card.sel .bind-check{background:var(--accent);border-color:var(--accent)}

/* ============ RETOUCHES (edit — fonctionnel, restyle léger) ============ */
#livre-pop .scr-edit{overflow:hidden}
#livre-pop .edit-note{padding:14px 16px 0;font-size:13px;color:var(--ink70);font-weight:600;text-align:center}
#livre-pop .edit-group{padding:16px 16px 0}
#livre-pop .eg-lab{font-family:var(--fdisplay);font-size:12px;font-weight:800;color:var(--ink);margin-bottom:8px}
#livre-pop .eg-input{width:100%;font-family:var(--fb);font-size:15px;font-weight:600;color:var(--ink);background:var(--surface);border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;outline:none}
#livre-pop .eg-input:focus{border-color:var(--accent)}
#livre-pop .eg-input+.eg-input{margin-top:8px}
#livre-pop .eg-covers{display:flex;gap:8px;flex-wrap:wrap}
#livre-pop .ed-cov{width:54px;height:54px;border-radius:11px;border:2.5px solid transparent;background-size:cover;background-position:center;background-color:var(--surface2)}
#livre-pop .ed-cov.on{border-color:var(--accent)}
#livre-pop .eg-stages{display:flex;flex-direction:column;gap:7px}
#livre-pop .ed-stage{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:11px 12px;font-size:13.5px;font-weight:700;color:var(--ink)}
#livre-pop .es-n{width:20px;height:20px;border-radius:50%;background:var(--surface2);display:grid;place-items:center;font-size:11px;color:var(--ink70);flex-shrink:0}
#livre-pop .es-nm{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#livre-pop .es-ph{font-size:11px;color:var(--ink50);font-weight:600}
#livre-pop .es-ord{display:flex;gap:2px}
#livre-pop .es-ord button{width:30px;height:30px;border-radius:8px;background:var(--surface2);color:var(--ink70);font-size:12px;display:grid;place-items:center}
#livre-pop .es-ord button:disabled{opacity:.3}
/* --- format & reliure dans Retouches --- */
#livre-pop .eg-chips{display:flex;gap:8px;margin-bottom:9px}
#livre-pop .eg-chip{flex:1;display:flex;flex-direction:column;gap:2px;align-items:flex-start;background:var(--surface);border:1.5px solid var(--line);border-radius:12px;padding:10px 11px;font-family:var(--fdisplay);font-weight:800;font-size:13.5px;color:var(--ink)}
#livre-pop .eg-chip.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
#livre-pop .eg-chip.soon{opacity:.55;cursor:default}
#livre-pop .eg-chip.soon .ec-sub{color:var(--amber);font-weight:800;text-transform:uppercase;letter-spacing:.04em}
#livre-pop .eg-chip .ec-sub{font-family:var(--fb);font-weight:600;font-size:10.5px;color:var(--ink50)}
#livre-pop .eg-binds{display:flex;gap:8px}
#livre-pop .eg-bind{flex:1;display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--line);border-radius:12px;padding:10px 11px}
#livre-pop .eg-bind.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
#livre-pop .eg-bind .eb-ic{width:26px;height:26px;flex-shrink:0;display:grid;place-items:center}
#livre-pop .eg-bind .eb-ic svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:1.8}
#livre-pop .eg-bind .eb-nm{flex:1;font-family:var(--fdisplay);font-weight:800;font-size:12.5px;color:var(--ink);line-height:1.1;text-align:left}
#livre-pop .eg-bind .eb-amt{font-family:var(--fdisplay);font-weight:800;font-size:14px;color:var(--accentDeep)}
#livre-pop .eg-fmtnote{margin-top:9px;font-size:12px;font-weight:600;color:var(--ink70);text-align:center}
#livre-pop .eg-fmtnote b{font-family:var(--fdisplay);color:var(--accentDeep)}
/* --- détail par étape (nom + note + photos) --- */
#livre-pop .eg-steps{display:flex;flex-direction:column;gap:11px}
#livre-pop .es-block{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:11px 12px}
#livre-pop .es-head{display:flex;align-items:center;gap:9px;margin-bottom:8px}
#livre-pop .es-name{padding:9px 11px;font-size:14px}
#livre-pop .es-noteinput{display:block;width:100%;font-family:var(--fb);font-size:13.5px;font-weight:600;color:var(--ink);background:var(--bg);border:1.5px solid var(--line);border-radius:11px;padding:9px 11px;outline:none;resize:none;line-height:1.4}
#livre-pop .es-noteinput:focus{border-color:var(--accent)}
#livre-pop .es-photos{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
#livre-pop .es-photo{position:relative;width:50px;height:50px;border-radius:10px;border:1.5px solid var(--line);background-size:cover;background-position:center;background-color:var(--surface2)}
#livre-pop .es-photo .esp-x{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--ink);color:#fff;font-size:12px;font-weight:800;display:grid;place-items:center;box-shadow:0 1px 3px rgba(0,0,0,.3)}
#livre-pop .es-photo.off{filter:grayscale(1);opacity:.45}
#livre-pop .es-photo.off .esp-x{background:var(--vertDeep)}
#livre-pop .es-empty{font-size:12px;color:var(--ink50);font-weight:600;margin-top:6px}
#livre-pop .eg-removed{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:6px 13px}
#livre-pop .er-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;font-size:13px;font-weight:600;color:var(--ink70);border-bottom:1px solid var(--line2)}
#livre-pop .er-row:last-child{border-bottom:none}
#livre-pop .er-row b{color:var(--ink)}

/* ============ COMMANDE (order) ============ */
#livre-pop .scr-order{overflow:hidden}
#livre-pop .ord-recap{display:flex;gap:14px;align-items:center;padding:14px 16px 0}
#livre-pop .or-book{width:64px;height:82px;border-radius:3px 7px 7px 3px;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:var(--shadow);flex-shrink:0}
#livre-pop .or-book.layflat{width:84px;height:62px}
#livre-pop .or-title{font-family:var(--fdisplay);font-weight:800;font-size:18px;line-height:1.05}
#livre-pop .or-sub{font-size:13px;font-weight:700;color:var(--ink70);margin-top:4px}
#livre-pop .or-format{font-size:12px;color:var(--ink50);font-weight:600;margin-top:2px}
#livre-pop .ord-lines{margin:18px 16px 0;background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:6px 15px}
#livre-pop .ol{display:flex;justify-content:space-between;align-items:center;padding:11px 0;font-size:14px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line2)}
#livre-pop .ol.muted{color:var(--ink50)} #livre-pop .ol.muted b{color:var(--vertDeep);font-weight:700}
#livre-pop .ol.total{border-bottom:none;font-weight:800}#livre-pop .ol.total b{font-family:var(--fdisplay);font-size:20px;color:var(--accentDeep)}
#livre-pop .ol.total i{font-size:11px;font-weight:600;color:var(--ink50);font-style:normal}
#livre-pop .ord-form{padding:16px 16px 0}
#livre-pop .of-lab{font-family:var(--fdisplay);font-size:12px;font-weight:800;margin-bottom:8px}
#livre-pop .ord-trust{display:flex;flex-wrap:wrap;gap:8px;padding:16px 16px 0;justify-content:center}
#livre-pop .ord-trust span{font-size:11px;font-weight:700;color:var(--ink70);background:var(--surface);border:1px solid var(--line);padding:7px 11px;border-radius:30px}

/* ============ CONFIRMATION (confirm) ============ */
#livre-pop .scr-confirm{overflow:hidden}
#livre-pop .confirm-scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-width:none;display:flex;flex-direction:column;align-items:center;text-align:center;padding:calc(40px + env(safe-area-inset-top)) 30px 24px}
#livre-pop .confirm-scroll::-webkit-scrollbar{display:none}
#livre-pop .cf-burst{position:relative;width:130px;height:130px;display:grid;place-items:center}
#livre-pop .cf-book{width:74px;height:92px;border-radius:4px 8px 8px 4px;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:var(--shadow);animation:l-cfpop .6s cubic-bezier(.3,1.4,.4,1) both}
@keyframes l-cfpop{from{opacity:0;transform:scale(.5) rotate(-12deg)}to{opacity:1;transform:none}}
#livre-pop .cf-ring{position:absolute;width:90px;height:90px;border-radius:50%;border:3px solid var(--accent);opacity:0;animation:l-cfring 1s ease-out .2s}
@keyframes l-cfring{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.7);opacity:0}}
#livre-pop .cf-spark{position:absolute;color:var(--amber);font-size:18px;animation:l-sp 1.6s ease-in-out infinite}
#livre-pop .cf-spark.a{top:0;right:18px}#livre-pop .cf-spark.b{bottom:14px;left:14px;animation-delay:.4s;color:var(--eauDeep)}#livre-pop .cf-spark.c{top:20px;left:6px;animation-delay:.8s;color:var(--accent)}
@keyframes l-sp{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
#livre-pop .cf-title{font-family:var(--fdisplay);font-weight:800;font-size:27px;margin-top:14px;line-height:1.05}
#livre-pop .cf-text{font-size:14px;color:var(--ink70);font-weight:500;line-height:1.55;margin-top:10px;max-width:30em}
#livre-pop .cf-card{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 20px;margin-top:22px}
#livre-pop .cf-steps{display:flex;flex-direction:column;gap:14px;text-align:left}
#livre-pop .cf-step{display:flex;align-items:center;gap:11px;font-family:var(--fdisplay);font-weight:800;font-size:13.5px;color:var(--ink50);position:relative}
#livre-pop .cf-step .d{width:14px;height:14px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;position:relative;z-index:2;background:var(--surface)}
#livre-pop .cf-step:not(:last-child)::after{content:"";position:absolute;left:6px;top:16px;width:2px;height:16px;background:var(--line)}
#livre-pop .cf-step.done{color:var(--ink)} #livre-pop .cf-step.done .d{background:var(--vert);border-color:var(--vert)}
#livre-pop .cf-step.now{color:var(--ink)} #livre-pop .cf-step.now .d{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px rgba(255,138,76,.22)}

/* ============ TOAST ============ */
#livre-pop .toast{position:absolute;left:50%;bottom:90px;transform:translateX(-50%) translateY(16px);background:var(--ink);color:var(--bg);font-family:var(--fdisplay);font-weight:800;font-size:13px;padding:11px 18px;border-radius:30px;box-shadow:var(--shadowLg);opacity:0;pointer-events:none;transition:.22s;z-index:60;white-space:nowrap}
#livre-pop .toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
