/* ==========================================================
   La Féelicità — Feuille de style principale
   ========================================================== */

/* === Base === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--cream:#F6F3EE;--cream-dark:#EDE8E0;--green:#2C3E2D;--green-light:#3A5A3C;--gold:#C5A258;--gold-light:#D4B76A;--text:#2C3E2D;--text-light:#5A6B5B;--white:#FDFCFA}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:"marseille",sans-serif;font-weight:400;background:var(--cream);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}.reveal-delay-2{transition-delay:.24s}.reveal-delay-3{transition-delay:.36s}.reveal-delay-4{transition-delay:.48s}

/* === Navigation (index.html – transparente au départ) === */
nav{position:fixed;top:0;left:0;right:0;z-index:160;padding:1.5rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:background .5s,padding .4s,backdrop-filter .5s,opacity .3s}
nav.menu-open{opacity:0;pointer-events:none}
nav.scrolled{background:rgba(246,243,238,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1rem 3rem;box-shadow:0 1px 0 rgba(44,62,45,.06)}
.nav-logo{font-family:"marseille",sans-serif;font-weight:300;font-size:1.35rem;letter-spacing:.04em;color:var(--white);text-decoration:none;transition:color .4s}
nav.scrolled .nav-logo{color:var(--green)}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-family:"marseille",sans-serif;font-weight:400;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--white);text-decoration:none;position:relative;transition:color .4s}
nav.scrolled .nav-links a{color:var(--text)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .4s cubic-bezier(.22,1,.36,1)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

/* === Navigation statique (salon.html – fond clair permanent) === */
nav.nav-static{background:rgba(246,243,238,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(44,62,45,.06)}
nav.nav-static .nav-logo{color:var(--green)}
nav.nav-static .nav-links a{color:var(--text)}
nav.nav-static.scrolled{padding:1rem 3rem}

/* === Burger === */
.nav-burger{display:none;position:fixed;top:1.3rem;right:1.5rem;flex-direction:column;justify-content:space-between;width:24px;height:18px;background:none;border:none;cursor:pointer;padding:0;z-index:170}
.nav-burger-line{display:block;width:100%;height:1.5px;background:var(--white);border-radius:2px;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .3s,background .4s;transform-origin:center}
.nav-burger.scrolled .nav-burger-line{background:var(--green)}
.nav-burger.open .nav-burger-line:nth-child(1){transform:translateY(8.25px) rotate(45deg)}
.nav-burger.open .nav-burger-line:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open .nav-burger-line:nth-child(3){transform:translateY(-8.25px) rotate(-45deg)}
.nav-burger.open .nav-burger-line{background:var(--white)!important}

/* === Menu mobile === */
.mobile-menu{position:fixed;inset:0;z-index:150;background:var(--green);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .55s cubic-bezier(.22,1,.36,1),visibility .55s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu-links{list-style:none;text-align:center;display:flex;flex-direction:column;gap:2.2rem}
.mobile-menu-links a{font-family:"marseille",sans-serif;font-weight:200;font-size:clamp(2rem,10vw,3.2rem);letter-spacing:.02em;color:var(--white);text-decoration:none;display:block;opacity:0;transform:translateY(22px);transition:opacity .55s cubic-bezier(.22,1,.36,1),transform .55s cubic-bezier(.22,1,.36,1),color .3s}
.mobile-menu.open .mobile-menu-links li:nth-child(1) a{opacity:1;transform:translateY(0);transition-delay:.12s}
.mobile-menu.open .mobile-menu-links li:nth-child(2) a{opacity:1;transform:translateY(0);transition-delay:.2s}
.mobile-menu.open .mobile-menu-links li:nth-child(3) a{opacity:1;transform:translateY(0);transition-delay:.28s}
.mobile-menu.open .mobile-menu-links li:nth-child(4) a{opacity:1;transform:translateY(0);transition-delay:.36s}
.mobile-menu.open .mobile-menu-links li:nth-child(5) a{opacity:1;transform:translateY(0);transition-delay:.44s}
.mobile-menu-links a:hover,.mobile-menu-links a.active{color:var(--gold)}
.mobile-menu-footer{position:absolute;bottom:2.5rem;left:0;right:0;text-align:center;font-weight:300;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(253,252,250,.28);opacity:0;transition:opacity .5s .5s}
.mobile-menu.open .mobile-menu-footer{opacity:1}
.mobile-menu-gold{width:28px;height:1px;background:var(--gold);margin:0 auto 1.2rem;opacity:.7}

/* === Sections communes === */
section{padding:7rem 3rem}
.section-label{font-weight:400;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.section-title{font-weight:200;font-size:clamp(2rem,4vw,3.2rem);line-height:1.15;letter-spacing:-.01em;max-width:600px}
.gold-line{width:50px;height:1px;background:var(--gold);margin:2rem auto 0}

/* === Boutons === */
.btn{display:inline-flex;align-items:center;gap:.75rem;font-family:"marseille",sans-serif;font-weight:400;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;color:var(--green);border:1px solid var(--green);padding:1rem 2rem;border-radius:100px;transition:background .4s,color .4s,transform .2s;cursor:pointer;background:transparent}
.btn:hover{background:var(--green);color:var(--white)}.btn:active{transform:scale(.97)}
.btn-light{color:var(--white);border-color:rgba(253,252,250,.3)}.btn-light:hover{background:var(--white);color:var(--green)}
.btn-arrow{transition:transform .3s}.btn:hover .btn-arrow{transform:translateX(4px)}

/* === Footer === */
footer{background:var(--green);color:rgba(253,252,250,.6);padding:5rem 3rem 2rem;border-top:1px solid rgba(253,252,250,.06)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;max-width:1100px;margin:0 auto 4rem}
.footer-brand-name{font-weight:200;font-size:1.8rem;color:var(--white);margin-bottom:1rem}
.footer-brand-desc{font-weight:300;font-size:.85rem;line-height:1.7;max-width:280px}
.footer-col-title{font-weight:500;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.footer-col a{display:block;font-weight:300;font-size:.88rem;color:rgba(253,252,250,.6);text-decoration:none;margin-bottom:.75rem;transition:color .3s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{max-width:1100px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(253,252,250,.08);display:flex;justify-content:space-between;align-items:center;font-size:.72rem;font-weight:300;letter-spacing:.05em}
body.modal-open{overflow:hidden}

/* ==========================================================
   index.html – Styles spécifiques
   ========================================================== */

/* Hero */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;background:var(--green)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,62,45,.08) 0%,rgba(44,62,45,.3) 50%,rgba(44,62,45,.78) 100%),url('../img/hero.jpg') center 60%/cover no-repeat;transform:scale(1.08);animation:heroZoom 12s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-content{position:relative;z-index:2;text-align:center;padding-bottom:8vh;color:var(--white)}
.hero-subtitle{font-weight:300;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-light);margin-bottom:1.5rem;opacity:0;animation:fadeUp 1s .4s cubic-bezier(.22,1,.36,1) forwards}
.hero-title{font-weight:200;font-size:clamp(3rem,8vw,6.5rem);line-height:1;letter-spacing:-.02em;margin-bottom:.3em;opacity:0;animation:fadeUp 1.2s .6s cubic-bezier(.22,1,.36,1) forwards}
.hero-tagline{font-weight:300;font-size:clamp(1rem,2vw,1.25rem);letter-spacing:.03em;color:rgba(253,252,250,.75);max-width:500px;margin:0 auto;opacity:0;animation:fadeUp 1.2s .9s cubic-bezier(.22,1,.36,1) forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-scroll{position:absolute;bottom:2rem;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(253,252,250,.4);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;opacity:0;animation:fadeUp 1s 1.5s ease forwards}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.3)}}

/* Philosophie */
.philosophy{display:flex;align-items:center;justify-content:center;text-align:center;min-height:50vh;padding:8rem 3rem;background:var(--cream)}
.philosophy-inner{max-width:700px}
.philosophy .section-title{margin:0 auto 2rem;max-width:600px}
.philosophy-text{font-weight:300;font-size:1.05rem;line-height:1.8;color:var(--text-light);max-width:520px;margin:0 auto}

/* Catégories */
.categories{background:var(--white);padding:7rem 3rem}
.categories-header{text-align:center;margin-bottom:4rem}
.categories-list{max-width:800px;margin:0 auto}
.cat-item{display:flex;align-items:center;justify-content:space-between;padding:1.6rem 0;border-bottom:1px solid rgba(44,62,45,.08);cursor:pointer;transition:padding-left .4s cubic-bezier(.22,1,.36,1)}
.cat-item:first-child{border-top:1px solid rgba(44,62,45,.08)}
.cat-item:hover{padding-left:1rem}
.cat-item-left{display:flex;align-items:baseline;gap:1.5rem}
.cat-item-number{font-weight:300;font-size:.72rem;color:var(--gold);letter-spacing:.05em;min-width:20px}
.cat-item-name{font-weight:400;font-size:clamp(1.1rem,2.5vw,1.5rem);letter-spacing:.01em;transition:color .3s}
.cat-item:hover .cat-item-name{color:var(--gold)}
.cat-item-arrow{font-size:1.2rem;color:var(--gold);opacity:0;transform:translateX(-10px);transition:opacity .3s,transform .3s}
.cat-item:hover .cat-item-arrow{opacity:1;transform:translateX(0)}
.cat-hover-img{position:fixed;width:280px;height:340px;border-radius:14px;object-fit:cover;pointer-events:none;z-index:50;opacity:0;transform:scale(.85);transition:opacity .35s cubic-bezier(.22,1,.36,1),transform .35s cubic-bezier(.22,1,.36,1);box-shadow:0 20px 60px rgba(44,62,45,.2)}
.cat-hover-img.visible{opacity:1;transform:scale(1)}

/* Modal galerie */
.cat-modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(44,62,45,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s}
.cat-modal-overlay.open{opacity:1;visibility:visible}
.cat-modal{position:fixed;top:0;right:0;z-index:201;width:min(680px,92vw);height:100vh;background:var(--white);transform:translateX(100%);transition:transform .6s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column}
.cat-modal.open{transform:translateX(0)}
.cat-modal-header{padding:2.5rem 2.5rem 2rem;display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0;border-bottom:1px solid rgba(44,62,45,.06)}
.cat-modal-title{font-weight:300;font-size:1.8rem;letter-spacing:-.01em;color:var(--text)}
.cat-modal-subtitle{font-weight:300;font-size:.85rem;color:var(--text-light);line-height:1.7;margin-top:.6rem;max-width:420px}
.cat-modal-close{width:44px;height:44px;border-radius:50%;border:1px solid rgba(44,62,45,.1);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text);transition:background .3s,border-color .3s;flex-shrink:0;margin-left:1.5rem}
.cat-modal-close:hover{background:var(--cream);border-color:rgba(44,62,45,.15)}
.cat-modal-gallery{flex:1;overflow-y:auto;padding:2rem 2.5rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-content:start;scrollbar-width:thin;scrollbar-color:var(--gold) transparent}
.cat-modal-gallery::-webkit-scrollbar{width:4px}
.cat-modal-gallery::-webkit-scrollbar-track{background:transparent}
.cat-modal-gallery::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}
.cat-modal-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:12px;opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}
.cat-modal.open .cat-modal-img{opacity:1;transform:translateY(0)}
.cat-modal-img:nth-child(1){transition-delay:.15s}.cat-modal-img:nth-child(2){transition-delay:.25s}.cat-modal-img:nth-child(3){transition-delay:.35s}.cat-modal-img:nth-child(4){transition-delay:.45s}.cat-modal-img:nth-child(5){transition-delay:.55s}.cat-modal-img:nth-child(6){transition-delay:.65s}
.cat-modal-img.tall{grid-row:span 2;aspect-ratio:auto;height:100%}

/* Signatures */
.signatures{background:var(--green);color:var(--white);padding:7rem 3rem;position:relative;overflow:hidden}
.signatures::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(197,162,88,.06) 0%,transparent 70%);pointer-events:none}
.signatures-header{text-align:center;margin-bottom:4rem}
.signatures .section-title{color:var(--white);margin:0 auto}
.signatures .section-label{color:var(--gold-light)}
.signatures-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:1100px;margin:0 auto}
.sig-card{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:3/4;cursor:pointer}
.sig-card-img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.sig-card:hover .sig-card-img{transform:scale(1.06)}
.sig-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(44,62,45,.85) 100%);display:flex;align-items:flex-end;padding:1.5rem;transition:background .5s}
.sig-card:hover .sig-card-overlay{background:linear-gradient(180deg,transparent 20%,rgba(44,62,45,.9) 100%)}
.sig-card-name{font-weight:300;font-size:1.15rem;letter-spacing:.03em}
.sig-card-detail{font-weight:300;font-size:.72rem;color:var(--gold-light);letter-spacing:.08em;text-transform:uppercase;margin-top:.3rem;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.sig-card:hover .sig-card-detail{opacity:1;transform:translateY(0)}

/* Événements */
.events{background:var(--cream);padding:7rem 3rem}
.events-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1100px;margin:0 auto;align-items:center}
.events-visual{position:relative}
.events-img-main{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px}
.events-accent{position:absolute;bottom:-30px;right:-30px;width:130px;height:130px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--white);text-align:center;box-shadow:0 16px 40px rgba(197,162,88,.25)}
.events-accent span:first-child{font-weight:200;font-size:1.6rem;line-height:1}
.events-accent span:last-child{font-weight:400;font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;margin-top:.25rem}
.events-content .section-title{margin-bottom:1.5rem}
.events-text{font-weight:300;font-size:1rem;line-height:1.85;color:var(--text-light);margin-bottom:2.5rem}
.events-services{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2.5rem}
.service-tag{display:flex;align-items:center;gap:.75rem;font-weight:400;font-size:.85rem;letter-spacing:.02em}
.service-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* Témoignage */
.testimonial{background:var(--white);text-align:center;padding:7rem 3rem}
.testimonial-quote{font-weight:200;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.5;max-width:700px;margin:0 auto 2rem;font-style:italic;color:var(--text)}
.testimonial-quote::before{content:'«';color:var(--gold);margin-right:.3em}.testimonial-quote::after{content:'»';color:var(--gold);margin-left:.3em}
.testimonial-author{font-weight:500;font-size:.85rem;letter-spacing:.05em}
.testimonial-role{font-weight:300;font-size:.75rem;color:var(--text-light);margin-top:.3rem}

/* Marquee */
.marquee-section{background:var(--green);padding:1.5rem 0;overflow:hidden}
.marquee-track{display:flex;animation:marquee 25s linear infinite;white-space:nowrap}
.marquee-item{font-weight:200;font-size:1rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(253,252,250,.4);padding:0 2.5rem;flex-shrink:0}
.marquee-dot{color:var(--gold);padding:0 1rem;flex-shrink:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Contact & formulaire */
.contact{background:var(--green);color:var(--white);padding:7rem 3rem;position:relative;overflow:hidden}
.contact::before{content:'';position:absolute;bottom:-300px;left:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(197,162,88,.05) 0%,transparent 70%);pointer-events:none}
.contact-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;max-width:1100px;margin:0 auto;align-items:start;position:relative;z-index:1}
.contact-info .section-label{color:var(--gold-light)}.contact-info .section-title{color:var(--white);margin-bottom:1.5rem}
.contact-intro{font-weight:300;font-size:1rem;line-height:1.85;color:rgba(253,252,250,.6);margin-bottom:3rem}
.contact-details{display:flex;flex-direction:column;gap:1.5rem}
.contact-detail{display:flex;align-items:flex-start;gap:1rem}
.contact-detail-icon{width:40px;height:40px;border-radius:50%;border:1px solid rgba(197,162,88,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.85rem;color:var(--gold);transition:background .3s,border-color .3s;font-variant-emoji:text}
.location-detail-icon{font-variant-emoji:text}
.contact-detail:hover .contact-detail-icon{background:rgba(197,162,88,.1);border-color:var(--gold)}
.contact-detail-label{font-weight:500;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.25rem}
.contact-detail-value{font-weight:300;font-size:.92rem;color:rgba(253,252,250,.7);line-height:1.5}
.contact-detail-value a{color:rgba(253,252,250,.7);text-decoration:none;transition:color .3s}
.contact-detail-value a:hover{color:var(--white)}
.contact-form-wrapper{background:rgba(253,252,250,.04);border:1px solid rgba(253,252,250,.07);border-radius:20px;padding:3rem;backdrop-filter:blur(10px)}
.contact-form-title{font-weight:300;font-size:1.2rem;letter-spacing:.02em;margin-bottom:2rem;color:var(--white)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-weight:400;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(253,252,250,.45);margin-bottom:.6rem}
.form-input,.form-select,.form-textarea{width:100%;font-family:"marseille",sans-serif;font-weight:300;font-size:.92rem;color:var(--white);background:rgba(253,252,250,.04);border:1px solid rgba(253,252,250,.1);border-radius:12px;padding:.9rem 1.15rem;outline:none;transition:border-color .4s,background .4s,box-shadow .4s;-webkit-appearance:none}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(253,252,250,.2);font-weight:300}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);background:rgba(197,162,88,.04);box-shadow:0 0 0 3px rgba(197,162,88,.08)}
.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='rgba(253,252,250,0.4)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.15rem center;padding-right:2.5rem}
.form-select option{background:var(--green);color:var(--white)}
.form-textarea{resize:vertical;min-height:120px}
.form-submit{display:inline-flex;align-items:center;gap:.75rem;font-family:"marseille",sans-serif;font-weight:400;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);background:var(--gold);border:none;padding:1.1rem 2.5rem;border-radius:100px;cursor:pointer;transition:background .4s,transform .2s,box-shadow .4s;margin-top:.5rem}
.form-submit:hover{background:var(--gold-light);box-shadow:0 8px 30px rgba(197,162,88,.25)}.form-submit:active{transform:scale(.97)}
.form-submit .btn-arrow{transition:transform .3s}.form-submit:hover .btn-arrow{transform:translateX(4px)}
.form-success{display:none;text-align:center;padding:3rem 1rem}.form-success.show{display:block}
.form-success-icon{width:60px;height:60px;border-radius:50%;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:1.4rem;color:var(--gold);animation:successPop .5s cubic-bezier(.22,1,.36,1)}
@keyframes successPop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.form-success-title{font-weight:300;font-size:1.3rem;color:var(--white);margin-bottom:.75rem}
.form-success-text{font-weight:300;font-size:.88rem;color:rgba(253,252,250,.5);line-height:1.6}

/* ==========================================================
   salon.html – Styles spécifiques
   ========================================================== */

/* Hero de page */
.page-hero{display:flex;align-items:center;justify-content:center;text-align:center;min-height:65vh;padding:10rem 3rem 6rem;background:var(--cream);position:relative}
.page-hero::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:1px;height:60px;background:linear-gradient(to bottom,var(--gold),transparent)}
.page-hero-label{font-weight:400;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s .2s cubic-bezier(.22,1,.36,1) forwards}
.page-hero-title{font-weight:200;font-size:clamp(3rem,8vw,6rem);line-height:1;letter-spacing:-.02em;opacity:0;animation:fadeUp 1s .4s cubic-bezier(.22,1,.36,1) forwards}
.page-hero-sub{font-weight:300;font-size:clamp(1rem,2vw,1.2rem);color:var(--text-light);margin-top:1.5rem;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.7;opacity:0;animation:fadeUp 1s .7s cubic-bezier(.22,1,.36,1) forwards}

/* Image pleine largeur */
.full-image{position:relative;height:60vh;min-height:400px;overflow:hidden}
.full-image img{width:100%;height:100%;object-fit:cover}

/* Blocs story */
.story{padding:7rem 3rem}
.story-block{display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1100px;margin:0 auto;align-items:center}
.story-block.reverse{direction:rtl}.story-block.reverse>*{direction:ltr}
.story-img-wrapper{position:relative;overflow:hidden;border-radius:20px}
.story-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.story-img-wrapper:hover .story-img{transform:scale(1.03)}
.story-label{font-weight:400;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.story-title{font-weight:200;font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1.2;letter-spacing:-.01em;margin-bottom:1.5rem}
.story-text{font-weight:300;font-size:1rem;line-height:1.85;color:var(--text-light)}
.story-text+.story-text{margin-top:1.2rem}
.story .gold-line{margin:2.5rem 0 0}

/* Citation */
.quote-section{background:var(--white);text-align:center;padding:6rem 3rem}
.quote-text{font-weight:200;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.5;font-style:italic;color:var(--text);max-width:700px;margin:0 auto}
.quote-text::before{content:'«';color:var(--gold);margin-right:.3em}
.quote-text::after{content:'»';color:var(--gold);margin-left:.3em}

/* Valeurs */
.values{background:var(--green);color:var(--white);padding:7rem 3rem}
.values-inner{max-width:1100px;margin:0 auto}
.values-header{text-align:center;margin-bottom:4rem}
.values-header .section-label{color:var(--gold-light)}
.values-header .section-title{color:var(--white);margin:0 auto}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem}
.value-card{text-align:center;padding:2.5rem 1.5rem}
.value-number{font-weight:200;font-size:2.5rem;color:var(--gold);margin-bottom:1rem;line-height:1}
.value-title{font-weight:400;font-size:1rem;letter-spacing:.03em;margin-bottom:1rem}
.value-text{font-weight:300;font-size:.88rem;line-height:1.7;color:rgba(253,252,250,.55)}

/* Localisation */
.location{padding:7rem 3rem;background:var(--white)}
.location-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.location-info .section-title{margin-bottom:1.5rem}
.location-text{font-weight:300;font-size:1rem;line-height:1.85;color:var(--text-light);margin-bottom:2rem}
.location-details{display:flex;flex-direction:column;gap:1.2rem}
.location-detail{display:flex;align-items:flex-start;gap:1rem}
.location-detail-icon{width:36px;height:36px;border-radius:50%;border:1px solid rgba(197,162,88,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.8rem;color:var(--gold)}
.location-detail-label{font-weight:500;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.2rem}
.location-detail-value{font-weight:300;font-size:.9rem;color:var(--text-light);line-height:1.5}
.location-map{border-radius:20px;overflow:hidden;aspect-ratio:1/1}
.location-map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}

/* CTA */
.cta-section{background:var(--cream);text-align:center;padding:7rem 3rem}
.cta-title{font-weight:200;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2;margin-bottom:1.5rem}
.cta-text{font-weight:300;font-size:1rem;color:var(--text-light);line-height:1.7;max-width:500px;margin:0 auto 2.5rem}

/* ==========================================================
   Media queries
   ========================================================== */

@media(max-width:1024px){
  .signatures-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}

@media(max-width:768px){
  nav{padding:1.2rem 1.5rem}
  section{padding:5rem 1.5rem}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .signatures-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .sig-card-detail{opacity:1;transform:translateY(0)}
  .events-layout{grid-template-columns:1fr;gap:3rem}
  .events-accent{bottom:-20px;right:-10px;width:100px;height:100px}
  .events-accent span:first-child{font-size:1.2rem}
  .contact-layout{grid-template-columns:1fr;gap:3rem}
  .contact-form-wrapper{padding:2rem}
  .form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .cat-modal{width:100vw}
  .cat-modal-header{padding:2rem 1.5rem 1.5rem}
  .cat-modal-gallery{padding:1.5rem}
  .story-block,.story-block.reverse{grid-template-columns:1fr;gap:2.5rem;direction:ltr}
  .values-grid{grid-template-columns:1fr}
  .location-inner{grid-template-columns:1fr;gap:2.5rem}
  .location-map{aspect-ratio:16/9}
  .full-image{height:40vh;min-height:280px}
}

@media(max-width:480px){
  .signatures-grid{grid-template-columns:1fr}
  .events-services{grid-template-columns:1fr}
  .cat-modal-gallery{grid-template-columns:1fr}
  .cat-modal-img.tall{grid-row:span 1;aspect-ratio:4/5}
}
