/*
Theme Name: Miniora Perfume
Theme URI: https://miniora.com
Author: Miniora Studio
Description: Luxury mini perfume e-commerce WordPress theme. Soft rose tones, serif typography, and delightful micro-animations. WooCommerce ready.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
WC requires at least: 7.0
WC tested up to: 8.5
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: miniora
Tags: e-commerce, woocommerce, custom-colors, custom-logo, custom-menu, featured-images
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --rose:        #d4a59a;
  --rose-light:  #e8b5a8;
  --rose-hover:  #c49585;
  --rose-pale:   rgba(255,212,212,0.25);
  --bg:          #fef8f5;
  --bg2:         #ffeee8;
  --white:       #ffffff;
  --text:        #252525;
  --muted:       #8b6f61;
  --serif:       'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:        'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --r-sm:        10px;
  --r-md:        18px;
  --r-lg:        24px;
  --r-xl:        32px;
  --r-pill:      9999px;
  --ease:        cubic-bezier(0.25,0.1,0.25,1);
  --ease-bounce: cubic-bezier(0.34,1.56,0.64,1);
  --sh-sm:  0 2px 16px rgba(212,165,154,0.12);
  --sh-md:  0 8px 32px rgba(212,165,154,0.18);
  --sh-lg:  0 16px 56px rgba(212,165,154,0.22);
  --sh-xl:  0 24px 80px rgba(212,165,154,0.28);
  --wrap:   1280px;
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
ul,ol{list-style:none}
button,input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none;background:none;cursor:pointer}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.15;color:var(--text)}

/* ============================================================
   UTILITIES
   ============================================================ */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--r-pill);font-size:.875rem;letter-spacing:.05em;font-weight:500;transition:all .3s var(--ease);white-space:nowrap;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--rose),var(--rose-light));color:#fff;box-shadow:var(--sh-md)}
.btn-primary:hover{background:linear-gradient(135deg,var(--rose-hover),var(--rose));transform:translateY(-2px) scale(1.04);box-shadow:0 14px 44px rgba(212,165,154,.45);color:#fff}
.btn-primary:active{transform:scale(.97)}
.btn-outline{border:2px solid rgba(212,165,154,.5);color:var(--muted);background:transparent}
.btn-outline:hover{border-color:var(--rose);background:rgba(255,255,255,.8);color:var(--rose);transform:translateY(-2px) scale(1.04)}
.btn-white{background:#fff;color:var(--rose);box-shadow:var(--sh-lg)}
.btn-white:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 20px 60px rgba(0,0,0,.2);color:var(--rose)}

/* Scroll-reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}

/* ============================================================
   FLOATING BACKGROUND
   ============================================================ */
.float-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.float-heart{position:absolute;font-size:1.5rem;animation:floatUp 4s ease-in-out infinite;opacity:0}
.float-heart:nth-child(1){left:10%;animation-delay:0s}
.float-heart:nth-child(2){left:30%;animation-delay:1s}
.float-heart:nth-child(3){left:50%;animation-delay:2s}
.float-heart:nth-child(4){left:70%;animation-delay:1.5s}
.float-heart:nth-child(5){left:90%;animation-delay:.5s}
@keyframes floatUp{0%{transform:translateY(100vh);opacity:0}15%{opacity:1}85%{opacity:1}100%{transform:translateY(-120px);opacity:0}}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(254,248,245,.93);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,212,212,.3);
  animation:slideDown .6s var(--ease) both;
  transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{box-shadow:0 4px 24px rgba(212,165,154,.15)}
@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}

.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:80px}

.site-logo{font-family:var(--serif);font-size:2rem;letter-spacing:-.02em;position:relative;transition:color .25s var(--ease);display:flex;align-items:center}
.site-logo:hover{color:var(--rose)}
.logo-star{position:absolute;top:-8px;right:-14px;font-size:.75rem;opacity:0;transition:opacity .25s var(--ease);animation:spin1 1s ease-in-out infinite}
.site-logo:hover .logo-star{opacity:1}
@keyframes spin1{0%,100%{transform:rotate(0) scale(1)}50%{transform:rotate(20deg) scale(1.2)}}

.nav-links{display:flex;align-items:center;gap:28px}
.nav-link{font-size:.875rem;letter-spacing:.05em;position:relative;padding-bottom:2px;transition:color .25s var(--ease)}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--rose);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-link:hover,.nav-link.active{color:var(--rose)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}

.nav-icon{position:relative;color:var(--text);transition:all .25s var(--ease);display:flex;align-items:center}
.nav-icon:hover{color:var(--rose);transform:scale(1.2)}
.nav-icon svg{width:22px;height:22px;stroke-width:1.5}
.nav-badge{position:absolute;top:-8px;right:-8px;background:var(--rose);color:#fff;font-size:.625rem;font-weight:700;width:18px;height:18px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;animation:badgePulse 1.5s ease-in-out infinite}
@keyframes badgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;z-index:300}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.mobile-nav{
  position:fixed;inset:0;z-index:190;
  background:rgba(254,248,245,.97);backdrop-filter:blur(18px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease);
}
.mobile-nav.open{opacity:1;pointer-events:all}
.mobile-nav .nav-link{font-family:var(--serif);font-size:2rem;color:var(--text)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100vh;padding-top:80px;
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);
  display:flex;align-items:center;position:relative;overflow:hidden;
}
.hero .wrap{width:100%}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:80px 0}
.hero-content{animation:fadeLeft .8s .2s both}
@keyframes fadeLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:none}}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;padding:8px 18px;
  background:rgba(255,255,255,.65);backdrop-filter:blur(8px);
  border-radius:var(--r-pill);font-size:.875rem;color:var(--muted);
  margin-bottom:28px;animation:fadeUp .6s .4s both;
}
.hero-badge svg{width:16px;height:16px;color:var(--rose)}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.hero-title{font-size:clamp(3rem,5.5vw,5rem);letter-spacing:-.02em;line-height:1.08;margin-bottom:24px}
.hero-title .accent{color:var(--rose)}
.hero-subtitle{font-size:1.2rem;color:var(--muted);max-width:480px;line-height:1.75;margin-bottom:36px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:16px}

.btn-hero{animation:bob 2s ease-in-out infinite;position:relative;overflow:hidden}
.btn-hero:hover{animation-play-state:paused}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* Hero image */
.hero-img-wrap{animation:fadeScale 1s .3s both}
@keyframes fadeScale{from{opacity:0;transform:scale(.9) rotate(3deg)}to{opacity:1;transform:none}}

.hero-img-inner{animation:heroFloat 4s ease-in-out infinite;position:relative}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}

.hero-img-box{aspect-ratio:3/4;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-xl);position:relative}
.hero-img-box img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.hero-img-box:hover img{transform:scale(1.05)}
.hero-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(212,165,154,.18),transparent)}

.hero-badge-deco{position:absolute;background:linear-gradient(135deg,#fff,#fff5f3);border-radius:var(--r-md);box-shadow:var(--sh-xl);padding:20px;font-size:2.25rem;cursor:pointer;transition:transform .3s var(--ease-bounce)}
.hero-badge-deco:hover{transform:scale(1.3) rotate(20deg)!important}
.deco-tr{top:-24px;right:-24px;animation:deco1 3s ease-in-out infinite}
.deco-bl{bottom:-24px;left:-24px;animation:deco2 3.5s ease-in-out infinite}
@keyframes deco1{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-15px) rotate(10deg)}}
@keyframes deco2{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(20px) rotate(-10deg)}}

.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--rose);animation:scrollHint 1.5s ease-in-out infinite;font-size:.8125rem;letter-spacing:.08em}
.scroll-hint .arr{animation:blink 1.5s ease-in-out infinite}
@keyframes scrollHint{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(10px)}}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:1}}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.sec-head{text-align:center;margin-bottom:64px}
.sec-emoji{font-size:3rem;display:block;margin-bottom:16px;animation:wiggle 2s ease-in-out infinite}
@keyframes wiggle{0%,100%{transform:rotate(0) scale(1)}25%{transform:rotate(10deg) scale(1.12)}75%{transform:rotate(-10deg) scale(1.12)}}
.sec-title{font-size:clamp(2.25rem,4.5vw,3.75rem);letter-spacing:-.02em;margin-bottom:14px}
.sec-sub{font-size:1.0625rem;color:var(--muted);max-width:560px;margin:0 auto;line-height:1.75}

/* ============================================================
   PRODUCT GRID & CARDS
   ============================================================ */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:960px){.products-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.products-grid{grid-template-columns:1fr}}

.pcard{
  background:#fff;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--sh-sm);border:2px solid var(--rose-pale);
  transition:all .3s var(--ease);position:relative;display:block;
}
.pcard:hover{transform:translateY(-10px) scale(1.02);box-shadow:var(--sh-xl);border-color:rgba(212,165,154,.4)}

.pcard-img{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:var(--r-xl) var(--r-xl) 0 0}
/* Image link fills the entire pcard-img area */
.pcard-img-lnk{display:block;width:100%;height:100%;position:absolute;inset:0;z-index:1}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);display:block}
.pcard:hover .pcard-img img{transform:scale(1.1)}
/* Buttons sit above the link in z-index */
.pcard-wish,.pcard-qadd{position:absolute;z-index:2}

.pcard-sparkle{position:absolute;top:14px;left:14px;color:var(--rose);opacity:0;transition:opacity .25s;animation:sparkFloat 2s ease-in-out infinite}
.pcard:hover .pcard-sparkle{opacity:1}
@keyframes sparkFloat{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(10deg)}}
.pcard-sparkle svg{width:24px;height:24px}

.pcard-wish{
  position:absolute;top:14px;right:14px;
  width:40px;height:40px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.92);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--sh-sm);transition:all .25s var(--ease-bounce);color:#aaa;
}
.pcard-wish:hover{transform:scale(1.2);color:var(--rose)}
.pcard-wish.active{color:var(--rose)}
.pcard-wish.active svg{fill:currentColor}
.pcard-wish svg{width:20px;height:20px}

.pcard-qadd{
  position:absolute;bottom:14px;left:14px;right:14px;
  opacity:0;transform:translateY(10px);transition:all .25s var(--ease);
}
.pcard:hover .pcard-qadd{opacity:1;transform:none}
.pcard-qadd-btn{
  width:100%;background:linear-gradient(135deg,var(--rose),var(--rose-light));
  color:#fff;padding:12px;border-radius:var(--r-pill);
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:.875rem;box-shadow:var(--sh-lg);transition:all .25s var(--ease);border:none;cursor:pointer;
}
.pcard-qadd-btn:hover{transform:scale(1.03);box-shadow:0 12px 36px rgba(212,165,154,.5)}
.pcard-qadd-btn svg{width:18px;height:18px}

.pcard-info{padding:22px}
.pcard-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}
.pcard-name{font-family:var(--serif);font-size:1.2rem;transition:color .25s var(--ease)}
.pcard:hover .pcard-name{color:var(--rose)}
.pcard-price{font-family:var(--serif);font-size:1.1rem;color:var(--rose);white-space:nowrap;animation:priceGlow 2s ease-in-out infinite}
@keyframes priceGlow{0%,100%{opacity:1}50%{opacity:.82}}
.pcard-desc{font-size:.875rem;color:var(--muted);line-height:1.6;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard-meta{font-size:.75rem;color:var(--rose);display:flex;align-items:center;gap:6px}
.pcard-corner{position:absolute;bottom:-8px;right:-8px;font-size:2.5rem;opacity:.15;pointer-events:none;animation:cornerPop 3s ease-in-out infinite}
@keyframes cornerPop{0%,100%{transform:rotate(0) scale(1)}50%{transform:rotate(10deg) scale(1.12)}}

/* ============================================================
   SECTIONS
   ============================================================ */
.sec-featured{padding:96px 0;background:#fff;position:relative}
.sec-why{padding:96px 0;background:linear-gradient(180deg,#fff,var(--bg2))}
.sec-testimonials{padding:96px 0;background:var(--bg)}
.sec-cta{padding:96px 0;background:linear-gradient(135deg,var(--rose),var(--rose-light));color:#fff;text-align:center;position:relative;overflow:hidden}

.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.features-grid{grid-template-columns:1fr}}

.feat-card{background:#fff;border-radius:var(--r-xl);padding:40px 28px;box-shadow:var(--sh-md);border:2px solid var(--rose-pale);text-align:center;transition:all .3s var(--ease)}
.feat-card:hover{transform:translateY(-10px) scale(1.05);box-shadow:var(--sh-xl)}
.feat-icon{color:var(--rose);display:flex;justify-content:center;margin-bottom:18px;animation:iconWig 3s ease-in-out infinite}
@keyframes iconWig{0%,100%{transform:rotate(0)}25%{transform:rotate(5deg)}75%{transform:rotate(-5deg)}}
.feat-icon svg{width:36px;height:36px}
.feat-title{font-family:var(--serif);font-size:1.5rem;margin-bottom:10px}
.feat-desc{font-size:.9375rem;color:var(--muted);line-height:1.7}

.test-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media(max-width:768px){.test-grid{grid-template-columns:1fr}}
.test-card{background:#fff;border-radius:var(--r-xl);padding:36px;box-shadow:var(--sh-md);border:2px solid var(--rose-pale);transition:all .3s var(--ease)}
.test-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:var(--sh-xl)}
.stars{display:flex;gap:4px;margin-bottom:14px;color:var(--rose)}
.test-text{font-size:1rem;color:var(--muted);font-style:italic;line-height:1.8;margin-bottom:20px}
.test-author{display:flex;align-items:center;gap:12px}
.test-av{width:46px;height:46px;border-radius:var(--r-pill);background:linear-gradient(135deg,var(--rose),var(--rose-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem;flex-shrink:0}
.test-name{font-weight:600;font-size:.9375rem}
.test-label{font-size:.8125rem;color:var(--muted)}

.cta-deco{position:absolute;font-size:4rem;opacity:.18;pointer-events:none}
.cta-deco-1{top:36px;right:36px;animation:rotateDeco 20s linear infinite}
.cta-deco-2{bottom:36px;left:36px;animation:rotateDeco 25s linear infinite reverse}
@keyframes rotateDeco{to{transform:rotate(360deg)}}
.cta-title{font-size:clamp(2rem,4vw,3.5rem);color:#fff;margin-bottom:14px;position:relative;z-index:1}
.cta-sub{font-size:1.2rem;opacity:.9;margin-bottom:40px;position:relative;z-index:1}

/* ============================================================
   SHOP PAGE
   ============================================================ */
.shop-hero{padding:80px 0 48px;background:linear-gradient(180deg,var(--bg2),transparent);text-align:center}
.shop-filters{padding:16px 0 32px}
.filter-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px}
.filter-lbl{font-size:.875rem;color:var(--muted);display:flex;align-items:center;gap:6px}
.filter-lbl svg{width:15px;height:15px}
.filter-btn{padding:8px 22px;border-radius:var(--r-pill);font-size:.875rem;border:2px solid rgba(255,212,212,.35);background:#fff;color:var(--muted);cursor:pointer;transition:all .25s var(--ease)}
.filter-btn:hover{border-color:rgba(212,165,154,.4);transform:scale(1.04)}
.filter-btn.on{background:linear-gradient(135deg,var(--rose),var(--rose-light));color:#fff;border-color:transparent;box-shadow:var(--sh-md)}
.products-count{text-align:center;font-size:.875rem;color:var(--muted);margin-bottom:28px}

.benefits-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:64px 0;background:#fff}
@media(max-width:640px){.benefits-row{grid-template-columns:1fr}}
.benefit{text-align:center;transition:all .3s var(--ease)}
.benefit:hover{transform:translateY(-5px) scale(1.05)}
.benefit-emoji{font-size:3rem;display:block;margin-bottom:10px;animation:wiggle 2s ease-in-out infinite}
.benefit:nth-child(2) .benefit-emoji{animation-delay:.3s}
.benefit:nth-child(3) .benefit-emoji{animation-delay:.6s}
.benefit-title{font-family:var(--serif);font-size:1.2rem;margin-bottom:4px}
.benefit-desc{font-size:.875rem;color:var(--muted)}

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.pd-page{padding-top:80px;min-height:100vh;background:var(--bg);position:relative}
.back-btn{display:inline-flex;align-items:center;gap:8px;font-size:.9375rem;color:var(--muted);margin-bottom:32px;transition:all .25s var(--ease)}
.back-btn:hover{color:var(--rose);transform:translateX(-4px)}
.back-btn svg{width:20px;height:20px}

.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
@media(max-width:900px){.pd-grid{grid-template-columns:1fr}}

.pd-main-img{aspect-ratio:3/4;border-radius:var(--r-xl);overflow:hidden;border:4px solid rgba(255,212,212,.3);box-shadow:var(--sh-xl);position:relative;cursor:zoom-in}
.pd-main-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.pd-main-img:hover img{transform:scale(1.07)}
.pd-heart-float{position:absolute;top:25%;left:25%;font-size:2.5rem;opacity:0;pointer-events:none;transition:opacity .3s;animation:floatHeart 2s ease-in-out infinite}
.pd-main-img:hover .pd-heart-float{opacity:1}
@keyframes floatHeart{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-30px) rotate(15deg)}}
.pd-limited{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);padding:8px 16px;border-radius:var(--r-pill);font-size:.8125rem;display:flex;align-items:center;gap:6px;box-shadow:var(--sh-sm);color:var(--muted);animation:limitedPulse 2s ease-in-out infinite}
@keyframes limitedPulse{0%,100%{transform:scale(1) rotate(0)}50%{transform:scale(1.05) rotate(2deg)}}
.pd-limited svg{width:15px;height:15px;color:var(--rose)}

.pd-thumbs{display:flex;gap:12px;margin-top:14px}
.pd-thumb{aspect-ratio:1;width:76px;border-radius:var(--r-md);overflow:hidden;border:2px solid rgba(255,212,212,.35);cursor:pointer;transition:all .25s var(--ease);opacity:.6}
.pd-thumb:hover,.pd-thumb.active{border-color:var(--rose);opacity:1;transform:scale(1.08) rotate(2deg);box-shadow:var(--sh-sm)}
.pd-thumb img{width:100%;height:100%;object-fit:cover}

.pd-cat{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(212,165,154,.1);border-radius:var(--r-pill);font-size:.8125rem;color:var(--rose);margin-bottom:18px;letter-spacing:.05em}
.pd-name{font-size:clamp(2rem,3.5vw,2.75rem);letter-spacing:-.02em;margin-bottom:14px}
.pd-price{font-family:var(--serif);font-size:2rem;color:var(--rose);margin-bottom:18px}
.pd-stars{display:flex;align-items:center;gap:4px;margin-bottom:22px}
.pd-stars .rc{font-size:.875rem;color:var(--muted);margin-left:8px}
.pd-desc{font-size:1rem;color:var(--muted);line-height:1.85;margin-bottom:28px}

.scent-box{background:linear-gradient(135deg,rgba(254,248,245,.8),rgba(255,238,232,.8));border-radius:var(--r-lg);padding:22px;margin-bottom:26px;border:1px solid rgba(212,165,154,.15)}
.scent-title{font-family:var(--serif);font-size:1.1rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.scent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.scent-item{text-align:center}
.scent-lbl{font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--rose);display:block;margin-bottom:3px}
.scent-val{font-size:.8125rem;color:var(--muted)}

/* Quantity */
.qty-wrap{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.qty-lbl{font-size:.9375rem;font-weight:500}
.qty-ctrl{display:flex;align-items:center;background:#fff;border:2px solid var(--rose-pale);border-radius:var(--r-pill);overflow:hidden}
.qty-btn-sm{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--muted);cursor:pointer;transition:all .2s var(--ease);border:none;background:none}
.qty-btn-sm:hover{background:var(--rose);color:#fff}
.qty-num{min-width:40px;text-align:center;font-size:1rem;font-weight:600;transition:transform .2s var(--ease-bounce)}

/* Actions */
.pd-actions{display:flex;gap:12px;margin-bottom:26px}
.pd-atc{flex:1;background:linear-gradient(135deg,var(--rose),var(--rose-light));color:#fff;padding:18px 24px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;gap:10px;font-size:1rem;font-weight:500;box-shadow:var(--sh-lg);transition:all .3s var(--ease);border:none;cursor:pointer;letter-spacing:.03em}
.pd-atc:hover{background:linear-gradient(135deg,var(--rose-hover),var(--rose));transform:translateY(-3px) scale(1.02);box-shadow:0 18px 52px rgba(212,165,154,.5)}
.pd-atc svg{width:22px;height:22px}
.pd-wish-btn{width:58px;height:58px;border-radius:var(--r-pill);border:2px solid rgba(212,165,154,.3);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s var(--ease-bounce);flex-shrink:0;color:var(--muted)}
.pd-wish-btn:hover{border-color:var(--rose);transform:scale(1.12);background:rgba(255,212,212,.08);color:var(--rose)}
.pd-wish-btn.active{background:rgba(212,165,154,.08);border-color:var(--rose);color:var(--rose)}
.pd-wish-btn.active svg{fill:currentColor}
.pd-wish-btn svg{width:22px;height:22px}

.pd-details{display:flex;flex-direction:column;gap:10px}
.pd-row{display:flex;align-items:center;gap:12px;font-size:.9375rem}
.pd-row svg{width:18px;height:18px;color:var(--rose);flex-shrink:0}
.pd-key{color:var(--muted);min-width:80px}
.pd-val{font-weight:500}

/* ============================================================
   CART (WooCommerce override)
   ============================================================ */
.cart-page{padding-top:80px;min-height:100vh;background:var(--bg)}
.cart-header{text-align:center;padding:64px 0 48px}
.cart-grid{display:grid;grid-template-columns:2fr 1fr;gap:32px;align-items:start;padding-bottom:96px}
@media(max-width:900px){.cart-grid{grid-template-columns:1fr}}

.cart-items-list{display:flex;flex-direction:column;gap:16px}
.cart-item-card{
  background:#fff;border-radius:var(--r-xl);padding:22px;
  box-shadow:var(--sh-sm);border:2px solid var(--rose-pale);
  display:flex;gap:20px;align-items:center;
  transition:all .3s var(--ease);
}
.cart-item-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.ci-img{width:100px;height:120px;border-radius:var(--r-lg);overflow:hidden;flex-shrink:0;border:2px solid var(--rose-pale)}
.ci-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.ci-img:hover img{transform:scale(1.08)}
.ci-info{flex:1}
.ci-name{font-family:var(--serif);font-size:1.25rem;margin-bottom:4px;transition:color .25s var(--ease)}
.ci-name:hover{color:var(--rose)}
.ci-meta{font-size:.8125rem;color:var(--muted);margin-bottom:12px}
.ci-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.ci-qty{display:flex;align-items:center;background:var(--bg);border:2px solid var(--rose-pale);border-radius:var(--r-pill);padding:2px}
.ci-qty-btn{width:32px;height:32px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;background:#fff;cursor:pointer;transition:all .2s var(--ease);border:none;font-size:.875rem;color:var(--muted)}
.ci-qty-btn:hover{background:var(--rose);color:#fff}
.ci-qty-num{width:32px;text-align:center;font-size:.9375rem;font-weight:600}
.ci-price{font-family:var(--serif);font-size:1.4rem;color:var(--rose);white-space:nowrap}
.ci-remove{color:#ccc;cursor:pointer;transition:all .25s var(--ease);display:flex;align-items:center;background:none;border:none;flex-shrink:0}
.ci-remove:hover{color:#e54b4b;transform:scale(1.2) rotate(5deg)}
.ci-remove svg{width:20px;height:20px}

/* Order summary */
.order-summary{
  background:linear-gradient(135deg,#fff,#fff5f3);
  border-radius:var(--r-xl);padding:32px;
  box-shadow:var(--sh-md);border:2px solid rgba(255,212,212,.3);
  position:sticky;top:96px;
}
.os-title{font-family:var(--serif);font-size:1.6rem;margin-bottom:22px}
.os-row{display:flex;justify-content:space-between;font-size:.9375rem;color:var(--muted);margin-bottom:10px}
.os-total{border-top:2px solid var(--rose-pale);padding-top:14px;margin-top:6px;font-size:1.1rem;font-weight:700;color:var(--text)}
.os-total span:last-child{color:var(--rose);font-family:var(--serif)}

.checkout-btn-main{
  width:100%;background:linear-gradient(135deg,var(--rose),var(--rose-light));
  color:#fff;padding:18px;border-radius:var(--r-pill);
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-size:1rem;box-shadow:var(--sh-lg);transition:all .3s var(--ease);
  border:none;cursor:pointer;margin-top:20px;letter-spacing:.03em;
  position:relative;overflow:hidden;
}
.checkout-btn-main::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transform:translateX(-200%);transition:transform .6s}
.checkout-btn-main:hover{transform:translateY(-2px);box-shadow:0 16px 52px rgba(212,165,154,.5)}
.checkout-btn-main:hover::after{transform:translateX(200%)}
.checkout-btn-main svg{width:20px;height:20px}

.os-perks{margin-top:20px;display:flex;flex-direction:column;gap:8px}
.os-perk{display:flex;align-items:center;gap:10px;font-size:.875rem;color:var(--muted)}

.cart-empty-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px}
.ce-emoji{font-size:5rem;display:block;margin-bottom:22px;animation:wiggle 2s ease-in-out infinite}
.ce-title{font-family:var(--serif);font-size:2.5rem;margin-bottom:10px}
.ce-desc{font-size:1.1rem;color:var(--muted);margin-bottom:32px;max-width:400px;margin-left:auto;margin-right:auto}

/* ============================================================
   WISHLIST PAGE
   ============================================================ */
.wish-page{padding-top:80px;min-height:100vh;background:var(--bg)}
.wish-empty{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-page{padding-top:80px;min-height:100vh;background:var(--bg)}
.about-2col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:900px){.about-2col{grid-template-columns:1fr}}
.about-img{aspect-ratio:4/3;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-xl);animation:heroFloat 4s ease-in-out infinite}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-txt-title{font-size:clamp(2rem,3.5vw,2.75rem);letter-spacing:-.02em;margin-bottom:22px}
.about-p{font-size:1.0625rem;color:var(--muted);line-height:1.9;margin-bottom:16px}
.vals-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:640px){.vals-grid{grid-template-columns:1fr}}
.val-card{background:#fff;border-radius:var(--r-lg);padding:26px 20px;box-shadow:var(--sh-sm);border:2px solid var(--rose-pale);text-align:center;transition:all .3s var(--ease)}
.val-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md)}
.val-emoji{font-size:2.25rem;display:block;margin-bottom:10px}
.val-title{font-family:var(--serif);font-size:1.1rem;margin-bottom:6px}
.val-desc{font-size:.875rem;color:var(--muted);line-height:1.6}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:640px){.stat-grid{grid-template-columns:1fr}}
.stat-card{background:#fff;border-radius:var(--r-xl);padding:40px 24px;box-shadow:var(--sh-md);border:2px solid var(--rose-pale);text-align:center}
.stat-num{font-family:var(--serif);font-size:2.75rem;color:var(--rose);display:block;margin-bottom:8px}
.stat-lbl{color:var(--muted);font-size:.9375rem}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-page{padding-top:80px;min-height:100vh;background:var(--bg)}
.contact-2col{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}
@media(max-width:900px){.contact-2col{grid-template-columns:1fr}}
.cform-card{background:#fff;border-radius:var(--r-xl);padding:44px 36px;box-shadow:var(--sh-md);border:2px solid var(--rose-pale)}
.cform-title{font-family:var(--serif);font-size:1.875rem;margin-bottom:30px}
.fgroup{margin-bottom:18px}
.flabel{display:block;font-size:.9375rem;font-weight:500;margin-bottom:8px}
.finput,.ftextarea{width:100%;padding:13px 18px;border:2px solid rgba(212,165,154,.2);border-radius:var(--r-md);font-size:.9375rem;background:var(--bg);color:var(--text);transition:all .25s var(--ease);display:block}
.finput:focus,.ftextarea:focus{border-color:var(--rose);background:#fff;box-shadow:0 0 0 3px rgba(212,165,154,.14);outline:none}
.ftextarea{height:140px;resize:vertical}
.fsubmit{width:100%;background:linear-gradient(135deg,var(--rose),var(--rose-light));color:#fff;padding:15px 24px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;gap:10px;font-size:1rem;font-weight:500;box-shadow:var(--sh-md);transition:all .3s var(--ease);border:none;cursor:pointer;letter-spacing:.03em}
.fsubmit:hover{transform:translateY(-2px);box-shadow:0 14px 44px rgba(212,165,154,.45)}
.fsubmit:disabled{opacity:.7;cursor:not-allowed;transform:none}
.fsubmit svg{width:20px;height:20px}
.csuccess{text-align:center;padding:48px 0}
.csuccess-emoji{font-size:3rem;display:block;margin-bottom:14px}
.csuccess-title{font-family:var(--serif);font-size:1.6rem;margin-bottom:8px}
.ferror{color:#e54b4b;background:#fff5f5;border:1px solid rgba(229,75,75,.2);border-radius:var(--r-sm);padding:12px 16px;font-size:.9375rem;margin-bottom:16px}

.cinfo-list{display:flex;flex-direction:column;gap:16px}
.cinfo-card{background:#fff;border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-sm);border:2px solid var(--rose-pale);display:flex;align-items:flex-start;gap:14px;transition:all .3s var(--ease)}
.cinfo-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.cinfo-icon{width:46px;height:46px;border-radius:var(--r-pill);background:rgba(212,165,154,.1);display:flex;align-items:center;justify-content:center;color:var(--rose);flex-shrink:0}
.cinfo-icon svg{width:22px;height:22px}
.cinfo-title{font-weight:600;margin-bottom:3px}
.cinfo-val{font-size:.9375rem;color:var(--muted)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:linear-gradient(180deg,#fff,var(--bg2));border-top:2px solid var(--rose-pale);position:relative;overflow:hidden}
.footer-deco{position:absolute;font-size:2.5rem;opacity:.16;pointer-events:none}
.footer-deco-1{top:36px;right:36px;animation:floatBob 4s ease-in-out infinite}
.footer-deco-2{bottom:36px;left:36px;animation:floatBob 5s ease-in-out infinite reverse}
@keyframes floatBob{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-18px) rotate(8deg)}}
.footer-body{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:64px 0}
@media(max-width:900px){.footer-body{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-body{grid-template-columns:1fr}}
.footer-brand-name{font-family:var(--serif);font-size:1.875rem;letter-spacing:-.02em;display:block;margin-bottom:12px;transition:all .25s var(--ease)}
.footer-brand-name:hover{color:var(--rose);transform:scale(1.04)}
.footer-brand-desc{font-size:.875rem;color:var(--muted);line-height:1.7;margin-bottom:18px}
.footer-socials{display:flex;gap:10px}
.footer-social{width:40px;height:40px;border-radius:var(--r-pill);background:rgba(212,165,154,.1);display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.footer-social svg{width:18px;height:18px}
.footer-social:hover{background:var(--rose);color:#fff;transform:scale(1.2) rotate(5deg)}
.footer-col-title{font-family:var(--serif);font-size:1.1rem;margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-link{font-size:.9375rem;color:var(--muted);transition:color .25s var(--ease)}
.footer-link:hover{color:var(--rose)}
.footer-bottom{padding:20px 0;border-top:2px solid var(--rose-pale);display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:.875rem;color:var(--muted);flex-wrap:wrap}
.footer-love{display:flex;align-items:center;gap:6px}
.heart-anim{color:var(--rose);animation:heartbeat 1s ease-in-out infinite;display:inline-block}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.35)}}

/* ============================================================
   TOASTS
   ============================================================ */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:10px}
.toast{background:#fff;border-radius:var(--r-lg);padding:14px 20px;box-shadow:var(--sh-xl);border-left:4px solid var(--rose);font-size:.9375rem;animation:toastIn .4s var(--ease-bounce) both;max-width:300px}
@keyframes toastIn{from{opacity:0;transform:translateX(100px) scale(.8)}to{opacity:1;transform:none}}

/* ============================================================
   NOT FOUND
   ============================================================ */
.nf-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;text-align:center;padding:40px;padding-top:80px}
.nf-emoji{font-size:6rem;display:block;margin-bottom:28px;animation:wiggle 2s ease-in-out infinite}
.nf-title{font-size:clamp(2.5rem,6vw,5rem);margin-bottom:14px}
.nf-desc{font-size:1.1rem;color:var(--muted);margin-bottom:36px}

/* ============================================================
   WOOCOMMERCE COMPATIBILITY
   ============================================================ */
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-info{
  border-radius:var(--r-lg);border-top-color:var(--rose);background:#fff;
  box-shadow:var(--sh-sm);font-size:.9375rem;margin-bottom:16px;
}
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{
  background:linear-gradient(135deg,var(--rose),var(--rose-light))!important;
  color:#fff!important;border-radius:var(--r-pill)!important;
  border:none!important;font-size:.9375rem!important;padding:13px 26px!important;
  transition:all .3s var(--ease)!important;box-shadow:var(--sh-md)!important;
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover{
  background:linear-gradient(135deg,var(--rose-hover),var(--rose))!important;
  transform:translateY(-2px) scale(1.03)!important;
  box-shadow:0 12px 40px rgba(212,165,154,.45)!important;
}
.woocommerce table.shop_table{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea{
  border:2px solid rgba(212,165,154,.22)!important;
  border-radius:var(--r-md)!important;padding:12px 16px!important;
  background:var(--bg)!important;transition:all .25s var(--ease)!important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus{
  border-color:var(--rose)!important;background:#fff!important;outline:none!important;
}
.woocommerce-checkout #payment{border-radius:var(--r-lg)!important}
select2-selection,.select2-container--default .select2-selection--single{
  border:2px solid rgba(212,165,154,.22)!important;border-radius:var(--r-md)!important;
  height:46px!important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:768px){
  .nav-links .nav-link{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-img-wrap{max-width:380px;margin:0 auto}
  .footer-body{grid-template-columns:1fr 1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .pd-grid{grid-template-columns:1fr}
  .cart-grid{grid-template-columns:1fr}
  .contact-2col{grid-template-columns:1fr}
  .sec-title{font-size:clamp(1.875rem,5vw,2.5rem)}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .float-bg,#sparkle-container{display:none}
}

/* ============================================================
   SINGLE PRODUCT PAGE — Figma-exact styles
   ============================================================ */
.spd-page { background:var(--bg); padding-top:80px; min-height:100vh; }

/* Breadcrumb */
.spd-breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-size:.9rem; color:var(--muted); margin-bottom:28px;
}
.spd-breadcrumb a { color:var(--muted); transition:color .2s; }
.spd-breadcrumb a:hover { color:var(--rose); }
.spd-breadcrumb span { color:var(--muted); }
.spd-bc-current { color:var(--rose); font-weight:500; }

/* Hero grid */
.spd-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px; align-items:start; padding-bottom:64px;
}
@media(max-width:900px){ .spd-grid{ grid-template-columns:1fr; gap:28px; padding-bottom:24px; } }
@media(min-width:901px){ .spd-grid{ grid-template-columns:1fr 1fr !important; } }

/* Image column */
.spd-img-col {}
.spd-main-wrap { position:relative; margin-bottom:16px; }
.spd-main-box {
  border-radius:var(--r-xl); overflow:hidden;
  border:2px solid rgba(255,212,212,.3);
  box-shadow:var(--sh-xl); background:#fff;
  aspect-ratio:1/1;
}
.spd-main-box img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease); display:block;
}
.spd-main-box:hover img { transform:scale(1.05); }

/* Limited Edition badge */
.spd-badge {
  position:absolute; top:16px; right:16px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  padding:8px 16px; border-radius:var(--r-pill);
  font-size:.8125rem; display:flex; align-items:center; gap:6px;
  box-shadow:var(--sh-sm); color:var(--muted);
  animation:limitedPulse 2s ease-in-out infinite; z-index:2;
}
.spd-badge svg { width:14px; height:14px; color:var(--rose); }

/* Thumbnail strip — horizontal row like Figma */
.spd-thumbs {
  display:flex; gap:12px; flex-wrap:wrap;
}
.spd-thumb {
  width:100px; height:100px; border-radius:var(--r-md);
  overflow:hidden; border:2px solid rgba(255,212,212,.35);
  cursor:pointer; transition:all .25s var(--ease); opacity:.65;
  flex-shrink:0; background:none; padding:0;
}
.spd-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.spd-thumb:hover, .spd-thumb.active {
  border-color:var(--rose); opacity:1;
  transform:scale(1.06) rotate(1.5deg); box-shadow:var(--sh-sm);
}

/* Info column */
.spd-info-col { padding-top:8px; }

.spd-name {
  font-family:var(--serif); font-size:clamp(2.25rem,4vw,3.25rem);
  letter-spacing:-.02em; line-height:1.1; margin-bottom:10px; color:var(--text);
}

.spd-subtitle {
  font-size:1rem; color:var(--muted); margin-bottom:16px; line-height:1.6;
}

/* Stars */
.spd-stars-row {
  display:flex; align-items:center; gap:8px; margin-bottom:16px;
}
.spd-stars { display:flex; gap:2px; color:var(--rose); }
.spd-rc { font-size:.875rem; color:var(--muted); }

/* Price */
.spd-price {
  font-family:var(--serif); font-size:2.25rem; color:var(--rose);
  margin-bottom:18px; line-height:1;
}
.spd-price .woocommerce-Price-amount { color:var(--rose); }

/* Description */
.spd-desc {
  font-size:.9375rem; color:var(--muted); line-height:1.8;
  margin-bottom:20px;
}
.spd-desc p { margin:0; }

/* Tags row — Rose & Vanilla | 15ml | Gift Ready */
.spd-tags {
  display:flex; flex-wrap:wrap; align-items:center; gap:0;
  background:#fff; border-radius:50px;
  padding:12px 20px; margin-bottom:24px;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
  width:fit-content;
}
.spd-tag {
  font-size:.875rem; color:var(--muted);
  display:flex; align-items:center; gap:6px;
  padding:0 16px; position:relative;
}
.spd-tag+.spd-tag::before {
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  height:14px; width:1px; background:rgba(0,0,0,.12);
}
.spd-tag:first-child { padding-left:0; }
.spd-tag:last-child  { padding-right:0; }

/* Quantity */
.spd-qty-wrap {
  display:flex; align-items:center; gap:16px; margin-bottom:20px;
}
.spd-qty-lbl { font-size:.9375rem; font-weight:500; color:var(--text); }
.spd-qty-ctrl {
  display:flex; align-items:center;
  background:#fff; border:1.5px solid rgba(212,165,154,.25);
  border-radius:var(--r-pill); overflow:hidden;
}
.spd-qty-btn {
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:var(--muted); cursor:pointer;
  transition:all .2s var(--ease); border:none; background:none;
}
.spd-qty-btn:hover { background:var(--rose); color:#fff; }
.spd-qty-num {
  min-width:40px; text-align:center; font-size:1rem; font-weight:600;
  color:var(--text);
}

/* Add to Cart + Wishlist */
.spd-cta { display:flex; gap:12px; margin-bottom:24px; }
.spd-atc {
  flex:1; background:linear-gradient(135deg,var(--rose),var(--rose-light));
  color:#fff; padding:18px 24px; border-radius:var(--r-pill);
  display:flex; align-items:center; justify-content:center; gap:10px;
  font-size:1rem; font-weight:500; box-shadow:var(--sh-lg);
  transition:all .3s var(--ease); border:none; cursor:pointer;
  letter-spacing:.02em;
}
.spd-atc:hover {
  background:linear-gradient(135deg,var(--rose-hover),var(--rose));
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 18px 52px rgba(212,165,154,.5);
}
.spd-atc svg { width:22px; height:22px; }
.spd-wish {
  width:58px; height:58px; border-radius:var(--r-pill);
  border:2px solid rgba(212,165,154,.3); background:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s var(--ease-bounce); flex-shrink:0;
  color:var(--muted);
}
.spd-wish:hover { border-color:var(--rose); transform:scale(1.12); color:var(--rose); }
.spd-wish.active { border-color:var(--rose); color:var(--rose); }
.spd-wish.active svg { fill:currentColor; }
.spd-wish svg { width:22px; height:22px; }

/* Perks row */
.spd-perks {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:12px; padding-top:20px;
  border-top:1px solid rgba(212,165,154,.2);
}
.spd-perk {
  display:flex; flex-direction:column; align-items:center;
  gap:8px; text-align:center; padding:16px 8px;
  background:#fff; border-radius:var(--r-md);
  border:1px solid rgba(212,165,154,.2);
  font-size:.8125rem; color:var(--muted);
  transition:all .25s var(--ease);
}
.spd-perk:hover { border-color:var(--rose); color:var(--rose); transform:translateY(-2px); }
.spd-perk svg { width:22px; height:22px; color:var(--rose); }

/* ── PRODUCT DETAILS SECTION ── */
.spd-details-section {
  padding:72px 0; background:var(--bg); margin-top:0;
}
.spd-section-title {
  font-family:var(--serif); font-size:clamp(1.75rem,3.5vw,2.5rem);
  letter-spacing:-.02em; text-align:center; margin-bottom:40px; color:var(--text);
}

/* Two-column detail cards */
.spd-details-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:28px;
}
@media(max-width:768px){ .spd-details-grid{ grid-template-columns:1fr; } }

.spd-dcard {
  background:#fff; border-radius:var(--r-xl); padding:36px 32px;
  box-shadow:var(--sh-sm); border:1px solid rgba(212,165,154,.18);
  transition:box-shadow .3s var(--ease);
}
.spd-dcard:hover { box-shadow:var(--sh-md); }

.spd-dcard-title {
  font-family:var(--serif); font-size:1.35rem; margin-bottom:24px;
  display:flex; align-items:center; gap:10px; color:var(--text);
}

/* Scent notes */
.spd-notes { display:flex; flex-direction:column; gap:18px; }
.spd-note { display:flex; flex-direction:column; gap:4px; }
.spd-note-lbl {
  font-size:.7rem; text-transform:uppercase; letter-spacing:.12em;
  color:var(--rose); font-weight:600;
}
.spd-note-val { font-size:1rem; color:var(--text); }

/* Spec rows */
.spd-specs { display:flex; flex-direction:column; gap:16px; }
.spd-spec {
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:16px; border-bottom:1px solid rgba(212,165,154,.12);
  font-size:.9375rem;
}
.spd-spec:last-child { border-bottom:none; padding-bottom:0; }
.spd-spec-k { color:var(--muted); }
.spd-spec-v { color:var(--text); font-weight:500; text-align:right; }

/* ── REVIEWS SECTION ── */
.spd-reviews-section {
  padding:72px 0; background:#fff;
}

.spd-reviews-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
@media(max-width:768px){ .spd-reviews-grid{ grid-template-columns:1fr; } }

.spd-review {
  background:var(--bg); border-radius:var(--r-xl); padding:28px;
  border:1px solid rgba(212,165,154,.18);
  transition:all .3s var(--ease);
}
.spd-review:hover { transform:translateY(-4px); box-shadow:var(--sh-md); }

.spd-rv-top {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:14px;
}
.spd-rv-stars { display:flex; gap:2px; }
.spd-rv-date { font-size:.8125rem; color:var(--muted); }

.spd-rv-text {
  font-size:.9375rem; color:var(--muted); font-style:italic;
  line-height:1.75; margin-bottom:18px;
}

.spd-rv-author { display:flex; align-items:center; gap:10px; }
.spd-rv-av {
  width:38px; height:38px; border-radius:var(--r-pill);
  background:linear-gradient(135deg,var(--rose),var(--rose-light));
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:600; font-size:.9375rem; flex-shrink:0;
}
.spd-rv-name { font-weight:600; font-size:.9375rem; color:var(--text); }

/* ============================================================
   MOBILE OVERHAUL — Complete responsive improvements
   All breakpoints: 480px, 640px, 768px
   ============================================================ */

/* ── Hide WooCommerce floating cart button (it overlaps content) ── */
.wc-block-mini-cart,
.woocommerce-store-notice,
a.added_to_cart,
.blocksy-floating-cart,
.floating-cart-btn,
[class*="floating-cart"],
[class*="mini-cart-btn"] { display:none!important; }

/* ── Floating hearts: reduce on mobile so they don't cover UI ── */
@media(max-width:768px){
  .float-bg { opacity:.4; }
  .float-heart { font-size:1rem; }
  .float-heart:nth-child(4),
  .float-heart:nth-child(5) { display:none; }
  #sparkle-container { display:none; }
}

/* ============================================================
   HEADER — mobile
   ============================================================ */
@media(max-width:768px){
  .site-header .wrap { height:64px; padding:0 18px; }
  .site-logo { font-size:1.6rem; }

  /* Show only icons in nav (hamburger + cart + wishlist) */
  .nav-links .nav-link { display:none; }
  .nav-links { gap:16px; }
  .hamburger { display:flex; }
  .nav-icon svg { width:20px; height:20px; }
  .nav-badge { width:16px; height:16px; font-size:.55rem; top:-6px; right:-6px; }
}

/* ============================================================
   HERO — mobile
   ============================================================ */
@media(max-width:768px){
  .hero { padding-top:64px; min-height:auto; }
  .hero-grid {
    grid-template-columns:1fr;
    gap:24px; padding:48px 0 40px;
  }
  .hero-title { font-size:2.6rem; }
  .hero-subtitle { font-size:1rem; }
  .hero-ctas { gap:12px; }
  .btn { padding:12px 22px; font-size:.8125rem; }
  .hero-img-wrap { max-width:100%; order:-1; }
  .hero-img-box { aspect-ratio:4/3; border-radius:var(--r-lg); }
  .hero-badge-deco { display:none; }
  .scroll-hint { display:none; }
}

/* ============================================================
   SECTION HEADINGS — mobile
   ============================================================ */
@media(max-width:768px){
  .sec-emoji { font-size:2.25rem; }
  .sec-title { font-size:1.875rem; }
  .sec-sub { font-size:.9375rem; }
  .sec-head { margin-bottom:36px; }
}

/* ============================================================
   SHOP PAGE — mobile
   ============================================================ */
@media(max-width:768px){
  .shop-hero { padding:48px 0 28px; }
  .shop-hero .sec-title { font-size:2rem; }

  /* Filter buttons: horizontal scrollable single row — no wrap */
  .shop-filters { padding:12px 0 20px; }
  .filter-row {
    flex-wrap:nowrap;
    overflow-x:auto;
    justify-content:flex-start;
    padding:4px 18px 12px;
    gap:8px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .filter-row::-webkit-scrollbar { display:none; }
  .filter-lbl { flex-shrink:0; }
  .filter-btn {
    flex-shrink:0;
    padding:8px 18px;
    font-size:.8125rem;
    white-space:nowrap;
  }

  /* Products: 2 columns on mobile */
  .products-grid {
    grid-template-columns:repeat(2,1fr);
    gap:14px;
  }
  .pcard { border-radius:var(--r-lg); }
  .pcard-info { padding:14px; }
  .pcard-name { font-size:1rem; }
  .pcard-price { font-size:.9375rem; }
  .pcard-desc { display:none; } /* hide on very small cards */
  .pcard-meta { font-size:.7rem; }
  .pcard-wish { width:32px; height:32px; top:10px; right:10px; }
  .pcard-wish svg { width:15px; height:15px; }

  /* Count text */
  .products-count { font-size:.8125rem; margin-bottom:16px; }

  /* Benefits row: horizontal scroll */
  .benefits-row {
    grid-template-columns:repeat(3,1fr);
    gap:12px; padding:40px 0;
  }
  .benefit-emoji { font-size:2rem; }
  .benefit-title { font-size:1rem; }
  .benefit-desc { font-size:.75rem; }
}

@media(max-width:480px){
  .products-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .pcard-name { font-size:.9rem; }
  .pcard-info { padding:12px 10px; }
}

/* ============================================================
   PRODUCT DETAIL PAGE — mobile
   ============================================================ */
@media(max-width:768px){
  .spd-grid { grid-template-columns:1fr; gap:24px; padding-bottom:32px; }
  .spd-name { font-size:2rem; }
  .spd-price { font-size:1.75rem; }
  .spd-main-box { aspect-ratio:4/3; border-radius:var(--r-lg); }
  .spd-thumb { width:70px; height:70px; }
  .spd-badge { top:10px; right:10px; padding:6px 12px; font-size:.75rem; }

  /* Tags: wrap naturally */
  .spd-tags { gap:0; padding:10px 16px; }
  .spd-tag { font-size:.8125rem; padding:0 12px; }

  /* Qty + CTA */
  .spd-qty-wrap { gap:12px; }
  .spd-qty-btn { width:36px; height:36px; }
  .spd-cta { gap:10px; }
  .spd-atc { padding:15px 18px; font-size:.9375rem; }
  .spd-wish { width:50px; height:50px; }
  .spd-wish svg { width:18px; height:18px; }

  /* Perks: full-width row */
  .spd-perks { grid-template-columns:repeat(3,1fr); gap:8px; }
  .spd-perk { padding:12px 6px; font-size:.75rem; gap:6px; }
  .spd-perk svg { width:18px; height:18px; }

  /* Details section */
  .spd-details-section { padding:48px 0; }
  .spd-section-title { font-size:1.6rem; margin-bottom:24px; }
  .spd-details-grid { grid-template-columns:1fr; gap:16px; }
  .spd-dcard { padding:24px 20px; }
  .spd-dcard-title { font-size:1.15rem; }

  /* Reviews */
  .spd-reviews-section { padding:48px 0; }
  .spd-reviews-grid { grid-template-columns:1fr; gap:14px; }
  .spd-review { padding:20px; }

  /* Breadcrumb */
  .spd-breadcrumb { font-size:.8rem; gap:5px; margin-bottom:18px; flex-wrap:wrap; }
}

/* ============================================================
   CART PAGE — mobile
   ============================================================ */
@media(max-width:768px){
  .cart-header { padding:48px 0 28px; }
  .cart-grid { grid-template-columns:1fr; gap:20px; }
  .cart-item-card { flex-wrap:wrap; gap:14px; padding:16px; }
  .ci-img { width:80px; height:96px; }
  .ci-name { font-size:1.05rem; }
  .ci-price { font-size:1.2rem; }
  .order-summary { position:static; } /* don't sticky on mobile */
  .os-title { font-size:1.35rem; }
  .checkout-btn-main { padding:15px; font-size:.9375rem; }
}

/* ============================================================
   ABOUT PAGE — mobile
   ============================================================ */
@media(max-width:768px){
  .about-2col { grid-template-columns:1fr; gap:28px; }
  .about-img { animation:none; } /* no float on mobile — layout stability */
  .about-txt-title { font-size:1.75rem; }
  .about-p { font-size:1rem; }
  .vals-grid { grid-template-columns:1fr 1fr; gap:14px; }
  .val-card { padding:20px 14px; }
  .stat-grid { grid-template-columns:repeat(3,1fr); gap:14px; }
  .stat-card { padding:24px 12px; }
  .stat-num { font-size:2rem; }
}

/* ============================================================
   CONTACT PAGE — mobile
   ============================================================ */
@media(max-width:768px){
  .contact-2col { grid-template-columns:1fr; gap:20px; }
  .cform-card { padding:28px 20px; }
  .cform-title { font-size:1.5rem; }
}

/* ============================================================
   FOOTER — mobile
   ============================================================ */
@media(max-width:768px){
  .footer-body { grid-template-columns:1fr 1fr; gap:24px; padding:48px 0; }
  .footer-brand-name { font-size:1.5rem; }
  .footer-brand-desc { font-size:.8125rem; }
  .footer-col-title { font-size:1rem; }
  .footer-link { font-size:.875rem; }
  .footer-bottom { flex-direction:column; text-align:center; gap:8px; font-size:.8125rem; }
}
@media(max-width:480px){
  .footer-body { grid-template-columns:1fr; gap:20px; padding:36px 0; }
}

/* ============================================================
   FEATURES / TESTIMONIALS / CTA — mobile
   ============================================================ */
@media(max-width:768px){
  .sec-featured,
  .sec-why,
  .sec-testimonials { padding:56px 0; }
  .sec-cta { padding:56px 0; }
  .cta-title { font-size:1.75rem; }
  .cta-sub { font-size:1rem; }

  .features-grid { grid-template-columns:1fr; gap:16px; }
  .feat-card { padding:28px 20px; }
  .feat-title { font-size:1.25rem; }
  .feat-icon svg { width:28px; height:28px; }

  .test-grid { grid-template-columns:1fr; gap:16px; }
  .test-card { padding:24px 20px; }
  .test-text { font-size:.9375rem; }

  .benefits-row { padding:40px 0; gap:14px; }
}

/* ============================================================
   WRAP PADDING — tighter on mobile
   ============================================================ */
@media(max-width:768px){
  .wrap { padding:0 16px; }
}
@media(max-width:480px){
  .wrap { padding:0 14px; }
}

/* ============================================================
   MOBILE NAV — improved
   ============================================================ */
.mobile-nav {
  padding:24px;
  padding-top:80px; /* clear header */
}
.mobile-nav .nav-link {
  font-size:1.75rem;
  padding:8px 0;
  border-bottom:1px solid rgba(212,165,154,.15);
  width:100%;
  text-align:center;
}

/* ============================================================
   TOUCH TARGETS — minimum 44px for all interactive elements
   ============================================================ */
@media(max-width:768px){
  .filter-btn,
  .nav-icon,
  .hamburger,
  .pcard-wish,
  .spd-qty-btn,
  .ci-qty-btn { min-height:44px; min-width:44px; }

  .btn { min-height:48px; }
}

/* ============================================================
   SINGLE PRODUCT — image on mobile (square, not tall)
   ============================================================ */
@media(max-width:480px){
  .spd-name { font-size:1.75rem; }
  .spd-price { font-size:1.5rem; }
  .spd-perks { grid-template-columns:repeat(3,1fr); gap:8px; }
  .spd-perk { flex-direction:column; justify-content:center; }
  .spd-thumbs { gap:8px; }
  .spd-thumb { width:60px; height:60px; }
}

/* ============================================================
   UTILITY — prevent horizontal overflow
   ============================================================ */
body { overflow-x:hidden; }
img  { max-width:100%; }

/* ============================================================
   FILTER SCROLL WRAPPER
   Desktop: centered wrap. Mobile: edge-to-edge horizontal scroll
   ============================================================ */
.filter-scroll-wrap {
  max-width: var(--wrap);
  margin: 0 auto;
  padding: 0 24px;
}
@media(max-width:768px){
  .filter-scroll-wrap {
    max-width:100%;
    padding:0;
    /* Allow the inner .filter-row to scroll */
  }
  .filter-row {
    padding: 4px 16px 12px;
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 8px;
  }
  .filter-row::-webkit-scrollbar { display:none; }
  /* Fade hint at right edge indicating more items */
  .filter-scroll-wrap::after {
    content:'';
    position:absolute;
    top:0; right:0;
    width:40px; height:100%;
    background:linear-gradient(to left, var(--bg), transparent);
    pointer-events:none;
  }
  .filter-scroll-wrap { position:relative; }
}

/* ============================================================
   IMPROVED MOBILE HEADER: logo | icons | hamburger
   ============================================================ */
@media(max-width:768px){
  /* Compress nav icon spacing */
  .nav-links {
    gap: 14px;
  }
  /* Make logo not overflow */
  .site-logo {
    font-size: 1.5rem;
    flex-shrink: 0;
  }
  /* Don't let header wrap */
  .site-header .wrap {
    height: 60px;
    gap: 12px;
  }
}

/* ============================================================
   PRODUCT CARDS: 2-col on mobile with better proportions
   ============================================================ */
@media(max-width:640px){
  .products-grid {
    grid-template-columns: repeat(2,1fr);
    gap: 12px;
  }
  /* Keep 3/4 aspect ratio on mobile — no max-height clipping */
  .pcard-img {
    aspect-ratio: 3/4;
  }
  .pcard-img img {
    width:100%; height:100%; object-fit:cover;
  }
  /* Tighter info area */
  .pcard-info { padding:12px 10px 10px; }
  .pcard-name { font-size:.9rem; line-height:1.3; }
  .pcard-price { font-size:.875rem; }
  .pcard-row { gap:6px; }
  .pcard-meta { display:none; }
  .pcard-corner { display:none; }
}

/* ============================================================
   WISHLIST BUTTON: stays in corner on small cards
   ============================================================ */
@media(max-width:640px){
  .pcard-wish {
    width:30px; height:30px;
    top:8px; right:8px;
  }
  .pcard-wish svg { width:14px; height:14px; }
  /* Quick add hidden on small screens — navigate to product instead */
  .pcard-qadd { display:none; }
}

/* ============================================================
   HERO: single column, image first on mobile
   ============================================================ */
@media(max-width:640px){
  .hero-grid { padding: 32px 0 36px; }
  .hero-title { font-size: 2.2rem; letter-spacing:-.02em; }
  .hero-badge { font-size:.8125rem; padding:6px 14px; margin-bottom:18px; }
  .hero-subtitle { font-size:.9375rem; margin-bottom:24px; }
  .hero-img-wrap { order:-1; max-width:100%; }
  .hero-img-box { aspect-ratio:16/9; border-radius:var(--r-lg); }

  /* CTA buttons full-width */
  .hero-ctas { flex-direction:column; gap:10px; }
  .hero-ctas .btn { width:100%; justify-content:center; }
}

/* ============================================================
   CTA SECTION: mobile
   ============================================================ */
@media(max-width:640px){
  .sec-cta { padding:48px 0; }
  .cta-title { font-size:1.6rem; }
  .cta-sub { font-size:.9375rem; margin-bottom:28px; }
  .cta-deco-1, .cta-deco-2 { font-size:2.5rem; }
}

/* ============================================================
   FEATURED PRODUCTS: 2-col on mobile
   ============================================================ */
@media(max-width:640px){
  .sec-featured { padding:48px 0; }
  .sec-featured .products-grid {
    grid-template-columns:repeat(2,1fr);
    gap:12px;
  }
  .sec-featured .sec-head { margin-bottom:28px; }
  /* View All button: full width */
  .sec-featured [style*="text-align:center"] {
    margin-top:28px;
  }
}

/* ============================================================
   WHY / FEATURES: single column on mobile
   ============================================================ */
@media(max-width:640px){
  .sec-why { padding:48px 0; }
  .features-grid { grid-template-columns:1fr; gap:12px; }
  .feat-card { padding:24px 18px; text-align:left; display:flex; align-items:flex-start; gap:16px; }
  .feat-icon { margin-bottom:0; flex-shrink:0; }
  .feat-icon svg { width:26px; height:26px; }
}

/* ============================================================
   TESTIMONIALS: single column on mobile
   ============================================================ */
@media(max-width:640px){
  .sec-testimonials { padding:48px 0; }
  .test-grid { grid-template-columns:1fr; gap:12px; }
  .test-card { padding:20px; }
}

/* ============================================================
   SHOP — benefits bar on mobile
   ============================================================ */
@media(max-width:640px){
  .benefits-row {
    grid-template-columns:repeat(3,1fr);
    gap:10px; padding:36px 0;
  }
  .benefit-emoji { font-size:1.75rem; margin-bottom:6px; }
  .benefit-title { font-size:.875rem; }
  .benefit-desc { font-size:.7rem; }
}

/* ============================================================
   CART ITEM CARD: stack on very small screens
   ============================================================ */
@media(max-width:480px){
  .cart-item-card { gap:12px; padding:14px; }
  .ci-img { width:72px; height:88px; }
  .ci-name { font-size:1rem; }
  .ci-bottom { flex-wrap:wrap; gap:10px; }
  .ci-price { font-size:1.1rem; }
}

/* ============================================================
   SINGLE PRODUCT: full-width image on small screens
   ============================================================ */
@media(max-width:640px){
  .spd-main-box { aspect-ratio:1/1; border-radius:var(--r-lg); }
  .spd-thumbs { gap:8px; }
  .spd-thumb { width:62px; height:62px; border-radius:var(--r-sm); }
  .spd-badge { font-size:.7rem; padding:5px 10px; }
  .spd-perks { grid-template-columns:repeat(3,1fr); gap:6px; }
  .spd-perk { padding:10px 4px; font-size:.7rem; border-radius:var(--r-sm); }
  .spd-perk svg { width:16px; height:16px; }
  .spd-cta { gap:8px; }
  .spd-atc { padding:14px 16px; font-size:.875rem; }
  .spd-wish { width:46px; height:46px; }
}

/* ============================================================
   ABOUT PAGE: stats grid stays 3-col on mobile
   ============================================================ */
@media(max-width:640px){
  .stat-grid { grid-template-columns:repeat(3,1fr); gap:10px; }
  .stat-card { padding:20px 10px; }
  .stat-num { font-size:1.75rem; }
  .stat-lbl { font-size:.75rem; }
}

/* ============================================================
   FOOTER: 2-col on mid, 1-col on small
   ============================================================ */
@media(max-width:560px){
  .footer-body { grid-template-columns:1fr; gap:20px; }
  .footer-brand-desc { font-size:.8125rem; }
}

/* ============================================================
   GLOBAL: Better tap highlighting and focus rings
   ============================================================ */
@media(max-width:768px){
  a, button { -webkit-tap-highlight-color:rgba(212,165,154,.2); }
  :focus-visible { outline:2px solid var(--rose); outline-offset:2px; border-radius:4px; }
}

/* ============================================================
   CHECKOUT PAGE — Complete redesign
   ============================================================ */
.co-page {
  background: var(--bg);
  padding-top: 80px;
  min-height: 100vh;
  /* No floating hearts on checkout */
}
/* Suppress floating BG on checkout only */
.co-page ~ .float-bg,
body.woocommerce-checkout .float-bg,
body.woocommerce-checkout #sparkle-container { display:none!important; }

/* Header */
.co-header {
  background: #fff;
  border-bottom: 1px solid rgba(212,165,154,.15);
  padding: 32px 0 24px;
}
.co-header-inner {
  text-align: center;
  margin-bottom: 28px;
}
.co-emoji {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 10px;
  animation: wiggle 2s ease-in-out infinite;
}
.co-title {
  font-family: var(--serif);
  font-size: clamp(1.75rem,3vw,2.5rem);
  letter-spacing: -.02em;
  margin-bottom: 8px;
  color: var(--text);
}
.co-secure {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .875rem;
  color: var(--muted);
  background: rgba(212,165,154,.08);
  padding: 6px 16px;
  border-radius: var(--r-pill);
}
.co-secure svg { width:14px; height:14px; color: var(--rose); }

/* Progress steps */
.co-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  max-width: 360px;
  margin: 0 auto;
}
.co-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.co-step-dot {
  width: 36px; height: 36px;
  border-radius: var(--r-pill);
  border: 2px solid rgba(212,165,154,.3);
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: .8125rem; font-weight: 600; color: var(--muted);
  transition: all .3s var(--ease);
}
.co-step.done .co-step-dot {
  background: var(--rose); border-color: var(--rose); color: #fff;
}
.co-step.active .co-step-dot {
  background: var(--rose); border-color: var(--rose); color: #fff;
  box-shadow: 0 0 0 4px rgba(212,165,154,.2);
}
.co-step-lbl {
  font-size: .75rem; color: var(--muted); white-space: nowrap;
}
.co-step.active .co-step-lbl { color: var(--rose); font-weight: 600; }
.co-step.done .co-step-lbl  { color: var(--rose); }
.co-step-line {
  flex: 1; height: 2px; background: rgba(212,165,154,.2);
  min-width: 40px; margin-bottom: 22px;
}
.co-step-line.done { background: var(--rose); }

/* Main wrap */
.co-wrap { padding-top: 40px; padding-bottom: 96px; }

/* Two-column grid */
.co-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 32px;
  align-items: start;
}
@media(max-width:1024px) {
  .co-grid { grid-template-columns: 1fr 340px; }
}
@media(max-width:900px) {
  .co-grid {
    grid-template-columns: 1fr;
    /* Order summary goes on top on mobile */
  }
  .co-right { order: -1; }
}

/* Sections */
.co-section {
  background: #fff;
  border-radius: var(--r-xl);
  box-shadow: var(--sh-sm);
  border: 1px solid rgba(212,165,154,.15);
  margin-bottom: 20px;
  overflow: hidden;
}
.co-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px 28px;
  border-bottom: 1px solid rgba(212,165,154,.12);
  background: linear-gradient(135deg, rgba(254,248,245,.8), #fff);
}
.co-section-icon { font-size: 1.25rem; }
.co-section-title {
  font-family: var(--serif);
  font-size: 1.25rem;
  letter-spacing: -.01em;
  color: var(--text);
  margin: 0;
}
.co-section-body { padding: 24px 28px; }

/* WooCommerce form field overrides inside checkout */
.co-section-body .woocommerce-billing-fields,
.co-section-body .woocommerce-shipping-fields,
.co-section-body .woocommerce-additional-fields { margin: 0; }

.co-section-body .form-row {
  margin-bottom: 16px !important;
}
.co-section-body .form-row label {
  font-size: .875rem !important;
  font-weight: 500 !important;
  color: var(--text) !important;
  margin-bottom: 6px !important;
  display: block !important;
}
.co-section-body .form-row input.input-text,
.co-section-body .form-row textarea,
.co-section-body .form-row select,
.co-section-body .select2-container--default .select2-selection--single {
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1.5px solid rgba(212,165,154,.25) !important;
  border-radius: var(--r-md) !important;
  background: var(--bg) !important;
  font-size: .9375rem !important;
  color: var(--text) !important;
  transition: all .25s var(--ease) !important;
  height: auto !important;
  line-height: 1.5 !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
}
.co-section-body .form-row input.input-text:focus,
.co-section-body .form-row textarea:focus,
.co-section-body .form-row select:focus {
  border-color: var(--rose) !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(212,165,154,.12) !important;
  outline: none !important;
}
/* Two columns for name fields on desktop */
.co-section-body .woocommerce-billing-fields__field-wrapper,
.co-section-body .woocommerce-shipping-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 16px;
}
.co-section-body .form-row-wide,
.co-section-body .form-row-last + .form-row-wide,
.co-section-body .form-row:only-child {
  grid-column: 1 / -1;
}
@media(max-width:640px){
  .co-section-body .woocommerce-billing-fields__field-wrapper,
  .co-section-body .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr;
  }
}
/* Payment section */
.co-section-body .woocommerce-checkout-payment { background: none !important; border: none !important; }
.co-section-body .woocommerce-checkout-payment .payment_methods { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.co-section-body .woocommerce-checkout-payment .payment_methods li {
  background: var(--bg);
  border: 1.5px solid rgba(212,165,154,.2);
  border-radius: var(--r-md);
  padding: 14px 16px;
  cursor: pointer;
  transition: all .2s var(--ease);
}
.co-section-body .woocommerce-checkout-payment .payment_methods li:hover,
.co-section-body .woocommerce-checkout-payment .payment_methods li.wc_payment_method.payment_method_paypal { border-color: var(--rose); }
.co-section-body .woocommerce-checkout-payment .place-order {
  padding: 0; background: none; margin: 0;
}
.co-section-body .woocommerce-checkout-payment #place_order {
  width: 100% !important;
  background: linear-gradient(135deg,var(--rose),var(--rose-light)) !important;
  color: #fff !important;
  padding: 18px !important;
  border-radius: var(--r-pill) !important;
  font-size: 1.0625rem !important;
  font-weight: 500 !important;
  border: none !important;
  cursor: pointer !important;
  transition: all .3s var(--ease) !important;
  box-shadow: var(--sh-lg) !important;
  letter-spacing: .03em !important;
  margin-top: 16px !important;
  position: relative;
  overflow: hidden;
}
.co-section-body .woocommerce-checkout-payment #place_order:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 16px 48px rgba(212,165,154,.5) !important;
}
/* Checkbox: ship to different address */
.co-section-body .woocommerce-shipping-fields h3 label {
  font-family: var(--serif) !important;
  font-size: 1.1rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  cursor: pointer;
}
.co-section-body #ship-to-different-address {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}

/* ===== RIGHT: Order Summary ===== */
.co-summary {
  background: #fff;
  border-radius: var(--r-xl);
  box-shadow: var(--sh-md);
  border: 1px solid rgba(212,165,154,.15);
  overflow: hidden;
  position: sticky;
  top: 96px;
}
.co-summary-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(212,165,154,.12);
  background: linear-gradient(135deg, rgba(254,248,245,.9), #fff);
}
.co-summary-title {
  font-family: var(--serif);
  font-size: 1.35rem;
  letter-spacing: -.01em;
  margin: 0;
}

/* Cart items in summary */
.co-items {
  padding: 16px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-bottom: 1px solid rgba(212,165,154,.1);
}
.co-item {
  display: flex;
  align-items: center;
  gap: 12px;
}
.co-item-img {
  position: relative;
  width: 56px; height: 56px;
  border-radius: var(--r-md);
  overflow: hidden;
  flex-shrink: 0;
  border: 1.5px solid var(--rose-pale);
}
.co-item-img img { width:100%; height:100%; object-fit:cover; }
.co-item-qty {
  position: absolute;
  top: -6px; right: -6px;
  background: var(--rose);
  color: #fff;
  font-size: .6rem;
  font-weight: 700;
  width: 18px; height: 18px;
  border-radius: var(--r-pill);
  display: flex; align-items: center; justify-content: center;
}
.co-item-info { flex: 1; min-width: 0; }
.co-item-name {
  font-size: .875rem;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
}
.co-item-meta { font-size: .75rem; color: var(--muted); }
.co-item-price {
  font-family: var(--serif);
  font-size: 1rem;
  color: var(--rose);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Totals */
.co-totals {
  padding: 16px 24px;
  border-bottom: 1px solid rgba(212,165,154,.1);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.co-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .9375rem;
  color: var(--muted);
}
.co-free { color: var(--rose); font-weight: 500; }
.co-grand-total {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--text);
  padding-top: 10px;
  border-top: 1px solid rgba(212,165,154,.15);
  margin-top: 4px;
}
.co-grand-total span:last-child {
  color: var(--rose);
  font-family: var(--serif);
  font-size: 1.25rem;
}

/* Trust badges */
.co-trust {
  padding: 16px 24px 20px;
  display: flex;
  justify-content: space-around;
  gap: 8px;
}
.co-trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-size: .7rem;
  color: var(--muted);
  text-align: center;
}
.co-trust-item span:first-child { font-size: 1.25rem; }

/* Mobile checkout adjustments */
@media(max-width:900px) {
  .co-header { padding: 20px 0 16px; }
  .co-emoji { font-size: 2rem; }
  .co-title { font-size: 1.5rem; }
  .co-steps { max-width: 300px; }
  .co-step-dot { width: 30px; height: 30px; font-size: .75rem; }
  .co-step-line { min-width: 28px; }
  .co-wrap { padding-top: 24px; }
  .co-summary { position: static; }
  .co-section-head { padding: 16px 20px; }
  .co-section-body { padding: 18px 20px; }
  .co-right { margin-bottom: 4px; }
}

@media(max-width:480px) {
  .co-header { padding: 16px 0; }
  .co-steps { max-width: 260px; gap: 0; }
  .co-step-dot { width: 28px; height: 28px; }
  .co-section-head { padding: 14px 16px; }
  .co-section-body { padding: 14px 16px; }
  .co-section-title { font-size: 1.1rem; }
  .co-section-body .form-row { margin-bottom: 12px !important; }
  .co-section-body .form-row input.input-text,
  .co-section-body .form-row select { padding: 10px 14px !important; font-size: .875rem !important; }
  .co-items { padding: 12px 16px; }
  .co-totals { padding: 12px 16px; }
  .co-trust { padding: 12px 16px 16px; }
}

/* ============================================================
   GIFTING SECTION
   ============================================================ */
.sec-gifting {
  padding: 100px 0;
  background: linear-gradient(180deg, #fff 0%, var(--bg2) 100%);
  overflow: hidden;
}

.gifting-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
@media(max-width:900px) {
  .gifting-grid { grid-template-columns: 1fr; gap: 36px; }
  .gifting-img-col { order: 2; max-width: 480px; margin: 0 auto; }
  .gifting-content-col { order: 1; }
}

/* Image column */
.gifting-img-col { position: relative; }
.gifting-img-main {
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-xl);
  aspect-ratio: 6/7;
  position: relative;
}
.gifting-img-main img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s var(--ease);
}
.gifting-img-main:hover img { transform: scale(1.04); }
.gifting-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(212,165,154,.22), transparent);
}

/* Floating badge over image */
.gifting-badge {
  position: absolute;
  bottom: -20px; right: -20px;
  background: #fff;
  border-radius: var(--r-lg);
  padding: 16px 20px;
  box-shadow: var(--sh-xl);
  display: flex;
  align-items: center;
  gap: 12px;
  animation: deco1 4s ease-in-out infinite;
  border: 1.5px solid var(--rose-pale);
  min-width: 180px;
}
.gifting-badge-emoji { font-size: 2rem; }
.gifting-badge-title { font-weight: 600; font-size: .9375rem; color: var(--text); }
.gifting-badge-sub { font-size: .8125rem; color: var(--muted); }

/* Stat pill */
.gifting-stat {
  position: absolute;
  top: 24px; left: -24px;
  background: linear-gradient(135deg, var(--rose), var(--rose-light));
  color: #fff;
  border-radius: var(--r-lg);
  padding: 14px 18px;
  box-shadow: var(--sh-lg);
  display: flex;
  align-items: center;
  gap: 10px;
  animation: deco2 3.5s ease-in-out infinite;
}
.gifting-stat span:first-child { font-size: 1.5rem; }
.gifting-stat-num { font-family: var(--serif); font-size: 1.25rem; line-height: 1; }
.gifting-stat-lbl { font-size: .75rem; opacity: .85; }

@media(max-width:640px){
  .gifting-badge { bottom: -12px; right: -8px; padding: 12px 14px; min-width: 150px; }
  .gifting-stat  { top: 12px; left: -8px; padding: 10px 14px; }
}

/* Content column */
.gifting-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .875rem;
  color: var(--rose);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 16px;
  background: rgba(212,165,154,.1);
  padding: 6px 16px;
  border-radius: var(--r-pill);
}

.gifting-title {
  font-family: var(--serif);
  font-size: clamp(2.25rem, 4vw, 3.5rem);
  letter-spacing: -.02em;
  line-height: 1.1;
  margin-bottom: 20px;
  color: var(--text);
}
.gifting-accent { color: var(--rose); }

.gifting-desc {
  font-size: 1.0625rem;
  color: var(--muted);
  line-height: 1.85;
  margin-bottom: 28px;
  max-width: 520px;
}

/* Perks list */
.gifting-perks {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 28px;
}
.gifting-perk {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,.7);
  border-radius: var(--r-md);
  border: 1px solid rgba(212,165,154,.15);
  transition: all .25s var(--ease);
}
.gifting-perk:hover {
  background: #fff;
  border-color: rgba(212,165,154,.3);
  transform: translateX(4px);
  box-shadow: var(--sh-sm);
}
.gifting-perk-icon {
  font-size: 1.375rem;
  flex-shrink: 0;
  margin-top: 1px;
}
.gifting-perk-title {
  font-weight: 600;
  font-size: .9375rem;
  color: var(--text);
  margin-bottom: 2px;
}
.gifting-perk-desc {
  font-size: .8125rem;
  color: var(--muted);
  line-height: 1.5;
}

/* Occasion tags */
.gifting-occasions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 28px;
}
.gifting-tag {
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font-size: .8125rem;
  background: rgba(212,165,154,.1);
  color: var(--rose);
  border: 1px solid rgba(212,165,154,.2);
  transition: all .2s var(--ease);
  cursor: default;
}
.gifting-tag:hover {
  background: var(--rose);
  color: #fff;
  transform: scale(1.04);
}

/* CTAs */
.gifting-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

/* Mobile gifting */
@media(max-width:640px) {
  .sec-gifting { padding: 64px 0; }
  .gifting-title { font-size: 2rem; }
  .gifting-desc { font-size: 1rem; }
  .gifting-perk { padding: 12px 14px; }
  .gifting-ctas { flex-direction: column; }
  .gifting-ctas .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   BEST SELLERS SECTION (homepage second product section)
   ============================================================ */
.sec-bestsellers { padding: 96px 0; background: var(--bg); }
@media(max-width:640px){ .sec-bestsellers { padding: 56px 0; } }

/* ============================================================
   SUPPRESS floating decorations on checkout — clean form UX
   ============================================================ */
body.woocommerce-checkout .float-bg,
body.woocommerce-checkout #sparkle-container,
body.woocommerce-checkout .float-heart { display:none!important; }

/* Suppress WC privacy policy text clutter on summary */
.co-section-body .woocommerce-privacy-policy-text { 
  font-size:.8rem; color:var(--muted); margin-top:12px; 
}
/* Payment description text */
.co-section-body .payment_box { 
  background:rgba(254,248,245,.8)!important; 
  border-radius:var(--r-sm)!important; 
  padding:12px!important;
  font-size:.875rem!important;
  color:var(--muted)!important;
  margin-top:10px!important;
}
/* Coupon row in checkout */
.woocommerce-checkout .showcoupon,
.woocommerce-checkout #coupon_code { font-size:.9rem; color:var(--rose); }
/* Validation errors */
.woocommerce-checkout .woocommerce-invalid input { border-color:#e54b4b!important; }
.woocommerce-checkout .woocommerce-invalid-required-field label::after { color:#e54b4b; }