/* ═══════════════════════════════════════════════
   ÉCOUTEN — Feuille de style partagée
   ═══════════════════════════════════════════════ */
:root {
  --bg:#080706; --bg2:#0F0D0C; --bg3:#181512; --bg4:#221E1A; --bg5:#2C2722;
  --gold:#C9963A; --gold-h:#E4B05A; --gold-l:#F2C97D; --gold-d:#8A6220;
  --text:#F0EBE3; --text2:rgba(240,235,227,0.55); --text3:rgba(240,235,227,0.25);
  --max:1280px; --nav-h:70px; --r:16px; --r2:24px;
  --ease:cubic-bezier(.25,.46,.45,.94); --ease2:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,sans-serif;line-height:1.6;overflow-x:hidden;cursor:none}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:none;background:none}
ul,ol{list-style:none}

/* LOADER */
#page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
#page-loader.hidden{opacity:0;visibility:hidden}
.loader-logo{font-family:'Playfair Display',serif;font-size:2rem;color:var(--gold);animation:pulse-gold 1.5s ease-in-out infinite}
@keyframes pulse-gold{0%,100%{opacity:.4;transform:scale(.95)}50%{opacity:1;transform:scale(1)}}

/* READING BAR */
#reading-bar{position:fixed;top:0;left:0;z-index:1001;height:3px;width:0%;background:linear-gradient(90deg,var(--gold-d),var(--gold),var(--gold-l));pointer-events:none;transition:width .1s linear}

/* CURSOR */
#cursor-dot,#cursor-ring{position:fixed;border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%)}
#cursor-dot{width:8px;height:8px;background:var(--gold);transition:transform .05s}
#cursor-ring{width:36px;height:36px;border:1.5px solid var(--gold);opacity:.6;transition:transform .15s,opacity .15s}
body.cursor-hover #cursor-dot{transform:translate(-50%,-50%) scale(2)}
body.cursor-hover #cursor-ring{transform:translate(-50%,-50%) scale(1.4);opacity:.3}
.skip-link{position:absolute;top:-100%;left:16px;background:var(--gold);color:var(--bg);padding:8px 16px;border-radius:0 0 8px 8px;font-weight:600;z-index:10001}
.skip-link:focus{top:0}

/* NAV */
nav#main-nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;padding:0 clamp(20px,4vw,60px);transition:background .4s,transform .4s,box-shadow .4s}
nav#main-nav.scrolled{background:rgba(8,7,6,.94);backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(201,150,58,.15)}
nav#main-nav.nav-hidden{transform:translateY(-100%)}
.nav-brand{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--gold);letter-spacing:.05em;margin-right:auto;display:flex;align-items:center;gap:10px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:.8rem;font-weight:500;color:var(--text2);letter-spacing:.06em;text-transform:uppercase;transition:color .25s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-cta{margin-left:24px;padding:10px 22px;border:1.5px solid var(--gold);border-radius:50px;font-size:.8rem;font-weight:600;color:var(--gold);cursor:none;transition:background .25s,color .25s;white-space:nowrap}
.nav-cta:hover{background:var(--gold);color:var(--bg)}
.nav-burger{display:none;flex-direction:column;gap:5px;width:28px;cursor:none;background:none;border:none}
.nav-burger span{display:block;height:2px;border-radius:2px;background:var(--text);transition:transform .3s,opacity .3s}
.nav-mobile-menu{display:none;position:fixed;inset:0;z-index:999;background:rgba(8,7,6,.97);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:32px}
.nav-mobile-menu.open{display:flex}
.nav-mobile-menu a{font-size:1.3rem;font-weight:500;color:var(--text);text-transform:uppercase;letter-spacing:.1em;transition:color .25s}
.nav-mobile-menu a:hover{color:var(--gold)}
.nav-mobile-close{position:absolute;top:24px;right:24px;font-size:1.5rem;color:var(--text2);cursor:none;background:none;border:none;font-family:inherit}

/* SECTIONS */
.section{padding:100px clamp(20px,4vw,60px)}
.section-inner{max-width:var(--max);margin:0 auto}
.section-label{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:600;line-height:1.15;margin-bottom:20px}
.section-title em{font-style:italic;color:var(--gold)}
.section-sub{font-size:1.05rem;color:var(--text2);max-width:620px;line-height:1.75}
.section-header{margin-bottom:64px}
.section-header.centered{text-align:center}
.section-header.centered .section-sub{margin:0 auto}

/* REVEAL */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease2),transform .8s var(--ease2)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:16px 36px;background:linear-gradient(135deg,var(--gold-d),var(--gold),var(--gold-h));color:var(--bg);font-weight:700;font-size:1rem;border-radius:50px;box-shadow:0 0 40px rgba(201,150,58,.3);transition:transform .25s,box-shadow .25s;cursor:none}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 60px rgba(201,150,58,.5)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:16px 36px;border:1.5px solid rgba(201,150,58,.4);color:var(--text);font-weight:600;font-size:1rem;border-radius:50px;background:rgba(201,150,58,.05);transition:border-color .25s,background .25s;cursor:none}
.btn-secondary:hover{border-color:var(--gold);background:rgba(201,150,58,.1)}
.btn-ghost{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:600;color:var(--gold);letter-spacing:.04em;transition:gap .2s}
.btn-ghost:hover{gap:10px}

/* PAGE HERO (inner pages) */
.page-hero{padding:calc(var(--nav-h) + 80px) clamp(20px,4vw,60px) 80px;background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);border-bottom:1px solid rgba(201,150,58,.08);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(201,150,58,.06) 0%,transparent 70%);pointer-events:none}
.page-hero-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.page-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.page-hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--gold)}
.page-hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,4.5rem);font-weight:600;line-height:1.1;letter-spacing:-.02em;margin-bottom:20px}
.page-hero-title em{font-style:italic;color:var(--gold)}
.page-hero-sub{font-size:1.1rem;color:var(--text2);max-width:600px;line-height:1.75}

/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text3);margin-bottom:24px}
.breadcrumb a{color:var(--text3);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb-sep{font-size:.6rem}

/* CARDS */
.card{background:var(--bg3);border:1px solid rgba(240,235,227,.06);border-radius:var(--r2);overflow:hidden;transition:transform .3s,border-color .3s}
.card:hover{transform:translateY(-4px);border-color:rgba(201,150,58,.2)}
.card-body{padding:32px}

/* BADGE */
.badge{display:inline-block;padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:.08em;background:rgba(201,150,58,.12);border:1px solid rgba(201,150,58,.25);color:var(--gold-l)}

/* FORM */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.75rem;font-weight:600;color:var(--text2);letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}
.form-input,.form-textarea,.form-select{width:100%;padding:14px 16px;background:rgba(240,235,227,.04);border:1.5px solid rgba(240,235,227,.1);border-radius:var(--r);color:var(--text);font-family:inherit;font-size:.95rem;transition:border-color .25s}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--gold)}
.form-textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;padding:16px;background:linear-gradient(135deg,var(--gold-d),var(--gold));color:var(--bg);font-weight:700;font-size:1rem;border-radius:50px;cursor:none;transition:opacity .25s,transform .25s;margin-top:8px}
.form-submit:hover{opacity:.9;transform:translateY(-1px)}
.form-submit.loading{opacity:.6;pointer-events:none}
.spinner{display:none;width:18px;height:18px;border-radius:50%;border:2px solid rgba(8,7,6,.3);border-top-color:var(--bg);animation:spin .6s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.form-success{display:none;text-align:center;padding:20px;color:var(--gold);font-weight:600;font-size:1rem}

/* FLOATING CTA */
#floating-cta{position:fixed;bottom:100px;right:32px;z-index:900;opacity:0;transform:translateY(20px);transition:opacity .4s,transform .4s;pointer-events:none}
#floating-cta.visible{opacity:1;transform:none;pointer-events:auto}
.floating-btn{padding:14px 22px;background:linear-gradient(135deg,var(--gold-d),var(--gold));color:var(--bg);font-weight:700;font-size:.85rem;border-radius:50px;box-shadow:0 8px 32px rgba(201,150,58,.4);cursor:none;transition:transform .25s,box-shadow .25s;border:none;font-family:inherit}
.floating-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(201,150,58,.5)}

/* FOOTER */
footer.site-footer{background:var(--bg2);border-top:1px solid rgba(201,150,58,.1);padding:80px clamp(20px,4vw,60px) 40px}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:60px;margin-bottom:60px}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--gold);margin-bottom:16px}
.footer-brand-desc{font-size:.875rem;color:var(--text2);line-height:1.7;max-width:280px}
.footer-col-title{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:block}
.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-links a{font-size:.875rem;color:var(--text2);transition:color .25s}
.footer-links a:hover{color:var(--gold)}
.footer-newsletter-desc{font-size:.875rem;color:var(--text2);margin-bottom:16px;line-height:1.6}
.newsletter-form{display:flex}
.newsletter-input{flex:1;padding:12px 16px;background:rgba(240,235,227,.05);border:1px solid rgba(240,235,227,.1);border-right:none;border-radius:var(--r) 0 0 var(--r);color:var(--text);font-family:inherit;font-size:.875rem}
.newsletter-input:focus{outline:none;border-color:var(--gold)}
.newsletter-btn{padding:12px 18px;background:var(--gold);color:var(--bg);font-weight:700;font-size:.875rem;border-radius:0 var(--r) var(--r) 0;cursor:none;border:none;font-family:inherit;transition:background .25s}
.newsletter-btn:hover{background:var(--gold-h)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:32px;border-top:1px solid rgba(240,235,227,.06);flex-wrap:wrap;gap:16px}
.footer-copy{font-size:.8rem;color:var(--text3)}
.footer-legal-links{display:flex;gap:24px}
.footer-legal-links a{font-size:.8rem;color:var(--text3);transition:color .25s}
.footer-legal-links a:hover{color:var(--text2)}
.footer-social{display:flex;gap:12px;margin-top:20px}
.social-link{width:36px;height:36px;border-radius:50%;background:rgba(240,235,227,.05);border:1px solid rgba(240,235,227,.08);display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:.9rem;transition:background .2s,color .2s,border-color .2s}
.social-link:hover{background:rgba(201,150,58,.1);color:var(--gold);border-color:rgba(201,150,58,.3)}

/* LEGAL PAGES */
.legal-content{max-width:820px}
.legal-content h2{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:600;color:var(--gold);margin:48px 0 16px;padding-bottom:12px;border-bottom:1px solid rgba(201,150,58,.15)}
.legal-content h3{font-size:1.1rem;font-weight:600;margin:28px 0 12px}
.legal-content p{font-size:.95rem;color:var(--text2);line-height:1.8;margin-bottom:16px}
.legal-content ul{margin:12px 0 20px 20px;list-style:disc}
.legal-content ul li{font-size:.95rem;color:var(--text2);line-height:1.7;margin-bottom:8px}
.legal-content a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.legal-content strong{color:var(--text);font-weight:600}
.legal-date{display:inline-block;font-size:.8rem;color:var(--text3);margin-bottom:40px;padding:6px 14px;background:rgba(201,150,58,.06);border:1px solid rgba(201,150,58,.12);border-radius:50px}
.legal-toc{background:var(--bg3);border:1px solid rgba(201,150,58,.1);border-radius:var(--r);padding:28px 32px;margin-bottom:48px}
.legal-toc-title{font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.legal-toc ol{list-style:decimal;padding-left:20px}
.legal-toc li{font-size:.875rem;color:var(--text2);margin-bottom:8px}
.legal-toc a{color:var(--text2);transition:color .2s}
.legal-toc a:hover{color:var(--gold)}

/* BOOKING MODAL */
#booking-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(8,7,6,.88);backdrop-filter:blur(12px);align-items:center;justify-content:center;padding:20px}
#booking-overlay.open{display:flex}
.booking-modal{background:var(--bg3);border:1px solid rgba(201,150,58,.2);border-radius:var(--r2);width:100%;max-width:560px;overflow:hidden;animation:modalIn .4s var(--ease2)}
@keyframes modalIn{from{opacity:0;transform:scale(.93) translateY(20px)}to{opacity:1;transform:none}}
.modal-header{padding:28px 32px 20px;border-bottom:1px solid rgba(201,150,58,.1);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-family:'Playfair Display',serif;font-size:1.4rem}
.modal-close{width:36px;height:36px;border-radius:50%;background:rgba(240,235,227,.05);display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:1.4rem;cursor:none;border:none;font-family:inherit;transition:background .2s,color .2s}
.modal-close:hover{background:rgba(201,150,58,.1);color:var(--gold)}
.modal-progress{display:flex;gap:8px;padding:16px 32px;border-bottom:1px solid rgba(201,150,58,.08)}
.modal-step{flex:1;height:3px;border-radius:3px;background:rgba(240,235,227,.1);transition:background .4s}
.modal-step.active{background:var(--gold)}
.modal-body{padding:32px}
.step-panel{display:none}.step-panel.active{display:block}
.step-title{font-weight:700;font-size:1.1rem;margin-bottom:20px;color:var(--text)}
.service-select-list{display:flex;flex-direction:column;gap:12px}
.service-select-item{display:flex;align-items:center;gap:16px;padding:16px 20px;border:1.5px solid rgba(201,150,58,.1);border-radius:var(--r);cursor:none;transition:border-color .25s,background .25s}
.service-select-item:hover,.service-select-item.selected{border-color:var(--gold);background:rgba(201,150,58,.05)}
.si-icon{font-size:1.6rem;width:40px;text-align:center;flex-shrink:0}
.si-info{flex:1}.si-name{font-weight:600;margin-bottom:2px}
.si-price{font-size:.85rem;color:var(--gold)}
.si-check{width:22px;height:22px;border-radius:50%;border:2px solid rgba(201,150,58,.3);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--gold);flex-shrink:0;transition:background .2s,border-color .2s}
.service-select-item.selected .si-check{background:var(--gold);border-color:var(--gold);color:var(--bg)}
.summary-box{background:rgba(201,150,58,.06);border:1px solid rgba(201,150,58,.15);border-radius:var(--r);padding:20px}
.summary-row{display:flex;justify-content:space-between;margin-bottom:10px;font-size:.9rem;color:var(--text2)}
.summary-total{display:flex;justify-content:space-between;font-weight:700;color:var(--gold);border-top:1px solid rgba(201,150,58,.2);padding-top:14px;margin-top:4px}
.modal-footer{padding:20px 32px 28px;display:flex;gap:12px;justify-content:flex-end;border-top:1px solid rgba(201,150,58,.08)}
.btn-modal-back{padding:12px 24px;border-radius:50px;border:1.5px solid rgba(240,235,227,.1);color:var(--text2);font-weight:600;cursor:none;font-family:inherit;transition:border-color .2s,color .2s}
.btn-modal-back:hover{border-color:var(--text2);color:var(--text)}
.btn-modal-next{padding:12px 28px;border-radius:50px;background:linear-gradient(135deg,var(--gold-d),var(--gold));color:var(--bg);font-weight:700;cursor:none;font-family:inherit;transition:opacity .2s}
.btn-modal-next:hover{opacity:.9}

/* RESPONSIVE */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .footer-top{grid-template-columns:1fr}
  #cursor-dot,#cursor-ring{display:none}
  body{cursor:auto}
  button{cursor:pointer}
  a{cursor:pointer}
  .page-hero-title{font-size:clamp(2rem,8vw,3rem)}
}
