
:root{
  --navy:#1a2e45;--blue:#2c4a6e;--blue-light:#e8f0f8;--blue-mid:#4a7ab8;
  --cream:#faf8f5;--lav:#eef1f7;--border:#e4e8f0;--border2:#ede8e0;
  --text:#1a2e45;--muted:#6b7f94;--hint:#8fa3b8;
  --gold:#f5a623;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;color:var(--text);font-size:18px;line-height:1.7;background:#fff}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.25;color:var(--navy)}
h1{font-size:clamp(2rem,3.5vw,3rem)}
h2{font-size:clamp(1.6rem,2.5vw,2.2rem)}
h3{font-size:1.15rem}
a{color:var(--blue);text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 2.5rem}
.eyebrow{display:inline-block;background:var(--blue-light);color:var(--blue);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .9rem;border-radius:20px;margin-bottom:1.2rem}
.section-label{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);opacity:.6;margin-bottom:.5rem}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,2.5vw,2.1rem);font-weight:700;color:var(--navy);margin-bottom:.7rem}
.section-sub{font-size:1rem;color:var(--muted);line-height:1.75;max-width:580px;margin-bottom:2.2rem}

/* BUTTONS */
.btn{display:inline-block;padding:.8rem 1.8rem;border-radius:10px;font-size:.97rem;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all .2s}
.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--navy);color:#fff}
.btn-outline{background:transparent;color:var(--blue);border:2px solid var(--blue)}.btn-outline:hover{background:var(--blue-light)}
.btn-white{background:#fff;color:var(--blue)}.btn-white:hover{background:var(--blue-light)}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45)}.btn-outline-white:hover{border-color:#fff}

/* HEADER */
.site-header{background:#fff;border-bottom:1px solid var(--border);padding:.9rem 0;position:sticky;top:0;z-index:100;box-shadow:0 1px 5px rgba(26,46,69,.06)}
.header-inner{display:flex;align-items:center;gap:2rem}
.logo-wrap{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.logo-icon{width:38px;height:38px;background:var(--blue-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.logo-name{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--blue);line-height:1.1}
.logo-sub{font-size:.65rem;color:var(--hint);letter-spacing:.05em}
.main-nav{display:flex;gap:1.8rem;margin-left:auto;font-size:.92rem}
.main-nav a{color:var(--muted);font-weight:500;transition:color .2s}.main-nav a:hover{color:var(--blue)}

/* HERO */
.hero{background:var(--cream);display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 62px)}
.hero-text{padding:4rem 3rem 4rem 0;display:flex;flex-direction:column;justify-content:center}
.hero h1{margin-bottom:.6rem}
.hero h1 .hl{color:var(--blue)}
.hero h1 em{color:var(--hint);font-style:italic;font-size:clamp(1.3rem,2vw,1.8rem);display:block;margin-top:.35rem;font-weight:400}
.hero-sub{font-size:1.05rem;color:var(--muted);max-width:460px;margin-bottom:.8rem;line-height:1.8}
.hero-price{font-size:1.05rem;margin-bottom:2rem}
.hero-price strong{color:var(--blue);font-size:1.2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.8rem}
.hero-trust{display:flex;flex-direction:column;gap:.45rem}
.trust-item{display:flex;align-items:center;gap:.55rem;font-size:.85rem;color:var(--hint)}
.trust-dot{width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0}
.hero-photo{position:relative;overflow:hidden}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.photo-badge{position:absolute;top:22px;left:22px;background:rgba(255,255,255,.9);border-radius:30px;padding:.45rem 1.1rem;font-size:.8rem;font-weight:600;color:var(--blue)}
.photo-quote{position:absolute;bottom:0;left:0;right:0;background:rgba(26,46,69,.58);padding:1.1rem 1.5rem}
.photo-quote p{font-size:.88rem;color:rgba(255,255,255,.92);font-style:italic;line-height:1.55;margin-bottom:.25rem}
.photo-quote span{font-size:.76rem;color:rgba(255,255,255,.6)}

/* STATS */
.stats-strip{background:#fff;padding:2rem 0;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;border-bottom:1px solid var(--border);border-top:1px solid var(--border)}
.stat-item{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem;background:var(--cream);border-radius:14px;border:1px solid var(--border2)}
.stat-icon{font-size:1.9rem;flex-shrink:0}
.stat-val{font-family:'Playfair Display',serif;font-size:1.75rem;font-weight:700;color:var(--blue);line-height:1}
.stat-lbl{font-size:.8rem;color:var(--hint);margin-top:.2rem;line-height:1.4}

/* DEUX NIVEAUX */
.deux-niveaux{padding:4.5rem 0;background:var(--lav)}
.dn-header{text-align:center;margin-bottom:3rem}
.dn-header h2 em{color:var(--blue);font-style:normal}
.dn-sub{font-size:1rem;color:var(--muted);max-width:560px;margin:.5rem auto 0;line-height:1.75}
.dn-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.8rem}
.dn-card{background:#fff;border-radius:16px;padding:2.2rem;border:1.5px solid var(--border);position:relative;display:flex;flex-direction:column;gap:.65rem}
.dn-agitee{border-color:var(--blue);border-width:2px}
.dn-exclusive{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:.32rem 1rem;border-radius:20px;white-space:nowrap}
.dn-icon{font-size:2rem;line-height:1}
.dn-badge{display:inline-block;font-size:.73rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.28rem .8rem;border-radius:20px;align-self:flex-start}
.dn-tranquille .dn-badge{background:var(--blue-light);color:var(--blue)}
.dn-agitee .dn-badge{background:var(--navy);color:#fff}
.dn-card h3{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--navy);line-height:1.2}
.dn-desc{font-size:.95rem;color:var(--muted);line-height:1.75}
.dn-suited{font-size:.75rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--hint);margin-top:.3rem}
.dn-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}
.dn-list li{font-size:.9rem;color:#374151;display:flex;align-items:center;gap:.6rem;padding:.28rem 0;border-bottom:1px solid #f0f4fa}
.dn-list li:last-child{border-bottom:none}
.dn-list li::before{content:'→';color:var(--blue);font-weight:700;flex-shrink:0;font-size:.8rem}
.dn-price{margin-top:.5rem;padding-top:.9rem;border-top:1px solid var(--border)}
.dn-price strong{display:block;font-family:'Playfair Display',serif;font-size:1.75rem;font-weight:700;color:var(--blue);line-height:1;margin-bottom:.2rem}
.dn-price span{font-size:.8rem;color:var(--hint)}
.dn-btn{display:block;text-align:center;padding:.85rem;border-radius:10px;font-weight:600;font-size:.95rem;text-decoration:none;margin-top:.4rem;cursor:pointer;border:none;transition:all .2s}
.dn-btn-light{background:var(--blue-light);color:var(--blue)}.dn-btn-light:hover{background:var(--blue);color:#fff}
.dn-btn-dark{background:var(--blue);color:#fff}.dn-btn-dark:hover{background:var(--navy);color:#fff}
.dn-note{background:#fff;border-radius:12px;padding:1.3rem 1.8rem;display:flex;align-items:center;gap:1.2rem;border:1px solid var(--border)}
.dn-note-icon{font-size:1.4rem;flex-shrink:0}
.dn-note p{font-size:.9rem;color:var(--muted);flex:1;line-height:1.6}
.dn-note a{white-space:nowrap;font-size:.9rem;font-weight:600;color:var(--blue);flex-shrink:0}

/* HOW */
.how{padding:4.5rem 0;background:var(--lav)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.step{background:#fff;border-radius:14px;padding:2rem;border:1px solid #dbe3ee}
.step-num{font-family:'Playfair Display',serif;font-size:3rem;font-weight:700;color:var(--blue-light);line-height:1;margin-bottom:.5rem}
.step h3{font-size:1.05rem;font-weight:600;color:var(--navy);margin-bottom:.5rem}
.step p{font-size:.9rem;color:var(--hint);line-height:1.65}

/* GARDIENS */
.gardiens{padding:4.5rem 0;background:#fff}
.gardiens-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.5rem}
.gardiens-header a{font-size:.9rem;color:var(--blue);font-weight:600}
.gardiens-list{display:flex;flex-direction:column;gap:1rem}
.gardien-row{display:grid;grid-template-columns:56px 1fr auto auto;align-items:center;gap:1.5rem;padding:1.4rem 1.6rem;background:var(--cream);border-radius:14px;border:1px solid var(--border2);transition:all .2s}
.gardien-row:hover{border-color:var(--blue);background:#f0f4fa}
.g-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;flex-shrink:0}
.g-info h3{font-size:1rem;font-weight:600;color:var(--navy);margin-bottom:.2rem}
.g-info p{font-size:.86rem;color:var(--hint);margin-bottom:.4rem}
.g-tags{display:flex;gap:.4rem;flex-wrap:wrap}
.g-tag{background:var(--blue-light);color:var(--blue);font-size:.7rem;padding:.17rem .62rem;border-radius:20px;font-weight:500}
.g-nights{text-align:center;padding:0 1.2rem;border-left:1px solid var(--border);border-right:1px solid var(--border)}
.g-nights strong{display:block;font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--blue);line-height:1}
.g-nights span{font-size:.73rem;color:var(--hint)}
.g-rating{text-align:center;padding-left:1.2rem}
.g-rating strong{display:block;font-size:1.1rem;font-weight:600;color:var(--navy);line-height:1}
.g-rating span{font-size:.73rem;color:var(--hint)}
.g-stars{color:var(--gold);font-size:.82rem;margin-bottom:.12rem}

/* TEMOIGNAGES */
.testimonials{padding:4.5rem 0;background:var(--cream)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2rem}
.testi{background:#fff;border-radius:14px;padding:2rem;border:1px solid var(--border2)}
.testi-stars{color:var(--gold);font-size:1rem;margin-bottom:1rem;letter-spacing:.1em}
.testi-quote{font-size:.93rem;color:#374151;font-style:italic;line-height:1.75;margin-bottom:1.1rem}
.testi-author{font-size:.8rem;color:var(--hint);display:flex;align-items:center;gap:.5rem}
.testi-dot{width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0}

/* CTA BAND */
.cta-band{background:var(--blue);padding:4rem 0;text-align:center}
.cta-band h2{color:#fff;margin-bottom:.85rem}
.cta-band p{font-size:1rem;color:rgba(255,255,255,.72);margin-bottom:2.2rem;max-width:540px;margin-left:auto;margin-right:auto;line-height:1.75}

/* FAQ */
.faq-section{padding:4.5rem 0;background:#fff}
.faq-list{display:flex;flex-direction:column;max-width:780px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:1.2rem 0;font-size:1rem;font-weight:600;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:'Source Sans 3',sans-serif}
.faq-icon{font-size:1.3rem;color:var(--blue);flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{display:none;padding:0 0 1.2rem;font-size:.95rem;color:var(--muted);line-height:1.75}
.faq-item.open .faq-a{display:block}

/* MODAL CONTACT */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(26,46,69,.55);z-index:1000;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.active{display:flex}
.modal{background:#fff;border-radius:16px;padding:2.5rem;max-width:520px;width:100%;position:relative;max-height:90vh;overflow-y:auto}
.modal h3{font-family:'Playfair Display',serif;font-size:1.5rem;margin-bottom:.5rem}
.modal p{font-size:.92rem;color:var(--muted);margin-bottom:1.5rem;line-height:1.65}
.modal-close{position:absolute;top:1.2rem;right:1.2rem;background:var(--lav);border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:.35rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:8px;font-size:.95rem;font-family:'Source Sans 3',sans-serif;color:var(--navy);transition:border-color .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{width:100%;padding:1rem;background:var(--blue);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:background .2s}
.form-submit:hover{background:var(--navy)}
.form-success{display:none;text-align:center;padding:2rem}
.form-success .success-icon{font-size:3rem;margin-bottom:1rem}
.form-success h4{font-family:'Playfair Display',serif;font-size:1.3rem;margin-bottom:.5rem}
.form-success p{font-size:.92rem;color:var(--muted)}

/* FOOTER */
footer{background:var(--navy);padding:3.5rem 0 0}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem}
.fbrand .fname{font-family:'Playfair Display',serif;font-size:1.25rem;color:#fff;margin-bottom:.85rem;display:flex;align-items:center;gap:.6rem}
.fbrand p{font-size:.86rem;color:#6b7f94;line-height:1.7;margin-bottom:.9rem}
.fbrand .fphone{color:rgba(255,255,255,.8);font-size:.92rem;font-weight:600}
.fcol h4{color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-family:'Source Sans 3',sans-serif}
.fcol a{display:block;color:#6b7f94;font-size:.86rem;margin-bottom:.5rem;transition:color .2s}
.fcol a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.07);padding:1.2rem;text-align:center;font-size:.76rem;color:rgba(255,255,255,.2)}

@media(max-width:960px){
  .hero{grid-template-columns:1fr}
  .hero-photo{min-height:300px}
  .stats-strip,.steps,.dn-grid,.testi-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .gardien-row{grid-template-columns:50px 1fr}
  .g-nights,.g-rating{display:none}
  .form-grid{grid-template-columns:1fr}
}
