/* ============================================================
   GlowUp Beauty & Salon — style.css
   EverGreen Theme: Forest Green + Gold + Ivory
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Jost:wght@300;400;500;600;700&display=swap');

:root {
  --green:          #1a472a;
  --green-mid:      #2d6a4f;
  --green-light:    #40916c;
  --green-bright:   #52b788;
  --green-pale:     #d8f3dc;
  --green-xpale:    #f0faf2;
  --green-dark:     #0d2818;
  --green-deep:     #081c10;
  --gold:           #c9a84c;
  --gold-light:     #e8c46a;
  --gold-pale:      #fdf5e0;
  --gold-dark:      #9c7a2e;
  --ivory:          #faf7f2;
  --ivory-dark:     #f0ebe0;
  --cream:          #f5f0e8;
  --dark:           #0d2818;
  --dark-2:         #1a3d28;
  --text:           #1a2e1f;
  --muted:          #5a7a60;
  --border:         #c8dfc8;
  --border-light:   #e2f0e2;
  --white:          #ffffff;
  --body-bg:        #faf7f2;
  --radius:         12px;
  --radius-lg:      20px;
  --radius-xl:      28px;
  --shadow:         0 4px 24px rgba(26,71,42,.10);
  --shadow-lg:      0 12px 48px rgba(26,71,42,.18);
  --shadow-green:   0 8px 32px rgba(26,71,42,.28);
  --shadow-gold:    0 8px 32px rgba(201,168,76,.30);
  --transition:     all .28s cubic-bezier(.4,0,.2,1);
  --navbar-h:       70px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--body-bg);color:var(--text);font-size:15px;line-height:1.7;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:var(--transition)}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--green-xpale)}
::-webkit-scrollbar-thumb{background:var(--green-light);border-radius:3px}
.display-font{font-family:'Cormorant Garamond',serif}
h1,h2,h3{font-family:'Cormorant Garamond',serif;line-height:1.15}
h4,h5,h6{font-family:'Jost',sans-serif}

/* LOADER */
#pageLoader{position:fixed;inset:0;background:var(--green-deep);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;transition:opacity .5s ease,visibility .5s ease}
#pageLoader.hidden{opacity:0;visibility:hidden}
.loader-logo{font-family:'Cormorant Garamond',serif;font-size:2rem;color:#fff;letter-spacing:2px}
.loader-logo span{color:var(--gold-light)}
.loader-bar{width:160px;height:3px;background:rgba(255,255,255,.15);border-radius:3px;overflow:hidden}
.loader-bar-fill{height:100%;background:linear-gradient(90deg,var(--green-bright),var(--gold));border-radius:3px;animation:loaderAnim 1.2s ease forwards}
@keyframes loaderAnim{from{width:0}to{width:100%}}

/* TOPBAR */
.topbar{background:var(--green-deep);color:rgba(255,255,255,.70);font-size:.78rem;padding:8px 0;letter-spacing:.3px}
.topbar a{color:rgba(255,255,255,.70)}
.topbar a:hover{color:var(--gold-light)}
.topbar-divider{margin:0 14px;opacity:.25}
.topbar i{color:var(--gold-light)}

/* NAVBAR */
.main-navbar{background:#fff;border-bottom:2px solid var(--border-light);height:var(--navbar-h);position:sticky;top:0;z-index:1000;transition:box-shadow .3s ease}
.main-navbar.scrolled{box-shadow:0 4px 24px rgba(26,71,42,.12)}

.brand-logo{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:700;color:var(--green);white-space:nowrap;display:flex;align-items:center;gap:10px}
.brand-logo .logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--green),var(--green-light));border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.05rem}
.brand-logo span{color:var(--gold)}

.nav-link-custom{font-size:.88rem;font-weight:600;color:var(--text)!important;padding:8px 14px!important;border-radius:8px;transition:var(--transition);position:relative;letter-spacing:.2px;white-space:nowrap}
.nav-link-custom::after{content:'';position:absolute;bottom:4px;left:50%;right:50%;height:2px;background:var(--green-light);border-radius:2px;transition:all .25s ease}
.nav-link-custom:hover{color:var(--green)!important;background:var(--green-xpale)}
.nav-link-custom:hover::after,.nav-link-custom.active::after{left:14px;right:14px}
.nav-link-custom.active{color:var(--green)!important;font-weight:700;background:var(--green-xpale)}

/* MEGA DROPDOWN */
.dropdown-mega{position:static!important}
.dropdown-mega-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border-top:3px solid var(--green-light);border-bottom:1px solid var(--border-light);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg);padding:28px 0;display:none;z-index:999;animation:dropDown .2s ease}
@keyframes dropDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.dropdown-mega:hover .dropdown-mega-menu{display:block}
.mega-col-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:12px}
.mega-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);font-size:.88rem;font-weight:500;color:var(--text);transition:var(--transition);margin-bottom:2px}
.mega-link:hover{background:var(--green-xpale);color:var(--green)}
.mega-link i{color:var(--green-light);font-size:.85rem;width:16px}

.nav-icon-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text);font-size:1rem;transition:var(--transition);position:relative;border:none;background:transparent;cursor:pointer}
.nav-icon-btn:hover{background:var(--green-xpale);color:var(--green)}
.cart-count{position:absolute;top:4px;right:4px;width:18px;height:18px;background:var(--green-light);color:#fff;font-size:.6rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}

.nav-search{display:flex;align-items:center;background:var(--green-xpale);border:2px solid var(--border);border-radius:50px;overflow:hidden;transition:var(--transition)}
.nav-search:focus-within{border-color:var(--green-light);background:#fff}
.nav-search input{border:none;background:transparent;padding:8px 16px;font-size:.87rem;outline:none;width:200px;font-family:'Jost',sans-serif;color:var(--text)}
.nav-search button{background:var(--green);border:none;color:#fff;padding:8px 16px;cursor:pointer;font-size:.85rem;transition:var(--transition)}
.nav-search button:hover{background:var(--green-mid)}

/* SECTION */
.section-pad{padding:90px 0}
.section-pad-sm{padding:60px 0}
.section-pad-xs{padding:40px 0}
.section-label{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--green-light);padding:6px 16px;background:var(--green-pale);border-radius:50px;margin-bottom:14px}
.section-title{font-size:clamp(2rem,4vw,3rem);color:var(--green-dark);margin-bottom:16px}
.section-sub{font-size:1.05rem;color:var(--muted);max-width:560px;line-height:1.7}

/* BUTTONS */
.btn-green,.btn-pink{background:linear-gradient(135deg,var(--green),var(--green-mid));color:#fff!important;border:none;padding:13px 32px;border-radius:50px;font-size:.92rem;font-weight:600;letter-spacing:.3px;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);cursor:pointer;box-shadow:var(--shadow-green)}
.btn-green:hover,.btn-pink:hover{transform:translateY(-2px);filter:brightness(1.1)}
.btn-outline-green,.btn-outline-pink{background:transparent;color:var(--green);border:2px solid var(--green);padding:11px 28px;border-radius:50px;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:var(--transition);cursor:pointer}
.btn-outline-green:hover,.btn-outline-pink:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#fff!important;border:none;padding:13px 32px;border-radius:50px;font-size:.92rem;font-weight:700;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);box-shadow:var(--shadow-gold)}
.btn-gold:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-dark{background:var(--green-dark);color:#fff;padding:13px 32px;border-radius:50px;font-size:.92rem;font-weight:600;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);border:none;cursor:pointer}
.btn-dark:hover{background:var(--green);transform:translateY(-2px)}

/* HERO */
.hero-section{position:relative;overflow:hidden}
.hero-slide{min-height:88vh;display:flex;align-items:center;background-size:cover;background-position:center;position:relative}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(13,40,24,.88) 0%,rgba(13,40,24,.55) 50%,rgba(13,40,24,.20) 100%)}
.hero-content{position:relative;z-index:2;max-width:640px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(82,183,136,.18);border:1px solid rgba(82,183,136,.45);color:var(--green-bright);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;padding:8px 18px;border-radius:50px;margin-bottom:20px}
.hero-title{font-size:clamp(2.6rem,6vw,4.8rem);color:#fff;line-height:1.08;margin-bottom:22px;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.hero-title em{color:var(--gold-light);font-style:italic}
.hero-subtitle{font-size:1.1rem;color:rgba(255,255,255,.8);margin-bottom:36px;line-height:1.7}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-badge{position:absolute;right:60px;bottom:60px;background:rgba(255,255,255,.10);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.20);border-radius:var(--radius-lg);padding:20px 28px;color:#fff;text-align:center;z-index:2}
.hero-badge .num{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;line-height:1;color:var(--gold-light)}
.hero-badge .txt{font-size:.75rem;opacity:.7;letter-spacing:1px;text-transform:uppercase;margin-top:4px}
.carousel-control-prev,.carousel-control-next{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);top:50%;transform:translateY(-50%);opacity:1}
.carousel-control-prev{left:30px}
.carousel-control-next{right:30px}
.carousel-control-prev:hover,.carousel-control-next:hover{background:var(--green-light)}

/* FEATURES BAR */
.features-bar{background:var(--green-dark);padding:0}
.feature-item{display:flex;align-items:center;gap:14px;padding:22px 24px;border-right:1px solid rgba(255,255,255,.07)}
.feature-item:last-child{border-right:none}
.feature-icon{width:44px;height:44px;border-radius:11px;background:rgba(82,183,136,.18);display:flex;align-items:center;justify-content:center;color:var(--green-bright);font-size:1.1rem;flex-shrink:0}
.feature-item strong{display:block;color:#fff;font-size:.9rem;font-weight:600}
.feature-item span{color:rgba(255,255,255,.40);font-size:.76rem}

/* CATEGORY CARDS */
.cat-card{border-radius:var(--radius-lg);overflow:hidden;position:relative;cursor:pointer;transition:var(--transition);aspect-ratio:4/5}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cat-card:hover img{transform:scale(1.07)}
.cat-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,40,24,.90) 0%,rgba(13,40,24,.20) 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:22px 20px}
.cat-card-name{color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;margin-bottom:4px}
.cat-card-count{color:rgba(255,255,255,.55);font-size:.78rem;margin-bottom:14px}
.cat-card-btn{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);color:#fff;padding:8px 18px;border-radius:50px;font-size:.82rem;font-weight:600;transform:translateY(8px);opacity:0;transition:var(--transition)}
.cat-card:hover .cat-card-btn{transform:translateY(0);opacity:1}

/* PRODUCT CARDS */
.product-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);border:1px solid var(--border-light);display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.product-img-wrap{position:relative;overflow:hidden;aspect-ratio:1}
.product-img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.product-card:hover .product-img{transform:scale(1.06)}
.product-badge{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge-sale{background:var(--green-light);color:#fff}
.badge-new{background:var(--gold);color:#fff}
.badge-best{background:var(--green-dark);color:#fff}
.product-actions{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:7px;transform:translateX(50px);opacity:0;transition:var(--transition)}
.product-card:hover .product-actions{transform:translateX(0);opacity:1}
.action-btn{width:36px;height:36px;border-radius:50%;background:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text);transition:var(--transition);box-shadow:0 2px 12px rgba(0,0,0,.1)}
.action-btn:hover{background:var(--green);color:#fff;transform:scale(1.1)}
.action-btn.wishlisted{background:var(--green);color:#fff}
.product-body{padding:16px;flex:1;display:flex;flex-direction:column}
.product-brand{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.product-name{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:10px;line-height:1.4}
.product-name a{color:inherit}
.product-name a:hover{color:var(--green)}
.product-rating{display:flex;align-items:center;gap:5px;margin-bottom:12px}
.stars{color:var(--gold);font-size:.78rem}
.rating-count{font-size:.76rem;color:var(--muted)}
.product-price{display:flex;align-items:center;gap:10px;margin-bottom:14px;margin-top:auto;flex-wrap:wrap}
.price-current{font-size:1.15rem;font-weight:700;color:var(--green)}
.price-original{font-size:.9rem;color:var(--muted);text-decoration:line-through}
.price-save{font-size:.75rem;background:var(--green-pale);color:var(--green);padding:2px 8px;border-radius:50px;font-weight:600}
.btn-add-cart{width:100%;background:var(--green-dark);color:#fff;border:none;padding:11px;border-radius:var(--radius);font-size:.88rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition)}
.btn-add-cart:hover{background:var(--green)}
.btn-add-cart.added{background:var(--green-mid)}

/* SERVICE CARDS */
.service-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light);transition:var(--transition);overflow:hidden;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--green-bright)}
.service-img-wrap{position:relative;overflow:hidden;aspect-ratio:16/10}
.service-img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.service-card:hover .service-img{transform:scale(1.05)}
.service-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,40,24,.72) 0%,transparent 60%)}
.service-cat-chip{position:absolute;top:14px;left:14px;background:var(--green);color:#fff;padding:5px 14px;border-radius:50px;font-size:.72rem;font-weight:600}
.service-duration{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);color:#fff;padding:5px 12px;border-radius:50px;font-size:.75rem;display:flex;align-items:center;gap:5px}
.service-body{padding:20px;flex:1;display:flex;flex-direction:column}
.service-icon-circle{width:48px;height:48px;border-radius:12px;background:var(--green-pale);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:14px}
.service-title{font-size:1.1rem;font-weight:700;color:var(--green-dark);margin-bottom:8px}
.service-desc{font-size:.86rem;color:var(--muted);line-height:1.6;margin-bottom:16px;flex:1}
.service-includes{list-style:none;padding:0;margin-bottom:18px}
.service-includes li{font-size:.82rem;color:var(--text);padding:4px 0;display:flex;align-items:center;gap:8px}
.service-includes li i{color:var(--green-light);font-size:.75rem}
.service-price-row{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border-light);margin-top:auto}
.service-price{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--green)}
.service-price small{font-family:'Jost',sans-serif;font-size:.75rem;color:var(--muted);font-weight:400;display:block}
.btn-book{background:linear-gradient(135deg,var(--green),var(--green-light));color:#fff;border:none;padding:10px 20px;border-radius:50px;font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px;transition:var(--transition)}
.btn-book:hover{transform:translateY(-2px);box-shadow:var(--shadow-green)}

/* FILTER PILLS */
.service-cat-pill{padding:9px 22px;border-radius:50px;border:2px solid var(--border);background:#fff;font-size:.88rem;font-weight:600;cursor:pointer;transition:var(--transition);color:var(--text)}
.service-cat-pill:hover,.service-cat-pill.active{background:var(--green);color:#fff;border-color:var(--green)}

/* TESTIMONIALS */
.testimonial-card{background:#fff;border-radius:var(--radius-xl);padding:32px;border:1px solid var(--border-light);transition:var(--transition);position:relative}
.testimonial-card::before{content:'\201C';font-family:'Cormorant Garamond',serif;font-size:5rem;color:var(--green-pale);position:absolute;top:10px;left:24px;line-height:1;pointer-events:none}
.testimonial-card:hover{border-color:var(--green-bright);box-shadow:var(--shadow)}
.testimonial-stars{color:var(--gold);font-size:.85rem;margin-bottom:14px}
.testimonial-text{font-size:.96rem;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;flex-shrink:0}
.author-name{font-weight:700;font-size:.92rem}
.author-role{font-size:.78rem;color:var(--muted)}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.gallery-item{aspect-ratio:1;overflow:hidden;border-radius:8px;position:relative;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-overlay{position:absolute;inset:0;background:rgba(26,71,42,.65);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;opacity:0;transition:var(--transition)}
.gallery-item:hover .gallery-overlay{opacity:1}

/* PROMO BANNER */
.promo-banner{background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 50%,var(--green-dark) 100%);padding:60px 0;position:relative;overflow:hidden}
.promo-banner::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%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2352b788' fill-opacity='0.08'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.promo-banner .section-label{background:rgba(82,183,136,.2);color:var(--green-bright)}
.promo-title{font-size:clamp(1.8rem,4vw,3rem);color:#fff;margin-bottom:14px}
.promo-sub{color:rgba(255,255,255,.7);font-size:1rem;margin-bottom:28px}
.promo-code{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.10);border:2px dashed rgba(201,168,76,.6);padding:10px 22px;border-radius:var(--radius);cursor:pointer;transition:var(--transition);color:#fff;font-weight:600}
.promo-code:hover{background:rgba(201,168,76,.2)}
.promo-code-text{font-size:1.1rem;letter-spacing:2px;color:var(--gold-light)}

/* CART SIDEBAR */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1100;opacity:0;visibility:hidden;transition:var(--transition)}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-sidebar{position:fixed;top:0;right:-440px;bottom:0;width:420px;background:#fff;z-index:1101;display:flex;flex-direction:column;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.15)}
.cart-sidebar.open{right:0}
.cart-header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.cart-header h5{font-size:1.1rem;font-weight:700;margin:0;color:var(--green-dark)}
.cart-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--muted);padding:4px}
.cart-close:hover{color:var(--green)}
.cart-body{flex:1;overflow-y:auto;padding:20px 24px}
.cart-empty{text-align:center;padding:60px 20px;color:var(--muted)}
.cart-empty i{font-size:3rem;margin-bottom:14px;color:var(--green-light)}
.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-light)}
.cart-item-img{width:70px;height:70px;border-radius:10px;object-fit:cover;flex-shrink:0;background:var(--green-xpale)}
.cart-item-body{flex:1;min-width:0}
.cart-item-name{font-weight:600;font-size:.9rem;margin-bottom:4px;color:var(--green-dark)}
.cart-item-brand{font-size:.75rem;color:var(--muted);margin-bottom:10px}
.cart-item-price{font-weight:700;color:var(--green);font-size:.95rem}
.qty-control{display:flex;align-items:center;gap:10px}
.qty-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.qty-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}
.qty-num{font-weight:600;min-width:24px;text-align:center}
.cart-item-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;padding:4px;transition:var(--transition)}
.cart-item-remove:hover{color:#dc3545}
.cart-footer{padding:20px 24px;border-top:1px solid var(--border-light)}
.cart-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cart-subtotal .label{font-size:.9rem;color:var(--muted)}
.cart-subtotal .amount{font-size:1.2rem;font-weight:700;color:var(--green)}

/* AUTH */
.auth-page{min-height:100vh;display:flex;align-items:center;background:var(--cream);padding:40px 0}
.auth-card{background:#fff;border-radius:var(--radius-xl);padding:48px 44px;box-shadow:var(--shadow-lg);max-width:480px;width:100%}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-logo .logo-icon{margin:0 auto 14px;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--green),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff}
.auth-title{font-size:1.7rem;text-align:center;color:var(--green-dark);margin-bottom:6px}
.auth-sub{text-align:center;color:var(--muted);font-size:.88rem}
.form-group{margin-bottom:20px}
.form-label{font-size:.83rem;font-weight:600;color:var(--text);margin-bottom:7px;display:block}
.form-input{width:100%;border:2px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:.92rem;color:var(--text);transition:var(--transition);background:#fff;font-family:'Jost',sans-serif}
.form-input:focus{border-color:var(--green-light);box-shadow:0 0 0 .2rem rgba(64,145,108,.15);outline:none}
.input-icon-wrap{position:relative}
.input-icon-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--green-light);font-size:.9rem}
.input-icon-wrap .form-input{padding-left:42px}
.input-icon-wrap .eye-btn{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted)}
.divider-text{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.82rem;margin:20px 0}
.divider-text::before,.divider-text::after{content:'';flex:1;height:1px;background:var(--border)}

/* SHOP */
.shop-header{background:linear-gradient(135deg,var(--green-dark),var(--green));padding:60px 0}
.shop-header h1{color:#fff;font-size:clamp(2rem,5vw,3.5rem)}
.breadcrumb-custom{display:flex;align-items:center;gap:8px;font-size:.84rem;color:rgba(255,255,255,.6);flex-wrap:wrap}
.breadcrumb-custom a{color:rgba(255,255,255,.7)}
.breadcrumb-custom a:hover{color:var(--gold-light)}
.breadcrumb-sep{color:rgba(255,255,255,.3)}
.filter-sidebar{background:#fff;border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border-light);position:sticky;top:90px}
.filter-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:14px}
.filter-option{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer}
.filter-option input{accent-color:var(--green);width:16px;height:16px}
.filter-option label{font-size:.88rem;cursor:pointer;flex:1}
.filter-divider{height:1px;background:var(--border-light);margin:18px 0}
.price-range-labels{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);margin-top:10px}
input[type=range]{width:100%;accent-color:var(--green)}
.sort-bar{background:#fff;border-radius:var(--radius);padding:14px 20px;border:1px solid var(--border-light);display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.sort-bar select{border:1px solid var(--border);border-radius:8px;padding:7px 14px;font-size:.87rem;color:var(--text);outline:none;cursor:pointer;font-family:'Jost',sans-serif}
.view-toggle{display:flex;gap:4px}
.view-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--muted);transition:var(--transition)}
.view-btn.active,.view-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* PRODUCT DETAIL */
.product-gallery-main{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:1;background:var(--cream)}
.product-gallery-main img{width:100%;height:100%;object-fit:cover}
.product-thumbs{display:flex;gap:10px;margin-top:12px}
.thumb-item{width:80px;height:80px;border-radius:10px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:var(--transition);flex-shrink:0}
.thumb-item:hover,.thumb-item.active{border-color:var(--green-light)}
.thumb-item img{width:100%;height:100%;object-fit:cover}
.product-detail-title{font-size:clamp(1.6rem,3vw,2.4rem);color:var(--green-dark);margin-bottom:10px}
.product-meta-row{display:flex;align-items:center;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.product-detail-price .price-now{font-size:2rem;font-weight:700;color:var(--green)}
.product-detail-price .price-was{font-size:1.1rem;color:var(--muted);text-decoration:line-through}
.product-detail-price .price-save-badge{background:var(--green-pale);color:var(--green);padding:4px 14px;border-radius:50px;font-size:.85rem;font-weight:600}
.quantity-selector{display:flex;align-items:center;gap:0;border:2px solid var(--border);border-radius:var(--radius);overflow:hidden;width:fit-content}
.qty-dec,.qty-inc{width:44px;height:48px;border:none;background:var(--cream);cursor:pointer;font-size:1rem;color:var(--text);transition:var(--transition)}
.qty-dec:hover,.qty-inc:hover{background:var(--green);color:#fff}
.qty-input{width:56px;height:48px;border:none;border-left:2px solid var(--border);border-right:2px solid var(--border);text-align:center;font-size:1rem;font-weight:600;font-family:'Jost',sans-serif;outline:none}
.tab-btn{padding:10px 24px;border:none;background:transparent;font-size:.9rem;font-weight:500;color:var(--muted);border-bottom:3px solid transparent;cursor:pointer;transition:var(--transition)}
.tab-btn.active{color:var(--green);border-bottom-color:var(--green);font-weight:600}
.tab-content-panel{display:none}
.tab-content-panel.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* SERVICE DETAIL */
.service-detail-img{border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;height:400px}
.service-detail-img img{width:100%;height:100%;object-fit:cover}
.booking-card{background:#fff;border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light);position:sticky;top:90px}
.booking-card-title{font-size:1.2rem;font-weight:700;color:var(--green-dark);margin-bottom:20px}
.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.slot-btn{padding:9px 6px;border-radius:8px;border:2px solid var(--border);background:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition);text-align:center;color:var(--text)}
.slot-btn:hover,.slot-btn.selected{background:var(--green);color:#fff;border-color:var(--green)}
.slot-btn.unavailable{opacity:.4;cursor:not-allowed;background:#f5f5f5}

/* ACCOUNT */
.account-sidebar{background:#fff;border-radius:var(--radius-xl);padding:28px;border:1px solid var(--border-light);position:sticky;top:90px}
.account-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff;margin:0 auto 14px}
.account-name{font-size:1.1rem;font-weight:700;text-align:center;color:var(--green-dark)}
.account-email{font-size:.83rem;color:var(--muted);text-align:center;margin-bottom:20px}
.account-nav a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--radius);font-size:.9rem;font-weight:500;color:var(--text);margin-bottom:3px;transition:var(--transition)}
.account-nav a:hover,.account-nav a.active{background:var(--green-pale);color:var(--green)}
.account-nav a i{width:18px;color:var(--muted);transition:var(--transition)}
.account-nav a:hover i,.account-nav a.active i{color:var(--green)}
.account-card{background:#fff;border-radius:var(--radius-xl);padding:28px;border:1px solid var(--border-light)}
.account-card-title{font-size:1.1rem;font-weight:700;color:var(--green-dark);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border-light)}
.order-row{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--border-light);flex-wrap:wrap}
.order-row:last-child{border-bottom:none}
.order-img{width:60px;height:60px;border-radius:10px;object-fit:cover;background:var(--green-xpale);flex-shrink:0}
.order-details{flex:1;min-width:0}
.order-num{font-weight:700;color:var(--green);font-size:.9rem}
.order-date{font-size:.78rem;color:var(--muted)}
.order-status{padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:600}
.status-pending{background:#fff3e0;color:#e65100}
.status-confirmed{background:var(--green-pale);color:var(--green-dark)}
.status-delivered{background:#e8f5e9;color:#1b5e20}
.status-cancelled{background:#fce4ec;color:#c62828}

/* FOOTER */
.main-footer{background:var(--green-dark);color:rgba(255,255,255,.70);padding:80px 0 0}
.footer-brand-desc{font-size:.88rem;line-height:1.8;color:rgba(255,255,255,.45);margin:16px 0 24px;max-width:280px}
.footer-social{display:flex;gap:10px}
.social-btn{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);font-size:.95rem;transition:var(--transition)}
.social-btn:hover{background:var(--green-light);color:#fff;transform:translateY(-2px)}
.footer-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:rgba(255,255,255,.35);margin-bottom:18px}
.footer-link{display:block;color:rgba(255,255,255,.55);font-size:.88rem;padding:6px 0;transition:var(--transition)}
.footer-link:hover{color:var(--gold-light);padding-left:6px}
.footer-contact-item{display:flex;align-items:flex-start;gap:12px;padding:8px 0;font-size:.87rem;color:rgba(255,255,255,.55)}
.footer-contact-item i{color:var(--gold-light);margin-top:3px;flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 0;margin-top:60px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom p{margin:0;font-size:.82rem;color:rgba(255,255,255,.35)}

/* TOASTS */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;gap:10px}
.toast-item{background:var(--green-dark);color:#fff;padding:14px 20px;border-radius:var(--radius);border-left:4px solid var(--green-bright);font-size:.88rem;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;transform:translateX(120%);transition:transform .35s cubic-bezier(.4,0,.2,1);min-width:280px}
.toast-item.show{transform:translateX(0)}
.toast-item.success{border-left-color:#22c55e}
.toast-item.error{border-left-color:#ef4444}
.toast-item.cart{border-left-color:var(--gold)}

/* FLOAT */
#backToTop{position:fixed;bottom:24px;left:24px;width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:var(--shadow-green);opacity:0;visibility:hidden;transition:var(--transition);z-index:500}
#backToTop.show{opacity:1;visibility:visible}
#backToTop:hover{transform:translateY(-3px)}
.whatsapp-float{position:fixed;bottom:80px;right:24px;width:52px;height:52px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 6px 24px rgba(37,211,102,.4);transition:var(--transition);z-index:500}
.whatsapp-float:hover{transform:scale(1.1)}

/* ANIMATIONS */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.delay-1{transition-delay:.1s}
.fade-up.delay-2{transition-delay:.2s}
.fade-up.delay-3{transition-delay:.3s}
.fade-up.delay-4{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:991px){.hero-badge{display:none}.dropdown-mega-menu{display:none!important}.section-pad{padding:60px 0}.cart-sidebar{width:100%;right:-100%}}
@media(max-width:767px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.auth-card{padding:32px 22px}.features-bar .feature-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}}
@media(max-width:575px){.hero-slide{min-height:80vh}.sort-bar{flex-direction:column;align-items:flex-start}.slot-grid{grid-template-columns:repeat(2,1fr)}}/* ============================================================
   GlowUp Beauty & Salon — style.css
   EverGreen Theme: Forest Green + Gold + Ivory
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Jost:wght@300;400;500;600;700&display=swap');

:root {
  --green:          #1a472a;
  --green-mid:      #2d6a4f;
  --green-light:    #40916c;
  --green-bright:   #52b788;
  --green-pale:     #d8f3dc;
  --green-xpale:    #f0faf2;
  --green-dark:     #0d2818;
  --green-deep:     #081c10;
  --gold:           #c9a84c;
  --gold-light:     #e8c46a;
  --gold-pale:      #fdf5e0;
  --gold-dark:      #9c7a2e;
  --ivory:          #faf7f2;
  --ivory-dark:     #f0ebe0;
  --cream:          #f5f0e8;
  --dark:           #0d2818;
  --dark-2:         #1a3d28;
  --text:           #1a2e1f;
  --muted:          #5a7a60;
  --border:         #c8dfc8;
  --border-light:   #e2f0e2;
  --white:          #ffffff;
  --body-bg:        #faf7f2;
  --radius:         12px;
  --radius-lg:      20px;
  --radius-xl:      28px;
  --shadow:         0 4px 24px rgba(26,71,42,.10);
  --shadow-lg:      0 12px 48px rgba(26,71,42,.18);
  --shadow-green:   0 8px 32px rgba(26,71,42,.28);
  --shadow-gold:    0 8px 32px rgba(201,168,76,.30);
  --transition:     all .28s cubic-bezier(.4,0,.2,1);
  --navbar-h:       70px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--body-bg);color:var(--text);font-size:15px;line-height:1.7;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:var(--transition)}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--green-xpale)}
::-webkit-scrollbar-thumb{background:var(--green-light);border-radius:3px}
.display-font{font-family:'Cormorant Garamond',serif}
h1,h2,h3{font-family:'Cormorant Garamond',serif;line-height:1.15}
h4,h5,h6{font-family:'Jost',sans-serif}

/* LOADER */
#pageLoader{position:fixed;inset:0;background:var(--green-deep);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;transition:opacity .5s ease,visibility .5s ease}
#pageLoader.hidden{opacity:0;visibility:hidden}
.loader-logo{font-family:'Cormorant Garamond',serif;font-size:2rem;color:#fff;letter-spacing:2px}
.loader-logo span{color:var(--gold-light)}
.loader-bar{width:160px;height:3px;background:rgba(255,255,255,.15);border-radius:3px;overflow:hidden}
.loader-bar-fill{height:100%;background:linear-gradient(90deg,var(--green-bright),var(--gold));border-radius:3px;animation:loaderAnim 1.2s ease forwards}
@keyframes loaderAnim{from{width:0}to{width:100%}}

/* TOPBAR */
.topbar{background:var(--green-deep);color:rgba(255,255,255,.70);font-size:.78rem;padding:8px 0;letter-spacing:.3px}
.topbar a{color:rgba(255,255,255,.70)}
.topbar a:hover{color:var(--gold-light)}
.topbar-divider{margin:0 14px;opacity:.25}
.topbar i{color:var(--gold-light)}

/* NAVBAR */
.main-navbar{background:#fff;border-bottom:2px solid var(--border-light);height:var(--navbar-h);position:sticky;top:0;z-index:1000;transition:box-shadow .3s ease}
.main-navbar.scrolled{box-shadow:0 4px 24px rgba(26,71,42,.12)}

.brand-logo{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:700;color:var(--green);white-space:nowrap;display:flex;align-items:center;gap:10px}
.brand-logo .logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--green),var(--green-light));border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.05rem}
.brand-logo span{color:var(--gold)}

.nav-link-custom{font-size:.88rem;font-weight:600;color:var(--text)!important;padding:8px 14px!important;border-radius:8px;transition:var(--transition);position:relative;letter-spacing:.2px;white-space:nowrap}
.nav-link-custom::after{content:'';position:absolute;bottom:4px;left:50%;right:50%;height:2px;background:var(--green-light);border-radius:2px;transition:all .25s ease}
.nav-link-custom:hover{color:var(--green)!important;background:var(--green-xpale)}
.nav-link-custom:hover::after,.nav-link-custom.active::after{left:14px;right:14px}
.nav-link-custom.active{color:var(--green)!important;font-weight:700;background:var(--green-xpale)}

/* MEGA DROPDOWN */
.dropdown-mega{position:static!important}
.dropdown-mega-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border-top:3px solid var(--green-light);border-bottom:1px solid var(--border-light);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg);padding:28px 0;display:none;z-index:999;animation:dropDown .2s ease}
@keyframes dropDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.dropdown-mega:hover .dropdown-mega-menu{display:block}
.mega-col-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:12px}
.mega-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);font-size:.88rem;font-weight:500;color:var(--text);transition:var(--transition);margin-bottom:2px}
.mega-link:hover{background:var(--green-xpale);color:var(--green)}
.mega-link i{color:var(--green-light);font-size:.85rem;width:16px}

.nav-icon-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text);font-size:1rem;transition:var(--transition);position:relative;border:none;background:transparent;cursor:pointer}
.nav-icon-btn:hover{background:var(--green-xpale);color:var(--green)}
.cart-count{position:absolute;top:4px;right:4px;width:18px;height:18px;background:var(--green-light);color:#fff;font-size:.6rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}

.nav-search{display:flex;align-items:center;background:var(--green-xpale);border:2px solid var(--border);border-radius:50px;overflow:hidden;transition:var(--transition)}
.nav-search:focus-within{border-color:var(--green-light);background:#fff}
.nav-search input{border:none;background:transparent;padding:8px 16px;font-size:.87rem;outline:none;width:200px;font-family:'Jost',sans-serif;color:var(--text)}
.nav-search button{background:var(--green);border:none;color:#fff;padding:8px 16px;cursor:pointer;font-size:.85rem;transition:var(--transition)}
.nav-search button:hover{background:var(--green-mid)}

/* SECTION */
.section-pad{padding:90px 0}
.section-pad-sm{padding:60px 0}
.section-pad-xs{padding:40px 0}
.section-label{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--green-light);padding:6px 16px;background:var(--green-pale);border-radius:50px;margin-bottom:14px}
.section-title{font-size:clamp(2rem,4vw,3rem);color:var(--green-dark);margin-bottom:16px}
.section-sub{font-size:1.05rem;color:var(--muted);max-width:560px;line-height:1.7}

/* BUTTONS */
.btn-green,.btn-pink{background:linear-gradient(135deg,var(--green),var(--green-mid));color:#fff!important;border:none;padding:13px 32px;border-radius:50px;font-size:.92rem;font-weight:600;letter-spacing:.3px;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);cursor:pointer;box-shadow:var(--shadow-green)}
.btn-green:hover,.btn-pink:hover{transform:translateY(-2px);filter:brightness(1.1)}
.btn-outline-green,.btn-outline-pink{background:transparent;color:var(--green);border:2px solid var(--green);padding:11px 28px;border-radius:50px;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:var(--transition);cursor:pointer}
.btn-outline-green:hover,.btn-outline-pink:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:#fff!important;border:none;padding:13px 32px;border-radius:50px;font-size:.92rem;font-weight:700;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);box-shadow:var(--shadow-gold)}
.btn-gold:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-dark{background:var(--green-dark);color:#fff;padding:13px 32px;border-radius:50px;font-size:.92rem;font-weight:600;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);border:none;cursor:pointer}
.btn-dark:hover{background:var(--green);transform:translateY(-2px)}

/* HERO */
.hero-section{position:relative;overflow:hidden}
.hero-slide{min-height:88vh;display:flex;align-items:center;background-size:cover;background-position:center;position:relative}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(13,40,24,.88) 0%,rgba(13,40,24,.55) 50%,rgba(13,40,24,.20) 100%)}
.hero-content{position:relative;z-index:2;max-width:640px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(82,183,136,.18);border:1px solid rgba(82,183,136,.45);color:var(--green-bright);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;padding:8px 18px;border-radius:50px;margin-bottom:20px}
.hero-title{font-size:clamp(2.6rem,6vw,4.8rem);color:#fff;line-height:1.08;margin-bottom:22px;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.hero-title em{color:var(--gold-light);font-style:italic}
.hero-subtitle{font-size:1.1rem;color:rgba(255,255,255,.8);margin-bottom:36px;line-height:1.7}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-badge{position:absolute;right:60px;bottom:60px;background:rgba(255,255,255,.10);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.20);border-radius:var(--radius-lg);padding:20px 28px;color:#fff;text-align:center;z-index:2}
.hero-badge .num{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;line-height:1;color:var(--gold-light)}
.hero-badge .txt{font-size:.75rem;opacity:.7;letter-spacing:1px;text-transform:uppercase;margin-top:4px}
.carousel-control-prev,.carousel-control-next{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);top:50%;transform:translateY(-50%);opacity:1}
.carousel-control-prev{left:30px}
.carousel-control-next{right:30px}
.carousel-control-prev:hover,.carousel-control-next:hover{background:var(--green-light)}

/* FEATURES BAR */
.features-bar{background:var(--green-dark);padding:0}
.feature-item{display:flex;align-items:center;gap:14px;padding:22px 24px;border-right:1px solid rgba(255,255,255,.07)}
.feature-item:last-child{border-right:none}
.feature-icon{width:44px;height:44px;border-radius:11px;background:rgba(82,183,136,.18);display:flex;align-items:center;justify-content:center;color:var(--green-bright);font-size:1.1rem;flex-shrink:0}
.feature-item strong{display:block;color:#fff;font-size:.9rem;font-weight:600}
.feature-item span{color:rgba(255,255,255,.40);font-size:.76rem}

/* CATEGORY CARDS */
.cat-card{border-radius:var(--radius-lg);overflow:hidden;position:relative;cursor:pointer;transition:var(--transition);aspect-ratio:4/5}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cat-card:hover img{transform:scale(1.07)}
.cat-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,40,24,.90) 0%,rgba(13,40,24,.20) 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:22px 20px}
.cat-card-name{color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;margin-bottom:4px}
.cat-card-count{color:rgba(255,255,255,.55);font-size:.78rem;margin-bottom:14px}
.cat-card-btn{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);color:#fff;padding:8px 18px;border-radius:50px;font-size:.82rem;font-weight:600;transform:translateY(8px);opacity:0;transition:var(--transition)}
.cat-card:hover .cat-card-btn{transform:translateY(0);opacity:1}

/* PRODUCT CARDS */
.product-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);border:1px solid var(--border-light);display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.product-img-wrap{position:relative;overflow:hidden;aspect-ratio:1}
.product-img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.product-card:hover .product-img{transform:scale(1.06)}
.product-badge{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge-sale{background:var(--green-light);color:#fff}
.badge-new{background:var(--gold);color:#fff}
.badge-best{background:var(--green-dark);color:#fff}
.product-actions{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:7px;transform:translateX(50px);opacity:0;transition:var(--transition)}
.product-card:hover .product-actions{transform:translateX(0);opacity:1}
.action-btn{width:36px;height:36px;border-radius:50%;background:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text);transition:var(--transition);box-shadow:0 2px 12px rgba(0,0,0,.1)}
.action-btn:hover{background:var(--green);color:#fff;transform:scale(1.1)}
.action-btn.wishlisted{background:var(--green);color:#fff}
.product-body{padding:16px;flex:1;display:flex;flex-direction:column}
.product-brand{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.product-name{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:10px;line-height:1.4}
.product-name a{color:inherit}
.product-name a:hover{color:var(--green)}
.product-rating{display:flex;align-items:center;gap:5px;margin-bottom:12px}
.stars{color:var(--gold);font-size:.78rem}
.rating-count{font-size:.76rem;color:var(--muted)}
.product-price{display:flex;align-items:center;gap:10px;margin-bottom:14px;margin-top:auto;flex-wrap:wrap}
.price-current{font-size:1.15rem;font-weight:700;color:var(--green)}
.price-original{font-size:.9rem;color:var(--muted);text-decoration:line-through}
.price-save{font-size:.75rem;background:var(--green-pale);color:var(--green);padding:2px 8px;border-radius:50px;font-weight:600}
.btn-add-cart{width:100%;background:var(--green-dark);color:#fff;border:none;padding:11px;border-radius:var(--radius);font-size:.88rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition)}
.btn-add-cart:hover{background:var(--green)}
.btn-add-cart.added{background:var(--green-mid)}

/* SERVICE CARDS */
.service-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light);transition:var(--transition);overflow:hidden;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--green-bright)}
.service-img-wrap{position:relative;overflow:hidden;aspect-ratio:16/10}
.service-img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.service-card:hover .service-img{transform:scale(1.05)}
.service-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,40,24,.72) 0%,transparent 60%)}
.service-cat-chip{position:absolute;top:14px;left:14px;background:var(--green);color:#fff;padding:5px 14px;border-radius:50px;font-size:.72rem;font-weight:600}
.service-duration{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);color:#fff;padding:5px 12px;border-radius:50px;font-size:.75rem;display:flex;align-items:center;gap:5px}
.service-body{padding:20px;flex:1;display:flex;flex-direction:column}
.service-icon-circle{width:48px;height:48px;border-radius:12px;background:var(--green-pale);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:14px}
.service-title{font-size:1.1rem;font-weight:700;color:var(--green-dark);margin-bottom:8px}
.service-desc{font-size:.86rem;color:var(--muted);line-height:1.6;margin-bottom:16px;flex:1}
.service-includes{list-style:none;padding:0;margin-bottom:18px}
.service-includes li{font-size:.82rem;color:var(--text);padding:4px 0;display:flex;align-items:center;gap:8px}
.service-includes li i{color:var(--green-light);font-size:.75rem}
.service-price-row{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border-light);margin-top:auto}
.service-price{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--green)}
.service-price small{font-family:'Jost',sans-serif;font-size:.75rem;color:var(--muted);font-weight:400;display:block}
.btn-book{background:linear-gradient(135deg,var(--green),var(--green-light));color:#fff;border:none;padding:10px 20px;border-radius:50px;font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px;transition:var(--transition)}
.btn-book:hover{transform:translateY(-2px);box-shadow:var(--shadow-green)}

/* FILTER PILLS */
.service-cat-pill{padding:9px 22px;border-radius:50px;border:2px solid var(--border);background:#fff;font-size:.88rem;font-weight:600;cursor:pointer;transition:var(--transition);color:var(--text)}
.service-cat-pill:hover,.service-cat-pill.active{background:var(--green);color:#fff;border-color:var(--green)}

/* TESTIMONIALS */
.testimonial-card{background:#fff;border-radius:var(--radius-xl);padding:32px;border:1px solid var(--border-light);transition:var(--transition);position:relative}
.testimonial-card::before{content:'\201C';font-family:'Cormorant Garamond',serif;font-size:5rem;color:var(--green-pale);position:absolute;top:10px;left:24px;line-height:1;pointer-events:none}
.testimonial-card:hover{border-color:var(--green-bright);box-shadow:var(--shadow)}
.testimonial-stars{color:var(--gold);font-size:.85rem;margin-bottom:14px}
.testimonial-text{font-size:.96rem;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;flex-shrink:0}
.author-name{font-weight:700;font-size:.92rem}
.author-role{font-size:.78rem;color:var(--muted)}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.gallery-item{aspect-ratio:1;overflow:hidden;border-radius:8px;position:relative;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-overlay{position:absolute;inset:0;background:rgba(26,71,42,.65);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;opacity:0;transition:var(--transition)}
.gallery-item:hover .gallery-overlay{opacity:1}

/* PROMO BANNER */
.promo-banner{background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 50%,var(--green-dark) 100%);padding:60px 0;position:relative;overflow:hidden}
.promo-banner::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%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2352b788' fill-opacity='0.08'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.promo-banner .section-label{background:rgba(82,183,136,.2);color:var(--green-bright)}
.promo-title{font-size:clamp(1.8rem,4vw,3rem);color:#fff;margin-bottom:14px}
.promo-sub{color:rgba(255,255,255,.7);font-size:1rem;margin-bottom:28px}
.promo-code{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.10);border:2px dashed rgba(201,168,76,.6);padding:10px 22px;border-radius:var(--radius);cursor:pointer;transition:var(--transition);color:#fff;font-weight:600}
.promo-code:hover{background:rgba(201,168,76,.2)}
.promo-code-text{font-size:1.1rem;letter-spacing:2px;color:var(--gold-light)}

/* CART SIDEBAR */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1100;opacity:0;visibility:hidden;transition:var(--transition)}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-sidebar{position:fixed;top:0;right:-440px;bottom:0;width:420px;background:#fff;z-index:1101;display:flex;flex-direction:column;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.15)}
.cart-sidebar.open{right:0}
.cart-header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.cart-header h5{font-size:1.1rem;font-weight:700;margin:0;color:var(--green-dark)}
.cart-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--muted);padding:4px}
.cart-close:hover{color:var(--green)}
.cart-body{flex:1;overflow-y:auto;padding:20px 24px}
.cart-empty{text-align:center;padding:60px 20px;color:var(--muted)}
.cart-empty i{font-size:3rem;margin-bottom:14px;color:var(--green-light)}
.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-light)}
.cart-item-img{width:70px;height:70px;border-radius:10px;object-fit:cover;flex-shrink:0;background:var(--green-xpale)}
.cart-item-body{flex:1;min-width:0}
.cart-item-name{font-weight:600;font-size:.9rem;margin-bottom:4px;color:var(--green-dark)}
.cart-item-brand{font-size:.75rem;color:var(--muted);margin-bottom:10px}
.cart-item-price{font-weight:700;color:var(--green);font-size:.95rem}
.qty-control{display:flex;align-items:center;gap:10px}
.qty-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.qty-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}
.qty-num{font-weight:600;min-width:24px;text-align:center}
.cart-item-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;padding:4px;transition:var(--transition)}
.cart-item-remove:hover{color:#dc3545}
.cart-footer{padding:20px 24px;border-top:1px solid var(--border-light)}
.cart-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cart-subtotal .label{font-size:.9rem;color:var(--muted)}
.cart-subtotal .amount{font-size:1.2rem;font-weight:700;color:var(--green)}

/* AUTH */
.auth-page{min-height:100vh;display:flex;align-items:center;background:var(--cream);padding:40px 0}
.auth-card{background:#fff;border-radius:var(--radius-xl);padding:48px 44px;box-shadow:var(--shadow-lg);max-width:480px;width:100%}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-logo .logo-icon{margin:0 auto 14px;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--green),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff}
.auth-title{font-size:1.7rem;text-align:center;color:var(--green-dark);margin-bottom:6px}
.auth-sub{text-align:center;color:var(--muted);font-size:.88rem}
.form-group{margin-bottom:20px}
.form-label{font-size:.83rem;font-weight:600;color:var(--text);margin-bottom:7px;display:block}
.form-input{width:100%;border:2px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:.92rem;color:var(--text);transition:var(--transition);background:#fff;font-family:'Jost',sans-serif}
.form-input:focus{border-color:var(--green-light);box-shadow:0 0 0 .2rem rgba(64,145,108,.15);outline:none}
.input-icon-wrap{position:relative}
.input-icon-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--green-light);font-size:.9rem}
.input-icon-wrap .form-input{padding-left:42px}
.input-icon-wrap .eye-btn{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted)}
.divider-text{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.82rem;margin:20px 0}
.divider-text::before,.divider-text::after{content:'';flex:1;height:1px;background:var(--border)}

/* SHOP */
.shop-header{background:linear-gradient(135deg,var(--green-dark),var(--green));padding:60px 0}
.shop-header h1{color:#fff;font-size:clamp(2rem,5vw,3.5rem)}
.breadcrumb-custom{display:flex;align-items:center;gap:8px;font-size:.84rem;color:rgba(255,255,255,.6);flex-wrap:wrap}
.breadcrumb-custom a{color:rgba(255,255,255,.7)}
.breadcrumb-custom a:hover{color:var(--gold-light)}
.breadcrumb-sep{color:rgba(255,255,255,.3)}
.filter-sidebar{background:#fff;border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border-light);position:sticky;top:90px}
.filter-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:14px}
.filter-option{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer}
.filter-option input{accent-color:var(--green);width:16px;height:16px}
.filter-option label{font-size:.88rem;cursor:pointer;flex:1}
.filter-divider{height:1px;background:var(--border-light);margin:18px 0}
.price-range-labels{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);margin-top:10px}
input[type=range]{width:100%;accent-color:var(--green)}
.sort-bar{background:#fff;border-radius:var(--radius);padding:14px 20px;border:1px solid var(--border-light);display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.sort-bar select{border:1px solid var(--border);border-radius:8px;padding:7px 14px;font-size:.87rem;color:var(--text);outline:none;cursor:pointer;font-family:'Jost',sans-serif}
.view-toggle{display:flex;gap:4px}
.view-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--muted);transition:var(--transition)}
.view-btn.active,.view-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* PRODUCT DETAIL */
.product-gallery-main{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:1;background:var(--cream)}
.product-gallery-main img{width:100%;height:100%;object-fit:cover}
.product-thumbs{display:flex;gap:10px;margin-top:12px}
.thumb-item{width:80px;height:80px;border-radius:10px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:var(--transition);flex-shrink:0}
.thumb-item:hover,.thumb-item.active{border-color:var(--green-light)}
.thumb-item img{width:100%;height:100%;object-fit:cover}
.product-detail-title{font-size:clamp(1.6rem,3vw,2.4rem);color:var(--green-dark);margin-bottom:10px}
.product-meta-row{display:flex;align-items:center;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.product-detail-price .price-now{font-size:2rem;font-weight:700;color:var(--green)}
.product-detail-price .price-was{font-size:1.1rem;color:var(--muted);text-decoration:line-through}
.product-detail-price .price-save-badge{background:var(--green-pale);color:var(--green);padding:4px 14px;border-radius:50px;font-size:.85rem;font-weight:600}
.quantity-selector{display:flex;align-items:center;gap:0;border:2px solid var(--border);border-radius:var(--radius);overflow:hidden;width:fit-content}
.qty-dec,.qty-inc{width:44px;height:48px;border:none;background:var(--cream);cursor:pointer;font-size:1rem;color:var(--text);transition:var(--transition)}
.qty-dec:hover,.qty-inc:hover{background:var(--green);color:#fff}
.qty-input{width:56px;height:48px;border:none;border-left:2px solid var(--border);border-right:2px solid var(--border);text-align:center;font-size:1rem;font-weight:600;font-family:'Jost',sans-serif;outline:none}
.tab-btn{padding:10px 24px;border:none;background:transparent;font-size:.9rem;font-weight:500;color:var(--muted);border-bottom:3px solid transparent;cursor:pointer;transition:var(--transition)}
.tab-btn.active{color:var(--green);border-bottom-color:var(--green);font-weight:600}
.tab-content-panel{display:none}
.tab-content-panel.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* SERVICE DETAIL */
.service-detail-img{border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;height:400px}
.service-detail-img img{width:100%;height:100%;object-fit:cover}
.booking-card{background:#fff;border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light);position:sticky;top:90px}
.booking-card-title{font-size:1.2rem;font-weight:700;color:var(--green-dark);margin-bottom:20px}
.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.slot-btn{padding:9px 6px;border-radius:8px;border:2px solid var(--border);background:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition);text-align:center;color:var(--text)}
.slot-btn:hover,.slot-btn.selected{background:var(--green);color:#fff;border-color:var(--green)}
.slot-btn.unavailable{opacity:.4;cursor:not-allowed;background:#f5f5f5}

/* ACCOUNT */
.account-sidebar{background:#fff;border-radius:var(--radius-xl);padding:28px;border:1px solid var(--border-light);position:sticky;top:90px}
.account-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff;margin:0 auto 14px}
.account-name{font-size:1.1rem;font-weight:700;text-align:center;color:var(--green-dark)}
.account-email{font-size:.83rem;color:var(--muted);text-align:center;margin-bottom:20px}
.account-nav a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--radius);font-size:.9rem;font-weight:500;color:var(--text);margin-bottom:3px;transition:var(--transition)}
.account-nav a:hover,.account-nav a.active{background:var(--green-pale);color:var(--green)}
.account-nav a i{width:18px;color:var(--muted);transition:var(--transition)}
.account-nav a:hover i,.account-nav a.active i{color:var(--green)}
.account-card{background:#fff;border-radius:var(--radius-xl);padding:28px;border:1px solid var(--border-light)}
.account-card-title{font-size:1.1rem;font-weight:700;color:var(--green-dark);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border-light)}
.order-row{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--border-light);flex-wrap:wrap}
.order-row:last-child{border-bottom:none}
.order-img{width:60px;height:60px;border-radius:10px;object-fit:cover;background:var(--green-xpale);flex-shrink:0}
.order-details{flex:1;min-width:0}
.order-num{font-weight:700;color:var(--green);font-size:.9rem}
.order-date{font-size:.78rem;color:var(--muted)}
.order-status{padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:600}
.status-pending{background:#fff3e0;color:#e65100}
.status-confirmed{background:var(--green-pale);color:var(--green-dark)}
.status-delivered{background:#e8f5e9;color:#1b5e20}
.status-cancelled{background:#fce4ec;color:#c62828}

/* FOOTER */
.main-footer{background:var(--green-dark);color:rgba(255,255,255,.70);padding:80px 0 0}
.footer-brand-desc{font-size:.88rem;line-height:1.8;color:rgba(255,255,255,.45);margin:16px 0 24px;max-width:280px}
.footer-social{display:flex;gap:10px}
.social-btn{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);font-size:.95rem;transition:var(--transition)}
.social-btn:hover{background:var(--green-light);color:#fff;transform:translateY(-2px)}
.footer-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:rgba(255,255,255,.35);margin-bottom:18px}
.footer-link{display:block;color:rgba(255,255,255,.55);font-size:.88rem;padding:6px 0;transition:var(--transition)}
.footer-link:hover{color:var(--gold-light);padding-left:6px}
.footer-contact-item{display:flex;align-items:flex-start;gap:12px;padding:8px 0;font-size:.87rem;color:rgba(255,255,255,.55)}
.footer-contact-item i{color:var(--gold-light);margin-top:3px;flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 0;margin-top:60px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom p{margin:0;font-size:.82rem;color:rgba(255,255,255,.35)}

/* TOASTS */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;gap:10px}
.toast-item{background:var(--green-dark);color:#fff;padding:14px 20px;border-radius:var(--radius);border-left:4px solid var(--green-bright);font-size:.88rem;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;transform:translateX(120%);transition:transform .35s cubic-bezier(.4,0,.2,1);min-width:280px}
.toast-item.show{transform:translateX(0)}
.toast-item.success{border-left-color:#22c55e}
.toast-item.error{border-left-color:#ef4444}
.toast-item.cart{border-left-color:var(--gold)}

/* FLOAT */
#backToTop{position:fixed;bottom:24px;left:24px;width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:var(--shadow-green);opacity:0;visibility:hidden;transition:var(--transition);z-index:500}
#backToTop.show{opacity:1;visibility:visible}
#backToTop:hover{transform:translateY(-3px)}
.whatsapp-float{position:fixed;bottom:80px;right:24px;width:52px;height:52px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 6px 24px rgba(37,211,102,.4);transition:var(--transition);z-index:500}
.whatsapp-float:hover{transform:scale(1.1)}

/* ANIMATIONS */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.delay-1{transition-delay:.1s}
.fade-up.delay-2{transition-delay:.2s}
.fade-up.delay-3{transition-delay:.3s}
.fade-up.delay-4{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:991px){.hero-badge{display:none}.dropdown-mega-menu{display:none!important}.section-pad{padding:60px 0}.cart-sidebar{width:100%;right:-100%}}
@media(max-width:767px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.auth-card{padding:32px 22px}.features-bar .feature-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}}
@media(max-width:575px){.hero-slide{min-height:80vh}.sort-bar{flex-direction:column;align-items:flex-start}.slot-grid{grid-template-columns:repeat(2,1fr)}}