:root{
  --bg:#ffffff; --bg-soft:#ffffff; --bg-muted:#f6f7fb;
  --txt:#0a0f1a; --muted:#5b657a;
  --brand:#111827; --accent:#374151;
  --line:rgba(0,0,0,.08);
  --footer-bg:#0f172a; --footer-txt:#e5e7eb; --footer-muted:#9aa3b2;
  --header-h:72px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; font:16px/1.65 Manrope,system-ui,-apple-system,Segoe UI,Inter,Roboto; color:var(--txt); background:var(--bg)}
a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto; display:block}
.container{width:min(1140px,92vw); margin-inline:auto}
.section{padding:3.6rem 0}
.kicker{font:600 .78rem Manrope; letter-spacing:.18em; text-transform:uppercase; color:var(--muted)}
.display{font-family:Fraunces,ui-serif,Georgia,serif; letter-spacing:.1px}
.display.small{font-size:1.25rem}
h1.display{font-size:clamp(2rem,2.2vw+1rem,3rem); line-height:1.08; margin:0 0 .9rem}
h2.display{font-size:clamp(1.6rem,1.2vw+1rem,2.2rem); line-height:1.12; margin:.2rem 0 .6rem}
.lead{color:var(--muted); font-size:1.05rem; max-width:70ch}

/* Header */
.header{position:sticky; top:0; z-index:70; background:rgba(255,255,255,.92); backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; justify-content:space-between; height:var(--header-h)}
.brand{font-weight:900; letter-spacing:.3px}
.menu{display:flex; gap:1rem}
.menu a{padding:.5rem .6rem; color:#394150; font-weight:700; border-radius:10px}
.menu a:hover{color:var(--txt); background:rgba(0,0,0,.05)}
.menu-toggle{display:none}
@media(max-width:900px){
  .menu-toggle{display:block; cursor:pointer; padding:.55rem .7rem; border:1px solid var(--line); border-radius:8px; background:var(--bg)}
  .menu{position:fixed; inset:0 0 0 auto; width:min(80%,360px); flex-direction:column; padding:1rem; background:var(--bg); border-left:1px solid var(--line); transform:translateX(100%); transition:transform .3s ease; height:100vh; z-index:75}
  .menu.open{transform:translateX(0)}
  .backdrop{position:fixed; inset:0; background:rgba(0,0,0,.35); opacity:0; pointer-events:none; transition:opacity .6s ease; z-index:74}
  .backdrop.show{opacity:1; pointer-events:auto}
}



/* Hero */
.bg-muted{background:var(--bg-muted)}
.hero{padding:6.6rem 0 4rem}
.split{display:grid; grid-template-columns:1.06fr 1fr; gap:2rem; align-items:center}
@media (max-width: 900px){ .split{grid-template-columns:1fr} }
.card{background:var(--bg-soft); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 10px 26px -18px rgba(0,0,0,.18)}
.pad{padding:1.2rem}
.flexcol{display:flex; flex-direction:column; min-height:100%}
.mt-auto{margin-top:auto}

:root{
  --about-bg: #f7f8fb;  /* fond très clair pour la 1re section après le hero */
}

/* Hero About déjà en place */
.about-hero{
  position:relative;
  min-height:78vh;
  color:#fff;
  background:url('./assets/images/about/hero_belem_storm.png') center/cover no-repeat;
}

/* Fondu en bas du hero vers le fond de la section suivante */
.about-hero::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-1px;
  height:160px;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, var(--about-bg) 95%);
  z-index:0;
}

/* la carte texte (si tu utilises déjà le hero-content, tu gardes) */
.about-hero .hero-content{ position:relative; z-index:1; }

/* 1re section après le hero */
.about-section.first{
  background: var(--about-bg);
}

/* sections suivantes inchangées */

/* Aspect ratio helpers + crop */
.cover{object-fit:cover}
.ar-16-10{aspect-ratio:16/10; width:100%}
.ar-4-3{aspect-ratio:4/3; width:100%}
.ar-3-2{aspect-ratio:3/2; width:100%}

/* CTA */
.cta{display:flex; gap:.8rem; flex-wrap:wrap; margin-top:1.1rem}
.btn{display:inline-flex; align-items:center; gap:.5rem; padding:.85rem 1.15rem; border-radius:999px; font-weight:800; cursor:pointer; text-decoration:none}
.btn-primary{background:var(--brand); color:#fff; border:1px solid var(--brand)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-secondary{background:#fff; color:var(--accent); border:1px solid var(--line)}
.btn-secondary:hover{transform:translateY(-2px)}

.spotlight{padding:2.2rem 0}
.spot{display:grid; grid-template-columns:1fr 1.1fr; gap:2rem; align-items:center; margin-bottom:2.2rem}
.spot.reverse .image{order:2}
.spot.reverse div{order:1}
@media (max-width: 900px){ .spot{grid-template-columns:1fr} }
.spot .image{border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 10px 26px -18px rgba(0,0,0,.18)}

/* Grids */
.grid{display:grid; gap:1.2rem}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
@media (max-width: 1100px){ .cols-4{grid-template-columns:repeat(2,1fr)} }
@media (max-width: 740px){ .cols-3,.cols-4{grid-template-columns:1fr} }
.feature{border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--bg-soft); transition:transform .25s ease, box-shadow .25s ease; display:flex; flex-direction:column}
.feature:hover{transform:translateY(-3px); box-shadow:0 16px 44px -22px rgba(0,0,0,.18)}
.feature .num{font-weight:900; margin-right:.35rem; color:var(--brand)}
.cap{font-size:.85rem; color:var(--muted); padding:.5rem .25rem; text-align:center}

/* Gallery grid hover */
.gallery-grid img{border-radius:12px; transition:transform .6s ease; cursor:pointer}
.gallery-grid img:hover{transform:scale(1.02)}

/* Footer */
.footer{padding:3rem 0 4rem; background:var(--footer-bg); color:var(--footer-txt); border-top:1px solid rgba(255,255,255,.08)}
.footer a{color:var(--footer-txt)}
.footer .lead{color:var(--footer-muted)}
.input, textarea{width:100%; padding:.95rem 1rem; border-radius:12px; background:#0b1226; color:#e5e7eb; border:1px solid rgba(255,255,255,.12)}
.input:focus, textarea:focus{outline:2px solid rgba(255,255,255,.22); border-color:transparent}
.form{display:grid; gap:1rem; grid-template-columns:1fr 1fr}
.form .full{grid-column:1 / -1}
@media (max-width: 720px){ .form{grid-template-columns:1fr} }
.footer-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-top:1.6rem}
@media (max-width: 900px){ .footer-grid{grid-template-columns:1fr 1fr} }
@media (max-width: 560px){ .footer-grid{grid-template-columns:1fr} }
.footer-links{list-style:none; padding:0; margin:.4rem 0 0}
.footer-links li{margin:.25rem 0}
.footer-bottom{display:flex; gap:.8rem; align-items:center; justify-content:space-between; border-top:1px solid rgba(255,255,255,.08); margin-top:1.2rem; padding-top:1rem; color:var(--footer-muted)}

/* Sticky CTA mobile */
@media (max-width:820px){
  .sticky-cta{
    position:fixed; left:50%; transform:translateX(-50%);
    bottom:12px; z-index:80; background:#111827; color:#fff;
    padding:.9rem 1.2rem; border-radius:999px; font-weight:800;
    box-shadow:0 8px 24px rgba(0,0,0,.2);
  }
}

/* Modals */
.modal-backdrop[hidden]{display:none!important}
.modal-backdrop{position:fixed; inset:0; background:rgba(0,0,0,.45); backdrop-filter:blur(2px); z-index:90; opacity:0; transition:opacity .6s ease}
.modal-backdrop.show{opacity:1}
.modal[hidden]{display:none!important}
.modal{position:fixed; inset:0; display:grid; place-items:center; z-index:100; padding:1.5rem; opacity:0; transform:scale(.94); transition:opacity .3s ease, transform .3s ease; pointer-events:none}
.modal.show{opacity:1; transform:scale(1); pointer-events:auto}
.modal-panel{max-width:720px; width:min(720px,92vw); background:var(--bg); color:var(--txt); border:1px solid var(--line); border-radius:16px; box-shadow:0 30px 80px rgba(0,0,0,.28); padding:1.2rem 1.2rem 1.4rem; position:relative}
.modal-close{position:absolute; top:.6rem; right:.8rem; border:1px solid var(--line); background:#fff; color:#111; width:36px; height:36px; border-radius:999px; font-size:1.1rem; cursor:pointer}
.modal-list{ margin:.75rem 0 0 1.1rem } 
.modal-list li{ margin:.35rem 0 }
.eligibility-row{ display:flex; gap:.5rem; flex-wrap:wrap; align-items:center; margin-top:.35rem }
.eligibility-msg{ margin:.35rem 0 0; font-size:.95rem; color: var(--muted) }

/* Lightbox */
.lightbox{position:fixed; inset:0; background:rgba(0,0,0,.92); display:flex; align-items:center; justify-content:center; z-index:2000}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92%; max-height:82%; border-radius:10px; box-shadow:0 8px 32px rgba(0,0,0,.6)}
.lightbox button{position:absolute; background:none; border:none; color:#fff; font-size:3rem; cursor:pointer; transition:opacity .6s}
.lightbox button:hover{opacity:.75}
.lightbox-close{top:20px; right:30px}
.lightbox-prev{left:30px}
.lightbox-next{right:30px}

.faq {
  padding: 4rem 2rem;
  background: #fff;
}

.faq h2 {
  text-align: center;
  margin-bottom: 2rem;
  font-size: 2rem;
}

.faq .faq-list {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  background: #f9f9f9;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  margin-bottom: 1rem;
  padding: 1rem 1.2rem;
  transition: background .3s;
  overflow: hidden;
}

.faq-item:hover {
  background: #f0f0f0;
}

.faq-item .question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  cursor: pointer;
}

.faq-item .chevron::before {
  content: "▼";
  font-size: .9rem;
  transition: transform .3s ease;
}

.faq-item:hover .chevron::before {
  transform: rotate(180deg);
}

.faq-item .answer {
  max-height: 0;
  opacity: 0;
  transition: max-height 1s ease-in-out, opacity .8s ease, margin-top .8s ease;
}

.faq-item:hover .answer {
  max-height: 300px; /* ajuster selon la taille du texte */
  opacity: 1;
  margin-top: .6rem;
}

/* ===== Contact section ===== */
.contact {
  padding: 4rem 2rem;
  background: #fafafa;
}

.contact-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  max-width: 1100px;
  margin: 0 auto;
  align-items: start;
}

.contact-text h2 {
  font-size: 2rem;
  margin-bottom: 1rem;
}

.contact-text p {
  margin-bottom: 1.5rem;
  line-height: 1.5;
}

.contact-infos {
  list-style: none;
  padding: 0;
  margin: 0;
}

.contact-infos li {
  margin-bottom: .6rem;
  color: #444;
}

.contact-infos a {
  color: inherit;
  text-decoration: underline;
}

.contact-form form {
  display: grid;
  gap: 1rem;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: .8rem;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 1rem;
}

.contact-form button {
  padding: .8rem 1.6rem;
  background: #111;
  color: #fff;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background .3s ease;
}

.contact-form button:hover {
  background: #333;
}

/* Responsive mobile */
@media (max-width: 768px) {
  .contact-container {
    grid-template-columns: 1fr;
  }
}

/* === ABOUT PAGE THEME (bleu nuit homogène) === */
body.about-page {
  background: #0d1b2a;   /* bleu nuit profond */
  color: #f8f9fa;        /* texte clair */
}

.about-section {
  padding: 4rem 1.5rem;
  background: #0d1b2a;   /* même couleur partout */
}

.about-hero::after {
  content:"";
  position:absolute;
  bottom:0; left:0; right:0; height:200px;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, #0d1b2a 100%);
}

.footer {
  background: #000814;   /* footer encore plus sombre */
  color: #f8f9fa;
}

/* ——— ABOUT : supprimer les cadres blancs & fonds clairs autour des images ——— */
body.about-page .about-card,
body.about-page .spot .image,
body.about-page .card,
body.about-page .about-grid figure {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

/* si tu veux garder des coins arrondis mais sans cadre */
body.about-page .about-card img,
body.about-page .spot .image img,
body.about-page .about-grid figure img {
  border-radius: 12px;
}

/* au cas où une règle globale met un fond/padding sur img */
body.about-page .about-section img {
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
  border: none !important;
}

/* ABOUT — rendre visibles les 4 cartes "Nos valeurs" sur fond bleu nuit */
body.about-page .values .value,
body.about-page .feature {                 /* au cas où tes cartes utilisent .feature */
  background: #14233c !important;         /* bleu nuit un peu plus clair que le fond */
  border: 1px solid rgba(255,255,255,.12) !important;
  color: #e9edf7 !important;
}

body.about-page .values .value h3,
body.about-page .feature h3 {
  color: #ffffff !important;
}

body.about-page .values .value p,
body.about-page .feature p {
  color: #d2dbea !important;
}

/* Harmoniser aussi les textes de section sur fond sombre */
body.about-page .lead { color: #cbd5e1 !important; }
body.about-page .kicker { color: #9fb3c8 !important; }

/* ABOUT — CTA lisible, centrée, et bouton qui ressort */
body.about-page .cta-band{
  background:#091427;              /* bleu nuit + profond pour contraster */
  color:#eef2f7;
  padding:3.2rem 1rem;
}
body.about-page .cta-band .container{
  text-align:center; max-width:900px;
}
body.about-page .cta-band .lead{
  color:#b7c3d5; margin:0 auto 1.1rem;
}
body.about-page .cta-actions{
  display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap;
}

/* Gros bouton clair qui pop sur fond sombre */
body.about-page .cta-band .btn{
  padding:1rem 1.35rem; font-weight:900; border-radius:999px;
}
body.about-page .cta-band .btn-primary{
  background:#ffffff; color:#0d1b2a; border:1px solid rgba(255,255,255,0);
  box-shadow:0 12px 28px -14px rgba(0,0,0,.55);
}
body.about-page .cta-band .btn-primary:hover{ transform:translateY(-2px); }

/* Bouton secondaire transparent bord blanc */
body.about-page .cta-band .btn-secondary{
  background:transparent; color:#ffffff; border:1.5px solid rgba(255,255,255,.35);
}
body.about-page .cta-band .btn-secondary:hover{ transform:translateY(-2px); }

/* Header spacing unifié */
:root { --nav-gap: 1.25rem; } /* ajuste à 1rem / 1.5rem selon ton goût */

.header .nav{
  display:flex;
  align-items:center;
  gap:var(--nav-gap);           /* espace logo ↔︎ bloc menu */
}

.header .menu{
  display:flex;
  align-items:center;
  gap:var(--nav-gap);           /* espace entre chaque lien du menu */
  margin:0; padding:0;
}

.header .menu a{
  display:inline-flex; align-items:center;
  text-decoration:none;
}

.header .brand{ color:#111 !important; white-space:nowrap; } /* logo lisible sur fond clair */
.lang-switch{ margin-left:auto; } /* la bascule FR/EN reste tout à droite */

/* Lang switch always black like the logo */
.header .lang-switch a{ color:#111 !important; }
.header .lang-switch a[aria-current="true"]{ font-weight:600; opacity:1; }
.header .lang-switch a:hover, .header .lang-switch a:focus{ text-decoration:underline; }


/* Header spacing unifié */
:root { --nav-gap: 1.25rem; } /* ajuste à 1rem / 1.5rem selon ton goût */

.header .nav{
  display:flex;
  align-items:center;
  gap:var(--nav-gap);           /* espace logo ↔︎ bloc menu */
}

.header .menu{
  display:flex;
  align-items:center;
  gap:var(--nav-gap);           /* espace entre chaque lien du menu */
  margin:0; padding:0;
}

.header .menu a{
  display:inline-flex; align-items:center;
  text-decoration:none;
}

.header .brand{ color:#111 !important; white-space:nowrap; } /* logo lisible sur fond clair */
.lang-switch{ margin-left:auto; } /* la bascule FR/EN reste tout à droite */


/* --- Promo banners (sticky, au-dessus du contenu) --- */
.site-announcements { position: sticky; top: 0; z-index: 60; }
.site-announcements .ann {
  display: flex; align-items: center; justify-content: center; gap: .75rem;
  padding: .6rem .75rem; margin: 0; font-weight: 600; text-align: center;
}
.site-announcements .ann-vat { background: #b45309; color: #fff; }     /* amber-700 */
.site-announcements .ann-deal { background: #065f46; color: #ecfdf5; }  /* emerald-800 */
.site-announcements .till { opacity: .95; font-weight: 700; }
.ann-close {
  margin-left: .5rem; background: transparent; border: 0; color: inherit;
  font-size: 1.25rem; line-height: 1; cursor: pointer; opacity: .9;
}
.ann-close:hover { opacity: 1; }
@media (max-width: 640px){
  .site-announcements .ann { padding: .55rem .6rem; font-weight: 600; }
}
