*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --g1:#1A3C2A;--g2:#2D6A4F;--g3:#40916C;--g4:#52B788;--g5:#95D5B2;--g6:#D8F3DC;
  --gold:#C9A84C;--gold2:#E8C97A;--gold3:#FFF5D6;
  --cream:#F9F8F4;--white:#FFFFFF;--dark:#111C15;
  --text:#243028;--muted:#5A7562;--border:rgba(45,106,79,0.12);
  --serif:'Playfair Display',serif;--sans:'Jost',sans-serif;
  --r:14px;--r2:24px;--sh:0 2px 20px rgba(17,28,21,0.08);--sh2:0 8px 40px rgba(17,28,21,0.14);
}
html{scroll-behavior:smooth;font-family:var(--sans);background:var(--cream);color:var(--text);font-size:16px;-webkit-text-size-adjust:100%}
body{overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
:focus-visible{outline:2px solid var(--g3);outline-offset:2px;border-radius:4px}

/* === TOPBAR === */
.topbar{background:var(--g1);color:rgba(255,255,255,0.75);font-size:12.5px;padding:8px 5%;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar span{display:flex;align-items:center;gap:6px}
.topbar a{color:var(--gold2);font-weight:500}
.iso-badge{background:var(--gold);color:var(--dark);font-size:10px;font-weight:600;padding:3px 10px;border-radius:50px;letter-spacing:0.5px}

/* === NAV === */
nav{background:rgba(249,248,244,0.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:900;transition:box-shadow .3s}
nav.up{box-shadow:var(--sh)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:0 5%;height:76px;max-width:1400px;margin:0 auto}
.logo{display:flex;align-items:center;gap:14px;cursor:pointer}
.logo-icon{width:48px;height:48px;flex-shrink:0}
.logo-name{font-family:var(--serif);font-size:22px;color:var(--g1);line-height:1.1}
.logo-tag{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase}
.nav-menu{display:flex;align-items:center;gap:4px;list-style:none}
.nav-menu li a{font-size:13.5px;font-weight:500;color:var(--text);padding:8px 14px;border-radius:8px;display:block;transition:all .2s;letter-spacing:0.2px}
.nav-menu li a:hover,.nav-menu li a.active{color:var(--g2);background:var(--g6)}
.nav-cta{background:var(--g2)!important;color:#fff!important;border-radius:50px!important;padding:10px 22px!important;transition:background .2s!important}
.nav-cta:hover{background:var(--g1)!important}
.nav-actions{display:flex;align-items:center;gap:12px}
.cart-btn{position:relative;background:var(--g6);border:none;width:42px;height:42px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}
.cart-btn:hover{background:var(--g5)}
.cart-count{position:absolute;top:-4px;right:-4px;background:var(--gold);color:var(--dark);font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.nav-toggle{display:none;background:var(--g6);border:none;width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:20px;align-items:center;justify-content:center;color:var(--g1)}

/* === PAGE ROUTER === */
.page{display:none}
.page.active{display:block}

/* === HERO === */
.hero{min-height:91vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:60px 5% 60px;gap:60px;background:linear-gradient(140deg,#EEF7F1 0%,#F9F8F4 50%,#FBF6E8 100%);position:relative;overflow:hidden;max-width:100%}
.hero::before{content:'';position:absolute;right:-100px;top:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(82,183,136,0.08),transparent 70%);pointer-events:none}
.hero::after{content:'';position:absolute;left:-80px;bottom:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(201,168,76,0.07),transparent 70%);pointer-events:none}
.hero-left{z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:var(--g6);color:var(--g2);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:7px 18px;border-radius:50px;margin-bottom:28px;border:1px solid rgba(64,145,108,0.25)}
.hero-pill::before{content:'';width:7px;height:7px;background:var(--g4);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.hero h1{font-family:var(--serif);font-size:clamp(44px,5.5vw,78px);color:var(--dark);line-height:1.05;font-weight:400;margin-bottom:22px}
.hero h1 em{color:var(--g3);font-style:italic}
.hero h1 span{display:block;font-size:0.55em;font-family:var(--sans);font-weight:300;color:var(--muted);letter-spacing:3px;text-transform:uppercase;margin-bottom:6px}
.hero-desc{font-size:16.5px;color:var(--muted);line-height:1.75;max-width:500px;font-weight:300;margin-bottom:40px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:52px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 34px;border-radius:50px;font-size:14.5px;font-weight:600;transition:all .3s;cursor:pointer;border:none;font-family:var(--sans);letter-spacing:0.3px}
.btn-green{background:var(--g2);color:#fff;box-shadow:0 6px 24px rgba(45,106,79,0.3)}
.btn-green:hover{background:var(--g1);transform:translateY(-2px);box-shadow:0 10px 32px rgba(45,106,79,0.35)}
.btn-ghost{background:transparent;color:var(--g2);border:1.5px solid var(--g3)}
.btn-ghost:hover{background:var(--g6)}
.hero-stats{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;background:white;box-shadow:var(--sh)}
.stat{padding:18px 28px;flex:1;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-n{font-family:var(--serif);font-size:36px;color:var(--g2);font-weight:500}
.stat-l{font-size:11.5px;color:var(--muted);margin-top:2px;font-weight:400;letter-spacing:0.3px}
.hero-right{position:relative;z-index:1}
.hero-card-main{background:#fff;border-radius:var(--r2);padding:36px;box-shadow:var(--sh2);border:1px solid var(--border);position:relative}
.hc-badge{position:absolute;top:-14px;left:28px;background:var(--gold);color:var(--dark);font-size:11px;font-weight:700;padding:6px 18px;border-radius:50px;letter-spacing:0.5px}
.doc-ava{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--g5),var(--g4));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:26px;color:var(--g1);font-weight:700;margin-bottom:14px}
.hero-card-main h3{font-family:var(--serif);font-size:22px;color:var(--dark)}
.hero-card-main p{font-size:13px;color:var(--muted);margin:4px 0 18px}
.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.tag{background:var(--g6);color:var(--g2);font-size:11px;font-weight:600;padding:4px 12px;border-radius:50px}
.avail{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text)}
.avail-dot{width:9px;height:9px;background:#34D399;border-radius:50%;box-shadow:0 0 0 3px rgba(52,211,153,0.2);animation:blink 2s infinite}
.float-card{position:absolute;background:#fff;border-radius:var(--r);padding:14px 18px;box-shadow:var(--sh2);border:1px solid var(--border);display:flex;align-items:center;gap:12px}
.float-card.f1{top:-28px;right:-20px}
.float-card.f2{bottom:-24px;left:-16px}
.fc-icon{font-size:26px}
.fc-title{font-size:12.5px;font-weight:600;color:var(--dark)}
.fc-sub{font-size:11px;color:var(--muted)}

/* === SECTIONS === */
section{padding:90px 5%;max-width:100%}
.sec-inner{max-width:1280px;margin:0 auto}
.sec-tag{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--g3);margin-bottom:10px;display:block}
.sec-h{font-family:var(--serif);font-size:clamp(30px,4vw,52px);color:var(--dark);font-weight:400;line-height:1.1}
.sec-h em{color:var(--g3);font-style:italic}
.sec-p{font-size:16px;color:var(--muted);line-height:1.75;font-weight:300;max-width:580px;margin-top:14px}
.sec-head{margin-bottom:56px}

/* === MARQUEE BAND === */
.band{background:var(--g1);padding:16px 0;overflow:hidden}
.band-track{display:flex;gap:0;animation:marquee 25s linear infinite;white-space:nowrap;will-change:transform}
.band-item{display:flex;align-items:center;gap:10px;padding:0 40px;font-size:13px;font-weight:500;color:rgba(255,255,255,0.8);flex-shrink:0}
.band-dot{width:5px;height:5px;background:var(--gold2);border-radius:50%}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* === ABOUT === */
.about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img-box{position:relative}
.about-img{width:100%;aspect-ratio:4/5;background:linear-gradient(160deg,var(--g5),var(--g4));border-radius:var(--r2);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--g1);font-size:14px;font-family:var(--serif)}
.about-float1{position:absolute;bottom:-24px;right:-24px;background:#fff;border-radius:var(--r);padding:20px 24px;box-shadow:var(--sh2);border:1px solid var(--border);text-align:center}
.about-float1 .n{font-family:var(--serif);font-size:36px;color:var(--gold);font-weight:500}
.about-float1 .l{font-size:11px;color:var(--muted);margin-top:2px}
.about-text p{font-size:15.5px;color:var(--muted);line-height:1.85;font-weight:300;margin-bottom:18px}
.qual-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.qual-item{background:var(--cream);border-radius:var(--r);padding:16px 18px;border:1px solid var(--border);display:flex;gap:12px;align-items:flex-start}
.qi-icon{width:38px;height:38px;background:var(--g6);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.qi-t{font-size:13.5px;font-weight:600;color:var(--dark)}
.qi-s{font-size:11.5px;color:var(--muted);margin-top:2px}

/* === SERVICES === */
.srv-bg{background:var(--cream)}
.srv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.srv-card{background:#fff;border-radius:var(--r2);padding:30px;border:1px solid var(--border);transition:all .3s;cursor:pointer;position:relative;overflow:hidden}
.srv-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--g3),var(--g4));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.srv-card:hover{transform:translateY(-5px);box-shadow:var(--sh2)}
.srv-card:hover::after{transform:scaleX(1)}
.srv-ic{width:56px;height:56px;background:var(--g6);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:22px}
.srv-card h3{font-family:var(--serif);font-size:19px;color:var(--dark);margin-bottom:10px}
.srv-card p{font-size:13.5px;color:var(--muted);line-height:1.65;font-weight:300}
.srv-link{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-size:13px;font-weight:600;color:var(--g3)}
.srv-link:hover{gap:10px}

/* === HOW IT WORKS === */
.how-bg{background:var(--dark);color:#fff}
.how-bg .sec-tag{color:var(--g4)}
.how-bg .sec-h{color:#fff}
.how-bg .sec-p{color:rgba(255,255,255,0.45)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative}
.steps::before{content:'';position:absolute;top:52px;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,rgba(82,183,136,0.4),transparent);z-index:0}
.step{text-align:center;z-index:1}
.step-ring{width:68px;height:68px;border-radius:50%;border:1.5px solid rgba(82,183,136,0.4);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;font-size:28px;background:rgba(82,183,136,0.08);transition:all .3s}
.step:hover .step-ring{background:rgba(82,183,136,0.2);border-color:var(--g4)}
.step-n{font-family:var(--serif);font-size:11px;color:var(--g4);margin-bottom:4px;letter-spacing:2px}
.step h4{font-family:var(--serif);font-size:17.5px;color:#fff;margin-bottom:10px}
.step p{font-size:13px;color:rgba(255,255,255,0.4);line-height:1.65;font-weight:300}

/* === TREATMENTS SHOWCASE === */
.treat-grid{display:grid;grid-template-columns:1fr 2fr;gap:32px}
.treat-list{display:flex;flex-direction:column;gap:10px}
.treat-tab{padding:16px 20px;border-radius:var(--r);border:1px solid var(--border);cursor:pointer;font-size:14.5px;font-weight:500;transition:all .2s;background:#fff;text-align:left;font-family:var(--sans);display:flex;align-items:center;gap:10px}
.treat-tab:hover,.treat-tab.active{background:var(--g2);color:#fff;border-color:var(--g2)}
.treat-tab.active .tab-ic{filter:brightness(10)}
.tab-ic{font-size:18px;transition:filter .2s}
.treat-detail{background:#fff;border-radius:var(--r2);padding:44px;border:1px solid var(--border);box-shadow:var(--sh)}
.td-top{display:flex;align-items:center;gap:20px;margin-bottom:28px}
.td-icon{width:64px;height:64px;background:var(--g6);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:30px}
.td-name{font-family:var(--serif);font-size:28px;color:var(--dark)}
.td-sub{font-size:13px;color:var(--muted);margin-top:4px}
.td-desc{font-size:15px;color:var(--muted);line-height:1.8;font-weight:300;margin-bottom:28px}
.td-tags{display:flex;flex-wrap:wrap;gap:8px}
.td-tag{background:var(--g6);color:var(--g2);font-size:12px;font-weight:600;padding:5px 14px;border-radius:50px}

/* === ONLINE CONSULT === */
.oc-bg{background:linear-gradient(135deg,var(--g1) 0%,#0E3020 100%)}
.oc-wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:72px;align-items:center}
.oc-left .sec-tag{color:var(--g4)}
.oc-left .sec-h{color:#fff}
.oc-left .sec-p{color:rgba(255,255,255,0.5)}
.oc-features{margin-top:40px;display:flex;flex-direction:column;gap:20px}
.oc-feat{display:flex;gap:16px;align-items:flex-start}
.oc-feat-ic{width:46px;height:46px;background:rgba(82,183,136,0.2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.oc-feat-t{font-size:15px;font-weight:600;color:#fff}
.oc-feat-s{font-size:13px;color:rgba(255,255,255,0.45);margin-top:3px;font-weight:300}
.oc-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:var(--r2);padding:36px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.oc-card h3{font-family:var(--serif);font-size:24px;color:#fff;margin-bottom:24px}
.oc-input{width:100%;padding:14px 18px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:var(--r);font-size:14px;font-family:var(--sans);color:#fff;outline:none;margin-bottom:14px;transition:border .2s}
.oc-input::placeholder{color:rgba(255,255,255,0.35)}
.oc-input:focus{border-color:var(--g4)}
.oc-input option{color:var(--dark)}

/* === TESTIMONIALS === */
.testi-bg{background:var(--cream)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi-card{background:#fff;border-radius:var(--r2);padding:32px;border:1px solid var(--border);transition:box-shadow .3s}
.testi-card:hover{box-shadow:var(--sh2)}
.stars{color:var(--gold);font-size:13px;margin-bottom:14px;letter-spacing:2px}
.qmark{font-family:var(--serif);font-size:72px;color:var(--g6);line-height:0.4;margin-bottom:18px}
.testi-text{font-size:14.5px;color:var(--text);line-height:1.75;font-weight:300;font-style:italic;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-ava{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--g5),var(--g4));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;font-weight:700;color:var(--g1)}
.ta-name{font-weight:600;font-size:14px;color:var(--dark)}
.ta-loc{font-size:11.5px;color:var(--muted);margin-top:2px}

/* === BEFORE/AFTER === */
.ba-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ba-card{border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;background:linear-gradient(180deg,var(--g5),var(--g3));display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:transform .3s}
.ba-card:hover{transform:scale(1.03)}
.ba-card span{font-size:12px;font-weight:600;color:rgba(255,255,255,0.9)}
.ba-label{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,0.5);color:#fff;font-size:10.5px;padding:4px 12px;border-radius:50px;white-space:nowrap}

/* === SHOP PAGE === */
.shop-hero{background:linear-gradient(140deg,#EEF7F1,#FBF6E8);padding:60px 5% 50px;text-align:center}
.shop-hero .sec-h{text-align:center}
.shop-hero .sec-p{margin:14px auto 32px;text-align:center}
.shop-search{display:flex;gap:0;max-width:520px;margin:0 auto;background:#fff;border:1.5px solid var(--border);border-radius:50px;overflow:hidden;box-shadow:var(--sh)}
.shop-search input{flex:1;padding:14px 22px;border:none;outline:none;font-size:14px;font-family:var(--sans);background:transparent;color:var(--text)}
.shop-search button{padding:12px 28px;background:var(--g2);color:#fff;border:none;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--sans);transition:background .2s;border-radius:0 50px 50px 0}
.shop-search button:hover{background:var(--g1)}
.shop-wrap{display:grid;grid-template-columns:240px 1fr;gap:40px;padding:60px 5%;max-width:1400px;margin:0 auto}
.shop-filters{background:#fff;border-radius:var(--r2);padding:28px;border:1px solid var(--border);height:fit-content;position:sticky;top:100px}
.filter-title{font-weight:700;font-size:13px;color:var(--dark);margin-bottom:16px;text-transform:uppercase;letter-spacing:1px}
.filter-cat{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}
.fcat-btn{padding:10px 14px;border-radius:var(--r);border:none;background:transparent;text-align:left;font-size:13.5px;font-family:var(--sans);cursor:pointer;color:var(--muted);transition:all .2s;font-weight:400}
.fcat-btn:hover,.fcat-btn.active{background:var(--g6);color:var(--g2);font-weight:600}
.price-range{margin-bottom:24px}
.price-range input[type=range]{width:100%;accent-color:var(--g3)}
.price-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:4px}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px}
.prod-card{background:#fff;border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);transition:all .3s;cursor:pointer}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--sh2)}
.prod-img{background:linear-gradient(135deg,var(--g6),var(--g5));height:200px;display:flex;align-items:center;justify-content:center;font-size:56px;position:relative}
.prod-badge{position:absolute;top:12px;left:12px;background:var(--gold);color:var(--dark);font-size:10px;font-weight:700;padding:3px 10px;border-radius:50px}
.prod-rx{position:absolute;top:12px;right:12px;background:rgba(45,106,79,0.9);color:#fff;font-size:9.5px;font-weight:700;padding:3px 8px;border-radius:50px}
.prod-body{padding:18px 20px}
.prod-cat{font-size:10.5px;font-weight:700;color:var(--g3);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.prod-name{font-family:var(--serif);font-size:16.5px;color:var(--dark);margin-bottom:6px;line-height:1.3}
.prod-desc{font-size:12.5px;color:var(--muted);line-height:1.55;font-weight:300;margin-bottom:14px}
.prod-footer{display:flex;align-items:center;justify-content:space-between}
.prod-price{font-family:var(--serif);font-size:20px;color:var(--g2);font-weight:500}
.prod-price s{font-size:13px;color:var(--muted);font-family:var(--sans);font-weight:300;margin-left:6px}
.add-cart{background:var(--g2);color:#fff;border:none;border-radius:50px;padding:9px 18px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:all .2s;display:flex;align-items:center;gap:6px}
.add-cart:hover{background:var(--g1)}
.add-cart.added{background:#34D399;color:var(--dark)}

/* === CART DRAWER === */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;right:0;top:0;bottom:0;width:400px;max-width:100%;background:#fff;z-index:1001;transform:translateX(100%);transition:transform .35s ease;box-shadow:-8px 0 40px rgba(0,0,0,0.15);display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-header{padding:24px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cart-header h3{font-family:var(--serif);font-size:22px;color:var(--dark)}
.cart-close{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.cart-close:hover{background:var(--cream)}
.cart-items{flex:1;overflow-y:auto;padding:20px 28px}
.cart-empty{text-align:center;padding:60px 0;color:var(--muted)}
.cart-empty .ce-icon{font-size:56px;margin-bottom:14px}
.cart-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}
.ci-img{width:64px;height:64px;border-radius:10px;background:var(--g6);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}
.ci-info{flex:1}
.ci-name{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:4px}
.ci-price{font-size:13px;color:var(--g2);font-weight:600}
.ci-qty{display:flex;align-items:center;gap:10px;margin-top:8px}
.qty-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:var(--sans)}
.qty-btn:hover{background:var(--g6)}
.qty-n{font-size:14px;font-weight:600;color:var(--dark);min-width:20px;text-align:center}
.ci-remove{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;padding:4px;transition:color .2s}
.ci-remove:hover{color:#E24B4A}
.cart-footer{padding:24px 28px;border-top:1px solid var(--border)}
.cart-subtotal{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px;color:var(--muted)}
.cart-total{display:flex;justify-content:space-between;font-family:var(--serif);font-size:22px;color:var(--dark);margin-bottom:20px;font-weight:500}
.checkout-btn{width:100%;padding:16px;background:var(--g2);color:#fff;border:none;border-radius:50px;font-size:15px;font-weight:700;font-family:var(--sans);cursor:pointer;transition:all .3s}
.checkout-btn:hover{background:var(--g1)}
.cart-note{text-align:center;font-size:11.5px;color:var(--muted);margin-top:12px}

/* === APPOINTMENT PAGE === */
.appt-page{background:var(--cream)}
.appt-hero{background:linear-gradient(140deg,#EEF7F1,#F9F8F4);padding:60px 5% 50px}
.appt-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:72px;padding:64px 5%;max-width:1280px;margin:0 auto;align-items:start}
.appt-info .sec-p{max-width:420px}
.appt-feats{display:flex;flex-direction:column;gap:24px;margin-top:44px}
.af-item{display:flex;gap:16px;align-items:flex-start}
.af-ic{width:48px;height:48px;background:var(--g6);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.af-t{font-weight:600;font-size:15px;color:var(--dark)}
.af-s{font-size:13px;color:var(--muted);margin-top:3px;font-weight:300}
.form-wrap{background:#fff;border-radius:var(--r2);padding:44px;box-shadow:var(--sh2);border:1px solid var(--border)}
.form-wrap h3{font-family:var(--serif);font-size:26px;color:var(--dark);margin-bottom:30px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fg{margin-bottom:20px}
.fg label{display:block;font-size:11.5px;font-weight:700;color:var(--muted);margin-bottom:7px;letter-spacing:0.8px;text-transform:uppercase}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--r);font-size:14px;font-family:var(--sans);background:#fff;color:var(--text);transition:border .2s;outline:none;appearance:none;-webkit-appearance:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g3)}
.fg textarea{min-height:110px;resize:vertical}
.form-submit{width:100%;padding:16px;background:var(--g2);color:#fff;border:none;border-radius:50px;font-size:15px;font-weight:700;font-family:var(--sans);cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 6px 24px rgba(45,106,79,0.3)}
.form-submit:hover{background:var(--g1);transform:translateY(-1px)}
.form-note{text-align:center;font-size:12px;color:var(--muted);margin-top:12px}

/* === CONTACT PAGE === */
.contact-page-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:72px;padding:72px 5%;max-width:1280px;margin:0 auto;align-items:start}
.ct-item{display:flex;gap:16px;margin-bottom:32px}
.ct-ic{width:50px;height:50px;background:var(--g6);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.ct-t{font-weight:600;font-size:15px;color:var(--dark)}
.ct-v{font-size:14px;color:var(--muted);margin-top:4px;line-height:1.5}
.hours-box{background:var(--cream);border-radius:var(--r);padding:24px;border:1px solid var(--border);margin-top:8px}
.hr-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:13.5px}
.hr-row:last-child{border:none}
.hr-day{color:var(--muted)}
.hr-time{font-weight:500;color:var(--dark)}
.hr-closed{color:#E24B4A;font-weight:500}
.map-box{background:linear-gradient(135deg,var(--g6),var(--g5));border-radius:var(--r2);height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border:1px solid var(--border)}
.map-box .mp{font-size:48px}
.map-box .mt{font-family:var(--serif);font-size:22px;color:var(--g1)}
.map-box .ms{font-size:13px;color:var(--muted)}
.map-btn{margin-top:16px;background:var(--g2);color:#fff;padding:12px 28px;border-radius:50px;font-size:13px;font-weight:600;border:none;cursor:pointer;font-family:var(--sans);transition:background .2s}
.map-btn:hover{background:var(--g1)}

/* === FAQ === */
.faq-sec{background:#fff}
.faq-layout{display:grid;grid-template-columns:1fr 1fr;gap:72px}
.faq-item2{border-bottom:1px solid var(--border)}
.faq-q2{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;font-size:15.5px;font-family:var(--sans);font-weight:500;color:var(--dark);transition:color .2s;gap:16px}
.faq-q2:hover{color:var(--g3)}
.faq-ico{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;transition:all .3s;color:var(--g3)}
.faq-item2.open .faq-ico{background:var(--g2);color:#fff;border-color:var(--g2);transform:rotate(45deg)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-ans-in{padding:0 0 22px;font-size:14px;color:var(--muted);line-height:1.75;font-weight:300}
.faq-item2.open .faq-ans{max-height:240px}
.faq-side{background:linear-gradient(135deg,var(--g6),#EEF7F1);border-radius:var(--r2);padding:40px;border:1px solid rgba(64,145,108,0.15)}
.faq-side h3{font-family:var(--serif);font-size:26px;color:var(--dark);margin-bottom:12px}
.faq-side p{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:28px;font-weight:300}
.clinks{display:flex;flex-direction:column;gap:10px}
.clink{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border-radius:var(--r);text-decoration:none;border:1px solid var(--border);transition:all .2s;color:var(--text)}
.clink:hover{border-color:var(--g3);color:var(--g2);transform:translateX(4px)}
.clink-l{font-size:14px;font-weight:600}
.clink-s{font-size:12px;color:var(--muted)}

/* === GALLERY PAGE === */
.gallery-grid2{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:60px 5%;max-width:1280px;margin:0 auto}
.gal-item{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;position:relative;cursor:pointer;background:linear-gradient(135deg,var(--g5),var(--g3));display:flex;align-items:center;justify-content:center;transition:transform .3s}
.gal-item:hover{transform:scale(1.02)}
.gal-item:nth-child(3n+1){aspect-ratio:16/9;grid-column:span 2}
.gal-item:nth-child(6n){aspect-ratio:1;grid-column:span 1}
.gal-overlay{position:absolute;inset:0;background:rgba(17,28,21,0);transition:background .3s;display:flex;align-items:flex-end;padding:16px}
.gal-item:hover .gal-overlay{background:rgba(17,28,21,0.4)}
.gal-label{color:#fff;font-size:13px;font-weight:600;opacity:0;transform:translateY(8px);transition:all .3s}
.gal-item:hover .gal-label{opacity:1;transform:translateY(0)}

/* === SUCCESS TOAST === */
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--g1);color:#fff;padding:14px 28px;border-radius:50px;font-size:14px;font-weight:600;z-index:2000;transition:transform .4s ease;box-shadow:var(--sh2);display:flex;align-items:center;gap:10px;max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}

/* === FOOTER === */
footer{background:var(--dark);color:rgba(255,255,255,0.65);padding:72px 5% 40px}
.footer-inner{max-width:1280px;margin:0 auto}
.foot-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:56px;margin-bottom:56px}
.foot-brand p{font-size:14px;line-height:1.75;margin-top:16px;font-weight:300;max-width:290px}
.foot-logo{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.foot-logo-t{font-family:var(--serif);font-size:20px;color:#fff}
.foot-col h4{color:#fff;font-size:13.5px;font-weight:700;margin-bottom:20px;letter-spacing:0.5px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:12px}
.foot-col a{color:rgba(255,255,255,0.45);font-size:13.5px;transition:color .2s}
.foot-col a:hover{color:var(--g4)}
.foot-bot{border-top:1px solid rgba(255,255,255,0.08);padding-top:32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-bot p{font-size:12.5px}
.soc-links{display:flex;gap:10px}
.soc-link{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.4);font-size:13px;transition:all .2s;text-decoration:none}
.soc-link:hover{border-color:var(--g4);color:var(--g4)}

/* === WHATSAPP + BACKTOP === */
.wa-btn{position:fixed;bottom:32px;right:32px;z-index:800;width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(37,211,102,0.45);text-decoration:none;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.wa-btn:hover{animation:none;transform:scale(1.1)}
.wa-btn svg{width:30px;height:30px;fill:#fff}
.btt{position:fixed;bottom:104px;right:32px;z-index:800;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;color:var(--text);box-shadow:var(--sh);opacity:0;pointer-events:none;transition:all .3s}
.btt.vis{opacity:1;pointer-events:auto}
.btt:hover{background:var(--g2);color:#fff;border-color:var(--g2)}

/* === FADE ANIMS === */
.fu{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.fu.in{opacity:1;transform:translateY(0)}
.fd1{transition-delay:.1s}.fd2{transition-delay:.2s}.fd3{transition-delay:.3s}

/* === RESPONSIVE === */
@media(max-width:900px){
  .hero,.about-wrap,.oc-wrap,.appt-grid,.contact-page-grid,.faq-layout,.treat-grid,.foot-grid{grid-template-columns:1fr;gap:40px}
  .steps{grid-template-columns:1fr 1fr}
  .steps::before{display:none}
  .testi-grid{grid-template-columns:1fr 1fr}
  .ba-grid{grid-template-columns:1fr 1fr}
  .gallery-grid2{grid-template-columns:1fr 1fr}
  .gal-item:nth-child(3n+1){grid-column:span 1;aspect-ratio:4/3}
  .hero-right{display:none}
  .shop-wrap{grid-template-columns:1fr}
  .shop-filters{position:static}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:span 2}
  .frow{grid-template-columns:1fr}
  .qual-grid{grid-template-columns:1fr}
  section{padding:64px 5%}
}
@media(max-width:600px){
  .testi-grid,.ba-grid,.steps{grid-template-columns:1fr}
  .hero-stats{flex-direction:column}
  .stat{border-right:none;border-bottom:1px solid var(--border)}
  .stat:last-child{border:none}
  .nav-menu{position:fixed;top:76px;left:0;right:0;background:var(--cream);flex-direction:column;align-items:stretch;gap:0;padding:8px 5% 20px;border-bottom:1px solid var(--border);box-shadow:var(--sh);transform:translateY(-130%);transition:transform .3s ease;z-index:899}
  .nav-menu.open{transform:translateY(0)}
  .nav-menu li a{padding:14px 10px;border-radius:0;border-bottom:1px solid var(--border)}
  .nav-cta{text-align:center;margin-top:8px;border-radius:50px!important}
  .nav-toggle{display:flex}
  .cart-drawer{width:100%}
  .gallery-grid2{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .foot-brand{grid-column:span 1}
  .foot-bot{flex-direction:column;text-align:center}
  .wa-btn{bottom:20px;right:20px;width:52px;height:52px}
  .btt{bottom:84px;right:20px}
  .topbar{justify-content:center;font-size:11.5px}
}

/* === REDUCED MOTION === */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .fu{opacity:1;transform:none}
}
