/* ================================================================
   EMPRESS NAILS BEAUTY & SPA — LUXURY E-SHOP STYLESHEET
   Premium Beauty Salon · Skopelos, Greece
   ================================================================ */

/* ----------------------------------------------------------------
   1. CUSTOM PROPERTIES
   ---------------------------------------------------------------- */
:root {
  /* Palette */
  --cream:        #F7EFE5;
  --gold:         #C8A97E;
  --gold-light:   #D4BA94;
  --gold-dark:    #B08D5E;
  --gold-pale:    rgba(200,169,126,.10);
  --dark:         #2C2C2C;
  --dark-soft:    #5A5A5A;
  --soft-pink:    #F5DCDC;
  --white:        #FFFFFF;
  --ivory:        #FDF8F2;
  --bg:           #FDFBF8;
  --border:       rgba(200,169,126,.18);
  --shadow-color: rgba(44,44,44,.06);
  --overlay:      rgba(44,44,44,.50);

  /* Typography */
  --font-serif:   'Cormorant Garamond', Georgia, serif;
  --font-sans:    'Montserrat', 'Helvetica Neue', Helvetica, Arial, sans-serif;

  /* Radii */
  --r-xs: 4px;  --r-sm: 8px;  --r-md: 16px;  --r-lg: 24px;  --r-xl: 32px;  --r-full: 9999px;

  /* Shadows */
  --sh-xs:   0  1px  4px  var(--shadow-color);
  --sh-sm:   0  2px  8px  var(--shadow-color);
  --sh-md:   0  4px 20px  rgba(44,44,44,.08);
  --sh-lg:   0  8px 40px  rgba(44,44,44,.10);
  --sh-gold: 0  4px 24px  rgba(200,169,126,.18);

  /* Transitions */
  --ease:  cubic-bezier(.4,0,.2,1);
  --t-fast: .2s var(--ease);
  --t-base: .35s var(--ease);
  --t-slow: .6s var(--ease);

  /* Layout */
  --max-w:    1320px;
  --nav-h:    72px;
  --ann-h:    38px;
}

/* ----------------------------------------------------------------
   2. RESET & BASE
   ---------------------------------------------------------------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}
body{font-family:var(--font-sans);color:var(--dark);background:var(--bg);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--t-fast)}
ul,ol{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit;border:none;outline:none;background:none}
button{cursor:pointer}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0s!important;transition-duration:0s!important}}

/* ----------------------------------------------------------------
   3. TYPOGRAPHY
   ---------------------------------------------------------------- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:500;line-height:1.15;color:var(--dark)}
h1{font-size:clamp(2.4rem,5vw,4.2rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.7rem)}
h4{font-size:clamp(1.05rem,2vw,1.25rem)}
p{font-size:.92rem;color:var(--dark-soft);line-height:1.8}
.section-label{font-family:var(--font-sans);font-size:.65rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.75rem}
.section-title{margin-bottom:.75rem}
.section-subtitle{max-width:560px;margin:0 auto 3rem;text-align:center;font-size:.95rem;color:var(--dark-soft)}
.gold-divider{width:50px;height:1.5px;background:var(--gold);margin:1rem auto}

/* ----------------------------------------------------------------
   4. UTILITY
   ---------------------------------------------------------------- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 2rem}
.text-center{text-align:center}
section{padding:5.5rem 0}

/* ----------------------------------------------------------------
   5. PRELOADER
   ---------------------------------------------------------------- */
.preloader{position:fixed;inset:0;z-index:10000;background:var(--white);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}
.preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-logo{font-family:var(--font-serif);font-size:1.8rem;color:var(--dark);font-weight:500;letter-spacing:.06em;margin-bottom:1.2rem}
.preloader-bar{width:100px;height:1.5px;background:var(--cream);margin:0 auto;border-radius:2px;overflow:hidden;position:relative}
.preloader-bar::after{content:'';position:absolute;top:0;left:-40%;width:40%;height:100%;background:var(--gold);animation:preload-slide 1s ease-in-out infinite}
@keyframes preload-slide{0%{left:-40%}100%{left:100%}}

/* ----------------------------------------------------------------
   6. ANNOUNCEMENT BAR
   ---------------------------------------------------------------- */
.announcement-bar{background:var(--dark);color:rgba(255,255,255,.85);height:var(--ann-h);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;z-index:999}
.announcement-bar .announcement-track{display:flex;white-space:nowrap;animation:announcement-scroll 24s linear infinite}
.announcement-bar .announcement-item{font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:0 3rem;display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.announcement-bar .announcement-item .ann-dot{width:3px;height:3px;border-radius:50%;background:var(--gold);display:inline-block}
@keyframes announcement-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ----------------------------------------------------------------
   7. NAVIGATION
   ---------------------------------------------------------------- */
.navbar{position:fixed;top:var(--ann-h);left:0;width:100%;z-index:1000;height:var(--nav-h);display:flex;align-items:center;transition:background var(--t-base),box-shadow var(--t-base),top var(--t-base)}
.navbar.scrolled{top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 1px 0 var(--border)}
.navbar .container{display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--font-serif);font-size:1.45rem;font-weight:600;color:var(--dark);letter-spacing:.04em}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:1.8rem}
.nav-links a{font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--dark-soft);position:relative;padding:.25rem 0}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--gold);transition:width var(--t-base)}
.nav-links a:hover,.nav-links a.active{color:var(--dark)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

.nav-cart{position:relative;display:flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--dark-soft);cursor:pointer;padding:.25rem 0}
.nav-cart:hover{color:var(--dark)}
.cart-count{background:var(--gold);color:var(--white);font-size:.55rem;font-weight:700;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:absolute;top:-6px;right:-10px}

.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--dark);transition:var(--t-fast)}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-5px)}

/* ----------------------------------------------------------------
   8. BUTTONS
   ---------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 2rem;font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;border-radius:var(--r-sm);transition:all var(--t-base);position:relative;overflow:hidden}
.btn-primary{background:var(--gold);color:var(--white)}
.btn-primary:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:var(--sh-gold)}
.btn-outline{background:transparent;color:var(--dark);border:1.5px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--white);transform:translateY(-2px);box-shadow:var(--sh-gold)}
.btn-dark{background:var(--dark);color:var(--white)}
.btn-dark:hover{background:#1a1a1a;transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn-white{background:var(--white);color:var(--dark)}
.btn-white:hover{background:var(--cream);transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn-sm{padding:.6rem 1.3rem;font-size:.65rem}
.btn-xs{padding:.45rem 1rem;font-size:.6rem;letter-spacing:.12em}

/* ----------------------------------------------------------------
   9. HERO
   ---------------------------------------------------------------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,var(--cream) 0%,var(--ivory) 40%,var(--soft-pink) 100%)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.12}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(253,251,248,.2) 0%,rgba(247,239,229,.5) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;max-width:760px;padding:0 2rem}
.hero-content .section-label{font-size:.6rem;letter-spacing:.4em;margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s ease forwards .3s}
.hero-content h1{font-weight:400;letter-spacing:.02em;margin-bottom:1.2rem;opacity:0;animation:fadeUp .8s ease forwards .5s}
.hero-content h1 em{font-style:italic;color:var(--gold)}
.hero-content p{font-size:1rem;margin-bottom:2.5rem;opacity:0;animation:fadeUp .8s ease forwards .7s}
.hero-buttons{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .8s ease forwards .9s}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;opacity:0;animation:fadeUp .8s ease forwards 1.2s}
.hero-scroll span{font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--gold)}
.hero-scroll-line{width:1px;height:36px;background:var(--gold);position:relative;overflow:hidden}
.hero-scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold-dark);animation:scrollLine 1.8s ease-in-out infinite}
@keyframes scrollLine{0%{top:-100%}50%{top:100%}100%{top:100%}}

/* ----------------------------------------------------------------
   10. FEATURED CATEGORIES
   ---------------------------------------------------------------- */
.categories-section{background:var(--white)}
.categories-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.2rem}
.category-card{position:relative;border-radius:var(--r-md);overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;cursor:pointer;text-decoration:none;transition:transform var(--t-base),box-shadow var(--t-base)}
.category-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.category-card-bg{position:absolute;inset:0;transition:transform var(--t-slow)}
.category-card:hover .category-card-bg{transform:scale(1.06)}
.category-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(44,44,44,.65) 100%)}
.category-card-content{position:relative;z-index:2;padding:1.4rem;width:100%;color:var(--white)}
.category-card-content h4{font-size:1.1rem;margin-bottom:.15rem;color:var(--white)}
.category-card-content p{font-size:.72rem;color:rgba(255,255,255,.75);letter-spacing:.05em}

/* Category card background images */
.category-card-bg{background-size:cover;background-position:center}
.category-card-bg img{width:100%;height:100%;object-fit:cover}

/* ----------------------------------------------------------------
   11. PRODUCT CARDS & GRID
   ---------------------------------------------------------------- */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.8rem}
.product-card{aspect-ratio: .8; background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-xs);transition:all var(--t-base);border:1px solid var(--border);position:relative}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.product-badge{position:absolute;top:.8rem;left:.8rem;z-index:2;background:var(--gold);color:var(--white);font-size:.55rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .7rem;border-radius:var(--r-full)}
.product-badge.badge-dark{background:var(--dark)}
.product-badge.badge-pink{background:#c9818a;color:var(--white)}
.product-card-image{height:280px;overflow:hidden;position:relative;background:var(--cream)}
.product-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.product-card:hover .product-card-image img{transform:scale(1.05)}

.product-card-actions{position:absolute;bottom:0;left:0;right:0;padding:.8rem;display:flex;justify-content:center;opacity:0;transform:translateY(10px);transition:all var(--t-base);z-index:3}
.product-card:hover .product-card-actions{opacity:1;transform:translateY(0)}

.product-card-body{padding:1.3rem 1.4rem 1.5rem;text-align:center}
.product-card-body h4{font-size:1.05rem;margin-bottom:.3rem;font-weight:500}
.product-card-body .product-subtitle{font-size:.76rem;color:var(--dark-soft);margin-bottom:.7rem}
.product-price{font-family:var(--font-serif);font-size:1.15rem;color:var(--gold);font-weight:600;display:block;margin-bottom:.8rem}
.product-card-actions-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.product-card-actions-row .add-to-cart{flex:1;min-width:0}
.product-card-actions-row .btn-icon{flex-shrink:0;width:44px;height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;border-radius:var(--r-sm)}
.product-card-body .btn:not(.btn-icon){width:100%}
.product-card-body .product-card-actions-row .add-to-cart{width:auto}

/* ----------------------------------------------------------------
   12. VALUE PROPOSITION
   ---------------------------------------------------------------- */
.values-section{background:var(--cream)}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.value-card{text-align:center;padding:2.5rem 1.5rem;border-radius:var(--r-md);background:var(--white);border:1px solid var(--border);transition:all var(--t-base)}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.value-icon{width:56px;height:56px;margin:0 auto 1.2rem;border-radius:50%;background:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:background var(--t-base)}
.value-card:hover .value-icon{background:var(--gold);color:var(--white)}
.value-card h4{margin-bottom:.5rem;font-size:1.1rem}
.value-card p{font-size:.82rem}

/* ----------------------------------------------------------------
   13. SIGNATURE SERVICES
   ---------------------------------------------------------------- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.8rem}
.service-card{background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-sm);transition:all var(--t-base);border:1px solid var(--border)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.service-card-image{height:220px;overflow:hidden;position:relative;background:var(--cream)}
.service-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.service-card:hover .service-card-image img{transform:scale(1.05)}
.service-card-body{padding:1.6rem}
.service-card-body h3{font-size:1.3rem;margin-bottom:.5rem}
.service-card-body p{font-size:.85rem;margin-bottom:1rem}
.service-card-footer{display:flex;align-items:center;justify-content:space-between}
.service-price{font-family:var(--font-serif);font-size:1.2rem;color:var(--gold);font-weight:600}

/* ----------------------------------------------------------------
   14. PROMOTIONAL BANNER
   ---------------------------------------------------------------- */
.promo-banner{position:relative;padding:6rem 0;overflow:hidden;background:var(--dark);color:var(--white);text-align:center}
.promo-banner .promo-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.3}
.promo-banner .promo-pattern{position:absolute;inset:0;opacity:.04;background-image:radial-gradient(circle at 20% 50%,var(--gold) 1px,transparent 1px),radial-gradient(circle at 80% 20%,var(--gold) 1px,transparent 1px);background-size:60px 60px}
.promo-banner .container{position:relative;z-index:2}
.promo-banner .section-label{color:var(--gold-light)}
.promo-banner h2{color:var(--white);margin-bottom:1rem;font-size:clamp(1.8rem,3.5vw,2.6rem)}
.promo-banner p{color:rgba(255,255,255,.65);max-width:520px;margin:0 auto 2.5rem}
.promo-buttons{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* ----------------------------------------------------------------
   15. BEAUTY INSPIRATION
   ---------------------------------------------------------------- */
.inspiration-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.inspiration-item{position:relative;border-radius:var(--r-md);overflow:hidden;aspect-ratio:1;cursor:pointer}
.inspiration-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.inspiration-item:hover img{transform:scale(1.08)}
.inspiration-overlay{position:absolute;inset:0;background:var(--overlay);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-base)}
.inspiration-item:hover .inspiration-overlay{opacity:1}
.inspiration-overlay span{color:var(--white);font-family:var(--font-serif);font-size:1rem;letter-spacing:.05em}
.inspiration-overlay .inspiration-tag{font-family:var(--font-sans);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-light);margin-top:.3rem}

/* ----------------------------------------------------------------
   16. REVIEWS PREVIEW
   ---------------------------------------------------------------- */
.reviews-summary{text-align:center;margin-bottom:2.5rem}
.reviews-rating-big{font-family:var(--font-serif);font-size:3.2rem;color:var(--dark);font-weight:500}
.reviews-stars{color:var(--gold);font-size:1.2rem;margin:.4rem 0;letter-spacing:.1em}
.reviews-count{font-size:.82rem;color:var(--dark-soft)}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.8rem}
.review-card{background:var(--white);border-radius:var(--r-md);padding:2rem;border:1px solid var(--border);box-shadow:var(--sh-xs);transition:all var(--t-base)}
.review-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.review-stars{color:var(--gold);font-size:.9rem;margin-bottom:.8rem;letter-spacing:.05em}
.review-text{font-size:.88rem;font-style:italic;line-height:1.8;margin-bottom:1rem;color:var(--dark-soft)}
.review-author{font-size:.75rem;font-weight:600;color:var(--dark);text-transform:uppercase;letter-spacing:.08em}
.review-date{font-size:.68rem;color:var(--dark-soft);margin-top:.15rem}

/* ----------------------------------------------------------------
   17. INSTAGRAM / SOCIAL GRID
   ---------------------------------------------------------------- */
.social-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.social-item{position:relative;aspect-ratio:1;border-radius:var(--r-sm);overflow:hidden;cursor:pointer}
.social-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.social-item:hover img{transform:scale(1.08)}
.social-overlay{position:absolute;inset:0;background:rgba(44,44,44,.45);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-base)}
.social-item:hover .social-overlay{opacity:1}
.social-overlay span{color:var(--white);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}

/* ----------------------------------------------------------------
   18. BOOKING CTA
   ---------------------------------------------------------------- */
.booking-cta{background:linear-gradient(135deg,var(--cream),var(--ivory),var(--soft-pink));text-align:center;position:relative;overflow:hidden}

/* ----------------------------------------------------------------
   19. CONTACT PREVIEW
   ---------------------------------------------------------------- */
.contact-preview{background:var(--white)}
.contact-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.contact-preview-info{display:flex;flex-direction:column;gap:1.2rem}
.contact-preview-item{display:flex;gap:.8rem;align-items:flex-start}
.contact-preview-icon{width:40px;height:40px;border-radius:var(--r-sm);background:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.contact-preview-text h4{font-size:.9rem;margin-bottom:.1rem}
.contact-preview-text p{font-size:.82rem}
.contact-preview-text a{color:var(--gold)}
.contact-preview-text a:hover{color:var(--gold-dark)}
.contact-map{border-radius:var(--r-md);overflow:hidden;height:100%;min-height:340px;box-shadow:var(--sh-sm);border:1px solid var(--border)}
.contact-map iframe{width:100%;height:100%;border:0}

/* ----------------------------------------------------------------
   20. NEWSLETTER
   ---------------------------------------------------------------- */
.newsletter-section{background:var(--dark);color:var(--white);text-align:center;padding:4.5rem 0}
.newsletter-section .section-label{color:var(--gold-light)}
.newsletter-section h2{color:var(--white);margin-bottom:.6rem}
.newsletter-section p{color:rgba(255,255,255,.55);max-width:460px;margin:0 auto 2rem}
.newsletter-form{display:flex;max-width:440px;margin:0 auto;gap:0;border-radius:var(--r-sm);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.newsletter-form input{flex:1;padding:.85rem 1.2rem;background:rgba(255,255,255,.06);color:var(--white);font-size:.85rem;border:none}
.newsletter-form input::placeholder{color:rgba(255,255,255,.35)}
.newsletter-form button{padding:.85rem 1.8rem;background:var(--gold);color:var(--white);font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;border:none;cursor:pointer;transition:background var(--t-fast);white-space:nowrap}
.newsletter-form button:hover{background:var(--gold-dark)}

/* ----------------------------------------------------------------
   21. FOOTER
   ---------------------------------------------------------------- */
.site-footer{background:var(--dark);color:rgba(255,255,255,.65);padding:5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand .nav-logo{color:var(--white);margin-bottom:1rem;display:inline-block}
.footer-brand p{font-size:.82rem;color:rgba(255,255,255,.4);max-width:260px;line-height:1.7}
.footer-col h4{font-family:var(--font-sans);font-size:.65rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.footer-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.45);padding:.25rem 0;transition:color var(--t-fast)}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.72rem;color:rgba(255,255,255,.3)}
.footer-social{display:flex;gap:.8rem}
.footer-social a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:rgba(255,255,255,.4);transition:all var(--t-fast)}
.footer-social a:hover{background:var(--gold);border-color:var(--gold);color:var(--white)}

/* ----------------------------------------------------------------
   22. CART SIDEBAR
   ---------------------------------------------------------------- */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:2000;opacity:0;visibility:hidden;transition:all var(--t-base)}
.cart-overlay.active{opacity:1;visibility:visible}
.cart-sidebar{position:fixed;top:0;right:-420px;width:400px;max-width:90vw;height:100vh;background:var(--white);z-index:2001;box-shadow:-4px 0 30px rgba(0,0,0,.1);transition:right var(--t-base);display:flex;flex-direction:column}
.cart-sidebar.active{right:0}
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 1.8rem;border-bottom:1px solid var(--border)}
.cart-header h3{font-size:1.1rem}
.cart-close{font-size:1.4rem;cursor:pointer;color:var(--dark-soft);transition:color var(--t-fast);background:none;border:none}
.cart-close:hover{color:var(--dark)}
.cart-items{flex:1;overflow-y:auto;padding:1.2rem 1.8rem}
.cart-empty{text-align:center;padding:3rem 0;color:var(--dark-soft);font-size:.88rem}
.cart-item{display:flex;gap:.8rem;padding:.8rem 0;border-bottom:1px solid var(--border);align-items:center}
.cart-item-image{width:56px;height:56px;border-radius:var(--r-sm);background:var(--cream);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}
.cart-item-image img{width:100%;height:100%;object-fit:cover}
.cart-item-image span{font-family:var(--font-serif);font-size:.7rem;color:var(--gold)}
.cart-item-info{flex:1}
.cart-item-info h4{font-size:.85rem;margin-bottom:.15rem}
.cart-item-info .cart-item-price{font-size:.8rem;color:var(--gold);font-weight:600}
.cart-item-qty{display:flex;align-items:center;gap:.4rem;margin-top:.35rem}
.cart-item-qty button{width:26px;height:26px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.8rem;cursor:pointer;transition:all var(--t-fast);background:var(--bg)}
.cart-item-qty button:hover{background:var(--gold);color:var(--white);border-color:var(--gold)}
.cart-item-qty span{font-size:.8rem;font-weight:600;min-width:18px;text-align:center}
.cart-item-remove{font-size:1rem;cursor:pointer;color:var(--dark-soft);opacity:.4;transition:all var(--t-fast);background:none;border:none}
.cart-item-remove:hover{opacity:1;color:#c9434b}
.cart-footer{padding:1.4rem 1.8rem;border-top:1px solid var(--border)}
.cart-shipping{font-size:.72rem;color:var(--dark-soft);text-align:center;margin-bottom:.8rem;padding:.5rem;background:var(--gold-pale);border-radius:var(--r-xs)}
.cart-total{display:flex;justify-content:space-between;margin-bottom:1rem}
.cart-total span:first-child{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.cart-total span:last-child{font-family:var(--font-serif);font-size:1.3rem;color:var(--gold);font-weight:600}
.cart-footer .btn{width:100%}

/* ----------------------------------------------------------------
   23. TOAST
   ---------------------------------------------------------------- */
.toast{position:fixed;bottom:2rem;right:2rem;background:var(--dark);color:var(--white);padding:.85rem 1.4rem;border-radius:var(--r-sm);font-size:.82rem;z-index:5000;transform:translateY(80px);opacity:0;transition:all var(--t-base);box-shadow:var(--sh-lg)}
.toast.show{transform:translateY(0);opacity:1}

/* ----------------------------------------------------------------
   24. LIGHTBOX — FULL (with arrows, counter, caption)
   ---------------------------------------------------------------- */
.lightbox-full{position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--t-base)}
.lightbox-full.active{opacity:1;visibility:visible}
.lightbox-overlay{position:absolute;inset:0}
.lightbox-close{position:absolute;top:1.2rem;right:1.2rem;color:white;font-size:1.8rem;cursor:pointer;z-index:3001;background:none;border:none;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast)}
.lightbox-close:hover{background:rgba(255,255,255,.12)}
.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);color:white;font-size:2.4rem;cursor:pointer;z-index:3001;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast);line-height:1}
.lightbox-arrow:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}
.lightbox-prev{left:1.2rem}
.lightbox-next{right:1.2rem}
.lightbox-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;max-width:85vw;max-height:85vh}
.lightbox-img-wrap{width:min(75vw,680px);aspect-ratio:1;border-radius:var(--r-md);overflow:hidden}
.lightbox-img-wrap img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--r-md);display:block}
.lightbox-caption{color:rgba(255,255,255,.75);font-family:var(--font-serif);font-size:1rem;margin-top:1rem;letter-spacing:.04em;text-align:center}
.lightbox-counter{color:rgba(255,255,255,.4);font-size:.72rem;font-weight:500;letter-spacing:.12em;margin-top:.4rem}

@media(max-width:768px){
  .lightbox-arrow{width:40px;height:40px;font-size:1.8rem}
  .lightbox-prev{left:.6rem}
  .lightbox-next{right:.6rem}
  .lightbox-img-wrap{width:90vw}
}

/* ----------------------------------------------------------------
   25. PAGE HEADER
   ---------------------------------------------------------------- */
.page-header{background:linear-gradient(135deg,var(--cream),var(--ivory));text-align:center;padding:calc(var(--nav-h) + var(--ann-h) + 3rem) 0 3.5rem;position:relative}
.page-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,var(--bg))}
.page-header .section-label{margin-bottom:.8rem}
.page-header h1{margin-bottom:.8rem}
.page-header p{max-width:500px;margin:0 auto;font-size:.95rem}

/* ----------------------------------------------------------------
   26. SHOP PAGE — FILTERS & SORTING
   ---------------------------------------------------------------- */
.shop-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.filter-chips{display:flex;gap:.5rem;flex-wrap:wrap}
.filter-chip{padding:.45rem 1rem;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--r-full);border:1.5px solid var(--border);color:var(--dark-soft);cursor:pointer;transition:all var(--t-fast);background:transparent}
.filter-chip:hover,.filter-chip.active{background:var(--gold);color:var(--white);border-color:var(--gold)}
.sort-select{padding:.5rem 2.2rem .5rem 1rem;font-size:.78rem;border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--dark);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23C8A97E' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center;cursor:pointer;background-color:var(--white)}

.load-more-wrap{text-align:center;margin-top:3rem}

/* ----------------------------------------------------------------
   27. GALLERY TABS
   ---------------------------------------------------------------- */
.gallery-tabs{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.gallery-tab{padding:.5rem 1.2rem;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--r-full);border:1.5px solid var(--border);color:var(--dark-soft);cursor:pointer;transition:all var(--t-fast);background:transparent}
.gallery-tab:hover,.gallery-tab.active{background:var(--gold);color:var(--white);border-color:var(--gold)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.gallery-item{position:relative;border-radius:var(--r-md);overflow:hidden;aspect-ratio:1;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-overlay{position:absolute;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-base)}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{color:var(--white);font-family:var(--font-serif);font-size:1.1rem;letter-spacing:.05em}

/* ----------------------------------------------------------------
   28. FORMS
   ---------------------------------------------------------------- */
.form-card{background:var(--white);border-radius:var(--r-md);padding:2.5rem;border:1px solid var(--border);box-shadow:var(--sh-sm);max-width:640px;margin:0 auto}
.form-group{margin-bottom:1.3rem}
.form-group label{display:block;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--dark);margin-bottom:.4rem}
.form-control{width:100%;padding:.8rem 1.1rem;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.88rem;color:var(--dark);transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.form-control:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,169,126,.1)}
.form-control::placeholder{color:#b5b0a8}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23C8A97E' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
textarea.form-control{resize:vertical;min-height:110px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.form-error{font-size:.7rem;color:#c9434b;margin-top:.3rem;display:none}
.form-group.error .form-control{border-color:#c9434b}
.form-group.error .form-error{display:block}
.form-success{text-align:center;padding:2rem;display:none}
.form-success.show{display:block}
.form-success h3{color:var(--gold);margin-bottom:.5rem}

/* ----------------------------------------------------------------
   29. ABOUT PAGE
   ---------------------------------------------------------------- */
.about-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-image{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4}
.about-text .section-label{margin-bottom:.8rem}
.about-text h2{margin-bottom:1.2rem}
.about-text p{margin-bottom:1rem}

/* ----------------------------------------------------------------
   30. CONTACT PAGE
   ---------------------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem}
.contact-info-card{background:var(--white);border-radius:var(--r-md);padding:2.2rem;border:1px solid var(--border);box-shadow:var(--sh-sm)}
.contact-item{display:flex;gap:.8rem;padding:1rem 0;border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none}
.contact-item-icon{flex-shrink:0;width:40px;height:40px;background:var(--gold-pale);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1rem}
.contact-item-text h4{font-size:.9rem;margin-bottom:.15rem}
.contact-item-text p{font-size:.82rem}
.contact-item-text a{color:var(--gold)}
.contact-item-text a:hover{color:var(--gold-dark)}
.map-container{border-radius:var(--r-md);overflow:hidden;height:100%;min-height:380px;box-shadow:var(--sh-sm);border:1px solid var(--border)}
.map-container iframe{width:100%;height:100%;border:0}
.map-actions{display:flex;gap:.6rem;margin-top:1.2rem;flex-wrap:wrap}

/* Reviews page rating bars */
.rating-bars{max-width:320px;margin:0 auto 2.5rem}
.rating-bar-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem;font-size:.78rem}
.rating-bar-row span:first-child{width:20px;text-align:right;font-weight:600}
.rating-bar-track{flex:1;height:6px;background:var(--cream);border-radius:3px;overflow:hidden}
.rating-bar-fill{height:100%;background:var(--gold);border-radius:3px}
.rating-bar-row span:last-child{width:30px;color:var(--dark-soft);font-size:.72rem}

/* ----------------------------------------------------------------
   31. IMAGE UTILITIES
   ---------------------------------------------------------------- */
.img-cover{width:100%;height:100%;object-fit:cover;display:block}

/* ----------------------------------------------------------------
   32. SCROLL ANIMATIONS
   ---------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.95);transition:opacity .7s ease,transform .7s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ----------------------------------------------------------------
   33. SHOP PAGE — SIDEBAR LAYOUT
   ---------------------------------------------------------------- */
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:2.5rem;align-items:start}
.shop-sidebar{position:sticky;top:calc(var(--nav-h) + 1.5rem)}
.shop-main{min-width:0}

.shop-search-wrap{position:relative;margin-bottom:1.5rem}
.shop-search{width:100%;padding:.75rem 1rem .75rem 2.4rem;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.85rem;background:var(--white);transition:border-color var(--t-fast)}
.shop-search:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,169,126,.1)}
.shop-search-icon{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);font-size:.85rem;color:var(--dark-soft);pointer-events:none}

.shop-top-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.8rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.shop-top-bar-left{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.product-count{font-size:.82rem;color:var(--dark-soft)}
.mobile-filter-btn{display:none;padding:.5rem 1rem;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;background:var(--white);transition:all var(--t-fast)}
.mobile-filter-btn:hover{border-color:var(--gold);color:var(--gold)}

/* Sidebar filter groups */
.filter-group{margin-bottom:1.8rem}
.filter-group-title{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--dark);margin-bottom:.8rem;display:block}
.filter-option{display:flex;align-items:center;gap:.6rem;padding:.35rem 0;cursor:pointer;font-size:.84rem;color:var(--dark-soft);transition:color var(--t-fast)}
.filter-option:hover{color:var(--dark)}
.filter-cb{width:16px;height:16px;accent-color:var(--gold);cursor:pointer}
.filter-option span{flex:1}
.filter-count{font-size:.72rem;color:var(--dark-soft);opacity:.5}

/* Price range slider */
.price-range-wrap{padding-top:.3rem}
.price-range-label{font-size:.82rem;color:var(--dark-soft);margin-bottom:.5rem;display:block}
.price-range{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:var(--cream);border-radius:2px;outline:none;cursor:pointer}
.price-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.price-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;border:none;box-shadow:0 1px 4px rgba(0,0,0,.15)}

/* Tag chips in sidebar */
.tag-chips{display:flex;flex-wrap:wrap;gap:.4rem}
.tag-chip{padding:.35rem .8rem;font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r-full);border:1.5px solid var(--border);color:var(--dark-soft);cursor:pointer;transition:all var(--t-fast);background:transparent}
.tag-chip:hover,.tag-chip.active{background:var(--gold);color:var(--white);border-color:var(--gold)}

.shop-empty{text-align:center;padding:4rem 2rem;grid-column:1 / -1}
.shop-empty p{margin-bottom:1rem;font-size:.95rem}

/* Mobile filter overlay */
.filter-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:2000;opacity:0;visibility:hidden;transition:all var(--t-base)}
.filter-overlay.active{opacity:1;visibility:visible}
.filter-close-btn{display:none;position:absolute;top:1rem;right:1rem;font-size:1.2rem;cursor:pointer;background:none;border:none;color:var(--dark-soft)}

/* Product card rating */
.product-card-rating{color:var(--gold);font-size:.72rem;margin-bottom:.5rem;letter-spacing:.03em}

/* ----------------------------------------------------------------
   34. PRODUCT PAGE
   ---------------------------------------------------------------- */
.breadcrumb{font-size:.78rem;color:var(--dark-soft);margin-bottom:2rem;display:flex;align-items:center;flex-wrap:wrap;gap:.3rem}
.breadcrumb a{color:var(--dark-soft);transition:color var(--t-fast)}
.breadcrumb a:hover{color:var(--gold)}
.bc-sep{color:var(--border);margin:0 .1rem}
.bc-current{color:var(--dark);font-weight:500}

.product-page-main{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;margin-bottom:3.5rem}
.product-gallery{position:sticky;top:calc(var(--nav-h) + 1.5rem)}
.product-gallery-main{border-radius:var(--r-md);overflow:hidden;aspect-ratio:1;margin-bottom:1rem;background:var(--cream)}
.product-gallery-main img{width:100%;height:100%;object-fit:cover}
.product-gallery-thumbs{display:flex;gap:.6rem}
.thumb-btn{width:72px;height:72px;border-radius:var(--r-sm);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color var(--t-fast);padding:0;background:none}
.thumb-btn.active,.thumb-btn:hover{border-color:var(--gold)}
.thumb-btn img{width:100%;height:100%;object-fit:cover}

.product-info .section-label{margin-bottom:.5rem}
.product-info h1{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.5rem}
.product-info-subtitle{font-size:.95rem;color:var(--dark-soft);margin-bottom:.8rem}
.product-info-rating{color:var(--gold);font-size:.9rem;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}
.rating-count{font-size:.78rem;color:var(--dark-soft)}
.product-info-price{font-family:var(--font-serif);font-size:1.8rem;color:var(--gold);font-weight:600;margin-bottom:1.2rem}
.product-info-desc{font-size:.9rem;line-height:1.8;margin-bottom:1.5rem}

.product-info-qty{margin-bottom:1.5rem}
.product-info-qty label{display:block;font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.5rem}
.qty-selector{display:inline-flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden}
.qty-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:all var(--t-fast);background:var(--bg);border:none}
.qty-btn:hover{background:var(--gold);color:var(--white)}
.qty-selector span{width:40px;text-align:center;font-size:.9rem;font-weight:600}

.product-info-actions{display:flex;gap:.8rem;margin-bottom:1.2rem}
.product-info-actions .btn-primary{flex:1}
.wishlist-btn{width:48px;font-size:1.3rem;display:flex;align-items:center;justify-content:center;padding:0;transition:color var(--t-fast),border-color var(--t-fast)}
.wishlist-btn.active{color:#c9434b;border-color:#c9434b}
.nav-wishlist,.nav-cart{display:inline-flex;align-items:center;gap:.35rem;position:relative}
.nav-icon{font-size:1rem;opacity:.9}
.wishlist-count{background:var(--gold);color:var(--white);font-size:.55rem;font-weight:700;min-width:17px;height:17px;padding:0 4px;border-radius:50%;display:none;align-items:center;justify-content:center;position:absolute;top:-6px;right:-8px}

.product-info-tags{margin-bottom:1rem}
.product-tag{display:inline-block;padding:.3rem .8rem;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--r-full);background:var(--gold-pale);color:var(--gold-dark)}
.product-info-shipping{font-size:.78rem;color:var(--dark-soft);padding:.6rem 0;border-top:1px solid var(--border)}

/* Product tabs */
.product-tabs-section{margin-bottom:3.5rem}
.product-tabs-nav{display:flex;gap:0;border-bottom:1.5px solid var(--border);margin-bottom:1.5rem}
.product-tab{padding:.8rem 1.5rem;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dark-soft);cursor:pointer;border:none;background:none;position:relative;transition:color var(--t-fast)}
.product-tab::after{content:'';position:absolute;bottom:-1.5px;left:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transition:transform var(--t-base)}
.product-tab:hover,.product-tab.active{color:var(--dark)}
.product-tab.active::after{transform:scaleX(1)}
.product-tab-content{display:none;font-size:.9rem;line-height:1.8;color:var(--dark-soft)}
.product-tab-content.active{display:block}

.product-review{padding:1.2rem 0;border-bottom:1px solid var(--border)}
.product-review:last-child{border-bottom:none}

.related-products{margin-bottom:2rem}

/* ----------------------------------------------------------------
   35. CART PAGE
   ---------------------------------------------------------------- */
.cart-page-empty{text-align:center;padding:4rem 0}
.cart-page-empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}
.cart-page-empty h2{margin-bottom:.5rem}
.cart-page-empty p{margin-bottom:1.5rem;color:var(--dark-soft)}

.cart-page-grid{display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start}
.cart-page-header-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 40px;gap:1rem;padding:.8rem 0;border-bottom:1.5px solid var(--border);font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--dark-soft)}

.cart-page-item{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 40px;gap:1rem;align-items:center;padding:1.2rem 0;border-bottom:1px solid var(--border)}
.cpi-product{display:flex;gap:.8rem;align-items:center}
.cpi-image{width:60px;height:60px;border-radius:var(--r-sm);background:var(--cream);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.cpi-image img{width:100%;height:100%;object-fit:cover}
.cpi-image span{font-family:var(--font-serif);font-size:.85rem;color:var(--gold)}
.cpi-info h4{font-size:.9rem;margin-bottom:.1rem}
.cpi-price{font-size:.88rem;color:var(--dark-soft)}
.cpi-total{font-weight:600;font-family:var(--font-serif);font-size:1rem;color:var(--gold)}
.cpi-remove{font-size:1.1rem;cursor:pointer;color:var(--dark-soft);opacity:.4;transition:all var(--t-fast);background:none;border:none;width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.cpi-remove:hover{opacity:1;color:#c9434b}

.cart-page-summary{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:2rem;box-shadow:var(--sh-sm);position:sticky;top:calc(var(--nav-h) + 1.5rem)}
.cart-page-summary h3{font-size:1.2rem;margin-bottom:1.5rem}
.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.88rem}
.summary-row:last-of-type{padding-bottom:.8rem}
.summary-free{color:var(--gold);font-weight:500}
.summary-divider{height:1px;background:var(--border);margin:.5rem 0}
.summary-total{font-weight:600;font-size:1rem}
.summary-total span:last-child{font-family:var(--font-serif);font-size:1.3rem;color:var(--gold)}
.promo-code-wrap{display:flex;gap:.5rem;margin:1.2rem 0}
.promo-input{flex:1}
.summary-checkout{width:100%;margin-bottom:.6rem}
.summary-continue{width:100%}
.summary-shipping-note{font-size:.72rem;color:var(--dark-soft);text-align:center;margin-top:1rem}

/* ----------------------------------------------------------------
   WISHLIST PAGE
   ---------------------------------------------------------------- */
.wishlist-empty{text-align:center;padding:4rem 2rem}
.wishlist-empty-icon{font-size:3.5rem;color:var(--gold);opacity:.6;margin-bottom:1rem}
.wishlist-empty h2{font-size:1.6rem;margin-bottom:.5rem}
.wishlist-empty p{margin-bottom:1.5rem;color:var(--dark-soft)}
.wishlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.8rem}
.wishlist-card{background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-xs);border:1px solid var(--border);transition:all var(--t-base)}
.wishlist-card:hover{box-shadow:var(--sh-md)}
.wishlist-card-image{display:block;height:220px;overflow:hidden;background:var(--cream)}
.wishlist-card-image img{width:100%;height:100%;object-fit:cover}
.wishlist-card-body{padding:1.3rem}
.wishlist-card-body h3{font-size:1.05rem;margin-bottom:.4rem;font-weight:500}
.wishlist-card-body h3 a{color:inherit;text-decoration:none}
.wishlist-card-body h3 a:hover{color:var(--gold)}
.wishlist-card-price{font-family:var(--font-serif);font-size:1.15rem;color:var(--gold);font-weight:600;display:block;margin-bottom:1rem}
.wishlist-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.wishlist-card-actions .btn{flex:1;min-width:0}

/* ----------------------------------------------------------------
   CHECKOUT PAGE
   ---------------------------------------------------------------- */
.checkout-section{padding-bottom:4rem}
.checkout-empty{max-width:480px;margin:0 auto}
.checkout-grid{display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start}
.checkout-form-col .form-group{margin-bottom:1.2rem}
.checkout-block-title{font-size:1.1rem;margin:1.8rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.checkout-block-title:first-child{margin-top:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.delivery-options{display:flex;flex-direction:column;gap:.6rem}
.delivery-option{display:flex;flex-wrap:wrap;align-items:flex-start;gap:.5rem;padding:1rem;border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast)}
.delivery-option:hover,.delivery-option:has(input:checked){border-color:var(--gold);background:var(--gold-pale)}
.delivery-option input{margin-top:.2rem}
.delivery-option-label{font-weight:600;font-size:.9rem;display:block;width:100%}
.delivery-option-desc{font-size:.8rem;color:var(--dark-soft);display:block}
.checkout-summary-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:2rem;box-shadow:var(--sh-sm);position:sticky;top:calc(var(--nav-h) + 1.5rem)}
.checkout-summary-card h3{font-size:1.2rem;margin-bottom:1.2rem}
.checkout-summary-items{max-height:200px;overflow-y:auto;margin-bottom:.8rem}
.checkout-summary-row{display:flex;justify-content:space-between;font-size:.85rem;padding:.35rem 0}
.checkout-summary-name{color:var(--dark-soft)}
.required{color:#c9434b}

@media(max-width:900px){
  .checkout-grid{grid-template-columns:1fr}
  .checkout-summary-card{position:static}
}

/* ----------------------------------------------------------------
   PAYMENT PAGE
   ---------------------------------------------------------------- */
.payment-section{padding-bottom:4rem}
.payment-grid{display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start}
.payment-secure-note{font-size:.8rem;color:var(--dark-soft);margin-bottom:1rem}
.payment-methods{display:flex;flex-direction:column;gap:.5rem}
.payment-method{display:flex;align-items:center;gap:.8rem;padding:1rem;border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast)}
.payment-method:hover,.payment-method:has(input:checked){border-color:var(--gold);background:var(--gold-pale)}
.payment-method-label{font-weight:500;font-size:.95rem}
.payment-summary-card{position:sticky;top:calc(var(--nav-h) + 1.5rem)}
.payment-success{text-align:center;max-width:520px;margin:0 auto;padding:3rem 2rem}
.payment-success-icon{width:72px;height:72px;border-radius:50%;background:var(--gold);color:var(--white);font-size:2.2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-weight:700}
.payment-success h2{font-size:1.8rem;margin-bottom:.8rem}
.payment-success p{margin-bottom:.8rem;color:var(--dark-soft)}
.payment-success-note{font-size:.85rem;color:var(--gold);font-weight:500}
.payment-success-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}

@media(max-width:900px){
  .payment-grid{grid-template-columns:1fr}
  .payment-summary-card{position:static}
}

/* ----------------------------------------------------------------
   36. QUICK VIEW MODAL
   ---------------------------------------------------------------- */
.quick-view-overlay{position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--t-base);padding:2rem}
.quick-view-overlay.active{opacity:1;visibility:visible}
.quick-view-content{background:var(--white);border-radius:var(--r-md);max-width:800px;width:100%;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;position:relative;box-shadow:var(--sh-lg);max-height:90vh}
.quick-view-close{position:absolute;top:.8rem;right:.8rem;font-size:1.4rem;cursor:pointer;z-index:1;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--border);transition:all var(--t-fast);color:var(--dark)}
.quick-view-close:hover{background:var(--gold);color:var(--white);border-color:var(--gold)}
.quick-view-image{aspect-ratio:1;background:var(--cream)}
.quick-view-image img{width:100%;height:100%;object-fit:cover}
.quick-view-info{padding:2rem;display:flex;flex-direction:column;justify-content:center;overflow-y:auto}
.quick-view-info h3{margin-bottom:.3rem}
.quick-view-info .product-subtitle{margin-bottom:.5rem}
.quick-view-info .product-card-rating{margin-bottom:.5rem}
.quick-view-info .product-price{margin-bottom:1rem}
.quick-view-desc{font-size:.84rem;line-height:1.7;color:var(--dark-soft);margin-bottom:1.5rem}
.quick-view-actions{display:flex;gap:.6rem}
.quick-view-actions .btn{flex:1}

/* ----------------------------------------------------------------
   37. RESPONSIVE — EXTENDED
   ---------------------------------------------------------------- */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .categories-grid{grid-template-columns:repeat(3,1fr)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .inspiration-grid{grid-template-columns:repeat(2,1fr)}
  .cart-page-grid{grid-template-columns:1fr}
  .cart-page-summary{position:static}
}

@media(max-width:900px){
  .shop-layout{grid-template-columns:1fr}
  .shop-sidebar{position:fixed;top:0;left:-320px;width:300px;max-width:85vw;height:100vh;background:var(--white);z-index:2001;padding:1.5rem;overflow-y:auto;transition:left var(--t-base);box-shadow:4px 0 30px rgba(0,0,0,.1)}
  .shop-sidebar.active{left:0}
  .mobile-filter-btn{display:inline-flex}
  .filter-close-btn{display:block}
  .product-page-main{grid-template-columns:1fr;gap:2rem}
  .product-gallery{position:static}
  .quick-view-content{grid-template-columns:1fr;max-height:90vh;overflow-y:auto}
  .quick-view-image{aspect-ratio:4/3}
}

@media(max-width:768px){
  :root{--nav-h:60px;--ann-h:34px}
  section{padding:4rem 0}
  .container{padding:0 1.2rem}

  .nav-links{position:fixed;top:0;right:-100%;width:82%;max-width:320px;height:100vh;background:var(--white);flex-direction:column;align-items:flex-start;padding:5rem 2rem 2rem;gap:1.3rem;box-shadow:-4px 0 30px rgba(0,0,0,.08);transition:right var(--t-base);z-index:999}
  .nav-links.active{right:0}
  .nav-toggle{display:flex}

  .hero-content h1{font-size:2rem}
  .categories-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}
  .category-card{aspect-ratio:4/5}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .services-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .social-grid{grid-template-columns:repeat(2,1fr)}
  .about-content,.contact-grid,.contact-preview-grid{grid-template-columns:1fr;gap:2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .page-header{padding:calc(var(--nav-h) + var(--ann-h) + 2rem) 0 2.5rem}
  .shop-controls{flex-direction:column;align-items:flex-start}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .promo-banner{padding:4rem 0}
  .newsletter-form{flex-direction:column;border-radius:var(--r-sm)}
  .newsletter-form input,.newsletter-form button{border-radius:0}

  .cart-page-header-row{display:none}
  .cart-page-item{grid-template-columns:1fr;gap:.6rem;padding:1rem 0}
  .cpi-product{order:1}.cpi-price{order:2;font-weight:600}.cpi-qty{order:3}.cpi-total{order:4;font-size:1.1rem}.cpi-remove{order:5;position:absolute;right:0;top:1rem}
  .cart-page-item{position:relative}
  .product-tabs-nav{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .product-tab{white-space:nowrap}
}

@media(max-width:480px){
  .products-grid{grid-template-columns:1fr}
  .categories-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .hero-buttons{flex-direction:column;align-items:center}
  .hero-buttons .btn{width:100%;max-width:280px}
  .inspiration-grid{grid-template-columns:1fr}
  .social-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .product-gallery-thumbs{gap:.4rem}
  .thumb-btn{width:56px;height:56px}
}

/* ----------------------------------------------------------------
   38. SERVICE DETAIL PAGES
   ---------------------------------------------------------------- */
.service-hero{position:relative;background:var(--cream);text-align:center;padding:calc(var(--nav-h) + var(--ann-h) + 3rem) 0 3.5rem;overflow:hidden}
.service-hero .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.25}
.service-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,var(--bg))}
.service-hero .breadcrumb{justify-content:center;margin-bottom:1.2rem}
.service-hero .section-label{margin-bottom:.8rem}
.service-hero h1{margin-bottom:.5rem}
.service-hero p{max-width:560px;margin:0 auto;font-size:.95rem}

.service-detail{padding:4rem 0}
.service-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.service-detail-image{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;position:sticky;top:calc(var(--nav-h) + 1.5rem);background:var(--cream)}
.service-detail-image img{width:100%;height:100%;object-fit:cover}
.service-detail-content h2{font-size:clamp(1.4rem,2.5vw,1.8rem);margin-bottom:1rem}
.service-detail-content p{margin-bottom:1.2rem;font-size:.9rem;line-height:1.8}

.service-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin:2rem 0}
.service-info-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);padding:1.5rem;text-align:center;transition:all var(--t-base)}
.service-info-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.service-info-card .sic-icon{font-size:1.5rem;margin-bottom:.6rem}
.service-info-card h4{font-size:.9rem;margin-bottom:.2rem}
.service-info-card p{font-size:.82rem}

.service-list{margin:1.5rem 0}
.service-list li{padding:.45rem 0 .45rem 1.6rem;position:relative;font-size:.88rem;color:var(--dark-soft)}
.service-list li::before{content:'✓';position:absolute;left:0;color:var(--gold);font-weight:700}

.service-cta-bar{background:linear-gradient(135deg,var(--cream),var(--ivory));padding:3.5rem 0;text-align:center}
.service-cta-buttons{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}

.service-related-section{padding:4rem 0}
.service-related-section h2{text-align:center;margin-bottom:2rem}

@media(max-width:900px){
  .service-detail-grid{grid-template-columns:1fr;gap:2rem}
  .service-detail-image{position:static;aspect-ratio:3/2}
  .service-info-grid{grid-template-columns:1fr}
}

/* ----------------------------------------------------------------
   39. CONTACT FORM SUCCESS
   ---------------------------------------------------------------- */
.contact-form-success{text-align:center;padding:2rem;display:none}
.contact-form-success.show{display:block}
.contact-form-success h3{color:var(--gold);margin-bottom:.5rem}

/* ----------------------------------------------------------------
   40. FAQ ACCORDION
   ---------------------------------------------------------------- */
.faq-section{margin-top:3rem}
.faq-item{border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:.6rem;overflow:hidden;transition:box-shadow var(--t-fast)}
.faq-item:hover{box-shadow:var(--sh-xs)}
.faq-question{width:100%;padding:1rem 1.4rem;display:flex;align-items:center;justify-content:space-between;font-size:.88rem;font-weight:600;color:var(--dark);cursor:pointer;background:var(--white);border:none;text-align:left;transition:background var(--t-fast)}
.faq-question:hover{background:var(--bg)}
.faq-question .faq-icon{font-size:1rem;color:var(--gold);transition:transform var(--t-fast)}
.faq-item.open .faq-question .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 1.4rem}
.faq-item.open .faq-answer{max-height:300px;padding:.5rem 1.4rem 1.2rem}
.faq-answer p{font-size:.85rem;color:var(--dark-soft);line-height:1.7}
