/* ===== VARIABLES ===== */
:root {
  --bleu:        #2980b9;
  --bleu-clair:  #d6eaf8;
  --bleu-fonce:  #1a5276;
  --orange:      #e67e22;
  --orange-clair:#fde8cc;
  --vert:        #4a7c59;
  --vert-clair:  #d5e8d4;
  --blanc:       #ffffff;
  --gris-clair:  #f5f8fa;
  --gris-texte:  #4a4a4a;
  --radius:      14px;
  --radius-sm:   8px;
  --shadow:      0 4px 20px rgba(41,128,185,.10);
  --shadow-hover:0 8px 32px rgba(41,128,185,.18);
  --font-titre:  'Raleway', sans-serif;
  --font-corps:  'Source Sans 3', sans-serif;
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-corps); font-size:17px; color:var(--gris-texte); background:var(--blanc); line-height:1.65; }
img  { max-width:100%; display:block; }
a    { color:var(--bleu); text-decoration:none; }
a:hover { color:var(--orange); }

/* ===== HEADER / NAV ===== */
header {
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(8px);
  border-bottom:2px solid var(--bleu-clair);
  box-shadow:0 2px 12px rgba(41,128,185,.07);
}
.nav-inner {
  max-width:1100px; margin:0 auto; padding:0 24px;
  display:flex; align-items:center; justify-content:space-between; height:72px;
}
.logo {
  display:flex; align-items:center; gap:14px;
  font-family:var(--font-titre); font-weight:800; font-size:1.1rem;
  color:var(--bleu-fonce); text-decoration:none;
}
.logo-img-wrap {
  width:58px; height:58px; border-radius:50%; overflow:hidden;
  border:3px solid var(--orange); background:var(--bleu-clair);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.logo-img-wrap img { width:100%; height:100%; object-fit:contain; }
.logo-texte { display:flex; flex-direction:column; line-height:1.15; }
.logo-texte span:first-child { color:var(--orange); font-size:.75rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; }
.logo-texte span:last-child  { color:var(--bleu-fonce); font-size:1rem; }

nav { display:flex; align-items:center; gap:4px; }
nav > a, .nav-dropdown > a {
  font-family:var(--font-titre); font-weight:600; font-size:.88rem; letter-spacing:.03em;
  padding:8px 14px; border-radius:var(--radius-sm); color:var(--bleu-fonce);
  transition:background .2s, color .2s;
}
nav > a:hover, nav > a.active,
.nav-dropdown:hover > a { background:var(--bleu-clair); color:var(--bleu); }
.nav-dropdown { position:relative; }
.nav-dropdown > a::after { content:' ▾'; font-size:.7em; }
.dropdown-menu {
  display:none; position:absolute; top:calc(100% + 6px); left:0;
  background:white; border-radius:var(--radius-sm);
  box-shadow:var(--shadow-hover); border:1px solid var(--bleu-clair);
  min-width:220px; padding:6px 0; z-index:200;
}
.dropdown-menu a { display:block; padding:9px 18px; font-size:.85rem; border-radius:0; }
.dropdown-menu a:hover { background:var(--gris-clair); }
.nav-cta { background:var(--orange) !important; color:white !important; border-radius:30px !important; padding:9px 18px !important; }
.nav-cta:hover { background:#d35400 !important; color:white !important; }

/* ===== BURGER ===== */
.burger {
  display:none; flex-direction:column; justify-content:center; align-items:center; gap:5px;
  background:none; border:none; cursor:pointer; padding:8px; margin-left:8px;
  width:40px; height:40px;
}
.burger span {
  display:block !important; width:24px; height:3px;
  background:var(--bleu-fonce); border-radius:2px; flex-shrink:0;
}

/* Nav mobile cachée par défaut */
.nav-mobile { display:none; }

/* ===== RESPONSIVE NAV ===== */
@media (max-width:860px) {
  .logo-texte { display:none; }
  .burger { display:flex; }
  header { position:relative; }

  /* Cacher nav desktop */
  .nav-desktop { display:none !important; }

  /* Nav mobile : menu déroulant vertical à plat */
  .nav-mobile {
    display:none;
    position:absolute; top:72px; left:0; right:0;
    flex-direction:column;
    background:white;
    border-top:2px solid var(--bleu-clair);
    border-bottom:2px solid var(--bleu-clair);
    box-shadow:0 8px 24px rgba(0,0,0,.12);
    z-index:99;
    padding:8px 0;
  }
  .nav-mobile.open { display:flex; }
  .nav-mobile a {
    padding:13px 24px;
    font-family:var(--font-titre); font-weight:600; font-size:.95rem;
    color:var(--bleu-fonce); border-bottom:1px solid var(--bleu-clair);
    transition:background .15s;
  }
  .nav-mobile a:last-child { border-bottom:none; }
  .nav-mobile a:hover, .nav-mobile a.active { background:var(--bleu-clair); color:var(--bleu); }
  .nav-cta { font-size:.82rem; padding:8px 14px !important; }
}

/* ===== HERO ===== */
.hero {
  position:relative; min-height:520px;
  background:linear-gradient(135deg, var(--bleu-fonce) 0%, var(--bleu) 50%, var(--vert) 100%);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 60%, rgba(255,255,255,.06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 80% 30%, rgba(74,124,89,.25) 0%, transparent 60%);
}
.hero-img { position:absolute; inset:0; object-fit:cover; width:100%; height:100%; opacity:.35; }
.hero-wave { position:absolute; bottom:-2px; left:0; width:100%; line-height:0; }
.hero-wave svg { display:block; width:100%; }
.hero-content {
  position:relative; z-index:2; text-align:center;
  padding:80px 24px 110px; color:white; max-width:800px;
}
.hero-saison {
  display:inline-block; background:rgba(230,126,34,.9); color:white;
  font-family:var(--font-titre); font-weight:700; font-size:.78rem;
  letter-spacing:.12em; text-transform:uppercase;
  padding:5px 16px; border-radius:30px; margin-bottom:16px;
  animation:fadeDown .7s ease both;
}
.hero-slogan {
  font-family:var(--font-titre); font-weight:300; font-size:.95rem;
  letter-spacing:.18em; text-transform:uppercase; opacity:.8; margin-bottom:12px;
  animation:fadeDown .75s .05s ease both;
}
.hero h1 {
  font-family:var(--font-titre); font-weight:800;
  font-size:clamp(2rem,5vw,3.2rem); line-height:1.15;
  margin-bottom:18px; text-shadow:0 2px 16px rgba(0,0,0,.25);
  animation:fadeDown .8s .1s ease both;
}
.hero-sub {
  font-size:1.05rem; font-weight:300; opacity:.92;
  max-width:560px; margin:0 auto 32px;
  animation:fadeDown .8s .2s ease both;
}
.hero-buttons {
  display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
  animation:fadeDown .8s .3s ease both;
}
@keyframes fadeDown {
  from { opacity:0; transform:translateY(-16px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ===== BANDEAU HERO PAGES SECONDAIRES ===== */
.page-hero {
  position:relative; min-height:280px;
  background:linear-gradient(135deg, var(--bleu-fonce) 0%, var(--bleu) 60%, var(--vert) 100%);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.page-hero-img { position:absolute; inset:0; object-fit:cover; width:100%; height:100%; opacity:.3; }
.page-hero-wave { position:absolute; bottom:-2px; left:0; width:100%; line-height:0; }
.page-hero-wave svg { display:block; width:100%; }
.page-hero-content { position:relative; z-index:2; text-align:center; padding:52px 24px 80px; color:white; }
.page-hero-content .breadcrumb { font-size:.82rem; opacity:.7; margin-bottom:10px; }
.page-hero-content .breadcrumb a { color:rgba(255,255,255,.8); }
.page-hero-content h1 {
  font-family:var(--font-titre); font-weight:800;
  font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:8px;
}
.page-hero-content .hero-sub { font-size:1rem; opacity:.85; max-width:600px; margin:0 auto; }

/* ===== BOUTONS ===== */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-titre); font-weight:700; font-size:.92rem;
  padding:13px 26px; border-radius:30px;
  transition:transform .18s, box-shadow .18s, background .18s; cursor:pointer;
}
.btn:hover { transform:translateY(-2px); box-shadow:0 6px 24px rgba(0,0,0,.18); }
.btn-primary { background:var(--orange); color:white; }
.btn-primary:hover { background:#d35400; color:white; }
.btn-outline { background:rgba(255,255,255,.15); color:white; border:2px solid rgba(255,255,255,.6); backdrop-filter:blur(4px); }
.btn-outline:hover { background:rgba(255,255,255,.25); color:white; }
.btn-blanc { background:white; color:var(--vert); font-family:var(--font-titre); font-weight:700; font-size:.95rem; padding:13px 30px; border-radius:30px; display:inline-block; transition:transform .18s, box-shadow .18s; }
.btn-blanc:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.15); color:var(--vert); }

/* ===== STRUCTURE ===== */
.section { padding:72px 24px; }
.section-gris { background:var(--gris-clair); }
.container { max-width:1100px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:52px; }
.section-header h2 { font-family:var(--font-titre); font-weight:800; font-size:clamp(1.6rem,3vw,2.2rem); color:var(--bleu-fonce); margin-bottom:10px; }
.section-header p { font-size:1.05rem; color:#666; max-width:560px; margin:0 auto; }
.trait-orange { width:48px; height:4px; background:var(--orange); border-radius:2px; margin:12px auto 0; }

/* ===== CARDS ===== */
.cards-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
@media (max-width:900px) { .cards-grid { grid-template-columns:1fr; } }
.card { background:white; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:transform .22s, box-shadow .22s; display:flex; flex-direction:column; }
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-hover); }
.card-img { height:200px; background:var(--bleu-clair); position:relative; overflow:hidden; }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.card:hover .card-img img { transform:scale(1.05); }
.card-badge { position:absolute; top:14px; left:14px; background:var(--orange); color:white; font-family:var(--font-titre); font-weight:700; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; padding:4px 12px; border-radius:20px; }
.card-body { padding:24px 26px 28px; flex:1; display:flex; flex-direction:column; }
.card-body h3 { font-family:var(--font-titre); font-weight:700; font-size:1.15rem; color:var(--bleu-fonce); margin-bottom:10px; }
.card-body p  { font-size:.93rem; color:#666; margin-bottom:20px; line-height:1.6; flex:1; }
.card-link { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-titre); font-weight:700; font-size:.88rem; color:var(--bleu); letter-spacing:.02em; margin-top:auto; }
.card-link::after { content:'→'; transition:transform .18s; }
.card-link:hover { color:var(--orange); }
.card-link:hover::after { transform:translateX(4px); }
.loisirs-list { list-style:none; margin-bottom:16px; }
.loisirs-list li { padding:4px 0; font-size:.92rem; display:flex; align-items:flex-start; gap:8px; }
.loisirs-list li::before { content:'✦'; color:var(--orange); font-size:.65rem; flex-shrink:0; margin-top:5px; }

/* ===== INFOS PRATIQUES ===== */
.infos-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:24px; }
.info-card { background:white; border-radius:var(--radius); padding:28px 24px; box-shadow:var(--shadow); text-align:center; border-top:4px solid var(--bleu); }
.info-card.accent-orange { border-top-color:var(--orange); }
.info-card.accent-vert   { border-top-color:var(--vert); }
.info-icon { font-size:2.2rem; margin-bottom:12px; }
.info-card h3 { font-family:var(--font-titre); font-weight:700; font-size:1rem; color:var(--bleu-fonce); margin-bottom:8px; }
.info-card p  { font-size:.9rem; color:#666; line-height:1.55; }
.info-card strong { color:var(--gris-texte); }

/* ===== CITATION STEVENSON ===== */
.stevenson { background:linear-gradient(135deg, var(--bleu-fonce) 0%, var(--bleu) 100%); padding:72px 24px; text-align:center; position:relative; overflow:hidden; }
.stevenson::before { content:'❝'; position:absolute; top:-10px; left:50%; transform:translateX(-50%); font-size:18rem; color:rgba(255,255,255,.04); font-family:Georgia,serif; line-height:1; }
.stevenson blockquote { position:relative; font-style:italic; font-size:clamp(1.05rem,2.2vw,1.3rem); color:rgba(255,255,255,.92); max-width:720px; margin:0 auto 20px; line-height:1.75; }
.stevenson cite { font-family:var(--font-titre); font-weight:600; font-style:normal; font-size:.85rem; color:var(--orange); letter-spacing:.06em; text-transform:uppercase; }

/* ===== MOT DU PRÉSIDENT ===== */
.president { display:grid; grid-template-columns:1fr 1.4fr; gap:52px; align-items:center; }
@media (max-width:700px) { .president { grid-template-columns:1fr; } }
.president-video { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-hover); }
.video-wrapper { position:relative; padding-bottom:56.25%; height:0; background:var(--bleu-fonce); }
.video-wrapper iframe { position:absolute; top:0; left:0; width:100%; height:100%; border:none; }
.president-texte h2 { font-family:var(--font-titre); font-weight:800; font-size:1.9rem; color:var(--bleu-fonce); margin-bottom:6px; }
.president-texte .trait-orange { margin:0 0 20px; }
.president-texte p { margin-bottom:14px; font-size:1rem; color:#555; }
.president-texte .signature { font-family:var(--font-titre); font-weight:700; color:var(--bleu-fonce); margin-top:18px; font-size:1rem; }
.badge-ffck { display:inline-flex; align-items:center; gap:10px; background:var(--bleu-clair); border-radius:30px; padding:8px 18px 8px 10px; font-size:.82rem; font-weight:600; color:var(--bleu-fonce); margin-top:20px; font-family:var(--font-titre); }
.badge-ffck .dot { width:32px; height:32px; background:var(--bleu); border-radius:50%; color:white; font-size:.7rem; font-weight:800; display:flex; align-items:center; justify-content:center; letter-spacing:-.02em; }

/* ===== TÉLÉCHARGEMENTS ===== */
.dl-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; }
.dl-card { background:white; border-radius:var(--radius); padding:22px 24px; box-shadow:var(--shadow); display:flex; align-items:center; gap:18px; transition:box-shadow .2s, transform .2s; }
.dl-card:hover { box-shadow:var(--shadow-hover); transform:translateY(-3px); }
.dl-icon { width:52px; height:52px; background:var(--orange-clair); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.6rem; flex-shrink:0; }
.dl-info h4 { font-family:var(--font-titre); font-weight:700; font-size:.95rem; color:var(--bleu-fonce); margin-bottom:3px; }
.dl-info span { font-size:.82rem; color:#888; }
.dl-btn { margin-left:auto; background:var(--bleu); color:white; font-family:var(--font-titre); font-weight:700; font-size:.8rem; padding:8px 16px; border-radius:20px; flex-shrink:0; transition:background .18s; }
.dl-btn:hover { background:var(--bleu-fonce); color:white; }

/* ===== CONTACT CTA ===== */
.contact-band { background:var(--vert); padding:56px 24px; text-align:center; color:white; }
.contact-band h2 { font-family:var(--font-titre); font-weight:800; font-size:clamp(1.5rem,3vw,2rem); margin-bottom:8px; }
.contact-band p { opacity:.88; margin-bottom:28px; font-size:1.05rem; }
.contact-infos { display:flex; flex-wrap:wrap; justify-content:center; gap:16px; margin-bottom:32px; }
.contact-item { display:flex; align-items:center; gap:10px; background:rgba(255,255,255,.15); border-radius:30px; padding:10px 22px; font-weight:600; font-size:.93rem; }

/* ===== ANCV ===== */
.ancv-band { background:var(--bleu-clair); padding:20px 24px; text-align:center; }
.ancv-inner { display:inline-flex; align-items:center; gap:12px; font-family:var(--font-titre); font-weight:600; font-size:.88rem; color:var(--bleu-fonce); }
.ancv-badge { background:var(--orange); color:white; font-weight:800; font-size:.8rem; padding:4px 12px; border-radius:20px; }

/* ===== FOOTER ===== */
footer { background:var(--bleu-fonce); color:rgba(255,255,255,.75); padding:48px 24px 24px; }
.footer-grid { max-width:1100px; margin:0 auto; display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:48px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.12); margin-bottom:24px; }
@media (max-width:700px) { .footer-grid { grid-template-columns:1fr; gap:28px; } }
.footer-logo { font-family:var(--font-titre); font-weight:800; font-size:1.05rem; color:white; margin-bottom:12px; }
.footer-desc { font-size:.88rem; line-height:1.6; }
.footer-desc a { color:rgba(255,255,255,.6); }
.footer-desc a:hover { color:white; }
footer h4 { font-family:var(--font-titre); font-weight:700; font-size:.85rem; letter-spacing:.08em; text-transform:uppercase; color:var(--orange); margin-bottom:14px; }
footer ul { list-style:none; }
footer ul li { margin-bottom:8px; }
footer ul li a { color:rgba(255,255,255,.7); font-size:.88rem; transition:color .18s; }
footer ul li a:hover { color:white; }
.footer-contact-item { font-size:.88rem; margin-bottom:8px; display:flex; align-items:flex-start; gap:8px; }
.footer-contact-item a { color:rgba(255,255,255,.7); }
.footer-contact-item a:hover { color:white; }
.footer-bottom { max-width:1100px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; font-size:.78rem; color:rgba(255,255,255,.4); }
.footer-bottom a { color:rgba(255,255,255,.4); }
.footer-bottom a:hover { color:white; }

@media (max-width:600px) {
  .hero-content { padding-top:60px; padding-bottom:90px; }
  .hero-buttons { flex-direction:column; align-items:center; }
}

/* ===== CSS PAGES SECONDAIRES (content-grid, sidebar, etc.) ===== */
.page-hero {
  position:relative; min-height:360px;
  background:linear-gradient(135deg, var(--bleu-fonce) 0%, var(--bleu) 100%);
  display:flex; align-items:flex-end; overflow:hidden;
}
.page-hero-img { position:absolute; inset:0; object-fit:cover; width:100%; height:100%; opacity:.38; }
.page-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(26,82,118,.2) 0%, rgba(26,82,118,.65) 100%); }
.page-hero-wave { position:absolute; bottom:-2px; left:0; width:100%; line-height:0; }
.page-hero-wave svg { display:block; width:100%; }
.page-hero-content { position:relative; z-index:2; width:100%; max-width:1100px; margin:0 auto; padding:0 24px 90px; color:white; }
.breadcrumb { font-size:.82rem; opacity:.75; margin-bottom:12px; font-family:var(--font-titre); }
.breadcrumb a { color:rgba(255,255,255,.75); }
.breadcrumb a:hover { color:white; }
.breadcrumb span { margin:0 6px; }
.page-hero-content h1 { font-family:var(--font-titre); font-weight:800; font-size:clamp(2rem,5vw,3rem); line-height:1.15; text-shadow:0 2px 16px rgba(0,0,0,.3); }
.page-hero-content .subtitle { font-size:1.1rem; font-weight:300; opacity:.9; margin-top:10px; max-width:560px; }

.content-grid { display:grid; grid-template-columns:1fr 380px; gap:52px; align-items:start; }
@media (max-width:860px) { .content-grid { grid-template-columns:1fr; } }
.content-main h2 { font-family:var(--font-titre); font-weight:800; font-size:clamp(1.5rem,3vw,2rem); color:var(--bleu-fonce); margin-bottom:6px; }
.content-main p { margin-bottom:16px; font-size:1rem; color:#555; line-height:1.7; }

.citation-inline { border-left:4px solid var(--orange); background:linear-gradient(135deg, var(--bleu-clair) 0%, #eaf4fb 100%); border-radius:0 var(--radius-sm) var(--radius-sm) 0; padding:20px 24px; margin:28px 0; }
.citation-inline blockquote { font-style:italic; font-size:1rem; color:var(--bleu-fonce); line-height:1.7; }
.citation-inline cite { display:block; margin-top:10px; font-family:var(--font-titre); font-weight:600; font-style:normal; font-size:.8rem; color:var(--orange); letter-spacing:.05em; text-transform:uppercase; }

.inline-gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:28px 0; }
.inline-gallery-item { border-radius:var(--radius-sm); overflow:hidden; aspect-ratio:4/3; background:var(--bleu-clair); display:flex; align-items:center; justify-content:center; font-size:2rem; color:var(--bleu); cursor:pointer; transition:transform .22s, box-shadow .22s; box-shadow:var(--shadow); }
.inline-gallery-item img { width:100%; height:100%; object-fit:cover; }
.inline-gallery-item:hover { transform:scale(1.03); box-shadow:var(--shadow-hover); }

.sidebar { display:flex; flex-direction:column; gap:20px; }
.info-box { background:white; border-radius:var(--radius); padding:26px; box-shadow:var(--shadow); border-top:4px solid var(--bleu); }
.info-box.orange { border-top-color:var(--orange); }
.info-box.vert   { border-top-color:var(--vert); }
.info-box h3 { font-family:var(--font-titre); font-weight:700; font-size:1rem; color:var(--bleu-fonce); margin-bottom:14px; }
.info-box ul { list-style:none; }
.info-box ul li { padding:6px 0; font-size:.92rem; color:#555; border-bottom:1px solid var(--bleu-clair); display:flex; align-items:flex-start; gap:10px; }
.info-box ul li:last-child { border-bottom:none; }
.info-box ul li .ico { flex-shrink:0; }
.info-box p { font-size:.92rem; color:#555; line-height:1.6; }

.alert-box { background:var(--orange-clair); border-radius:var(--radius); border-left:4px solid var(--orange); padding:18px 20px; font-size:.9rem; color:#7d4e0a; line-height:1.6; }
.alert-box strong { color:#5d3800; }

.contact-sidebar { background:linear-gradient(135deg, var(--bleu-fonce), var(--bleu)); border-radius:var(--radius); padding:26px; color:white; text-align:center; }
.contact-sidebar h3 { font-family:var(--font-titre); font-weight:700; font-size:1rem; margin-bottom:14px; }
.contact-sidebar a.tel { display:block; font-family:var(--font-titre); font-weight:800; font-size:1.15rem; color:white; margin-bottom:6px; }
.contact-sidebar a.tel:hover { color:var(--orange-clair); }
.contact-sidebar .port { font-size:.9rem; opacity:.85; margin-bottom:16px; }
.contact-sidebar a.mail { display:inline-block; background:var(--orange); color:white; font-family:var(--font-titre); font-weight:700; font-size:.85rem; padding:9px 20px; border-radius:20px; transition:background .18s; }
.contact-sidebar a.mail:hover { background:#d35400; color:white; }
.contact-sidebar .dl-link { display:block; margin-top:12px; font-size:.82rem; color:rgba(255,255,255,.75); text-decoration:underline; }
.contact-sidebar .dl-link:hover { color:white; }

/* ===== CSS CENTRE-LOISIRS ===== */
.intro-section h2{font-family:var(--font-titre);font-weight:800;font-size:clamp(1.5rem,3vw,2rem);color:var(--bleu-fonce);margin-bottom:6px}
.intro-section p{font-size:1rem;color:#555;line-height:1.7;margin-bottom:16px;max-width:780px}
.activites-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:48px}
.activite-card{background:white;border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow);border-top:4px solid var(--bleu);transition:transform .22s,box-shadow .22s}
.activite-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.activite-card.vert{border-top-color:var(--vert)}
.activite-card.orange{border-top-color:var(--orange)}
.activite-card.bleu-fonce{border-top-color:var(--bleu-fonce)}
.activite-icon{font-size:2.4rem;margin-bottom:14px}
.activite-card h3{font-family:var(--font-titre);font-weight:700;font-size:1.05rem;color:var(--bleu-fonce);margin-bottom:10px}
.activite-card p{font-size:.92rem;color:#666;line-height:1.6}
.sejour-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;margin-top:48px}
@media(max-width:700px){.sejour-grid{grid-template-columns:1fr}}
.sejour-imgs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sejour-img{border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:4/3;background:var(--vert-clair);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:var(--shadow)}
.sejour-img img{width:100%;height:100%;object-fit:cover}
.sejour-img:first-child{grid-column:1/-1;aspect-ratio:16/7}
.sejour-texte h2{font-family:var(--font-titre);font-weight:800;font-size:1.6rem;color:var(--bleu-fonce);margin-bottom:8px}
.sejour-texte p{font-size:.97rem;color:#555;line-height:1.7;margin-bottom:14px}
.citation-sejour{background:var(--vert-clair);border-left:4px solid var(--vert);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:16px 20px;margin:20px 0;font-style:italic;font-size:.97rem;color:#2d5a3d}
.cta-band{background:linear-gradient(135deg,var(--bleu-fonce),var(--vert));padding:56px 24px;text-align:center;color:white;border-radius:var(--radius);margin-top:48px}
.cta-band h2{font-family:var(--font-titre);font-weight:800;font-size:1.8rem;margin-bottom:10px}
.cta-band p{opacity:.9;margin-bottom:28px;font-size:1.05rem}

/* ===== CSS GALERIE & LIGHTBOX ===== */
.galerie-grille{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:640px){.galerie-grille{grid-template-columns:repeat(2,1fr)}}
@media(max-width:400px){.galerie-grille{grid-template-columns:1fr}}
.galerie-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:4/3;background:var(--bleu-clair);cursor:pointer;box-shadow:var(--shadow);transition:transform .22s,box-shadow .22s}
.galerie-item:hover{transform:scale(1.02);box-shadow:var(--shadow-hover)}
.galerie-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.galerie-item:hover img{transform:scale(1.06)}
.galerie-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,82,118,.75) 0%,transparent 55%);opacity:0;transition:opacity .25s;display:flex;align-items:flex-end;padding:14px}
.galerie-item:hover .galerie-item-overlay{opacity:1}
.galerie-item-overlay span{font-family:var(--font-titre);font-weight:600;font-size:.85rem;color:white;letter-spacing:.02em}
.galerie-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--bleu);font-family:var(--font-titre);font-size:.82rem;font-weight:600;text-align:center;padding:12px}
.galerie-placeholder .ico{font-size:2.2rem}
.galerie-item-fixe{grid-column:1/-1;aspect-ratio:16/5;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-hover);position:relative;background:var(--bleu-fonce);transition:box-shadow .22s}
.galerie-item-fixe:hover{box-shadow:0 12px 40px rgba(41,128,185,.25)}
.galerie-item-fixe img{width:100%;height:100%;object-fit:cover;display:block}
.galerie-item-fixe .galerie-item-overlay{opacity:1;background:linear-gradient(to top,rgba(26,82,118,.6) 0%,transparent 50%)}
.galerie-item-fixe .galerie-item-overlay span{font-size:1rem}
.galerie-loading{grid-column:1/-1;text-align:center;padding:40px;color:var(--bleu);font-family:var(--font-titre);font-size:.95rem}
.lightbox{display:none;position:fixed;inset:0;z-index:9000;background:rgba(10,20,35,.94);align-items:center;justify-content:center;padding:20px}
.lightbox.active{display:flex}
.lb-inner{position:relative;max-width:1000px;width:100%;display:flex;flex-direction:column;align-items:center;gap:14px}
.lb-img-wrap{width:100%;border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);background:#0a1420;display:flex;align-items:center;justify-content:center;max-height:75vh}
.lb-img-wrap img{max-width:100%;max-height:75vh;object-fit:contain;display:block}
.lb-titre{font-family:var(--font-titre);font-weight:600;font-size:1rem;color:rgba(255,255,255,.9);letter-spacing:.04em;text-align:center}
.lb-compteur{font-size:.8rem;color:rgba(255,255,255,.5);font-family:var(--font-titre);letter-spacing:.08em}
.lb-btn{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;cursor:pointer;width:50px;height:50px;border-radius:50%;color:white;font-size:1.4rem;display:flex;align-items:center;justify-content:center;transition:background .18s;z-index:9001;backdrop-filter:blur(4px)}
.lb-btn:hover{background:rgba(255,255,255,.25)}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-close{position:fixed;top:16px;right:16px;background:rgba(255,255,255,.12);border:none;cursor:pointer;width:44px;height:44px;border-radius:50%;color:white;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .18s;z-index:9001;backdrop-filter:blur(4px)}
.lb-close:hover{background:rgba(230,126,34,.8)}

/* ===== CSS PARCOURS-TARIFS ===== */
.trait-orange-left{width:48px;height:4px;background:var(--orange);border-radius:2px;margin:10px 0 20px}
.apercu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:20px}
@media(max-width:860px){.apercu-grid{grid-template-columns:1fr}}
.apercu-card{background:white;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column}
.apercu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.apercu-img{position:relative;background:var(--bleu-clair);display:flex;align-items:center;justify-content:center;min-height:220px;overflow:hidden}
.apercu-img img{width:100%;object-fit:contain;padding:12px;transition:transform .3s}
.apercu-card:hover .apercu-img img{transform:scale(1.03)}
.apercu-img-overlay{position:absolute;inset:0;background:rgba(26,82,118,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .22s;text-decoration:none}
.apercu-card:hover .apercu-img-overlay{opacity:1}
.apercu-img-overlay span{font-family:var(--font-titre);font-weight:700;font-size:.9rem;color:white;background:rgba(0,0,0,.35);padding:8px 18px;border-radius:20px;letter-spacing:.04em}
.apercu-placeholder{width:100%;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--bleu);font-family:var(--font-titre);font-size:.88rem;font-weight:600;text-align:center;padding:24px}
.apercu-placeholder .ico{font-size:3rem}
.apercu-body{padding:20px 22px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.apercu-body-info h3{font-family:var(--font-titre);font-weight:700;font-size:.97rem;color:var(--bleu-fonce);margin-bottom:3px}
.apercu-body-info span{font-size:.82rem;color:#888}
.btn-dl{display:inline-flex;align-items:center;gap:8px;background:var(--bleu);color:white;font-family:var(--font-titre);font-weight:700;font-size:.85rem;padding:10px 20px;border-radius:24px;transition:background .18s,transform .18s;white-space:nowrap;flex-shrink:0}
.btn-dl:hover{background:var(--bleu-fonce);color:white;transform:translateY(-1px)}
.btn-dl.orange{background:var(--orange)}
.btn-dl.orange:hover{background:#d35400;color:white}
.dl-section-title{font-family:var(--font-titre);font-weight:800;font-size:1.4rem;color:var(--bleu-fonce);margin-bottom:6px}
.dl-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:28px}
.dl-card{background:white;border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow);display:flex;align-items:center;gap:18px;transition:box-shadow .2s,transform .2s}
.dl-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.dl-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0}
.dl-icon.bleu{background:var(--bleu-clair)}
.dl-icon.orange{background:var(--orange-clair)}
.dl-icon.vert{background:var(--vert-clair)}
.dl-info{flex:1}
.dl-info h4{font-family:var(--font-titre);font-weight:700;font-size:.97rem;color:var(--bleu-fonce);margin-bottom:3px}
.dl-info p{font-size:.83rem;color:#888;line-height:1.4}
.dl-btn-wrap{flex-shrink:0}

/* ===== CSS CONTACTS ===== */
.trait-orange-center{width:48px;height:4px;background:var(--orange);border-radius:2px;margin:10px auto 0}
.contact-grid{display:grid;grid-template-columns:380px 1fr;gap:40px;align-items:start}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
.coord-card{background:white;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.coord-card-header{background:linear-gradient(135deg,var(--bleu-fonce),var(--bleu));padding:22px 26px;color:white}
.coord-card-header h2{font-family:var(--font-titre);font-weight:800;font-size:1.2rem;margin-bottom:4px}
.coord-card-header p{font-size:.85rem;opacity:.8}
.coord-card-body{padding:24px 26px}
.coord-item{display:flex;align-items:flex-start;gap:14px;padding:12px 0;border-bottom:1px solid var(--bleu-clair)}
.coord-item:last-child{border-bottom:none;padding-bottom:0}
.coord-ico{width:38px;height:38px;border-radius:10px;background:var(--bleu-clair);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;margin-top:1px}
.coord-ico.orange{background:var(--orange-clair)}
.coord-ico.vert{background:var(--vert-clair)}
.coord-texte{flex:1}
.coord-texte label{display:block;font-family:var(--font-titre);font-weight:700;font-size:.75rem;letter-spacing:.07em;text-transform:uppercase;color:#999;margin-bottom:3px}
.coord-texte a,.coord-texte span{font-size:.97rem;color:var(--gris-texte);font-weight:500;display:block;line-height:1.4}
.coord-texte a{color:var(--bleu)}
.coord-texte a:hover{color:var(--orange)}
.btn-appel{display:flex;align-items:center;gap:10px;background:var(--orange);color:white;font-family:var(--font-titre);font-weight:700;font-size:.92rem;padding:12px 22px;border-radius:30px;margin-top:20px;transition:background .18s,transform .18s;justify-content:center}
.btn-appel:hover{background:#d35400;color:white;transform:translateY(-1px)}
.btn-mail{display:flex;align-items:center;gap:10px;background:var(--bleu);color:white;font-family:var(--font-titre);font-weight:700;font-size:.92rem;padding:12px 22px;border-radius:30px;margin-top:10px;transition:background .18s,transform .18s;justify-content:center}
.btn-mail:hover{background:var(--bleu-fonce);color:white;transform:translateY(-1px)}
.gps-band{background:var(--bleu-clair);border-radius:var(--radius-sm);padding:12px 18px;margin-top:16px;font-family:var(--font-titre);font-size:.85rem;color:var(--bleu-fonce);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-hover)}
.map-wrap iframe{width:100%;height:420px;border:none;display:block}
.map-acces{background:white;border-radius:var(--radius);padding:22px 24px;margin-top:20px;box-shadow:var(--shadow)}
.map-acces h3{font-family:var(--font-titre);font-weight:700;font-size:1rem;color:var(--bleu-fonce);margin-bottom:14px}
.acces-list{list-style:none}
.acces-list li{display:flex;align-items:flex-start;gap:10px;padding:6px 0;font-size:.92rem;color:#555;border-bottom:1px solid var(--bleu-clair)}
.acces-list li:last-child{border-bottom:none}
.acces-list li .ico{flex-shrink:0;margin-top:1px}
.qui-intro{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:700px){.qui-intro{grid-template-columns:1fr}}
.qui-texte h2{font-family:var(--font-titre);font-weight:800;font-size:clamp(1.4rem,3vw,1.9rem);color:var(--bleu-fonce);margin-bottom:6px}
.qui-texte p{font-size:.97rem;color:#555;line-height:1.7;margin-bottom:14px}
.qui-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-hover);aspect-ratio:4/3;background:var(--bleu-clair);display:flex;align-items:center;justify-content:center;font-size:3rem}
.qui-img img{width:100%;height:100%;object-fit:cover}
.equipe-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:36px}
.equipe-card{background:white;border-radius:var(--radius);padding:22px 20px;box-shadow:var(--shadow);text-align:center;border-top:4px solid var(--bleu);transition:transform .2s,box-shadow .2s}
.equipe-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.equipe-card.orange{border-top-color:var(--orange)}
.equipe-card.vert{border-top-color:var(--vert)}
.equipe-card.bleu2{border-top-color:#5dade2}
.equipe-icon{font-size:2rem;margin-bottom:10px}
.equipe-card h3{font-family:var(--font-titre);font-weight:700;font-size:.88rem;color:var(--bleu-fonce);margin-bottom:4px}
.equipe-card small{font-size:.8rem;color:#999;font-family:var(--font-titre)}
.liens-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.lien-card{background:white;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;align-items:flex-start;gap:18px;padding:22px;transition:transform .22s,box-shadow .22s;border-left:4px solid var(--bleu);text-decoration:none;color:inherit}
.lien-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);color:inherit}
.lien-card.orange{border-left-color:var(--orange)}
.lien-card.vert{border-left-color:var(--vert)}
.lien-ico{width:48px;height:48px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--bleu-clair)}
.lien-ico.orange{background:var(--orange-clair)}
.lien-ico.vert{background:var(--vert-clair)}
.lien-info{flex:1;min-width:0}
.lien-info h3{font-family:var(--font-titre);font-weight:700;font-size:.97rem;color:var(--bleu-fonce);margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lien-info p{font-size:.87rem;color:#777;line-height:1.5;margin-bottom:8px}
.lien-url{font-family:var(--font-titre);font-size:.78rem;font-weight:600;color:var(--bleu);letter-spacing:.02em;display:inline-flex;align-items:center;gap:4px}
.lien-url::after{content:'↗';font-size:.85em}
.lien-card:hover .lien-url{color:var(--orange)}
.cat-title{font-family:var(--font-titre);font-weight:800;font-size:1.1rem;color:var(--bleu-fonce);margin:0 0 20px;display:flex;align-items:center;gap:12px}
.cat-title::after{content:'';flex:1;height:2px;background:linear-gradient(to right,var(--bleu-clair),transparent);border-radius:2px}
.cat-block{margin-bottom:52px}
.cat-block:last-child{margin-bottom:0}
