*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:       #F5F2EC;
  --bg2:      #EDE8DF;
  --khaki:    #C4B99A;
  --khaki-lt: #e2e1de;
  --rose:     #ffffff;
  --rose-md:  #ffffff;
  --rose-dk:  #B88080;
  --dark:     #B88080;
  --mist:     #8A8478;
  --white:    #FFFEFB;
  --hero1:    #EDE0D8;
  --hero2:    #D9C8BE;
}

html { scroll-behavior: smooth; }
body { 
  font-family:'Jost',sans-serif; 
  background:var(--bg); 
  color:var(--dark); 
  overflow-x:hidden;
  line-height: 1.6;
}

/* ══════════════════════════════════════════════════════════════════════
   NAVIGATION
   ══════════════════════════════════════════════════════════════════════ */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  padding: 0 5vw;
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
  transition: background .45s, backdrop-filter .45s;
}
nav.scrolled {
  background: rgba(245,242,236,.95);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(196,185,154,.25);
}
.nav-logo { text-decoration:none; display:flex; align-items:center; }
.nav-links { display:flex; gap:2.2rem; list-style:none; }
.nav-links a {
  font-size:1.0rem; font-weight:300; letter-spacing:.18em; text-transform:uppercase;
  color:var(--dark); text-decoration:none; position:relative; padding-bottom:3px;
  transition:color .3s;
}
.nav-links a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1px; background:var(--rose-dk); transition:width .3s; }
.nav-links a:hover { color:var(--rose-dk); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
  font-size:0.97rem; font-weight:400; letter-spacing:.16em; text-transform:uppercase;
  color:var(--white); background:var(--rose-dk); border:none;
  padding:.58rem 1.4rem; cursor:pointer; transition:background .3s; text-decoration:none;
}
.nav-cta:hover { background:var(--khaki); }

/* Burger menu mobile */
.burger {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  background:none; border:none; padding:4px;
}
.burger span { display:block; width:24px; height:1.5px; background:var(--dark); transition:transform .3s, opacity .3s; }

/* Menu mobile overlay */
.mobile-menu {
  display:none; position:fixed; inset:0; z-index:250;
  background:rgba(245,242,236,.98); backdrop-filter:blur(20px);
  flex-direction:column; align-items:center; justify-content:center; gap:2.5rem;
}
.mobile-menu.open { display:flex; animation:fadeUp .3s ease both; }
.mobile-menu a {
  font-family:'Cormorant Garamond',serif; font-size:2.45rem; font-weight:300;
  color:var(--dark); text-decoration:none; letter-spacing:.06em;
  transition:color .3s;
}
.mobile-menu a:hover { color:var(--rose-dk); }
.mobile-menu .mm-cta {
  font-family:'Jost',sans-serif; font-size:1.05rem; font-weight:400;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--white); background:var(--rose-dk);
  padding:.85rem 2.5rem; margin-top:1rem;
}
.mm-close {
  position:absolute; top:1.4rem; right:5vw;
  font-size:2.05rem; color:var(--mist); cursor:pointer;
  background:none; border:none; line-height:1;
}

@media(max-width:768px){
  .nav-links,.nav-cta { display:none; }
  .burger { display:flex; }
}

/* ══════════════════════════════════════════════════════════════════════
   PAGE SYSTEM
   ══════════════════════════════════════════════════════════════════════ */
.page { display:none; }
.page.active { display:block; animation:fadeUp .5s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);} }

/* ══════════════════════════════════════════════════════════════════════
   CONFETTIS
   ══════════════════════════════════════════════════════════════════════ */
.confetti-layer { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
@keyframes confFall {
  0%   { transform:translateY(-30px) rotate(0deg); opacity:0; }
  8%   { opacity:1; }
  88%  { opacity:.85; }
  100% { transform:translateY(105vh) rotate(600deg); opacity:0; }
}

/* ══════════════════════════════════════════════════════════════════════
   SCROLL HINT & MARQUEE BAND
   ══════════════════════════════════════════════════════════════════════ */
.scroll-hint { position:absolute; bottom:2.2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.5rem; z-index:1; opacity:.6; }
.scroll-hint span { font-size:0.82rem; letter-spacing:.24em; text-transform:uppercase; color:var(--dark); }
.scroll-tick { width:1px; height:44px; background:linear-gradient(to bottom,rgba(184,128,128,.5),transparent); animation:tickPulse 2s ease infinite; }
@keyframes tickPulse { 0%,100%{opacity:.3;}50%{opacity:1;} }

.marquee-band { background:var(--rose-dk); padding:.9rem 0; overflow:hidden; display:flex; position:relative; }
.marquee-band::before,.marquee-band::after { content:''; position:absolute; top:0; bottom:0; width:60px; z-index:2; pointer-events:none; }
.marquee-band::before { left:0; background:linear-gradient(to right,var(--rose-dk),transparent); }
.marquee-band::after { right:0; background:linear-gradient(to left,var(--rose-dk),transparent); }
.marquee-track { display:flex; white-space:nowrap; animation:marquee 32s linear infinite; will-change:transform; }
.marquee-track:hover { animation-play-state:paused; }
@keyframes marquee { from{transform:translateX(0);}to{transform:translateX(-50%);} }
.mi { display:inline-flex; align-items:center; gap:1.4rem; padding:0 1.6rem; font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.25rem; font-weight:300; color:rgba(255,255,255,.88); letter-spacing:.04em; flex-shrink:0; }
.mi-tag { font-family:'Jost',sans-serif; font-style:normal; font-size:0.88rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.5); }
.mi-dot { display:inline-block; width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,.38); flex-shrink:0; }

/* ══════════════════════════════════════════════════════════════════════
   HERO SECTION
   ══════════════════════════════════════════════════════════════════════ */
.hero {
  min-height:80vh;
  background: radial-gradient(ellipse 100% 90% at 50% 40%, var(--hero1) 0%, var(--hero2) 100%);
  position:relative; display:flex; align-items:center; justify-content:center;
  padding:clamp(3rem,10vw,6rem) 5vw 4rem;
}
.hero-inner { max-width:980px; text-align:center; position:relative; z-index:2; }
.hero-tag {
  font-family:'Jost',sans-serif;
  font-size:clamp(0.82rem,1.8vw,0.92rem);
  font-weight:300; letter-spacing:.28em; text-transform:uppercase;
  color:var(--mist); margin-bottom:1.2rem;
}
.hero h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,6.2vw,5.2rem);
  font-weight:300; line-height:1.15; color:var(--dark);
  margin-bottom:1.5rem;
}
.hero h1 em { font-style:italic; font-weight:400; }
.hero-subtitle {
  font-family:'Jost',sans-serif;
  font-size:clamp(1.05rem,2.2vw,1.32rem);
  font-weight:300; line-height:1.55; color:var(--mist);
  max-width:680px; margin:0 auto 2.8rem;
}
.hero-ctas { display:flex; gap:1.2rem; justify-content:center; flex-wrap:wrap; }
.hero-btn {
  font-family:'Jost',sans-serif;
  font-size:clamp(0.92rem,1.8vw,1.02rem);
  font-weight:400; letter-spacing:.16em; text-transform:uppercase;
  padding:clamp(0.75rem,2vw,0.95rem) clamp(1.8rem,4vw,2.5rem);
  text-decoration:none; cursor:pointer; transition:all .35s;
  border:none;
}
.hero-btn-primary {
  background:var(--rose-dk); color:var(--white);
}
.hero-btn-primary:hover { background:var(--khaki); transform:translateY(-2px); }
.hero-btn-secondary {
  background:transparent; color:var(--dark);
  border:1px solid rgba(184,128,128,.35);
}
.hero-btn-secondary:hover { background:rgba(184,128,128,.08); border-color:var(--rose-dk); }

/* Décoration hero */
.hero::before {
  content:'✦'; position:absolute; top:18%; left:12%;
  font-size:1.8rem; color:rgba(184,128,128,.15);
  animation:float1 8s ease-in-out infinite;
}
.hero::after {
  content:'✦'; position:absolute; bottom:22%; right:15%;
  font-size:1.4rem; color:rgba(184,128,128,.12);
  animation:float2 9s ease-in-out infinite;
}
@keyframes float1 { 0%,100%{transform:translateY(0) rotate(0deg);} 50%{transform:translateY(-18px) rotate(15deg);} }
@keyframes float2 { 0%,100%{transform:translateY(0) rotate(0deg);} 50%{transform:translateY(22px) rotate(-12deg);} }

@media(max-width:768px){
  .hero { min-height:70vh; padding-top:5rem; }
  .hero-ctas { flex-direction:column; align-items:center; }
  .hero-btn { width:100%; max-width:300px; text-align:center; }
}

/* ══════════════════════════════════════════════════════════════════════
   SECTION SEO - CONTENU OPTIMISÉ
   ══════════════════════════════════════════════════════════════════════ */
.seo-section {
  padding:clamp(4rem,10vw,7rem) 5vw;
  background:var(--white);
}
.seo-container {
  max-width:1140px;
  margin:0 auto;
}
.seo-section h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4.5vw,3.2rem);
  font-weight:400; line-height:1.25; color:var(--dark);
  margin-bottom:1.8rem;
  text-align:center;
}
.seo-section h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.6rem,3.2vw,2.2rem);
  font-weight:500; line-height:1.3; color:var(--dark);
  margin:2.5rem 0 1.2rem;
}
.seo-section h4 {
  font-family:'Jost',sans-serif;
  font-size:clamp(1.1rem,2vw,1.35rem);
  font-weight:500; letter-spacing:.05em;
  color:var(--rose-dk);
  margin:2rem 0 1rem;
}
.seo-section p {
  font-size:clamp(1.02rem,2vw,1.12rem);
  line-height:1.75;
  color:var(--mist);
  margin-bottom:1.5rem;
}
.seo-section ul, .seo-section ol {
  margin:1.5rem 0 1.5rem 1.5rem;
  line-height:1.8;
  color:var(--mist);
}
.seo-section li {
  font-size:clamp(1.02rem,2vw,1.12rem);
  margin-bottom:0.8rem;
}
.seo-section strong {
  color:var(--dark);
  font-weight:500;
}
.seo-divider {
  text-align:center;
  font-size:1.8rem;
  color:var(--khaki);
  margin:3rem 0;
  letter-spacing:1.5rem;
}
.seo-intro {
  font-size:clamp(1.12rem,2.2vw,1.28rem);
  line-height:1.7;
  color:var(--dark);
  font-weight:300;
  margin-bottom:2.5rem;
  padding:2rem;
  background:rgba(196,185,154,.08);
  border-left:3px solid var(--rose-dk);
}

/* CTA dans sections SEO */
.seo-cta-box {
  background: linear-gradient(135deg, var(--hero1) 0%, var(--hero2) 100%);
  padding:clamp(2rem,5vw,3rem);
  margin:3rem 0;
  text-align:center;
  border-radius:8px;
  border:1px solid rgba(196,185,154,.2);
}
.seo-cta-box h3 {
  margin-top:0;
  margin-bottom:1rem;
}
.seo-cta-box p {
  font-size:clamp(1.05rem,2vw,1.18rem);
  margin-bottom:2rem;
}
.seo-cta-btn {
  display:inline-block;
  font-family:'Jost',sans-serif;
  font-size:1.02rem; font-weight:400; letter-spacing:.16em;
  text-transform:uppercase;
  background:var(--rose-dk); color:var(--white);
  padding:.95rem 2.5rem;
  text-decoration:none;
  transition:all .35s;
  border:none;
  cursor:pointer;
}
.seo-cta-btn:hover {
  background:var(--khaki);
  transform:translateY(-2px);
}
.seo-cta-btn-secondary {
  background:transparent;
  color:var(--dark);
  border:1px solid rgba(184,128,128,.35);
  margin-left:1rem;
}
.seo-cta-btn-secondary:hover {
  background:rgba(184,128,128,.08);
  border-color:var(--rose-dk);
}

/* Tableau comparatif */
.comparison-table {
  width:100%;
  margin:2rem 0;
  border-collapse:collapse;
  font-size:clamp(0.95rem,1.8vw,1.05rem);
}
.comparison-table th {
  background:var(--rose-dk);
  color:var(--white);
  padding:1rem;
  text-align:left;
  font-weight:500;
  letter-spacing:.05em;
}
.comparison-table td {
  padding:1rem;
  border-bottom:1px solid rgba(196,185,154,.2);
}
.comparison-table tr:nth-child(even) {
  background:rgba(196,185,154,.05);
}

@media(max-width:768px){
  .comparison-table {
    font-size:0.9rem;
  }
  .comparison-table th, .comparison-table td {
    padding:0.7rem;
  }
  .seo-cta-btn-secondary {
    margin-left:0;
    margin-top:1rem;
    display:block;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   OFFRES / TARIFS
   ══════════════════════════════════════════════════════════════════════ */
.tarifs {
  padding:clamp(4rem,10vw,7rem) 5vw;
  background:var(--bg);
}
.tarifs-header {
  max-width:780px; margin:0 auto 4rem; text-align:center;
}
.tarifs-header h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4.5vw,3.2rem);
  font-weight:400; line-height:1.25; color:var(--dark);
  margin-bottom:1.2rem;
}
.tarifs-header p {
  font-size:clamp(1.05rem,2.2vw,1.22rem);
  font-weight:300; line-height:1.6; color:var(--mist);
}
.tarifs-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 320px),1fr));
  gap:clamp(1.5rem,4vw,2.5rem);
  max-width:1180px; margin:0 auto;
}
.tarif-card {
  background:var(--white);
  padding:clamp(2rem,5vw,2.8rem) clamp(1.8rem,4vw,2.4rem);
  position:relative;
  border:1px solid rgba(196,185,154,.2);
  transition:transform .3s, box-shadow .3s;
}
.tarif-card:hover {
  transform:translateY(-6px);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.tarif-badge {
  position:absolute; top:-12px; right:1.5rem;
  background:var(--rose-dk); color:var(--white);
  font-size:0.75rem; font-weight:400; letter-spacing:.14em;
  text-transform:uppercase; padding:.4rem 1rem;
}
.tarif-name {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.6rem,3vw,2rem);
  font-weight:500; color:var(--dark);
  margin-bottom:0.8rem;
}
.tarif-price {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5vw,3.8rem);
  font-weight:400; color:var(--rose-dk);
  margin-bottom:0.3rem;
}
.tarif-price span { font-size:clamp(1.2rem,2.5vw,1.6rem); font-weight:300; color:var(--mist); }
.tarif-desc {
  font-size:clamp(0.95rem,1.8vw,1.05rem);
  color:var(--mist); line-height:1.6;
  margin-bottom:1.8rem;
}
.tarif-features {
  list-style:none; margin-bottom:2rem;
}
.tarif-features li {
  font-size:clamp(0.95rem,1.8vw,1.05rem);
  color:var(--dark); padding:0.6rem 0;
  padding-left:1.8rem; position:relative;
  line-height:1.5;
}
.tarif-features li::before {
  content:'✦'; position:absolute; left:0; top:0.6rem;
  color:var(--khaki); font-size:0.9rem;
}
.tarif-btn {
  display:block; width:100%; text-align:center;
  font-family:'Jost',sans-serif;
  font-size:0.95rem; font-weight:400; letter-spacing:.16em;
  text-transform:uppercase;
  background:var(--rose-dk); color:var(--white);
  padding:.85rem 1.5rem; cursor:pointer; transition:background .3s;
  text-decoration:none; border:none;
}
.tarif-btn:hover { background:var(--khaki); }

@media(max-width:768px){
  .tarifs-grid {
    grid-template-columns:1fr;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   CONFIGURATEUR (code existant conservé)
   ══════════════════════════════════════════════════════════════════════ */
.configurateur {
  padding:clamp(4rem,10vw,7rem) 5vw;
  background:var(--white);
}
.cfg-header {
  max-width:880px; margin:0 auto 4.5rem; text-align:center;
}
.cfg-header h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4.5vw,3.2rem);
  font-weight:400; color:var(--dark);
  margin-bottom:1.2rem;
}
.cfg-header p {
  font-size:clamp(1.05rem,2.2vw,1.22rem);
  font-weight:300; line-height:1.6; color:var(--mist);
}
.cfg-step {
  max-width:1200px; margin:0 auto 4rem;
}
.cfg-step-title {
  font-family:'Jost',sans-serif;
  font-size:clamp(0.85rem,1.6vw,0.95rem);
  font-weight:400; letter-spacing:.25em; text-transform:uppercase;
  color:var(--khaki); margin-bottom:1.5rem;
  text-align:center;
}
.cfg-packs {
  display:flex; gap:1.5rem; justify-content:center; margin-bottom:3rem; flex-wrap:wrap;
}
.cfg-pack {
  background:var(--bg); color:var(--dark);
  font-family:'Jost',sans-serif; font-size:0.95rem; font-weight:400;
  letter-spacing:.14em; text-transform:uppercase;
  padding:1rem 2rem; cursor:pointer; transition:all .3s;
  border:1.5px solid transparent;
}
.cfg-pack:hover { border-color:var(--khaki); }
.cfg-pack-active { background:var(--rose-dk); color:var(--white); border-color:var(--rose-dk); }
.cfg-counter {
  text-align:center; font-size:clamp(1.05rem,2vw,1.2rem);
  color:var(--mist); margin-bottom:3rem;
}
.cfg-counter strong { color:var(--rose-dk); font-size:1.35em; font-weight:500; }
.cfg-footer { margin-top:2.5rem; text-align:center; }
.cfg-submit {
  display:inline-block; font-family:'Jost',sans-serif; font-size:1rem;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--white); background:var(--rose-dk); border:none;
  padding:1.1rem 3rem; cursor:pointer; text-decoration:none;
  transition:all 0.3s ease;
}
.cfg-submit:hover { background:var(--dark); transform:translateY(-2px); }
.cfg-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));
  gap:1.5rem;
}
.cfg-section {
  background:var(--bg); padding:1.5rem; position:relative; cursor:pointer;
  transition:all .3s; border:2px solid transparent;
}
.cfg-section:hover { border-color:var(--khaki); transform:translateY(-3px); }
.cfg-section.selected { border-color:var(--rose-dk); background:rgba(184,128,128,.05); }
.cfg-section.disabled { opacity:0.4; pointer-events:none; }
.cfg-section-header {
  display:flex; align-items:flex-start; gap:0.8rem; margin-bottom:0.8rem;
}
.cfg-section-header input[type="checkbox"] {
  margin-top:0.2rem; width:18px; height:18px; cursor:pointer;
  accent-color:var(--rose-dk);
}
.cfg-section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.2rem,2.5vw,1.5rem);
  font-weight:500; color:var(--dark); line-height:1.3; flex:1;
}
.cfg-section-desc {
  font-size:clamp(0.92rem,1.8vw,1.02rem);
  color:var(--mist); line-height:1.5; margin-bottom:0.8rem;
}
.cfg-section-preview {
  display:inline-block;
  font-size:0.88rem; font-weight:400; letter-spacing:.12em;
  text-transform:uppercase; color:var(--khaki);
  text-decoration:underline; cursor:pointer; transition:color .3s;
}
.cfg-section-preview:hover { color:var(--rose-dk); }
.cfg-cta-wrapper {
  text-align:center; margin-top:3rem;
}
.cfg-btn {
  display:inline-block;
  font-family:'Jost',sans-serif;
  font-size:1.02rem; font-weight:400; letter-spacing:.16em;
  text-transform:uppercase;
  background:var(--rose-dk); color:var(--white);
  padding:.95rem 2.8rem; cursor:pointer; transition:background .3s;
  text-decoration:none; border:none;
}
.cfg-btn:hover { background:var(--khaki); }

/* Modal section preview */
.section-modal {
  display:none;
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:9999;
  background:rgba(0,0,0,0.6);
  backdrop-filter:blur(4px);
  justify-content:center;
  align-items:center;
}
.section-modal.open {
  display:flex !important;
}
.section-modal-content {
  position:relative;
  background:#FFFEFB;
  max-width:480px;
  width:90%;
  max-height:90vh;
  overflow-y:auto;
  box-shadow:0 25px 80px rgba(0,0,0,0.3);
  z-index:10000;
}
.section-modal-close {
  position:absolute;
  top:1rem;
  right:1rem;
  width:36px;
  height:36px;
  border-radius:50%;
  border:none;
  background:#F5F2EC;
  color:#8A8478;
  font-size:1.2rem;
  cursor:pointer;
  transition:all 0.2s ease;
  z-index:10001;
}
.section-modal-close:hover { background:#B88080; color:#FFFEFB; }
.section-modal-image-wrapper {
  width:100%;
  height:500px;
  min-height:300px;
  overflow:auto;
  background:#fff;
  position:relative;
}
.section-modal-image {
  width:100%;
  height:auto;
  object-fit:contain;
  display:block;
}
.section-modal-iframe {
  width:100%;
  height:100%;
  border:none;
  display:block;
  background:#fff;
}

/* Modal responsive mobile */
@media(max-width:768px) {
  .section-modal-content {
    max-height:92vh;
    width:98%;
  }
  .section-modal-image-wrapper {
    height:450px;
    min-height:450px;
  }
  .section-modal-title {
    font-size:1.5rem;
    padding:1rem 1.5rem 0.5rem;
  }
  .section-modal-desc {
    font-size:0.95rem;
    padding:0 1.5rem 1rem;
  }
  .section-modal-btn {
    width:calc(100% - 3rem);
    margin:0 1.5rem 1.5rem;
  }
}

.section-modal-title {
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;
  font-weight:400;
  color:#B88080;
  text-align:center;
  padding:1.5rem 2rem 0.5rem;
}
.section-modal-desc {
  font-size:1rem;
  line-height:1.7;
  color:#8A8478;
  font-weight:300;
  text-align:center;
  padding:0 2rem 1.5rem;
}
.section-modal-btn {
  display:block;
  width:calc(100% - 4rem);
  margin:0 2rem 2rem;
  font-family:'Jost',sans-serif;
  font-size:0.95rem;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:#FFFEFB;
  background:#B88080;
  border:none;
  padding:1rem;
  cursor:pointer;
  transition:all 0.3s ease;
}
.section-modal-btn:hover { background:var(--dark); }

.cfg-color-note {
  text-align: center;
  font-size: 0.97rem;
  color: var(--rose-dk);
  font-weight: 400;
  margin: 1.8rem auto 0;
  max-width: 600px;
  padding: 0 1rem;
  font-style: italic;
}
.section-modal-btn:hover { background:#3A3530; }
.section-modal-btn.added { background:#C4B99A; pointer-events:none; }

@media(max-width:768px){
  .cfg-packs { flex-direction:column; align-items:center; }
  .cfg-pack { width:100%; max-width:300px; text-align:center; }
  .section-modal-iframe { height:500px; }
}

/* ══════════════════════════════════════════════════════════════════════
   CONTACT
   ══════════════════════════════════════════════════════════════════════ */
.contact {
  padding:clamp(4rem,10vw,7rem) 5vw;
  background: radial-gradient(ellipse 100% 90% at 50% 40%, var(--hero1) 0%, var(--hero2) 100%);
}
.ct-container {
  max-width:880px; margin:0 auto;
}
.ct-header {
  text-align:center; margin-bottom:3rem;
}
.ct-header h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4.5vw,3.2rem);
  font-weight:400; color:var(--dark);
  margin-bottom:1.2rem;
}
.ct-header p {
  font-size:clamp(1.05rem,2.2vw,1.22rem);
  font-weight:300; line-height:1.6; color:var(--mist);
}
.ct-form {
  background:var(--white); padding:clamp(2rem,5vw,3rem);
  border:1px solid rgba(196,185,154,.2);
}
.ct-row {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));
  gap:1.5rem; margin-bottom:1.5rem;
}
.ct-field {
  display:flex; flex-direction:column;
}
.ct-field label {
  font-size:0.95rem; font-weight:400; letter-spacing:.08em;
  color:var(--dark); margin-bottom:0.5rem; text-transform:uppercase;
}
.ct-field input,
.ct-field select,
.ct-field textarea {
  font-family:'Jost',sans-serif; font-size:1.02rem;
  padding:0.85rem 1rem; background:var(--bg);
  border:1px solid rgba(196,185,154,.3);
  color:var(--dark); transition:border-color .3s;
}
.ct-field input:focus,
.ct-field select:focus,
.ct-field textarea:focus {
  outline:none; border-color:var(--rose-dk);
}
.ct-field textarea {
  resize:vertical; min-height:140px;
}
.ct-offer-label {
  font-size:0.95rem; font-weight:400; letter-spacing:.08em;
  color:var(--dark); margin-bottom:1rem; text-transform:uppercase;
}
.ct-offer-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,160px),1fr));
  gap:1rem; margin-bottom:1.5rem;
}
.ct-offer-btn {
  background:var(--bg); color:var(--dark);
  font-size:0.92rem; font-weight:400; letter-spacing:.1em;
  text-transform:uppercase; padding:0.9rem 1.2rem;
  cursor:pointer; transition:all .3s;
  border:1.5px solid transparent; text-align:center;
}
.ct-offer-btn:hover { border-color:var(--khaki); }
.ct-offer-btn.selected {
  background:var(--rose-dk); color:var(--white); border-color:var(--rose-dk);
}
.ct-submit {
  display:block; width:100%;
  font-family:'Jost',sans-serif;
  font-size:1.02rem; font-weight:400; letter-spacing:.16em;
  text-transform:uppercase;
  background:var(--rose-dk); color:var(--white);
  padding:1rem 2rem; cursor:pointer; transition:background .3s;
  border:none; margin-top:1.5rem;
}
.ct-submit:hover { background:var(--khaki); }

@media(max-width:768px){
  .ct-row { grid-template-columns:1fr; }
  .ct-offer-grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════════════════════════════════
   PAGE RÉCAPITULATIF
   ══════════════════════════════════════════════════════════════════════ */
.recap-page { padding:0 0 5rem; background:var(--bg); }
.recap-hero {
  background: linear-gradient(135deg, var(--hero2) 0%, var(--rose) 100%);
  padding: 4rem 6vw 3rem; text-align:center;
}
.recap-hero-title {
  font-family: 'Great Vibes', cursive;
  font-size: clamp(1.5rem, 7vw, 4rem); color: var(--white); margin-bottom:0.5rem;
  text-shadow: 0 2px 20px rgba(184,128,128,.25);
}
.recap-container {
  max-width: 750px; margin: -3rem auto 4rem; padding: 0 5vw;
}
.recap-box {
  background: var(--white); border: 2px solid var(--rose-dk);
  border-radius: 12px; padding: 2.5rem 2rem;
  box-shadow: 0 10px 40px rgba(184, 128, 128, 0.18);
}
.recap-title {
  font-family: 'Cormorant Garamond', serif; font-size: 2rem;
  color: var(--rose-dk); text-align: center; margin-bottom: 2rem; font-weight: 400;
}
.recap-plan {
  background: var(--bg); padding: 1.5rem; border-radius: 8px;
  margin-bottom: 2rem; text-align: center;
}
.recap-plan-label {
  font-size: 0.92rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--mist); margin-bottom: 0.6rem;
}
.recap-plan-name {
  font-family: 'Great Vibes', cursive; font-size: 2.5rem;
  color: var(--rose-dk); margin-bottom: 0.4rem; line-height:1.2;
}
.recap-plan-price {
  font-family: 'Cormorant Garamond', serif; font-size: 1.6rem;
  color: var(--dark); font-weight: 500;
}
.recap-sections-label {
  font-size: 0.98rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mist); margin-bottom: 1.2rem; font-weight: 400;
}
.recap-sections-list {
  list-style: none; padding: 0; margin: 0 0 2rem 0;
}
.recap-sections-list li {
  padding: 0.8rem 0; border-bottom: 1px solid var(--khaki-lt);
  font-size: 1.08rem; color: var(--dark);
  display: flex; align-items: center; gap: 0.7rem;
}
.recap-sections-list li::before {
  content: '✓'; color: var(--rose-dk); font-weight: 600; font-size: 1.25rem;
}
.recap-sections-list li:last-child { border-bottom: none; }
.recap-edit-btn {
  display: block; width: 100%; font-family: 'Jost', sans-serif;
  font-size: 0.98rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--rose-dk); background: transparent;
  border: 1.5px solid var(--rose-dk); padding: 1rem;
  cursor: pointer; transition: all 0.3s; text-align: center;
}
.recap-edit-btn:hover { background: var(--rose-dk); color: var(--white); }

.recap-form-wrap { max-width: 750px; margin: 0 auto; padding: 0 5vw 3rem; }
.recap-form-header { text-align:center; margin-bottom:2.5rem; }
.recap-form-title {
  font-family: 'Cormorant Garamond', serif; font-size: 2.2rem;
  color: var(--dark); margin-bottom: 0.6rem;
}
.recap-form-desc { color: var(--mist); font-size: 1.08rem; }

.ct-step-label {
  font-size: 0.95rem; font-weight: 400; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--rose-dk);
  margin-bottom: 1.2rem; margin-top: 2rem;
}
.ct-fields { margin-bottom: 1.5rem; }
.ct-fg {
  display: flex; flex-direction: column; margin-bottom: 1.2rem;
}
.ct-fg label {
  font-size: 0.95rem; font-weight: 400; letter-spacing: 0.08em;
  color: var(--dark); margin-bottom: 0.5rem; text-transform: uppercase;
}
.ct-fg input,
.ct-fg select,
.ct-fg textarea {
  font-family: 'Jost', sans-serif; font-size: 1.02rem;
  padding: 0.85rem 1rem; background: var(--bg);
  border: 1px solid rgba(196, 185, 154, 0.3);
  color: var(--dark); transition: border-color 0.3s;
}
.ct-fg input:focus,
.ct-fg select:focus,
.ct-fg textarea:focus {
  outline: none; border-color: var(--rose-dk);
}
.ct-fg textarea {
  resize: vertical; min-height: 140px;
}

@media(max-width:768px) {
  .recap-hero { padding: 3rem 6vw 2.5rem; }
  .recap-box { padding: 2rem 1.5rem; }
  .recap-title { font-size: 1.65rem; }
  .recap-plan-name { font-size: 2rem; }
  .recap-container { margin: -2rem auto 3rem; }
  .ct-row { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════
   PAGE MERCI / CONFIRMATION
   ══════════════════════════════════════════════════════════════════════ */
.thank-you-page {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--hero2) 0%, var(--rose) 50%, var(--khaki) 100%);
  padding: 2rem 5vw;
}
.thank-you-card {
  max-width: 600px; background: var(--white); border-radius: 16px;
  padding: 1.5rem 2.5rem; text-align: center;
  box-shadow: 0 20px 60px rgba(184, 128, 128, 0.3);
  animation: fadeInScale 0.6s ease-out;
}
@keyframes fadeInScale {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}
.thank-you-icon {
  width: 80px; height: 80px; margin: 0 auto 0.6rem;
  animation: bounce 1s ease infinite;
}
@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
.thank-you-title {
  font-family: 'Great Vibes', cursive;
  font-size: clamp(2.2rem, 6vw, 3rem);
  color: var(--rose-dk); margin-bottom: 0.5rem; line-height: 1.1;
}
.thank-you-message {
  font-size: 1.05rem; color: var(--dark);
  line-height: 1.5; margin-bottom: 1rem;
}
.thank-you-details {
  background: var(--bg); padding: 1rem; border-radius: 8px;
  margin-bottom: 1rem; text-align: left;
}
.thank-you-details p {
  margin: 0.3rem 0; font-size: 0.92rem; color: var(--mist);
}
.thank-you-btn {
  display: inline-block; font-family: 'Jost', sans-serif;
  font-size: 0.95rem; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--white); background: var(--rose-dk); border: none;
  padding: 0.85rem 2.2rem; border-radius: 50px;
  cursor: pointer; transition: all 0.3s; text-decoration: none;
}
.thank-you-btn:hover {
  background: var(--rose); transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(184, 128, 128, 0.3);
}

@media(max-width:768px) {
  .thank-you-card { padding: 1.3rem 1.5rem; }
  .thank-you-icon { width: 60px; height: 60px; }
  .thank-you-title { font-size: 1.8rem; }
}

/* ══════════════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════════════ */
footer {
  background:var(--bg2);
  padding:clamp(3rem,8vw,5rem) 5vw clamp(2rem,5vw,3rem);
  border-top:1px solid rgba(196,185,154,.25);
}
.footer-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));
  gap:clamp(2rem,5vw,3rem);
  max-width:1200px; margin:0 auto 3rem;
}
.footer-col h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.3rem,2.5vw,1.6rem);
  font-weight:500; color:var(--dark);
  margin-bottom:1.2rem;
}
.footer-col p,
.footer-col a {
  font-size:clamp(0.95rem,1.8vw,1.05rem);
  color:var(--mist); line-height:1.7;
  text-decoration:none; display:block;
  margin-bottom:0.6rem; transition:color .3s;
}
.footer-col a:hover { color:var(--rose-dk); }
.footer-social {
  display:flex; gap:1.2rem; margin-top:1rem;
}
.footer-social a {
  font-size:1.5rem; color:var(--mist);
  transition:color .3s; display:inline-block;
}
.footer-social a:hover { color:var(--rose-dk); }
.footer-bottom {
  text-align:center; padding-top:2rem;
  border-top:1px solid rgba(196,185,154,.2);
}
.footer-bottom p {
  font-size:0.92rem; color:var(--mist);
}

@media(max-width:768px){
  .footer-grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════════════════════════════════
   GALERIE / MODÈLES
   ══════════════════════════════════════════════════════════════════════ */
.sh {
  text-align:center;
  padding:7rem 5vw 3.5rem;
}
.sh-tag {
  font-size:0.93rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--rose-dk);
  display:block;
  margin-bottom:.9rem;
}
.sh-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.15rem,4vw,3.25rem);
  font-weight:300;
  line-height:1.2;
}
.sh-title em {
  font-style:italic;
  color:var(--rose-dk);
}
.sh-div {
  display:flex;
  align-items:center;
  gap:.9rem;
  justify-content:center;
  margin:1.4rem auto;
}
.sh-div span {
  display:block;
  width:32px;
  height:1px;
  background:var(--khaki-lt);
}
.sh-div i {
  color:var(--rose-dk);
  font-size:0.93rem;
  font-style:normal;
}
.sh-desc {
  max-width:500px;
  margin:0 auto;
  font-size:1.13rem;
  line-height:1.9;
  color:var(--mist);
  font-weight:300;
}

.gal {
  padding:1.5rem 5vw 8rem;
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
}
.gi {
  background:var(--bg2);
  border:1px solid var(--khaki-lt);
  overflow:hidden;
  transition:transform .3s, box-shadow .3s;
}
a.gi {
  text-decoration:none;
  color:inherit;
  display:block;
}
.gi:hover {
  transform:translateY(-5px);
  box-shadow:0 12px 28px rgba(0,0,0,.12);
}
.gi.feat2 {
  grid-column:span 2;
  grid-row:span 2;
}
.gvs {
  width:100%;
  aspect-ratio:16/10;
  background:linear-gradient(135deg,#4a3d38,#2a1e1a);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.9rem;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition:transform .4s;
}
.gi.feat2 .gvs {
  aspect-ratio:16/9;
}
.gvs:hover {
  transform:scale(1.02);
}
.gvs::before {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(232,200,200,.08),transparent);
}
.gvs-play {
  width:54px;
  height:54px;
  border:1.5px solid rgba(232, 200, 200, 0);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--rose);
  font-size:1.45rem;
  position:relative;
  z-index:1;
  transition:transform .3s,border-color .3s;
}
.gvs:hover .gvs-play {
  transform:scale(1.1);
  border-color:var(--rose);
}
.gvs-lbl {
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.13rem;
  color:rgba(255,255,255,.45);
  position:relative;
  z-index:1;
  text-align:center;
  padding:0 1rem;
}
.gvs-tag {
  position:absolute;
  bottom:.7rem;
  right:.7rem;
  font-size:0.85rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(232,200,200,.6);
  background:rgba(0,0,0,.35);
  padding:.25rem .6rem;
  backdrop-filter:blur(4px);
}
.gc {
  padding:.85rem 1rem;
  border-top:1px solid rgba(196,185,154,.2);
}
.gc h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;
  font-weight:400;
  color:var(--dark);
  margin-bottom:.18rem;
}
.gc p {
  font-size:0.96rem;
  color:var(--mist);
  font-weight:300;
  letter-spacing:.04em;
}

@media(max-width:768px){
  .gal {
    grid-template-columns:1fr;
  }
  .gi.feat2 {
    grid-column:span 1;
    grid-row:span 1;
  }
  .sh {
    padding:5rem 6vw 2.5rem;
  }
  .sh-title {
    font-size:2.0rem;
  }
  .seo-section {
    padding:clamp(3rem,8vw,5rem) 5vw;
  }
  .seo-section h2 {
    font-size:clamp(1.8rem,4vw,2.5rem);
  }
  .seo-section h3 {
    font-size:clamp(1.4rem,3vw,1.8rem);
  }
  .seo-cta-box {
    padding:clamp(1.5rem,4vw,2rem);
  }
  .seo-cta-btn-secondary {
    margin-left:0;
    margin-top:1rem;
    display:block;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   UTILITAIRES
   ══════════════════════════════════════════════════════════════════════ */
.text-center { text-align:center; }
.mt-4 { margin-top:2rem; }
.mb-4 { margin-bottom:2rem; }

/* ══════════════════════════════════════════════════════════════════════
   ACTIVE NAV LINK (multi-page)
   ══════════════════════════════════════════════════════════════════════ */
.nav-links a.active { color: var(--rose-dk); }
.nav-links a.active::after { width: 100%; }

/* ══════════════════════════════════════════════════════════════════════
   PAGE WRAPPER (remplace le système .page pour les vraies pages)
   ══════════════════════════════════════════════════════════════════════ */
.page-content { animation: fadeUp .5s ease both; }
