/* ============================================
   INFOCAMPING.FR — Design System
   Palette : Blanc + 2 nuances de bleu
   Bleu principal : #1B6CA8   |   Bleu clair / accent : #36B9BF
   ============================================ */

:root{
  --blue-deep:#1B6CA8;
  --blue-light:#36B9BF;
  --blue-pale:#EAF7F8;
  --blue-pale-2:#DFF3F4;
  --ink:#0F2A3D;
  --ink-soft:#4C6473;
  --paper:#FFFFFF;
  --paper-soft:#F7FBFC;
  --line:#E2EEF0;
  --radius-lg:24px;
  --radius-md:16px;
  --radius-sm:10px;
  --shadow-soft:0 20px 50px -25px rgba(27,108,168,0.35);
  --shadow-card:0 10px 30px -15px rgba(15,42,61,0.18);
  --font-display:'Sora', system-ui, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:1180px;margin:0 auto;padding:0 24px;}
section{position:relative;}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.12;
  margin:0;
  color:var(--ink);
  letter-spacing:-0.01em;
}
p{margin:0;color:var(--ink-soft);}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--blue-deep);
  background:var(--blue-pale);
  padding:7px 16px;
  border-radius:999px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--blue-light);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.88);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:800;font-size:1.18rem;color:var(--ink);
}
.brand-mark{
  width:38px;height:38px;border-radius:11px;
  background:linear-gradient(155deg,var(--blue-light),var(--blue-deep));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.05rem;
}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:0.68rem;color:var(--ink-soft);letter-spacing:0.04em;}

nav.main-nav{display:flex;align-items:center;gap:30px;}
nav.main-nav a{
  font-size:0.92rem;font-weight:600;color:var(--ink-soft);
  position:relative;padding:6px 0;
  transition:color .2s ease;
}
nav.main-nav a:hover,nav.main-nav a.active{color:var(--blue-deep);}
nav.main-nav a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--blue-light);border-radius:2px;
}

.nav-item{position:relative;}
.nav-item>a{display:flex;align-items:center;gap:5px;}
.nav-item>a .caret{font-size:0.62rem;transition:transform .2s ease;color:var(--ink-soft);}
.nav-item:hover>a .caret{transform:rotate(180deg);}
.dropdown{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-6px);
  padding-top:14px;margin-top:0;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .18s ease,transform .18s ease,visibility .18s ease;
  z-index:50;
}
.dropdown-inner{
  background:var(--paper);border-radius:var(--radius-md);box-shadow:0 18px 40px -12px rgba(15,42,61,0.18);
  border:1px solid rgba(15,42,61,0.06);padding:10px;min-width:230px;
}
.nav-item:hover .dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);}
.dropdown a{
  display:block;padding:9px 14px;border-radius:10px;font-size:0.88rem;font-weight:600;
  color:var(--ink-soft);white-space:nowrap;
}
.dropdown a:hover{background:var(--blue-pale);color:var(--blue-deep);}
.dropdown a.active{color:var(--blue-deep);background:var(--blue-pale);}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:700;font-size:0.88rem;
  padding:12px 22px;border-radius:999px;
  border:none;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease;
}
.btn-primary{
  background:linear-gradient(120deg,var(--blue-deep),var(--blue-light));
  color:#fff;box-shadow:0 14px 28px -12px rgba(27,108,168,0.55);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 32px -10px rgba(27,108,168,0.6);}
.btn-ghost{
  background:var(--paper);color:var(--blue-deep);
  border:1.5px solid var(--blue-pale-2);
}
.btn-ghost:hover{border-color:var(--blue-light);background:var(--blue-pale);}
.btn-sm{padding:9px 16px;font-size:0.8rem;}

/* ---------- Hero ---------- */
.hero{
  padding:84px 0 70px;
  background:
    radial-gradient(circle at 14% 18%, rgba(54,185,191,0.16), transparent 42%),
    radial-gradient(circle at 86% 8%, rgba(27,108,168,0.12), transparent 38%),
    var(--paper);
  overflow:hidden;
}
.hero .container{display:grid;grid-template-columns:1.05fr 0.95fr;gap:54px;align-items:center;}
.hero h1{font-size:clamp(2.3rem,4vw,3.4rem);margin:18px 0 20px;}
.hero h1 .accent{color:var(--blue-light);}
.hero p.lead{font-size:1.08rem;max-width:520px;margin-bottom:30px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px;}

.stat-row{display:flex;gap:34px;flex-wrap:wrap;}
.stat-row .stat b{display:block;font-family:var(--font-display);font-size:1.7rem;color:var(--blue-deep);}
.stat-row .stat span{font-size:0.8rem;color:var(--ink-soft);}

.hero-visual{position:relative;}
.hero-card{
  background:var(--paper);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
  overflow:hidden;border:1px solid var(--line);
}
.hero-card img{width:100%;height:380px;object-fit:cover;}
.float-card{
  position:absolute;background:#fff;border-radius:var(--radius-md);
  box-shadow:var(--shadow-card);padding:14px 18px;
  display:flex;align-items:center;gap:12px;
  border:1px solid var(--line);
  animation:floatUp 5s ease-in-out infinite;
}
.float-card.fc-1{top:-22px;left:-26px;animation-delay:0s;}
.float-card.fc-2{bottom:-24px;right:-22px;animation-delay:1.2s;}
.float-card .ic{
  width:38px;height:38px;border-radius:10px;background:var(--blue-pale);
  display:flex;align-items:center;justify-content:center;color:var(--blue-deep);font-size:1.1rem;
}
.float-card b{font-family:var(--font-display);font-size:0.92rem;display:block;}
.float-card span{font-size:0.74rem;color:var(--ink-soft);}
@keyframes floatUp{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

@media(prefers-reduced-motion:reduce){
  .float-card{animation:none;}
}

/* ---------- Generic section spacing ---------- */
.section{padding:88px 0;}
.section-soft{background:var(--paper-soft);}
.section-deep{background:var(--ink);color:#fff;}
.section-deep h2,.section-deep h3{color:#fff;}
.section-deep p{color:#B9CCD6;}

.section-head{max-width:680px;margin:0 auto 50px;text-align:center;}
.section-head h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-top:14px;}
.section-head p{margin-top:14px;font-size:1.02rem;}
.section-head.left{margin:0 0 46px;text-align:left;}

/* ---------- Cards grid : campings ---------- */
.camp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.camp-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-card);
  transition:transform .3s ease,border-color .3s ease;
  display:flex;flex-direction:column;
}
.camp-card:hover{transform:translateY(-6px);border-color:var(--blue-light);}
.camp-card .img-wrap{position:relative;height:200px;overflow:hidden;}
.camp-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.camp-card:hover .img-wrap img{transform:scale(1.06);}
.camp-card .tag{
  position:absolute;top:14px;left:14px;background:rgba(255,255,255,0.92);
  color:var(--blue-deep);font-family:var(--font-display);font-size:0.72rem;font-weight:700;
  padding:5px 12px;border-radius:999px;letter-spacing:0.02em;
}
.camp-card .body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px;flex:1;}
.camp-card .body h3{font-size:1.18rem;}
.camp-card .loc{display:flex;align-items:center;gap:6px;font-size:0.82rem;color:var(--blue-deep);font-weight:600;}
.camp-card .body p{font-size:0.92rem;}
.camp-card .cta-row{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:8px;}
.camp-card .cta-row a{font-family:var(--font-display);font-weight:700;font-size:0.85rem;color:var(--blue-deep);display:flex;align-items:center;gap:6px;}
.camp-card .cta-row a:hover{color:var(--blue-light);}

/* ---------- Feature list with icon ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.feature-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  padding:26px 22px;transition:border-color .25s ease,transform .25s ease;
}
.feature-card:hover{border-color:var(--blue-light);transform:translateY(-4px);}
.feature-card .ic{
  width:46px;height:46px;border-radius:12px;background:var(--blue-pale);
  display:flex;align-items:center;justify-content:center;color:var(--blue-deep);font-size:1.3rem;margin-bottom:16px;
}
.feature-card h4{font-size:1.02rem;margin-bottom:8px;}
.feature-card p{font-size:0.88rem;}

/* ---------- Stat band ---------- */
.stat-band{
  background:linear-gradient(120deg,var(--blue-deep),var(--blue-light));
  border-radius:var(--radius-lg);padding:42px 40px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;color:#fff;
}
.stat-band .item b{display:block;font-family:var(--font-display);font-size:2rem;}
.stat-band .item span{font-size:0.84rem;opacity:0.9;}

/* ---------- Map / serp simulation ---------- */
.serp-mock{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  padding:22px 24px;box-shadow:var(--shadow-card);
}
.serp-mock .serp-url{font-size:0.78rem;color:#1a7a4a;margin-bottom:4px;}
.serp-mock .serp-title{color:#1558a8;font-size:1.08rem;font-weight:600;margin-bottom:4px;}
.serp-mock .serp-desc{font-size:0.86rem;color:var(--ink-soft);}

/* ---------- Accordion FAQ ---------- */
.accordion-item{border-bottom:1px solid var(--line);}
.accordion-item summary{
  cursor:pointer;list-style:none;padding:20px 4px;
  font-family:var(--font-display);font-weight:700;font-size:1rem;
  display:flex;align-items:center;justify-content:space-between;
}
.accordion-item summary::-webkit-details-marker{display:none;}
.accordion-item summary::after{content:"+";color:var(--blue-deep);font-size:1.3rem;font-weight:400;}
.accordion-item[open] summary::after{content:"–";}
.accordion-item .acc-body{padding:0 4px 22px;font-size:0.92rem;color:var(--ink-soft);}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cfe2ea;padding:64px 0 30px;}
.site-footer .container{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;}
.site-footer h5{color:#fff;font-family:var(--font-display);font-size:0.92rem;margin-bottom:16px;}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.site-footer a{font-size:0.88rem;color:#a9c2cc;transition:color .2s ease;}
.site-footer a:hover{color:#fff;}
.footer-bottom{
  max-width:1180px;margin:46px auto 0;padding:24px 24px 0;
  border-top:1px solid rgba(255,255,255,0.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  font-size:0.8rem;color:#7c97a1;
}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:0.84rem;color:var(--ink-soft);padding:20px 0 0;}
.breadcrumb a{color:var(--blue-deep);font-weight:600;}
.breadcrumb span{margin:0 6px;}

/* ---------- Camping detail hero ---------- */
.camp-hero{padding:34px 0 0;}
.camp-hero-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:18px;margin-top:24px;}
.camp-hero-grid img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg);}
.camp-hero-grid .main-img{height:460px;}
.camp-hero-grid .side-imgs{display:grid;grid-template-rows:1fr 1fr;gap:18px;}
.camp-hero-grid .side-imgs img{height:221px;}

.camp-title-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin:30px 0 6px;}
.camp-title-row h1{font-size:clamp(2rem,3.4vw,2.7rem);}
.camp-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:10px;}
.camp-meta .pill{
  display:flex;align-items:center;gap:7px;font-size:0.86rem;font-weight:600;color:var(--ink-soft);
  background:var(--paper-soft);border:1px solid var(--line);padding:8px 14px;border-radius:999px;
}

.two-col{display:grid;grid-template-columns:1.4fr 0.9fr;gap:50px;align-items:start;}
.info-box{
  background:var(--blue-pale);border-radius:var(--radius-md);padding:26px;
  border:1px solid var(--blue-pale-2);
}
.info-box h4{font-size:1rem;margin-bottom:14px;color:var(--blue-deep);}
.info-box ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;}
.info-box li{display:flex;justify-content:space-between;font-size:0.88rem;border-bottom:1px dashed var(--blue-pale-2);padding-bottom:10px;}
.info-box li b{color:var(--ink);}
.info-box .official-link{
  margin-top:18px;display:flex;justify-content:center;
  background:linear-gradient(120deg,var(--blue-deep),var(--blue-light));
  color:#fff;padding:13px 18px;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:0.88rem;
}

.tag-pill{display:inline-flex;align-items:center;gap:6px;background:var(--blue-pale);color:var(--blue-deep);font-size:0.78rem;font-weight:700;padding:6px 13px;border-radius:999px;margin-right:8px;margin-bottom:8px;}

.gallery-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px;}
.gallery-strip img{height:150px;width:100%;object-fit:cover;border-radius:var(--radius-sm);}

.review-band{
  background:var(--paper-soft);border-radius:var(--radius-lg);padding:32px;
  display:flex;align-items:center;gap:30px;margin-top:14px;
  border:1px solid var(--line);
}
.review-score{
  font-family:var(--font-display);font-size:2.4rem;font-weight:800;color:var(--blue-deep);
  display:flex;flex-direction:column;align-items:center;min-width:120px;
}
.review-score span{font-size:0.78rem;color:var(--ink-soft);font-weight:600;}
.review-quote{font-size:0.95rem;color:var(--ink-soft);font-style:italic;flex:1;}

.other-camps-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.mini-camp{
  border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden;background:#fff;
  transition:transform .25s ease,border-color .25s ease;
}
.mini-camp:hover{transform:translateY(-4px);border-color:var(--blue-light);}
.mini-camp img{height:100px;width:100%;object-fit:cover;}
.mini-camp .mc-body{padding:12px 14px;}
.mini-camp h5{font-family:var(--font-display);font-size:0.84rem;margin:0 0 4px;}
.mini-camp span{font-size:0.72rem;color:var(--ink-soft);}

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--blue-pale);border-radius:var(--radius-lg);padding:54px 50px;
  display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
}
.cta-band h3{font-size:1.5rem;max-width:480px;}

/* ---------- Animations: fadeInUp on scroll ---------- */
.reveal{opacity:1;transform:translateY(0);}
.js-ready .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease;}
.js-ready .reveal.in{opacity:1;transform:translateY(0);}

/* shimmer border for highlighted cards */
.shimmer-border{position:relative;}
.shimmer-border::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(120deg,var(--blue-light),transparent,var(--blue-deep),transparent);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  background-size:300% 300%;animation:shimmer 5s linear infinite;pointer-events:none;
}
@keyframes shimmer{0%{background-position:0% 50%;}100%{background-position:300% 50%;}}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero .container{grid-template-columns:1fr;}
  .hero-visual{order:-1;}
  .camp-grid{grid-template-columns:repeat(2,1fr);}
  .feature-grid{grid-template-columns:repeat(2,1fr);}
  .stat-band{grid-template-columns:repeat(2,1fr);}
  .two-col{grid-template-columns:1fr;}
  .site-footer .container{grid-template-columns:repeat(2,1fr);}
  .camp-hero-grid{grid-template-columns:1fr;}
  .camp-hero-grid .main-img{height:320px;}
  .camp-hero-grid .side-imgs{display:none;}
  .other-camps-strip{grid-template-columns:repeat(2,1fr);}
  nav.main-nav{display:none;}
}
@media(max-width:620px){
  .camp-grid{grid-template-columns:1fr;}
  .feature-grid{grid-template-columns:1fr;}
  .stat-band{grid-template-columns:1fr;}
  .gallery-strip{grid-template-columns:repeat(2,1fr);}
  .other-camps-strip{grid-template-columns:1fr;}
  .cta-band{flex-direction:column;text-align:center;}
}
