/* =========================================================
   Aurora Jewelry — Hello Elementor Child Theme
   Main stylesheet
   ========================================================= */

:root{
  --cream:#FBF7F0;
  --ivory:#F5EFE5;
  --beige:#E8DCC4;
  --tan:#C9A47B;
  --gold:#B8935E;
  --dark:#2A2520;
  --charcoal:#4A413A;
  --muted:#8B8077;
  --line:#E5DFD3;
  --white:#fff;

  --display:'Cormorant Garamond', Georgia, serif;
  --body:'Jost', system-ui, sans-serif;

  --container:1400px;
}

/* Reset Hello Elementor defaults that may interfere */
body.aurora-overrides{}
body{
  font-family:var(--body);
  font-size:15px;
  font-weight:300;
  color:var(--dark);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  margin:0;
}
.site-main{min-height:60vh}

img{max-width:100%;display:block;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.container{max-width:var(--container);margin:0 auto;padding:0 24px;width:100%;box-sizing:border-box}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:.5px;line-height:1.15;margin:0 0 .5em}
.eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:500}
.section-title{font-size:clamp(28px, 4vw, 44px);text-align:center;margin-bottom:8px}
.section-sub{text-align:center;color:var(--muted);font-size:13px;letter-spacing:1px;text-transform:uppercase;margin-bottom:48px}
.section{padding:90px 0}

/* =========== ANNOUNCEMENT BAR =========== */
.announce{
  background:var(--dark);color:var(--ivory);
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  padding:10px 24px;text-align:center;overflow:hidden;
  position:relative;
}
.announce-track{
  display:flex;gap:60px;
  animation:slide 40s linear infinite;
  white-space:nowrap;width:max-content;
}
.announce-item{display:flex;align-items:center;gap:8px}
.announce-item::before{content:'✦';color:var(--gold);font-size:10px}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========== HEADER =========== */
.header{
  background:var(--cream);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:100;
}
.header-inner{
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;padding:18px 24px;
  max-width:var(--container);margin:0 auto;gap:24px;
}
.header-left{display:flex;align-items:center;gap:18px}
.header-right{display:flex;align-items:center;gap:14px;justify-content:flex-end}
.header-logo{text-align:center}
.logo, .header .custom-logo-link{
  font-family:var(--display);
  font-size:32px;font-weight:500;
  letter-spacing:6px;color:var(--dark);
  text-decoration:none;display:inline-block;
}
.custom-logo{max-height:50px;width:auto}

.icon-btn{
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:background .2s;
  position:relative;color:var(--dark);text-decoration:none;
}
.icon-btn:hover{background:var(--ivory)}
.icon-btn svg{width:20px;height:20px;stroke:var(--dark);fill:none;stroke-width:1.5}
.cart-badge{
  position:absolute;top:4px;right:4px;
  background:var(--gold);color:#fff;
  font-size:10px;width:18px;height:18px;
  border-radius:50%;display:flex;
  align-items:center;justify-content:center;
}
.lang-switch{
  font-size:12px;letter-spacing:1.5px;
  color:var(--charcoal);padding:6px 10px;
  border:1px solid var(--line);border-radius:20px;
}
.hamburger{display:none}

/* =========== NAV =========== */
.nav{
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--container);margin:0 auto;
  padding:0 24px;display:flex;
  justify-content:center;
}
.aurora-menu, #primary-menu{
  display:flex;gap:40px;
  margin:0;padding:0;list-style:none;
}
.aurora-menu li, #primary-menu li{position:relative}
.aurora-menu a, #primary-menu a{
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
  padding:18px 0;display:inline-block;
  color:var(--charcoal);font-weight:400;
  text-decoration:none;
}
.aurora-menu a:hover, #primary-menu a:hover{color:var(--gold)}
.aurora-menu .sub-menu, #primary-menu .sub-menu{
  position:absolute;top:100%;left:0;
  background:#fff;padding:20px;min-width:200px;
  border:1px solid var(--line);
  box-shadow:0 20px 40px -10px rgba(0,0,0,.1);
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:all .3s;list-style:none;z-index:50;
}
.aurora-menu li:hover .sub-menu, #primary-menu li:hover .sub-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
.sub-menu a{padding:8px 0;letter-spacing:0;text-transform:none;font-size:14px}

/* =========== HERO SLIDER =========== */
.hero{position:relative;overflow:hidden;background:var(--ivory)}
.hero-track{display:flex;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.hero-slide{
  min-width:100%;height:78vh;min-height:540px;
  display:flex;align-items:end;
  position:relative;
}
.hero-slide-1{background:linear-gradient(135deg, #E8DCC4 0%, #F5EFE5 50%, #D4B896 100%)}
.hero-slide-2{background:linear-gradient(135deg, #2A2520 0%, #4A413A 100%);color:var(--cream)}
.hero-slide-3{background:linear-gradient(135deg, #FBF7F0 0%, #E5C9A6 100%)}
.hero-slide-4{background:linear-gradient(135deg, #C9A47B 0%, #B8935E 100%);color:var(--cream)}
.hero-content{max-width:640px;position:relative;z-index:2}
.hero-eyebrow{
  font-size:11px;letter-spacing:4px;text-transform:uppercase;
  margin-bottom:18px;opacity:.85;
}
.hero-title{
  font-size:clamp(40px, 7vw, 76px);font-weight:300;
  margin:0 0 18px;line-height:1.05;letter-spacing:-.5px;
}
.hero-title em{font-style:italic;font-weight:400}
.hero-text{
  font-size:15px;margin:0 auto 32px;
  opacity:.85;max-width:480px;
}

.btn{
  display:inline-block;padding:14px 38px;
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  background:var(--dark);color:var(--cream);
  border:1px solid var(--dark);transition:all .3s;
  font-weight:500;text-decoration:none;cursor:pointer;
}
.btn:hover{background:transparent;color:var(--dark)}
.btn-light{background:var(--cream);color:var(--dark);border-color:var(--cream)}
.btn-light:hover{background:transparent;color:var(--cream)}

.hero-arrow{
  position:absolute;top:50%;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.7);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  transform:translateY(-50%);z-index:5;transition:background .2s;
}
.hero-arrow:hover{background:#fff}
.hero-arrow svg{width:18px;height:18px;stroke:var(--dark);fill:none;stroke-width:1.5}
.hero-prev{left:24px}.hero-next{right:24px}

.hero-dots{
  position:absolute;bottom:32px;left:50%;
  transform:translateX(-50%);display:flex;gap:10px;z-index:5;
}
.hero-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.4);
  border:1px solid rgba(255,255,255,.6);
  transition:all .3s;cursor:pointer;
}
.hero-dot.active{background:#fff;width:32px;border-radius:4px}

/* =========== PRODUCT CAROUSEL =========== */

.view-all{
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--charcoal);border-bottom:1px solid currentColor;
  padding-bottom:2px;text-decoration:none;
}

.carousel{position:relative}
.carousel-track{
  display:flex;gap:24px;
  overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;padding-bottom:8px;
  scrollbar-width:none;
}
.carousel-track::-webkit-scrollbar{display:none}

.product-card{
  flex:0 0 calc(25% - 18px);
  scroll-snap-align:start;
  background:var(--white);text-align:left;
  transition:transform .3s;
}
.product-card:hover{transform:translateY(-4px)}
.product-card a.product-link{display:block;color:inherit;text-decoration:none}
.product-image{
  aspect-ratio:3/4;
  background:linear-gradient(135deg,var(--ivory),var(--beige));
  position:relative;overflow:hidden;
  margin-bottom:14px;
}
.product-image img.product-img{
  width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;
}
.product-image::before{
  content:attr(data-name);
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:13px;
  color:var(--gold);letter-spacing:1px;
  opacity:.5;text-align:center;padding:20px;
}
.product-image img.product-img + ::before, .product-image:has(img)::before{display:none}
.product-badge{
  position:absolute;top:12px;left:12px;z-index:2;
  background:var(--dark);color:var(--cream);
  font-size:10px;letter-spacing:1.5px;
  padding:5px 10px;text-transform:uppercase;
}
.product-badge-sale{background:#A0392E}
.product-name{
  font-family:var(--display);
  font-size:18px;font-weight:400;
  margin:0 0 6px;padding:0 4px;
}
.product-price{
  padding:0 4px;display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--dark);
}
.product-price del{color:var(--muted);font-size:13px}
.product-price ins{color:#A0392E;text-decoration:none}

.carousel-arrows{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}
.car-arrow{
  width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line);background:transparent;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;cursor:pointer;
}
.car-arrow:hover{background:var(--dark);border-color:var(--dark)}
.car-arrow:hover svg{stroke:var(--cream)}
.car-arrow svg{width:16px;height:16px;stroke:var(--dark);fill:none;stroke-width:1.5}

/* =========== PRESS LOGOS =========== */
.press{
  background:var(--ivory);padding:50px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.press-title{
  text-align:center;font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--muted);margin-bottom:32px;
}
.press-track{
  display:flex;align-items:center;
  justify-content:space-around;gap:60px;flex-wrap:wrap;
}
.press-logo{
  font-family:var(--display);font-size:24px;letter-spacing:2px;
  color:var(--charcoal);opacity:.5;transition:opacity .2s;
}
.press-logo:hover{opacity:1}

/* =========== CATEGORY GRID =========== */
.category-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;
}
.category-card{
  position:relative;aspect-ratio:1/1;overflow:hidden;
  background:linear-gradient(135deg,var(--ivory),var(--beige));
  display:flex;align-items:flex-end;padding:30px;
  transition:transform .4s;text-decoration:none;color:inherit;
}
.category-card:nth-child(1){background:linear-gradient(135deg,#E8DCC4,#C9A47B)}
.category-card:nth-child(2){background:linear-gradient(135deg,#FBF7F0,#D4B896)}
.category-card:nth-child(3){background:linear-gradient(135deg,#2A2520,#4A413A)}
.category-card:nth-child(4){background:linear-gradient(135deg,#C9A47B,#B8935E)}
.category-card:nth-child(5){background:linear-gradient(135deg,#F5EFE5,#E8DCC4)}
.category-card:nth-child(6){background:linear-gradient(135deg,#4A413A,#8B6F47)}
.category-card:nth-child(3) .cat-name,
.category-card:nth-child(3) .cat-cta,
.category-card:nth-child(6) .cat-name,
.category-card:nth-child(6) .cat-cta{color:var(--cream)}
.category-card:hover{transform:scale(.98)}
.cat-content{position:relative;z-index:2}



/* =========== FEATURED COLLECTION =========== */
.feature-collection{background:var(--ivory);padding:100px 0}
.feature-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;
}
.feature-image{
  aspect-ratio:4/5;
  background:linear-gradient(135deg, #C9A47B 0%, #E8DCC4 50%, #F5EFE5 100%);
  position:relative;
}
.feature-image::after{
  content:'COLLECTION IMAGE';
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:14px;
  color:rgba(255,255,255,.7);letter-spacing:3px;
}
.feature-text h2{font-size:clamp(34px, 5vw, 56px);margin-bottom:24px}
.feature-text p{font-size:16px;color:var(--charcoal);line-height:1.8;margin-bottom:20px}

/* =========== TESTIMONIALS =========== */
.testimonials{
  background:var(--dark);color:var(--cream);
  padding:100px 0;text-align:center;
}
.testimonials .section-title{color:var(--cream)}
.testi-track{
  display:flex;overflow-x:auto;
  scroll-snap-type:x mandatory;
  gap:32px;padding:20px 0;scrollbar-width:none;
}
.testi-track::-webkit-scrollbar{display:none}
.testi-card{
  flex:0 0 100%;scroll-snap-align:center;
  padding:0 60px;text-align:center;
}
.testi-stars{color:var(--gold);letter-spacing:4px;margin-bottom:24px;font-size:18px}
.testi-quote{
  font-family:var(--display);
  font-size:clamp(20px, 3vw, 28px);
  font-weight:300;font-style:italic;line-height:1.5;
  margin:0 auto 24px;max-width:720px;
}
.testi-author{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);
}

/* =========== VISIT IN STORE =========== */
.visit{
  height:600px;position:relative;
  background:linear-gradient(135deg, #2A2520, #4A413A 50%, #8B6F47 100%);
  display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--cream);overflow:hidden;
}
.visit::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at center, transparent 0%, rgba(0,0,0,.3) 100%);
}
.visit-content{position:relative;z-index:2;max-width:600px;padding:24px}
.visit h2{font-size:clamp(36px, 5vw, 60px);margin-bottom:20px}
.visit p{font-size:16px;margin-bottom:32px;opacity:.9}

/* =========== INSTAGRAM =========== */
.insta-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:8px;
}
.insta-item{
  aspect-ratio:1/1;position:relative;overflow:hidden;
  cursor:pointer;text-decoration:none;
}
.insta-item:nth-child(1){background:linear-gradient(135deg,#E8DCC4,#C9A47B)}
.insta-item:nth-child(2){background:linear-gradient(135deg,#FBF7F0,#D4B896)}
.insta-item:nth-child(3){background:linear-gradient(135deg,#C9A47B,#8B6F47)}
.insta-item:nth-child(4){background:linear-gradient(135deg,#F5EFE5,#E8DCC4)}
.insta-item:nth-child(5){background:linear-gradient(135deg,#D4B896,#B8935E)}
.insta-item:nth-child(6){background:linear-gradient(135deg,#E8DCC4,#FBF7F0)}
.insta-item:nth-child(7){background:linear-gradient(135deg,#B8935E,#8B6F47)}
.insta-item:nth-child(8){background:linear-gradient(135deg,#F5EFE5,#C9A47B)}
.insta-item::after{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,0);transition:background .3s;
}
.insta-item:hover::after{background:rgba(0,0,0,.3)}
.insta-icon{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.5);
  opacity:0;transition:all .3s;z-index:2;
}
.insta-item:hover .insta-icon{opacity:1;transform:translate(-50%,-50%) scale(1)}
.insta-icon svg{width:32px;height:32px;stroke:#fff;fill:none;stroke-width:1.5}

/* =========== NEWSLETTER =========== */
.newsletter{background:var(--ivory);padding:80px 0;text-align:center}
.newsletter-form{
  max-width:480px;margin:32px auto 0;display:flex;
  border-bottom:1px solid var(--charcoal);
}
.newsletter-form input{
  flex:1;border:none;background:transparent;
  padding:14px 8px;font-family:inherit;font-size:14px;
  color:var(--dark);outline:none;
}
.newsletter-form button{
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  font-weight:500;padding:14px 8px;color:var(--dark);
}

/* =========== FOOTER =========== */
.footer{background:var(--cream);border-top:1px solid var(--line);padding:70px 0 30px}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:50px;
}
.footer-brand h3{
  font-family:var(--display);font-size:28px;letter-spacing:4px;margin:0 0 16px;
}
.footer-brand p{color:var(--charcoal);font-size:14px;line-height:1.8;max-width:380px;margin:0}
.footer-col h4{
  font-family:var(--body);font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;font-weight:500;color:var(--gold);margin:0 0 18px;
}
.footer-col a, .footer-col li{
  display:block;font-size:14px;padding:6px 0;
  color:var(--charcoal);font-weight:300;
  text-decoration:none;list-style:none;
}
.footer-col a:hover{color:var(--gold)}
.footer-list{list-style:none;padding:0;margin:0}

.footer-bottom{
  border-top:1px solid var(--line);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--muted);flex-wrap:wrap;gap:16px;
}
.footer-features{
  display:grid;grid-template-columns:repeat(6, 1fr);
  gap:24px;padding:40px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:50px;
}
.feat-item{text-align:center;padding:0 8px}
.feat-icon{font-size:22px;margin-bottom:8px;color:var(--gold)}
.feat-title{
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  font-weight:500;color:var(--dark);margin-bottom:4px;
}
.feat-text{font-size:11px;color:var(--muted);line-height:1.5}

/* =========== WHATSAPP FLOAT =========== */
.whatsapp-float{
  position:fixed;bottom:24px;right:24px;
  width:56px;height:56px;background:#25D366;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.4);
  z-index:90;transition:transform .2s;text-decoration:none;
}
.whatsapp-float:hover{transform:scale(1.1)}
.whatsapp-float svg{width:30px;height:30px;fill:#fff}

/* =========== MOBILE MENU =========== */
.mobile-menu{
  position:fixed;inset:0;background:var(--cream);
  z-index:200;padding:24px;
  transform:translateX(-100%);
  transition:transform .4s ease;overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-head{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:24px;border-bottom:1px solid var(--line);margin-bottom:24px;
}
.mobile-menu a, .mobile-nav a{
  display:block;padding:14px 0;
  border-bottom:1px solid var(--line);
  font-size:14px;letter-spacing:2px;text-transform:uppercase;
  color:var(--charcoal);text-decoration:none;
}
.mobile-nav{padding:0;margin:0;list-style:none}
.mobile-nav li{list-style:none}
.close-btn{font-size:24px;color:var(--dark);cursor:pointer;border:none;background:none}

/* =========== WOOCOMMERCE PAGE STYLING =========== */

.woocommerce ul.products li.product{
  width:auto !important;float:none !important;
  margin:0 !important;clear:none !important;
  list-style:none;
}
.woocommerce ul.products li.product .aurora-product-inner{
  background:#fff;
}
.woocommerce ul.products li.product img{
  margin:0 0 14px;width:100%;aspect-ratio:3/4;object-fit:cover;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-family:var(--display) !important;
  font-size:18px !important;font-weight:400 !important;
  padding:0 4px !important;margin:0 0 6px !important;color:var(--dark);
}
.woocommerce ul.products li.product .price{
  color:var(--dark) !important;
  padding:0 4px;font-size:14px !important;
  font-weight:400 !important;
}
.woocommerce ul.products li.product .price del{color:var(--muted) !important}
.woocommerce ul.products li.product .price ins{
  color:#A0392E !important;background:transparent !important;
  font-weight:400 !important;
}
/* Shop card Add-to-Bag link — neutralized; appearance is provided by the round icon parent */

/* Single product page */
.woocommerce div.product .product_title{
  font-family:var(--display);font-size:36px;font-weight:400;
}
.woocommerce div.product .price{font-size:20px;color:var(--dark)}
.woocommerce div.product .single_add_to_cart_button{
  background:var(--dark) !important;color:var(--cream) !important;
  padding:14px 38px !important;border-radius:0 !important;
  font-size:12px !important;letter-spacing:2.5px !important;
  text-transform:uppercase !important;
}
.woocommerce div.product .single_add_to_cart_button:hover{
  background:var(--gold) !important;
}

/* Cart, Checkout buttons */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button{
  background:var(--dark) !important;color:var(--cream) !important;
  border-radius:0 !important;padding:12px 28px !important;
  font-size:12px !important;letter-spacing:2px !important;
  text-transform:uppercase !important;font-weight:500 !important;
}


/* Page wrapper */
.page-wrap{max-width:var(--container);margin:0 auto;}

/* =========== RESPONSIVE =========== */
@media(max-width:1024px){
  .nav-inner{justify-content:flex-start;overflow-x:auto;padding:0 16px}
  .nav-inner::-webkit-scrollbar{display:none}
  .aurora-menu, #primary-menu{gap:24px}
  .product-card{flex:0 0 calc(33.33% - 16px)}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .footer-features{grid-template-columns:repeat(3, 1fr);gap:20px}
  .woocommerce ul.products{grid-template-columns:repeat(3, 1fr);gap:24px}
}

@media(max-width:768px){
  .header-inner{grid-template-columns:auto 1fr auto;padding:14px 16px}
  .header-left{display:none}
  .lang-switch{display:none}
  .logo, .header .custom-logo-link{font-size:24px;letter-spacing:4px}
  .hamburger{display:flex;width:38px;height:38px;align-items:center;justify-content:center}
  .hamburger svg{width:22px;height:22px;stroke:var(--dark);fill:none;stroke-width:1.5}
  .nav{display:none}
    .press-track{
         gap:0px;
     }
  .section{padding:60px 0}
  .container{padding:0 16px}

  .hero-arrow{width:40px;height:40px}
  .hero-prev{left:12px}.hero-next{right:12px}

  .product-card{flex:0 0 calc(50% - 12px)}
  .carousel-track{gap:16px}

  .category-grid{grid-template-columns:1fr 1fr;gap:12px}
  .category-card{padding:20px}
  .cat-name{font-size:24px}

  .feature-grid{grid-template-columns:1fr;gap:32px}
  .feature-collection{padding:60px 0}

  .testi-card{padding:0 24px}

  .insta-grid{grid-template-columns:repeat(2, 1fr);gap:6px}

  .footer-top{grid-template-columns:1fr;gap:36px}
  .footer-features{grid-template-columns:repeat(2, 1fr);padding:30px 0}
  .footer-bottom{flex-direction:column;text-align:center}


  .press-logo{font-size:18px}

  .whatsapp-float{width:50px;height:50px;bottom:16px;right:16px}

  .woocommerce ul.products{grid-template-columns:repeat(2, 1fr);gap:14px}
}

@media(max-width:480px){
  .product-card{flex:0 0 calc(75% - 12px)}
}


/* =========================================================
   WOOCOMMERCE — SHOP / ARCHIVE PAGE
   ========================================================= */

/* Shop Hero Banner */
.shop-hero{
  background:linear-gradient(135deg, var(--ivory) 0%, var(--beige) 100%);
  padding:60px 0 50px;
  text-align:center;
  border-bottom:1px solid var(--line);
}
.shop-hero-eyebrow{margin-bottom:18px}
.shop-hero-title{
  font-size:clamp(36px, 5vw, 60px);
  font-weight:400;
  margin:0 0 8px;
  color:var(--dark);
}
.shop-hero-sub{
  color:var(--charcoal);
  max-width:600px;margin:0 auto 16px;
  font-size:15px;
}
.shop-hero-count{
  font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--gold);
  margin:0;
}
.aurora-breadcrumb{
  font-size:11px;letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
}
.aurora-breadcrumb a{color:var(--charcoal);text-decoration:none}
.aurora-breadcrumb a:hover{color:var(--gold)}

/* Shop layout: sidebar + main */
.shop-wrap{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:48px;
  padding:60px 24px;
  max-width:var(--container);
  margin:0 auto;
}
.shop-main{min-width:0}

/* Sidebar */
.shop-sidebar{
  position:sticky;top:160px;
  align-self:start;
  height:fit-content;
}
.sidebar-head{
  display:none;
  justify-content:space-between;
  align-items:center;
  padding-bottom:16px;
  border-bottom:1px solid var(--line);
  margin-bottom:20px;
}
.sidebar-head h3{
  font-family:var(--display);
  font-size:24px;margin:0;
}
.aurora-widget{
  padding-bottom:24px;
  margin-bottom:24px;
  border-bottom:1px solid var(--line);
}
.aurora-widget:last-child{border-bottom:none}
.widget-title{
  font-family:var(--body);
  font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;
  font-weight:500;color:var(--gold);
  margin:0 0 16px;
}
.aurora-widget ul{
  list-style:none;padding:0;margin:0;
}
.aurora-widget ul li{
  padding:6px 0;
  font-size:14px;
}
.aurora-widget ul li a{
  color:var(--charcoal);
  text-decoration:none;
}
.aurora-widget ul li a:hover{color:var(--gold)}
.aurora-widget .count{
  color:var(--muted);
  font-size:12px;
  margin-left:6px;
}

/* Filter empty state */
.filter-empty{
  background:var(--ivory);
  padding:20px;
  border-radius:4px;
}

/* Toolbar (sort + result count) */
.shop-toolbar{
  display:flex;
  align-items:center;
  gap:16px;
  padding-bottom:24px;
  border-bottom:1px solid var(--line);
  margin-bottom:32px;
  flex-wrap:wrap;
}
.shop-result-count{
  font-size:13px;
  color:var(--muted);
  margin:0;
  flex:1;
}
.woocommerce-result-count{
  margin:0 !important;
  font-size:13px !important;
  color:var(--muted) !important;
}
.shop-sort, .woocommerce-ordering{
  margin:0 !important;
}
.woocommerce-ordering select, .orderby{
  font-family:var(--body) !important;
  font-size:13px !important;
  padding:10px 36px 10px 14px !important;
  border:1px solid var(--line) !important;
  background:var(--cream) !important;
  border-radius:0 !important;
  color:var(--dark) !important;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232A2520' stroke-width='1.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 12px center !important;
  background-size:14px !important;
}
.filter-toggle{
  display:none;
  align-items:center;gap:8px;
  font-size:12px;letter-spacing:2px;
  text-transform:uppercase;
  padding:10px 16px;
  border:1px solid var(--line);
  background:var(--cream);
  color:var(--dark);
  cursor:pointer;
}


/* Custom Aurora product card */
.aurora-card{
  position:relative;
  background:transparent;
}
.aurora-card-link{
  display:block;
  color:inherit;
  text-decoration:none;
}
.aurora-card-media{
  position:relative;
  aspect-ratio:3/4;
  background:linear-gradient(135deg,var(--ivory),var(--beige));
  overflow:hidden;
  margin-bottom:14px;
}
.aurora-card-media::before{
  content:attr(data-name);
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:13px;
  color:var(--gold);letter-spacing:1px;
  opacity:.5;text-align:center;padding:20px;z-index:0;
}
.aurora-card-img{
  position:absolute;inset:0;
  width:100% !important;height:100% !important;
  object-fit:cover;
  z-index:1;
}
.aurora-card-img-hover{
  opacity:0;
  transition:opacity .4s ease;
}
.aurora-card:hover .aurora-card-img-hover{opacity:1}
.aurora-card:hover .aurora-card-img-main{opacity:0}
.aurora-card-img-main{transition:opacity .4s ease}

.aurora-card-wishlist{
  position:absolute;top:12px;right:12px;
  width:45px;height:45px;
  border-radius:50%;
  background:rgba(255,255,255,.9);
  display:flex;align-items:center;justify-content:center;
  z-index:3;border:none;cursor:pointer;
  transition:all .2s;
}
.aurora-card-wishlist:hover{background:#fff;transform:scale(1.1)}
.aurora-card-wishlist svg{
  width:16px;height:16px;
  stroke:var(--dark);fill:none;stroke-width:1.5;
  transition:fill .2s;
}
.aurora-card-wishlist.active svg{
  fill:#A0392E;stroke:#A0392E;
}

.aurora-card-quickadd{
  position:absolute;
  left:12px;right:12px;bottom:12px;
  z-index:3;
  opacity:0;transform:translateY(8px);
  transition:all .3s;
}
.aurora-card:hover .aurora-card-quickadd{
  opacity:1;transform:translateY(0);
}
.aurora-card-quickadd .button,
.aurora-card-quickadd .added_to_cart{
  display:block !important;
  width:100% !important;
  text-align:center !important;
  background:var(--dark) !important;
  color:var(--cream) !important;
  padding:12px 18px !important;
  font-size:11px !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  font-weight:500 !important;
  border-radius:0 !important;
  margin:0 !important;
  text-decoration:none !important;
  border:none !important;
}
.aurora-card-quickadd .button:hover{
  background:var(--gold) !important;
}

.aurora-card-body{
  text-align:left;
  padding:0 4px;
}
.aurora-card-title{
  font-family:var(--display);
  font-size:18px;font-weight:400;
  margin:0 0 6px;color:var(--dark);
  line-height:1.3;
}
.aurora-card-price{
  font-size:14px;
  color:var(--dark);
  display:flex;align-items:center;gap:10px;
  margin-bottom:6px;
}
.aurora-card-price del,
.aurora-card-price .price del{
  color:var(--muted);
  font-size:13px;
  text-decoration:line-through;
}
.aurora-card-price ins,
.aurora-card-price .price ins{
  color:#A0392E;
  text-decoration:none;
}
.aurora-card-price .price{margin:0}
.aurora-card-rating{
  display:flex;align-items:center;gap:6px;
  font-size:12px;color:var(--muted);
}
.aurora-card-rating .stars{color:var(--gold);letter-spacing:1px}

.product-badge-new{background:var(--gold)}

/* Pagination */
.shop-pagination{
  margin-top:48px;
  text-align:center;
}
.woocommerce nav.woocommerce-pagination ul{
  border:none !important;
  display:inline-flex !important;
  gap:6px;
}
.woocommerce nav.woocommerce-pagination ul li{
  border:none !important;
  margin:0 !important;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{
  min-width:38px;height:38px;
  display:inline-flex !important;
  align-items:center;justify-content:center;
  background:transparent !important;
  color:var(--charcoal) !important;
  font-size:13px !important;
  border:1px solid var(--line) !important;
  padding:0 !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover{
  background:var(--dark) !important;
  color:var(--cream) !important;
  border-color:var(--dark) !important;
}

.shop-empty{
  text-align:center;
  padding:80px 24px;
}
.shop-empty h2{font-size:32px;margin-bottom:12px}
.shop-empty p{color:var(--muted);margin-bottom:24px}

/* Mobile filter overlay */
.shop-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.4);
  z-index:80;
}
.shop-overlay.show{display:block}


/* =========================================================
   WOOCOMMERCE — SINGLE PRODUCT PAGE
   ========================================================= */

.single-product-wrap{
  padding:30px 0 80px;
 
}
.single-breadcrumb{
  padding:0 24px 24px;
}

.woocommerce div.product{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
}

/* Product Gallery (left side) */
.woocommerce div.product div.images{
  width:100% !important;
  margin-bottom:0 !important;
  position:sticky;
  align-self:start;
}
.woocommerce div.product div.images .flex-control-thumbs{
  display:grid !important;
  grid-template-columns:repeat(4, 1fr) !important;
  gap:8px !important;
  margin-top:8px !important;
}
.woocommerce div.product div.images .flex-control-thumbs li{
  width:auto !important;
  margin:0 !important;
  list-style:none;
}
.woocommerce div.product div.images .flex-control-thumbs li img{
  cursor:pointer;
  opacity:.6;
  transition:opacity .2s;
}
.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li img:hover{
  opacity:1;
}
.woocommerce div.product div.images img{
  width:100%;
  background:var(--ivory);
}

/* Product Summary (right side) */
.woocommerce div.product div.summary{
  width:100% !important;
  margin-bottom:0 !important;
  float:none !important;
  padding-top:8px;
}
.woocommerce div.product .product_title{
  font-family:var(--display) !important;
  font-size:clamp(28px, 4vw, 42px) !important;
  font-weight:400 !important;
  margin:0 0 12px !important;
  letter-spacing:.5px;
  line-height:1.2;
}
.woocommerce div.product .woocommerce-product-rating{
  margin-bottom:20px !important;
  color:var(--muted);
  font-size:13px;
}
.woocommerce .star-rating, .woocommerce-product-rating .star-rating{
  color:var(--gold);
  letter-spacing:2px;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price{
  color:var(--dark) !important;
  font-size:22px !important;
  font-weight:400 !important;
  margin:0 0 24px !important;
  font-family:var(--body);
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del{
  color:var(--muted) !important;
  font-size:18px !important;
  margin-right:10px;
}
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins{
  color:#A0392E !important;
  text-decoration:none !important;
  background:transparent !important;
  font-weight:400 !important;
}

.woocommerce-product-details__short-description{
  padding:24px 0;
  margin:24px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  color:var(--charcoal);
  font-size:15px;
  line-height:1.8;
}

/* Variations / size selector */
.woocommerce div.product form.cart .variations{
  margin-bottom:24px !important;
}
.woocommerce div.product form.cart .variations label{
  font-size:11px;letter-spacing:2px;
  text-transform:uppercase;
  font-weight:500;
  color:var(--gold);
  margin-bottom:8px;
}
.woocommerce div.product form.cart .variations select{
  padding:12px 36px 12px 14px !important;
  border:1px solid var(--line) !important;
  background:var(--cream) !important;
  font-family:var(--body) !important;
  font-size:14px !important;
  border-radius:0 !important;
  width:100%;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232A2520' stroke-width='1.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 12px center !important;
  background-size:14px !important;
}

/* Quantity + Add to Cart */
.woocommerce div.product form.cart{
  display:flex !important;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:32px !important;
  align-items:center;
}
.woocommerce .quantity .qty{
  width:80px !important;
  padding:14px !important;
  border:1px solid var(--line) !important;
  font-family:var(--body) !important;
  font-size:14px !important;
  text-align:center !important;
  background:var(--cream);
}
.woocommerce div.product form.cart .button,
.woocommerce div.product form.cart button{
  background:var(--dark) !important;
  color:var(--cream) !important;
  padding:14px 38px !important;
  border:1px solid var(--dark) !important;
  border-radius:0 !important;
  font-size:12px !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  font-weight:500 !important;
  font-family:var(--body) !important;
  flex:1;min-width:200px;
  transition:all .3s;
}
.woocommerce div.product form.cart .button:hover{
  background:var(--gold) !important;
  border-color:var(--gold) !important;
}

/* Product meta */
.product_meta{
  font-size:12px;
  color:var(--muted);
  padding-top:24px;
  border-top:1px solid var(--line);
}
.product_meta > span{
  display:block;
  margin-bottom:6px;
}
.product_meta a{color:var(--charcoal);text-decoration:none}
.product_meta a:hover{color:var(--gold)}

/* Tabs */
.woocommerce div.product .woocommerce-tabs{
  grid-column:1 / -1;
  margin-top:80px !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs{
  border-bottom:1px solid var(--line) !important;
  padding:0 !important;
  margin:0 !important;
  display:flex;
  gap:32px;
  flex-wrap:wrap;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{
  display:none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  background:transparent !important;
  border:none !important;
  border-bottom:2px solid transparent !important;
  border-radius:0 !important;
  margin:0 !important;
  padding:0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none !important}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  padding:14px 0 !important;
  font-size:12px !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  font-weight:500 !important;
  color:var(--charcoal) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{
  border-bottom-color:var(--dark) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{
  color:var(--dark) !important;
}
.woocommerce div.product .woocommerce-Tabs-panel{
  padding:32px 0 !important;
  font-size:15px;
  line-height:1.8;
  color:var(--charcoal);
}
.woocommerce div.product .woocommerce-Tabs-panel h2{
  font-family:var(--display);
  font-size:24px;
  font-weight:400;
  margin-bottom:16px;
}

/* Related products */
.related.products{
  grid-column:1 / -1;
}
.related.products > h2{
  font-family:var(--display) !important;
  font-size:clamp(28px, 4vw, 40px) !important;
  font-weight:400 !important;
  text-align:center;
  padding-bottom: 30px;
}
.related.products::before{
  content:'You May Also Love';
  display:block;
  font-size:11px;letter-spacing:3px;
  text-transform:uppercase;
  color:var(--gold);
  text-align:center;
  margin-bottom:8px;
}





/* =========================================================
   WOOCOMMERCE — MY ACCOUNT PAGE
   ========================================================= */

.woocommerce-account .woocommerce{
  display:block;
}
.woocommerce-account .woocommerce-MyAccount-navigation{
  width:240px !important;
  float:left !important;
  margin-right:48px;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li{
  border-bottom:1px solid var(--line);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{
  display:block;
  padding:14px 0;
  font-size:13px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--charcoal);
  text-decoration:none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a{
  color:var(--gold);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover{
  color:var(--gold);
}
.woocommerce-account .woocommerce-MyAccount-content{
  width:calc(100% - 288px) !important;
  float:right !important;
}

/* Login forms */
.woocommerce-account .woocommerce > .u-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  max-width:900px;
  margin:0 auto !important;
}
.woocommerce-account .woocommerce > .u-columns .col-1,
.woocommerce-account .woocommerce > .u-columns .col-2{
  width:100% !important;
  float:none !important;
}

.woocommerce form.checkout_coupon,
.woocommerce form.lost_reset_password{
  border:1px solid var(--line) !important;
  padding:32px !important;
  border-radius:0 !important;
}


/* =========================================================
   NOTICES
   ========================================================= */

.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error,
.woocommerce-noreviews,
p.no-comments{
  border-radius:0;
  background:#fff;
  border:1px solid var(--line);
  font-size:14px;
  margin:0 0 24px;
  color:var(--dark);
  font-family:var(--body);
  letter-spacing:.3px;
  position:relative;
}
.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-error::before{
  color:var(--gold);
  top:14px;
  left:18px;
}
.woocommerce .woocommerce-message{
  border-left:3px solid var(--dark);
}
.woocommerce .woocommerce-error{
  border-left:3px solid #A0392E;
}
.woocommerce .woocommerce-message .button,
.woocommerce .woocommerce-info .button{
  float:right;
  background:var(--dark) !important;
  color:#fff !important;
  padding:8px 16px !important;
  font-size:11px !important;
  letter-spacing:1.5px !important;
}


/* =========================================================
   RESPONSIVE — WOOCOMMERCE
   ========================================================= */
@media(max-width:1024px){
  .shop-wrap{
    grid-template-columns:1fr;
    gap:0;
  }
  .shop-sidebar{
    position:fixed;
    top:0;left:-300px;
    width:300px;height:100vh;
    background:var(--cream);
    padding:24px;
    z-index:90;
    overflow-y:auto;
    box-shadow:4px 0 20px rgba(0,0,0,.1);
    transition:left .3s ease;
  }
  .shop-sidebar.open{left:0}
  .sidebar-head{display:flex}
  .filter-toggle{display:inline-flex}

  .woocommerce ul.products{grid-template-columns:repeat(2, 1fr) !important;gap:16px !important}
  .woocommerce div.product{grid-template-columns:1fr;gap:32px}
  .woocommerce div.product div.images{position:static}

  .woocommerce-checkout form.checkout{grid-template-columns:1fr}
  .woocommerce-checkout #order_review_heading,
  .woocommerce-checkout #order_review{grid-column:1;grid-row:auto}

  .woocommerce-account .woocommerce-MyAccount-navigation,
  .woocommerce-account .woocommerce-MyAccount-content{
    width:100% !important;
    float:none !important;
    margin:0 0 32px;
  }

  .woocommerce-account .woocommerce > .u-columns{grid-template-columns:1fr;gap:32px}
}

@media(max-width:600px){
  .woocommerce ul.products{gap:12px !important}
  .aurora-card-quickadd{
    opacity:1;transform:none;
    position:static;
    margin-top:8px;
    padding:0;
  }
  .woocommerce table.shop_table_responsive tr td{
    padding:8px !important;
    font-size:13px !important;
  }
  .woocommerce .cart-collaterals .cart_totals{padding:20px}
}

/* Hide shop sidebar feature toggle bar on mobile when filters open */
.shop-sidebar.open ~ .shop-overlay{display:block}


/* =========================================================
   MEGA MENU (Shop hover — full-width panel with 4 columns)
   ========================================================= */

.aurora-nav{
  display:flex;gap:42px;
  margin:0;padding:0;list-style:none;
}
.aurora-nav > li{
  position:static; /* important — mega menu spans full width */
  list-style:none;
}
.aurora-nav > li > a{
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
  padding:18px 0;display:inline-block;
  color:var(--charcoal);font-weight:400;
  text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color .2s, color .2s;
}
.aurora-nav > li > a:hover,
.aurora-nav > li.nav-has-mega:hover > a{
  color:var(--dark);
  border-bottom-color:var(--dark);
}

/* Full-width mega menu panel */
.mega-menu{
  position:absolute;
  left:0;right:0;top:100%;
  background:#fff;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  box-shadow:0 30px 60px -25px rgba(0,0,0,.12);
  padding:50px 0;
  opacity:0;visibility:hidden;
  transform:translateY(-8px);
  transition:opacity .25s ease, transform .25s ease, visibility .25s;
  z-index:99;
}
.nav-has-mega:hover > .mega-menu,
.mega-menu:hover{
  opacity:1;visibility:visible;transform:translateY(0);
}

.mega-col h4{
  font-family:var(--body);
  font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;font-weight:500;
  color:var(--gold);margin:0 0 16px;
}
.mega-col ul{list-style:none;padding:0;margin:0}
.mega-col ul li{margin:0;list-style:none}
.mega-col ul li a{
  display:block;padding:7px 0;
  font-size:14px;letter-spacing:0;text-transform:none;
  color:var(--charcoal);font-weight:300;
  text-decoration:none;
  transition:color .15s, padding-left .2s;
}
.mega-col ul li a:hover{color:var(--dark);padding-left:6px}


/* =========================================================
   CART DRAWER (slides from right)
   ========================================================= */

.cart-drawer{
  position:fixed;top:0;right:-440px;
  width:420px;max-width:100vw;height:100vh;
  background:var(--cream);
  z-index:300;
  display:flex;flex-direction:column;
  transition:right .35s cubic-bezier(.4,0,.2,1);
  box-shadow:-20px 0 60px -10px rgba(0,0,0,.2);
}
.cart-drawer.open{right:0}

.cart-drawer-head{
  padding:24px 28px;
  border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
}
.cart-drawer-head h3{
  font-family:var(--display);
  font-size:24px;font-weight:400;margin:0;
  letter-spacing:.5px;
}

.cart-drawer-shipping{
  padding:18px 28px;
  border-bottom:1px solid var(--line);
  background:var(--ivory);
  text-align:center;
}
.cart-drawer-shipping p{
  font-size:13px;
  color:var(--charcoal);
  margin:0 0 10px;
  letter-spacing:.3px;
}
.cart-progress{
  height:3px;background:var(--line);
  border-radius:2px;overflow:hidden;
}
.cart-progress-bar{
  height:100%;background:var(--gold);
  transition:width .4s ease;
}

.cart-drawer-body{
  flex:1;overflow-y:auto;
  padding:8px 28px;
}
.cart-drawer-items{
  list-style:none;padding:0;margin:0;
}
.cart-drawer-item{
  display:flex;gap:16px;
  padding:20px 0;
  border-bottom:1px solid var(--line);
  list-style:none;
}
.cart-drawer-item:last-child{border-bottom:none}

.cart-item-image{
  width:80px;height:100px;flex-shrink:0;
  background:var(--ivory);
  display:block;overflow:hidden;
}
.cart-item-image img{
  width:100% !important;height:100% !important;
  object-fit:cover;
}
.cart-item-info{
  flex:1;display:flex;flex-direction:column;gap:4px;
  min-width:0;
}
.cart-item-name{
  font-family:var(--display);
  font-size:16px;font-weight:400;
  color:var(--dark);
  text-decoration:none;line-height:1.3;
}
.cart-item-name:hover{color:var(--gold)}
.cart-item-meta{
  font-size:12px;color:var(--muted);
  letter-spacing:.5px;
}
.cart-item-price{
  font-size:14px;color:var(--dark);
  margin-top:4px;
}
.cart-item-remove{
  font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:underline;
  margin-top:auto;align-self:flex-start;
  padding:6px 0 0;
}
.cart-item-remove:hover{color:#A0392E}

.cart-drawer-empty{
  padding:60px 28px;
  text-align:center;
}
.cart-drawer-empty p{
  font-family:var(--display);
  font-size:22px;font-weight:300;
  color:var(--dark);
  margin:0 0 24px;
}

.cart-drawer-foot{
  padding:24px 28px;
  border-top:1px solid var(--line);
  background:var(--ivory);
}
.cart-subtotal{
  display:flex;justify-content:space-between;align-items:center;
  font-size:14px;color:var(--charcoal);
  margin-bottom:18px;
}
.cart-subtotal strong{
  font-family:var(--display);
  font-size:20px;font-weight:500;
  color:var(--dark);
}
.cart-checkout-btn{
  display:block !important;
  width:100% !important;
  text-align:center;
  padding:16px !important;
  font-size:13px !important;
  letter-spacing:2.5px !important;
  margin-bottom:8px;
}
.cart-view-link{
  display:block;text-align:center;
  font-size:11px;letter-spacing:2px;
  text-transform:uppercase;
  color:var(--charcoal);
  text-decoration:underline;
  padding:10px 0;
}


/* =========================================================
   SHARED OVERLAY (cart, menu, filters)
   ========================================================= */


/*.aurora-overlay.open{*/
/*  opacity:1;visibility:visible;*/
/*}*/
body.aurora-locked{overflow:hidden}


/* =========================================================
   SHOP FILTER DRAWER (replaces sidebar — slides from left)
   ========================================================= */

/* Override previous shop layout — now single column with drawer */
.shop-wrap{
  grid-template-columns:1fr !important;
  gap:0 !important;
}
.shop-sidebar{
  position:fixed !important;
  top:0;left:-340px !important;
  width:340px;max-width:90vw;
  height:100vh;
  background:var(--cream);
  z-index:280;
  padding:0;
  margin:0;
  overflow-y:auto;
  box-shadow:20px 0 40px -10px rgba(0,0,0,.15);
  transition:left .35s cubic-bezier(.4,0,.2,1);
}
.shop-sidebar.open{
  left:0 !important;
}
.shop-sidebar .sidebar-head{
  display:flex !important;
  padding:24px 28px !important;
  border-bottom:1px solid var(--line);
  background:var(--cream);
  position:sticky;top:0;
  margin:0 !important;
}
.shop-sidebar .sidebar-head h3{
  font-family:var(--display);
  font-size:24px;font-weight:400;margin:0;
}
.shop-sidebar .aurora-widget{
  padding:20px 28px;margin:0;
  border-bottom:1px solid var(--line);
}
.shop-sidebar .aurora-widget:last-child{border-bottom:none}

/* Filter button always visible (top of shop) */
.shop-toolbar .filter-toggle{
  display:inline-flex !important;
  align-items:center;gap:8px;
  font-size:12px;letter-spacing:2px;
  text-transform:uppercase;
  padding:10px 16px;
  border:1px solid var(--line);
  background:transparent;
  color:var(--dark);
  cursor:pointer;
  font-family:var(--body);
}
.shop-toolbar .filter-toggle:hover{
  background:var(--dark);color:var(--cream);
  border-color:var(--dark);
}


/* =========================================================
   COLOR REFINEMENTS — cleaner, more minimal
   ========================================================= */

/* Reduce gold prominence in key areas — more like aishas */
:root{
  --cream:#FAF7F1;        /* slightly cleaner cream */
  --ivory:#F5EFE5;
  --dark:#1F1B17;         /* deeper, near-black */
  --gold:#A88A5C;         /* less saturated, more classy */
  --line:#E5DFD3;
}

/* Make eyebrows less prominent — they were too gold-heavy */
.eyebrow{color:var(--gold);opacity:.95}

/* Header logo cleaner spacing */
.logo, .header .custom-logo-link{
  letter-spacing:5px;
  font-weight:500;
}


/* =========================================================
   RESPONSIVE — mega menu, cart drawer
   ========================================================= */

@media(max-width:1024px){
  .nav{display:none}
  .mega-menu{display:none !important}
  .cart-drawer{width:380px}
}

@media(max-width:768px){
  .cart-drawer{width:100vw;right:-100vw}
  .cart-drawer.open{right:0}
  .cart-drawer-head, .cart-drawer-shipping, .cart-drawer-body, .cart-drawer-foot{
    padding-left:20px;padding-right:20px;
  }
  .shop-sidebar{width:300px;left:-300px !important}
}

/* Mobile menu list improvements */
.mobile-nav-list{margin-top:8px}
.mobile-nav-list a{
  display:block;padding:14px 0;
  border-bottom:1px solid var(--line);
  font-size:14px;letter-spacing:2px;text-transform:uppercase;
  color:var(--charcoal);text-decoration:none;
}
.mobile-nav-list a strong{color:var(--dark)}
.mobile-menu-footer{
  padding:24px 0;
  display:flex;gap:12px;flex-wrap:wrap;
}


/* =========================================================
   v1.2 — TOP BAR + FOOTER COLOR + POPUPS + HOVER FIX
   ========================================================= */

/* Top bar (announcement) — soft pink theme as requested */
:root{
  --topbar-bg:#CCA9A9;
  --topbar-text:#FFFFFF;
  --footer-bg:#FFF7F7;
}
.announce{
  background:var(--topbar-bg) !important;
  color:var(--topbar-text) !important;
}
.announce-item::before{color:var(--topbar-text);opacity:.7}

/* Footer bg refined */
.footer{
  background:var(--footer-bg) !important;
  border-top:1px solid var(--line);
}
.footer-features{
  background:var(--footer-bg);
}

/* =========================================================
   MEGA MENU — robust hover fix (v1.1 had spec issues)
   ========================================================= */
.nav{position:relative;z-index:99}
.aurora-nav > li.nav-has-mega{position:static}
.aurora-nav > li.nav-has-mega > a{position:relative;cursor:pointer}
.aurora-nav > li.nav-has-mega > a::after{
  content:'';display:inline-block;
  width:6px;height:6px;
  border-right:1px solid currentColor;
  border-bottom:1px solid currentColor;
  transform:rotate(45deg);
  margin-left:8px;margin-bottom:3px;
  vertical-align:middle;
  transition:transform .2s;
}
.aurora-nav > li.nav-has-mega:hover > a::after{transform:rotate(225deg);margin-bottom:-3px}

.mega-menu{
  display:block !important; /* override any inherited display:none */
  pointer-events:none;
}
.mega-menu .mega-inner{pointer-events:auto}
.nav-has-mega:hover > .mega-menu,
.mega-menu:hover{
  opacity:1 !important;
  visibility:visible !important;
  transform:translateY(0) !important;
  pointer-events:auto;
}
.mega-menu{
  pointer-events:none;
  opacity:0;visibility:hidden;
}

/* Add invisible bridge so menu doesn't close when moving cursor */
.aurora-nav > li.nav-has-mega::before{
  content:'';
  position:absolute;
  left:0;right:0;
  top:100%;
  height:20px;
  z-index:98;
}
.aurora-nav > li.nav-has-mega:hover::before{display:block}




/* =========================================================
   NEWSLETTER POPUP — small dismissible bottom-left card
   ========================================================= */
.newsletter-pop{
  position:fixed;
  left:24px;bottom:24px;
  width:340px;max-width:calc(100vw - 48px);
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 20px 50px -10px rgba(0,0,0,.15);
  z-index:150;
  padding:24px;
  transform:translateY(140%);
  opacity:0;visibility:hidden;
  transition:all .5s cubic-bezier(.4,0,.2,1);
}
.newsletter-pop.show{
  transform:translateY(0);
  opacity:1;visibility:visible;
}
.newsletter-pop-close{
  position:absolute;top:8px;right:8px;
  width:28px;height:28px;
  background:transparent;border:none;cursor:pointer;
  color:var(--muted);font-size:18px;
}
.newsletter-pop-eyebrow{
  font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:6px;font-weight:500;
}
.newsletter-pop h4{
  font-family:var(--display);
  font-size:22px;font-weight:400;
  margin:0 0 8px;line-height:1.2;
}
.newsletter-pop p{
  font-size:13px;color:var(--charcoal);
  margin:0 0 16px;line-height:1.5;
}
.newsletter-pop-form{
  display:flex;
  border-bottom:1px solid var(--dark);
}
.newsletter-pop-form input{
  flex:1;border:none;background:transparent;
  padding:10px 4px;font-family:inherit;font-size:13px;
  color:var(--dark);outline:none;
}
.newsletter-pop-form button{
  font-size:11px;letter-spacing:2px;
  text-transform:uppercase;font-weight:500;
  padding:10px 4px;color:var(--dark);
  background:transparent;border:none;cursor:pointer;
}
.newsletter-pop-tos{
  font-size:10px;color:var(--muted);
  margin-top:10px;line-height:1.4;
}

@media(max-width:600px){
  .newsletter-pop{
    left:12px;right:12px;width:auto;
    bottom:80px;
  }
}


/* =========================================================
   v1.3 — SINGLE-MESSAGE ANNOUNCE BAR + FULL-WIDTH MEGA + 
   FOOTER #FFF7F7 + LIFESTYLE SECTIONS
   ========================================================= */

/* New rotating announce bar (one message at a time, arrows) */
.announce-bar{
  background:var(--topbar-bg);
  color:var(--topbar-text);
  position:relative;
  overflow:hidden;
  min-height:48px;
}
.announce-bar-inner{
  display:flex;align-items:center;justify-content:center;
  gap:12px;padding:10px 16px;
  max-width:var(--container);margin:0 auto;
}
.announce-arrow{
  width:30px;height:30px;border-radius:50%;
  background:transparent;border:none;
  display:flex;align-items:center;justify-content:center;
  color:var(--topbar-text);cursor:pointer;
  transition:background .2s;flex-shrink:0;
}
.announce-arrow:hover{background:rgba(255,255,255,.15)}
.announce-slides{
  position:relative;
  flex:1;max-width:600px;
  height:32px;
  text-align:center;
}
.announce-slide{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  gap:10px;font-size:13px;letter-spacing:.5px;
  opacity:0;visibility:hidden;
  transition:opacity .4s ease;
  flex-wrap:wrap;
}
.announce-slide.active{opacity:1;visibility:visible}
.announce-slide strong{
  font-weight:600;text-transform:uppercase;letter-spacing:1px;
}
.announce-slide span{opacity:.9;font-weight:300}

/* Hide old announce bar styling */
.announce{display:none}


/* =========================================================
   MEGA MENU — TRUE FULL-WIDTH (extends edge to edge)
   ========================================================= */

.nav{position:relative;z-index:99}
.aurora-nav > li.nav-has-mega{position:static !important}
.mega-menu{
  position:absolute !important;
  left:0 !important;right:0 !important;
  width:100% !important;
  top:100% !important;
  background:#fff !important;
  border-top:1px solid var(--line) !important;
  border-bottom:1px solid var(--line) !important;
  box-shadow:0 30px 60px -25px rgba(0,0,0,.12) !important;
  padding:50px 0 !important;
  z-index:99 !important;
}
.mega-inner{
  max-width:var(--container) !important;
  margin:0 auto !important;
  padding:0 24px !important;
  width:100% !important;
}


/* =========================================================
   SEARCH ICON — BIGGER
   ========================================================= */

.icon-btn-search{width:44px !important;height:44px !important}
.icon-btn-search svg{width:24px !important;height:24px !important;stroke-width:1.6}


/* =========================================================
   FOOTER — FULLY #FFF7F7 (incl. features bar + AS FEATURED IN)
   ========================================================= */

.press{background:var(--footer-bg) !important;border:none !important}
.footer-features{background:var(--footer-bg) !important;border:none !important;margin-top:0 !important}
.footer{background:var(--footer-bg) !important;padding-top:30px !important}
.newsletter{background:var(--footer-bg) !important}

/* Wrapper section that ensures continuous bg */
.bottom-wrap{background:var(--footer-bg)}


/* =========================================================
   SHOP THE EDIT — lifestyle image (left) + product carousel (right)
   ========================================================= */

.shop-edit-section{
  padding:90px 0;
  background:#fff;
}
.shop-edit-head{
  text-align:center;margin-bottom:50px;
}
.shop-edit-head h2{
  font-size:clamp(28px, 4vw, 40px);
  font-weight:400;letter-spacing:1px;
  text-transform:uppercase;margin:0;
}
.shop-edit-grid{
  max-width:var(--container);margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:48px;align-items:center;
}
.shop-edit-image{
  position:relative;
  aspect-ratio:4/5;
  background:linear-gradient(135deg,#E8DCC4,#C9A47B);
  background-size:cover;background-position:center;
  overflow:hidden;
}

.shop-edit-image:has(img)::before{display:none}
.shop-edit-image img{
  width:100%;height:100%;
  object-fit:cover;
  position:absolute;inset:0;
}

/* Hotspot tags (clickable circles on lifestyle image) */
.shop-edit-hotspot{
  position:absolute;
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.95);
  padding:6px 14px;
  border-radius:30px;
  font-size:12px;color:var(--dark);
  text-decoration:none;
  box-shadow:0 4px 12px rgba(0,0,0,.1);
  z-index:3;
  transition:transform .2s;
}
.shop-edit-hotspot:hover{transform:scale(1.05)}
.shop-edit-hotspot::before{
  content:'';
  width:8px;height:8px;border-radius:50%;
  background:var(--dark);
}

.shop-edit-products{
  position:relative;padding:0 50px;
}
.shop-edit-prev, .shop-edit-next{
  position:absolute;top:40%;
  width:36px;height:36px;border-radius:50%;
  background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:2;
}
.shop-edit-prev{left:0}
.shop-edit-next{right:0}
.shop-edit-prev svg, .shop-edit-next svg{width:14px;height:14px;stroke:var(--dark);fill:none;stroke-width:1.5}

.shop-edit-track{
  display:flex;
  overflow:hidden;
  scroll-snap-type:x mandatory;
}
.shop-edit-card{
  flex:0 0 100%;scroll-snap-align:start;
  text-align:center;
}
.shop-edit-card-img{
  aspect-ratio:1/1;
  background:linear-gradient(135deg,var(--ivory),var(--beige));
  background-size:cover;background-position:center;
  margin-bottom:14px;
}
.shop-edit-card-img img{width:100%;height:100%;object-fit:cover}
.shop-edit-card-name{
  font-family:var(--display);
  font-size:16px;font-weight:400;
  margin-bottom:4px;
}
.shop-edit-card-price{font-size:14px;color:var(--dark)}

.shop-edit-dots{
  display:flex;justify-content:center;
  gap:8px;margin-top:18px;
}
.shop-edit-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--line);border:none;cursor:pointer;
  transition:background .2s;
}
.shop-edit-dot.active{background:var(--dark)}


/* =========================================================
   VISIT US IN STORE — 50/50 image (left) + text (right)
   ========================================================= */


.visit-store-image{
  background:linear-gradient(135deg,#E8DCC4,#C9A47B);
  background-size:cover;background-position:center;
  position:relative;
}

.visit-store-image:has(img)::before{display:none}
.visit-store-image img{width:100%;height:100%;object-fit:cover}
.visit-store-text{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 48px;text-align:center;
  background:var(--ivory);
}
.visit-store-text h2{
  font-family:var(--display);
  font-size:clamp(26px, 3vw, 34px);
  font-weight:400;letter-spacing:2px;
  text-transform:uppercase;
  margin:0 0 24px;
}
.visit-store-text p{
  font-size:15px;line-height:1.7;
  color:var(--charcoal);
  max-width:440px;margin:0 0 14px;
}
.visit-store-text .btn{
  margin-top:24px;
  border-radius:30px !important;
  padding:14px 32px !important;
  background:var(--dark) !important;color:var(--cream) !important;
}

/* Replace the old .visit section in CSS */
.visit{display:none !important}


/* =========================================================
   GIFT GIVING — A LOVE LANGUAGE (centered text + image)
   ========================================================= */

.gift-giving{
  background:var(--footer-bg);
  padding:80px 0;
  text-align:center;
}
.gift-giving-inner{
  max-width:900px;margin:0 auto;
  padding:0 24px;
}
.gift-giving h2{
  font-family:var(--body);
  font-size:13px;letter-spacing:3px;
  text-transform:uppercase;font-weight:500;
  color:var(--dark);margin:0 0 24px;
}
.gift-giving p{
  font-size:15px;line-height:1.7;
  color:var(--charcoal);
  max-width:680px;margin:0 auto 18px;
}
.gift-giving p.italic{
  font-style:italic;color:var(--charcoal);
  margin-top:8px;
}
.gift-giving-cta{
  font-size:13px;letter-spacing:1px;
  text-transform:none;
  color:var(--dark);text-decoration:none;
  border-bottom:1px solid var(--dark);
  padding:0 0 4px;display:inline-block;
  margin:8px 0 36px;
}
.gift-giving-image{
  max-width:560px;margin:0 auto;
  aspect-ratio:4/5;
  background:linear-gradient(135deg,#E8DCC4,#C9A47B);
  background-size:cover;background-position:center;
  position:relative;
}

.gift-giving-image:has(img)::before{display:none}
.gift-giving-image img{width:100%;height:100%;object-fit:cover}


/* =========================================================
   RESPONSIVE — v1.3 sections
   ========================================================= */

@media(max-width:768px){
  .announce-slide{font-size:12px}
  .announce-slide strong{display:block;margin-bottom:2px}

  .shop-edit-grid{grid-template-columns:1fr;gap:32px}
  .shop-edit-products{padding:0 40px}

  .visit-store{grid-template-columns:1fr}
  .visit-store-text{padding:48px 24px}

  .gift-giving{padding:60px 0}
  .gift-giving-image{aspect-ratio:4/5;max-width:100%}
}


/* =========================================================
   v1.4 — TARGETED FIXES
   ========================================================= */

/* --- FIX: WooCommerce / My Account pages need full width --- */
.page-wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:60px 24px;
  width:100%;
  box-sizing:border-box;
}
.entry-content-editorial{
  max-width:780px;margin:0 auto;
  font-size:16px;line-height:1.8;
}
.entry-content-wide{
  max-width:100%;width:100%;
}
.page-header-aurora{
  text-align:center;margin-bottom:48px;
}
.page-header-aurora h1{
  font-family:var(--display);
  font-size:clamp(36px, 5vw, 56px);
  font-weight:400;margin:0;
}




/* --- FIX: Search icon size (force higher specificity) --- */
header.header .header-right .icon-btn.icon-btn-search,
header.header button.icon-btn-search{
  width:44px !important;
  height:44px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}
header.header .icon-btn-search svg{
  width:24px !important;
  height:24px !important;
  stroke-width:1.6 !important;
}
/* Also enlarge other header icons for consistency */
header.header .icon-btn{
  width:44px !important;height:44px !important;
}
header.header .icon-btn svg{
  width:22px !important;height:22px !important;
}


/* --- FIX: Mega menu TRUE full-viewport width (uses transform trick) --- */
nav.nav{
  position:relative !important;
  width:100% !important;
  z-index:99 !important;
}
nav.nav .aurora-nav > li.nav-has-mega{
  position:static !important;
}
nav.nav .aurora-nav > li.nav-has-mega > .mega-menu{
  position:absolute !important;
  left:50% !important;
  right:auto !important;
  top:100% !important;
  width:100vw !important;
  max-width:100vw !important;
  transform:translateX(-50%) !important;
  margin-left:0 !important;
  background:#fff !important;
  border-top:1px solid var(--line) !important;
  border-bottom:1px solid var(--line) !important;
  box-shadow:0 30px 60px -25px rgba(0,0,0,.12) !important;
  padding:50px 0 !important;
  z-index:99 !important;
}
nav.nav .aurora-nav > li.nav-has-mega:hover > .mega-menu,
nav.nav .aurora-nav > li.nav-has-mega > .mega-menu:hover{
  opacity:1 !important;
  visibility:visible !important;
  transform:translateX(-50%) translateY(0) !important;
  pointer-events:auto !important;
}
/* Reset mega-menu default state with proper transform */
nav.nav .aurora-nav > li.nav-has-mega > .mega-menu{
  opacity:0;visibility:hidden;
  transform:translateX(-50%) translateY(-8px) !important;
}


/* --- FIX: Category cards height 640px --- */
.category-grid{
  grid-template-columns:repeat(3, 1fr) !important;
  gap:16px !important;
}
.category-card{
  aspect-ratio:unset !important;
  height:640px !important;
  padding:36px !important;
}
.category-card .cat-name{
  font-size:38px !important;
}

@media(max-width:1024px){
  .category-card{height:480px !important}
  .category-card .cat-name{font-size:30px !important}
}
@media(max-width:768px){
  .category-grid{grid-template-columns:1fr 1fr !important;gap:10px !important}
  .category-card{height:360px !important;padding:20px !important}
  .category-card .cat-name{font-size:24px !important}
}


/* --- Shop The Edit hotspot ACTIVE state --- */
.shop-edit-hotspot.active{
  background:var(--dark) !important;
  color:var(--cream) !important;
}
.shop-edit-hotspot.active::before{
  background:var(--cream) !important;
}


/* =========================================================
   v1.5 — SHOP THE EDIT SLIDER FIX + COLOR UPDATES
   ========================================================= */

/* Shop The Edit — clean viewport + track for proper slider */
.shop-edit-products{
  position:relative;
  padding:0 50px;
  display:flex;flex-direction:column;
}
.shop-edit-viewport{
  width:100%;
  overflow:hidden;
  position:relative;
}
.shop-edit-track{
  display:flex !important;
  width:100%;
  transition:transform .5s cubic-bezier(.4,0,.2,1) !important;
  overflow:visible !important;
  scroll-snap-type:none !important;
}
.shop-edit-card{
  flex:0 0 100% !important;
  width:100% !important;
  scroll-snap-align:none !important;
  padding:0 8px;
  box-sizing:border-box;
}
.shop-edit-card-img{
  aspect-ratio:1/1;
  background:linear-gradient(135deg,var(--ivory),var(--beige));
  margin-bottom:14px;
  overflow:hidden;
  position:relative;
}
.shop-edit-card-img img{
  width:100% !important;height:100% !important;
  object-fit:cover;
  position:absolute;inset:0;
}

/* Visit Us In Store — right side bg #efede7 */
.visit-store-text{
  background:#efede7 !important;
}

/* Gift Giving — confirm bg #fff7f7 */
.gift-giving{
  background:#fff7f7 !important;
}

/* Hero slider — ensure background-image inline works smoothly with gradient fallback */
.hero-slide{
  background-size:cover !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
}
.hero-slide-1{background-color:#E8DCC4}
.hero-slide-2{background-color:#2A2520;color:var(--cream)}
.hero-slide-3{background-color:#FBF7F0}
.hero-slide-4{background-color:#C9A47B;color:var(--cream)}

/* Hero text — make readable on photo backgrounds */
.hero-slide .hero-content{
  padding:40px;
  border-radius:4px;
}


/* When user adds real photo via inline style, override gradient bg */



/* =========================================================
   v1.6 — MEGA MENU CENTERED + TAGLINE SECTION + POLISH
   ========================================================= */

/* MEGA MENU — centered dropdown with min-width (NOT full 100vw) */
nav.nav .aurora-nav > li.nav-has-mega > .mega-menu{
  position:absolute !important;
  left:50% !important;
  right:auto !important;
  top:100% !important;
  transform:translateX(-50%) translateY(-8px) !important;
  width:auto !important;
  min-width:720px !important;
  max-width:90vw !important;
  background:#fff !important;
  border:1px solid var(--line) !important;
  border-top-width:1px !important;
  box-shadow:0 30px 60px -25px rgba(0,0,0,.12) !important;
  padding:36px 40px !important;
  z-index:99 !important;
  opacity:0;visibility:hidden;
  pointer-events:none;
  transition:all .25s ease !important;
}
nav.nav .aurora-nav > li.nav-has-mega:hover > .mega-menu,
nav.nav .aurora-nav > li.nav-has-mega > .mega-menu:hover{
  opacity:1 !important;visibility:visible !important;
  transform:translateX(-50%) translateY(0) !important;
  pointer-events:auto !important;
}

/* Small mega menu (Gift Guide, About — 2 columns) */
nav.nav .aurora-nav > li.nav-has-mega > .mega-menu.mega-menu-small{
  min-width:130px !important;
  max-width:560px !important;
}




/* =========================================================
   TAGLINE SECTION — "YOUR NEXT FAVORITE PIECE..." + 6 USPs
   ========================================================= */

.tagline-bar{
  background:var(--footer-bg);
  padding:0px 0 60px;
  text-align:center;
  border-bottom:1px solid var(--line);
}
.tagline-bar-heading{
  font-family:var(--display);
  font-size:clamp(22px, 3vw, 34px);
  font-weight:400;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--dark);
  margin:0 0 60px;
  padding:0 24px;
}

/* Override footer-features to be cleaner, larger spacing */
.tagline-bar .footer-features{
  display:grid !important;
  grid-template-columns:repeat(6, 1fr) !important;
  gap:24px !important;
  margin:0 auto !important;
  padding:0 24px !important;
  border:none !important;
  background:transparent !important;
}

.tagline-bar .feat-item{
  text-align:center;
  padding:0 8px;
}
.tagline-bar .feat-icon{
  font-size:32px !important;
  margin-bottom:14px !important;
  color:var(--dark) !important;
  display:block;
}
.tagline-bar .feat-title{
  font-size:13px !important;
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-weight:500;
  color:var(--dark);
  margin-bottom:6px !important;
}
.tagline-bar .feat-text{
  font-size:12px !important;
  color:var(--muted) !important;
  line-height:1.5;
  max-width:160px;
  margin:0 auto;
}

/* Hide the old footer-features (now inside tagline-bar) */
body .footer-features:not(.tagline-bar .footer-features){
  display:none;
}


/* =========================================================
   VISIT US IN STORE — image edge-to-edge on left
   ========================================================= */

.visit-store{
  grid-template-columns:1fr 1fr !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  padding:0 !important;
}
.visit-store-image{
  width:100% !important;
  height:100% !important;
  min-height:600px !important;
}


/* =========================================================
   RESPONSIVE — v1.6
   ========================================================= */
@media(max-width:1024px){
  nav.nav .aurora-nav > li.nav-has-mega > .mega-menu{
    min-width:600px !important;
  }
  .tagline-bar .footer-features{
    grid-template-columns:repeat(3, 1fr) !important;
    gap:32px 16px !important;
  }
}
@media(max-width:768px){
  .tagline-bar{padding:60px 0 40px}
  .tagline-bar-heading{margin-bottom:40px}
  .tagline-bar .footer-features{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:32px 12px !important;
  }
  .visit-store-image{min-height:400px !important}
}


/* =========================================================
   v1.7 — SHOP THE EDIT LAYOUT FIX (overlap bug)
   ========================================================= */

/* Reset all previous shop-edit styles with hard overrides */
.shop-edit-section{
  background:#fff;
  padding:80px 0;
}
.shop-edit-head{
  text-align:center;
  margin-bottom:50px;
}
.shop-edit-head h2{
  font-family:var(--display);
  font-size:clamp(28px, 4vw, 40px);
  font-weight:400;
  letter-spacing:2px;
  text-transform:uppercase;
  margin:0;
}

/* Grid container — clean 60/40 split */
.shop-edit-grid{
  display:grid !important;
  grid-template-columns:60% 40% !important;
  gap:0 !important;
  max-width:var(--container);
  margin:0 auto !important;
  padding:0 24px !important;
  align-items:center !important;
}

/* Lifestyle image — left side */
.shop-edit-image{
  position:relative !important;
  width:100% !important;
  aspect-ratio:1/1 !important;
  background-color:var(--beige) !important;
  background-size:cover !important;
  background-position:center !important;
  overflow:visible !important;
}

/* Hotspot pills — positioned over lifestyle image */
.shop-edit-hotspot{
  position:absolute !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  background:#fff !important;
  color:var(--dark) !important;
  padding:8px 18px !important;
  border-radius:30px !important;
  font-size:13px !important;
  font-family:var(--body) !important;
  font-weight:400 !important;
  text-decoration:none !important;
  border:none !important;
  cursor:pointer !important;
  box-shadow:0 4px 14px rgba(0,0,0,.12) !important;
  z-index:5 !important;
  transition:all .2s !important;
  transform:translate(-50%, -50%) !important;
  white-space:nowrap !important;
}
.shop-edit-hotspot::before{
  content:'' !important;
  width:8px !important;
  height:8px !important;
  border-radius:50% !important;
  background:var(--dark) !important;
}
.shop-edit-hotspot:hover{
  background:var(--dark) !important;
  color:#fff !important;
}
.shop-edit-hotspot:hover::before{
  background:#fff !important;
}
.shop-edit-hotspot.active{
  background:var(--dark) !important;
  color:#fff !important;
}
.shop-edit-hotspot.active::before{
  background:#fff !important;
}

/* Products column — right side */
.shop-edit-products{
  position:relative !important;
  width:100% !important;
  padding:0 60px !important;
  box-sizing:border-box !important;
  display:block !important;
}

/* Arrows positioned at sides of products column */
.shop-edit-prev,
.shop-edit-next{
  position:absolute !important;
  top:42% !important;
  width:42px !important;
  height:42px !important;
  border-radius:50% !important;
  background:#fff !important;
  border:1px solid var(--line) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer !important;
  z-index:6 !important;
  transition:all .2s !important;
}
.shop-edit-prev{left:40px !important}
.shop-edit-next{right:40px !important}
.shop-edit-prev:hover, .shop-edit-next:hover{
  background:var(--dark) !important;
  border-color:var(--dark) !important;
}
.shop-edit-prev:hover svg, .shop-edit-next:hover svg{stroke:#fff !important}
.shop-edit-prev svg, .shop-edit-next svg{
  width:14px !important;
  height:14px !important;
  stroke:var(--dark) !important;
  fill:none !important;
  stroke-width:1.5 !important;
}

/* Viewport — clips the track */
.shop-edit-viewport{
  width:100% !important;
  overflow:hidden !important;
  position:relative !important;
}

/* Track — flex row of cards */
.shop-edit-track{
  display:flex !important;
  width:100% !important;
  transition:transform .5s cubic-bezier(.4,0,.2,1) !important;
  overflow:visible !important;
}

/* Each card = 100% of viewport (one visible at a time) */
.shop-edit-card{
  flex:0 0 100% !important;
  width:100% !important;
  min-width:100% !important;
  padding:0 !important;
  box-sizing:border-box !important;
  text-align:center !important;
}
.shop-edit-card a{
  display:block;
  text-decoration:none;
  color:inherit;
}
.shop-edit-card-img{
  width:100% !important;
  aspect-ratio:1/1 !important;
  background:linear-gradient(135deg,var(--ivory),var(--beige)) !important;
  margin-bottom:16px !important;
  overflow:hidden !important;
  position:relative !important;
}
.shop-edit-card-img img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  position:absolute !important;
  inset:0 !important;
}
.shop-edit-card-name{
  font-family:var(--display) !important;
  font-size:16px !important;
  font-weight:400 !important;
  margin:0 0 6px !important;
  color:var(--dark) !important;
}
.shop-edit-card-price{
  font-size:14px !important;
  color:var(--dark) !important;
}

/* Dots */
.shop-edit-dots{
  display:flex !important;
  justify-content:center !important;
  gap:8px !important;
  margin-top:20px !important;
}
.shop-edit-dot{
  width:8px !important;
  height:8px !important;
  border-radius:50% !important;
  background:var(--line) !important;
  border:none !important;
  cursor:pointer !important;
  transition:background .2s !important;
  padding:0 !important;
}
.shop-edit-dot.active{
  background:var(--dark) !important;
}

/* Mobile */
@media(max-width:768px){
  .shop-edit-grid{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  .shop-edit-products{padding:0 40px !important}
  .shop-edit-image{aspect-ratio:4/5 !important}
}


/* =========================================================
   v1.8 — GRID FIRST-COLUMN-EMPTY FIX + RELATED 4-COL + POLISH
   ========================================================= */

/* Force product grids to fill properly — no empty cells from the start */
.woocommerce ul.products,
.woocommerce-page ul.products,
ul.products{
  display:grid !important;
  grid-template-columns:repeat(3, 1fr) !important;
  grid-auto-flow:row dense !important;
  gap:32px !important;
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}

/* Hide any empty product li (legacy hooks may inject these) */
.woocommerce ul.products li.product:empty,
.woocommerce ul.products li.product:not(:has(.aurora-card-link)){
  display:none !important;
}

/* RELATED PRODUCTS — force 4 columns in one row */
.related.products ul.products,
.related-products ul.products,
section.related ul.products,
.woocommerce .related ul.products{
  grid-template-columns:repeat(4, 1fr) !important;
  gap:24px !important;
}

@media(max-width:1024px){
  .related.products ul.products,
  .woocommerce .related ul.products{
    grid-template-columns:repeat(2, 1fr) !important;
  }
}
@media(max-width:600px){
  .woocommerce ul.products, ul.products{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:14px !important;
  }
  .related.products ul.products,
  .woocommerce .related ul.products{
    grid-template-columns:repeat(2, 1fr) !important;
  }
}



/* =========================================================
   PAGE TEMPLATES — Our Story / Locations / Shipping / Contact
   ========================================================= */

.page-wrap.aurora-story-page,
.page-wrap.aurora-locations-page,
.page-wrap.aurora-policy-page,
.page-wrap.aurora-contact-page{
  max-width:1100px;
  padding:80px 24px;
}

.story-hero, .locations-hero, .policy-hero, .contact-hero{
  text-align:center;
  margin-bottom:64px;
}
.story-hero h1, .locations-hero h1, .policy-hero h1, .contact-hero h1{
  font-family:var(--display);
  font-size:clamp(40px, 6vw, 64px);
  font-weight:400;
  margin:8px 0 16px;
}
.story-lead{
  font-size:17px;
  color:var(--charcoal);
  max-width:600px;
  margin:0 auto;
  line-height:1.7;
}

.story-section, .policy-section{
  max-width:780px;
  margin:0 auto 56px;
}
.story-section h2, .policy-section h2{
  font-family:var(--display);
  font-size:clamp(24px, 3vw, 32px);
  font-weight:400;
  margin:0 0 20px;
}
.story-section p, .policy-section p{
  font-size:16px;
  line-height:1.8;
  color:var(--charcoal);
  margin:0 0 18px;
}

.story-values{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:36px;
  margin-top:32px;
}
.value-item h3{
  font-family:var(--display);
  font-size:22px;
  font-weight:400;
  margin:0 0 12px;
  color:var(--dark);
}
.value-item p{
  font-size:15px;
  line-height:1.7;
  color:var(--charcoal);
  margin:0;
}

.story-promise{
  text-align:center;
  background:var(--footer-bg);
  padding:48px 32px;
  margin-top:48px;
}
.story-promise .btn{margin-top:16px}

.locations-grid{
  display:grid;
  gap:48px;
  margin-bottom:80px;
}
.location-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}
.location-image{
  width:100%;
  aspect-ratio:4/3;
  background:linear-gradient(135deg, var(--ivory), var(--beige));
}
.location-info h3{
  font-family:var(--display);
  font-size:32px;
  font-weight:400;
  margin:0 0 16px;
}
.location-info p{
  font-size:15px;
  color:var(--charcoal);
  line-height:1.8;
  margin:0 0 14px;
}
.location-info .btn{margin-top:8px}

.locations-cta{
  text-align:center;
  background:#efede7;
  padding:60px 32px;
}
.locations-cta h2{
  font-family:var(--display);
  font-size:32px;
  font-weight:400;
  margin:0 0 12px;
}
.locations-cta-buttons{
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:24px;
}

.policy-help{
  text-align:center;
  border-top:1px solid var(--line);
  padding-top:48px;
}
.policy-help a{
  color:var(--dark);
  text-decoration:underline;
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
}
.contact-channels{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.contact-channel{
  background:var(--footer-bg);
  padding:28px 24px;
  text-align:center;
}
.channel-icon{font-size:32px;margin-bottom:12px}
.contact-channel h3{
  font-family:var(--display);
  font-size:22px;
  font-weight:400;
  margin:0 0 8px;
}
.contact-channel p{
  font-size:13px;
  color:var(--charcoal);
  margin:0 0 16px;
  line-height:1.5;
}
.contact-channel .btn{
  padding:10px 18px !important;
  font-size:11px !important;
}

.contact-form-wrap h2{
  font-family:var(--display);
  font-size:28px;
  font-weight:400;
  margin:0 0 8px;
}
.aurora-contact-form{margin-top:24px}
.aurora-contact-form .form-row{margin-bottom:18px}
.aurora-contact-form label{
  display:block;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:500;
  color:var(--gold);
  margin-bottom:6px;
}


@media(max-width:768px){
  .story-values, .location-card, .contact-grid, .contact-channels{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
}
/* About mega menu — smaller, 1 column, offset */
nav.nav .aurora-nav > li.nav-has-mega:nth-of-type(3) > .mega-menu {
    min-width: 150px !important;
    max-width: 250px !important;
    transform: translateX(-7%) translateY(0) !important;
}
nav.nav .aurora-nav > li.nav-has-mega:nth-of-type(2) > .mega-menu .mega-inner {
    grid-template-columns: repeat(1, 1fr) !important;
}
/* =========================================================
   v1.9 — HEADER ICONS MATCH + SEARCH MODAL UPGRADE
   ========================================================= */

/* All header icons same size */
header.header .icon-btn,
header.header .icon-btn-search,
header.header button.icon-btn,
header.header a.icon-btn{
  width:42px !important;
  height:42px !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}
header.header .icon-btn svg,
header.header .icon-btn-search svg{
  width:22px !important;
  height:22px !important;
  stroke-width:1.5 !important;
  stroke:var(--dark) !important;
  fill:none !important;
}
header.header .cart-badge{
  position:absolute !important;
  top:2px !important;
  right:2px !important;
  background:var(--gold) !important;
  color:#fff !important;
  font-size:10px !important;
  width:18px !important;
  height:18px !important;
  border-radius:50% !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}

/* SEARCH MODAL — new layout */
.search-suggestions strong{
  font-weight:500 !important;
  color:#111 !important;
}
.search-suggestions a{
  color:#777 !important;
  text-decoration:none !important;
}
.search-suggestions a:hover{ color:#111 !important; }

/* Results container */
#auroraSearchResults{
  width:100% !important;
  margin-top:50px !important;
}
.search-results-grid{
  display:grid !important;
  grid-template-columns:repeat(3, 1fr) !important;
  gap:48px !important;
  width:100% !important;
}
.search-result-card{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  text-align:center !important;
  text-decoration:none !important;
  color:#111 !important;
  padding:20px 12px !important;
  background:#fff !important;
}
.search-result-card .search-result-img{
  width:100% !important;
  aspect-ratio:1 / 1 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin-bottom:24px !important;
  background:#fff !important;
}
.search-result-card .search-result-img img{
  max-width:80% !important;
  max-height:80% !important;
  object-fit:contain !important;
  mix-blend-mode:multiply;
}
.search-result-card .search-result-name{
  font-family:'Jost', sans-serif !important;
  font-size:14px !important;
  font-weight:400 !important;
  color:#111 !important;
  margin-bottom:6px !important;
  letter-spacing:.3px !important;
}
.search-result-card .search-result-price,
.search-result-card .search-result-price .woocommerce-Price-amount{
  font-family:'Jost', sans-serif !important;
  font-size:14px !important;
  color:#222 !important;
  font-weight:400 !important;
  text-decoration:none !important;
}

/* View All button */
.search-view-all-wrap{
  width:100%;
  text-align:center !important;
  margin-top:60px !important;
}
.search-view-all{
  display:inline-block !important;
  padding:18px 40px !important;
  background:transparent !important;
  border:1px solid #111 !important;
  color:#111 !important;
  font-family:'Jost', sans-serif !important;
  font-size:12px !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  text-decoration:none !important;
  font-weight:500 !important;
}
.search-view-all:hover{
  background:#111 !important;
  color:#fff !important;
}

.search-no-results{
  font-family:'Jost', sans-serif !important;
  text-align:center;
  padding:60px 20px;
  color:#777;
}


.search-modal-inner{
  width:100% !important;
  max-width:1100px !important;
  margin:0 auto !important;
  padding:0 !important;
}

.search-modal-form{
  flex:1 !important;
  background:#f5f0e8 !important;
  border:none !important;
  border-radius:4px !important;
  display:flex !important;
  align-items:center !important;
  padding:0 20px !important;
}
.search-modal-form input{
  flex:1 !important;
  padding:18px 8px !important;
  background:transparent !important;
  border:none !important;
  outline:none !important;
  font-family:'Jost', sans-serif !important;
  font-size:16px !important;
  color:#111 !important;
}

.search-modal{
  position:fixed;
  inset:0;
  background:rgba(250,247,241,.98);
  z-index:9999;
  display:none;
}
.search-modal.active{
  display:flex !important;
  flex-direction:column;
}
.search-modal{
  background:rgba(250, 247, 241, .98) !important;
  padding-top:60px !important;
  align-items:flex-start !important;
  overflow-y:auto !important;
}

.search-modal-bar{
  display:flex !important;
  align-items:center !important;
  gap:24px !important;
}


.search-modal-form input::placeholder{
  color:var(--muted) !important;
  font-style:normal !important;
}
.search-modal-form .search-submit-icon{
  background:transparent !important;
  border:none !important;
  padding:14px 8px !important;
  cursor:pointer !important;
  color:var(--dark) !important;
}
.search-modal-form .search-submit-icon svg{
  width:22px !important;
  height:22px !important;
  stroke:var(--dark) !important;
  fill:none !important;
  stroke-width:1.5 !important;
}
.search-modal-close{
  position:static !important;
  width:42px !important;
  height:42px !important;
  border:1px solid var(--line) !important;
  border-radius:50% !important;
  background:transparent !important;
  color:var(--dark) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer !important;
  flex-shrink:0 !important;
}

.search-suggestions{
  display:flex !important;
  align-items:center !important;
  gap:18px !important;
  margin-top:28px !important;
  flex-wrap:wrap !important;
  font-size:14px !important;
  color:var(--charcoal) !important;
}
.search-suggestions strong{
  color:var(--dark) !important;
  font-weight:500 !important;
  font-size:13px !important;
  letter-spacing:.5px !important;
}
.search-suggestions a{
  color:var(--charcoal) !important;
  text-decoration:none !important;
  padding:4px 0 !important;
  border-bottom:1px solid transparent !important;
}
.search-suggestions a:hover{
  color:var(--dark) !important;
  border-bottom-color:var(--dark) !important;
}

.search-results-wrap{
  min-height:50vh;
  padding-top:8px;
}
.search-results{
  display:grid !important;
  grid-template-columns:repeat(3, 1fr) !important;
  gap:36px !important;
  margin-top:48px !important;
}
.search-result-item{
  text-align:center !important;
  text-decoration:none !important;
  color:inherit !important;
  display:block !important;
}
.search-result-img{
  width:100% !important;
  aspect-ratio:1/1 !important;
  margin-bottom:18px !important;
  background:var(--ivory) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:hidden !important;
}
.search-result-img img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}
.search-result-name{
  font-family:var(--display) !important;
  font-size:16px !important;
  font-weight:400 !important;
  margin-bottom:6px !important;
  color:var(--dark) !important;
}
.search-result-price{
  font-size:14px !important;
  color:var(--dark) !important;
}

.search-view-all{
  display:block !important;
  width:280px !important;
  margin:48px auto 60px !important;
  padding:16px !important;
  background:transparent !important;
  color:var(--dark) !important;
  border:1px solid var(--dark) !important;
  text-align:center !important;
  font-size:12px !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  text-decoration:none !important;
  font-weight:500 !important;
}
.search-view-all:hover{
  background:var(--dark) !important;
  color:#fff !important;
}
.search-no-results{
  text-align:center !important;
  padding:48px 24px !important;
  color:var(--muted) !important;
  font-size:15px !important;
}

@media(max-width:768px){
  .search-modal-inner{padding:0 20px !important}
  .search-modal-bar{gap:12px !important}
  .search-modal-form input{font-size:16px !important}
  .search-results{grid-template-columns:repeat(2, 1fr) !important;gap:16px !important}
  .search-suggestions{font-size:13px !important;gap:12px !important}
}


/* =========================================================
   ╔═══════════════════════════════════════════════════════╗
   ║                     v2.0 OVERRIDES                    ║
   ║   Sticky stack · Mobile header · Footer redesign      ║
   ║   Retailers strip · Testimonial · Picks centered      ║
   ╚═══════════════════════════════════════════════════════╝
   ========================================================= */

/* ---------- 1. STICKY HEADER STACK (announce + header + nav) ---------- */

/* Old standalone sticky on header is no longer needed — disable */
.header{position:relative !important; top:auto !important; z-index:auto !important}


/* ---------- 2. ANNOUNCEMENT BAR — language switcher on right ---------- */
.announce-bar{
  background:var(--topbar-bg) !important;
  color:var(--topbar-text) !important;
  min-height:38px !important;
}
.announce-bar-inner{
  display:grid !important;
  grid-template-columns:36px 1fr 36px auto !important;
  align-items:center !important;
  gap:12px !important;
  max-width:var(--container) !important;
  padding:8px 24px !important;
  margin:0 auto !important;
}
.announce-prev{grid-column:1}
.announce-slides{grid-column:2; max-width:none !important; height:28px !important}
.announce-next{grid-column:3}
.announce-lang{
  grid-column:4;
  display:flex; align-items:center; gap:10px;
  font-size:12px; color:var(--topbar-text);
  white-space:nowrap;
}
.announce-lang-item{
  display:inline-flex; align-items:center; gap:6px;
  cursor:pointer; opacity:.95;
}
.announce-lang-item:hover{opacity:1}
.announce-lang-sep{opacity:.5}
.flag-emoji{font-size:14px; line-height:1}

@media(max-width:900px){
  .announce-bar-inner{grid-template-columns:30px 1fr 30px !important; padding:8px 12px !important}
  .announce-lang{display:none}
}


/* ---------- 3. HEADER — desktop & mobile layout ---------- */
.header{
  background:var(--cream) !important;
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:grid !important;
  grid-template-columns:1fr auto 1fr !important;
  align-items:center;
  padding:18px 24px !important;
  max-width:var(--container);
  margin:0 auto;
  gap:16px !important;
}
.header-left{
  display:flex !important;
  align-items:center;
  gap:8px;
  justify-content:flex-start;
}
.header-right{
  display:flex !important;
  align-items:center;
  gap:8px;
  justify-content:flex-end;
}
.header-logo{
  text-align:center !important;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* Logo: diamond mark + brand text stacked (or use uploaded logo) */
.logo, .header .custom-logo-link{
  font-family:var(--display) !important;
  font-size:30px !important;
  font-weight:500;
  letter-spacing:6px;
  color:var(--dark) !important;
  text-decoration:none;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
  line-height:1;
}
/* Diamond mark above brand name (when no custom logo) */
.logo::before,
.header .custom-logo-link::before {
    content: '';
    width: 35px;
    height: 35px;
    background-image: url('https://biosweepuae.com/aishaswhy/wp-content/uploads/2026/05/cropped-iconyamber1.webp');
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    display: block;           /* Yeh zaroori hai */
    
}

/* Optional: Agar sirf mobile mein dikhana hai */
@media (max-width: 768px) {
    .logo::before,
    .header .custom-logo-link::before {
        width: 30px;
        height: 30px;
    }
}
.custom-logo{max-height:60px !important; width:auto !important}
/* Hide diamond when an uploaded logo image is present */
.header .custom-logo-link.custom-logo-link::before{display:none}

/* Hide tagline span if exists */
.logo .brand-tagline-line{
  font-size:8px; letter-spacing:3px; opacity:.7; font-family:var(--body); margin-top:2px;
}

/* Hamburger — visible on mobile only */
.hamburger{
  display:none;
  width:50px; height:50px;
  align-items:center;
  background:transparent; border:none; cursor:pointer; color:var(--dark);
  padding:0px !important;
}
.hamburger svg{width:22px; height:22px; stroke:var(--dark); fill:none; stroke-width:1.5}

/* All header icons same size */
.header .icon-btn{
  width:42px !important; height:42px !important;
  display:inline-flex !important;
  align-items:center !important; justify-content:center !important;
  border-radius:50%;
  position:relative;
  color:var(--dark);
  text-decoration:none;
  background:transparent !important;
  border:none;
  cursor:pointer;
}
.header .icon-btn:hover{background:var(--ivory) !important}
.header .icon-btn svg{
  width:22px !important; height:22px !important;
  stroke:var(--dark) !important;
  fill:none !important;
  stroke-width:1.5 !important;
}
.header .cart-badge{
  position:absolute !important;
  top:2px !important; right:2px !important;
  background:var(--gold) !important;
  color:#fff !important;
  font-size:10px !important;
  width:18px !important; height:18px !important;
  border-radius:50% !important;
  display:flex !important;
  align-items:center !important; justify-content:center !important;
  line-height:1 !important;
}


/* ---------- 4. NAV BAR ---------- */
.nav{
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
  display:flex; justify-content:center;
}
.aurora-nav{
  display:flex; gap:48px;
  margin:0; padding:0; list-style:none;
}
.aurora-nav > li > a{
  font-size:13px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  padding:14px 0;
  display:inline-block;
  color:var(--dark);
  font-weight:400;
  text-decoration:none;
}
.aurora-nav > li > a:hover{color:var(--gold)}


/* ---------- 5. PRESS LOGOS — distinct typography ---------- */
.press{
  background:var(--footer-bg) !important;
  padding:40px 0 50px !important;
  text-align:center;
}
.press-title{
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:20px;
}

.press-logo-vogue{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-style:italic !important;
  font-size:30px !important;
  font-weight:500 !important;
  letter-spacing:0 !important;
  color:var(--dark) !important;
}
.press-logo-tatler{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:24px !important;
  font-weight:600 !important;
  letter-spacing:6px !important;
  color:var(--dark) !important;
}
.press-logo-grazia{
  font-family:'Jost', sans-serif !important;
  font-size:22px !important;
  font-weight:700 !important;
  letter-spacing:4px !important;
  color:var(--dark) !important;
}


/* ---------- 6. PICKS HEADER (centered with arrows on sides) ---------- */
.section-picks{padding:80px 24px 60px !important}
.picks-head-center{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:24px !important;
  margin-bottom:40px !important;
}
.picks-head-center .picks-title{
  font-family:var(--display) !important;
  font-size:clamp(24px, 3vw, 32px) !important;
  font-weight:400 !important;
  letter-spacing:4px !important;
  text-transform:uppercase !important;
  margin:0 !important;
  color:var(--dark) !important;
}
.car-arrow-side{
  width:34px; height:34px; border-radius:50%;
  background:transparent; border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s;
}
.car-arrow-side:hover{background:var(--ivory)}
.car-arrow-side svg{width:14px; height:14px; stroke:var(--dark); fill:none; stroke-width:1.5}

/* Product card rating stars */
.product-rating{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
  margin-top:6px;
  font-size:12px;
}
.product-rating .stars{
  color:var(--gold);
  letter-spacing:1px;
}
.product-rating .rating-count{color:var(--muted); font-size:11px}


/* ---------- 7. SECTION TITLE (single line, no eyebrow) ---------- */
.section-categories{padding:60px 24px 80px !important}
.section-categories .section-title{
  font-family:var(--display) !important;
  font-size:clamp(24px, 3vw, 32px) !important;
  font-weight:400 !important;
  letter-spacing:4px !important;
  text-transform:uppercase !important;
  text-align:center !important;
  margin:0 0 36px !important;
  color:var(--dark) !important;
}


/* ---------- 8. CATEGORY GRID — taller cards, model-photo style ---------- */
.category-grid{
  display:grid !important;
  grid-template-columns:repeat(3, 1fr) !important;
  gap:14px !important;
}
.category-card{
  position:relative;
  display:flex; flex-direction:column;
  justify-content:flex-end;
  min-height:480px !important;
  padding:30px !important;
  text-decoration:none;
  background:var(--ivory);
  background-size:cover !important;
  background-position:center !important;
  overflow:hidden;
}
.category-card::before{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.45) 0%, rgba(0,0,0,.05) 50%, transparent 100%);
  pointer-events:none;
}
.cat-content{
  position:relative;
  z-index:1;
  color:#fff;
}
.cat-name{
  font-family:var(--display);
  font-size:32px !important;
  font-weight:400 !important;
  letter-spacing:3px;
  margin-bottom:4px;
}
.cat-cta{
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  opacity:.95;
  border-bottom:1px solid rgba(255,255,255,.7);
  display:inline-block;
  padding-bottom:2px;
}


/* ---------- 9. RETAILERS STRIP ---------- */
.retailers{
  background:#fff;
  padding:40px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.retailers-track{
  gap:32px 48px;
}


/* ---------- 10. TESTIMONIAL BLOCK ---------- */
.testimonial-block{
  background:var(--footer-bg);
  padding:80px 24px;
  text-align:center;
  position:relative;
}
.testimonial-block .container{max-width:780px !important; margin:0 auto}
.testi-stars{
  font-size:20px;
  color:var(--dark);
  letter-spacing:4px;
  margin-bottom:24px;
}
.testi-quote{
  font-family:var(--display);
  font-size:clamp(18px, 2.4vw, 22px);
  font-weight:400;
  color:var(--dark);
  line-height:1.55;
  margin:0 0 20px;
  font-style:italic;
}
.testi-author{
  font-size:13px;
  color:var(--charcoal);
  letter-spacing:1px;
}
.testi-nav{
  display:flex;
  justify-content:center;
  gap:24px;
  margin-top:32px;
}
.testi-arrow{
  width:34px; height:34px; border-radius:50%;
  background:transparent; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s;
}
.testi-arrow:hover{background:#fff}
.testi-arrow svg{width:14px; height:14px; stroke:var(--dark); fill:none; stroke-width:1.5}


/* ---------- 11. VISIT US IN STORE — text wrap centered ---------- */
.visit-store-text-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 24px;
  background:#eeede8;
}

.visit-store-text h2{
  font-family:var(--display);
  font-size:clamp(28px, 3vw, 36px);
  font-weight:400;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:18px;
}
.visit-store-text p{
  color:var(--charcoal);
  font-size:14px;
  line-height:1.7;
  margin-bottom:14px;
}
.visit-store-text .btn{
  margin-top:18px;
  display:inline-block;
}


/* ---------- 12. GET INSPIRED / INSTAGRAM STRIP (horizontal 6) ---------- */
.insta-strip-section{
  padding:80px 0 60px;
  background:#fff;
  text-align:center;
}
.eyebrow-center{
  text-align:center;
  margin-bottom:6px;
  color:var(--dark) !important;
  font-weight:500;
  font-size:13px !important;
  letter-spacing:3px !important;
}
.insta-strip-sub{
  font-size:12px;
  color:var(--muted);
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:36px;
}

.insta-strip-item:hover{opacity:.85}
.insta-strip-item .insta-icon svg{
  width:28px; height:28px;
  stroke:rgba(255,255,255,.8);
  fill:none; stroke-width:1.5;
}


/* ---------- 13. FOOTER REDESIGN — aishas.com 4-column layout ---------- */
.footer{
  background:var(--footer-bg) !important;
  padding:80px 0 30px !important;
  border-top:none !important;
}
.footer .container{max-width:var(--container) !important; padding:0 40px !important}
.footer-top{
  display:grid !important;
  grid-template-columns:2fr 1fr 1fr 1fr !important;
  gap:60px !important;
  margin-bottom:60px !important;
}
.footer-col h4{
  font-family:var(--display) !important;
  font-size:15px !important;
  font-weight:500 !important;
  letter-spacing:3px !important;
  text-transform:uppercase !important;
  color:var(--dark) !important;
  margin:0 0 22px !important;
}
.footer-col a, .footer-col li{
  font-size:14px;
  padding:6px 0;
  color:var(--charcoal);
  font-weight:300;
  text-decoration:none;
  list-style:none;
}
.footer-col a{display:block}
.footer-col a:hover{color:var(--dark)}
.footer-list{list-style:none; padding:0; margin:0}
.footer-brand p{
  color:var(--charcoal);
  font-size:14px;
  line-height:1.8;
  max-width:380px;
  margin:0;
  font-weight:300;
}

/* Big brandmark below 4 columns */
.footer-brandmark{
  padding:30px 0 40px;
}
.footer-brandmark .custom-logo{
  max-height:80px !important;
  width:auto !important;
}
.footer-brandmark-text{
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  line-height:1;
}
.footer-brandmark-text .brand-diamond{
  font-size:32px;
  color:var(--dark);
  line-height:1;
}
.footer-brandmark-text .brand-name{
  font-family:var(--display);
  font-size:36px;
  font-weight:500;
  letter-spacing:8px;
  color:var(--dark);
}
.footer-brandmark-text .brand-tagline{
  font-size:9px;
  letter-spacing:5px;
  color:var(--charcoal);
  margin-top:4px;
}

/* Bottom row */
.footer-bottom{
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  padding-top:30px !important;
  border-top:none !important;
  font-size:12px;
  color:var(--muted);
  flex-wrap:wrap;
  gap:20px;
}
.footer-lang-row{
  display:flex; gap:12px;
  flex-wrap:wrap;
}
.footer-lang-select{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border:1px solid var(--line);
  border-radius:4px;
  background:#fff;
  font-size:13px;
  color:var(--charcoal);
  cursor:pointer;
  min-width:200px;
}
.footer-lang-select:hover{border-color:var(--charcoal)}
.footer-lang-select svg{margin-left:auto}
.footer-copyright{
  font-size:12px;
  color:var(--muted);
}


/* ---------- 14. SEARCH MODAL — clean .active class (kills .open conflict) ---------- */



/* ---------- 15. MOBILE RESPONSIVE — header, nav, footer, sections ---------- */

@media(max-width:900px){

  /* Hide nav bar on mobile (use hamburger menu) */
  .nav{display:none}

  /* Show hamburger */
  .hamburger{display:flex !important}

  /* Compact header padding */
  .header-inner{
    padding:12px 12px !important;
    grid-template-columns:auto 1fr auto !important;
    gap:4px !important;
  }
  .header-left{gap:0 !important}
  .header-right{gap:0 !important}
  .logo, .header .custom-logo-link{
    font-size:22px !important;
    letter-spacing:5px !important;
  }
  .logo::before, .header .custom-logo-link::before{
    width:22px; height:18px;
  }
  .custom-logo{max-height:44px !important}

  /* Hero shorter on mobile */
  .hero-slide{height:60vh !important; min-height:380px !important}

  /* Picks header tightening */
  .section-picks{padding:50px 16px 40px !important}
  .picks-head-center{gap:10px !important; margin-bottom:24px !important}
  .picks-head-center .picks-title{font-size:18px !important; letter-spacing:2px !important}

  /* Categories: 2 columns on mobile */
  .category-grid{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:8px !important;
  }
  .category-card{min-height:280px !important; padding:16px !important}
  .cat-name{font-size:20px !important; letter-spacing:1.5px !important}
  .cat-cta{font-size:10px !important; letter-spacing:1.5px !important}

  /* Retailers: smaller text, scrollable */
  .retailers{padding:24px 0}
  .retailers-track{
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    justify-content:flex-start !important;
    gap:28px !important;
    padding:0 16px !important;
  }
  .retailers-track::-webkit-scrollbar{display:none}
  .retailer-logo{font-size:11px !important; letter-spacing:1.5px !important}

  /* Shop the Edit: stack vertically */
  .shop-edit-section{padding:50px 0 !important}
  .shop-edit-grid{
    grid-template-columns:1fr !important;
    gap:30px !important;
    padding:0 16px !important;
  }
  .shop-edit-products{padding:0 36px !important}

  /* Testimonial */
  .testimonial-block{padding:60px 16px !important}
  .testi-quote{font-size:15px !important}

  /* Visit store stacked */
  .visit-store{grid-template-columns:1fr !important}
  .visit-store-image{min-height:300px !important}
  .visit-store-text-wrap{padding:50px 24px !important}

  /* Instagram strip: 3 columns mobile */

  .insta-strip-section{padding:50px 0 40px !important}

  /* Tagline / USP grid 2 columns */
  .tagline-bar{padding:50px 0 30px !important}
  .tagline-bar-heading{font-size:18px !important; letter-spacing:1px !important; margin-bottom:30px !important; padding:0 16px !important}
  .tagline-bar .footer-features{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:24px 8px !important;
    padding:0 16px !important;
  }
  .tagline-bar .feat-title{font-size:11px !important; letter-spacing:1px !important}
  .tagline-bar .feat-text{font-size:10px !important; max-width:140px !important}

  /* Footer mobile: stacked, accordion-feel */
  .footer{padding:50px 0 24px !important}
  .footer .container{padding:0 20px !important}
  .footer-top{
    grid-template-columns:1fr !important;
    gap:30px !important;
    margin-bottom:36px !important;
  }
  .footer-col h4{
    display:flex; justify-content:space-between; align-items:center;
    padding-bottom:14px; border-bottom:1px solid var(--line);
    margin-bottom:14px !important;
    font-size:13px !important; letter-spacing:2px !important;
  }
  .footer-col h4::after{
    content:'+';
    font-size:22px; font-weight:300; color:var(--charcoal);
  }
  .footer-brand p{font-size:13px; line-height:1.7}
  .footer-brandmark{padding:20px 0 30px}
  .footer-brandmark-text .brand-name{font-size:28px; letter-spacing:5px}
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start !important;
    gap:14px;
  }
  .footer-lang-row{flex-direction:column; width:100%}
  .footer-lang-select{width:100%; min-width:0}
}

@media(max-width:480px){
  .product-card{flex:0 0 calc(75% - 12px)}
  .category-grid{grid-template-columns:1fr 1fr !important}
}


/* ---------- 16. BODY LOCK WHEN MODAL/DRAWER OPEN ---------- */
body.aurora-locked{overflow:hidden !important}


/* ---------- 17. AURORA OVERLAY (used by cart/menu/filters) ---------- */


/*.aurora-overlay.open{opacity:1; visibility:visible}*/


/* ---------- 18. MOBILE MENU FOOTER (lang rows) ---------- */
.mobile-lang-row{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 0;
  border-bottom:1px solid var(--line);
  font-size:13px;
  color:var(--charcoal);
}
.mobile-lang-row:last-child{border-bottom:none}


/* ---------- 19. KILL OLD CONFLICTING STYLES ---------- */
/* Hide the old footer-features that aren't inside tagline-bar (since v1.x had this rule but we want it stronger) */
body > .footer-features,
.footer > .footer-features,
.footer .container > .footer-features{display:none !important}

/* Old .nav-has-mega arrow position fix on mobile (no mega menu on mobile so no need) */
@media(max-width:900px){
  .aurora-nav > li.nav-has-mega > a::after{display:none !important}
}


/* ---------- 20. WHATSAPP — keep above overlays but below modals ---------- */
.whatsapp-float{z-index:95 !important}



/* =========================================================
   ╔═══════════════════════════════════════════════════════╗
   ║                 v2.1 — AISHAS-MATCH TUNING            ║
   ║   · White body & header bg                            ║
   ║   · Full-width Visit Us / Get Inspired / Insta        ║
   ║   · Refined Picks carousel                            ║
   ║   · Mobile announce-bar polish                        ║
   ║   · WHYAMBER brand throughout                         ║
   ╚═══════════════════════════════════════════════════════╝
   ========================================================= */

/* ---------- 1. WHITE BACKGROUND THROUGHOUT ---------- */
body{ background:#FFFFFF !important; }
.aurora-stickytop{ background:#FFFFFF !important; }
.header{ background:#FFFFFF !important; }
.nav{ background:#FFFFFF !important; }
.mega-menu{ background:#FFFFFF !important; }
.section{ background:#FFFFFF; }
.hero, .section-picks, .section-categories,
.gift-giving, .testimonial-block{ background:#FFFFFF !important; }


/* ---------- 2. PICKS CAROUSEL — match reference image ---------- */
.section-picks{
  padding:80px 0 100px !important;
  background:#fff !important;
}
.section-picks .picks-head-center{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:32px !important;
  margin-bottom:50px !important;
}
.section-picks .picks-title{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:clamp(22px, 2.4vw, 30px) !important;
  font-weight:500 !important;
  letter-spacing:3px !important;
  text-transform:uppercase !important;
  color:#111 !important;
  margin:0 !important;
  text-align:center !important;
}
.section-picks .car-arrow-side{
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  background:transparent; border:none;
  cursor:pointer; color:#111;
  transition:opacity .2s;
}
.section-picks .car-arrow-side:hover{ opacity:.55; }
.section-picks .car-arrow-side svg{
  width:18px; height:18px;
  stroke:currentColor; fill:none; stroke-width:1.5;
}

/* Carousel track — show ~4 cards desktop */
.section-picks .carousel{
  overflow:hidden;
  position:relative;
  padding:0 24px;
}
.section-picks .carousel-track{
  display:flex !important;
  gap:24px !important;
  overflow-x:auto !important;
  scroll-behavior:smooth;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:8px;
  scrollbar-width:none;
}
.section-picks .carousel-track::-webkit-scrollbar{ display:none; }

.section-picks .product-card{
  flex:0 0 calc((100% - 72px) / 4) !important;
  min-width:0 !important;
  scroll-snap-align:start;
  background:#fff !important;
  text-align:center !important;
}
.section-picks .product-card .product-link{
  display:block;
  text-decoration:none;
  color:inherit;
}
.section-picks .product-image{
  width:100% !important;
  aspect-ratio:1 / 1 !important;
  background:#fff !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  overflow:hidden !important;
  padding:30px !important;
  box-sizing:border-box !important;
  border:none !important;
  margin-bottom:18px !important;
}

.section-picks .product-name{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:14px !important;
  font-weight:400 !important;
  color:#111 !important;
  letter-spacing:.3px !important;
  margin:0 0 6px !important;
  line-height:1.4 !important;
}
.section-picks .product-price,
.section-picks .product-price .woocommerce-Price-amount,
.section-picks .product-price ins,
.section-picks .product-price del{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:14px !important;
  color:#222 !important;
  font-weight:400 !important;
  letter-spacing:.3px !important;
  text-decoration:none !important;
}
.section-picks .product-price{ margin-bottom:8px !important; }
.section-picks .product-rating{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:13px !important;
  color:#333 !important;
}
.section-picks .product-rating .stars{
  color:#111 !important;
  letter-spacing:1px !important;
  font-size:12px !important;
}
.section-picks .product-rating .rating-count{
  color:#555 !important;
  font-size:13px !important;
}

@media(max-width:1100px){
  .section-picks .product-card{ flex-basis:calc((100% - 48px) / 3) !important; }
}
@media(max-width:760px){
  .section-picks{ padding:50px 0 60px !important; }
  .section-picks .picks-head-center{ gap:18px !important; margin-bottom:30px !important; }
  .section-picks .product-card{ flex-basis:calc((100% - 24px) / 2) !important; }
  .section-picks .product-image{ padding:20px !important; }
  .section-picks .product-name{ font-size:13px !important; }
  .section-picks .product-price{ font-size:13px !important; }
}


/* ---------- 3. FULL-WIDTH SECTIONS (Visit / Get Inspired / Instagram) ---------- */
.visit-store,
.insta-strip-section,
.testimonial-block,
.shop-edit-section,
.gift-giving{
  width:100% !important;
  max-width:100% !important;
  padding-left:0 !important;
  padding-right:0 !important;
  margin-left:0 !important;
  margin-right:0 !important;
}

/* Visit Us — 50/50 full bleed */
.visit-store{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  align-items:stretch !important;
  gap:0 !important;
  background:#fff !important;
}
.visit-store .visit-store-img,
.visit-store .visit-store-image{
  width:100% !important;
  height:100% !important;
  min-height:500px !important;
  background-size:cover !important;
  background-position:center !important;
}

.visit-store h2,
.visit-store .section-title{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:clamp(28px, 3.4vw, 44px) !important;
  font-weight:400 !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  margin:0 0 24px !important;
  color:#111 !important;
}
.visit-store p{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:15px !important;
  color:#444 !important;
  line-height:1.7 !important;
  margin:0 0 14px !important;
  max-width:480px !important;
}
.visit-store .btn,
.visit-store a.btn{
  margin-top:24px !important;
  padding:14px 32px !important;
  background:#111 !important; color:#fff !important;
  text-decoration:none !important;
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:12px !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  border:none !important;
  display:inline-block !important;
}

@media(max-width:900px){
  .visit-store{ grid-template-columns:1fr !important; }
  .visit-store .visit-store-img,
  .visit-store .visit-store-image{ min-height:320px !important; }
  .visit-store .visit-store-text-wrap,
  .visit-store .visit-store-content{ padding:50px 24px !important; }
}


/* Instagram strip — TRUE full-bleed, 6 across desktop, 3 mobile */
.insta-strip-section{
  padding:80px 0 !important;
  background:#fff !important;
  text-align:center !important;
}
.insta-strip-section .insta-eyebrow,
.insta-strip-section .insta-eyebrow-text{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:11px !important;
  letter-spacing:3px !important;
  text-transform:uppercase !important;
  color:#777 !important;
  margin:0 0 10px !important;
}
.insta-strip-section h2,
.insta-strip-section .insta-title{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:clamp(26px, 3vw, 38px) !important;
  font-weight:400 !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  margin:0 0 12px !important;
  color:#111 !important;
}
.insta-strip-section .insta-handle{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:14px !important;
  color:#555 !important;
  margin:0 0 40px !important;
}



/* Gift Giving — wider container, more breathing room */
.gift-giving{
  padding:80px 8vw !important;
  text-align:center !important;
  background:#fff !important;
}
.gift-giving h2{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:clamp(28px, 3.4vw, 44px) !important;
  font-weight:400 !important;
  letter-spacing:2px !important;
  margin:0 0 24px !important;
}
.gift-giving p{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:15px !important;
  color:#444 !important;
  line-height:1.8 !important;
  max-width:720px !important;
  margin:0 auto 14px !important;
}


/* Testimonial — full width centered */
.testimonial-block{
  padding:100px 24px !important;
  text-align:center !important;
  background:#fff !important;
}
.testimonial-block .testi-stars{
  font-size:18px !important;
  color:#111 !important;
  letter-spacing:6px !important;
  margin-bottom:24px !important;
}
.testimonial-block .testi-quote{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-style:italic !important;
  font-size:clamp(20px, 2.2vw, 28px) !important;
  color:#222 !important;
  max-width:780px !important;
  margin:0 auto 24px !important;
  line-height:1.5 !important;
  font-weight:400 !important;
}
.testimonial-block .testi-author{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:13px !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  color:#555 !important;
  margin-bottom:24px !important;
}
.testimonial-block .testi-arrows{
  display:flex !important;
  justify-content:center !important;
  gap:18px !important;
  margin-top:24px !important;
}
.testimonial-block .testi-arrow{
  width:42px; height:42px;
  border:1px solid #ddd;
  border-radius:50%;
  background:#fff;
  cursor:pointer;
  display:inline-flex;
  align-items:center; justify-content:center;
}


/* ---------- 4. MOBILE ANNOUNCE-BAR POLISH ---------- */
@media(max-width:760px){
  .announce-bar{
    min-height:34px !important;
    font-size:11px !important;
            display: none;
  }
  .announce-bar-inner{
    grid-template-columns:24px 1fr 24px !important;
    padding:6px 8px !important;
    gap:6px !important;
  }
  .announce-prev, .announce-next{
    width:24px; height:24px;
    padding:0 !important;
    background:transparent;
    border:none;
    color:var(--topbar-text);
  }
  .announce-prev svg, .announce-next svg{
    width:12px !important; height:12px !important;
    stroke:currentColor; fill:none; stroke-width:2;
  }
  .announce-slides{
    overflow:hidden;
    text-align:center;
    height: 54px !important;
  }
  .announce-slide{
    font-size:14px !important;
    letter-spacing:.4px !important;
    line-height:1.3 !important;
    padding:0 4px !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
   height: 54px !important;
  }
  .announce-lang{ display:none !important; }
}


/* ---------- 5. HEADER REFINEMENTS for white bg ---------- */
.header{
  border-bottom:1px solid #f0e8e0 !important;
}
.header .logo,
.header .custom-logo-link span,
.header-logo a{
  color:#111 !important;
}
.header .icon-btn,
.header .hamburger{
  color:#111 !important;
}
.header .icon-btn svg,
.header .hamburger svg{
  stroke:#111 !important;
}


/* ---------- 6. SEARCH MODAL — final reliability fix ---------- */


/* ---------- 7. PRESS LOGOS — tighter row, no bg ---------- */
.press{
  border-top:1px solid #f5ece2;
  border-bottom:1px solid #f5ece2;
}
.press-inner{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:80px !important;
  max-width:var(--container, 1280px) !important;
  margin:0 auto !important;
  flex-wrap:wrap !important;
}
.press-eyebrow{
  font-family:'Jost', sans-serif !important;
  font-size:11px !important;
  letter-spacing:3px !important;
  text-transform:uppercase !important;
  color:#888 !important;
  margin-right:20px !important;
}


/* ---------- 8. CATEGORY GRID — white bg, cleaner ---------- */
.section-categories{
  padding:60px 0 80px !important;
  background:#fff !important;
}
.section-categories .section-title{
  text-align:center !important;
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:clamp(24px, 2.8vw, 36px) !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  margin:0 0 40px !important;
  font-weight:400 !important;
}


/* ---------- 9. RETAILERS STRIP — white bg ---------- */
.retailers{
  background:#fff !important;
  border-top:1px solid #f5ece2;
  border-bottom:1px solid #f5ece2;
}
.retailers .retailers-inner{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  justify-content:center !important;
  gap:48px !important;
  max-width:var(--container, 1280px) !important;
  margin:0 auto !important;
}
.retailers .retailer-name{
  font-family:'Jost', system-ui, sans-serif !important;
  font-size:11px !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  color:#666 !important;
}


/* ---------- 10. SHOP THE EDIT — keep readable on white ---------- */
.shop-edit-section{
  padding:80px 0 !important;
  background:#fff !important;
}


/* ---------- 11. FOOTER tweaks — white-friendly ---------- */
.footer-features-bar{
  background:#fff !important;
  border-bottom:1px solid #f0e8e0 !important;
}
.tagline-bar{
  background:#fff !important;
  border-bottom:1px solid #f0e8e0 !important;
}


/* ---------- 12. HERO — ensure carousel works on white ---------- */
.hero{
  background:#fff !important;
}


/* ---------- 13. NAV (under header) — white bg ---------- */
.nav-inner, .nav-list{
  background:#fff !important;
}





/* ---------- END v2.1 ---------- */


/* =========================================================
   ╔═══════════════════════════════════════════════════════╗
   ║      v2.2 — FINAL CONSOLIDATION & POLISH              ║
   ║   · Container 1380px                                  ║
   ║   · Kill #c36 button hover from Hello Elementor       ║
   ║   · Gift Giving bg #fff7f7                            ║
   ║   · Search popup like aishas.com (3-card grid)        ║
   ║   · Shop By Category mobile slider                    ║
   ║   · Mobile menu polish (Image 2 reference)            ║
   ║   · Section-by-section width audit                    ║
   ╚═══════════════════════════════════════════════════════╝
   ========================================================= */

/* ---------- 1. CONTAINER & BASE ---------- */
:root{
  --container:1380px;
}
.container{
  max-width:1380px !important;
  margin:0 auto !important;
  padding-left:24px !important;
  padding-right:24px !important;
  box-sizing:border-box !important;
}


/* ---------- 2. KILL HELLO-ELEMENTOR'S MAGENTA HOVER (#c36) ---------- */
/* Hello Elementor parent theme applies background-color:#c36 + color:#fff
   on every button:hover/focus. This kills it across the whole site. */
button:hover, button:focus,
[type="button"]:hover, [type="button"]:focus,
[type="submit"]:hover, [type="submit"]:focus,
.btn:hover, .btn:focus,
a.btn:hover, a.btn:focus,
input[type="button"]:hover, input[type="button"]:focus,
input[type="submit"]:hover, input[type="submit"]:focus{
  background-color:inherit !important;
  color:inherit !important;
  text-decoration:none !important;
}

/* Re-apply the INTENDED hover styles for our specific button classes */
.btn{
  background:#111 !important;
  color:#fff !important;
  display:inline-block;
  padding:14px 32px;
  font-family:'Jost', system-ui, sans-serif;
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  border:1px solid #111;
  cursor:pointer;
  transition:opacity .2s, background .2s, color .2s;
  text-decoration:none !important;
}
.btn:hover, .btn:focus{
  background:#333 !important;
  color:#fff !important;
  opacity:.92;
}
.btn-light{
  background:#fff !important;
  color:#111 !important;
  border:1px solid #111 !important;
}
.btn-light:hover, .btn-light:focus{
  background:#111 !important;
  color:#fff !important;
}

/* Icon buttons in header */
.header .icon-btn:hover,
.header .hamburger:hover,
.header .icon-btn:focus,
.header .hamburger:focus{
  background:transparent !important;
  color:#111 !important;
  opacity:.65;
}

/* Carousel arrows */
.car-arrow:hover, .car-arrow:focus,
.car-arrow-side:hover, .car-arrow-side:focus,
.cat-arrow:hover, .cat-arrow:focus,
.testi-arrow:hover, .testi-arrow:focus,
.hero-arrow:hover, .hero-arrow:focus,
.announce-arrow:hover, .announce-arrow:focus,
.shop-edit-prev:hover, .shop-edit-next:hover{
  background:transparent !important;
  color:inherit !important;
  opacity:.6;
}

/* Close buttons */
.close-btn:hover, .close-btn:focus,
.search-modal-close:hover, .search-modal-close:focus,
.newsletter-pop-close:hover, .newsletter-pop-close:focus{
  background:transparent !important;
  color:#111 !important;
  opacity:.65;
}

/* Add to cart / WooCommerce buttons re-style */
.woocommerce a.button:hover, .woocommerce button.button:hover,
.woocommerce .button:hover, .woocommerce-page .button:hover,
.single_add_to_cart_button:hover,
.add_to_cart_button:hover{
  background:#333 !important;
  color:#fff !important;
}


/* ---------- 3. GIFT GIVING — #fff7f7 background ---------- */
.gift-giving{
  background:#fff7f7 !important;
  padding:90px 8vw !important;
}





/* ---------- 5. SHOP BY CATEGORY — mobile slider ---------- */
.section-categories{
  padding:60px 0 80px !important;
}
.section-categories .section-title{
  text-align:center !important;
  margin:0 0 50px !important;
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:clamp(24px, 2.8vw, 34px) !important;
  letter-spacing:2px !important;
  text-transform:uppercase !important;
  font-weight:400 !important;
}
.category-carousel{
  position:relative !important;
  display:flex !important;
  align-items:center !important;
  gap:0 !important;
}
.category-grid{
  display:grid !important;
  grid-template-columns:repeat(3, 1fr) !important;
  gap:18px !important;
  width:100% !important;
}
.category-card{
  position:relative;
  display:block;
  aspect-ratio:3/4;
  overflow:hidden;
  background:#f0e6d8;
  background-size:cover !important;
  background-position:center !important;
  text-decoration:none;
  min-height:420px;
}
.category-card .cat-content{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:30px 24px;
 
  color:#fff;
  background:linear-gradient(to top, rgba(0,0,0,.55), transparent);
}
.category-card .cat-name{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:30px;
  letter-spacing:4px;
  text-transform:uppercase;
  margin-bottom:6px;
}
.category-card .cat-cta{
  font-family:'Jost', sans-serif !important;
  font-size:11px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  text-decoration:underline;
  text-underline-offset:4px;
}
.cat-arrow{
  display:none;
  width:42px; height:42px;
  border-radius:50%;
  background:rgba(255,255,255,.85) !important;
  border:none;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  color:#111;
  flex-shrink:0;
}
.cat-arrow svg{
  width:16px; height:16px;
  stroke:currentColor; fill:none; stroke-width:1.8;
}
.cat-arrow-prev{ left:10px; }
.cat-arrow-next{ right:10px; }

@media(max-width:900px){
  .category-grid{
    grid-template-columns:none !important;
    display:flex !important;
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:14px !important;
    padding:0 16px !important;
  }
  .category-grid::-webkit-scrollbar{ display:none; }
  .category-card{
    flex:0 0 75% !important;
    scroll-snap-align:center;
    min-height:360px !important;
  }
  .cat-arrow{
    display:flex !important;
  }
}


/* ---------- 6. MOBILE MENU POLISH (Image 2 reference) ---------- */
.mobile-menu{
  position:fixed !important;
  top:0; left:0; bottom:0;
  width:88% !important;
  max-width:420px !important;
  background:#fff !important;
  z-index:9990 !important;
  transform:translateX(-100%);
  transition:transform .3s ease;
  display:flex !important;
  flex-direction:column !important;
  box-shadow:0 0 30px rgba(0,0,0,.1);
}
.mobile-menu.open{
  transform:translateX(0) !important;
}
.mobile-menu-head{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  padding:18px 24px !important;
  border-bottom:1px solid #f0e8e0 !important;
  min-height:60px !important;
}
.mobile-menu-head .logo,
.mobile-menu-head span{
  font-family:'Cormorant Garamond', Georgia, serif !important;
  font-size:20px !important;
  letter-spacing:2px !important;
  color:#111 !important;
}
.mobile-menu-head .close-btn{
  background:transparent !important;
  border:none !important;
  font-size:20px !important;
  color:#111 !important;
  cursor:pointer;
  padding:8px;
}
.mobile-nav-list{
  flex:1 !important;
  overflow-y:auto !important;
  padding:14px 0 !important;
}
.mobile-nav-list a{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  padding:16px 26px !important;
  font-family:'Jost', sans-serif !important;
  font-size:16px !important;
  font-weight:400 !important;
  color:#111 !important;
  text-decoration:none !important;
  border-bottom:none !important;
  letter-spacing:.4px;
}
.mobile-nav-list a:hover{
  background:#fafafa !important;
  color:#111 !important;
}
.mobile-nav-list a strong{ font-weight:500 !important; }
.mobile-nav-list a.has-arrow::after{
  content:'›';
  font-size:22px;
  color:#999;
  line-height:1;
}
.mobile-menu-footer{
  border-top:1px solid #f0e8e0 !important;
  padding:18px 26px !important;
}
.mobile-lang-row{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
  padding:10px 0 !important;
  font-family:'Jost', sans-serif !important;
  font-size:14px !important;
  color:#111 !important;
}
.mobile-lang-row .flag-emoji{ font-size:18px; }
.mobile-lang-row::after{
  content:'›';
  color:#999;
  font-size:20px;
  margin-left:auto;
}


/* ---------- 7. SECTION WIDTH AUDIT (matches aishas.com) ---------- */

/* Sections with container — capped at 1380px */
.section-picks,
.section-categories,
.section.container,
.press .press-inner,
.retailers .container,
.shop-edit-section .container{
  max-width:1380px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:24px !important;
  padding-right:24px !important;
  width:100% !important;
  box-sizing:border-box !important;
}

/* Full-bleed sections — edge-to-edge */
.hero,
.visit-store,
.insta-strip-section,
.testimonial-block,
.footer-features-bar,
.tagline-bar{
  width:100% !important;
  max-width:100% !important;
  padding-left:0 !important;
  padding-right:0 !important;
  margin-left:0 !important;
  margin-right:0 !important;
}

/* Sections needing horizontal padding but full-bleed bg */
.gift-giving{
  width:100% !important;
  max-width:100% !important;
  text-align:center !important;
}




/* ---------- 9. CART DRAWER & OVERLAY ---------- */
.cart-drawer{
  position:fixed !important;
  top:0; right:0; bottom:0;
  width:420px; max-width:90%;
  background:#fff !important;
  z-index:9991 !important;
  transform:translateX(100%);
  transition:transform .3s ease;
  display:flex; flex-direction:column;
}
.cart-drawer.open{
  transform:translateX(0) !important;
}
.aurora-overlay{
  position:fixed !important;
  inset:0 !important;
  background:rgba(0,0,0,.5) !important;
  z-index:9989 !important;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s;
}
/*.aurora-overlay.open{*/
/*  opacity:1 !important;*/
/*  pointer-events:auto !important;*/
/*}*/


/* ---------- 10. HOVER STATES THROUGHOUT — never magenta ---------- */
a:hover, a:focus{
  color:inherit;
  text-decoration:none;
}
.nav-link:hover{
  color:#666 !important;
  background:transparent !important;
}
.product-card a:hover{
  color:#111 !important;
  background:transparent !important;
}


/* ---------- END v2.2 ---------- */
.retailers {
  width: 100%;
  padding: 60px 0;
  background: #ffffff;
  overflow: hidden;
}

.retailers-wrapper {
  width: 100%;
  overflow: hidden;
  /* Edges pe smooth fade */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0,
    #000 100px,
    #000 calc(100% - 100px),
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0,
    #000 100px,
    #000 calc(100% - 100px),
    transparent 100%
  );
}

.retailers-track {
  display: flex;
  align-items: center;
  
  width: max-content;
  animation: scroll-left 50s linear infinite;
}

/* Hover pe pause */
.retailers-track:hover {
  animation-play-state: paused;
}

.retailer-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-decoration: none;
}

.retailer-logo img {

  width: auto;
  max-width: 180px;
  object-fit: contain;
  display: block;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.retailer-logo:hover img {
  opacity: 0.7;
  transform: scale(1.05);
}

/* Seamless loop animation */
@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* Tablet */
@media (max-width: 991px) {
  .retailers-track {
    gap: 30px;
    animation-duration: 40s;
  }
  
}

/* Mobile */
@media (max-width: 600px) {
  .retailers {
    padding: 25px 0;
  }
  .retailers-track {
    gap: 40px;
    animation-duration: 30s;
  }
  
}

/* Reduced motion accessibility */
@media (prefers-reduced-motion: reduce) {
  .retailers-track {
    animation: none;
  }
}

/* FIX PRODUCT GRID HIDE ISSUE */
.woocommerce ul.products{
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px;
}

/* remove fake table behavior */
.woocommerce ul.products::before,
.woocommerce ul.products::after{
    display: none !important;
    content: none !important;
}

/* ensure items behave properly */
.woocommerce ul.products li.product{
    width: auto !important;
    margin: 0 !important;
    float: none !important;
}

/* =========================================================
   v2.5 â€” CART PAGE + CART DRAWER + CHECKOUT + HOVER ICONS
   ========================================================= */

/* ---------- HIDE NEW BADGE (per request) ---------- */
.product-badge.product-badge-new { display: none !important; }

/* ---------- PRODUCT CARD HOVER ICON ACTIONS ---------- */
.aurora-card-media {
  position: relative;
  overflow: hidden;
}
.aurora-card-imglink {
  display: block;
  width: 100%; height: 100%;
  position: absolute; inset: 0;
  z-index: 1;
}
.aurora-card-wishlist { display: none !important; }
.aurora-card-quickadd { display: none !important; }

.aurora-card-actions {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%) translateX(20px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 4;
  opacity: 0;
  transition: all .35s cubic-bezier(.4,0,.2,1);
}
.aurora-card:hover .aurora-card-actions {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
.aurora-action {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  border: none;
  box-shadow: 0 4px 14px rgba(0,0,0,.10);
  transition: all .2s ease;
  text-decoration: none;
  color: var(--dark);
  position: relative;
}
.aurora-action:hover {
  background: var(--dark);
  color: #fff;
  transform: scale(1.05);
}
.aurora-action svg {
  width: 18px; height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  pointer-events: none;
}
.aurora-action.aurora-action-wish.active svg {
  fill: #A0392E;
  stroke: #A0392E;
}
.aurora-action-cart { padding: 0; overflow: hidden; }
.aurora-action-cart .aurora-action-cart-link,
.aurora-action-cart .button,
.aurora-action-cart .added_to_cart {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  font-size: 0 !important;
  color: transparent !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  text-indent: -9999px !important;
  z-index: 2;
}
.aurora-action-cart-icon {
  width: 18px; height: 18px;
  stroke: currentColor; fill: none; stroke-width: 1.6;
  pointer-events: none;
  position: relative; z-index: 1;
}
.aurora-card-link { display: block; text-decoration: none; color: inherit; }

@media (max-width: 768px) {
  .aurora-card-actions {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
    right: 8px;
  }
  .aurora-action { width: 36px; height: 36px; }
  .aurora-action svg, .aurora-action-cart-icon { width: 16px; height: 16px; }
}


/* =========================================================
   CART PAGE
   ========================================================= */

.aurora-cart-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 24px 80px;
  font-family: var(--body);
}
.aurora-cart-page .cart-title {
  font-family: var(--display);
  font-size: clamp(28px, 4vw, 38px);
  font-weight: 400;
  text-align: center;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin: 0 0 40px;
  color: var(--dark);
}

.aurora-cart-page .shop_table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 50px;
  background: transparent;
}
.aurora-cart-page .shop_table thead th {
  text-align: left;
  padding: 16px 12px;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--charcoal);
  border-bottom: 1px solid var(--line);
  background: transparent;
}
.aurora-cart-page .shop_table thead .th-price,
.aurora-cart-page .shop_table thead .th-qty,
.aurora-cart-page .shop_table thead .th-subtotal { text-align: center; }
.aurora-cart-page .shop_table thead .th-subtotal { text-align: right; }

.aurora-cart-page .shop_table td {
  padding: 28px 12px;
  vertical-align: middle;
  border-bottom: 1px solid var(--line);
  font-size: 15px;
  color: var(--dark);
  background: transparent;
}

.aurora-cart-page .product-info {
  display: flex;
  gap: 22px;
  align-items: center;
}
.aurora-cart-page .product-thumb,
.aurora-cart-page .product-thumb img {
  width: 90px; height: 90px;
  object-fit: cover;
  display: block;
  background: var(--ivory);
}
.aurora-cart-page .product-thumb { flex-shrink: 0; }
.aurora-cart-page .cart-product-name {
  margin: 0 0 6px;
  font-family: var(--display);
  font-size: 17px;
  font-weight: 400;
  line-height: 1.3;
}
.aurora-cart-page .cart-product-name a {
  color: var(--dark);
  text-decoration: none;
}
.aurora-cart-page .cart-product-name a:hover { color: var(--gold); }
.aurora-cart-page .stock-info {
  font-size: 12px;
  color: var(--muted);
  letter-spacing: .5px;
}

.aurora-cart-page .product-price,
.aurora-cart-page .product-subtotal {
  font-size: 16px;
  color: var(--dark);
  text-align: center;
}
.aurora-cart-page .product-subtotal { text-align: right; font-weight: 500; }

.aurora-cart-page .product-quantity { text-align: center; }
.aurora-cart-page .product-quantity .quantity { display: inline-block; }
.aurora-cart-page .product-quantity input.qty {
  width: 78px;
  text-align: center;
  padding: 10px 8px;
  border: 1px solid var(--line);
  background: #fff;
  font-family: var(--body);
  font-size: 15px;
  color: var(--dark);
  border-radius: 0;
}
.aurora-cart-page .remove-item {
  display: block;
  margin-top: 10px;
  font-size: 12px;
  color: var(--muted);
  text-decoration: underline;
  letter-spacing: .5px;
}
.aurora-cart-page .remove-item:hover { color: #A0392E; }

.aurora-cart-page .packaging-summary {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 50px;
  margin-top: 30px;
}
.aurora-cart-page .packaging .packaging-img {
  width: 100%;
  max-width: 600px;
  display: block;
  margin-bottom: 22px;
  background: var(--ivory);
}
.aurora-cart-page .packaging h3 {
  font-family: var(--display);
  font-size: 20px;
  font-weight: 400;
  margin: 0 0 8px;
  color: var(--dark);
}
.aurora-cart-page .packaging p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--charcoal);
  margin: 0 0 20px;
}
.aurora-cart-page .gift-card-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--dark);
  cursor: pointer;
  margin-top: 18px;
}
.aurora-cart-page .gift-card-toggle input { accent-color: var(--dark); }
.aurora-cart-page .gift-card-toggle em { color: var(--muted); font-style: normal; }
.aurora-cart-page .gift-card-note {
  font-size: 13px;
  color: var(--muted);
  margin: 6px 0 0 26px;
  line-height: 1.5;
}
.aurora-cart-page .gift-card-fields textarea {
  width: 100%;
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  font-family: var(--body);
  font-size: 14px;
  background: var(--cream);
  resize: vertical;
  outline: none;
  box-sizing: border-box;
}

.aurora-cart-page .summary-box {
  background: var(--ivory);
  padding: 32px 28px;
  border: 1px solid var(--line);
  align-self: start;
  position: sticky;
  top: 200px;
}
.aurora-cart-page .subtotal-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 18px;
  font-weight: 500;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
  color: var(--dark);
  letter-spacing: 1px;
}
.aurora-cart-page .subtotal-row span:last-child {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 500;
}
.aurora-cart-page .summary-note {
  font-size: 12px;
  color: var(--muted);
  margin: 14px 0 16px;
  letter-spacing: .3px;
}
.aurora-cart-page .free-shipping-msg {
  text-align: center;
  font-weight: 500;
  font-size: 14px;
  color: var(--dark);
  margin: 8px 0 18px;
}
.aurora-cart-page .checkout-wrapper .checkout-button,
.aurora-cart-page .checkout-wrapper a.checkout-button {
  display: block !important;
  width: 100% !important;
  background: var(--dark) !important;
  color: #fff !important;
  padding: 18px !important;
  font-size: 13px !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  text-align: center !important;
  border: 1px solid var(--dark) !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  margin: 0 !important;
}
.aurora-cart-page .checkout-wrapper .checkout-button:hover {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
}
.aurora-cart-page .continue-shopping {
  display: block;
  text-align: center;
  margin-top: 16px;
  font-size: 13px;
  letter-spacing: .5px;
  color: var(--charcoal);
  text-decoration: underline;
}
.aurora-cart-page .continue-shopping:hover { color: var(--dark); }

.aurora-cart-page .cart-empty-state {
  text-align: center;
  padding: 60px 24px;
}
.aurora-cart-page .cart-empty-state p {
  font-family: var(--display);
  font-size: 22px;
  color: var(--charcoal);
  margin-bottom: 24px;
}

@media (max-width: 992px) {
  .aurora-cart-page .packaging-summary {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .aurora-cart-page .summary-box { position: static; }
}
@media (max-width: 768px) {
  .aurora-cart-page .shop_table thead { display: none; }
  .aurora-cart-page .shop_table tr.cart_item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px 16px;
    padding: 20px 0;
    border-bottom: 1px solid var(--line);
  }
  .aurora-cart-page .shop_table td {
    border: none !important;
    padding: 4px 0;
  }
  .aurora-cart-page .shop_table td.product-name { grid-column: 1 / -1; }
  .aurora-cart-page .shop_table td.product-price {
    grid-column: 1;
    text-align: left;
    font-size: 14px;
    color: var(--muted);
  }
  .aurora-cart-page .shop_table td.product-price::before {
    content: 'Price: '; font-weight: 500; color: var(--dark);
  }
  .aurora-cart-page .shop_table td.product-quantity {
    grid-column: 2;
    text-align: right;
  }
  .aurora-cart-page .shop_table td.product-subtotal {
    grid-column: 1 / -1;
    text-align: right;
    padding-top: 8px;
    border-top: 1px dashed var(--line) !important;
    font-weight: 500;
  }
  .aurora-cart-page .shop_table td.product-subtotal::before {
    content: 'Subtotal: '; color: var(--muted); font-weight: 400;
  }
  .aurora-cart-page .product-info { gap: 14px; }
  .aurora-cart-page .product-thumb,
  .aurora-cart-page .product-thumb img { width: 72px; height: 72px; }
  .aurora-cart-page .cart-product-name { font-size: 15px; }
  .aurora-cart-page .summary-box { padding: 24px 20px; }
}


/* =========================================================
   CART DRAWER â€” refined
   ========================================================= */

.cart-drawer-head h3 {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: 3px;
  text-transform: uppercase;
}
.cart-drawer-head .cart-drawer-count {
  font-weight: 300;
  color: var(--muted);
  margin-left: 4px;
}
.cart-drawer-shipping {
  background: var(--ivory);
  padding: 14px 28px;
  border-bottom: 1px solid var(--line);
  text-align: left;
}
.cart-drawer-shipping p {
  font-size: 14px;
  margin: 0;
  color: var(--dark);
  font-weight: 500;
}
.cart-drawer-shipping .sparkle { display: inline-block; margin-left: 4px; }

.cart-drawer-items { padding: 0; margin: 0; }

.cart-drawer-item {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
  align-items: flex-start;
}
.cart-item-image {
  width: 96px; height: 110px;
  background: var(--ivory);
  overflow: hidden;
  display: block;
}
.cart-item-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
}
.cart-item-info { display: flex; flex-direction: column; gap: 6px; min-width: 0; }

.cart-item-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.cart-item-name {
  font-family: var(--display);
  font-size: 16px;
  font-weight: 500;
  color: var(--dark);
  text-decoration: none;
  line-height: 1.3;
  flex: 1;
}
.cart-item-name:hover { color: var(--gold); }
.cart-item-price {
  font-size: 14px;
  color: var(--dark);
  white-space: nowrap;
  font-weight: 500;
}

.cart-item-meta {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}
.cart-item-meta dl, .cart-item-meta dd, .cart-item-meta dt { display: inline; margin: 0; }
.cart-item-meta dt { font-weight: 500; color: var(--charcoal); }
.cart-item-meta dt::after { content: ': '; }
.cart-item-meta dd { margin-right: 8px; }

.cart-item-stock {
  font-size: 12px;
  color: #A0392E;
  font-style: italic;
}

.cart-item-qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: #fff;
  width: fit-content;
  margin-top: 4px;
}
.cart-item-qty .qty-btn {
  width: 34px; height: 34px;
  background: transparent;
  border: none;
  font-size: 16px;
  color: var(--dark);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cart-item-qty .qty-btn:hover { background: var(--ivory); }
.cart-item-qty .qty-value {
  min-width: 34px;
  text-align: center;
  font-size: 14px;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  line-height: 34px;
}

.cart-item-remove {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: underline;
  margin-top: 4px;
  align-self: flex-start;
}
.cart-item-remove:hover { color: #A0392E; }

.cart-drawer-packaging {
  padding: 24px 0 8px;
  border-top: 1px solid var(--line);
  margin-top: 10px;
}
.cart-drawer-packaging h4 {
  font-family: var(--display);
  font-size: 18px;
  font-weight: 500;
  margin: 0 0 6px;
  color: var(--dark);
}
.cart-drawer-packaging p {
  font-size: 13px;
  color: var(--charcoal);
  margin: 0 0 16px;
  line-height: 1.5;
}
.cart-drawer-packaging img {
  width: 100%;
  height: auto;
  display: block;
  background: var(--ivory);
}

.cart-drawer-foot {
  padding: 20px 28px 24px;
  border-top: 1px solid var(--line);
  background: #fff;
}
.cart-drawer-foot .cart-subtotal {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1.5px;
  margin: 0 0 6px;
  color: var(--dark);
}
.cart-drawer-foot .cart-subtotal strong {
  font-family: var(--display);
  font-size: 20px;
}
.cart-drawer-foot .cart-subtotal-note {
  font-size: 12px;
  color: var(--muted);
  margin: 0 0 14px;
}
.cart-drawer-foot .cart-gift-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--dark);
  cursor: pointer;
  margin: 8px 0 0;
}
.cart-drawer-foot .cart-gift-toggle em {
  color: var(--muted);
  font-style: normal;
  font-size: 13px;
}
.cart-drawer-foot .cart-gift-note {
  font-size: 12px;
  color: var(--muted);
  margin: 4px 0 16px 26px;
  line-height: 1.5;
}
.cart-drawer-foot .cart-checkout-btn {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  background: var(--dark) !important;
  color: #fff !important;
  padding: 16px !important;
  font-size: 13px !important;
  letter-spacing: 3px !important;
  border: 1px solid var(--dark) !important;
  margin-bottom: 8px !important;
  text-decoration: none !important;
}
.cart-drawer-foot .cart-checkout-btn:hover {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
}
.cart-drawer-foot .cart-view-link {
  display: block;
  text-align: center;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--charcoal);
  text-decoration: underline;
  padding: 10px 0 0;
}

@media (max-width: 600px) {
  .cart-drawer {
    width: 100vw !important;
    right: -100vw !important;
    max-width: 100vw !important;
  }
  .cart-drawer.open { right: 0 !important; }
  .cart-drawer-head,
  .cart-drawer-shipping,
  .cart-drawer-body,
  .cart-drawer-foot {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .cart-drawer-item {
    grid-template-columns: 80px 1fr;
    gap: 12px;
  }
  .cart-item-image { width: 80px; height: 95px; }
  .cart-item-name { font-size: 14px; }
}


/* =========================================================
   CHECKOUT PAGE
   ========================================================= */

.aurora-checkout-page {
  max-width: 1200px;
  margin: 0 auto;
}
.aurora-checkout-page .checkout-head {
  text-align: center;
  margin-bottom: 32px;
  position: relative;
}
.aurora-checkout-page .checkout-title {
  font-family: var(--display);
  font-size: clamp(26px, 4vw, 36px);
  font-weight: 400;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin: 0 0 8px;
}
.aurora-checkout-page .checkout-back-link {
  display: inline-block;
  font-size: 13px;
  color: var(--charcoal);
  text-decoration: none;
  letter-spacing: .5px;
}
.aurora-checkout-page .checkout-back-link:hover { color: var(--dark); text-decoration: underline; }

.aurora-checkout-page .checkout-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: flex-start;
}
.aurora-checkout-page .checkout-main {
  background: #fff;
  padding: 32px;
  border: 1px solid var(--line);
}
.aurora-checkout-page .checkout-section + .checkout-section {
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}
.aurora-checkout-page h3,
.aurora-checkout-page .woocommerce-billing-fields h3,
.aurora-checkout-page .woocommerce-shipping-fields h3,
.aurora-checkout-page .woocommerce-additional-fields h3 {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 400;
  margin: 0 0 18px;
  color: var(--dark);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.aurora-checkout-page label {
  display: block;
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--charcoal);
  margin-bottom: 6px;
  font-weight: 500;
}
.aurora-checkout-page .woocommerce-input-wrapper { display: block; }
.aurora-checkout-page input[type="text"],
.aurora-checkout-page input[type="email"],
.aurora-checkout-page input[type="tel"],
.aurora-checkout-page input[type="password"],
.aurora-checkout-page input[type="number"],
.aurora-checkout-page textarea,
.aurora-checkout-page .select2-container--default .select2-selection--single {
  width: 100% !important;
  padding: 12px 14px !important;
  border: 1px solid var(--line) !important;
  background: var(--cream) !important;
  font-family: var(--body) !important;
  font-size: 14px !important;
  color: var(--dark) !important;
  border-radius: 0 !important;
  outline: none;
  box-sizing: border-box;
  height: auto !important;
}

.aurora-checkout-page .form-row { margin-bottom: 16px; }
.aurora-checkout-page .form-row-first,
.aurora-checkout-page .form-row-last { width: calc(50% - 8px); display: inline-block; }
.aurora-checkout-page .form-row-first { margin-right: 12px; }

.aurora-checkout-page .checkout-sidebar {
  position: sticky;
  top: 200px;
}
.aurora-checkout-page .checkout-summary-box {
  background: var(--ivory);
  padding: 28px;
  border: 1px solid var(--line);
}
.aurora-checkout-page .checkout-summary-title {
  font-family: var(--display);
  font-size: 20px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin: 0 0 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.aurora-checkout-page #order_review .shop_table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.aurora-checkout-page #order_review .shop_table th,
.aurora-checkout-page #order_review .shop_table td {
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  text-align: left;
}
.aurora-checkout-page #order_review .shop_table .product-name {
  font-family: var(--display);
  font-size: 15px;
  color: var(--dark);
}
.aurora-checkout-page #order_review .shop_table tfoot th,
.aurora-checkout-page #order_review .shop_table tfoot td {
  font-weight: 500;
}
.aurora-checkout-page #order_review .order-total .amount {
  font-family: var(--display);
  font-size: 20px;
  color: var(--dark);
}
.aurora-checkout-page #payment {
  background: transparent !important;
  border-radius: 0 !important;
  margin-top: 16px;
}
.aurora-checkout-page #payment ul.payment_methods {
  border: 1px solid var(--line) !important;
  padding: 16px !important;
  background: #fff !important;
}
.aurora-checkout-page #payment ul.payment_methods li { border: none !important; }
.aurora-checkout-page #payment .place-order { padding: 0 !important; margin-top: 16px; }
.aurora-checkout-page #place_order {
  width: 100% !important;
  background: var(--dark) !important;
  color: #fff !important;
  padding: 18px !important;
  font-size: 13px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  border: 1px solid var(--dark) !important;
  border-radius: 0 !important;
  font-weight: 500 !important;
  cursor: pointer;
}
.aurora-checkout-page #place_order:hover {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
}

.aurora-checkout-page .checkout-trust {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 20px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
}
.aurora-checkout-page .trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  color: var(--charcoal);
}
.aurora-checkout-page .trust-item svg { color: var(--gold); flex-shrink: 0; }

@media (max-width: 992px) {
  .aurora-checkout-page .checkout-grid {
    grid-template-columns: 1fr;
  }
  .aurora-checkout-page .checkout-sidebar { position: static; }
  .aurora-checkout-page .checkout-main { padding: 10px; }
  .aurora-checkout-page .form-row-first,
  .aurora-checkout-page .form-row-last { width: 100%; display: block; margin-right: 0; }
  
}


/* =========================================================
   SEARCH MODAL â€” improved
   ========================================================= */

.search-modal-inner {
  padding: 0 60px !important;
}
.search-modal-form {
  flex-direction: row-reverse !important;
}
.search-modal-form .search-submit-icon {
  padding: 14px 12px 14px 8px !important;
}
.search-modal-form input {
  padding: 18px 12px !important;
  font-size: 16px !important;
}
.search-suggestions {
  margin-top: 24px !important;
  padding: 0 !important;
}
.search-pages-wrap {
  margin-top: 40px;
  text-align: center;
  border-top: 1px solid var(--line);
  padding-top: 28px;
}
.search-pages-title {
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--dark);
  margin-bottom: 14px;
  font-weight: 500;
}
.search-pages-wrap a {
  display: block;
  padding: 6px 0;
  font-size: 14px;
  color: var(--charcoal);
  text-decoration: none;
}
.search-pages-wrap a:hover { color: var(--dark); text-decoration: underline; }

#auroraSearchResults:not(:empty) + .search-pages-wrap { display: none; }

@media (max-width: 768px) {
  .search-modal-inner { padding: 0 16px !important; }
  .search-modal-form .search-submit-icon { padding: 12px 8px !important; }
  .search-modal-form input { padding: 14px 8px !important; font-size: 15px !important; }
  .search-suggestions { font-size: 13px !important; gap: 10px !important; }
}


/* =========================================================
   FOOTER SOCIAL ICONS
   ========================================================= */

.footer-social {
  display: flex;
  gap: 14px;
  margin-top: 18px;
}
.footer-social a {
  width: 38px; height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--dark);
  background: #fff;
  transition: all .2s ease;
  padding: 0;
}
.footer-social a:hover {
  background: var(--dark);
  color: #fff;
  border-color: var(--dark);
}


/* =========================================================
   HEADER POLISH â€” keep search/cart icons aligned on mobile
   ========================================================= */
@media (max-width: 768px) {
  .header-inner {
    grid-template-columns: auto 1fr auto !important;
    padding: 12px 14px !important;
    gap: 8px !important;
  }
  .header-left { gap: 4px; display: flex !important; }
  .header-right { gap: 4px; }
  .header .icon-btn,
  header.header .icon-btn,
  header.header .icon-btn-search,
  .hamburger {
    width: 38px !important; height: 38px !important;
  }
  .header .icon-btn svg,
  header.header .icon-btn svg,
  header.header .icon-btn-search svg {
    width: 18px !important; height: 18px !important;
  }
  .hamburger { display: inline-flex !important; }
  .header-logo .logo,
  .header .custom-logo-link { font-size: 22px !important; letter-spacing: 4px !important; }
  .header .custom-logo { max-height: 44px !important; }
  .header-logo .logo::before { width: 22px !important; height: 18px !important; }
}

.icon-btn-search { display: inline-flex !important; }



/* =========================================================
   v2.6 â€” TARGETED FIXES (cart, drawer, checkout, footer, search)
   ========================================================= */

/* ---------- FOOTER: BRAND/POLICIES 2-col + social icons ---------- */
.footer-top {
  grid-template-columns: 2fr 1fr 1fr !important;
  gap: 48px !important;
}
@media (max-width: 992px) {
  .footer-top { grid-template-columns: 1fr 1fr !important; gap: 32px !important; }
}
@media (max-width: 600px) {
  .footer-top { grid-template-columns: 1fr !important; gap: 32px !important; }
}
.footer-social {
  display: flex;
  gap: 12px;
  margin-top: 22px;
  align-items: center;
}
.footer-social a {
  width: 40px; height: 40px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--dark);
  background: #fff;
  padding: 0 !important;
  transition: all .2s ease;
}
.footer-social a:hover {
  background: var(--dark);
  color: #fff;
  border-color: var(--dark);
}
.footer-social svg {
  width: 18px;
  height: 18px;
  display: block;
}

/* ---------- HEADER: Hide PAGES strip in search, keep suggestions ---------- */
.search-pages-wrap { display: none !important; }
/* Suggestions only show while typing nothing â€” when typing, JS hides them */
.search-modal.search-typing .search-suggestions { display: none !important; }

/* ---------- CART DRAWER: shoppy-style +/- box ---------- */

.cart-drawer-item .quantity-down,
.cart-drawer-item .quantity-up {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  cursor: pointer;
  color: var(--dark);
  text-decoration: none;
}
.cart-drawer-item .quantity-down:hover,
.cart-drawer-item .quantity-up:hover { background: var(--ivory); }
.cart-drawer-item .quantity-down svg,
.cart-drawer-item .quantity-up svg { width: 16px; height: 16px; stroke: currentColor; }
.cart-drawer-item input.cart-item__quantity-input {
  width: 36px !important;
  height: 32px !important;
  text-align: center;
  border: none !important;
  border-left: 1px solid var(--line) !important;
  border-right: 1px solid var(--line) !important;
  background: transparent !important;
  font-family: var(--body);
  font-size: 14px;
  color: var(--dark);
  border-radius: 0 !important;
  padding: 0 !important;
  -moz-appearance: textfield;
  outline: none;
}
.cart-drawer-item input.cart-item__quantity-input::-webkit-inner-spin-button,
.cart-drawer-item input.cart-item__quantity-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ---------- CART PAGE: shoppy-style +/- box ---------- */
.aurora-cart-page .quantity.buttoned-input {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: #fff;
  width: fit-content;
  margin: 0 auto;
}
.aurora-cart-page .quantity-down,
.aurora-cart-page .quantity-up {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 40px;
  cursor: pointer;
  color: var(--dark);
  text-decoration: none;
}
.aurora-cart-page .quantity-down:hover,
.aurora-cart-page .quantity-up:hover { background: var(--ivory); }
.aurora-cart-page .quantity-down svg,
.aurora-cart-page .quantity-up svg { width: 18px; height: 18px; stroke: currentColor; }
.aurora-cart-page input.cart-item__quantity-input {
  width: 44px !important;
  height: 40px !important;
  text-align: center;
  border: none !important;
  border-left: 1px solid var(--line) !important;
  border-right: 1px solid var(--line) !important;
  background: transparent !important;
  font-family: var(--body);
  font-size: 15px;
  color: var(--dark);
  border-radius: 0 !important;
  padding: 0 !important;
  -moz-appearance: textfield;
  outline: none;
}
.aurora-cart-page input.cart-item__quantity-input::-webkit-inner-spin-button,
.aurora-cart-page input.cart-item__quantity-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ---------- CHECKOUT: remove ivory bg + repair table ---------- */
.aurora-checkout-page .checkout-summary-box {
  background: #fff !important;
  border: 1px solid var(--line);
}
.aurora-checkout-page .checkout-main {
  background: #fff;
}
.aurora-checkout-page #order_review .shop_table thead th,
.aurora-checkout-page #order_review .shop_table tbody td,
.aurora-checkout-page #order_review .shop_table tfoot th,
.aurora-checkout-page #order_review .shop_table tfoot td {
  display: table-cell !important;
  width: auto !important;
  padding: 12px 8px !important;
  font-size: 14px !important;
  border: none !important;
  border-bottom: 1px solid var(--line) !important;
  text-align: left !important;
  background: transparent !important;
  font-family: var(--body) !important;
}
.aurora-checkout-page #order_review .shop_table thead th { display: none !important; }
.aurora-checkout-page #order_review .shop_table tbody td.product-name {
  font-family: var(--display) !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  width: 60% !important;
}
.aurora-checkout-page #order_review .shop_table tbody td.product-total {
  text-align: right !important;
  font-weight: 500 !important;
  white-space: nowrap;
}
.aurora-checkout-page #order_review .shop_table tfoot th {
  font-weight: 500 !important;
  color: var(--charcoal) !important;
  text-transform: uppercase;
  font-size: 12px !important;
  letter-spacing: 1px;
}
.aurora-checkout-page #order_review .shop_table tfoot td {
  text-align: right !important;
  font-weight: 500 !important;
  white-space: nowrap;
}
.aurora-checkout-page #order_review .shop_table tfoot tr.order-total th,
.aurora-checkout-page #order_review .shop_table tfoot tr.order-total td {
  font-family: var(--display) !important;
  font-size: 18px !important;
  color: var(--dark) !important;
  border-bottom: none !important;
  padding-top: 14px !important;
}
.aurora-checkout-page #order_review_heading { display: none; }

/* ---------- PRODUCT CARD: tweaks after wishlist removed ---------- */
.aurora-card-actions { gap: 8px !important; }

/* ---------- CATEGORY ARCHIVE HERO BANNER ---------- */
.archive .shop-hero {
  background: linear-gradient(135deg, var(--ivory) 0%, var(--beige) 100%);
  padding: 70px 0 50px;
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.shop-hero-banner-img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  display: block;
  margin: 0 auto 24px;
  max-width: 1400px;
}
.term-description {
  max-width: 720px;
  margin: 14px auto 0;
  font-size: 15px;
  color: var(--charcoal);
  line-height: 1.7;
}
@media (max-width: 768px) {
  .archive .shop-hero { padding: 40px 0 30px; }
  .shop-hero-banner-img { height: 180px; }
  .aurora-checkout-page .checkout-summary-box {
    padding: 10px;}
}

/* ---------- USP STRIP (front page) ---------- */
.usp-strip {
  background: var(--cream);
  padding: 50px 0;
}
.usp-strip-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
}
.usp-card {
  background: var(--ivory);
  border-radius: 12px;
  padding: 36px 28px;
  text-align: center;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease, box-shadow .2s ease;
}
.usp-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px -10px rgba(0,0,0,.12);
}
.usp-icon {
  color: var(--gold);
  margin-bottom: 16px;
}
.usp-icon svg { stroke: currentColor; fill: none; }
.usp-title {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 6px;
  color: var(--dark);
}
.usp-text {
  font-size: 13px;
  color: var(--charcoal);
  margin: 0;
  line-height: 1.6;
}
@media (max-width: 768px) {
  .usp-strip-inner { grid-template-columns: 1fr; gap: 16px; }
  .usp-card { padding: 28px 20px; }
}

/* ---------- SHOP GRID / LIST TOGGLE ---------- */
.shop-view-toggle {
  display: inline-flex;
  gap: 6px;
  margin-right: 8px;
}
.shop-view-toggle button {
  width: 38px; height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--dark);
  cursor: pointer;
  padding: 0;
}
.shop-view-toggle button.active {
  background: var(--dark);
  color: #fff;
  border-color: var(--dark);
}
.shop-view-toggle svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.6; }

/* List view layout */
.woocommerce.shop-view-list ul.products {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce.shop-view-list ul.products li.product {
  display: grid !important;
  grid-template-columns: 220px 1fr;
  gap: 24px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding: 20px 0;
}
.woocommerce.shop-view-list ul.products li.product .aurora-card-media {
  aspect-ratio: 1 / 1;
  width: 220px;
}
.woocommerce.shop-view-list ul.products li.product .aurora-card-body {
  text-align: left;
}
@media (max-width: 600px) {
  .woocommerce.shop-view-list ul.products li.product {
    grid-template-columns: 120px 1fr;
    gap: 14px;
  }
  .woocommerce.shop-view-list ul.products li.product .aurora-card-media { width: 120px; }
}

/* Hide gift-card UI on cart pages where it lingers (legacy) */
.gift-card-toggle,
.gift-card-fields,
.cart-gift-toggle,
.cart-gift-note { display: none !important; }



/* =========================================================
   v2.7 â€” ABOUT SPLIT + TRACKING + SEARCH ENHANCEMENT
   ========================================================= */

/* ---------- ABOUT â€” image + text split sections ---------- */
.about-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  margin: 0 auto 80px;
  max-width: 1100px;
}
.about-split-reverse .about-split-image { order: 2; }
.about-split-reverse .about-split-text  { order: 1; }
.about-split-image img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  background: var(--ivory);
  border-radius: 4px;
}
.about-split-text h2 {
  font-family: var(--display);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 400;
  margin: 0 0 20px;
  color: var(--dark);
}
.about-split-text p {
  font-size: 16px;
  color: var(--charcoal);
  line-height: 1.8;
  margin: 0 0 16px;
}
@media (max-width: 768px) {
  .about-split { grid-template-columns: 1fr; gap: 28px; margin-bottom: 48px; }
  .about-split-reverse .about-split-image { order: 1; }
  .about-split-reverse .about-split-text  { order: 2; }
}

/* ---------- ORDER TRACKING FORM (WC shortcode) ---------- */
.aurora-tracking-page .track_order {
  max-width: 560px;
  margin: 0 auto;
}
.aurora-tracking-page .track_order .form-row {
  margin-bottom: 18px;
}
.aurora-tracking-page .track_order label {
  display: block;
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--charcoal);
  margin-bottom: 6px;
  font-weight: 500;
}
.aurora-tracking-page .track_order input[type="text"],
.aurora-tracking-page .track_order input[type="email"] {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--line);
  background: #fff;
  font-family: var(--body);
  font-size: 14px;
  color: var(--dark);
  border-radius: 0;
  outline: none;
  box-sizing: border-box;
}
.aurora-tracking-page .track_order button[type="submit"] {
  width: 100%;
  background: var(--dark);
  color: #fff;
  padding: 16px;
  font-size: 13px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  border: 1px solid var(--dark);
  border-radius: 0;
  font-family: var(--body);
  font-weight: 500;
  cursor: pointer;
  margin-top: 8px;
}
.aurora-tracking-page .track_order button[type="submit"]:hover {
  background: var(--gold);
  border-color: var(--gold);
}

/* ---------- SEARCH â€” refined suggestions row ---------- */
.search-suggestions {
  justify-content: center !important;
}
.search-suggestions strong { display: inline-block; margin-right: 6px; }
.search-suggestions a {
  padding: 4px 10px !important;
  border: 1px solid transparent;
  border-radius: 20px;
  background: transparent;
}
.search-suggestions a:hover {
  background: var(--ivory) !important;
  border-color: var(--line) !important;
}

/* Hide PAGES strip wholly (covered by .search-pages-wrap{display:none} already) */



/* =========================================================
   v2.8 â€” SEARCH UX + ABOUT NARROW + DEFENSIVE TWEAKS
   ========================================================= */

.search-empty-hint {
  text-align: center;
  padding: 60px 24px;
  color: var(--muted);
  font-size: 14px;
  letter-spacing: .3px;
}
.search-loading {
  text-align: center;
  padding: 60px 24px;
  color: var(--muted);
  font-size: 13px;
  letter-spacing: 1px;
}

/* Suggestions chips returned by AJAX live search */
#auroraSearchResults .search-suggestions {
  margin: 0 0 28px !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
}
#auroraSearchResults .search-suggestions strong {
  display: inline-block;
  margin-right: 8px;
  font-size: 13px;
  color: var(--dark);
  letter-spacing: .5px;
}
#auroraSearchResults .search-suggestions a {
  display: inline-block;
  padding: 4px 12px !important;
  margin: 4px 4px 4px 0;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: transparent;
  color: var(--charcoal) !important;
  font-size: 13px;
  text-decoration: none !important;
}
#auroraSearchResults .search-suggestions a:hover {
  background: var(--dark) !important;
  color: #fff !important;
  border-color: var(--dark) !important;
}

/* About â€” narrow story paragraph */
.story-section-narrow {
  max-width: 780px;
  margin: 0 auto 56px;
  text-align: center;
}
.story-section-narrow h2 {
  font-family: var(--display);
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 400;
  margin: 0 0 18px;
}
.story-section-narrow p {
  font-size: 16px;
  line-height: 1.8;
  color: var(--charcoal);
  margin: 0 0 14px;
}

/* Story values â€” make 3-up on desktop instead of 2-up (we have 6 items now) */
.story-values { grid-template-columns: repeat(3, 1fr) !important; gap: 32px 28px !important; }
@media (max-width: 992px) { .story-values { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 600px) { .story-values { grid-template-columns: 1fr !important; gap: 24px !important; } }



/* =========================================================
   v3.0 â€” UNIVERSAL +/- QUANTITY WIDGET
   Same look on cart page, cart drawer, single product page
   ========================================================= */



/* +/- buttons */
.quantity .quantity-down,
.quantity .quantity-up {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 44px;
  background: transparent;
  border: none !important;
  color: var(--dark);
  cursor: pointer;
  text-decoration: none;
  padding: 0 !important;
  margin: 0 !important;
}
.quantity .quantity-down:hover,
.quantity .quantity-up:hover { background: var(--ivory); }
.quantity .quantity-down svg,
.quantity .quantity-up svg {
  width: 18px; height: 18px;
  stroke: currentColor; fill: none; stroke-width: 1.6;
  pointer-events: none;
}

/* Input â€” neutral, framed by the +/- buttons */
.quantity input.qty,
.quantity input[type="number"],
.quantity input.cart-item__quantity-input {
  width: 50px !important;
  height: 44px !important;
  text-align: center !important;
  border: none !important;
  border-left: 1px solid var(--line) !important;
  border-right: 1px solid var(--line) !important;
  background: transparent !important;
  font-family: var(--body) !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  -moz-appearance: textfield;
  outline: none;
}
.quantity input.qty::-webkit-inner-spin-button,
.quantity input.qty::-webkit-outer-spin-button,
.quantity input[type="number"]::-webkit-inner-spin-button,
.quantity input[type="number"]::-webkit-outer-spin-button,
.quantity input.cart-item__quantity-input::-webkit-inner-spin-button,
.quantity input.cart-item__quantity-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Smaller variant inside cart drawer (compact) */
#auroraCartDrawer .quantity .quantity-down,
#auroraCartDrawer .quantity .quantity-up { width: 32px; height: 36px; }
#auroraCartDrawer .quantity input.cart-item__quantity-input { width: 38px !important; height: 36px !important; font-size: 14px !important; }

/* Single product page â€” space the qty + add-to-cart button neatly */
.woocommerce div.product form.cart {
  display: flex !important;
  flex-wrap: wrap;
  gap: 14px !important;
  align-items: center;
  margin-bottom: 28px;
}
.woocommerce div.product form.cart .quantity { margin: 0 !important; }



/* =========================================================
   v3.2 â€” POLISH (about, contact, single product, category hero)
   ========================================================= */

/* ---------- ABOUT EYEBROW + values head ---------- */
.about-eyebrow {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
  margin-bottom: 12px;
}
.values-head {
  text-align: center;
  margin-bottom: 36px;
}
.values-head h2 {
  font-family: var(--display);
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 400;
  margin: 0;
}
.about-split { gap: 64px; }
.about-split-text h2 {
  font-family: var(--display);
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 400;
  margin: 0 0 16px;
}
.about-split-image img {
  border-radius: 4px;
  box-shadow: 0 16px 40px -16px rgba(0,0,0,.18);
}

/* ---------- CATEGORY HERO â€” clean, no image ---------- */
.shop-hero.shop-hero-clean {
  background: var(--cream) !important;
  padding: 50px 0 30px !important;
  border-bottom: 1px solid var(--line);
}
.shop-hero.shop-hero-clean .shop-hero-title {
  font-family: var(--display);
  font-size: clamp(32px, 4vw, 50px);
  font-weight: 400;
  margin: 8px 0;
}
.shop-hero.shop-hero-clean .shop-hero-banner-img,
.archive .shop-hero .shop-hero-banner-img,
.shop-hero .shop-hero-banner-img { display: none !important; }


/* ---------- CONTACT PAGE â€” polished channel cards ---------- */
.aurora-contact-page .contact-grid {
  grid-template-columns: 1fr 1fr !important;
  gap: 56px !important;
}
@media (max-width: 992px) {
  .aurora-contact-page .contact-grid { grid-template-columns: 1fr !important; gap: 40px !important; }
}

.contact-channels {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
}
@media (max-width: 480px) {
  .contact-channels { grid-template-columns: 1fr !important; }
}
.contact-channel {
  display: block;
  background: #fff !important;
  border: 1px solid var(--line);
  padding: 26px 22px !important;
  text-align: left !important;
  text-decoration: none !important;
  color: var(--dark) !important;
  transition: all .25s ease;
  border-radius: 4px;
}
.contact-channel:hover {
  border-color: var(--dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px -10px rgba(0,0,0,.12);
}
.contact-channel .channel-icon {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--ivory);
  color: var(--dark);
  margin-bottom: 14px !important;
  font-size: 22px !important;
}
.contact-channel:hover .channel-icon {
  background: var(--dark);
  color: #fff;
}
.contact-channel .channel-icon svg { stroke: currentColor; fill: none; width: 22px; height: 22px; }
.contact-channel:hover .channel-icon svg[fill="currentColor"] { fill: #fff; }
.contact-channel h3 {
  font-family: var(--display) !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  margin: 0 0 6px !important;
  color: var(--dark);
}
.contact-channel p {
  font-size: 13px !important;
  color: var(--charcoal) !important;
  margin: 0 0 12px !important;
  line-height: 1.5;
}
.contact-channel-value {
  display: inline-block;
  font-size: 13px;
  color: var(--dark);
  font-weight: 500;
  letter-spacing: .3px;
  border-bottom: 1px solid var(--dark);
  padding-bottom: 2px;
}

/* Hide the old .btn inside contact-channel (we use the value link style now) */
.contact-channel .btn { display: none !important; }

/* Contact map */
.contact-map-wrap {
  margin-top: 64px;
  border-top: 1px solid var(--line);
  padding-top: 60px;
}
.contact-map-head { text-align: center; margin-bottom: 28px; }
.contact-map-head h2 {
  font-family: var(--display);
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 400;
  margin: 6px 0 6px;
}
.contact-map-head p { color: var(--charcoal); font-size: 14px; margin: 0; }
.contact-map iframe {
  display: block;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 4px;
}

/* ---------- LOCATIONS PAGE â€” map embed in card ---------- */
.aurora-locations-page .location-image {
  width: 100%;
  height: 420px;
  background: var(--ivory);
  overflow: hidden;
  border-radius: 4px;
}
.aurora-locations-page .location-image iframe { width: 100%; height: 100%; border: 0; display: block; }
@media (max-width: 768px) {
  .aurora-locations-page .location-image { height: 280px; }
}


/* ---------- SINGLE PRODUCT PAGE â€” match aishas.com elegance ---------- */
.woocommerce div.product .summary {
  padding-left: 24px;
}
@media (max-width: 1024px) { .woocommerce div.product .summary { padding-left: 0; } }

/* Quantity label above input */
.woocommerce div.product form.cart::before {
  content: "Quantity";
  display: block;
  width: 100%;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--charcoal);
  font-weight: 500;
  margin: 0 0 10px;
}
.woocommerce div.product form.cart {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  margin-bottom: 28px !important;
}
.woocommerce div.product form.cart .quantity {
  width: fit-content !important;
  height: 48px;
}
.woocommerce div.product form.cart .quantity .quantity-down,
.woocommerce div.product form.cart .quantity .quantity-up { width: 44px; height: 46px; }
.woocommerce div.product form.cart .quantity input.qty,
.woocommerce div.product form.cart .quantity input[type="number"] {
  width: 60px !important;
  height: 46px !important;
  font-size: 15px !important;
}

/* Add to Cart button â€” full width, outlined â†’ fills on hover */
.woocommerce div.product .single_add_to_cart_button,
.woocommerce div.product form.cart .single_add_to_cart_button {
  display: block !important;
  width: 100% !important;
  background: transparent !important;
  color: var(--dark) !important;
  border: 1px solid var(--dark) !important;
  padding: 16px 24px !important;
  font-size: 12px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
  border-radius: 0 !important;
  text-align: center !important;
  margin: 0 !important;
  transition: all .25s ease !important;
  font-family: var(--body) !important;
  cursor: pointer;
}
.woocommerce div.product .single_add_to_cart_button:hover,
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  background: var(--dark) !important;
  color: #fff !important;
}
.woocommerce div.product .single_add_to_cart_button.loading {
  opacity: .7;
  cursor: not-allowed;
}

/* Trust-badge row under add-to-cart (auto-rendered via JS â€” optional) */
.aurora-single-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}
.aurora-trust-item {
  text-align: center;
  font-size: 12px;
  color: var(--charcoal);
}
.aurora-trust-item .ti-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  margin-bottom: 6px;
  color: var(--dark);
}
.aurora-trust-item .ti-icon svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 1.4; }
.aurora-trust-item strong {
  display: block;
  font-size: 12px;
  letter-spacing: .5px;
  color: var(--dark);
  font-weight: 500;
}
@media (max-width: 600px) { .aurora-single-trust { grid-template-columns: 1fr 1fr; } }



/* =========================================================
   v3.6 — qty-btn disabled state (when at min/max stock)
   ========================================================= */
.quantity .quantity-down.is-disabled,
.quantity .quantity-up.is-disabled {
  opacity: .35 !important;
  cursor: not-allowed !important;
  pointer-events: auto !important; /* still clickable to show toast */
}
.quantity .quantity-down.is-disabled:hover,
.quantity .quantity-up.is-disabled:hover {
  background: transparent !important;
}


/* =========================================================
   v3.7 — SINGLE-PRODUCT QTY BOX OVERRIDE
   The existing .woocommerce div.product form.cart button rule
   was giving our +/- buttons a dark background. Override it.
   ========================================================= */

.woocommerce div.product form.cart .quantity,
.woocommerce div.product form.cart .quantity.buttoned-input {
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  flex: 0 0 auto !important;
  max-width: 160px !important;
  background: #fff !important;
  border: 1px solid #e5dfd3 !important;
  padding: 0 !important;
  margin: 0 14px 0 0 !important;
  border-radius: 0 !important;
  overflow: hidden;
}

.woocommerce div.product form.cart .quantity .quantity-down,
.woocommerce div.product form.cart .quantity .quantity-up,
body.single-product .quantity .quantity-down,
body.single-product .quantity .quantity-up {
  background: transparent !important;
  color: #1F1B17 !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
  width: 44px !important;
  height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-size: 14px !important;
  box-shadow: none !important;
}

.woocommerce div.product form.cart .quantity .quantity-down:hover,
.woocommerce div.product form.cart .quantity .quantity-up:hover {
  background: #F5EFE5 !important;
  color: #1F1B17 !important;
  border: none !important;
}

.woocommerce div.product form.cart .quantity .quantity-down svg,
.woocommerce div.product form.cart .quantity .quantity-up svg {
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 1.6 !important;
  pointer-events: none;
}

.woocommerce div.product form.cart .quantity input.qty,
.woocommerce div.product form.cart .quantity input[type="number"] {
  width: 52px !important;
  height: 46px !important;
  text-align: center !important;
  border: none !important;
  border-left: 1px solid #e5dfd3 !important;
  border-right: 1px solid #e5dfd3 !important;
  background: #fff !important;
  color: #1F1B17 !important;
  font-family: var(--body) !important;
  font-size: 15px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  -moz-appearance: textfield;
  box-shadow: none !important;
  outline: none !important;
}

.woocommerce div.product form.cart .quantity input.qty::-webkit-inner-spin-button,
.woocommerce div.product form.cart .quantity input.qty::-webkit-outer-spin-button,
.woocommerce div.product form.cart .quantity input[type="number"]::-webkit-inner-spin-button,
.woocommerce div.product form.cart .quantity input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Ensure the Add-to-Cart button keeps its normal styling and sits next to the qty box */
.woocommerce div.product form.cart .single_add_to_cart_button {
  flex: 1 1 auto !important;
  min-width: 200px !important;
}


/* =========================================================
   v3.8 — FORCE QTY INPUT VISIBLE EVERYWHERE
   Some parent CSS (Hello Elementor / WC defaults) was hiding
   the input between +/-. These rules bulletproof its display.
   ========================================================= */

/* Force qty wrapper as an inline-flex row, never full-width */

/* Force the input visible — covers all WC input class variants */
body.single-product .quantity input,
.woocommerce div.product form.cart .quantity input,
form.cart .quantity input,
.woocommerce .quantity input.qty,
.woocommerce .quantity input.input-text,
.woocommerce .quantity input.text,
.woocommerce .quantity input[type="number"] {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: static !important;
  width: 56px !important;
  min-width: 56px !important;
  max-width: 56px !important;
  height: 46px !important;
  text-align: center !important;
  border: none !important;
  border-left: 1px solid #e5dfd3 !important;
  border-right: 1px solid #e5dfd3 !important;
  background: #fff !important;
  color: #1F1B17 !important;
  font-family: var(--body, 'Jost', sans-serif) !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  flex: 0 0 auto !important;
  box-sizing: border-box !important;
  -moz-appearance: textfield !important;
  appearance: textfield !important;
  line-height: 46px !important;
}

/* Hide WC screen-reader label so it doesn't take flex space */
body.single-product .quantity label,
.woocommerce .quantity label,
.woocommerce .quantity .screen-reader-text {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}

/* Buttons inside the qty wrapper — neutralize any parent button rules */
body.single-product .quantity .quantity-down,
body.single-product .quantity .quantity-up,
.woocommerce div.product form.cart .quantity .quantity-down,
.woocommerce div.product form.cart .quantity .quantity-up,
form.cart .quantity .quantity-down,
form.cart .quantity .quantity-up {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 46px !important;
  height: 46px !important;
  background: transparent !important;
  color: #1F1B17 !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
  font-size: 14px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-weight: 400 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}
body.single-product .quantity .quantity-down:hover,
body.single-product .quantity .quantity-up:hover,
.woocommerce div.product form.cart .quantity .quantity-down:hover,
.woocommerce div.product form.cart .quantity .quantity-up:hover {
  background: #F5EFE5 !important;
}
.quantity .quantity-down svg,
.quantity .quantity-up svg {
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 1.6 !important;
  pointer-events: none !important;
}

/* Hide spinner arrows on number inputs */
.woocommerce .quantity input[type="number"]::-webkit-inner-spin-button,
.woocommerce .quantity input[type="number"]::-webkit-outer-spin-button,
.woocommerce .quantity input.qty::-webkit-inner-spin-button,
.woocommerce .quantity input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

/* Add-to-Cart button keeps normal styling next to qty box */
.woocommerce div.product form.cart .single_add_to_cart_button {
  flex: 1 1 auto !important;
  min-width: 200px !important;
}


/* =========================================================
   v3.9 — POLISH: shop card, contact page, hero, mobile
   ========================================================= */

/* ---------- Hero slide backgrounds (4 slides) ---------- */
.hero-slide-3 { background-color: #FBF7F0; color: var(--dark); }
.hero-slide-4 { background-color: #C9A47B; color: var(--cream); }

/* ---------- Shop card cart icon button — strong overrides ---------- */
.aurora-card-actions .aurora-action-cart {
  background: #fff !important;
  border: none !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  color: #1F1B17 !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.10) !important;
  cursor: pointer !important;
  transition: all .2s ease;
}
.aurora-card-actions .aurora-action-cart:hover {
  background: #1F1B17 !important;
  color: #fff !important;
  transform: scale(1.05);
}
.aurora-card-actions .aurora-action-cart .aurora-action-cart-link,
.aurora-card-actions .aurora-action-cart a.button,
.aurora-card-actions .aurora-action-cart a {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: transparent !important;
  color: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0 !important;
  text-indent: -9999px !important;
  letter-spacing: 0 !important;
  display: block !important;
  text-decoration: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  z-index: 2 !important;
}
.aurora-card-actions .aurora-action-cart .aurora-action-cart-icon {
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 1.6 !important;
  pointer-events: none !important;
  position: relative;
  z-index: 1;
}

/* When the AJAX add fires, WC adds "loading" then "added" classes — keep our shape */
.aurora-card-actions .aurora-action-cart .loading,
.aurora-card-actions .aurora-action-cart.loading,
.aurora-card-actions .aurora-action-cart .added {
  opacity: .6;
}

/* ---------- Footer Follow line ---------- */
.footer-follow-line {
  font-size: 13px;
  color: var(--charcoal);
  margin: 14px 0 0;
  letter-spacing: .3px;
}
.footer-follow-line a {
  color: var(--dark);
  text-decoration: underline;
  font-weight: 500;
}
.footer-follow-line a:hover { color: var(--gold); }


/* ---------- CONTACT PAGE — smaller centered channels ---------- */
.aurora-contact-page { max-width: 1100px !important; }

.contact-channels-strip {
  max-width: 900px;
  margin: 0 auto 50px;
}
.contact-channels-strip .contact-channels {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  margin: 0 !important;
}
.contact-channels-strip .contact-channel {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  padding: 22px 14px !important;
  text-align: center;
  text-decoration: none;
  color: var(--dark);
  display: flex !important;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: all .2s ease;
  border-radius: 0;
}
.contact-channels-strip .contact-channel:hover {
  background: var(--ivory) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}
.contact-channels-strip .channel-icon { color: var(--gold); margin: 0; }
.contact-channels-strip .contact-channel h3 {
  font-family: var(--display);
  font-size: 16px;
  margin: 0;
  font-weight: 500;
}
.contact-channels-strip .contact-channel-value {
  font-size: 12px;
  color: var(--charcoal);
  letter-spacing: .3px;
  line-height: 1.4;
}

@media (max-width: 768px) {
  .contact-channels-strip .contact-channels {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* CONTACT FORM */
.contact-form-section {
  max-width: 720px;
  margin: 0 auto 60px;
  background: var(--ivory);
  padding: 40px 36px;
  border: 1px solid var(--line);
}
.contact-form-section h2 {
  font-family: var(--display);
  font-size: clamp(22px, 3vw, 28px);
  text-align: center;
  margin: 0 0 6px;
}
.contact-form-section .form-intro {
  text-align: center;
  color: var(--charcoal);
  font-size: 14px;
  margin: 0 0 28px;
}
.aurora-contact-form .form-row { margin-bottom: 14px; }
.aurora-contact-form .form-row-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.aurora-contact-form .form-row-2col > div { display: flex; flex-direction: column; }
.aurora-contact-form label {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--charcoal);
  margin-bottom: 6px;
}
.aurora-contact-form input,
.aurora-contact-form select,
.aurora-contact-form textarea {
  width: 100% !important;
  padding: 12px 14px !important;
  border: 1px solid var(--line) !important;
  background: #fff !important;
  font-family: var(--body) !important;
  font-size: 14px !important;
  color: var(--dark) !important;
  border-radius: 0 !important;
  box-sizing: border-box !important;
  outline: none !important;
  margin-bottom: 10px;
}
.contact-submit-btn {
  display: block !important;
  width: 100% !important;
  margin-top: 14px !important;
  padding: 16px !important;
  font-size: 12px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  background: var(--dark) !important;
  color: #fff !important;
  border: 1px solid var(--dark) !important;
}
.contact-submit-btn:hover { background: var(--gold) !important; border-color: var(--gold) !important; }
.form-status {
  text-align: center;
  margin: 12px 0 0;
  font-size: 14px;
  min-height: 20px;
}
.form-status.success { color: #2e7d32; }
.form-status.error   { color: #A0392E; }
.form-status.sending { color: var(--charcoal); }

@media (max-width: 600px) {
  .contact-form-section { padding: 28px 18px; }
  .aurora-contact-form .form-row-2col { grid-template-columns: 1fr; gap: 0; }
}

/* Contact map area centered */
.contact-map-wrap {
  max-width: 1100px;
  margin: 0 auto 60px;
}
.contact-map-head { text-align: center; margin-bottom: 24px; }
.contact-map iframe { display: block; width: 100% !important; }


/* ---------- SEARCH — category suggestions chip group ---------- */
.search-cat-suggestions strong { color: var(--gold) !important; }
.search-cat-suggestions a {
  background: var(--ivory) !important;
  border-color: var(--ivory) !important;
}
.search-cat-suggestions a:hover {
  background: var(--dark) !important;
  color: #fff !important;
  border-color: var(--dark) !important;
}


/* ---------- CART DRAWER QTY box — refined ---------- */
#auroraCartDrawer .cart-item-info .quantity.buttoned-input,
#auroraCartDrawer .cart-item-info .quantity {
  display: inline-flex !important;
  align-items: center !important;
  border: 1px solid var(--line) !important;
  background: #fff !important;
  width: 123px !important;
  min-width: 0 !important;
  margin: 6px 0 4px !important;
  border-radius: 0;
}
#auroraCartDrawer .quantity .quantity-down,
#auroraCartDrawer .quantity .quantity-up {
  width: 32px !important;
  height: 32px !important;
  background: transparent !important;
  color: var(--dark) !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#auroraCartDrawer .quantity input.cart-item__quantity-input {
  width: 36px !important;
  height: 32px !important;
  text-align: center !important;
  border: none !important;
  border-left: 1px solid var(--line) !important;
  border-right: 1px solid var(--line) !important;
  background: transparent !important;
  color: var(--dark) !important;
  font-family: var(--body) !important;
  font-size: 13px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  -moz-appearance: textfield !important;
  outline: none !important;
}
#auroraCartDrawer .quantity .quantity-down svg,
#auroraCartDrawer .quantity .quantity-up svg {
  width: 14px !important;
  height: 14px !important;
}


/* ---------- MOBILE RESPONSIVE POLISH ---------- */
@media (max-width: 768px) {
  /* Header tighter */
  .header-inner { padding: 10px 12px !important; gap: 6px !important; }
  .header-logo .logo { font-size: 20px !important; letter-spacing: 3px !important; }

  /* Cart page table → stacked card layout */
  .aurora-cart-page { padding: 0px !important; }
  .aurora-cart-page .cart-title { font-size: 24px !important; margin-bottom: 24px !important; letter-spacing: 3px !important; }

  /* Shop archive grid: 2 cols */
  .woocommerce ul.products, ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }
  .aurora-card-title { font-size: 14px !important; }
  .aurora-card-price { font-size: 13px !important; }
  .aurora-card-rating { font-size: 11px !important; }

  /* Single product summary stacks below image */
  .woocommerce div.product {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    padding: 0 14px !important;
  }
  .woocommerce div.product .product_title { font-size: 24px !important; }
  .woocommerce div.product form.cart {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .woocommerce div.product form.cart .quantity {
    margin: 0 0 12px 0 !important;
  }
  .woocommerce div.product form.cart .single_add_to_cart_button {
    width: 100% !important;
    min-width: 0 !important;
  }

  /* Tagline bar smaller */
  .tagline-bar-heading {
    font-size: 18px !important;
    letter-spacing: 1px !important;
    margin-bottom: 28px !important;
    padding: 0 18px !important;
  }

  /* Footer columns stack */
  .footer-top {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .footer-brand p { max-width: 100% !important; }

  /* Newsletter popup — bottom centered on mobile */
  .newsletter-pop {
    left: 12px !important;
    right: 12px !important;
    bottom: 80px !important;
    width: auto !important;
    max-width: none !important;
  }

  /* Hero slide arrows smaller on mobile */
  .hero-arrow { width: 36px !important; height: 36px !important; }
}

@media (max-width: 480px) {
  /* Cart drawer full width */
  .cart-drawer { width: 100vw !important; max-width: 100vw !important; }
  .cart-drawer-head h3 { font-size: 18px !important; }

  /* Shop hero smaller */
  .shop-hero { padding: 32px 0 24px !important; }
  .shop-hero-title { font-size: 26px !important; }
  .shop-hero-banner-img { height: 140px !important; }
}


/* =========================================================
   v4.0 — STOCK ALERT MODAL + BUY IT NOW + SHOP CARD CLEANUP
   ========================================================= */

/* ---------- Shop card cart icon — the <a class="button"> inside should NOT inherit any button styling ---------- */
.aurora-card-actions .aurora-action-cart .aurora-action-cart-link,
.aurora-card-actions .aurora-action-cart a.button,
.aurora-card-actions .aurora-action-cart a.add_to_cart_button {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: transparent !important;
  color: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0 !important;
  letter-spacing: 0 !important;
  text-indent: -9999px !important;
  text-decoration: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  display: block !important;
  line-height: 1 !important;
  z-index: 2 !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ---------- Buy It Now button ---------- */
.aurora-buy-now {
  display: block !important;
  width: 100% !important;
  padding: 14px 24px !important;
  margin-top: 10px !important;
  background: transparent !important;
  color: #1F1B17 !important;
  border: 1px solid #1F1B17 !important;
  font-family: var(--body) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  transition: all .25s ease !important;
  flex-basis: 100% !important;
  text-align: center !important;
}
.aurora-buy-now:hover {
  background: var(--gold) !important;
  color: #fff !important;
  border-color: var(--gold) !important;
}
.aurora-buy-now.is-loading,
.aurora-buy-now:disabled {
  opacity: .6 !important;
  cursor: not-allowed !important;
}
.woocommerce div.product form.cart {
  flex-wrap: wrap !important;
}
.woocommerce div.product form.cart .aurora-buy-now {
  order: 99;
}

/* ---------- THEMED STOCK ALERT MODAL ---------- */
.aurora-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 18, 14, .55);
  backdrop-filter: blur(3px);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s ease, visibility .25s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.aurora-modal-overlay.open {
  opacity: 1;
  visibility: visible;
}
.aurora-modal {
  background: #fff;
  width: 100%;
  max-width: 480px;
  padding: 32px 36px 26px;
  border-radius: 8px;
  position: relative;
  box-shadow: 0 24px 60px -10px rgba(0,0,0,.25);
  transform: translateY(20px);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1);
  font-family: var(--body);
}
.aurora-modal-overlay.open .aurora-modal {
  transform: translateY(0);
}
.aurora-modal-close {
  position: absolute;
  top: 14px; right: 14px;
  width: 32px; height: 32px;
  background: transparent;
  border: none;
  color: var(--charcoal);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 50%;
  transition: background .15s;
}
.aurora-modal-close:hover { background: var(--ivory); }
.aurora-modal-title {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 400;
  margin: 0 0 10px;
  color: var(--dark);
  padding-right: 28px;
}
.aurora-modal-body {
  font-size: 14px;
  line-height: 1.6;
  color: var(--charcoal);
  margin: 0 0 22px;
}

.aurora-modal-product {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  background: var(--ivory);
  border-radius: 4px;
  margin-bottom: 20px;
}
.aurora-modal-product[hidden] { display: none; }
.aurora-modal-product-img {
  width: 64px;
  height: 64px;
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.aurora-modal-product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.aurora-modal-product-info {
  flex: 1;
  min-width: 0;
}
.aurora-modal-product-name {
  font-family: var(--display);
  font-size: 16px;
  color: var(--dark);
  font-weight: 500;
  margin-bottom: 4px;
  line-height: 1.3;
}
.aurora-modal-product-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
  color: #A0392E;
}

.aurora-modal-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.aurora-modal-actions .btn,
.aurora-modal-btn-primary {
  flex: 1;
  min-width: 140px;
  padding: 12px 18px !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  background: var(--dark) !important;
  color: #fff !important;
  border: 1px solid var(--dark) !important;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
}
.aurora-modal-actions .btn:hover,
.aurora-modal-btn-primary:hover {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
}
.aurora-modal-btn-secondary {
  flex: 1;
  min-width: 140px;
  padding: 12px 18px;
  font-size: 11px;
  letter-spacing: 2px;
  font-family: var(--body);
  font-weight: 500;
  text-transform: uppercase;
  background: transparent;
  color: var(--dark);
  border: 1px solid var(--line);
  cursor: pointer;
  border-radius: 0;
  transition: all .2s ease;
}
.aurora-modal-btn-secondary:hover {
  background: var(--ivory);
  border-color: var(--dark);
}

@media (max-width: 480px) {
  .aurora-modal { padding: 24px 22px 20px; }
  .aurora-modal-actions { flex-direction: column; }
  .aurora-modal-actions .btn,
  .aurora-modal-btn-primary,
  .aurora-modal-btn-secondary { width: 100%; }
}


/* =========================================================
   v4.2 — MODAL VISIBILITY HARDENED + SHOP CART ICON LOCKED
   ========================================================= */

/* Force modal hidden when not .open */
.aurora-modal-overlay {
  display: flex !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
.aurora-modal-overlay.open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Lock shop card cart icon — single source of truth */
.aurora-card-actions .aurora-action-cart {
  position: relative !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: #fff !important;
  color: #1F1B17 !important;
  border: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.10) !important;
  cursor: pointer !important;
  transition: all .2s ease;
}
.aurora-card-actions .aurora-action-cart:hover {
  background: #1F1B17 !important;
  color: #fff !important;
  transform: scale(1.05);
}
.aurora-card-actions .aurora-action-cart.loading {
  opacity: .6;
  pointer-events: none;
}
.aurora-card-actions .aurora-action-cart .aurora-action-cart-link,
.aurora-card-actions .aurora-action-cart .add_to_cart_button,
.aurora-card-actions .aurora-action-cart a.button,
.aurora-card-actions .aurora-action-cart a {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: transparent !important;
  color: transparent !important;
  font-size: 0 !important;
  text-indent: -9999px !important;
  border: none !important;
  border-radius: 50% !important;
  padding: 0 !important;
  margin: 0 !important;
  letter-spacing: 0 !important;
  z-index: 2 !important;
  cursor: pointer !important;
  display: block !important;
  line-height: 1 !important;
}
.aurora-card-actions .aurora-action-cart-icon {
  position: relative !important;
  z-index: 1 !important;
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 1.6 !important;
  pointer-events: none !important;
  display: block !important;
}

@media (max-width: 768px) {
.search-results-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important; }
    
    .shop-wrap {
        padding: 20px 0px;}
    
    .site-main {   
        padding: 0px !important;
    }
}
#sb_instagram{
padding:0 !important;
}

.sb_instagram_header.sbi_medium {
    display: none !important;
}

#sb_instagram .sbi_item{
padding:5px !important;
}


/* =============================================================
   ╔══════════════════════════════════════════════════════════╗
   ║   v4.3 — CLIENT FIXES (LOGO / MEGA-MENU / HERO / PERF)   ║
   ╚══════════════════════════════════════════════════════════╝
   Loaded LAST → these rules win the cascade.
   ============================================================= */

/* ---------- A. HEADER LOGO — show uploaded image properly ---------- */
/* Force the diamond pseudo-element OFF whenever an <img> logo is rendered.
   Old CSS only hid it via a fragile double-class selector that broke when
   the user uploaded a custom logo. */
.header-logo .custom-logo-link::before,
.header-logo .aurora-header-logo-link::before,
.header-logo a:has(img)::before{
  display:none !important;
  content:none !important;
  background:none !important;
  width:0 !important;height:0 !important;
}
.header-logo{
  text-align:center !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:60px;
}
.header-logo .custom-logo-link,
.header-logo .aurora-header-logo-link{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex-direction:row !important; /* override old column flex */
  padding:0 !important;
  line-height:1 !important;
  /* clear text-style leftovers when an image is inside */
  letter-spacing:0 !important;
  font-size:0 !important;
}
.header-logo .custom-logo,
.header-logo .aurora-header-logo-img{
  display:block !important;
  height:auto !important;
  max-height:64px !important;
  width:auto !important;
  max-width:240px !important;
  object-fit:contain !important;
}
@media (max-width:768px){
  .header-logo{min-height:48px}
  .header-logo .custom-logo,
  .header-logo .aurora-header-logo-img{
    max-height:44px !important;
    max-width:180px !important;
  }
}


/* ---------- B. SHOP MEGA MENU — 2-row category grid, narrower ---------- */
nav.nav .aurora-nav > li.nav-has-mega-shop > .mega-menu.mega-menu-shop{
  min-width:560px !important;
  max-width:640px !important;
  padding:30px 36px 26px !important;
}
.mega-menu-shop .mega-col-cats{ width:100% }
.mega-menu-shop .mega-col-cats h4{
  text-align:center;
  margin:0 0 18px !important;
  font-size:11px !important;
  letter-spacing:2.5px !important;
  color:var(--gold) !important;
}
.mega-cats-grid{
  display:grid !important;
  /* 3 columns × 2 rows for 6 categories */
  grid-template-columns:repeat(3, 1fr) !important;
  gap:8px 28px !important;
  list-style:none !important;
  margin:0 0 18px !important;
  padding:0 !important;
}
.mega-cats-grid li{ margin:0 !important; list-style:none !important }
.mega-cats-grid li a{
  display:block !important;
  padding:9px 12px !important;
  font-size:13.5px !important;
  font-weight:400 !important;
  letter-spacing:.5px !important;
  text-transform:none !important;
  color:#2A2520 !important;
  text-decoration:none !important;
  border:1px solid transparent !important;
  border-radius:2px !important;
  transition:background .18s ease, border-color .18s ease, padding-left .18s ease !important;
  text-align:center !important;
}
.mega-cats-grid li a:hover{
  background:#FBF7F0 !important;
  border-color:#E8DCC4 !important;
  color:#000 !important;
  padding-left:12px !important;
}
.mega-cats-viewall{
  display:block !important;
  text-align:center !important;
  margin-top:8px !important;
  padding-top:14px !important;
  border-top:1px solid #f0e8e0 !important;
  font-size:11px !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  color:#B8935E !important;
  text-decoration:none !important;
  font-weight:500 !important;
}
.mega-cats-viewall:hover{ color:#2A2520 !important; letter-spacing:3px !important }

/* If fewer than 4 categories, drop to 2 columns automatically (visual balance) */
@supports (selector(:has(*))) {
  .mega-cats-grid:has(li:nth-child(-n+3):last-child){ grid-template-columns:repeat(2,1fr) !important }
  .mega-cats-grid:has(li:nth-child(-n+2):last-child){ grid-template-columns:1fr !important }
}


/* ---------- C. HERO SLIDER — true <img> based, mobile centered ---------- */
.hero.hero-v2{
  background:#F5EFE5 !important;
  overflow:hidden;
}
.hero.hero-v2 .hero-track{ align-items:stretch }
.hero.hero-v2 .hero-slide{
  min-width:100% !important;
  position:relative !important;
  height:78vh !important;
  min-height:560px !important;
  max-height:780px !important;
  display:flex !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  overflow:hidden !important;
  background:#F5EFE5 !important; /* solid fallback */
}
.hero.hero-v2 .hero-img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center 25% !important; /* show the model + ring on desktop */
  z-index:1 !important;
  display:block !important;
  background:#F5EFE5;
}
.hero.hero-v2 .hero-overlay{
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.18) 100%);
  pointer-events:none;
}
.hero.hero-v2 .hero-overlay-light{
  background:linear-gradient(180deg, rgba(255,255,255,0) 55%, rgba(0,0,0,.10) 100%);
}
.hero.hero-v2 .hero-content{
  position:relative !important;
  z-index:3 !important;
  padding:0 0 70px 70px !important;
  max-width:520px;
}
.hero.hero-v2 .hero-content .btn{
  background:#1F1B17 !important;
  color:#fff !important;
  border:1px solid #1F1B17 !important;
  padding:16px 38px !important;
  font-size:12px !important;
  letter-spacing:2.5px !important;
  box-shadow:0 6px 22px -10px rgba(0,0,0,.35);
}
.hero.hero-v2 .hero-content .btn-light{
  background:#fff !important;
  color:#1F1B17 !important;
  border:1px solid #fff !important;
}
.hero.hero-v2 .hero-content .btn:hover{ background:#000 !important; color:#fff !important; opacity:1 }
.hero.hero-v2 .hero-content .btn-light:hover{ background:#1F1B17 !important; color:#fff !important }

/* Per-slide focal-point tweaks (desktop) */
.hero.hero-v2 .hero-slide-1 .hero-img{ object-position:60% 30% !important } /* ring + hand emphasis */
.hero.hero-v2 .hero-slide-2 .hero-img{ object-position:center 35% !important } /* pendant centered */
.hero.hero-v2 .hero-slide-3 .hero-img{ object-position:center 30% !important }
.hero.hero-v2 .hero-slide-4 .hero-img{ object-position:center 30% !important }

/* Arrows on top of image */
.hero.hero-v2 .hero-arrow{
  z-index:4 !important;
  width:46px !important;height:46px !important;
  background:rgba(255,255,255,.85) !important;
  backdrop-filter:blur(6px);
}
.hero.hero-v2 .hero-arrow:hover{ background:#fff !important }
.hero.hero-v2 .hero-dots{ z-index:4 !important; bottom:24px !important }

/* ----- HERO MOBILE — centered, properly framed ----- */
@media (max-width:768px){
  .hero.hero-v2 .hero-slide{
    height:auto !important;
    min-height:0 !important;
    max-height:none !important;
    aspect-ratio:3/4;     /* portrait frame on mobile */
    align-items:flex-end !important;
  }
  .hero.hero-v2 .hero-img{
    object-position:center center !important;
  }
  /* Per-slide mobile focal tweaks — keep subject centered, not cropped weird */
  .hero.hero-v2 .hero-slide-1 .hero-img{ object-position:55% center !important }
  .hero.hero-v2 .hero-slide-2 .hero-img{ object-position:center center !important }
  .hero.hero-v2 .hero-slide-3 .hero-img{ object-position:center center !important }
  .hero.hero-v2 .hero-slide-4 .hero-img{ object-position:center center !important }

  .hero.hero-v2 .hero-content{
    padding:0 16px 26px !important;
    max-width:100% !important;
    width:100% !important;
    text-align:center !important;
    display:flex; justify-content:center;
  }
  .hero.hero-v2 .hero-content .btn{
    padding:14px 28px !important;
    font-size:11px !important;
    letter-spacing:2px !important;
    width:auto !important;
    min-width:220px;
    text-align:center;
  }
  /* gentler bottom gradient so the button reads clearly */
  .hero.hero-v2 .hero-overlay{
    background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.28) 100%);
  }
  .hero.hero-v2 .hero-overlay-light{
    background:linear-gradient(180deg, rgba(255,255,255,0) 55%, rgba(0,0,0,.22) 100%);
  }
  .hero.hero-v2 .hero-arrow{
    width:36px !important;height:36px !important;
    background:rgba(255,255,255,.7) !important;
  }
  .hero.hero-v2 .hero-prev{ left:8px !important }
  .hero.hero-v2 .hero-next{ right:8px !important }
  .hero.hero-v2 .hero-dots{ bottom:80px !important; gap:6px !important }
  .hero.hero-v2 .hero-dot{ width:6px !important; height:6px !important }
  .hero.hero-v2 .hero-dot.active{ width:22px !important }
}

/* Smaller phones */
@media (max-width:420px){
  .hero.hero-v2 .hero-slide{ aspect-ratio:4/5 }
  .hero.hero-v2 .hero-content .btn{ min-width:200px; font-size:10.5px !important }
}


/* ---------- D. PERF — image rendering hints & layout-shift guards ---------- */
img{
  max-width:100%;
  height:auto;
}
.hero-img,
.product-card img,
.category-card img{
  content-visibility:auto;
  contain-intrinsic-size:600px;
}
/* Stop layout shift on slow-loading hero */
.hero-slide{ background-color:#F5EFE5 }

/* Save bandwidth on far-below-fold sections */
.insta-strip-section,
.tagline-bar,
.footer{ content-visibility:auto; contain-intrinsic-size:800px }

