/* =========================================================
   MIRI48 — Design system "Lagon & Tiaré"
   Palette inspirée de Tahiti : lagon turquoise, vert tropical,
   corail des couchers de soleil, jaune hibiscus, bois clair.
   ========================================================= */

:root{
  /* Couleurs */
  --lagon:        #11a3ac;   /* turquoise lagon */
  --lagon-deep:   #0a6c79;   /* turquoise profond */
  --lagon-dark:   #0b4a54;   /* texte sombre teinté lagon */
  --vert:         #2f7d52;   /* vert tropical */
  --vert-deep:    #1f5a3a;
  --corail:       #e8654a;   /* corail / coucher de soleil */
  --corail-soft:  #f08a5d;
  --hibiscus:     #f4b740;   /* jaune hibiscus */
  --sable:        #faf4e9;   /* fond sable clair */
  --sable-2:      #f3e9d6;   /* fond sable un peu plus saturé */
  --bois:         #b07d4e;   /* bois clair */
  --ivoire:       #fffdf8;
  --encre:        #1d2a2c;   /* texte principal */
  --encre-doux:   #4a5a5c;   /* texte secondaire */
  --ligne:        #e6dcc8;   /* bordures douces */

  /* Typo */
  --serif: "Marcellus", "Cormorant Garamond", Georgia, serif;
  --sans:  "Mulish", system-ui, -apple-system, sans-serif;

  /* Mesures */
  --max:    1200px;
  --gut:    clamp(20px, 5vw, 64px);
  --radius: 18px;
  --radius-sm: 12px;
  --shadow:    0 18px 48px -22px rgba(11,74,84,.45);
  --shadow-sm: 0 8px 24px -14px rgba(11,74,84,.4);
  --header-h: 76px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--encre);
  background:var(--sable);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{ display:block; max-width:100%; }
a{ color:var(--lagon-deep); text-decoration:none; }
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.1;
  margin:0;
  color:var(--lagon-dark);
  letter-spacing:.01em;
}
p{ margin:0 0 1em; text-wrap:pretty; }
.wrap{ max-width:var(--max); margin-inline:auto; padding-inline:var(--gut); }
.center{ text-align:center; }

/* Eyebrow / kicker */
.kicker{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:800;
  color:var(--corail);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  margin-bottom:1rem;
}
.kicker::before, .kicker.two::after{
  content:"";
  width:26px; height:2px;
  background:currentColor;
  opacity:.5;
}

/* ============ Boutons ============ */
.btn{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--sans); font-weight:800;
  font-size:.95rem; letter-spacing:.01em;
  padding:.85em 1.6em;
  border-radius:999px;
  border:2px solid transparent;
  cursor:pointer;
  white-space:nowrap;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  line-height:1;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn-primary{ background:var(--corail); color:#fff; box-shadow:0 12px 26px -12px rgba(232,101,74,.8); }
.btn-primary:hover{ transform:translateY(-2px); background:#df573b; box-shadow:0 18px 32px -12px rgba(232,101,74,.85); }
.btn-lagon{ background:var(--lagon-deep); color:#fff; }
.btn-lagon:hover{ transform:translateY(-2px); background:var(--lagon-dark); }
.btn-ghost{ background:transparent; color:var(--lagon-dark); border-color:var(--lagon-deep); }
.btn-ghost:hover{ background:var(--lagon-deep); color:#fff; transform:translateY(-2px); }
.btn-light{ background:rgba(255,255,255,.92); color:var(--lagon-dark); }
.btn-light:hover{ background:#fff; transform:translateY(-2px); }

/* ============ Header / Nav ============ */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,253,248,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--ligne);
}
.nav{
  height:var(--header-h);
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem;
}
.brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--serif); }
.brand .mark{ width:34px; height:34px; flex:none; }
.brand .name{ font-size:1.5rem; letter-spacing:.06em; color:var(--lagon-dark); line-height:1; }
.brand .name b{ color:var(--corail); font-weight:400; }

.nav-links{ display:flex; align-items:center; gap:.35rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-family:var(--sans); font-weight:700; font-size:.95rem;
  color:var(--encre); padding:.55em .9em; border-radius:999px;
  transition:background .15s, color .15s; position:relative;
}
.nav-links a:hover{ background:var(--sable-2); color:var(--lagon-dark); }
.nav-links a{ white-space:nowrap; }
.nav-links a.active{ color:var(--lagon-deep); }
.nav-links a.active::after{
  content:""; position:absolute; left:.9em; right:.9em; bottom:.28em;
  height:2px; background:var(--corail); border-radius:2px;
}
.nav-right{ display:flex; align-items:center; gap:.7rem; }

/* Sélecteur de langue */
.lang{
  display:inline-flex; border:1.5px solid var(--ligne); border-radius:999px;
  overflow:hidden; background:#fff;
}
.lang button{
  border:none; background:transparent; cursor:pointer;
  font-family:var(--sans); font-weight:800; font-size:.8rem;
  padding:.42em .8em; color:var(--encre-doux); letter-spacing:.04em;
  transition:background .15s, color .15s;
}
.lang button.on{ background:var(--lagon-deep); color:#fff; }

.burger{
  display:none; width:44px; height:44px; border:none; background:transparent;
  cursor:pointer; padding:9px; border-radius:12px;
}
.burger span{ display:block; height:2.5px; background:var(--lagon-dark); border-radius:2px; margin:5px 0; transition:.25s; }
.burger.open span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

@media (max-width:880px){
  .burger{ display:block; }
  .nav-links{
    position:fixed; inset:var(--header-h) 0 auto 0;
    flex-direction:column; align-items:stretch; gap:0;
    background:var(--ivoire); border-bottom:1px solid var(--ligne);
    padding:.5rem var(--gut) 1.4rem;
    transform:translateY(-130%); transition:transform .32s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--shadow); max-height:calc(100vh - var(--header-h)); overflow:auto;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ padding:.9em .4em; border-bottom:1px solid var(--ligne); border-radius:0; font-size:1.05rem; }
  .nav-links a.active::after{ display:none; }
  .nav-cta{ display:none; }
}
@media (max-width:420px){
  .brand .name{ font-size:1.3rem; }
}

/* ============ Hero ============ */
.hero{ position:relative; isolation:isolate; }
.hero-media{ position:absolute; inset:0; z-index:-2; overflow:hidden; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(11,74,84,.32) 0%, rgba(11,74,84,.12) 35%, rgba(13,40,46,.78) 100%);
}
.hero-inner{
  min-height:clamp(560px, 88vh, 860px);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding-top:calc(var(--header-h) + 2rem); padding-bottom:clamp(2.5rem,6vw,5rem);
  color:#fff;
}
.hero h1{ color:#fff; font-size:clamp(2.6rem, 7vw, 5.4rem); max-width:14ch; }
.hero .lead{
  font-size:clamp(1.05rem,2.2vw,1.4rem); max-width:46ch;
  margin-top:1.1rem; color:rgba(255,255,255,.94); font-weight:500;
}
.hero .hero-cta{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }
.hero .kicker{ color:var(--hibiscus); }

/* badge note / superhost */
.rating-badge{
  display:inline-flex; align-items:center; gap:1rem;
  background:rgba(255,253,248,.95); color:var(--lagon-dark);
  border-radius:16px; padding:.7rem 1.1rem; box-shadow:var(--shadow);
  font-family:var(--sans);
}
.rating-badge .score{ font-family:var(--serif); font-size:1.7rem; line-height:1; }
.rating-badge .stars{ color:var(--corail); font-size:.8rem; letter-spacing:.1em; }
.rating-badge .sep{ width:1px; align-self:stretch; background:var(--ligne); }
.rating-badge .sh{ font-size:.82rem; font-weight:800; line-height:1.25; }
.rating-badge .sh small{ display:block; color:var(--encre-doux); font-weight:600; letter-spacing:.02em; }
.rating-badge .heart{ color:var(--corail); }

/* ============ Sections ============ */
.section{ padding-block:clamp(3.5rem, 8vw, 6.5rem); }
.section.sable2{ background:var(--sable-2); }
.section.lagon{
  background:linear-gradient(135deg, var(--lagon-deep), var(--lagon-dark));
  color:#fff;
}
.section.lagon h2, .section.lagon h3{ color:#fff; }
.section-head{ max-width:60ch; margin-bottom:2.6rem; }
.section-head.center{ margin-inline:auto; }
.section h2{ font-size:clamp(1.9rem, 4.2vw, 3rem); }
.section .sub{ color:var(--encre-doux); font-size:1.08rem; margin-top:.7rem; }
.section.lagon .sub{ color:rgba(255,255,255,.85); }

/* Séparateur tapa */
.tapa-divider{ height:34px; width:100%; color:var(--hibiscus); opacity:.9; }
.tapa-divider svg{ width:100%; height:100%; }

/* ============ Points forts ============ */
.highlights{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.1rem; }
.hl-card{
  background:var(--ivoire); border:1px solid var(--ligne); border-radius:var(--radius);
  padding:1.6rem 1.5rem; box-shadow:var(--shadow-sm);
  transition:transform .2s ease, box-shadow .2s ease;
}
.hl-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.hl-card .ic{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:var(--sable-2); color:var(--lagon-deep); margin-bottom:1rem;
}
.hl-card .ic svg{ width:26px; height:26px; }
.hl-card h3{ font-size:1.25rem; margin-bottom:.35rem; }
.hl-card p{ color:var(--encre-doux); font-size:.97rem; margin:0; }

/* ============ Aperçu logement (split) ============ */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; }
.split.rev{ grid-template-columns:1fr 1.05fr; }
.split.rev .split-media{ order:-1; }
.split-media{ position:relative; }
.split-media img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:4/3; object-fit:cover; }
.split-media .stamp{
  position:absolute; bottom:-18px; right:-12px;
  background:var(--hibiscus); color:var(--lagon-dark);
  font-family:var(--serif); font-size:1rem; padding:.7rem 1.1rem; border-radius:14px;
  box-shadow:var(--shadow-sm); transform:rotate(-3deg);
}
.split h2{ font-size:clamp(1.8rem,4vw,2.7rem); }
.feature-list{ list-style:none; padding:0; margin:1.4rem 0 1.8rem; display:grid; gap:.7rem; }
.feature-list li{ display:flex; gap:.7rem; align-items:flex-start; color:var(--encre-doux); }
.feature-list li svg{ flex:none; width:22px; height:22px; color:var(--vert); margin-top:.15rem; }
@media (max-width:760px){
  .split, .split.rev{ grid-template-columns:1fr; }
  .split.rev .split-media{ order:0; }
}

/* ============ Avis ============ */
.reviews{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.3rem; }
.review{
  background:var(--ivoire); border-radius:var(--radius); padding:1.8rem;
  border:1px solid var(--ligne); box-shadow:var(--shadow-sm); position:relative;
}
.review .quote-mark{ font-family:var(--serif); font-size:3.5rem; color:var(--hibiscus); line-height:.6; height:.5em; display:block; }
.review p{ font-size:1.02rem; color:var(--encre); font-style:italic; }
.review .who{ display:flex; align-items:center; gap:.8rem; margin-top:1.2rem; }
.review .who .av{ width:42px; height:42px; border-radius:50%; background:var(--lagon); color:#fff; display:grid; place-items:center; font-weight:800; font-family:var(--sans); }
.review .who b{ display:block; color:var(--lagon-dark); }
.review .who small{ color:var(--encre-doux); }
.section.lagon .review{ background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.16); }
.section.lagon .review p{ color:#fff; }
.section.lagon .review .who b{ color:#fff; }
.section.lagon .review .who small{ color:rgba(255,255,255,.7); }

/* Note détaillée */
.score-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:1rem 1.6rem; margin-top:1.5rem; }
.score-row{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.6rem 0; border-bottom:1px solid rgba(255,255,255,.16); }
.section.lagon .score-row b{ color:#fff; font-family:var(--serif); font-size:1.15rem; }
.score-row span{ font-weight:600; }

/* ============ Galerie teaser ============ */
.gal-teaser{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:180px; gap:1rem; }
.gal-teaser a{ overflow:hidden; border-radius:var(--radius-sm); box-shadow:var(--shadow-sm); }
.gal-teaser img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gal-teaser a:hover img{ transform:scale(1.06); }
.gal-teaser .big{ grid-column:span 2; grid-row:span 2; }
@media (max-width:760px){ .gal-teaser{ grid-template-columns:repeat(2,1fr); grid-auto-rows:140px; } .gal-teaser .big{ grid-column:span 2; } }

/* ============ CTA bandeau ============ */
.cta-band{ position:relative; isolation:isolate; overflow:hidden; border-radius:var(--radius); }
.cta-band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(110deg, rgba(11,74,84,.92), rgba(232,101,74,.72)); }
.cta-band .inner{ padding:clamp(2.5rem,6vw,4.5rem); color:#fff; }
.cta-band h2{ color:#fff; font-size:clamp(1.9rem,4.5vw,3rem); max-width:18ch; }
.cta-band p{ color:rgba(255,255,255,.92); max-width:46ch; margin-top:.8rem; }
.cta-band .btn-row{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:1.8rem; }

/* ============ Footer ============ */
.site-footer{ background:var(--lagon-dark); color:rgba(255,255,255,.82); padding-block:3.4rem 2rem; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:2.5rem; }
.site-footer h4{ color:#fff; font-family:var(--sans); font-weight:800; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1rem; }
.site-footer a{ color:rgba(255,255,255,.82); }
.site-footer a:hover{ color:var(--hibiscus); }
.footer-links{ list-style:none; padding:0; margin:0; display:grid; gap:.6rem; font-size:.96rem; }
.footer-brand .name{ font-family:var(--serif); font-size:1.7rem; color:#fff; letter-spacing:.06em; }
.footer-brand .name b{ color:var(--hibiscus); font-weight:400; }
.footer-brand p{ font-size:.96rem; margin-top:.8rem; max-width:34ch; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.14); margin-top:2.6rem; padding-top:1.4rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.85rem; color:rgba(255,255,255,.6); }
@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr; gap:1.8rem; } }

/* =========================================================
   ÉDITORIAL — mise en page inspirée des maquettes "villas"
   (héros collage, cadres portrait, bande lagon, cartes projets)
   Palette chaude : corail soleil · turquoise lagon · jaune hibiscus · sable
   ========================================================= */

/* Bouton pilule contour */
.btn-outline{ background:#fff; color:var(--lagon-dark); border-color:var(--ligne); }
.btn-outline:hover{ border-color:var(--lagon-deep); color:var(--lagon-deep); transform:translateY(-2px); }
/* la pilule secondaire ne s'affiche qu'au-delà de l'espace disponible confortable */
@media (max-width:1080px){ .nav-cta.btn-outline{ display:none; } }

/* =========================================================
   HÉROS IMMERSIF — Polynésie : lagon, soleil, scintillement
   Image plein cadre + couches animées (CSS pur, sans vidéo).
   ========================================================= */
.hero-immersive{
  position:relative; isolation:isolate; overflow:hidden; color:#fff;
  min-height:clamp(580px,94vh,960px);
  display:flex; align-items:flex-end;
}
.hero-immersive > .layer{ position:absolute; inset:0; pointer-events:none; }
.hero-immersive .l-img{ z-index:0; overflow:hidden; }
.hero-immersive .l-img img{
  width:100%; height:100%; object-fit:cover; transform-origin:60% 70%;
  animation:hero-zoom 30s ease-in-out infinite alternate;
}
@keyframes hero-zoom{ 0%{ transform:scale(1.05); } 100%{ transform:scale(1.18); } }

/* dégradé de lisibilité + ciel chaud */
.hero-immersive .l-grad{ z-index:1;
  background:
    linear-gradient(180deg, rgba(13,40,48,.30) 0%, rgba(13,40,48,.04) 30%, rgba(8,30,36,.74) 100%),
    linear-gradient(115deg, rgba(232,101,74,.10), transparent 45%);
}
/* soleil qui respire */
.hero-immersive .l-sun{ z-index:1;
  background:radial-gradient(120% 95% at 84% 6%, rgba(255,224,158,.62), rgba(255,176,92,.20) 24%, transparent 52%);
  mix-blend-mode:screen; animation:hero-sun 6.5s ease-in-out infinite alternate;
}
@keyframes hero-sun{ 0%{ opacity:.62; } 100%{ opacity:1; } }
/* scintillement de l'eau (bas de l'image) */
.hero-immersive .l-shimmer{ z-index:1; top:auto; bottom:0; height:46%;
  background:repeating-linear-gradient(98deg,
    rgba(255,255,255,.04) 0 14px, rgba(150,228,236,.12) 14px 28px, rgba(255,255,255,.04) 28px 42px);
  mix-blend-mode:screen; opacity:.55;
  -webkit-mask:linear-gradient(180deg,transparent,#000 65%); mask:linear-gradient(180deg,transparent,#000 65%);
  animation:hero-shimmer 10s linear infinite;
}
@keyframes hero-shimmer{ from{ background-position:0 0; } to{ background-position:280px 0; } }
/* poussières de lumière qui s'élèvent */
.hero-immersive .mote{
  position:absolute; z-index:1; width:7px; height:7px; border-radius:50%; opacity:0;
  background:radial-gradient(circle, rgba(255,238,196,.95), rgba(255,200,120,.3) 55%, transparent 72%);
  animation:mote-rise var(--d,12s) ease-in-out infinite; animation-delay:var(--delay,0s);
}
@keyframes mote-rise{
  0%{ transform:translateY(20px) scale(.5); opacity:0; }
  18%{ opacity:.85; }
  82%{ opacity:.6; }
  100%{ transform:translateY(-150px) scale(1.15); opacity:0; }
}

.hero-immersive .hero-content{
  position:relative; z-index:3; width:100%;
  padding-top:calc(var(--header-h) + 2rem); padding-bottom:clamp(3rem,7vw,6rem);
}
.hero-immersive .kicker{ color:var(--hibiscus); }
.hero-immersive h1{
  color:#fff; font-size:clamp(3.2rem,11vw,8rem); line-height:.92; letter-spacing:.05em;
  text-shadow:0 12px 48px rgba(0,0,0,.35); margin-top:.3rem;
}
.hero-immersive .lead{
  font-size:clamp(1.08rem,2.1vw,1.45rem); max-width:46ch; margin-top:1.1rem;
  color:rgba(255,255,255,.95); font-weight:500; text-shadow:0 2px 18px rgba(0,0,0,.3);
}
.hero-immersive .h-cta{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }
.hero-immersive .hero-badge{ margin-top:2.4rem; }
/* indice de défilement */
.scroll-cue{
  position:absolute; left:50%; bottom:1.4rem; transform:translateX(-50%); z-index:3;
  width:26px; height:42px; border:2px solid rgba(255,255,255,.7); border-radius:14px;
  display:grid; justify-items:center; padding-top:7px;
}
.scroll-cue span{ width:4px; height:9px; border-radius:3px; background:#fff; animation:cue 1.6s ease-in-out infinite; }
@keyframes cue{ 0%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(12px); opacity:0; } 100%{ opacity:0; } }
@media (max-width:600px){ .scroll-cue{ display:none; } }

@media (prefers-reduced-motion:reduce){
  .hero-immersive .l-img img{ animation:none; transform:scale(1.05); }
  .hero-immersive .l-sun{ animation:none; opacity:.85; }
  .hero-immersive .l-shimmer{ animation:none; }
  .hero-immersive .mote{ display:none; }
  .scroll-cue span{ animation:none; }
}

/* ---- Héros collage ---- */
.hero-edit{
  padding-top:calc(var(--header-h) + clamp(1.6rem,4vw,3rem));
  padding-bottom:clamp(2.5rem,6vw,4.5rem);
}
.hero-edit .h-top{
  display:grid; grid-template-columns:0.82fr 1.18fr;
  gap:clamp(1rem,3vw,2.6rem); align-items:end;
}
.hero-edit .h-copy{ padding-bottom:clamp(.5rem,2vw,1.6rem); }
.hero-edit .h-copy h1{
  font-size:clamp(2.4rem,5.2vw,4.1rem); line-height:1.04; margin-top:.4rem;
  max-width:12ch;
}
.hero-edit .h-copy .lead{
  color:var(--encre-doux); font-size:clamp(1.02rem,1.6vw,1.18rem);
  margin-top:1.1rem; max-width:42ch;
}
.hero-edit .h-cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem; }
.hero-edit .h-top-img{
  height:clamp(280px,36vw,440px); width:100%; object-fit:cover;
  border-radius:var(--radius); box-shadow:var(--shadow);
}
.hero-edit .h-wide{
  position:relative; margin-top:clamp(-46px,-4vw,-22px); z-index:2;
}
.hero-edit .h-wide img{
  width:100%; height:clamp(240px,30vw,400px); object-fit:cover;
  border-radius:var(--radius); box-shadow:var(--shadow);
  border:8px solid #fff;
}
.hero-edit .h-badge{
  position:absolute; left:clamp(1rem,3vw,2.4rem); bottom:-26px; z-index:3;
}
@media (max-width:820px){
  .hero-edit .h-top{ grid-template-columns:1fr; gap:1.4rem; }
  .hero-edit .h-top-img{ height:clamp(220px,52vw,340px); }
  .hero-edit .h-wide{ margin-top:1rem; }
}

/* ---- Cadre portrait avec panneau sable derrière ---- */
.framed{ position:relative; }
.framed::before{
  content:""; position:absolute; z-index:0;
  inset:22px -22px -22px 22px; background:var(--sable-2); border-radius:var(--radius);
}
.framed img{
  position:relative; z-index:1; width:100%;
  border-radius:var(--radius); box-shadow:var(--shadow);
}
.framed.portrait img{ aspect-ratio:3/4; object-fit:cover; }
.framed .tag{
  position:absolute; z-index:2; left:-14px; top:18px;
  background:var(--hibiscus); color:var(--lagon-dark);
  font-family:var(--serif); font-size:.95rem; padding:.55rem 1rem;
  border-radius:12px; box-shadow:var(--shadow-sm); transform:rotate(-3deg);
}
@media (max-width:760px){ .framed::before{ inset:14px -14px -14px 14px; } }

/* deux boutons pilule alignés */
.btn-pair{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.6rem; }

/* ---- Bande lagon : image + panneau coloré ---- */
.band{
  display:grid; grid-template-columns:1fr 1fr; align-items:stretch;
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
}
.band .band-img{ position:relative; min-height:340px; }
.band .band-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.band .band-copy{
  background:linear-gradient(140deg, var(--lagon), var(--lagon-deep));
  color:#fff; padding:clamp(2rem,4vw,3.4rem);
  display:flex; flex-direction:column; justify-content:center;
}
.band .band-copy .kicker{ color:rgba(255,255,255,.92); }
.band .band-copy h2{ color:#fff; font-size:clamp(1.7rem,3.4vw,2.5rem); }
.band .band-copy p{ color:rgba(255,255,255,.92); margin-top:.9rem; }
.band .band-bullets{ list-style:none; padding:0; margin:1.1rem 0 0; display:grid; gap:.7rem; }
.band .band-bullets li{ display:flex; gap:.6rem; align-items:flex-start; color:rgba(255,255,255,.95); font-weight:500; }
.band .band-bullets li svg{ flex:none; width:20px; height:20px; color:var(--hibiscus); margin-top:.2rem; }
.band .band-copy .btn{ align-self:flex-start; margin-top:1.6rem; }
@media (max-width:760px){
  .band{ grid-template-columns:1fr; }
  .band .band-img{ min-height:240px; }
}

/* ---- Cartes projets / galerie (rangée) ---- */
.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.1rem,2.4vw,1.8rem); }
.proj-card{ display:flex; flex-direction:column; }
.proj-card .ph{ overflow:hidden; border-radius:var(--radius-sm); box-shadow:var(--shadow-sm); }
.proj-card img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform .5s ease; }
.proj-card:hover img{ transform:scale(1.05); }
.proj-card h3{ font-size:1.18rem; margin-top:1rem; }
.proj-card p{ color:var(--encre-doux); font-size:.95rem; margin-top:.35rem; }
@media (max-width:760px){ .proj-grid{ grid-template-columns:1fr; } }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } html{ scroll-behavior:auto; } }
