/* ═══════════ MAIA MANSION — luxury dark theme ═══════════ */
:root{
  --bg:#0b0a08;
  --bg2:#12100c;
  --gold:#c8a35f;
  --gold-light:#e3c98f;
  --ivory:#f4efe6;
  --muted:#9b9180;
  --serif:'Cormorant Garamond',serif;
  --sans:'Jost',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ivory);font-family:var(--sans);font-weight:300;overflow-x:hidden}
::selection{background:var(--gold);color:#000}

h1,h2,h3{font-family:var(--serif);font-weight:500}
.kicker{letter-spacing:.45em;text-transform:uppercase;font-size:.7rem;color:var(--gold);margin-bottom:1rem}
.section-head{text-align:center;padding:6rem 1.5rem 3rem}
.section-head h2{font-size:clamp(2.2rem,5vw,3.6rem);letter-spacing:.04em}
.section-head h2 span{color:var(--gold);font-style:italic}

.btn-gold{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#1a1610;text-decoration:none;
  padding:.85rem 2.2rem;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;font-weight:500;border:none;cursor:pointer;
  transition:transform .3s,box-shadow .3s}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(200,163,95,.35)}
.btn-ghost{background:none;border:1px solid rgba(200,163,95,.5);color:var(--gold);padding:.7rem 1.6rem;letter-spacing:.15em;
  text-transform:uppercase;font-size:.7rem;cursor:pointer;font-family:var(--sans);transition:background .3s,color .3s}
.btn-ghost:hover{background:var(--gold);color:#1a1610}

/* ═══════════ NAV ═══════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;
  padding:1.3rem 3rem;transition:background .4s,padding .4s;background:linear-gradient(180deg,rgba(0,0,0,.55),transparent)}
.nav.scrolled{background:rgba(11,10,8,.92);backdrop-filter:blur(12px);padding:.9rem 3rem;border-bottom:1px solid rgba(200,163,95,.15)}
.nav-logo{font-family:var(--serif);font-size:1.35rem;letter-spacing:.3em}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{color:var(--ivory);text-decoration:none;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;opacity:.85;transition:color .3s,opacity .3s}
.nav-links a:hover{color:var(--gold);opacity:1}
.nav-cta{border:1px solid var(--gold);padding:.5rem 1.2rem;color:var(--gold)!important}

/* ═══════════ HERO SCROLLYTELLING ═══════════ */
.hero-track{height:640vh;position:relative}
/* la scène est FIXE : la vidéo (figée sur sa dernière image en fin de scroll)
   sert de décor unique, les sections défilent par-dessus → aucun doublon */
.hero-stage{position:fixed;inset:0;height:100vh;width:100%;overflow:hidden;background:#050403;z-index:0;pointer-events:none}
#heroVideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;will-change:transform}
.interior{position:absolute;inset:0;opacity:0;pointer-events:none;will-change:transform}
.interior img{width:100%;height:100%;object-fit:cover}
.interior-veil{position:absolute;inset:0;background:
  radial-gradient(ellipse at center,transparent 45%,rgba(5,4,3,.45) 100%),
  linear-gradient(180deg,rgba(5,4,3,.30),transparent 28%,transparent 60%,rgba(11,10,8,.82) 100%)}
.hero-vignette{position:absolute;inset:0;background:
  radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.55) 100%),
  linear-gradient(180deg,rgba(0,0,0,.35) 0%,transparent 25%,transparent 70%,rgba(11,10,8,.85) 100%)}

.hero-text{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;opacity:0;pointer-events:none;padding:0 1.5rem}
.hero-kicker{display:inline-block;letter-spacing:.4em;text-transform:uppercase;font-size:.72rem;
  color:var(--gold-light);margin-bottom:1.6rem;padding:.6rem 1.5rem;
  border:1px solid rgba(200,163,95,.6);background:rgba(8,7,5,.34);backdrop-filter:blur(4px);
  box-shadow:0 6px 26px rgba(0,0,0,.4), inset 0 0 16px rgba(0,0,0,.18);
  text-shadow:0 1px 10px rgba(0,0,0,.85)}
.hero-kicker::before,.hero-kicker::after{content:'';position:absolute;width:7px;height:7px;border:1px solid var(--gold)}
.hero-kicker{position:relative}
.hero-kicker::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hero-kicker::after{bottom:-1px;right:-1px;border-left:0;border-top:0}
.hero-text h1{font-size:clamp(3rem,9vw,7.5rem);letter-spacing:.12em;text-shadow:0 4px 40px rgba(0,0,0,.7)}
.hero-text h1 span{color:var(--gold)}
.hero-text h2{font-size:clamp(2.4rem,7vw,5.5rem);letter-spacing:.1em;text-shadow:0 4px 40px rgba(0,0,0,.7)}
.hero-text h2 span{color:var(--gold)}
.hero-sub{margin-top:1.2rem;font-size:clamp(.95rem,2vw,1.25rem);letter-spacing:.3em;text-transform:uppercase;color:var(--ivory);opacity:.9;text-shadow:0 2px 16px rgba(0,0,0,.8)}
.serif-it{font-style:italic;font-weight:400;line-height:1.25}

.scroll-hint{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);text-align:center;color:var(--ivory);opacity:.85}
.scroll-hint span{display:block;font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;margin-bottom:.7rem}
.scroll-line{width:1px;height:46px;margin:0 auto;background:linear-gradient(180deg,var(--gold),transparent);animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.25;transform:scaleY(.6);transform-origin:top}50%{opacity:1;transform:scaleY(1)}}

/* ═══════════ AGENTS — apparition fumée ═══════════ */
.agents{position:absolute;inset:0;opacity:0;pointer-events:none}
.agents.active{pointer-events:auto}
.agents-kicker{position:absolute;top:14vh;left:0;right:0;text-align:center;
  letter-spacing:.5em;text-transform:uppercase;font-size:.8rem;color:var(--gold-light);
  text-shadow:0 2px 18px rgba(0,0,0,.9)}
/* Annotation éditoriale : cercle autour de la tête + trait + plaquette sans fond */
.agents-row{position:absolute;inset:0}
.agent-card{position:absolute;top:29%;width:240px;margin-left:-120px;text-align:center;
  display:flex;flex-direction:column;align-items:center;
  text-shadow:0 2px 16px rgba(0,0,0,.92), 0 0 5px rgba(0,0,0,.7)}
.agent-card:nth-child(1){left:22%}
.agent-card:nth-child(2){left:78%}
.agent-ring{width:122px;height:122px;border-radius:50%;border:1.5px solid var(--gold);
  box-shadow:0 0 30px rgba(200,163,95,.30), inset 0 0 24px rgba(200,163,95,.12)}
.agent-stem{width:1px;height:62px;margin:8px 0 16px;
  background:linear-gradient(var(--gold),rgba(200,163,95,.12))}
.agent-overline{font-size:.6rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.agent-card h3{font-size:1.7rem;letter-spacing:.04em;line-height:1.12;font-weight:500;color:var(--ivory)}
.agent-card h3 span{display:block;color:var(--gold);font-style:italic}
.agent-divider{width:40px;height:1px;margin:.85rem auto;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);position:relative}
.agent-divider::after{content:'◆';position:absolute;top:-7px;left:50%;transform:translateX(-50%);
  font-size:.5rem;color:var(--gold)}
.agent-role{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivory);opacity:.85;
  white-space:normal;line-height:1.7;margin-bottom:.9rem}
.agent-phone{display:block;font-family:var(--serif);color:var(--ivory);text-decoration:none;font-size:1.25rem;
  letter-spacing:.1em;margin-bottom:1rem;transition:color .3s}
.agent-phone:hover{color:var(--gold-light)}
.agent-card .btn-gold{background:none;border:1px solid rgba(200,163,95,.75);color:var(--gold);padding:.55rem 1.5rem;font-size:.62rem;text-shadow:none}
.agent-card .btn-gold:hover{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#1a1610;box-shadow:0 8px 30px rgba(200,163,95,.3)}
.agent-avatar{display:none}
.agent-avatar.big{display:flex;width:120px;height:120px;font-size:2.3rem;margin:0 auto 1.8rem;border-radius:50%;
  align-items:center;justify-content:center;font-family:var(--serif);color:#1a1610;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));letter-spacing:.05em}

.smoke{position:absolute;width:60vmax;height:60vmax;border-radius:50%;filter:blur(70px);opacity:0;pointer-events:none;
  background:radial-gradient(circle,rgba(200,180,150,.16),transparent 60%)}
.smoke-1{top:-10%;left:-5%}
.smoke-2{bottom:-15%;right:-8%;background:radial-gradient(circle,rgba(160,140,120,.13),transparent 60%)}
.smoke-3{top:25%;left:35%;background:radial-gradient(circle,rgba(220,200,170,.10),transparent 65%)}

/* ═══════════ LISTINGS ═══════════ */
/* Annonces : transparentes pour laisser voir le décor figé (la scène fixe),
   avec un voile dégradé pour la lisibilité des cartes */
.listings{position:relative;z-index:1;padding-bottom:5rem;background:transparent}
.listings::before{content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,7,5,.30) 0%,rgba(8,7,5,.55) 55%,rgba(8,7,5,.92) 100%)}
.filters{display:flex;gap:1.4rem;justify-content:center;align-items:flex-end;flex-wrap:wrap;margin:0 auto 3.5rem;padding:0 1.5rem;max-width:1100px}
.filter label{display:block;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.filter select{appearance:none;background:var(--bg2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23c8a35f'/%3E%3C/svg%3E") no-repeat right 1rem center;
  border:1px solid rgba(200,163,95,.3);color:var(--ivory);font-family:var(--sans);font-size:.85rem;letter-spacing:.06em;
  padding:.75rem 2.6rem .75rem 1.1rem;min-width:170px;cursor:pointer;transition:border-color .3s}
.filter select:hover,.filter select:focus{border-color:var(--gold);outline:none}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:2.2rem;max-width:1320px;margin:0 auto;padding:0 1.5rem}
.card{background:var(--bg2);border:1px solid rgba(200,163,95,.14);overflow:hidden;opacity:0;transform:translateY(40px);
  transition:border-color .35s,transform .35s;cursor:pointer;text-decoration:none;color:inherit;display:block}
.card.visible{opacity:1;transform:translateY(0);transition:opacity .8s ease,transform .8s ease,border-color .35s}
.card:hover{border-color:rgba(200,163,95,.55);transform:translateY(-6px)}
.card-img{position:relative;aspect-ratio:16/10.5;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.card:hover .card-img img{transform:scale(1.07)}
.badge{position:absolute;top:1rem;left:1rem;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#1a1610;
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;padding:.45rem .9rem}
.card-body{padding:1.6rem 1.7rem 1.8rem}
.card-loc{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.card-body h3{font-size:1.55rem;letter-spacing:.03em;margin-bottom:.7rem}
.card-specs{display:flex;gap:1.3rem;font-size:.8rem;color:var(--muted);margin-bottom:1rem;flex-wrap:wrap}
.card-price{font-family:var(--serif);font-size:1.45rem;color:var(--gold-light);letter-spacing:.05em}
.no-result{text-align:center;color:var(--muted);padding:3rem 1.5rem;font-size:1.05rem}
.no-result a{color:var(--gold)}

/* ═══════════ SUR MESURE ═══════════ */
.surmesure{background:linear-gradient(180deg,var(--bg) 0%,#161310 50%,var(--bg) 100%);padding:7rem 1.5rem;position:relative;z-index:1}
.sm-inner{max-width:1150px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:center}
.sm-left{text-align:center}
.sm-quote{font-family:var(--serif);font-size:1.6rem;line-height:1.5;font-weight:400}
.sm-quote em{color:var(--gold)}
.sm-sign{margin-top:1.4rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.sm-right h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1.4rem}
.sm-right h2 span{color:var(--gold);font-style:italic}
.sm-text{color:var(--muted);line-height:1.85;font-size:1rem;margin-bottom:2rem;max-width:560px}
.sm-steps{list-style:none;margin-bottom:2.5rem}
.sm-steps li{padding:.85rem 0;border-bottom:1px solid rgba(200,163,95,.14);font-size:.95rem;letter-spacing:.04em}
.sm-steps li span{color:var(--gold);font-family:var(--serif);margin-right:1.1rem;font-size:1.05rem}

/* ═══════════ SERVICES ═══════════ */
.services{padding-bottom:6rem;position:relative;z-index:1;background:var(--bg)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.8rem;max-width:1320px;margin:0 auto;padding:0 1.5rem}
.service{border:1px solid rgba(200,163,95,.18);padding:2.6rem 2.2rem;background:var(--bg2);transition:border-color .35s,transform .35s}
.service:hover{border-color:rgba(200,163,95,.5);transform:translateY(-5px)}
.service-num{font-family:var(--serif);font-size:2.2rem;color:var(--gold);opacity:.65;margin-bottom:1.2rem}
.service h3{font-size:1.45rem;margin-bottom:.9rem;letter-spacing:.03em}
.service p{color:var(--muted);font-size:.92rem;line-height:1.75;margin-bottom:1.4rem}
.service a{color:var(--gold);text-decoration:none;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase}
.service a:hover{color:var(--gold-light)}

/* ═══════════ AVIS ═══════════ */
.avis{background:linear-gradient(180deg,var(--bg),#100e0b);padding-bottom:6rem;position:relative;z-index:1}
.avis-score{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.4rem;flex-wrap:wrap}
.g-logo{font-weight:600;font-size:1.5rem;font-family:Arial,sans-serif;letter-spacing:-.02em}
.g-logo .g1{color:#4285F4}.g-logo .g2{color:#EA4335}.g-logo .g3{color:#FBBC05}.g-logo .g4{color:#34A853}
.stars{color:#FBBC05;letter-spacing:.18em;font-size:1.1rem}
.stars.sm{font-size:.8rem;display:block;margin-top:.15rem}
.score-num{color:var(--muted);font-size:.9rem;letter-spacing:.08em}
.avis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.8rem;max-width:1320px;margin:0 auto;padding:0 1.5rem}
.review{background:var(--bg2);border:1px solid rgba(200,163,95,.14);padding:2rem}
.review-head{display:flex;gap:1rem;align-items:center;margin-bottom:1.1rem}
.review-avatar{width:46px;height:46px;border-radius:50%;background:#2a251d;color:var(--gold);display:flex;align-items:center;
  justify-content:center;font-size:.85rem;letter-spacing:.05em;flex-shrink:0}
.review-head b{font-weight:500;letter-spacing:.05em;font-size:.95rem}
.review p{color:var(--muted);font-size:.9rem;line-height:1.75;font-style:italic}

/* ═══════════ FOOTER ═══════════ */
.footer{border-top:1px solid rgba(200,163,95,.18);text-align:center;padding:4.5rem 1.5rem 2.5rem;position:relative;z-index:1;background:var(--bg)}
.footer-logo{font-family:var(--serif);font-size:1.8rem;letter-spacing:.3em}
.footer-logo span{color:var(--gold)}
.footer-tag{font-family:var(--serif);font-style:italic;color:var(--muted);margin:.9rem 0 2rem;font-size:1.05rem}
.footer-cols{display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.footer-cols a,.footer-cols span{color:var(--ivory);opacity:.8;text-decoration:none;font-size:.85rem;letter-spacing:.12em}
.footer-cols a:hover{color:var(--gold);opacity:1}
.footer-legal{color:#5d564a;font-size:.72rem;letter-spacing:.08em}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:900px){
  .nav{padding:1rem 1.3rem}
  .nav.scrolled{padding:.8rem 1.3rem}
  .nav-links{gap:1.1rem}
  .nav-links a:not(.nav-cta){display:none}
  .sm-inner{grid-template-columns:1fr;gap:3rem;text-align:center}
  .sm-text{margin-left:auto;margin-right:auto}
  .sm-steps{text-align:left}
  /* mobile : la vidéo recadre les fondateurs hors champ → on masque les cercles
     et on pose les deux plaquettes centrées en bas, sans tracé */
  .agents-kicker{top:11vh;bottom:auto}
  .agent-ring,.agent-stem{display:none}
  .agent-card{top:auto;bottom:6vh;width:44vw;margin-left:0}
  .agent-card:nth-child(1){left:3vw}
  .agent-card:nth-child(2){left:auto;right:3vw}
  .agent-card h3{font-size:1.15rem}
  .agent-role{font-size:.52rem;margin-bottom:.7rem}
  .agent-phone{font-size:.95rem;margin-bottom:.9rem}
  .agent-card .btn-gold{padding:.55rem 1rem;font-size:.58rem}
  .agent-divider{margin:.7rem auto}
}
