/* ============================================================
   GARDEN INSTITUT & SPA — Shared Stylesheet (Multi-page)
   Palette Fougère Dorée · Cormorant Garamond + Inter
   ============================================================ */

/* ===== RESET & VARIABLES ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
--vert:#355748;--creme:#F4EEDF;--or:#B89A5D;--cuivre:#B8745A;
--taupe:#8A8172;--brun:#5D4A3D;--rose:#E8D2CC;--sauge:#B7C3B0;
--mousse:#6E8A73;--champagne:#D7C59A;--sable:#D9C7AE;
--malachite:#1F5B4B;--prune:#6A4B53;--nuit:#39434A;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Inter',sans-serif;background:var(--creme);color:var(--brun);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:400;color:var(--vert)}
.serif{font-family:'Cormorant Garamond',serif}

/* ===== CURSOR GLOW ===== */
.cursor-glow{position:fixed;width:300px;height:300px;border-radius:50%;pointer-events:none;z-index:9999;
background:radial-gradient(circle,rgba(184,154,93,0.08) 0%,transparent 70%);
transform:translate(-50%,-50%);transition:opacity .3s}

/* ===== LOADER ===== */
#loader{position:fixed;inset:0;z-index:10000;background:var(--vert);display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity 1s,visibility 1s}
#loader.hidden{opacity:0;visibility:hidden}
#loader svg{width:80px;height:80px;animation:pulse 2s infinite}
#loader p{color:var(--or);font-family:'Cormorant Garamond',serif;font-size:1.2rem;margin-top:1.5rem;letter-spacing:.3em;text-transform:uppercase;opacity:0;animation:fadeUp 1s .5s forwards}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 3rem;display:flex;align-items:center;justify-content:space-between;transition:all .5s;background:transparent;backdrop-filter:none;opacity:0;pointer-events:none}
nav.scrolled{background:rgba(53,87,72,.97);backdrop-filter:blur(20px);padding:.8rem 3rem;box-shadow:0 4px 30px rgba(0,0,0,.15);opacity:1;pointer-events:auto}
.nav-logo{display:flex;align-items:center;gap:.8rem;text-decoration:none}
.nav-logo-icon{width:42px;height:42px}
.nav-logo span{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--or);letter-spacing:.15em;text-transform:uppercase;font-weight:500}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{color:var(--creme);text-decoration:none;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--or);transition:width .4s}
.nav-links a:hover::after{width:100%}
.nav-links a:hover{color:var(--or)}
/* Active nav link */
.nav-links a.active{color:var(--or)}
.nav-links a.active::after{width:100%}
.nav-cta{background:var(--or)!important;color:var(--vert)!important;padding:.6rem 1.5rem;border-radius:2px;font-weight:500;transition:all .3s!important}
.nav-cta:hover{background:var(--cuivre)!important;transform:translateY(-2px)}
.nav-cta::after{display:none!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001}
.nav-toggle span{width:28px;height:2px;background:var(--or);transition:all .3s}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== NAV — INTERIOR PAGES (always visible) ===== */
body.interior nav{background:rgba(53,87,72,.97);backdrop-filter:blur(20px);padding:.8rem 3rem;box-shadow:0 4px 30px rgba(0,0,0,.15);opacity:1;pointer-events:auto}

/* ===== NAV — DROPDOWN SUB-MENUS ===== */
.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:.3rem}
.nav-dropdown>a .dropdown-arrow{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--creme);transition:transform .3s;margin-left:.2rem}
.nav-dropdown:hover>a .dropdown-arrow{transform:rotate(180deg);border-top-color:var(--or)}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:220px;background:rgba(53,87,72,.98);backdrop-filter:blur(20px);border:1px solid rgba(184,154,93,.15);box-shadow:0 15px 40px rgba(0,0,0,.25);padding:.5rem 0;opacity:0;visibility:hidden;transition:all .3s;margin-top:.8rem;z-index:1001}
.nav-dropdown-menu::before{content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid rgba(53,87,72,.98)}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;margin-top:.4rem}
.nav-dropdown-menu a{display:block;padding:.7rem 1.5rem;color:var(--creme)!important;font-size:.8rem!important;letter-spacing:.08em!important;text-transform:uppercase!important;transition:all .3s;white-space:nowrap}
.nav-dropdown-menu a::after{display:none!important}
.nav-dropdown-menu a:hover{background:rgba(184,154,93,.12);color:var(--or)!important;padding-left:1.8rem}
.nav-dropdown-menu a .dropdown-desc{display:block;font-size:.7rem;color:var(--sauge);letter-spacing:.02em;text-transform:none;margin-top:.2rem;font-weight:300}

/* ===== HERO (Homepage) ===== */
#hero{position:relative;overflow:hidden;background:#050a05;margin-bottom:0;padding:0}
.hero-img{width:100%;height:auto;display:block;position:relative;z-index:1}
#hero-canvas{position:absolute;top:0;left:0;width:100%;height:100vh;z-index:2;pointer-events:none}
.hero-overlay{position:absolute;bottom:0;left:0;right:0;height:180px;z-index:3;pointer-events:none;
background:linear-gradient(to bottom,transparent 0%,rgba(244,238,223,.3) 40%,rgba(244,238,223,.7) 70%,var(--creme) 100%)}
/* Hotspots — transparent clickable areas over image buttons */
.hero-hotspots{position:absolute;inset:0;z-index:5;pointer-events:none}
.hero-hotspot{position:absolute;pointer-events:auto;display:block;color:transparent;font-size:0;text-decoration:none;cursor:pointer;background:transparent;transition:background .3s,box-shadow .3s;border-radius:3px}
.hero-hotspot:hover{background:rgba(184,154,93,.12);box-shadow:0 0 25px rgba(184,154,93,.3),inset 0 0 15px rgba(184,154,93,.08)}
.hero-hs-reserver{top:72.2%;left:22%;width:18%;height:3.2%}
.hero-hs-decouvrir{top:72.2%;left:44%;width:24%;height:3.2%}
.hero-hs-scroll{top:89.5%;left:35%;width:30%;height:4%;border-radius:0}
.hero-hs-nav-reserver{top:0.8%;left:75%;width:18%;height:3.5%;border-radius:20px}
.hero-hs-audio{top:92%;left:91%;width:7%;height:6%;border-radius:50%;cursor:pointer}
/* Botanical leaf decorations — hidden: mockup image has built-in foliage */
.hero-foliage{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none;display:none}
.hero-leaf{position:absolute;opacity:.65;transition:transform 8s ease-in-out}
.hero-leaf svg{width:100%;height:100%;filter:drop-shadow(0 0 30px rgba(10,30,15,.7))}
.hero-leaf-tl{top:-10%;left:-5%;width:clamp(280px,38vw,620px);height:auto;transform:rotate(15deg)}
.hero-leaf-tr{top:-8%;right:-8%;width:clamp(300px,40vw,650px);height:auto;transform:rotate(-20deg) scaleX(-1)}
.hero-leaf-bl{bottom:-12%;left:-8%;width:clamp(320px,42vw,680px);height:auto;transform:rotate(-10deg)}
.hero-leaf-br{bottom:-10%;right:-5%;width:clamp(280px,36vw,600px);height:auto;transform:rotate(25deg) scaleX(-1)}
.hero-leaf-ml{top:28%;left:-3%;width:clamp(160px,22vw,350px);height:auto;opacity:.45;transform:rotate(30deg)}
.hero-leaf-mr{top:22%;right:-3%;width:clamp(180px,24vw,380px);height:auto;opacity:.5;transform:rotate(-25deg) scaleX(-1)}
/* Gold-tipped leaves */
.hero-leaf-gold{opacity:.35;filter:drop-shadow(0 0 20px rgba(184,154,93,.4))}
.hero-leaf-gold svg path{fill:url(#goldLeafGrad)!important}
/* Foreground foliage — hidden: mockup image has built-in foliage */
.hero-foliage-front{position:absolute;inset:0;z-index:6;overflow:hidden;pointer-events:none;display:none}
.hero-leaf-front{position:absolute}
.hero-leaf-front svg{width:100%;height:100%;filter:drop-shadow(0 0 25px rgba(5,15,5,.8))}
.hero-leaf-front-tl{top:-8%;left:-4%;width:clamp(220px,32vw,520px);height:auto;opacity:.7;transform:rotate(18deg)}
.hero-leaf-front-tr{top:-6%;right:-6%;width:clamp(240px,34vw,550px);height:auto;opacity:.65;transform:rotate(-22deg) scaleX(-1)}
.hero-leaf-front-bl{bottom:-10%;left:-6%;width:clamp(260px,36vw,560px);height:auto;opacity:.6;transform:rotate(-8deg)}
.hero-leaf-front-br{bottom:-8%;right:-4%;width:clamp(230px,30vw,500px);height:auto;opacity:.55;transform:rotate(20deg) scaleX(-1)}
.hero-leaf-front-tc{top:-12%;left:50%;width:clamp(180px,25vw,400px);height:auto;opacity:.4;transform:translateX(-50%) rotate(180deg)}

.hero-content{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
/* SR-only: hero text hidden visually — mockup image provides the visuals */
.hero-title-main,.hero-badge,.hero-title,.hero-sub{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important;opacity:0!important;animation:none!important}
/* GARDEN INSTITUT — golden neon 3D title */
.hero-title-main{font-family:'Cormorant Garamond',serif;font-size:clamp(4rem,13vw,9.5rem);font-weight:600;
text-transform:uppercase;letter-spacing:.08em;line-height:.88;margin-bottom:.5rem;
color:transparent;
-webkit-text-stroke:2px rgba(212,176,84,.95);
paint-order:stroke fill;
text-shadow:none;
filter:drop-shadow(0 0 6px rgba(212,176,84,.5)) drop-shadow(0 0 20px rgba(184,154,93,.25)) drop-shadow(0 0 50px rgba(184,154,93,.1)) drop-shadow(2px 3px 6px rgba(0,0,0,.9));
opacity:0;animation:fadeUp 1.2s 1.2s forwards}
.hero-title-main span{font-size:.6em;letter-spacing:.3em;display:block;-webkit-text-stroke-width:1.5px}
.hero-title-sub{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,4.5vw,3.5rem);font-weight:400;
text-transform:uppercase;letter-spacing:.35em;line-height:1;margin-bottom:2rem;
color:#D4B054;
text-shadow:0 0 6px rgba(212,176,84,.4),0 0 15px rgba(184,154,93,.25),1px 2px 4px rgba(0,0,0,.6);
opacity:0;animation:fadeUp 1s 1.5s forwards}
.hero-badge{display:inline-block;border:1px solid var(--or);color:var(--or);padding:.5rem 2rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:2.5rem;
background:rgba(184,154,93,.08);opacity:0;animation:fadeUp 1s 1.8s forwards}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,5.5vw,4rem);color:var(--creme);line-height:1.15;margin-bottom:1.5rem;opacity:0;animation:fadeUp 1s 2.1s forwards}
.hero-title em{font-style:italic;color:var(--or)}
.hero-sub{color:rgba(183,195,176,.85);font-size:1.05rem;font-weight:300;letter-spacing:.03em;margin-bottom:3rem;max-width:550px;margin-left:auto;margin-right:auto;opacity:0;animation:fadeUp 1s 2.4s forwards}
.hero-btns{display:none}
.btn-primary{background:var(--or);color:var(--vert);padding:.9rem 2.5rem;text-decoration:none;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;transition:all .4s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--cuivre);transform:translateY(-3px);box-shadow:0 10px 30px rgba(184,154,93,.4),0 0 15px rgba(184,154,93,.2)}
.btn-outline{border:1px solid var(--or);color:var(--or);padding:.9rem 2.5rem;text-decoration:none;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;transition:all .4s;background:rgba(184,154,93,.05)}
.btn-outline:hover{background:rgba(184,154,93,.18);transform:translateY(-3px);box-shadow:0 0 20px rgba(184,154,93,.15)}
.hero-scroll{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);z-index:5;display:none;flex-direction:column;align-items:center;gap:.5rem;color:var(--or);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;opacity:0;animation:fadeUp 1s 3s forwards}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--or),transparent);animation:scrollLine 2s infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===== MINI-HERO (Interior pages) ===== */
.mini-hero{position:relative;overflow:hidden;background:var(--vert);padding:8rem 2rem 4rem;text-align:center;min-height:280px;display:flex;align-items:center;justify-content:center}
.mini-hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse at 20% 50%,rgba(184,154,93,.08) 0%,transparent 50%),
  radial-gradient(ellipse at 80% 50%,rgba(31,91,75,.3) 0%,transparent 50%),
  linear-gradient(135deg,var(--malachite) 0%,var(--vert) 40%,#2a4a3d 100%);
z-index:0}
.mini-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:80px;z-index:1;
background:linear-gradient(to bottom,transparent,var(--creme))}
.mini-hero-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none}
.mini-hero-content{position:relative;z-index:2}
.mini-hero .section-badge{color:var(--or)}
.mini-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,5vw,3.5rem);color:var(--creme);margin-bottom:.8rem;line-height:1.2}
.mini-hero h1 em{font-style:italic;color:var(--or)}
.mini-hero p{color:var(--sauge);font-size:1.05rem;font-weight:300;max-width:550px;margin:0 auto;line-height:1.7}
/* Decorative botanical pattern overlay for mini-hero */
.mini-hero .hero-pattern{position:absolute;inset:0;z-index:0;opacity:.03;
background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5 Q35 20 30 35 Q25 20 30 5' fill='none' stroke='%23B89A5D' stroke-width='0.5'/%3E%3C/svg%3E") repeat}

/* ===== BREADCRUMB ===== */
.breadcrumb{max-width:1200px;margin:2rem auto 0;padding:0 2rem;font-size:.8rem;color:var(--taupe)}
.breadcrumb a{color:var(--or);text-decoration:none;transition:color .3s}
.breadcrumb a:hover{color:var(--cuivre)}
.breadcrumb span{margin:0 .4rem;color:var(--sable)}

/* ===== AUDIO TOGGLE ===== */
#audio-toggle{position:fixed;bottom:2rem;right:2rem;z-index:999;width:50px;height:50px;border-radius:50%;background:var(--vert);border:1px solid var(--or);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;opacity:0;animation:fadeUp 1s 3s forwards}
#audio-toggle:hover{transform:scale(1.1);box-shadow:0 5px 20px rgba(184,154,93,.3)}
#audio-toggle svg{width:20px;height:20px;fill:var(--or)}
.sound-waves{position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--or);opacity:0;animation:soundWave 2s infinite}
.sound-waves:nth-child(2){animation-delay:.5s}
@keyframes soundWave{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}

/* ===== SECTIONS ===== */
section{padding:8rem 2rem}
.section-badge{display:inline-block;color:var(--or);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:1rem}
.section-title{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem;line-height:1.2}
.section-line{width:60px;height:1px;background:var(--or);margin:1.5rem 0}
.section-desc{color:var(--taupe);font-size:1rem;line-height:1.8;max-width:600px;font-weight:300}

/* ===== PHILOSOPHY ===== */
#philosophy{background:var(--creme);position:relative;overflow:hidden}
.philosophy-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.philosophy-visual{position:relative;height:500px}
.philosophy-circle{width:350px;height:350px;border-radius:50%;background:linear-gradient(135deg,var(--vert),var(--malachite));position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);overflow:hidden}
.philosophy-circle::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5 Q35 20 30 35 Q25 20 30 5' fill='none' stroke='rgba(184,154,93,0.1)' stroke-width='0.5'/%3E%3C/svg%3E") repeat;opacity:.5}
.philosophy-float{position:absolute;background:white;padding:1.5rem 2rem;box-shadow:0 20px 60px rgba(0,0,0,.08);max-width:250px}
.philosophy-float-1{top:10%;right:5%;animation:float 6s ease-in-out infinite}
.philosophy-float-2{bottom:10%;left:5%;animation:float 6s ease-in-out infinite 2s}
.philosophy-float h4{font-size:1.1rem;margin-bottom:.4rem}
.philosophy-float p{font-size:.85rem;color:var(--taupe);line-height:1.5}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}

/* ===== SPECIALTIES (Homepage grid) ===== */
#specialties{background:var(--vert);color:var(--creme);position:relative}
#specialties::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='1' fill='rgba(184,154,93,0.05)'/%3E%3C/svg%3E") repeat}
.spec-header{text-align:center;max-width:700px;margin:0 auto 5rem;position:relative;z-index:1}
.spec-header .section-title{color:var(--creme)}
.spec-header .section-desc{color:var(--sauge);margin:0 auto}
.spec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto;position:relative;z-index:1}
.spec-card{background:rgba(255,255,255,.04);border:1px solid rgba(184,154,93,.15);padding:2rem 1.5rem;text-align:center;transition:all .5s;cursor:pointer;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.spec-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(184,154,93,.1),transparent);opacity:0;transition:opacity .5s}
.spec-card:hover{transform:translateY(-8px);border-color:var(--or);box-shadow:0 20px 40px rgba(0,0,0,.2)}
.spec-card:hover::before{opacity:1}
.spec-icon{width:50px;height:50px;margin:0 auto 1.2rem;border:1px solid var(--or);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .5s}
.spec-card:hover .spec-icon{background:var(--or);transform:scale(1.1)}
.spec-icon svg{width:22px;height:22px;stroke:var(--or);fill:none;stroke-width:1.5;transition:stroke .3s}
.spec-card:hover .spec-icon svg{stroke:var(--vert)}
.spec-card h3{font-size:1.1rem;color:var(--creme);margin-bottom:.5rem;position:relative;z-index:1}
.spec-card p{font-size:.8rem;color:var(--sauge);line-height:1.5;position:relative;z-index:1}

/* ===== HOMEPAGE CATEGORY CARDS (Accueil multi-pages) ===== */
.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:0 auto;position:relative;z-index:1}
.category-card{position:relative;overflow:hidden;border:1px solid rgba(184,154,93,.2);background:rgba(255,255,255,.04);padding:3rem 2rem;text-align:center;transition:all .5s;text-decoration:none;display:block;min-height:220px}
.category-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(184,154,93,.08),transparent);opacity:0;transition:opacity .5s}
.category-card:hover{transform:translateY(-8px);border-color:var(--or);box-shadow:0 20px 50px rgba(0,0,0,.2)}
.category-card:hover::before{opacity:1}
.category-card-icon{width:60px;height:60px;margin:0 auto 1.5rem;border:1px solid var(--or);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .5s}
.category-card:hover .category-card-icon{background:var(--or);transform:scale(1.1)}
.category-card-icon svg{width:28px;height:28px;stroke:var(--or);fill:none;stroke-width:1.5;transition:stroke .3s}
.category-card:hover .category-card-icon svg{stroke:var(--vert)}
.category-card h3{font-size:1.4rem;color:var(--creme);margin-bottom:.8rem;position:relative;z-index:1}
.category-card p{font-size:.9rem;color:var(--sauge);line-height:1.6;position:relative;z-index:1;margin-bottom:1.5rem}
.category-card .card-count{font-size:.75rem;color:var(--or);letter-spacing:.15em;text-transform:uppercase;position:relative;z-index:1}
.category-card .card-arrow{position:absolute;bottom:1.5rem;right:1.5rem;width:30px;height:30px;border:1px solid rgba(184,154,93,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .4s}
.category-card:hover .card-arrow{background:var(--or);border-color:var(--or)}
.category-card .card-arrow svg{width:14px;height:14px;stroke:var(--or);fill:none;stroke-width:2;transition:stroke .3s}
.category-card:hover .card-arrow svg{stroke:var(--vert)}

/* ===== SERVICE DETAIL CARDS (Interior pages) ===== */
.service-section{padding:5rem 2rem;position:relative}
.service-section:nth-child(even){background:rgba(53,87,72,.03)}
.service-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.service-grid.reverse{direction:rtl}
.service-grid.reverse>*{direction:ltr}
.service-visual{position:relative;height:350px;background:linear-gradient(135deg,var(--vert),var(--malachite));border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.service-visual::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5 Q35 20 30 35 Q25 20 30 5' fill='none' stroke='rgba(184,154,93,0.08)' stroke-width='0.5'/%3E%3C/svg%3E") repeat}
.service-visual .service-placeholder{position:relative;z-index:1;text-align:center}
.service-visual .service-placeholder svg{width:60px;height:60px;stroke:var(--or);fill:none;stroke-width:1.2;margin-bottom:1rem}
.service-visual .service-placeholder span{display:block;color:var(--or);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase}
.service-content{padding:1rem 0}
.service-content .section-badge{margin-bottom:.5rem}
.service-content h2{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:1rem}
.service-content p{color:var(--taupe);font-size:.95rem;line-height:1.8;font-weight:300;margin-bottom:1.5rem}
.service-content .service-details{list-style:none;margin-bottom:2rem}
.service-content .service-details li{padding:.5rem 0;border-bottom:1px solid rgba(184,154,93,.1);font-size:.9rem;color:var(--brun);display:flex;align-items:center;gap:.8rem}
.service-content .service-details li svg{width:16px;height:16px;stroke:var(--or);fill:none;flex-shrink:0}
.service-cta{display:inline-flex;align-items:center;gap:.6rem}

/* ===== AMBIANCE (parallax quote) ===== */
#ambiance{padding:0;height:60vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;
background:linear-gradient(rgba(31,91,75,.8),rgba(53,87,72,.85)),linear-gradient(var(--vert),var(--malachite));
background-attachment:fixed}
.ambiance-content{text-align:center;z-index:2;padding:2rem}
.ambiance-quote{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,4vw,3rem);color:var(--creme);font-style:italic;line-height:1.4;max-width:700px;margin:0 auto}
.ambiance-quote span{color:var(--or)}
.ambiance-author{color:var(--or);font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;margin-top:2rem}

/* ===== EXPERIENCE ===== */
#experience{background:var(--creme)}
.exp-container{max-width:1200px;margin:0 auto}
.exp-header{text-align:center;margin-bottom:5rem}
.exp-header .section-desc{margin:0 auto}
.exp-timeline{position:relative;padding-left:3rem}
.exp-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,var(--or),transparent)}
.exp-step{position:relative;margin-bottom:4rem;padding-left:3rem;opacity:0;transform:translateX(-30px);transition:all .8s}
.exp-step.visible{opacity:1;transform:translateX(0)}
.exp-step::before{content:'';position:absolute;left:-3.4rem;top:.5rem;width:10px;height:10px;border:2px solid var(--or);border-radius:50%;background:var(--creme);transition:all .3s}
.exp-step.visible::before{background:var(--or)}
.exp-step-num{color:var(--or);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:.5rem}
.exp-step h3{font-size:1.6rem;margin-bottom:.8rem}
.exp-step p{color:var(--taupe);line-height:1.8;font-weight:300}

/* ===== AVIS ===== */
#avis{background:white;text-align:center}
.avis-container{max-width:900px;margin:0 auto}
.avis-stars{color:var(--or);font-size:2rem;margin-bottom:1rem;letter-spacing:.3rem}
.avis-score{font-family:'Cormorant Garamond',serif;font-size:4rem;color:var(--vert);line-height:1}
.avis-count{color:var(--taupe);font-size:.9rem;margin-top:.5rem;margin-bottom:3rem}
.avis-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}
.avis-card{background:var(--creme);padding:2rem;text-align:left;border-left:3px solid var(--or)}
.avis-card p{font-style:italic;color:var(--brun);line-height:1.7;margin-bottom:1rem;font-size:.95rem}
.avis-card cite{color:var(--or);font-size:.8rem;letter-spacing:.1em;font-style:normal}

/* ===== HORAIRES & CONTACT ===== */
#contact{background:var(--vert);color:var(--creme)}
.contact-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:3rem}
.contact-block h3{font-size:1.5rem;color:var(--creme);margin-bottom:1.5rem}
.contact-block .gold-line{width:40px;height:1px;background:var(--or);margin-bottom:1.5rem}
.contact-info{list-style:none}
.contact-info li{padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:.9rem;color:var(--sauge);display:flex;align-items:center;gap:.8rem}
.contact-info li svg{width:16px;height:16px;stroke:var(--or);flex-shrink:0}
.contact-hours td{padding:.4rem 0;font-size:.9rem;color:var(--sauge)}
.contact-hours td:first-child{color:var(--creme);padding-right:2rem;font-weight:500}
.contact-map{position:relative;overflow:hidden;border:1px solid rgba(184,154,93,.2)}
.contact-map iframe{width:100%;height:100%;min-height:300px;border:0;filter:grayscale(.8) contrast(1.1)}

/* ===== ABOUT PAGE — Timeline ===== */
.about-timeline{max-width:900px;margin:3rem auto;position:relative;padding-left:3rem}
.about-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--or),var(--mousse),var(--or))}
.about-timeline-item{position:relative;margin-bottom:3rem;padding-left:2.5rem}
.about-timeline-item::before{content:'';position:absolute;left:-3.6rem;top:.3rem;width:14px;height:14px;border:2px solid var(--or);border-radius:50%;background:var(--creme)}
.about-timeline-item.visible::before{background:var(--or)}
.about-timeline-item .year{color:var(--or);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:.3rem;font-weight:500}
.about-timeline-item h3{font-size:1.4rem;margin-bottom:.5rem}
.about-timeline-item p{color:var(--taupe);line-height:1.7;font-weight:300}

/* ===== ABOUT PAGE — Team ===== */
.team-section{background:var(--vert);padding:5rem 2rem;text-align:center}
.team-section .section-title{color:var(--creme)}
.team-section .section-desc{color:var(--sauge);margin:0 auto 3rem}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1000px;margin:0 auto}
.team-card{background:rgba(255,255,255,.05);border:1px solid rgba(184,154,93,.15);padding:2.5rem 2rem;text-align:center;transition:all .4s}
.team-card:hover{border-color:var(--or);transform:translateY(-5px)}
.team-card-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--malachite),var(--vert));margin:0 auto 1.2rem;display:flex;align-items:center;justify-content:center;border:2px solid var(--or)}
.team-card-avatar svg{width:36px;height:36px;stroke:var(--or);fill:none;stroke-width:1.2}
.team-card h3{font-size:1.2rem;color:var(--creme);margin-bottom:.4rem}
.team-card p{font-size:.85rem;color:var(--sauge);line-height:1.5}

/* ===== CONTACT PAGE — Full layout ===== */
.contact-full{max-width:1100px;margin:0 auto;padding:4rem 2rem}
.contact-full-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:3rem}
.contact-full-map{border:1px solid rgba(184,154,93,.2);overflow:hidden;min-height:400px}
.contact-full-map iframe{width:100%;height:100%;min-height:400px;border:0;filter:grayscale(.8) contrast(1.1)}
.contact-socials{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.contact-social-link{display:flex;align-items:center;gap:.6rem;padding:.6rem 1.2rem;border:1px solid rgba(184,154,93,.2);text-decoration:none;color:var(--brun);font-size:.85rem;transition:all .3s;letter-spacing:.05em}
.contact-social-link:hover{border-color:var(--or);background:rgba(184,154,93,.05);transform:translateY(-2px)}
.contact-social-link svg{width:18px;height:18px;fill:var(--or)}

/* ===== EPILATION PAGE — Pricing hints ===== */
.price-note{max-width:800px;margin:3rem auto;padding:2rem;background:rgba(184,154,93,.06);border:1px solid rgba(184,154,93,.15);text-align:center}
.price-note p{color:var(--taupe);font-size:.9rem;line-height:1.7}
.price-note a{color:var(--or);text-decoration:underline}

/* ===== FOOTER ===== */
footer{background:var(--malachite);padding:3rem 2rem;text-align:center}
.footer-content{max-width:1200px;margin:0 auto}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--or);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1rem}
.footer-nav{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem}
.footer-nav a{color:var(--sauge);text-decoration:none;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.footer-nav a:hover{color:var(--or)}
.footer-socials{display:flex;justify-content:center;gap:1.5rem;margin-bottom:1.5rem}
.footer-socials a{width:40px;height:40px;border:1px solid rgba(184,154,93,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s;text-decoration:none}
.footer-socials a:hover{background:var(--or);border-color:var(--or)}
.footer-socials a svg{width:16px;height:16px;fill:var(--or);transition:fill .3s}
.footer-socials a:hover svg{fill:var(--vert)}
.footer-hours{margin-bottom:1.5rem;font-size:.8rem;color:var(--sauge)}
.footer-hours span{color:var(--creme);margin-right:.3rem}
footer p{color:var(--sauge);font-size:.75rem;letter-spacing:.05em}
footer a{color:var(--or);text-decoration:none}

/* ===== REVEAL ANIMATION ===== */
.reveal{opacity:0;transform:translateY(40px);transition:all .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.2s}
.reveal-delay-2{transition-delay:.4s}
.reveal-delay-3{transition-delay:.6s}

/* ===== PARTICLES ===== */
.particle{position:absolute;width:3px;height:3px;background:var(--or);border-radius:50%;opacity:.3;pointer-events:none}

/* ===== MOBILE ===== */
@media(max-width:900px){
nav{padding:1rem 1.5rem}
nav.scrolled,body.interior nav{padding:.6rem 1.5rem}
.nav-links{position:fixed;top:0;right:-100%;width:80%;height:100vh;background:rgba(31,91,75,.98);backdrop-filter:blur(20px);flex-direction:column;justify-content:center;gap:2rem;transition:right .5s;padding:2rem}
.nav-links.open{right:0}
.nav-toggle{display:flex}
/* Mobile dropdowns — expand inline */
.nav-dropdown-menu{position:static;transform:none;min-width:auto;background:transparent;border:none;box-shadow:none;padding:0 0 0 1rem;opacity:1;visibility:visible;margin-top:.5rem;display:none}
.nav-dropdown.open .nav-dropdown-menu{display:block}
.nav-dropdown-menu::before{display:none}
.nav-dropdown-menu a{padding:.5rem 1rem;font-size:.75rem!important}
.nav-dropdown-menu a:hover{padding-left:1.3rem}
.philosophy-grid{grid-template-columns:1fr;gap:3rem}
.philosophy-visual{height:300px}
.philosophy-circle{width:250px;height:250px}
.contact-grid{grid-template-columns:1fr}
.contact-full-grid{grid-template-columns:1fr}
section{padding:5rem 1.5rem}
.spec-grid{grid-template-columns:1fr 1fr}
.exp-timeline{padding-left:2rem}
.exp-step{padding-left:2rem}
.service-grid{grid-template-columns:1fr;gap:2rem}
.service-grid.reverse{direction:ltr}
.service-visual{height:250px}
.mini-hero{padding:6rem 1.5rem 3rem;min-height:200px}
.category-grid{grid-template-columns:1fr}
.team-grid{grid-template-columns:1fr}
}
@media(max-width:500px){
.spec-grid{grid-template-columns:1fr}
.hero-btns{flex-direction:column;align-items:center}
.footer-nav{flex-direction:column;gap:.8rem;align-items:center}
}
