/* =====================================================================
   Livres Caroline — Direction "Pop primaire"
   Blanc franc, blocs de couleurs primaires (rouge/bleu/jaune), typo ronde
   XXL (Fredoka) + corps Nunito Sans. Logo signature typographique.
   ===================================================================== */

:root{
  --papier:#FFFDF8;        /* fond blanc cassé */
  --papier-fonce:#FFF3D6;  /* jaune très pâle pour zones alternées */
  --encre:#241F1B;
  --rouge:#EF4A34;         --rouge-fonce:#C5341F;
  --bleu:#1E88A8;          --bleu-fonce:#15677F;
  --jaune:#FFC02E;
  --vert:#4FA05B;
  --blanc:#FFFFFF;
  --gris:#8A8073;

  --ombre:0 5px 0 rgba(36,31,27,.14);
  --ombre-carte:0 16px 34px -18px rgba(36,31,27,.5);
  --rayon:18px;
  --max:1180px;

  --titre:"Fredoka", system-ui, sans-serif;
  --corps:"Nunito Sans", system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--corps);color:var(--encre);background:var(--papier);line-height:1.6;font-size:17px}
img{max-width:100%;height:auto;display:block}
a{color:var(--bleu-fonce);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--titre);line-height:1.05;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5.2vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:1.25rem;font-weight:600}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--jaune);padding:10px 16px;border-radius:0 0 12px 0;z-index:100}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--bleu);outline-offset:2px;border-radius:6px}

/* --- Bandeau d'annonce -------------------------------------------------*/
.annonce{background:var(--bleu);color:#fff;text-align:center;font-family:var(--titre);font-weight:500;
  font-size:.95rem;padding:8px 16px}
.annonce strong{color:var(--jaune);font-weight:700}

/* --- En-tête -----------------------------------------------------------*/
.site-header{background:var(--blanc);position:sticky;top:0;z-index:50;box-shadow:0 2px 16px -10px rgba(36,31,27,.5)}
.header-inner{display:flex;align-items:center;gap:18px;padding:14px 22px;flex-wrap:wrap}
.logo{display:inline-flex;text-decoration:none}
.logo:hover{text-decoration:none}
.logo-signature{display:flex;flex-direction:column;line-height:1}
.logo-caroline{position:relative;font-family:var(--titre);font-weight:700;font-size:1.9rem;color:var(--rouge);letter-spacing:.5px}
.logo-soleil{position:absolute;top:-4px;right:-12px;width:13px;height:13px;border-radius:50%;background:var(--jaune)}
.logo-sous{font-family:var(--titre);font-weight:600;font-size:.62rem;letter-spacing:3px;text-transform:uppercase;color:var(--bleu);margin-top:3px}
.nav{order:5;flex-basis:100%}
.nav-toggle{display:none}
.nav-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center}
.nav-list a{font-family:var(--titre);color:var(--encre);font-weight:500;padding:6px 2px;border-bottom:3px solid transparent;text-decoration:none}
.nav-list a:hover{border-color:var(--jaune)}
.nav-sub a{font-size:.92rem;color:var(--gris)}
.nav-drop{position:relative}
.nav-caret{font-size:.7em;opacity:.7}
.nav-menu{list-style:none;margin:0;padding:8px;position:absolute;top:100%;left:0;min-width:250px;background:#fff;border:2px solid var(--encre);border-radius:14px;box-shadow:0 14px 30px rgba(0,0,0,.16);display:none;z-index:60}
.nav-drop:hover>.nav-menu,.nav-drop:focus-within>.nav-menu{display:block}
.nav-menu li{margin:0}
.nav-menu a{display:block;padding:9px 12px;border-radius:9px;border-bottom:0;color:var(--encre);font-size:.95rem;font-weight:500}
.nav-menu a:hover{background:var(--papier-fonce);border-color:transparent}
.nav-menu li:first-child a{font-weight:700;border-bottom:1px solid var(--papier-fonce);border-radius:9px 9px 0 0;margin-bottom:4px}
.nav-sep{height:1px;background:var(--papier-fonce);margin:6px 8px}
.nav-menu a.nav-rare{color:var(--rouge);font-weight:600}
.nav-menu a.nav-rare:hover{background:#fbe9e4}
.recherche{display:flex;flex:1;min-width:160px;max-width:300px;margin-left:auto;border:2.5px solid var(--encre);border-radius:999px;overflow:hidden;background:var(--blanc)}
.recherche input{flex:1;border:0;background:transparent;padding:8px 14px;font-family:var(--corps);font-size:.95rem}
.recherche input:focus{outline:none}
.recherche button{border:0;background:var(--jaune);padding:0 16px;font-size:1.1rem;cursor:pointer}
.compte-lien{font-family:var(--titre);font-weight:600;color:var(--bleu-fonce);text-decoration:none;white-space:nowrap}
.compte-lien:hover{text-decoration:underline}
.panier-lien{position:relative;display:flex;align-items:center;text-decoration:none;font-size:1.5rem}
.panier-lien:hover{text-decoration:none}
.panier-compteur{position:absolute;top:-8px;right:-12px;min-width:22px;height:22px;padding:0 5px;background:var(--rouge);color:#fff;border-radius:999px;font-family:var(--titre);font-size:.78rem;display:flex;align-items:center;justify-content:center;line-height:1}

/* --- Boutons -----------------------------------------------------------*/
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--titre);font-weight:600;font-size:1.02rem;padding:13px 28px;border-radius:999px;border:0;text-decoration:none;transition:transform .08s ease,box-shadow .08s ease}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn:active{transform:translateY(1px)}
.btn--primaire{background:var(--rouge);color:#fff;box-shadow:0 5px 0 var(--rouge-fonce)}
.btn--primaire:hover{box-shadow:0 7px 0 var(--rouge-fonce)}
.btn--bleu{background:var(--bleu);color:#fff;box-shadow:0 5px 0 var(--bleu-fonce)}
.btn--bleu:hover{box-shadow:0 7px 0 var(--bleu-fonce)}
.btn--clair{background:var(--blanc);color:var(--encre);box-shadow:var(--ombre)}
.btn--bloc{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* --- Blocs de couleur (signature Pop) ----------------------------------*/
.bloc-pop{border-radius:var(--rayon);padding:26px;border:3px solid var(--encre);box-shadow:var(--ombre)}
.bloc-pop--jaune{background:var(--jaune)}
.bloc-pop--bleu{background:var(--bleu);color:#fff}
.bloc-pop--rouge{background:var(--rouge);color:#fff}

/* --- Hero --------------------------------------------------------------*/
.hero{position:relative;background:var(--papier);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:60px 22px}
.hero-eyebrow{display:inline-block;font-family:var(--titre);font-weight:600;color:#fff;background:var(--bleu);padding:5px 14px;border-radius:999px;font-size:.82rem;letter-spacing:.5px}
.hero h1{margin:.35em 0 .35em;color:var(--encre)}
.hero h1 em{font-style:normal;color:var(--rouge)}
.hero p.accroche{font-size:1.18rem;max-width:46ch;margin:0 0 1.6em}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-carousel{position:relative;min-width:0;width:100%;max-width:440px;margin-left:auto;margin-right:auto}
.hero::before{content:"";position:absolute;top:-60px;right:-60px;width:230px;height:230px;border-radius:50%;background:var(--jaune);opacity:.5;z-index:0}
.hero-grid>*{position:relative;z-index:1;min-width:0}

/* --- Carrousel ---------------------------------------------------------*/
.carousel{position:relative;min-width:0;border-radius:var(--rayon);overflow:hidden;background:var(--blanc);box-shadow:var(--ombre-carte);border:3px solid var(--encre)}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-slide{min-width:100%;display:flex;flex-direction:column;align-items:center;padding:26px;text-align:center;text-decoration:none;color:inherit}
.carousel-slide img{width:auto;max-height:300px;border-radius:8px;box-shadow:var(--ombre)}
.carousel-slide .titre{font-family:var(--titre);font-weight:600;font-size:1.15rem;margin-top:16px;color:var(--encre)}
.carousel-slide .prix{color:var(--rouge);font-weight:700;font-family:var(--titre);margin-top:4px}
.carousel-btns{position:absolute;inset:0;display:flex;justify-content:space-between;align-items:center;pointer-events:none}
.carousel-btns button{pointer-events:auto;margin:0 8px;width:42px;height:42px;border-radius:50%;border:2px solid var(--encre);background:var(--jaune);font-size:1.3rem;cursor:pointer}
.carousel-dots{display:flex;gap:8px;justify-content:center;margin-top:14px}
.carousel-dots button{width:11px;height:11px;border-radius:50%;border:0;background:#e5ddcb;cursor:pointer}
.carousel-dots button[aria-current="true"]{background:var(--rouge)}

/* --- Sections ----------------------------------------------------------*/
.section{padding:60px 0}
.section--alt{background:var(--papier-fonce)}
.section-titre{text-align:center;margin-bottom:8px}
.section-sous{text-align:center;color:var(--gris);max-width:60ch;margin:0 auto 38px}

/* --- Démarche ----------------------------------------------------------*/
.demarche{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.demarche-carte{background:var(--blanc);border-radius:var(--rayon);padding:28px;border:3px solid var(--encre);box-shadow:var(--ombre)}
.demarche-carte:nth-child(1){background:#FFF3D6}
.demarche-carte:nth-child(2){background:#E3F0F4}
.demarche-carte:nth-child(3){background:#FCE6E1}
.demarche-carte h3{color:var(--encre)}

/* --- Collections -------------------------------------------------------*/
.collections{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.collection-carte{display:block;background:var(--blanc);border-radius:var(--rayon);padding:26px;border:3px solid var(--encre);box-shadow:var(--ombre);text-decoration:none;color:var(--encre);transition:transform .12s ease}
.collection-carte:hover{transform:translateY(-4px) rotate(-1deg);text-decoration:none}
.collection-carte h3{font-size:1.3rem;color:var(--rouge)}
.collection-carte p{font-size:.96rem;margin:0}
.collection-carte .fleche{font-family:var(--titre);font-weight:600;color:var(--bleu);margin-top:14px;display:inline-block}

/* --- Grille de livres --------------------------------------------------*/
.grille{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.livre-carte{position:relative;background:var(--blanc);border-radius:var(--rayon);overflow:hidden;border:3px solid var(--encre);box-shadow:var(--ombre);display:flex;flex-direction:column;transition:transform .12s ease,box-shadow .12s ease}
.livre-carte:hover{transform:translateY(-4px);box-shadow:var(--ombre-carte)}
.livre-carte a{text-decoration:none;color:inherit}
.livre-visuel{aspect-ratio:3/4;background:var(--papier-fonce);display:flex;align-items:center;justify-content:center;overflow:hidden}
.livre-visuel img{width:100%;height:100%;object-fit:cover}
.livre-infos{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.livre-serie{font-size:.74rem;text-transform:uppercase;letter-spacing:1px;color:#fff;background:var(--bleu);align-self:flex-start;padding:2px 8px;border-radius:999px;font-family:var(--titre);font-weight:500}
.livre-titre{font-family:var(--titre);font-weight:600;font-size:1.08rem;line-height:1.15}
.livre-prix{margin-top:auto;font-family:var(--titre);font-weight:700;color:var(--rouge)}
.badge{position:absolute;margin:10px;background:var(--jaune);color:var(--encre);font-family:var(--titre);font-weight:600;font-size:.78rem;padding:4px 10px;border-radius:999px;border:2px solid var(--encre);z-index:2}

/* --- Fiche livre -------------------------------------------------------*/
.fiche{display:grid;grid-template-columns:1fr 1fr;gap:46px;padding:48px 0}
.fiche-galerie img{width:100%;border-radius:var(--rayon);border:3px solid var(--encre);box-shadow:var(--ombre-carte)}
.fiche-vignettes{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.fiche-vignettes img{width:74px;height:74px;object-fit:cover;border-radius:10px;border:2px solid var(--encre);cursor:pointer}
.fiche h1{margin-bottom:.1em}
.fiche .meta{color:var(--gris);margin-bottom:18px}
.etats{display:flex;flex-direction:column;gap:10px;margin:22px 0}
.etat-option{display:flex;align-items:center;justify-content:space-between;gap:14px;border:2.5px solid #ece3cf;border-radius:14px;padding:12px 16px;cursor:pointer;background:var(--blanc);transition:border-color .1s}
.etat-option:has(input:checked){border-color:var(--rouge)}
.etat-option input{accent-color:var(--rouge);width:18px;height:18px}
.etat-nom{font-family:var(--titre);font-weight:600}
.etat-prix{font-family:var(--titre);font-weight:700;color:var(--rouge)}
.etat-stock{font-size:.85rem;color:var(--gris)}
.etat-rupture{opacity:.55;cursor:not-allowed}

/* --- Panier ------------------------------------------------------------*/
.panier-table{width:100%;border-collapse:collapse;background:var(--blanc);border-radius:var(--rayon);overflow:hidden;border:3px solid var(--encre)}
.panier-table th,.panier-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #efe6d2}
.panier-table th{font-family:var(--titre);font-weight:600;background:var(--papier-fonce)}
.panier-table img{width:56px;border-radius:8px}
.panier-recap{background:var(--blanc);border-radius:var(--rayon);padding:24px;border:3px solid var(--encre);box-shadow:var(--ombre)}
.panier-recap .ligne{display:flex;justify-content:space-between;margin:8px 0}
.panier-recap .ligne--remise{color:var(--vert);font-weight:700}
.panier-recap .total{font-family:var(--titre);font-weight:700;font-size:1.3rem;border-top:2px solid var(--encre);padding-top:12px;margin-top:12px}
.promo-box{display:flex;gap:8px;margin-top:14px}
.promo-box input{flex:1;padding:10px 12px;border:2px solid var(--encre);border-radius:10px;font-family:var(--corps)}
.barre-franco{background:var(--papier-fonce);border-radius:999px;height:12px;overflow:hidden;margin:10px 0 4px}
.barre-franco i{display:block;height:100%;background:var(--vert);border-radius:999px}

/* --- Formulaires -------------------------------------------------------*/
.champ{margin-bottom:16px}
.champ label{display:block;font-family:var(--titre);font-weight:600;margin-bottom:6px}
.champ input,.champ select,.champ textarea{width:100%;padding:12px 14px;border:2.5px solid var(--encre);border-radius:12px;font-family:var(--corps);font-size:1rem;background:var(--blanc)}
.champ textarea{min-height:140px;resize:vertical}
.form-carte{background:var(--blanc);border-radius:var(--rayon);padding:30px;border:3px solid var(--encre);box-shadow:var(--ombre);max-width:640px}

/* --- Messages ----------------------------------------------------------*/
.alerte{padding:14px 18px;border-radius:12px;margin:16px 0;font-weight:600;border:2px solid var(--encre)}
.alerte--ok{background:#e7f3e2}
.alerte--info{background:#e3f0f4}
.alerte--erreur{background:#fce6e1}

/* --- Contenu / pages ---------------------------------------------------*/
.contenu-page{max-width:760px;margin:0 auto;padding:48px 22px}
.contenu-page p{margin:0 0 1.1em}
.contenu-page h2{margin-top:1.6em}
.lettrine::first-letter{font-family:var(--titre);font-size:3.4rem;float:left;line-height:.8;color:var(--rouge);padding:6px 10px 0 0}

/* --- Pied de page ------------------------------------------------------*/
.site-footer{background:var(--encre);color:#EFE7D6;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px;padding:48px 22px 30px}
.footer-col h3{color:var(--jaune);font-size:1.05rem}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.footer-col a{color:#EFE7D6}
.footer-brand .logo-text,.footer-brand b{color:var(--jaune);font-family:var(--titre);font-weight:700;font-size:1.4rem}
.footer-brand p{font-size:.95rem;color:#cfc6b4}
.footer-bas{border-top:1px solid rgba(255,255,255,.12);padding:18px 22px;font-size:.82rem;color:#b6ac99}
.footer-bas p{margin:4px 0}

/* --- Responsive --------------------------------------------------------*/
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-actions{justify-content:center}
  .demarche,.collections{grid-template-columns:1fr 1fr}
  .grille{grid-template-columns:1fr 1fr}
  .fiche{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .nav-toggle{display:inline-block;font-family:var(--titre);font-weight:600;background:var(--jaune);border:2px solid var(--encre);padding:8px 16px;border-radius:999px;cursor:pointer}
  .nav-list{display:none;flex-direction:column;width:100%;margin-top:10px}
  .nav.is-open .nav-list{display:flex}
  .nav-menu{position:static;display:block;border:0;box-shadow:none;padding:4px 0 8px 14px;min-width:0}
  .nav-caret{display:none}
  .nav-menu li:first-child a{border-bottom:0}
  .demarche,.collections,.grille,.footer-grid{grid-template-columns:1fr}
  .recherche{order:6;max-width:none;margin:8px 0 0}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* --- Responsive renforcé (tunnel + tableaux) -------------------------- */
.grille-2-1{display:grid;grid-template-columns:2fr 1fr;gap:30px;align-items:start}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:760px){
  .grille-2-1{grid-template-columns:1fr}
  .panier-table{font-size:.92rem}
  .panier-table th,.panier-table td{padding:10px 8px}
  .fiche-galerie img{max-width:420px;margin:0 auto}
}
@media(max-width:520px){
  body{font-size:16px}
  .header-inner{gap:12px}
  .logo-caroline{font-size:1.6rem}
  .recherche{order:6}
  .hero-grid{padding:40px 16px}
  .wrap{padding:0 16px}
  /* tableaux larges : défilement horizontal propre */
  .panier-table{display:block;overflow-x:auto;white-space:nowrap}
}

@media(max-width:600px){ .grille-perso{grid-template-columns:1fr !important} }

/* Personnages : signatures typographiques (une police + une couleur par caractère) */
.perso-carte{display:flex;flex-direction:column;min-height:220px}
.perso-carte .perso-type{margin:0 0 2px;color:var(--gris);text-transform:uppercase;letter-spacing:1.6px;font-size:.74rem;font-weight:600;font-family:var(--titre)}
.perso-carte .sig{display:block;line-height:1;margin:0 0 .42em;color:var(--encre);font-weight:700;font-size:clamp(2rem,4.6vw,2.7rem)}
.perso-carte .sig + p{margin:0 0 16px}
.perso-carte .sig-caroline{font-family:'Pacifico',cursive;font-weight:400;color:var(--rouge);font-size:clamp(2.2rem,5vw,3rem)}
.perso-carte .sig-pitou{font-family:'Playfair Display',serif;font-style:italic;font-weight:900;color:#2b2622;letter-spacing:.3px}
.perso-carte .sig-pouf{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;color:var(--bleu);letter-spacing:.5px;font-size:clamp(2.2rem,5vw,3rem)}
.perso-carte .sig-noiraud{font-family:'Permanent Marker',cursive;font-weight:400;color:#201f24;display:inline-block;transform:rotate(-2.5deg)}
.perso-carte .sig-pipo{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#2f6f7e}
.perso-carte .sig-youpi{font-family:'Baloo 2',cursive;font-weight:800;color:#cf7d1e}
.perso-carte .sig-boum{font-family:'Chewy',cursive;font-weight:400;color:#9a6b3f}
.perso-carte .sig-kid{font-family:'Titan One',sans-serif;font-weight:400;color:#c8941f}
.perso-carte .sig-bobi{font-family:'Righteous',sans-serif;font-weight:400;color:#4f8a68;display:inline-block;transform:skewX(-8deg)}
.perso-carte .sig-titus{font-family:'Orbitron',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:4px;color:#5b6470;font-size:clamp(1.6rem,3.4vw,2.1rem)}
