/* ============================================================
   Ô Cœur Sibérien — chat-siberien-passion.fr — refonte 2026
   Palette : forêt (sérieux, nature sibérienne) + roux (notre passion)
   ============================================================ */
:root{
  /* Palette « douceur crèche » — crème lait, rose poudré, brun tendre, caramel roux.
     Le bleu nuit historique #040B31 a été retiré : trop dur pour notre univers. */
  --foret:#5b4a44; --foret-2:#4a3b35; --sapin:#6e5750;
  --roux:#c56a86; --roux-2:#a8506c; --or:#e7a9c1;
  --creme:#fbf6f0; --blanc:#ffffff; --encre:#4a3b35;
  --gris:#8a7b72; --ligne:#efdfe3;
  --r:18px; --ombre:0 10px 30px rgba(74,59,53,.08);
  --serif:"Fraunces",Georgia,serif; --sans:"Outfit",-apple-system,Segoe UI,Roboto,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--encre);background:var(--creme);line-height:1.65;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--roux)}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.15;color:var(--foret)}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.5rem,3.4vw,2.3rem)}
h3{font-size:1.2rem}
.wrap{max-width:1160px;margin:0 auto;padding:0 22px}
.btn{display:inline-block;background:var(--roux);color:#fff;text-decoration:none;font-weight:600;
  padding:14px 26px;border-radius:999px;transition:transform .15s,background .15s;border:none;cursor:pointer;font-size:1rem;margin:0 4px 10px;vertical-align:middle}
nav.menu .btn,.hero .ctas .btn{margin-bottom:0}
.btn:hover{background:var(--roux-2);transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--foret);border:2px solid var(--foret)}
.btn.ghost:hover{background:var(--foret);color:#fff}
.btn.clair{background:#fff;color:var(--foret)}
.kicker{display:inline-block;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--roux);font-weight:700;margin-bottom:10px}

/* ---------- header ---------- */
.topbar{background:var(--foret);color:#fff;font-size:.85rem;text-align:center;padding:7px 12px}
.topbar a{color:var(--or);text-decoration:none;font-weight:600}
header.site{position:sticky;top:0;z-index:50;background:rgba(250,246,239,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--ligne)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;max-width:1280px;margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo .pawmark{width:42px;height:42px;border-radius:50%;background:var(--foret);color:var(--or);display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.logo b{font-family:var(--serif);color:var(--foret);font-size:1.15rem;line-height:1.1}
.logo small{display:block;color:var(--gris);font-weight:400;font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;line-height:1.25}
.logo small .ville{display:block}
@media(max-width:480px){.logo b{font-size:1.02rem}.logo small{font-size:.54rem}}
nav.menu{display:flex;gap:18px;align-items:center;flex-wrap:nowrap}
nav.menu a{color:var(--encre);text-decoration:none;font-weight:500;font-size:.9rem;white-space:nowrap}
nav.menu a:hover{color:var(--roux)}
nav.menu .btn{padding:9px 16px;font-size:.84rem}
.burger{display:none;background:none;border:none;font-size:1.6rem;color:var(--foret);cursor:pointer}
@media(max-width:1200px){
  nav.menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--blanc);flex-direction:column;
    padding:18px;gap:16px;border-bottom:1px solid var(--ligne);box-shadow:var(--ombre)}
  nav.menu.open{display:flex}
  .burger{display:block}
}

/* ---------- hero (douceur : crème + halos rose poudré / caramel) ---------- */
.hero{position:relative;background:
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.62'/%3E%3C/svg%3E"),
  radial-gradient(1100px 600px at 80% 12%,rgba(226,150,178,.85),transparent 60%),
  radial-gradient(900px 560px at 6% 95%,rgba(231,169,193,.55),transparent 60%),
  linear-gradient(180deg,#fbe7ee,#fdf1f0);
  background-blend-mode:multiply,normal,normal,normal;color:var(--foret);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding-top:74px;padding-bottom:74px}
.hero h1{color:var(--foret);font-size:clamp(2.3rem,5.6vw,4rem)}
.hero h1 em{font-style:italic;color:var(--or)}
.hero p.lead{font-size:1.15rem;color:#6b5d54;margin:18px 0 26px;max-width:34rem}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero .visuel{position:relative}
.hero .visuel::before{content:"";position:absolute;inset:-16px;border-radius:34px;
  background:linear-gradient(135deg,rgba(226,150,178,.5),rgba(212,162,118,.35));transform:rotate(-3deg);z-index:0}
.hero .visuel img{position:relative;z-index:1;border-radius:22px;border:7px solid #fff;box-shadow:0 18px 50px rgba(74,59,53,.22);aspect-ratio:4/4.1;object-fit:cover;object-position:58% 40%;width:100%}
.hero .badge-live{position:absolute;bottom:18px;left:18px;z-index:2;background:#fff;color:var(--foret);border-radius:999px;
  padding:9px 16px;font-weight:700;font-size:.85rem;display:flex;gap:8px;align-items:center;box-shadow:var(--ombre)}
.hero .badge-live .dot{width:9px;height:9px;border-radius:50%;background:#3ec97e;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.confiance{display:flex;gap:26px;flex-wrap:wrap;margin-top:30px;font-size:.85rem;color:#8a7b72}
.confiance b{display:block;font-size:1.25rem;color:var(--foret);font-family:var(--serif)}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;padding-top:40px;padding-bottom:46px}}

/* ---------- sections ---------- */
section{padding:64px 0}
section.alt{background:var(--blanc)}
.sec-head{max-width:680px;margin-bottom:38px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* chatons */
.grille-chatons{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:22px}
.carte-chaton{background:var(--blanc);border-radius:var(--r);overflow:hidden;box-shadow:var(--ombre);
  text-decoration:none;color:var(--encre);transition:transform .18s}
.carte-chaton:hover{transform:translateY(-5px)}
.carte-chaton .ph{aspect-ratio:1/1.05;background:linear-gradient(135deg,#e8e2d4,#d8d0bd);position:relative;overflow:hidden}
.carte-chaton .ph img{width:100%;height:100%;object-fit:cover}
.carte-chaton .ph.ph-vide{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:linear-gradient(150deg,#c98a8a,#d8a578)}
.carte-chaton .ph-logo{width:46%;aspect-ratio:1;max-width:100px}
.carte-chaton .ph-vide .ph-cap{color:#fff;font-size:.78rem;font-weight:600;opacity:.92;letter-spacing:.03em}

/* fiche chaton individuelle */
.fiche-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;align-items:center}
@media(max-width:820px){.fiche-grid{grid-template-columns:1fr;gap:26px}}
.fiche-photo .ph{aspect-ratio:1/1;border-radius:22px;overflow:hidden;border:7px solid #fff;box-shadow:0 18px 50px rgba(74,59,53,.2)}
.fiche-photo .ph img{width:100%;height:100%;object-fit:cover}
.fiche-photo .ph.ph-vide{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(150deg,#c98a8a,#d8a578)}
.fiche-photo .ph-logo{width:44%;aspect-ratio:1;max-width:150px}
.fiche-photo .ph-vide .ph-cap{color:#fff;font-weight:600;letter-spacing:.03em}
.fiche-info h1{margin:8px 0 6px}
.fiche-badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.fiche-badge{background:#fbe7ef;color:var(--roux);border-radius:999px;padding:5px 14px;font-size:.85rem;font-weight:600;text-transform:capitalize}
.fiche-meta{color:var(--gris);margin-bottom:6px}
.fiche-desc{background:#fff;border-left:3px solid var(--roux);border-radius:0 12px 12px 0;padding:14px 18px;margin:6px 0 18px;color:#5b5048;font-size:1.02rem;line-height:1.6;font-style:italic}
/* Camping-car : cadre blanc sobre, sans halo décalé */
#livraison .pic img{border:7px solid #fff;box-shadow:0 12px 36px rgba(74,59,53,.12)}
.fiche-prix{font-family:var(--serif);font-size:2rem;color:var(--foret);margin:10px 0 16px}
.form-demande{display:none;margin-top:24px;background:#fff;border:1px solid #f0dfe2;border-radius:18px;
  padding:24px;box-shadow:0 10px 40px rgba(74,59,53,.07);position:relative}
.form-demande.open{display:block;animation:fdIn .35s ease}
@keyframes fdIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.form-demande h3{font-family:var(--serif);color:var(--foret);margin:0 0 4px}
.form-demande .fd-intro{color:#6b5d54;font-size:.92rem;margin:0 0 16px}
.form-demande .fd-row{display:flex;gap:14px;flex-wrap:wrap}
.form-demande .fd-row label{flex:1 1 180px}
.form-demande label{display:block;font-size:.85rem;font-weight:600;color:#5b4f48;margin-bottom:12px}
.form-demande input,.form-demande textarea{display:block;width:100%;margin-top:5px;padding:11px 13px;
  border:1px solid #e3d2d6;border-radius:11px;font:inherit;background:#fffdfd;box-sizing:border-box}
.form-demande input:focus,.form-demande textarea:focus{outline:none;border-color:var(--roux);box-shadow:0 0 0 3px rgba(197,106,134,.14)}
.form-demande textarea{resize:vertical}
.form-demande button[type=submit]{margin-top:6px}
.fd-msg{margin:12px 0 0;font-size:.9rem;min-height:1em}
.fd-msg.err{color:#b0356b}
.fd-merci{text-align:center;padding:18px 8px}
.fd-merci h3{font-family:var(--serif);color:var(--foret);margin:0 0 8px}
.fd-merci p{color:#5b5048;margin:0}
.carte-chaton .ph .sexe{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.94);border-radius:999px;
  padding:4px 12px;font-size:.78rem;font-weight:700}
.carte-chaton .ph .sexe.f{color:#b0356b}.carte-chaton .ph .sexe.m{color:#1c5f9e}
.carte-chaton .inf{padding:16px 18px}
.carte-chaton .inf h3{margin-bottom:2px}
.carte-chaton .inf .coul{color:var(--gris);font-size:.88rem;min-height:1.3em}
.carte-chaton .inf .bas{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.carte-chaton .inf .prix{font-weight:700;color:var(--foret);font-size:1.05rem}
.carte-chaton .inf .age{font-size:.8rem;color:var(--gris)}
.vide-chatons{background:var(--blanc);border:2px dashed var(--ligne);border-radius:var(--r);padding:42px;text-align:center;color:var(--gris)}
.maj-info{font-size:.8rem;color:var(--gris);margin-top:16px}

/* parcours pédagogique */
.parcours{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;counter-reset:etape}
.parcours.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.parcours.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.parcours.cols-4{grid-template-columns:1fr}}
.etape{background:var(--blanc);border-radius:var(--r);padding:22px;position:relative;box-shadow:var(--ombre)}
.etape::before{counter-increment:etape;content:counter(etape);position:absolute;top:-14px;left:18px;width:32px;height:32px;
  border-radius:50%;background:var(--roux);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.95rem}
.etape .ico{font-size:1.7rem;margin-bottom:8px}
.etape h3{font-size:1.02rem;margin-bottom:6px}
.etape p{font-size:.86rem;color:var(--gris)}

/* valeurs */
.valeurs{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.valeur{background:var(--foret);color:#fff;border-radius:var(--r);padding:28px}
.valeur .ico{font-size:1.9rem}
.valeur h3{color:var(--or);margin:10px 0 8px}
.valeur p{font-size:.92rem;color:#e3ddcf}

/* bandeau réseaux */
.social{background:linear-gradient(120deg,var(--roux),var(--roux-2));color:#fff;text-align:center}
.social h2{color:#fff}
.social .stats{display:flex;gap:46px;justify-content:center;flex-wrap:wrap;margin:26px 0}
.social .stats b{font-size:2.3rem;font-family:var(--serif);display:block}
.social .stats span{font-size:.85rem;opacity:.9}

/* vidéos */
.videos{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.videos iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:var(--r);box-shadow:var(--ombre)}

/* dates / tournées — étapes d'itinéraire road-trip */
.dates{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:18px}
.etape-tournee{display:flex;background:var(--blanc);border-radius:16px;overflow:hidden;box-shadow:var(--ombre);position:relative;transition:transform .18s}
.etape-tournee:hover{transform:translateY(-4px)}
.etape-tournee .et-chip{flex:0 0 74px;background:linear-gradient(160deg,#e2b4b4,#d4a276);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 6px}
.etape-tournee .et-chip .et-van{width:30px;height:30px;color:#fff}
.etape-tournee .et-info h3 .ic{width:18px;height:18px;vertical-align:-3px;color:var(--roux)}
.etape-tournee .et-tag .ic{width:13px;height:13px;vertical-align:-2px;color:var(--roux)}
.etape-tournee .et-chip .et-mois{font-family:var(--serif);font-size:1.02rem;font-weight:600;letter-spacing:.04em}
.etape-tournee .et-info{padding:14px 16px;flex:1;min-width:0}
.etape-tournee .et-info h3{font-size:1.05rem;color:var(--foret);margin-bottom:4px}
.etape-tournee .et-date{font-size:.92rem;color:var(--encre);font-weight:600;margin-bottom:9px}
.etape-tournee .et-tag{display:inline-block;font-size:.74rem;background:#fbe7ef;color:var(--roux);padding:3px 11px;border-radius:999px;font-weight:600}
.etape-tournee::after{content:"";position:absolute;left:74px;top:9px;bottom:9px;border-left:2px dashed #f0d9df}

/* faq */
.faq details{background:var(--blanc);border-radius:10px;margin-bottom:12px;box-shadow:var(--ombre);overflow:hidden}
.faq summary{padding:18px 22px;font-weight:600;cursor:pointer;color:var(--foret);list-style:none;display:flex;justify-content:space-between}
.faq summary::after{content:"+";font-size:1.3rem;color:var(--roux)}
.faq details[open] summary::after{content:"–"}
.faq .rep{padding:0 22px 18px;color:var(--gris)}

/* footer */
footer{background:var(--foret-2);color:#cfc9ba;padding:54px 0 26px;font-size:.9rem}
footer h4{color:#fff;font-family:var(--serif);margin-bottom:14px;font-size:1.05rem}
footer a{color:var(--or);text-decoration:none}
.foot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:34px;margin-bottom:34px}
.foot-legal{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;font-size:.78rem;text-align:center;color:#9aa192}
footer ul{list-style:none}
footer li{margin-bottom:8px}

/* ---------- récit / histoire (l'émotion d'abord) ---------- */
.story{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:38px 0}
.story.inverse .txt{order:2}.story.inverse .pic{order:1}
.story .pic img{border-radius:22px;box-shadow:var(--ombre);width:100%;aspect-ratio:4/3.4;object-fit:cover}
.story .txt .kicker{margin-bottom:6px}
.story .txt h2{margin-bottom:14px}
.story .txt p{margin-bottom:14px;color:#3d4437}
.story .txt p strong{color:var(--foret)}
.signature{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--roux);margin-top:6px}
.encart{background:var(--blanc);border-left:5px solid var(--or);border-radius:12px;padding:18px 22px;margin:14px 0;box-shadow:var(--ombre);font-size:.95rem}
@media(max-width:860px){.story{grid-template-columns:1fr;gap:22px}.story.inverse .txt{order:1}.story.inverse .pic{order:2}}

/* ---------- effets "spectaculaire moderne" ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.vu{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}
.hero .visuel img{transform:rotate(1.5deg)}
.story .pic img{transition:transform .5s ease}
.story:hover .pic img{transform:scale(1.025)}
.carte-chaton .ph img{transition:transform .5s ease}
.carte-chaton:hover .ph img{transform:scale(1.06)}
.social{background:linear-gradient(120deg,#c56a86,#9e5470)}

/* ---------- icônes maison (signature patte-cœur) ---------- */
.icb{width:46px;height:46px;border-radius:14px;background:#fbe7ef;color:var(--roux);
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-bottom:10px}
.icb svg{width:24px;height:24px}
.ic{width:20px;height:20px;vertical-align:-4px;color:var(--roux)}
.encart{display:flex;gap:14px;align-items:flex-start}
.encart .icb{margin-bottom:0;width:42px;height:42px;border-radius:12px}
.encart div{flex:1}
.pawmark svg{width:24px;height:24px}

/* ---------- reproducteurs ---------- */
.grille-repro{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:20px}
.carte-repro{background:var(--blanc);border-radius:var(--r);overflow:hidden;box-shadow:var(--ombre);text-align:center;transition:transform .18s}
.carte-repro:hover{transform:translateY(-5px)}
.carte-repro .rph{aspect-ratio:1/1;position:relative;overflow:hidden;background:linear-gradient(135deg,#f4d4de,#f7e7dc);display:flex;align-items:center;justify-content:center}
.carte-repro .rph img{width:100%;height:100%;object-fit:cover}
.carte-repro .rph .ini{font-family:var(--serif);font-size:2.8rem;color:var(--roux);opacity:.6}
.carte-repro .rph .badge-retr{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.92);color:var(--foret);border-radius:999px;padding:3px 10px;font-size:.7rem;font-weight:700}
.carte-repro .rinf{padding:14px 14px 16px}
.carte-repro .rinf h3{font-size:1rem;color:var(--foret);margin-bottom:3px}
.carte-repro .rinf .robe{font-size:.83rem;color:var(--gris);text-transform:capitalize;min-height:1.1em}
.carte-repro .rinf .nee{font-size:.78rem;color:var(--roux);font-weight:600;margin-top:5px}
.repro-groupe-titre{font-family:var(--serif);color:var(--foret);font-size:1.4rem;margin:0 0 20px;display:flex;align-items:center;gap:8px}
.repro-groupe-titre svg{width:26px;height:26px;color:var(--roux);flex:0 0 auto}
