:root{
  --noir:#0a0a0a;
  --noir-2:#121212;
  --or:#c8a165;
  --or-clair:#e3c896;
  --blanc:#f7f5f1;
  --gris:#9a9a9a;
  --glass:rgba(255,255,255,0.06);
  --glass-border:rgba(255,255,255,0.12);
  --font-titre:'Cormorant Garamond',Georgia,serif;
  --font-texte:'Jost','Segoe UI',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-texte);
  background:var(--noir);
  color:var(--blanc);
  line-height:1.7;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1240px;margin:0 auto;padding:0 5%}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px 5%;
  transition:all .4s ease;
  background:transparent;
}
.nav.scrolled{
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(14px);
  padding:16px 5%;
  border-bottom:1px solid var(--glass-border);
}
.logo{
  font-family:var(--font-titre);
  font-size:1.7rem;
  font-weight:600;
  letter-spacing:1px;
  display:flex;align-items:center;gap:10px;
}
.logo span{color:var(--or)}
.logo svg{width:30px;height:30px}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{
  font-size:.85rem;text-transform:uppercase;letter-spacing:2px;
  position:relative;padding:4px 0;color:var(--blanc);
  transition:color .3s;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:-2px;width:0;height:1px;
  background:var(--or);transition:width .35s ease;
}
.nav-links a:hover{color:var(--or-clair)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--or)}
.burger{display:none;flex-direction:column;gap:6px;cursor:pointer;z-index:1100}
.burger span{width:28px;height:2px;background:var(--blanc);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;
  background:linear-gradient(rgba(8,8,8,.55),rgba(8,8,8,.78)),
    url('https://images.unsplash.com/photo-1534438327276-14e5300c3a48?w=1600&q=80') center/cover fixed;
}
.hero-inner{max-width:760px}
.hero .eyebrow{
  color:var(--or);letter-spacing:5px;text-transform:uppercase;
  font-size:.8rem;margin-bottom:24px;
}
.hero h1{
  font-family:var(--font-titre);
  font-size:clamp(3rem,7vw,5.6rem);
  line-height:1.05;font-weight:600;margin-bottom:26px;
}
.hero h1 em{color:var(--or);font-style:italic}
.hero p{font-size:1.15rem;color:#d8d4cd;max-width:560px;margin-bottom:40px}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}

.btn{
  display:inline-block;padding:15px 38px;
  font-size:.82rem;text-transform:uppercase;letter-spacing:2px;
  border:1px solid var(--or);cursor:pointer;
  transition:all .35s ease;background:transparent;color:var(--blanc);
}
.btn-primary{background:var(--or);color:var(--noir);font-weight:600}
.btn-primary:hover{background:var(--or-clair);transform:translateY(-3px)}
.btn-ghost:hover{background:var(--or);color:var(--noir);transform:translateY(-3px)}

.scroll-down{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  color:var(--gris);font-size:.7rem;letter-spacing:3px;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.scroll-down::after{content:'';width:1px;height:46px;background:linear-gradient(var(--or),transparent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ---------- SECTIONS ---------- */
section{padding:120px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 70px}
.section-head .eyebrow{color:var(--or);letter-spacing:4px;text-transform:uppercase;font-size:.78rem;margin-bottom:18px;display:block}
.section-head h2{font-family:var(--font-titre);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:600;line-height:1.1;margin-bottom:18px}
.section-head p{color:var(--gris);font-size:1.05rem}
.dark{background:var(--noir-2)}

/* ---------- INTRO SPLIT ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.split .img-wrap{position:relative}
.split .img-wrap img{height:560px;object-fit:cover;width:100%;filter:grayscale(.2)}
.split .img-wrap::before{content:'';position:absolute;inset:18px;border:1px solid var(--or);z-index:-1;transform:translate(20px,20px)}
.split h2{font-family:var(--font-titre);font-size:2.8rem;font-weight:600;margin-bottom:24px;line-height:1.15}
.split .eyebrow{color:var(--or);letter-spacing:4px;text-transform:uppercase;font-size:.78rem;margin-bottom:18px;display:block}
.split p{color:#c4c0b9;margin-bottom:20px}
.stats{display:flex;gap:40px;margin-top:34px}
.stat .num{font-family:var(--font-titre);font-size:2.6rem;color:var(--or)}
.stat .lab{font-size:.78rem;text-transform:uppercase;letter-spacing:2px;color:var(--gris)}

/* ---------- SERVICES ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{
  background:var(--glass);border:1px solid var(--glass-border);
  backdrop-filter:blur(10px);padding:0;overflow:hidden;
  transition:transform .5s ease,box-shadow .5s ease;
}
.card:hover{transform:translateY(-12px);box-shadow:0 30px 60px rgba(0,0,0,.5)}
.card .card-img{height:230px;overflow:hidden}
.card .card-img img{height:100%;width:100%;object-fit:cover;transition:transform .8s ease}
.card:hover .card-img img{transform:scale(1.1)}
.card-body{padding:34px 30px 38px}
.card .ico{width:48px;height:48px;color:var(--or);margin-bottom:18px}
.card h3{font-family:var(--font-titre);font-size:1.7rem;margin-bottom:14px;font-weight:600}
.card p{color:var(--gris);font-size:.96rem;margin-bottom:18px}
.card .price-tag{color:var(--or);font-size:.85rem;letter-spacing:2px;text-transform:uppercase;border-top:1px solid var(--glass-border);padding-top:16px}

/* ---------- TARIFS ---------- */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:34px;max-width:880px;margin:0 auto}
.price-card{
  background:var(--glass);border:1px solid var(--glass-border);
  backdrop-filter:blur(10px);padding:50px 44px;text-align:center;
  transition:all .45s ease;position:relative;
}
.price-card.featured{border-color:var(--or);background:rgba(200,161,101,.07)}
.price-card .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--or);color:var(--noir);font-size:.68rem;letter-spacing:2px;text-transform:uppercase;padding:6px 18px;font-weight:600}
.price-card:hover{transform:translateY(-10px);border-color:var(--or)}
.price-card h3{font-family:var(--font-titre);font-size:1.9rem;margin-bottom:8px;font-weight:600}
.price-card .sub{color:var(--gris);font-size:.9rem;margin-bottom:26px}
.price-card .amount{font-family:var(--font-titre);font-size:3.6rem;color:var(--or);line-height:1}
.price-card .amount small{font-size:1rem;color:var(--gris)}
.price-card ul{list-style:none;margin:30px 0;text-align:left}
.price-card li{padding:10px 0;border-bottom:1px solid var(--glass-border);font-size:.95rem;color:#cfcbc4;display:flex;align-items:center;gap:12px}
.price-card li svg{width:18px;height:18px;color:var(--or);flex-shrink:0}

/* ---------- GALERIE ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery a{overflow:hidden;position:relative;display:block}
.gallery img{height:300px;width:100%;object-fit:cover;transition:transform .7s ease,filter .7s}
.gallery a:hover img{transform:scale(1.12)}
.gallery a::after{content:'';position:absolute;inset:0;background:rgba(200,161,101,.0);transition:.5s}
.gallery a:hover::after{background:rgba(10,10,10,.25)}

/* ---------- TEMOIGNAGES ---------- */
.testi{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.testi-card{background:var(--glass);border:1px solid var(--glass-border);padding:40px 34px;backdrop-filter:blur(10px)}
.testi-card .stars{color:var(--or);margin-bottom:18px;letter-spacing:3px}
.testi-card p{font-style:italic;color:#d4d0c9;margin-bottom:24px;font-size:1.02rem}
.testi-card .who{display:flex;align-items:center;gap:14px}
.testi-card .who img{width:52px;height:52px;border-radius:50%;object-fit:cover}
.testi-card .who strong{display:block;font-family:var(--font-titre);font-size:1.2rem}
.testi-card .who span{font-size:.78rem;color:var(--gris);text-transform:uppercase;letter-spacing:1px}

/* ---------- REASSURANCE ---------- */
.reassure{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.reassure-item{text-align:center;padding:36px 22px;border:1px solid var(--glass-border);background:var(--glass);transition:.4s}
.reassure-item:hover{transform:translateY(-6px);border-color:var(--or)}
.reassure-item svg{width:46px;height:46px;color:var(--or);margin-bottom:18px}
.reassure-item h4{font-family:var(--font-titre);font-size:1.35rem;margin-bottom:8px;font-weight:600}
.reassure-item p{font-size:.86rem;color:var(--gris)}

/* ---------- CTA BAND ---------- */
.cta-band{
  text-align:center;
  background:linear-gradient(rgba(8,8,8,.7),rgba(8,8,8,.85)),
    url('https://images.unsplash.com/photo-1517836357463-d25dfeac3438?w=1600&q=80') center/cover fixed;
}
.cta-band h2{font-family:var(--font-titre);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;margin-bottom:20px}
.cta-band p{color:#d4d0c9;max-width:560px;margin:0 auto 36px;font-size:1.1rem}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info h3{font-family:var(--font-titre);font-size:2rem;margin-bottom:24px;font-weight:600}
.contact-info .line{display:flex;align-items:flex-start;gap:18px;margin-bottom:26px}
.contact-info .line svg{width:26px;height:26px;color:var(--or);flex-shrink:0;margin-top:4px}
.contact-info .line strong{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:2px;color:var(--or);margin-bottom:4px}
.contact-info .line span{color:#cfcbc4}
.form-card{background:var(--glass);border:1px solid var(--glass-border);padding:46px 40px;backdrop-filter:blur(10px)}
.form-group{margin-bottom:22px}
.form-group label{display:block;font-size:.76rem;text-transform:uppercase;letter-spacing:2px;color:var(--gris);margin-bottom:9px}
.form-group input,.form-group textarea{
  width:100%;background:rgba(0,0,0,.3);border:1px solid var(--glass-border);
  padding:14px 16px;color:var(--blanc);font-family:var(--font-texte);font-size:.95rem;
  transition:border-color .3s;
}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--or)}
.form-group textarea{resize:vertical;min-height:130px}
.form-msg{padding:14px;margin-bottom:20px;font-size:.9rem;display:none}
.form-msg.ok{display:block;background:rgba(200,161,101,.15);border:1px solid var(--or);color:var(--or-clair)}
.form-msg.err{display:block;background:rgba(200,80,80,.15);border:1px solid #c85050;color:#e6a0a0}
.map-wrap{margin-top:40px;border:1px solid var(--glass-border)}
.map-wrap iframe{width:100%;height:320px;display:block;filter:grayscale(.4) invert(.9) contrast(.85)}

/* ---------- FOOTER ---------- */
footer{background:#070707;padding:80px 0 36px;border-top:1px solid var(--glass-border)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:50px;margin-bottom:54px}
.foot-col .logo{margin-bottom:20px}
.foot-col p{color:var(--gris);font-size:.92rem;max-width:320px}
.foot-col h5{font-size:.8rem;text-transform:uppercase;letter-spacing:2px;color:var(--or);margin-bottom:22px}
.foot-col a{display:block;color:var(--gris);margin-bottom:12px;font-size:.92rem;transition:color .3s}
.foot-col a:hover{color:var(--or)}
.foot-bottom{text-align:center;padding-top:30px;border-top:1px solid var(--glass-border);color:#6a6a6a;font-size:.82rem}
.foot-bottom a{color:var(--gris)}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s ease}
.reveal.visible{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}
.reveal.d2{transition-delay:.24s}
.reveal.d3{transition-delay:.36s}

/* ---------- PAGE HEADER ---------- */
.page-head{
  min-height:52vh;display:flex;align-items:center;text-align:center;
  background:linear-gradient(rgba(8,8,8,.6),rgba(8,8,8,.82)),var(--ph-img) center/cover;
}
.page-head .inner{width:100%}
.page-head .eyebrow{color:var(--or);letter-spacing:5px;text-transform:uppercase;font-size:.78rem;margin-bottom:18px;display:block}
.page-head h1{font-family:var(--font-titre);font-size:clamp(2.6rem,6vw,4.4rem);font-weight:600}
.page-head .crumb{margin-top:18px;color:var(--gris);font-size:.85rem;letter-spacing:1px}
.page-head .crumb a:hover{color:var(--or)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .split{grid-template-columns:1fr;gap:40px}
  .split .img-wrap img{height:420px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .testi{grid-template-columns:1fr}
  .reassure{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:680px){
  .nav-links{
    position:fixed;top:0;right:-100%;width:78%;height:100vh;
    background:rgba(10,10,10,.97);backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;gap:30px;
    transition:right .45s ease;border-left:1px solid var(--glass-border);
  }
  .nav-links.open{right:0}
  .burger{display:flex}
  section{padding:80px 0}
  .cards,.gallery,.pricing{grid-template-columns:1fr}
  .reassure{grid-template-columns:1fr}
  .stats{gap:26px}
  .hero{background-attachment:scroll}
  .cta-band,.page-head{background-attachment:scroll}
}
