/* Will You Take My Hand — site dynamique (livre + blog), thème du livre */
@font-face{font-family:"Ingrid Darling";src:url("fonts/IngridDarling-Regular.ttf") format("truetype");font-display:swap}
:root{
  --fuchsia:#B20A6C; --rose-mid:#E39EB0; --rose-pale:#FAD1D9; --rose-deep:#C97A8A;
  --royal:#172090; --navy:#0A1038; --ivory:#FAF5E6; --ivory-warm:#F5EDD9;
  --ink:#29212E; --sepia:#5C4733;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:Georgia,"Times New Roman",serif;background:#13162a;color:#eee;line-height:1.5}
img{max-width:100%}
.app{max-width:1180px;margin:0 auto;padding:16px}

/* ===== Entête du site ===== */
.site-header{display:flex;align-items:center;gap:16px;padding:18px 8px 14px;border-bottom:1px solid rgba(227,158,176,.25);margin-bottom:18px}
.site-header .site-emblem{height:58px;width:auto}
.site-header .site-title{font-size:26px;color:var(--rose-pale);letter-spacing:.5px}
.site-header .site-title small{display:block;font-size:13px;color:var(--rose-mid);font-style:italic;margin-top:2px}
.site-header .modes{margin-left:auto;display:flex;gap:8px}
.mode-btn{font-family:inherit;font-size:14px;padding:9px 18px;border-radius:22px;border:1px solid var(--rose-deep);background:transparent;color:var(--rose-pale);cursor:pointer;transition:.2s}
.mode-btn.active{background:var(--fuchsia);border-color:var(--fuchsia);color:#fff}

/* ===== Barre d'outils CMS (admin) ===== */
.toolbar{display:none;gap:8px;align-items:center;flex-wrap:wrap;background:rgba(10,16,40,.95);
  padding:10px 14px;border-radius:12px;margin-bottom:16px;border:1px solid rgba(227,158,176,.3)}
.toolbar.admin{display:flex}
.toolbar .group{display:flex;gap:6px;align-items:center}
.toolbar .sp{margin-left:auto}
.toolbar button{font-family:inherit;font-size:13px;padding:8px 13px;border-radius:8px;border:1px solid var(--rose-deep);background:transparent;color:var(--rose-pale);cursor:pointer;transition:.2s}
.toolbar button:hover{background:var(--fuchsia);border-color:var(--fuchsia);color:#fff}
.toolbar button.primary{background:var(--fuchsia);border-color:var(--fuchsia);color:#fff}
.toolbar .nav input{width:52px;text-align:center;padding:6px;border-radius:6px;border:1px solid var(--rose-deep);background:#0a1028;color:#fff;font-family:inherit}

/* ===== MODE LIVRE (feuilleté) ===== */
.book{display:flex;justify-content:center}
.page-wrap{position:relative;width:100%;max-width:1000px}
.page{position:relative;width:100%;max-width:1000px;aspect-ratio:1.414/1;border-radius:6px;overflow:hidden;box-shadow:0 10px 40px rgba(0,0,0,.5);background:var(--royal)}
.page.royal{background:linear-gradient(135deg,var(--navy),var(--royal))}
.page.ivory{background:linear-gradient(135deg,var(--ivory),var(--ivory-warm))}

.cover-grid{display:grid;grid-template-columns:46% 54%;height:100%}
.cover-left{padding:8% 6%;display:flex;flex-direction:column;justify-content:center;position:relative}
.cover-left .bar{position:absolute;left:5%;top:12%;bottom:12%;width:4px;background:linear-gradient(var(--fuchsia),var(--rose-mid))}
.cover-emblem-top{width:14%;margin-bottom:5%}
.cover-sub{color:var(--rose-mid);font-size:1.1vw;font-style:italic;margin-bottom:3%}
.cover-title{color:var(--fuchsia);font-size:3.6vw;font-weight:bold;line-height:1.1;margin-bottom:2%}
.cover-rule{height:1px;background:var(--rose-mid);width:60%;margin:3% 0}
.cover-authors{color:var(--rose-pale);font-size:1.3vw;margin-bottom:1.5%}
.cover-years{color:var(--rose-mid);font-size:.95vw}
.cover-img{width:100%;height:100%;object-fit:cover;object-position:center 30%}

.backcover{display:flex;align-items:center;justify-content:center;height:100%;position:relative;background:var(--navy)}
.backcover img.bc-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.backcover .veil{position:absolute;inset:0;background:linear-gradient(rgba(10,16,40,.82),rgba(10,16,40,.45))}
.backcover .bc-inner{position:relative;text-align:center;z-index:2}
.backcover .bc-emblem{width:7%;margin:0 auto 3%}
.backcover h2{color:#fff;font-style:italic;font-size:3vw;margin-bottom:2%}
.backcover .bc-rule{height:1px;width:14%;background:var(--rose-mid);margin:2% auto}
.backcover .bc-authors{color:var(--rose-pale);font-size:1.2vw}
.backcover .bc-years{color:var(--rose-mid);font-size:.9vw;margin-top:1%}

/* Poème — la taille du texte est pilotée en JS (variable --pf) pour ne jamais déborder */
.poem{display:grid;height:100%}
.poem.left{grid-template-columns:46% 54%}
.poem.right{grid-template-columns:54% 46%}
.poem-photo-wrap{overflow:hidden;position:relative}
.poem-photo{width:100%;height:100%;object-fit:cover;object-position:var(--op,center 28%)}
.poem-text{padding:4% 5%;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.poem.royal .poem-text{color:var(--rose-pale)}
.poem.ivory .poem-text{color:var(--ink)}
.poem-head{display:flex;align-items:center;gap:8px;margin-bottom:2%}
.poem-gimmick{height:1.6em;width:auto;opacity:.92}
.poem-date{font-family:Arial,sans-serif;font-size:.8vw;letter-spacing:.5px}
.poem.royal .poem-date{color:var(--rose-mid)}
.poem.ivory .poem-date{color:var(--rose-deep)}
.poem-date-rule{height:1px;width:8%;margin-bottom:3%}
.poem.royal .poem-date-rule{background:var(--rose-mid)}
.poem.ivory .poem-date-rule{background:var(--rose-deep)}
.poem-lines{font-family:"Ingrid Darling",cursive;font-size:var(--pf,20px);line-height:1.5;white-space:pre-wrap}
.poem-lines.two-col{column-count:2;column-gap:6%}
.poem-sep{position:absolute;top:8%;bottom:8%;width:3px}
.poem.left .poem-sep{left:0}.poem.right .poem-sep{right:0}
.poem.royal .poem-sep{background:var(--fuchsia)}
.poem.ivory .poem-sep{background:var(--rose-deep)}
/* poème très long : photo en bandeau haut, texte pleine largeur dessous (2 colonnes) */
.poem.fulltext{display:flex;flex-direction:column}
.poem.fulltext .poem-photo-wrap{width:100%;height:34%;flex:0 0 34%}
.poem.fulltext .poem-photo{object-position:var(--op,center 30%)}
.poem.fulltext .poem-text{flex:1;justify-content:flex-start;padding-top:2.5%}
.poem.fulltext .poem-sep{display:none}
.poem.fulltext .poem-lines.two-col{column-count:2;column-gap:5%}

/* Collage */
.collage{height:100%;position:relative}
.collage-band{position:absolute;bottom:0;left:0;right:0;height:9%;display:flex;align-items:center;padding:0 4%;z-index:5}
.collage.royal .collage-band{background:linear-gradient(90deg,var(--fuchsia),#73031C);color:#fff;border-top:2px solid var(--rose-mid)}
.collage.ivory .collage-band{background:linear-gradient(90deg,var(--ivory-warm),#E5D9BD);color:var(--sepia);border-top:2px solid var(--rose-deep)}
.collage-band .lbl{font-style:italic;font-size:1.4vw}
.collage-band .cnt{margin-left:auto;font-family:Arial,sans-serif;font-size:.75vw;opacity:.85}
.collage-imgs{position:absolute;top:3%;left:3%;right:3%;bottom:12%;display:grid;gap:1.5%}
.collage-imgs.n1{grid-template-columns:1fr;grid-template-rows:1fr}
.collage-imgs.n2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}
.collage-imgs.n3{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.collage-imgs.n3 .c0{grid-column:1/3;grid-row:1}
.collage-imgs.n3 .c1{grid-column:1;grid-row:2}
.collage-imgs.n3 .c2{grid-column:2;grid-row:2}
.collage-imgs img{width:100%;height:100%;object-fit:cover;object-position:var(--op,center 30%);border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.collage.bg-landscape .collage-imgs{display:block}
.collage-bgimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.collage .veil{position:absolute;inset:0;background:rgba(10,16,40,.18)}
.vignette{position:absolute;border:3px solid #fff;object-fit:cover;box-shadow:0 6px 18px rgba(0,0,0,.5)}
.emblem-tl{position:absolute;top:3%;width:3.5%;z-index:6}
.poem .emblem-tl{right:4%}
.collage .emblem-tl{left:3%;top:auto;bottom:4.5%;width:3%;z-index:7}

.letter{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy),var(--royal));padding:4%}
.letter img{max-width:88%;max-height:88%;object-fit:contain;border:2px solid var(--rose-mid)}

/* ===== MODE BLOG (liste type "Heures") ===== */
.blog{max-width:1180px;margin:0 auto}
.blog-hero{text-align:center;padding:30px 16px 8px}
.blog-hero .kicker{color:var(--rose-mid);letter-spacing:3px;font-size:12px;font-family:Arial,sans-serif}
.blog-hero h2{color:var(--rose-pale);font-size:40px;margin:6px 0}
.blog-hero p{color:#b9b2c8;font-style:italic}
.blog-controls{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;margin:16px 0 26px}
.blog-controls input[type=search]{background:#0a1028;border:1px solid var(--rose-deep);color:#fff;border-radius:22px;padding:9px 16px;font-family:inherit;min-width:220px}
.blog-controls select{background:#0a1028;border:1px solid var(--rose-deep);color:var(--rose-pale);border-radius:22px;padding:9px 14px;font-family:Arial,sans-serif;font-size:13px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;padding:0 8px 40px}
.card{background:linear-gradient(160deg,#1b1f3a,#141830);border:1px solid rgba(227,158,176,.18);border-radius:14px;overflow:hidden;cursor:pointer;transition:.2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);border-color:var(--rose-mid);box-shadow:0 12px 30px rgba(0,0,0,.45)}
.card-cover{aspect-ratio:3/2;width:100%;object-fit:cover;object-position:var(--op,center 30%);background:#0a1028}
.card-body{padding:14px 16px 18px}
.card-date{font-family:Arial,sans-serif;font-size:11px;color:var(--rose-mid);letter-spacing:1px}
.card-title{font-family:"Ingrid Darling",cursive;font-size:24px;color:var(--rose-pale);margin:4px 0 8px;line-height:1.2}
.card-excerpt{font-size:13px;color:#aaa3bd;font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Lecture d'un texte (blog) */
.reader{max-width:780px;margin:0 auto;padding:10px 18px 60px}
.reader .back{color:var(--rose-mid);cursor:pointer;font-family:Arial,sans-serif;font-size:13px;margin-bottom:18px;display:inline-block}
.reader-cover{width:100%;aspect-ratio:16/7;object-fit:cover;object-position:var(--op,center 35%);border-radius:12px;margin-bottom:22px}
.reader-head{text-align:center;margin-bottom:8px}
.reader-date{font-family:Arial,sans-serif;font-size:12px;color:var(--rose-mid);letter-spacing:2px}
.reader-gimmick{height:46px;margin:14px auto 6px;display:block}
.reader-rule{height:1px;width:80px;background:var(--rose-mid);margin:14px auto 26px}
.reader-lines{font-family:"Ingrid Darling",cursive;font-size:27px;line-height:1.6;color:#efe7f2;white-space:pre-wrap;text-align:center}
.reader-inline-img{width:100%;border-radius:10px;margin:26px 0;border:1px solid rgba(227,158,176,.3)}

/* ===== Modals (éditeur, recadrage, login) ===== */
.editor,.crop-modal,.login-modal{position:fixed;inset:0;z-index:200;display:none}
.editor.open,.crop-modal.open,.login-modal.open{display:block}
.editor{background:rgba(8,10,24,.96);overflow-y:auto;padding:30px}
.editor .ed-box{max-width:780px;margin:0 auto;background:#12152a;border:1px solid var(--rose-deep);border-radius:14px;padding:26px}
.editor h2{color:var(--rose-pale);font-weight:normal;margin-bottom:18px;font-size:20px}
.editor label{display:block;color:var(--rose-mid);font-size:13px;margin:14px 0 5px;font-family:Arial,sans-serif}
.editor textarea,.editor input[type=text],.editor select{width:100%;background:#0a1028;color:#fff;border:1px solid #333a5c;border-radius:8px;padding:10px;font-family:"Ingrid Darling",cursive;font-size:18px;line-height:1.5}
.editor input[type=text],.editor select{font-family:Arial,sans-serif;font-size:14px}
.editor textarea{min-height:220px;resize:vertical}
.editor .row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.editor .ed-actions{margin-top:22px;display:flex;gap:10px;justify-content:flex-end}
.editor button{font-family:inherit;font-size:14px;padding:9px 18px;border-radius:8px;cursor:pointer;border:1px solid var(--rose-deep);background:transparent;color:var(--rose-pale)}
.editor button.primary{background:var(--fuchsia);border-color:var(--fuchsia);color:#fff}
.editor .thumb{max-width:160px;max-height:160px;border:2px solid var(--rose-mid);border-radius:6px;margin-top:8px}
.hint{font-size:12px;color:#8890b5;font-family:Arial,sans-serif;margin-top:6px}

.crop-modal{background:rgba(0,0,0,.9)}
.crop-modal .crop-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:20px}
.crop-stage{position:relative;max-width:90vw;max-height:68vh;overflow:hidden;touch-action:none}
.crop-stage img{display:block;max-width:90vw;max-height:68vh;user-select:none}
.crop-frame{position:absolute;border:2px dashed var(--rose-pale);box-shadow:0 0 0 9999px rgba(0,0,0,.55);cursor:move}
.crop-controls{margin-top:16px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center}
.crop-controls button{font-family:inherit;padding:8px 16px;border-radius:8px;cursor:pointer;border:1px solid var(--rose-deep);background:transparent;color:var(--rose-pale)}
.crop-controls button.primary{background:var(--fuchsia);border-color:var(--fuchsia);color:#fff}
.crop-controls label{color:var(--rose-mid);font-family:Arial,sans-serif;font-size:13px}
.crop-ratio{display:flex;gap:6px}
.crop-ratio button{font-size:12px;padding:5px 10px}
.crop-ratio button.on{background:var(--fuchsia);color:#fff;border-color:var(--fuchsia)}

.login-modal{background:rgba(8,10,24,.97)}
.login-box{max-width:380px;margin:14vh auto 0;background:#12152a;border:1px solid var(--rose-deep);border-radius:16px;padding:30px;text-align:center}
.login-box img{height:60px;margin-bottom:14px}
.login-box h3{color:var(--rose-pale);font-weight:normal;margin-bottom:16px}
.login-box input{width:100%;background:#0a1028;color:#fff;border:1px solid #333a5c;border-radius:8px;padding:11px;font-family:Arial,sans-serif;margin-bottom:14px}
.login-box button{width:100%;background:var(--fuchsia);color:#fff;border:none;border-radius:8px;padding:11px;font-family:inherit;font-size:15px;cursor:pointer}
.login-box .err{color:#ff8a8a;font-size:13px;font-family:Arial,sans-serif;min-height:18px}
.admin-login-link{position:fixed;bottom:10px;right:14px;font-size:11px;color:#555c80;cursor:pointer;font-family:Arial,sans-serif;z-index:60}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--fuchsia);color:#fff;padding:12px 22px;border-radius:30px;z-index:400;font-family:Arial,sans-serif;font-size:14px;opacity:0;transition:.3s;pointer-events:none}
.toast.show{opacity:1}
.edit-badge{position:absolute;top:10px;left:10px;z-index:20;background:var(--fuchsia);color:#fff;border:none;padding:7px 13px;border-radius:20px;font-family:Arial,sans-serif;font-size:12px;cursor:pointer;display:none}
body.admin .page-wrap:hover .edit-badge,body.admin .card .edit-badge{display:block}
.card .edit-badge{opacity:.95}

@media(max-width:760px){
  .site-header .site-title{font-size:20px}
  .cover-title{font-size:7vw}
  .blog-hero h2{font-size:30px}
  .reader-lines{font-size:22px}
}
