/* ══════════════════════════════════════════════════════
   Claire Dornac — CSS partagé (toutes pages)
   ══════════════════════════════════════════════════════ */

/* ── Variables ── */
:root{
  --bg:#FFFBEF; --bg2:#FDEAF1; --text:#2B1B20; --muted: rgba(43,27,32,.72);
  --plum:#5C1741; --magenta:#B5134E; --rose:#DB65A1;
  --card: rgba(255,255,255,.72); --card2: rgba(255,255,255,.62);
  --cardBorder: rgba(92,23,65,.12);
  --shadow: 0 18px 46px rgba(43,27,32,.14);
  --radius: 24px; --radius2: 16px; --focus: rgba(181,19,78,.28);
  --title: "Playfair Display", ui-serif, Georgia, serif;
  --body: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --fs-0: .875rem; --fs-1: 1rem; --fs-2: 1.125rem;
  --max: 1040px;
}

/* ── Reset ── */
*{ box-sizing:border-box; }
body{
  margin:0; font-family: var(--body);
  background: var(--bg); color: var(--text); line-height:1.7;
}
a{ color: var(--magenta); text-decoration:none; }
a:hover{ text-decoration:underline; }
a:focus{ outline: 3px solid var(--focus); outline-offset: 2px; border-radius: 8px; }

/* ── Background principal ── */
.bg{
  min-height:100vh; padding: 28px 16px 44px;
  background:
    radial-gradient(900px 520px at 15% 10%, rgba(181,19,78,.08), transparent 60%),
    radial-gradient(780px 520px at 86% 18%, rgba(92,23,65,.07), transparent 62%),
    linear-gradient(180deg, var(--bg) 0%, #FFF 60%, var(--bg2) 120%);
  position: relative; overflow:hidden;
}

/* ── Sparkles (décor animé) ── */
.sparkles{ position:absolute; inset:-40px; pointer-events:none; opacity:.32; filter: blur(.2px); }
.sparkles::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(6px 6px at 12% 22%, rgba(181,19,78,.18), transparent 62%),
    radial-gradient(5px 5px at 24% 48%, rgba(92,23,65,.14), transparent 62%),
    radial-gradient(7px 7px at 78% 18%, rgba(181,19,78,.14), transparent 62%),
    radial-gradient(4px 4px at 86% 44%, rgba(92,23,65,.12), transparent 65%),
    radial-gradient(6px 6px at 64% 62%, rgba(181,19,78,.12), transparent 62%),
    radial-gradient(5px 5px at 18% 78%, rgba(92,23,65,.10), transparent 62%),
    radial-gradient(7px 7px at 90% 78%, rgba(181,19,78,.10), transparent 62%);
  animation: floatDots 10s ease-in-out infinite;
}
.sparkles::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(45deg, transparent 0 46%, rgba(92,23,65,.10) 48%, transparent 50%) 10% 18%/140px 140px no-repeat,
    linear-gradient(45deg, transparent 0 46%, rgba(181,19,78,.08) 48%, transparent 50%) 74% 14%/160px 160px no-repeat,
    linear-gradient(45deg, transparent 0 46%, rgba(92,23,65,.08) 48%, transparent 50%) 84% 56%/190px 190px no-repeat,
    linear-gradient(45deg, transparent 0 46%, rgba(181,19,78,.07) 48%, transparent 50%) 26% 74%/170px 170px no-repeat;
  animation: twinkle 7s ease-in-out infinite; opacity:.9;
}
@keyframes floatDots{ 0%,100%{ transform: translate3d(0,0,0); opacity:.26;} 50%{ transform: translate3d(0,-10px,0); opacity:.50;} }
@keyframes twinkle{ 0%,100%{ transform: translate3d(0,0,0); opacity:.20;} 50%{ transform: translate3d(0,8px,0); opacity:.45;} }

/* ── Layout ── */
.wrap{ max-width: var(--max); margin: 0 auto; position: relative; z-index: 2; }

/* ── Navigation globale ── */
.topnav{
  display:flex; justify-content:space-between; align-items:center;
  gap:12px; flex-wrap:wrap; padding: 0 0 10px;
}
.topnav-brand{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--title); font-weight: 700;
  font-size: 1.25rem; color: var(--plum);
  text-decoration:none;
}
.topnav-brand:hover{ text-decoration:none; opacity:.85; }
.topnav-links{ display:flex; gap:6px; flex-wrap:wrap; }
.topnav-links a{
  padding: 8px 14px; border-radius: 12px;
  font-size: .9rem; font-weight: 700; color: var(--plum);
  text-decoration:none; border: 1px solid transparent;
  transition: background .12s ease, border-color .12s ease;
}
.topnav-links a:hover{
  background: rgba(255,255,255,.70); border-color: rgba(92,23,65,.14);
  text-decoration:none;
}
.topnav-links a[aria-current="page"]{
  background: rgba(255,255,255,.80); border-color: rgba(92,23,65,.18);
  color: var(--magenta);
}

/* ── Titres ── */
h1{
  margin:0; font-family: var(--title); font-weight: 700;
  font-size: clamp(2rem, 3.6vw, 3.1rem);
  line-height: 1.02; color: var(--plum);
}
h2.kicker{
  font-family: var(--body); font-size: 1.15rem; font-weight: 800;
  color: var(--magenta); margin: 28px 0 12px; line-height: 1.2;
  letter-spacing: .16em; text-transform: uppercase;
}
h2.kicker:first-of-type{ margin-top: 0; }

.subtitle{ margin: 8px 0 0; color: var(--muted); font-size: var(--fs-1); line-height: 1.7; }
.text{ margin:0; color: rgba(43,27,32,.88); line-height: 1.7; font-size: var(--fs-1); }
.rule{ margin: 14px 0 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(92,23,65,.22), transparent); }

/* ── Boutons ── */
a.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 12px 16px; border-radius: 14px; text-decoration:none; font-weight: 700;
  border: 1px solid rgba(92,23,65,.18); background: rgba(255,255,255,.86);
  color: var(--plum); box-shadow: 0 10px 24px rgba(43,27,32,.10);
  transition: transform .12s ease, background .12s ease, box-shadow .12s ease;
  user-select:none; backdrop-filter: blur(10px);
}
a.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.95); box-shadow: 0 16px 34px rgba(43,27,32,.14); text-decoration:none; }
a.btn:focus{ outline: 3px solid var(--focus); outline-offset: 2px; }
a.btn.primary{ background: var(--magenta); color:#fff; border-color: transparent; }
a.btn.primary:hover{ background:#a81246; }

span.btn.disabled{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 12px 16px; border-radius: 14px; font-weight: 700;
  border: 1px solid rgba(92,23,65,.12); background: rgba(255,255,255,.50);
  color: rgba(92,23,65,.50); box-shadow: 0 10px 24px rgba(43,27,32,.06);
  cursor: default; user-select:none;
}

/* ── Cards / Veil ── */
.veil{
  margin-top: 18px; padding: 18px;
  border-radius: calc(var(--radius) + 6px);
  background: var(--card); border: 1px solid var(--cardBorder);
  backdrop-filter: blur(12px); box-shadow: var(--shadow);
}
.section{ padding: 14px 10px; }

/* ── Livres (grille + cards) ── */
.booksGrid{ margin-top: 14px; display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.bookCard{
  position:relative; border-radius: calc(var(--radius2) + 6px); overflow:hidden;
  background: var(--card2); border: 1px solid var(--cardBorder);
  box-shadow: 0 14px 30px rgba(43,27,32,.12); backdrop-filter: blur(10px);
}
.bookInner{
  padding: 16px; display:grid; grid-template-columns: 160px 1fr;
  gap: 14px; align-items:start;
}
.coverWrap{
  width:160px; border-radius: calc(var(--radius2) + 10px); padding: 14px;
  background: linear-gradient(180deg, rgba(253,234,241,.90), rgba(255,255,255,.86));
  border: 1px solid rgba(92,23,65,.10); box-shadow: 0 18px 42px rgba(43,27,32,.10);
}
.cover{
  width:100%; border-radius: var(--radius2); overflow:hidden; background:#fff;
  border: 1px solid rgba(92,23,65,.18);
  box-shadow: 0 24px 60px rgba(43,27,32,.28), 0 6px 16px rgba(43,27,32,.12);
  display:block;
}
.cover img{ width:100%; height:auto; display:block; }
.bookTitle{
  margin: 0; font-family: var(--title); font-weight: 700;
  font-size: 1.1rem; line-height: 1.25; color: rgba(92,23,65,.96);
}
.bookSub{ margin: 10px 0 0; color: rgba(43,27,32,.72); font-size: .95rem; line-height: 1.6; }
.bookActions{ margin-top: 12px; display:flex; flex-wrap:wrap; gap:10px; }
.ribbon{
  position:absolute; top: 14px; right: -54px; transform: rotate(35deg);
  background: var(--magenta); color: #fff; font-weight: 900;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 8px 70px; font-size: 12px;
  box-shadow: 0 12px 24px rgba(43,27,32,.14); border: 1px solid rgba(0,0,0,.06);
}

/* ── Séries ── */
.series{ margin-top: 6px; color: rgba(43,27,32,.72); font-size: 1.05rem; }
.series strong{ font-weight: 800; color: rgba(92,23,65,.92); font-size: 1.1rem; }

/* ── Pills (tags visuels) ── */
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding: 10px 12px; border-radius: 999px;
  border: 1px solid rgba(92,23,65,.14);
  background: rgba(255,255,255,.65);
  color: rgba(92,23,65,.92); font-weight: 800;
  box-shadow: 0 10px 22px rgba(43,27,32,.08);
  margin-top: 12px;
}

/* ── Catégories bibliothèque ── */
.catTitle{
  font-family: var(--title); font-weight: 700;
  font-size: 1.15rem; line-height: 1.2;
  color: rgba(92,23,65,.92);
  margin: 22px 0 6px; padding: 0;
}
.catTitle:first-of-type{ margin-top: 18px; }

/* ── Quote ── */
.quote{
  margin: 18px 8px 0; font-family: var(--title); font-weight: 600;
  font-size: clamp(1.05rem, 2.2vw, 1.35rem); font-style: italic;
  color: rgba(92,23,65,.92);
}
.quoteAuthor{
  display: block; margin-top: 4px; font-style: normal; font-weight: 500;
  font-size: .85rem; color: rgba(92,23,65,.56); font-family: var(--body);
}
.pullQuote{
  margin: 24px 0; padding: 18px 24px;
  border-left: 3px solid rgba(181,19,78,.32);
  background: rgba(253,234,241,.38);
  border-radius: 0 16px 16px 0;
  font-family: var(--title); font-style: italic;
  font-size: 1.1rem; color: rgba(92,23,65,.88); line-height: 1.6;
}

/* ── Disclaimer ── */
.disclaimer{
  margin-top: 22px; padding: 16px 20px; border-radius: 16px;
  background: rgba(255,255,255,.48); border: 1px solid rgba(92,23,65,.08);
  color: rgba(43,27,32,.58); font-size: .88rem; line-height: 1.65; text-align:center;
}

/* ── FAQ (details) ── */
details{ margin-top:10px; border-bottom: 1px solid rgba(92,23,65,.10); padding-bottom:12px; }
details:first-of-type{ margin-top:12px; }
details:last-of-type{ border-bottom:none; }
summary{
  cursor:pointer; font-weight:700; color: var(--plum);
  font-size:1rem; padding:6px 0;
}

/* ── Cards pages légales ── */
.card{
  margin-top: 14px; padding: 18px;
  border-radius: calc(var(--radius) + 6px);
  background: var(--card); border: 1px solid var(--cardBorder);
  backdrop-filter: blur(12px); box-shadow: var(--shadow);
}
.card h2{ margin:0 0 10px; font-size: 1.05rem; color: rgba(92,23,65,.96); }
.card p{ margin:0 0 10px; color: rgba(43,27,32,.86); }
.card ul{ margin:10px 0 0 18px; color: rgba(43,27,32,.86); }
.card li{ margin: 6px 0; }

/* ── Footer ── */
.siteFooter{ margin-top: 18px; padding: 12px 4px 22px; text-align:center; color: rgba(43,27,32,.72); font-size: .82rem; }
.siteFooter .small{ opacity:.92; margin-top: 6px; }
.footerLegal{
  margin-top: 8px; opacity:.85; font-size: .82rem;
  display:flex; gap:12px; justify-content:center; flex-wrap:wrap;
}
.footerLegal a{ color: inherit; text-decoration: none; border-bottom: 1px dotted rgba(92,23,65,.28); }
.footerLegal a:hover{ border-bottom-color: rgba(92,23,65,.58); text-decoration:none; }

/* ── Utilitaires ── */
.muted{ color: var(--muted); }
.small{ font-size: .9rem; }
.text-center{ text-align:center; }
.text-justify{ text-align:justify; }

/* ══════════════════════════════════════════════════════
   Responsive
   ══════════════════════════════════════════════════════ */
@media (max-width: 900px){
  .booksGrid{ grid-template-columns: 1fr; }
  .bookInner{ grid-template-columns: 160px 1fr; }
}
@media (max-width: 600px){
  .bookInner{ grid-template-columns: 1fr; }
  .coverWrap{ width: 190px; margin: 0 auto; }
  .topnav{ flex-direction:column; align-items:flex-start; gap:8px; }
  .topnav-links{ width:100%; justify-content:flex-start; }
  .quote{ text-align: center; }
  .footerLegal{ justify-content:center; }
}
