/* =========================================================
   vallorcine.info — design system (site statique)
   Zéro dépendance externe. Police système = TTFB minimal.
   ========================================================= */

:root{
  --vert:#1f4d3a;        /* vert sapin — identité alpine */
  --vert-fonce:#163a2b;
  --vert-clair:#e8f0eb;
  --ardoise:#2b3440;     /* texte principal */
  --gris:#5b6672;
  --gris-clair:#eef1f3;
  --accent:#c9772e;      /* orange chaleureux — CTA */
  --accent-fonce:#a85f1f;
  --neige:#ffffff;
  --fond:#fbfcfb;
  --bordure:#dfe4e2;
  --ombre:0 1px 3px rgba(22,58,43,.08),0 8px 24px rgba(22,58,43,.06);
  --rayon:12px;
  --largeur:min(100% - 2rem, 760px);
  --largeur-large:min(100% - 2rem, 1080px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--ardoise);background:var(--fond);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:1.06rem;line-height:1.65;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--vert);text-underline-offset:2px}
a:hover{color:var(--accent-fonce)}

/* ---------- mise en page ---------- */
.wrap{width:var(--largeur);margin-inline:auto}
.wrap-large{width:var(--largeur-large);margin-inline:auto}
main{padding-block:1.5rem 3rem}
section{margin-block:2.4rem}

/* ---------- en-tête / nav ---------- */
.site-header{background:var(--vert);color:#fff;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.site-header .wrap-large{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.55rem;color:#fff;text-decoration:none;font-weight:700;font-size:1.15rem;letter-spacing:.2px}
.brand .mark{width:26px;height:26px;flex:0 0 26px}
.nav{display:flex;gap:1.1rem;flex-wrap:wrap}
.nav a{color:#dbe7e0;text-decoration:none;font-size:.95rem;font-weight:500}
.nav a:hover,.nav a[aria-current]{color:#fff}
@media(max-width:640px){.nav{display:none}}

/* ---------- fil d'ariane ---------- */
.breadcrumb{font-size:.85rem;color:var(--gris);padding-top:1rem}
.breadcrumb a{color:var(--gris);text-decoration:none}
.breadcrumb a:hover{color:var(--vert)}

/* ---------- titre / hero ---------- */
h1{font-size:clamp(1.7rem,4.5vw,2.5rem);line-height:1.15;margin:.4rem 0 .6rem;color:var(--vert-fonce);letter-spacing:-.5px}
.lede{font-size:1.15rem;color:var(--gris);margin-top:0}
h2{font-size:clamp(1.35rem,3vw,1.7rem);margin-top:2.2rem;color:var(--vert-fonce);letter-spacing:-.3px}
h3{font-size:1.15rem;margin-top:1.6rem;color:var(--ardoise)}
.hero-img{border-radius:var(--rayon);box-shadow:var(--ombre);margin:1.2rem 0;aspect-ratio:16/9;object-fit:cover;width:100%;background:var(--vert-clair)}

.meta{display:flex;flex-wrap:wrap;gap:.4rem 1rem;font-size:.85rem;color:var(--gris);margin:.4rem 0 1rem}
.meta strong{color:var(--ardoise)}

/* ---------- encadré "l'essentiel" (extractible GEO) ---------- */
.essentiel{background:var(--vert-clair);border:1px solid #cfe0d6;border-left:4px solid var(--vert);
  border-radius:var(--rayon);padding:1.1rem 1.3rem;margin:1.4rem 0}
.essentiel h2{margin:.1rem 0 .6rem;font-size:1.05rem;text-transform:uppercase;letter-spacing:.6px;color:var(--vert)}
.essentiel ul{margin:.3rem 0;padding-left:1.1rem}
.essentiel li{margin:.35rem 0}

/* ---------- tableaux de données ---------- */
.tableau{overflow-x:auto;margin:1.1rem 0;border-radius:var(--rayon);border:1px solid var(--bordure)}
table{width:100%;border-collapse:collapse;font-size:.95rem;background:#fff}
caption{text-align:left;font-size:.82rem;color:var(--gris);padding:.5rem .2rem;caption-side:bottom}
th,td{padding:.6rem .8rem;text-align:left;border-bottom:1px solid var(--bordure)}
thead th{background:var(--vert);color:#fff;font-weight:600;white-space:nowrap}
tbody tr:nth-child(even){background:var(--gris-clair)}
tbody tr:last-child td{border-bottom:0}

/* ---------- cartes activités ---------- */
.grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin:1.2rem 0}
.card{background:#fff;border:1px solid var(--bordure);border-radius:var(--rayon);padding:1.1rem;box-shadow:var(--ombre)}
.card h3{margin-top:0}
.card p{margin:.4rem 0 0;font-size:.95rem;color:var(--gris)}

/* ---------- bloc monétisé / CTA ---------- */
.cta{background:linear-gradient(135deg,var(--vert) 0%,var(--vert-fonce) 100%);color:#fff;
  border-radius:var(--rayon);padding:1.5rem 1.6rem;margin:1.8rem 0;box-shadow:var(--ombre)}
.cta h3{color:#fff;margin:0 0 .4rem}
.cta p{margin:0 0 1rem;color:#d6e5dc}
.btn{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;font-weight:600;
  padding:.75rem 1.4rem;border-radius:8px;transition:background .15s}
.btn:hover{background:var(--accent-fonce);color:#fff}
.btn-outline{background:transparent;border:1.5px solid #fff;color:#fff}
.btn-outline:hover{background:rgba(255,255,255,.12);color:#fff}
.aff-note{font-size:.78rem;color:var(--gris);font-style:italic;margin-top:.3rem}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--bordure);border-radius:10px;padding:.4rem 1rem;margin:.6rem 0}
.faq summary{font-weight:600;cursor:pointer;padding:.5rem 0;color:var(--vert-fonce)}
.faq summary::marker{color:var(--accent)}
.faq p{margin:.2rem 0 .8rem}

/* ---------- badge "vérifié" ---------- */
.verif{display:inline-flex;align-items:center;gap:.35rem;background:#fff;border:1px solid var(--bordure);
  border-radius:999px;padding:.25rem .7rem;font-size:.8rem;color:var(--vert);font-weight:600}

/* ---------- pied de page ---------- */
.site-footer{background:var(--vert-fonce);color:#c6d6cd;margin-top:3rem;padding-block:2rem}
.site-footer a{color:#e7f0ea}
.site-footer .cols{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.site-footer h4{color:#fff;margin:0 0 .5rem;font-size:.95rem}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:.3rem 0;font-size:.9rem}
.site-footer .legal{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.15);font-size:.82rem;color:#9fb5aa}

/* ---------- sources ---------- */
.sources{font-size:.85rem;color:var(--gris);border-top:1px solid var(--bordure);padding-top:1rem;margin-top:2.5rem}
.sources ol{margin:.4rem 0;padding-left:1.2rem}
.sources li{margin:.2rem 0}
