/*
  ÉquiLibre — V2 (immersif / editorial)
  Objectif : images au premier plan + typographie magazine.
*/

@font-face{
  font-family: "Solea";
  src:
    url("../fonts/Solea-Regular.ttf") format("truetype"),
    url("../fonts/Solea-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root{
  --bg: #fbf7f0;
  --ink: #141a1b;
  --muted: rgba(20,26,27,.70);
  --muted2: rgba(20,26,27,.58);
  --line: rgba(20,26,27,.14);
  --cream: rgba(255,255,255,.72);
  --glass: rgba(255,255,255,.14);
  --glass2: rgba(255,255,255,.18);
  --ocean: #2f5f66;
  --radius: 26px;
  --max: 1180px;
  --shadow: 0 26px 70px rgba(0,0,0,.16);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  line-height:1.55;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.90}
img{max-width:100%; display:block}

/* Layout */
.container{max-width:var(--max); margin:0 auto; padding:0 22px}
.section{padding:92px 0}
.section.compact{padding:56px 0}
.section.flush{padding:0}

/* Navigation */
.nav-backdrop{display:none}

.nav{
  position:sticky; top:0; z-index:50;
  background: rgba(251,247,240,.62);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(20,26,27,.10);
}
.nav-inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0}
.brand{display:flex; align-items:center; gap:12px}
.brand-logo{height:30px; width:auto}

.nav-toggle{display:none; border:1px solid rgba(20,26,27,.18); background:transparent; border-radius:999px; padding:8px 11px}

.menu{display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:flex-end}
.menu a{font-size:14px; color:rgba(20,26,27,.78)}
.menu a.active{color: var(--ocean)}

.cta{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(47,95,102,.35);
  background: rgba(47,95,102,.08);
  color: var(--ocean);
  font-weight:700;
}

/* Type */
.kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.92;
}
.h1{
  font-family:"Solea", ui-serif, Georgia, "Times New Roman", Times, serif;
  font-weight:400;
  font-size: clamp(42px, 6vw, 82px);
  line-height:1.02;
  letter-spacing: .01em;
  margin:14px 0 12px;
}
.h2{
  font-family:"Solea", ui-serif, Georgia, "Times New Roman", Times, serif;
  font-weight:400;
  font-size: clamp(30px, 3.3vw, 46px);
  line-height:1.12;
  letter-spacing: .01em;
  margin:0 0 10px;
}
.lede{margin:0; color: var(--muted); font-size: 17px; max-width: 70ch}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.55);
  background: var(--glass);
  color:#fff;
  font-weight:800;
  font-size:14px;
  letter-spacing:.01em;
  backdrop-filter: blur(7px);
}
.btn:hover{background: var(--glass2); border-color: rgba(255,255,255,.70)}

.btn.primary{
  background: rgba(47,95,102,.95);
  border-color: rgba(47,95,102,1);
}
.btn.primary:hover{background: rgba(47,95,102,1)}

.btn.dark{
  background: rgba(20,26,27,.90);
  border-color: rgba(255,255,255,.35);
}

/* Hero full-bleed */
.hero{
  position:relative;
  min-height: 82vh;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.20) 35%, rgba(0,0,0,.52) 100%),
    var(--hero, none);
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}
.hero video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  z-index:0;
  filter:saturate(1.03);
}
.hero .overlay{
  position:absolute; inset:0;
  z-index:1;
  background: linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.18) 40%, rgba(0,0,0,.62) 100%);
}

/* Hero video */
.hero.has-video::before{
  background: linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.20) 35%, rgba(0,0,0,.52) 100%);
}
.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transform: scale(1.02);
  z-index:0;
}
.hero-inner{
  position:relative;
  z-index:2;
}

.hero-inner{
  position:relative;
  z-index:2;
  width:100%;
  padding: 0 0 56px;
  color:#fff;
}
.hero-copy{max-width: 86ch}
.hero-meta{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.28);
  color:#fff;
  font-weight:700;
  font-size:12px;
  letter-spacing:.02em;
  backdrop-filter: blur(7px);
}

/* Immersive sections */
.split{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:22px;
  align-items:stretch;
}

.panel{
  border-radius: var(--radius);
  overflow:hidden;
  position:relative;
  min-height: 520px;
  box-shadow: var(--shadow);
}
.panel .media{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}
.panel .shade{position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.12) 45%, rgba(0,0,0,.62) 100%)}
.panel .content{
  position:absolute; inset:auto 0 0 0;
  padding:26px;
  color:#fff;
}

.editorial{
  border-radius: var(--radius);
  background: rgba(255,255,255,.64);
  border:1px solid rgba(20,26,27,.10);
  padding: 28px;
  box-shadow: 0 18px 55px rgba(0,0,0,.08);
}
.editorial p{margin:0 0 12px; color: var(--muted)}
.editorial p:last-child{margin-bottom:0}

/* Image mosaic */
.mosaic{display:grid; gap:14px; grid-template-columns: 1.1fr .9fr; align-items:stretch}
.mosaic .big{border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); aspect-ratio: 16/11}
.mosaic .big img{width:100%; height:100%; object-fit:cover}
.mosaic .stack{display:grid; gap:14px}
.mosaic .small{border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); aspect-ratio: 16/11}
.mosaic .small img{width:100%; height:100%; object-fit:cover}

/* Calendar cards (full image) */
.cards{display:grid; grid-template-columns: repeat(3, 1fr); gap:16px}
.card{
  position:relative;
  border-radius: var(--radius);
  overflow:hidden;
  min-height: 420px;
  box-shadow: var(--shadow);
}
.card::before{
  content:"";
  position:absolute; inset:0;
  background: var(--bgimg);
  background-size:cover;
  background-position:center;
  transform: scale(1.03);
}
.card::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.18) 45%, rgba(0,0,0,.66) 100%);
}
.card .body{position:absolute; inset:auto 0 0 0; z-index:2; padding:22px; color:#fff}
.card .title{font-family:"Solea", ui-serif, Georgia, serif; font-size:28px; font-weight:400; margin:0 0 4px; line-height:1.08}
.card .meta{color: rgba(255,255,255,.86); font-size:14px; margin:0 0 12px}

/* Testimonials */
.quotes{display:grid; grid-template-columns: repeat(3, 1fr); gap:16px}
.quote{
  border-radius: var(--radius);
  border: 1px solid rgba(20,26,27,.10);
  background: rgba(255,255,255,.66);
  padding: 22px;
  box-shadow: 0 18px 55px rgba(0,0,0,.08);
}
.quote .text{font-family: ui-serif, Georgia, serif; font-size: 18px; color: rgba(20,26,27,.78)}
.quote .who{margin-top:12px; font-size:13px; color: rgba(20,26,27,.62)}

/* Footer */
.footer{padding:52px 0; border-top:1px solid rgba(20,26,27,.10); color: var(--muted2)}
.footer .cols{display:grid; grid-template-columns: 1fr 1fr; gap:18px}
.footer-logo{height:30px; width:auto}
.small{font-size:13px}

/* Newsletter modal (keep existing, tuned) */
.modal-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.50);
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
  z-index:80;
}
.modal{
  width:min(760px, 100%);
  background: rgba(251,247,240,.98);
  border:1px solid rgba(255,255,255,.18);
  border-radius: 30px;
  box-shadow: 0 30px 90px rgba(0,0,0,.30);
  overflow:hidden;
}
.modal-inner{display:grid; grid-template-columns: 1fr 1fr}
.modal-media{background:#d8d8d8; min-height:260px}
.modal-media img{width:100%; height:100%; object-fit:cover}
.modal-body{padding:22px}
.modal-body h3{font-family:"Solea", ui-serif, Georgia, serif; font-weight:400; margin:0 0 8px; font-size:30px; line-height:1.08}
.modal-body p{margin:0 0 14px; color: var(--muted)}

.form-row{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.input{
  flex:1 1 220px;
  padding:12px 14px;
  border-radius: 999px;
  border:1px solid rgba(20,26,27,.18);
  background: rgba(255,255,255,.80);
  font-size:14px;
}
.notice{margin-top:10px; font-size:13px; color: var(--muted2)}
.modal-actions{margin-top:14px; display:flex; gap:14px; align-items:center; justify-content:space-between; flex-wrap:wrap}
.close{border:none; background:transparent; color: var(--ocean); font-weight:800; cursor:pointer}

/* Mobile */
@media (max-width: 900px){
  .split{grid-template-columns: 1fr;}
  .cards{grid-template-columns: 1fr;}
  .quotes{grid-template-columns: 1fr;}
  .mosaic{grid-template-columns: 1fr;}
  .panel{min-height: 420px;}
  .hero-inner{padding-bottom: 42px;}

  .nav-toggle{display:inline-flex;}
  .menu{
    position: fixed;
    top: 64px;
    right: 14px;
    left: 14px;
    display: none;
    padding: 16px;
    gap: 12px;
    background: rgba(251,247,240,.98);
    border:1px solid rgba(20,26,27,.10);
    border-radius: 18px;
    box-shadow: 0 18px 55px rgba(0,0,0,.18);
  }
  body.nav-open .menu{display:flex; flex-direction:column; align-items:flex-start;}

  .nav-backdrop{position:fixed; inset:0; display:none; background: rgba(0,0,0,.35); z-index:40;}
  body.nav-open .nav-backdrop{display:block;}
}

@media (prefers-reduced-motion: reduce){
  .hero::before, .panel .media, .card::before{transform:none}
}


/* Content box (for legal / simple pages) */
.paper{
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(20,26,27,.12);
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 18px 55px rgba(0,0,0,.08);
}
																																				/* Galerie Immersive Expanding Cards */
.gallery-immersive {
  display: flex;
  gap: 12px;
  width: 100%;
  height: 450px;
  margin-top: 20px;
}

.gallery-item {
  flex: 1;
  overflow: hidden;
  border-radius: 18px;
  position: relative;
  cursor: pointer;
  transition: all 0.6s cubic-bezier(0.25, 1, 0.5, 1);
  background-image: var(--img);
  background-size: cover;
  background-position: center;
}

.gallery-item:hover {
  flex: 4; /* L'image s'élargit au survol */
}

.gallery-label {
  position: absolute;
  bottom: 20px;
  left: 20px;
  color: white;
  background: rgba(0,0,0,0.4);
  padding: 4px 12px;
  border-radius: 20px;
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: 0.3s;
}

.gallery-item:hover .gallery-label {
  opacity: 1;
}

@media (max-width: 768px) {
  .gallery-immersive {
    flex-direction: column;
    height: 600px;
  }
}
/* Grille de témoignages harmonisée */
.quotes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  align-items: start;
}

.quote-card {
  background: white;
  padding: 30px;
  border-radius: 20px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.04);
  transition: transform 0.3s ease;
  margin: 0;
  border: 1px solid rgba(20,26,27,0.05);
}

.quote-card:hover {
  transform: translateY(-8px);
}

.quote-content blockquote.lede {
  /* On utilise les propriétés de votre classe .lede */
  margin: 0 0 20px 0;
  font-size: 17px; /* Même taille que vos descriptions */
  line-height: 1.55;
  color: var(--muted); /* Même couleur que vos descriptions */
  font-style: normal; /* Pas d'italique pour rester fidèle aux descriptions */
}

.quote-card figcaption {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  opacity: 0.6;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-top: 1px solid rgba(20,26,27,0.08);
  padding-top: 15px;
}

/* Rythme visuel sur ordinateur */
@media (min-width: 992px) {
  .quote-card:nth-child(even) {
    margin-top: 30px;
  }
}																																					  
