/*
Theme Name: Sandhya Designer Studio
Theme URI: https://sandhyadesignerstudio.com
Author: Sandhya Designer Studio
Description: A custom original theme for Sandhya Designer Studio — fine jewellery, handcrafted in a blush and rose-gold aesthetic. Built from scratch with an original layout, signature "traced setting" hover motif, and no reused third-party assets.
Version: 1.0.0
Requires PHP: 7.4
Text Domain: sandhya-studio
*/

/* -----------------------------------------------------
   DESIGN TOKENS
----------------------------------------------------- */
:root{
  --bg:            #FDF6F4;
  --cream:         #FFFDF9;
  --blush:         #EFC7C2;
  --blush-soft:    #F6DEDA;
  --rose-gold:     #B14F63;
  --rose-gold-lt:  #D89AA6;
  --gold:          #C9A66B;
  --gold-soft:     #E4CFA3;
  --ink:           #2E2624;
  --ink-soft:      #6E5457;
  --line:          rgba(59,42,46,0.12);

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Jost', 'Segoe UI', sans-serif;
  --font-label:   'Cormorant Garamond', Georgia, serif;

  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 40px;
  --space-5: 64px;
  --space-6: 96px;

  --radius: 2px;
  --container: 1180px;
}

/* -----------------------------------------------------
   RESET / BASE
----------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:300;
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family:inherit; cursor:pointer; }
input,textarea,select{ font-family:inherit; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  margin:0 0 var(--space-2);
  color:var(--ink);
  letter-spacing:0.01em;
}
h1{ font-size:clamp(2rem,3.6vw,3.2rem); line-height:1.12; }
h2{ font-size:clamp(1.7rem,2.6vw,2.3rem); line-height:1.18; }
h3{ font-size:1.4rem; }
p{ margin:0 0 var(--space-2); color:var(--ink-soft); }

.eyebrow{
  font-family:var(--font-label);
  font-style:italic;
  font-size:1.05rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--rose-gold);
  display:inline-block;
  margin-bottom:var(--space-1);
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 clamp(20px, 5vw, 56px) !important;
}

/* visible keyboard focus everywhere */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--rose-gold);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* -----------------------------------------------------
   SIGNATURE MOTIF — the "traced setting"
   A thin rose-gold line that draws itself around a card
   border on hover/focus, like a jeweller tracing a setting.
----------------------------------------------------- */
.setting-frame{ position:relative; }
.setting-frame svg.trace{
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none;
}
.setting-frame svg.trace rect{
  fill:none;
  stroke:var(--rose-gold);
  stroke-width:1.5;
  stroke-dasharray:1200;
  stroke-dashoffset:1200;
  transition:stroke-dashoffset 0.9s ease;
}
.setting-frame:hover svg.trace rect,
.setting-frame:focus-within svg.trace rect{
  stroke-dashoffset:0;
}

/* thin chain-link divider */
.chain-divider{
  display:flex; align-items:center; justify-content:center;
  gap:var(--space-1);
  margin:var(--space-5) 0;
  color:var(--gold);
}
.chain-divider::before,.chain-divider::after{
  content:"";
  height:1px; width:80px;
  background:linear-gradient(90deg,transparent,var(--gold));
}
.chain-divider::after{ background:linear-gradient(90deg,var(--gold),transparent); }

/* -----------------------------------------------------
   HEADER — two-tier: utility bar + category/mega-menu bar
----------------------------------------------------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.header-top{ background:rgba(253,246,244,0.96); backdrop-filter:blur(6px); }
.header-top-inner{
  display:flex; align-items:center; gap:var(--space-4);
  height:84px;
}
.site-logo{ display:flex; align-items:center; gap:10px; max-height:52px; flex:0 0 auto; }
.site-logo img,
.custom-logo-link img,
.site-logo .custom-logo{ height:auto; max-height:48px; width:auto; max-width:220px; object-fit:contain; }
.site-logo .logo-text{ font-family:var(--font-display); font-size:1.3rem; letter-spacing:0.04em; white-space:nowrap; }

.header-search{ flex:1 1 auto; max-width:520px; }
.header-search form.woocommerce-product-search{ display:flex; border:1px solid var(--line); border-radius:30px; overflow:hidden; background:var(--bg); }
.header-search input[type="search"]{ flex:1; border:none; background:none; padding:12px 18px; font-size:0.92rem; }
.header-search button{ border:none; background:var(--rose-gold); color:var(--cream); padding:0 20px; font-size:1rem; }

.header-actions{ display:flex; align-items:center; gap:var(--space-3); flex:0 0 auto; }
.icon-btn{ background:none; border:none; color:var(--ink); font-size:1.15rem; }
.icon-link{
  position:relative;
  display:flex; flex-direction:column; align-items:center; gap:3px;
  color:var(--ink);
}
.icon-link:hover{ color:var(--rose-gold); }
.icon-outline{ width:21px; height:21px; }
.icon-label{
  font-size:0.62rem; letter-spacing:0.05em; text-transform:uppercase;
  color:inherit; font-weight:500;
}
.icon-link .cart-count{ top:-4px; right:-8px; }
.cart-count{
  position:absolute; top:-8px; right:-10px;
  background:var(--rose-gold); color:var(--cream);
  font-family:var(--font-body); font-size:0.65rem;
  width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.nav-toggle{ display:none; background:none; border:none; font-size:1.4rem; }
.nav-close{ display:none; }

.header-nav-bar{ background:var(--rose-gold); position:relative; }
.primary-nav > ul{ display:flex; justify-content:center; gap:var(--space-4); }
.primary-nav .menu-item-top{ position:static; }
.primary-nav .menu-item-top > a{
  display:block; padding:14px 4px;
  font-size:0.82rem; letter-spacing:0.1em; text-transform:uppercase;
  color:#FFFFFF; font-weight:900;
}
.primary-nav .menu-item-top.has-mega > a::after{ content:" \25BE"; font-size:0.65em; }

@media (max-width:900px){
  .header-search{ display:none; }
  .header-nav-bar{ padding:0; }
  .header-nav-bar .container{ padding:0; }
  .primary-nav{ display:none; }
  .nav-toggle{ display:block; }
}

/* -----------------------------------------------------
   MEGA MENU PANEL
----------------------------------------------------- */
.menu-item-top.has-mega .mega-panel{
  display:none;
  position:absolute; left:0; right:0; top:100%;
  background:var(--cream);
  border-top:2px solid var(--gold);
  box-shadow:0 20px 40px rgba(59,42,46,0.12);
  z-index:40;
}
.menu-item-top.has-mega:hover .mega-panel,
.menu-item-top.has-mega:focus-within .mega-panel{ display:block; }
.mega-panel-inner{
  display:flex; gap:var(--space-5); padding:var(--space-4) var(--space-3);
  align-items:flex-start;
}
.mega-panel-links{
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-2) var(--space-4);
  flex:1;
}
.mega-panel-links li a{
  font-size:0.85rem; color:var(--ink-soft); padding:6px 0; display:block;
}
.mega-panel-links li a:hover{ color:var(--rose-gold); }
.mega-panel-feature{
  flex:0 0 220px; display:block; position:relative; overflow:hidden;
}
.mega-panel-feature img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.mega-panel-feature span{
  position:absolute; bottom:0; left:0; right:0; padding:12px;
  background:linear-gradient(0deg,rgba(59,42,46,0.75),transparent);
  color:var(--cream); font-size:0.78rem; letter-spacing:0.06em; text-transform:uppercase;
}

/* -----------------------------------------------------
   BUTTONS
----------------------------------------------------- */
.btn{
  display:inline-block;
  padding:14px 34px;
  border:1px solid var(--ink);
  font-size:0.78rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  background:transparent;
  color:var(--ink);
  transition:background 0.35s ease,color 0.35s ease,border-color 0.35s ease;
}
.btn:hover,.btn:focus-visible{ background:var(--ink); color:var(--cream); }
.btn-gold{
  border-color:var(--rose-gold);
  color:var(--rose-gold);
}
.btn-gold:hover,.btn-gold:focus-visible{ background:var(--rose-gold); color:var(--cream); border-color:var(--rose-gold); }
.btn-solid{ background:var(--ink); color:var(--cream); }
.btn-solid:hover{ background:var(--rose-gold); border-color:var(--rose-gold); }

/* -----------------------------------------------------
   HERO
----------------------------------------------------- */
.hero{
  position:relative;
  min-height:88vh;
  display:flex; align-items:center;
  background:linear-gradient(180deg,var(--blush-soft) 0%,var(--bg) 100%);
  overflow:hidden;
  text-align:center;
}
.hero .container{ position:relative; z-index:2; }
.hero-eyebrow{
  font-family:var(--font-label);
  font-style:italic;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--rose-gold);
  font-size:1.1rem;
}
.hero h1{ max-width:820px; margin:var(--space-2) auto; }
.hero p.lede{ max-width:520px; margin:0 auto var(--space-3); font-size:1.05rem; }
.hero-cta{ display:flex; gap:var(--space-2); justify-content:center; flex-wrap:wrap; }
.hero-ornament{
  position:absolute; inset:0; z-index:1; opacity:0.5;
  background:
    radial-gradient(circle at 12% 20%, var(--gold-soft) 0, transparent 40%),
    radial-gradient(circle at 90% 75%, var(--rose-gold-lt) 0, transparent 45%);
}

/* -----------------------------------------------------
   HOMEPAGE SLIDER (up to 5 slides, Customizer-managed)
----------------------------------------------------- */
.hero-slider{ position:relative; min-height:88vh; overflow:hidden; }
.hero-slide{
  position:absolute; inset:0; z-index:1;
  display:flex; align-items:center; justify-content:center; text-align:center;
  opacity:0; visibility:hidden; transition:opacity 0.8s ease;
  background-size:cover; background-position:center;
}
.hero-slide::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(59,42,46,0.15),rgba(59,42,46,0.45));
}
.hero-slide.is-active{ opacity:1; visibility:visible; z-index:2; }
.hero-slide .slide-content{ position:relative; z-index:2; color:var(--cream); max-width:720px; padding:0 var(--space-3); }
.hero-slide .slide-content .eyebrow{ color:var(--gold-soft); }
.hero-slide .slide-content h1{ color:var(--cream); }
.hero-slider-dots{
  position:absolute; bottom:28px; left:0; right:0; z-index:3;
  display:flex; justify-content:center; gap:10px;
}
.hero-slider-dots button{
  width:9px; height:9px; border-radius:50%; border:1px solid var(--cream);
  background:transparent; padding:0;
}
.hero-slider-dots button.is-active{ background:var(--cream); }
.hero-slider-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:3;
  width:44px; height:44px; border-radius:50%; border:1px solid rgba(255,253,249,0.6);
  background:rgba(59,42,46,0.25); color:var(--cream); font-size:1.1rem;
}
.hero-slider-arrow.prev{ left:24px; }
.hero-slider-arrow.next{ right:24px; }
@media (max-width:760px){ .hero-slider-arrow{ display:none; } }

/* -----------------------------------------------------
   SECTION SPACING
----------------------------------------------------- */
.section{ padding:var(--space-6) 0; }
.section-head{ text-align:center; max-width:640px; margin:0 auto var(--space-5); }

/* -----------------------------------------------------
   COLLECTIONS GRID / CARDS
----------------------------------------------------- */
.grid{ display:grid; gap:var(--space-3); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .grid-3,.grid-4{ grid-template-columns:1fr;} }

.card{
  position:relative;
  background:var(--cream);
  padding:2px;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 2px 10px rgba(59,42,46,0.06);
  transition:box-shadow 0.3s ease, transform 0.3s ease;
}
.card:hover{ box-shadow:0 14px 30px rgba(59,42,46,0.14); transform:translateY(-3px); }
.card-media{
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--blush-soft);
}
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease; }
.card:hover .card-media img{ transform:scale(1.06); }
.card-body{ padding:var(--space-2) var(--space-1) 0; text-align:center; }
.card-body .cat{
  font-family:var(--font-label); font-style:italic; color:var(--rose-gold);
  font-size:0.95rem; letter-spacing:0.06em;
}
.card-body h3{ margin:4px 0 0; font-size:1.2rem; }

/* -----------------------------------------------------
   SPLIT / ABOUT TEASER
----------------------------------------------------- */
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:var(--space-5); align-items:center;
}
@media (max-width:860px){ .split{ grid-template-columns:1fr; gap:var(--space-3);} }
.split img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.split.reverse{ direction:rtl; }
.split.reverse > *{ direction:ltr; }

/* -----------------------------------------------------
   TESTIMONIALS
----------------------------------------------------- */
.testimonial{
  max-width:680px; margin:0 auto; text-align:center;
}
.testimonial blockquote{
  font-family:var(--font-display); font-size:1.4rem; font-style:italic;
  color:var(--ink); margin:0 0 var(--space-2); line-height:1.5;
}
.testimonial cite{
  font-family:var(--font-body); font-style:normal; font-size:0.85rem;
  letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-soft);
}

/* -----------------------------------------------------
   INSTAGRAM / STRIP GALLERY
----------------------------------------------------- */
.strip{
  display:grid; grid-template-columns:repeat(6,1fr); gap:4px;
}
.strip a{ aspect-ratio:1/1; overflow:hidden; display:block; }
.strip img{ width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.strip a:hover img{ transform:scale(1.1); }
@media (max-width:760px){ .strip{ grid-template-columns:repeat(3,1fr);} }

/* -----------------------------------------------------
   NEWSLETTER / FOOTER
----------------------------------------------------- */
.newsletter{
  background:var(--ink); color:var(--cream); text-align:center;
  padding:var(--space-5) 0;
}
.newsletter h2{ color:var(--cream); }
.newsletter p{ color:rgba(255,253,249,0.7); }
.newsletter-form{
  display:flex; max-width:420px; margin:var(--space-3) auto 0;
  border-bottom:1px solid rgba(255,253,249,0.4);
}
.newsletter-form input{
  flex:1; background:none; border:none; color:var(--cream);
  padding:12px 4px; font-size:0.95rem;
}
.newsletter-form input::placeholder{ color:rgba(255,253,249,0.5); }
.newsletter-form button{
  background:none; border:none; color:var(--gold-soft);
  letter-spacing:0.14em; text-transform:uppercase; font-size:0.78rem;
}

.site-footer{ background:var(--cream); border-top:1px solid var(--line); padding:var(--space-5) 0 var(--space-3); }
.footer-grid{
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:var(--space-4);
  margin-bottom:var(--space-4);
}
@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
.footer-grid h4{
  font-family:var(--font-body); font-size:0.78rem; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--rose-gold); margin-bottom:var(--space-2);
}
.footer-grid ul li{ margin-bottom:8px; }
.footer-grid ul a:hover{ color:var(--rose-gold); }
.footer-bottom{
  border-top:1px solid var(--line); padding-top:var(--space-3);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px;
  font-size:0.78rem; color:var(--ink-soft);
}

/* -----------------------------------------------------
   PAGE HEADER (interior pages)
----------------------------------------------------- */
.page-header{
  text-align:center; padding:var(--space-5) 0 var(--space-4);
  border-bottom:1px solid var(--line);
  background:var(--blush-soft);
}
.page-header .eyebrow{ margin-bottom:0; }

/* -----------------------------------------------------
   CONTACT PAGE
----------------------------------------------------- */
.contact-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-5); }
@media (max-width:860px){ .contact-wrap{ grid-template-columns:1fr; } }
.form-row{ margin-bottom:var(--space-2); }
.form-row label{
  display:block; font-size:0.78rem; letter-spacing:0.1em; text-transform:uppercase;
  margin-bottom:6px; color:var(--ink-soft);
}
.form-row input,.form-row textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line);
  background:var(--cream); border-radius:var(--radius); font-size:0.95rem;
}
.contact-info li{ margin-bottom:var(--space-2); }
.contact-info .label{ font-family:var(--font-label); font-style:italic; color:var(--rose-gold); display:block; }

/* -----------------------------------------------------
   BLOG
----------------------------------------------------- */
.post-list{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); }
@media (max-width:760px){ .post-list{ grid-template-columns:1fr; } }
.post-card .card-media{ aspect-ratio:16/10; }
.post-card .meta{ font-size:0.78rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--rose-gold); margin:var(--space-2) 0 4px; }
.single-content{ max-width:720px; margin:0 auto; }
.single-content img{ margin:var(--space-3) 0; }

/* -----------------------------------------------------
   404
----------------------------------------------------- */
.error-404{ text-align:center; padding:var(--space-6) 0; }

/* -----------------------------------------------------
   SHOP BY CATEGORY (home page)
----------------------------------------------------- */
.category-tile{ position:relative; text-align:center; }
.category-tile .card-media{ aspect-ratio:1/1; border-radius:50%; overflow:hidden; }
.category-tile h3{ margin-top:var(--space-2); font-size:1.05rem; }

/* -----------------------------------------------------
   GLOBAL WOOCOMMERCE FALLBACK
   Targets WooCommerce's own default classes directly
   (not nested under .woo-wrap) so styling still applies
   even if a product grid renders via a shortcode/widget
   outside our theme's page template.
----------------------------------------------------- */
ul.products{
  display:grid !important; grid-template-columns:repeat(4,1fr) !important; gap:24px !important;
  list-style:none !important; margin:0 0 40px !important; padding:0 !important;
}
@media (max-width:900px){ ul.products{ grid-template-columns:repeat(2,1fr) !important; } }
@media (max-width:560px){ ul.products{ grid-template-columns:1fr !important; } }

ul.products li.product{
  background:#FFFDF9 !important; position:relative !important; list-style:none !important;
  border-radius:14px !important; overflow:hidden !important;
  box-shadow:0 2px 10px rgba(59,42,46,0.06) !important;
  border:1px solid rgba(59,42,46,0.12) !important;
  padding:0 !important;
  transition:box-shadow 0.3s ease, transform 0.3s ease;
}
ul.products li.product:hover{ box-shadow:0 14px 30px rgba(59,42,46,0.14) !important; transform:translateY(-3px); }
ul.products li.product a{ text-decoration:none !important; }
ul.products li.product img{
  aspect-ratio:4/5 !important; object-fit:cover !important; width:100% !important; height:auto !important;
  border-radius:0 !important;
}
ul.products li.product .woocommerce-loop-product__title{
  font-family:'Playfair Display',Georgia,serif !important; font-size:1.1rem !important; font-weight:600 !important;
  margin:16px 0 4px !important; text-align:center !important; color:#2E2624 !important; padding:0 10px !important;
}
ul.products li.product .price{
  display:block !important; text-align:center !important; color:#B14F63 !important;
  font-family:'Jost','Segoe UI',sans-serif !important; font-size:0.95rem !important; margin-bottom:16px !important; font-weight:500 !important;
}
ul.products li.product .price ins{ text-decoration:none !important; color:#B14F63 !important; }
ul.products li.product .price .woocommerce-Price-amount{ color:inherit !important; }
ul.products li.product .price del{ color:#6E5457 !important; opacity:0.6 !important; margin-right:6px !important; }
ul.products li.product .button,
ul.products li.product .add_to_cart_button{
  display:block !important; margin:0 auto 16px !important; width:calc(100% - 24px) !important;
  text-align:center !important; padding:12px !important; border:1px solid #2E2624 !important; border-radius:30px !important;
  background:transparent !important; color:#2E2624 !important;
  text-transform:uppercase !important; font-size:0.72rem !important; letter-spacing:0.12em !important;
  transition:background 0.3s ease,color 0.3s ease;
}
ul.products li.product .button:hover{ background:#2E2624 !important; color:#FFFDF9 !important; }
ul.products li.product .onsale,
.onsale{
  position:absolute !important; top:12px !important; left:12px !important; right:auto !important; z-index:2 !important;
  background:#B14F63 !important; color:#FFFDF9 !important; font-size:0.68rem !important;
  text-transform:uppercase !important; letter-spacing:0.08em !important; padding:4px 10px !important; border-radius:20px !important;
  font-weight:500 !important; min-height:0 !important; min-width:0 !important; line-height:1.6 !important; margin:0 !important;
}
.price ins{ text-decoration:none !important; color:#B14F63 !important; }
.price del{ color:#6E5457 !important; opacity:0.6 !important; }

/* -----------------------------------------------------
   SHOP SIDEBAR (Price Filter, Categories, Special Offers,
   Recently Viewed) — Appearance > Widgets > Shop Sidebar
----------------------------------------------------- */
.shop-layout{
  display:grid; grid-template-columns:260px minmax(0,1fr); gap:var(--space-5);
  align-items:start;
}
@media (max-width:900px){ .shop-layout{ grid-template-columns:1fr; } }

/* the product grid is wrapped a second time by WooCommerce's own hooks —
   neutralize its padding/width here since the outer .shop-layout already
   provides page-level spacing */
.shop-layout .woo-wrap{
  padding-left:0 !important; padding-right:0 !important;
  max-width:none !important; margin:0 !important;
}

.shop-sidebar{ position:sticky; top:104px; }
@media (max-width:900px){ .shop-sidebar{ position:static; margin-bottom:var(--space-4); } }

.shop-widget{
  background:var(--cream); border:1px solid var(--line); border-radius:12px;
  padding:var(--space-3); margin-bottom:var(--space-3);
}
.shop-widget-title{
  font-family:var(--font-body); font-size:0.78rem; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--rose-gold); margin-bottom:var(--space-2); font-weight:600;
}

/* Price Filter widget */
.shop-widget .price_slider{ margin-bottom:16px; }
.shop-widget .price_slider_amount{ display:flex; align-items:center; justify-content:space-between; font-size:0.82rem; color:var(--ink-soft); }
.shop-widget .price_slider_amount .button{
  background:var(--ink); color:var(--cream); border:none; padding:8px 16px;
  text-transform:uppercase; font-size:0.68rem; letter-spacing:0.08em; border-radius:20px;
}
.shop-widget .ui-slider{ position:relative; height:4px; background:var(--line); border-radius:4px; margin:14px 0; }
.shop-widget .ui-slider .ui-slider-range{ position:absolute; height:4px; background:var(--rose-gold); border-radius:4px; }
.shop-widget .ui-slider .ui-slider-handle{
  position:absolute; top:-6px; width:16px; height:16px; border-radius:50%;
  background:var(--cream); border:2px solid var(--rose-gold); cursor:pointer; outline:none;
}

/* Product Categories widget */
.shop-widget.woocommerce.widget_product_categories ul,
.shop-widget ul.product-categories{ list-style:none; margin:0; padding:0; }
.shop-widget ul.product-categories li{ margin-bottom:6px; }
.shop-widget ul.product-categories a{ font-size:0.86rem; color:var(--ink-soft); }
.shop-widget ul.product-categories a:hover{ color:var(--rose-gold); }
.shop-widget ul.product-categories .count{ color:var(--ink-soft); opacity:0.6; font-size:0.78rem; margin-left:4px; }
.shop-widget ul.product-categories .current-cat > a{ color:var(--rose-gold); font-weight:600; }

/* Products widget (Special Offers) + Recently Viewed */
.shop-widget ul.product_list_widget{ list-style:none; margin:0; padding:0; }
.shop-widget ul.product_list_widget li{
  display:flex; gap:10px; align-items:flex-start; margin-bottom:14px;
  padding-bottom:14px; border-bottom:1px solid var(--line);
}
.shop-widget ul.product_list_widget li:last-child{ border-bottom:none; margin-bottom:0; padding-bottom:0; }
.shop-widget ul.product_list_widget img{ width:56px; height:56px; object-fit:cover; border-radius:8px; flex-shrink:0; }
.shop-widget ul.product_list_widget a{ font-size:0.85rem; color:var(--ink); line-height:1.4; }
.shop-widget ul.product_list_widget a:hover{ color:var(--rose-gold); }
.shop-widget ul.product_list_widget .woocommerce-Price-amount{ color:var(--rose-gold); font-size:0.82rem; display:block; margin-top:2px; }
.shop-widget ul.product_list_widget del .woocommerce-Price-amount{ color:var(--ink-soft); opacity:0.6; }
.shop-widget ul.product_list_widget .reviewer{ display:none; }

/* the product grid within the sidebar layout drops to 3 columns to fit */
.shop-main .woo-wrap ul.products{ grid-template-columns:repeat(3,1fr) !important; }
@media (max-width:1100px){ .shop-main .woo-wrap ul.products{ grid-template-columns:repeat(2,1fr) !important; } }
@media (max-width:560px){ .shop-main .woo-wrap ul.products{ grid-template-columns:1fr !important; } }

/* -----------------------------------------------------
   WOOCOMMERCE — SHOP / PRODUCT GRID
----------------------------------------------------- */
.woo-section{ padding-top:var(--space-5); }
.woo-wrap{ padding-left:clamp(20px,5vw,56px) !important; padding-right:clamp(20px,5vw,56px) !important; box-sizing:border-box; }
.woo-wrap ul.products{
  display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-3);
  list-style:none; margin:0 0 var(--space-5); padding:0;
}
@media (max-width:900px){ .woo-wrap ul.products{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .woo-wrap ul.products{ grid-template-columns:1fr;} }

.woo-wrap ul.products li.product{
  background:var(--cream); position:relative; list-style:none;
  border-radius:14px; overflow:hidden;
  box-shadow:0 2px 10px rgba(59,42,46,0.06);
  border:1px solid var(--line);
  transition:box-shadow 0.3s ease, transform 0.3s ease;
}
.woo-wrap ul.products li.product:hover{
  box-shadow:0 14px 30px rgba(59,42,46,0.14);
  transform:translateY(-3px);
}
.woo-wrap ul.products li.product a img{
  aspect-ratio:4/5; object-fit:cover; width:100%;
  transition:transform 0.8s ease;
}
.woo-wrap ul.products li.product:hover a img{ transform:scale(1.06); }
.woo-wrap ul.products li.product .woocommerce-loop-product__title{
  font-family:var(--font-display); font-size:1.1rem; font-weight:600;
  margin:var(--space-2) 0 4px; text-align:center; color:var(--ink); padding:0 10px;
}
.woo-wrap ul.products li.product .price{
  display:block; text-align:center; color:var(--rose-gold) !important;
  font-family:var(--font-body); font-size:0.95rem; margin-bottom:var(--space-2); font-weight:500;
}
.woo-wrap ul.products li.product .price ins{ text-decoration:none; color:var(--rose-gold) !important; }
.woo-wrap ul.products li.product .price .woocommerce-Price-amount{ color:inherit !important; }
.woo-wrap ul.products li.product .price del{ color:var(--ink-soft) !important; opacity:0.6; margin-right:6px; }
.woo-wrap ul.products li.product .button{
  display:block; margin:0 auto var(--space-2); width:calc(100% - 24px);
  text-align:center; padding:12px; border:1px solid var(--ink); border-radius:30px;
  background:transparent; text-transform:uppercase; font-size:0.72rem; letter-spacing:0.12em;
  transition:background 0.3s ease,color 0.3s ease;
}
.woo-wrap ul.products li.product .button:hover{ background:var(--ink); color:var(--cream); }
.woo-wrap ul.products li.product .onsale{
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--rose-gold) !important; color:var(--cream) !important; font-size:0.68rem;
  text-transform:uppercase; letter-spacing:0.08em; padding:4px 10px; border-radius:20px;
  font-weight:500; min-height:0 !important; min-width:0 !important; line-height:1.6 !important;
}
.woo-wrap .woocommerce-ordering,
.woo-wrap .woocommerce-result-count{
  font-family:var(--font-body); font-size:0.85rem; color:var(--ink-soft); margin-bottom:var(--space-3);
}
.woo-wrap nav.woocommerce-pagination{ text-align:center; margin-top:var(--space-4); }
.woo-wrap nav.woocommerce-pagination ul{ display:inline-flex; gap:6px; }
.woo-wrap nav.woocommerce-pagination a,
.woo-wrap nav.woocommerce-pagination span{
  display:inline-block; padding:8px 14px; border:1px solid var(--line);
}

/* -----------------------------------------------------
   BREADCRUMB (single product)
----------------------------------------------------- */
.sds-breadcrumb{
  font-size:0.78rem; color:var(--ink-soft); letter-spacing:0.02em;
  margin-bottom:var(--space-3);
}
.sds-breadcrumb a{ color:var(--ink-soft); }
.sds-breadcrumb a:hover{ color:var(--rose-gold); }
.sds-breadcrumb .sep{ margin:0 8px; opacity:0.5; }

/* -----------------------------------------------------
   WOOCOMMERCE — SINGLE PRODUCT (clean two-column layout)
----------------------------------------------------- */
.woo-wrap div.product{
  display:grid !important; grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
  gap:var(--space-5); align-items:start;
  position:relative;
}
@media (max-width:860px){ .woo-wrap div.product{ grid-template-columns:1fr !important; } }

.woo-wrap div.product .images{ position:relative; float:none !important; width:auto !important; }
.woo-wrap div.product .woocommerce-product-gallery{
  position:relative;
}

.woo-wrap div.product .woocommerce-product-gallery__wrapper{
  display:flex; overflow:hidden; margin:0; padding:0; list-style:none;
  position:relative; background:var(--blush-soft);
}
.woo-wrap div.product .woocommerce-product-gallery__wrapper .woocommerce-product-gallery__image{
  flex:0 0 100%; margin:0; max-width:100%;
}
.woo-wrap div.product .woocommerce-product-gallery__image img,
.woo-wrap div.product .woocommerce-product-gallery img{
  width:100%; aspect-ratio:4/5; object-fit:cover; display:block;
}
.woo-wrap div.product .flex-control-thumbs{ display:flex; gap:8px; margin-top:10px; list-style:none; padding:0; }
.woo-wrap div.product .flex-control-thumbs li{ width:64px; margin:0; }
.woo-wrap div.product .flex-control-thumbs img{ aspect-ratio:1/1; opacity:0.6; border:1px solid var(--line); cursor:pointer; }
.woo-wrap div.product .flex-control-thumbs img.flex-active{ opacity:1; border-color:var(--rose-gold); }

/* the zoom-search icon WooCommerce injects has no theme styling of its own — hide it */
.woo-wrap div.product .woocommerce-product-gallery__trigger{ display:none !important; }

.woo-wrap div.product .onsale{
  position:absolute !important; top:16px !important; left:16px !important; right:auto !important; z-index:5;
  background:var(--rose-gold) !important; color:var(--cream) !important;
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.08em;
  padding:6px 14px !important; border-radius:20px; min-height:0 !important; min-width:0 !important;
  margin:0 !important; line-height:1.6 !important;
}

.woo-wrap .product .summary{ padding-top:0; float:none !important; width:auto !important; }
.woo-wrap .product .summary > .woocommerce-product-details__short-description{ order:5; }
.woo-wrap .product h1.product_title{ margin-bottom:10px; font-size:clamp(1.5rem,2.4vw,2.1rem); line-height:1.25; }

.woo-wrap .product .price{
  color:var(--rose-gold) !important; font-size:1.5rem; font-family:var(--font-display);
  margin:var(--space-1) 0 var(--space-2); font-weight:600;
}
.woo-wrap .product .price ins{ text-decoration:none; color:var(--rose-gold) !important; }
.woo-wrap .product .price del{ color:var(--ink-soft) !important; opacity:0.55; font-size:0.85em; margin-right:8px; }
.woo-wrap .product .price .woocommerce-Price-amount{ color:inherit !important; }

.woo-wrap .product .stock{
  font-size:0.8rem; letter-spacing:0.04em; text-transform:uppercase;
  color:var(--rose-gold); margin-bottom:var(--space-2);
}
.woo-wrap .product .stock.out-of-stock{ color:#a33; }

.woo-wrap .product .cart{ margin:var(--space-3) 0; display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.woo-wrap .product .quantity input{ width:64px; padding:12px 10px; border:1px solid var(--line); text-align:center; background:var(--cream); }

.woo-wrap .product form.cart button.single_add_to_cart_button.single_add_to_cart_button,
.woo-wrap .product form.cart a.single_add_to_cart_button.single_add_to_cart_button,
.woo-wrap .product form.cart .button.single_add_to_cart_button.single_add_to_cart_button,
body.single-product button.single_add_to_cart_button.single_add_to_cart_button{
  padding:16px 40px !important; background:var(--ink) !important; color:var(--cream) !important;
  border:1px solid var(--ink) !important; border-radius:2px !important;
  text-transform:uppercase !important; letter-spacing:0.14em !important; font-size:0.78rem !important;
  font-weight:500 !important; box-shadow:none !important; text-shadow:none !important;
  font-family:var(--font-body) !important;
}
.woo-wrap .product form.cart button.single_add_to_cart_button.single_add_to_cart_button:hover,
body.single-product button.single_add_to_cart_button.single_add_to_cart_button:hover{
  background:var(--rose-gold) !important; border-color:var(--rose-gold) !important;
}

.woo-wrap .product .woocommerce-product-details__short-description{ color:var(--ink-soft); margin:var(--space-2) 0; }

/* category pills instead of default plain text list */
.woo-wrap .product .product_meta{
  display:flex; flex-wrap:wrap; gap:8px; margin-top:var(--space-3); font-size:0; /* hide default label text */
}
.woo-wrap .product .product_meta > span{ display:none; } /* hide SKU line by default, keep categories */
.woo-wrap .product .posted_in{ display:flex !important; flex-wrap:wrap; gap:8px; font-size:0.78rem; }
.woo-wrap .product .posted_in a{
  border:1px solid var(--line); border-radius:20px; padding:5px 14px;
  color:var(--ink-soft); text-transform:uppercase; letter-spacing:0.05em; font-size:0.72rem;
}
.woo-wrap .product .posted_in a:hover{ border-color:var(--rose-gold); color:var(--rose-gold); }

/* sidebar info accordion (Care, Size & Fit, Style, Shipping, Authenticity) */
.sds-info-accordion{ margin-top:var(--space-2); border-top:1px solid var(--line); }
.sds-accordion-item{ border-bottom:1px solid var(--line); }
.sds-accordion-trigger{
  display:flex; align-items:center; gap:12px; padding:15px 2px;
  cursor:pointer; list-style:none;
}
.sds-accordion-trigger::-webkit-details-marker{ display:none; }
.sds-accordion-trigger::marker{ content:""; }
.sds-accordion-trigger .icon-outline{ width:19px; height:19px; color:var(--rose-gold); flex-shrink:0; }
.sds-accordion-label{
  flex:1; font-size:0.82rem; text-transform:uppercase; letter-spacing:0.06em;
  font-weight:500; color:var(--ink);
}
.sds-accordion-chevron{
  color:var(--ink-soft); font-size:1.1rem; transform:rotate(90deg);
  transition:transform 0.25s ease; line-height:1;
}
.sds-accordion-item[open] .sds-accordion-chevron{ transform:rotate(-90deg); }
.sds-accordion-panel{
  padding:0 2px var(--space-2) 32px; color:var(--ink-soft);
  font-size:0.88rem; line-height:1.75;
}
.sds-accordion-panel p{ margin-bottom:10px; }
.sds-accordion-panel p:last-child{ margin-bottom:0; }

/* trust badges row */
.sds-trust-badges{
  display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-2);
  margin:var(--space-4) 0; padding:var(--space-3) 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
@media (max-width:560px){ .sds-trust-badges{ grid-template-columns:repeat(2,1fr); } }
.sds-trust-badge{ text-align:center; }
.sds-trust-badge .icon-outline{ width:26px; height:26px; color:var(--rose-gold); margin-bottom:6px; }
.sds-trust-badge span{ display:block; font-size:0.68rem; letter-spacing:0.03em; text-transform:uppercase; color:var(--ink-soft); line-height:1.3; }

/* -----------------------------------------------------
   WOOCOMMERCE — PRODUCT TABS (modern pill/segmented style)
----------------------------------------------------- */
.woo-wrap .woocommerce-tabs{ margin-top:var(--space-6); }
.woo-wrap .woocommerce-tabs ul.tabs{
  display:flex; flex-wrap:wrap; gap:8px;
  background:var(--blush-soft);
  border:none; border-radius:40px;
  margin:0 0 var(--space-4); padding:6px; list-style:none;
  width:fit-content; max-width:100%;
}
.woo-wrap .woocommerce-tabs ul.tabs li{
  margin:0; padding:0; border:none;
}
.woo-wrap .woocommerce-tabs ul.tabs li a{
  display:block; padding:10px 22px;
  text-transform:uppercase; font-size:0.72rem; letter-spacing:0.08em; font-weight:500;
  color:var(--ink-soft); border-radius:30px; transition:background 0.25s ease,color 0.25s ease;
  white-space:nowrap;
}
.woo-wrap .woocommerce-tabs ul.tabs li a:hover{ color:var(--rose-gold); }
.woo-wrap .woocommerce-tabs ul.tabs li.active a{
  background:var(--ink); color:var(--cream) !important;
}
.woo-wrap .woocommerce-tabs .panel{
  max-width:760px; color:var(--ink-soft); line-height:1.85; font-size:0.98rem;
  animation:sdsFadeIn 0.35s ease;
}
.woo-wrap .woocommerce-tabs .panel h2{ display:none; } /* default "Description" H2 redundant with tab label */
.woo-wrap .sds-tab-content p{ margin-bottom:14px; }
@keyframes sdsFadeIn{ from{ opacity:0; transform:translateY(4px);} to{ opacity:1; transform:translateY(0);} }
.woo-wrap .sds-size-chart-table{ width:100%; border-collapse:collapse; margin-top:var(--space-2); }
.woo-wrap .sds-size-chart-table th,
.woo-wrap .sds-size-chart-table td{ padding:10px 14px; border:1px solid var(--line); font-size:0.88rem; text-align:left; }
.woo-wrap .sds-size-chart-table th{ background:var(--blush-soft); text-transform:uppercase; font-size:0.72rem; letter-spacing:0.06em; }

/* -----------------------------------------------------
   RELATED PRODUCTS
----------------------------------------------------- */
.woo-wrap .related.products{ margin-top:var(--space-6); padding-top:var(--space-5); border-top:1px solid var(--line); }
.woo-wrap .related.products > h2{
  font-family:var(--font-display); text-align:center; margin-bottom:var(--space-4);
  font-size:clamp(1.6rem,3vw,2.1rem);
}

/* wishlist heart button on product cards */
.wishlist-btn{
  position:absolute; top:12px; right:12px; z-index:2;
  width:34px; height:34px; border-radius:50%; background:var(--cream);
  border:1px solid var(--line); font-size:1rem; color:var(--ink);
  display:flex; align-items:center; justify-content:center;
}
.wishlist-btn.is-active{ color:var(--rose-gold); border-color:var(--rose-gold); }

/* -----------------------------------------------------
   WOOCOMMERCE — CART / CHECKOUT
----------------------------------------------------- */
.woo-wrap table.shop_table{ width:100%; border-collapse:collapse; margin-bottom:var(--space-4); }
.woo-wrap table.shop_table th{
  text-align:left; text-transform:uppercase; font-size:0.75rem; letter-spacing:0.08em;
  color:var(--ink-soft); padding:12px; border-bottom:1px solid var(--line);
}
.woo-wrap table.shop_table td{ padding:16px 12px; border-bottom:1px solid var(--line); }
.woo-wrap .product-thumbnail img{ width:80px; }
.woo-wrap .cart-collaterals{ max-width:420px; margin-left:auto; }
.woo-wrap .cart_totals table{ width:100%; }
.woo-wrap .wc-proceed-to-checkout a{
  display:block; text-align:center; padding:16px; background:var(--ink); color:var(--cream);
  text-transform:uppercase; letter-spacing:0.12em; font-size:0.8rem; margin-top:var(--space-2);
}
.woo-wrap .wc-proceed-to-checkout a:hover{ background:var(--rose-gold); }
.woo-wrap #payment .place-order button{
  padding:16px 34px; background:var(--ink); color:var(--cream); border:none;
  text-transform:uppercase; letter-spacing:0.12em; font-size:0.8rem;
}
.woo-wrap .woocommerce-checkout input[type="text"],
.woo-wrap .woocommerce-checkout input[type="email"],
.woo-wrap .woocommerce-checkout input[type="tel"],
.woo-wrap .woocommerce-checkout select,
.woo-wrap .woocommerce-checkout textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line); background:var(--cream); margin-bottom:var(--space-1);
}

/* -----------------------------------------------------
   WOOCOMMERCE — MY ACCOUNT
----------------------------------------------------- */
.woo-wrap .woocommerce-MyAccount-navigation ul{ display:flex; flex-wrap:wrap; gap:var(--space-2); margin-bottom:var(--space-4); border-bottom:1px solid var(--line); padding-bottom:var(--space-2); }
.woo-wrap .woocommerce-MyAccount-navigation a{ text-transform:uppercase; font-size:0.78rem; letter-spacing:0.08em; }
.woo-wrap .woocommerce-MyAccount-navigation .is-active a{ color:var(--rose-gold); }

/* -----------------------------------------------------
   PRODUCT REEL SLIDER (home page)
   Horizontal, swipeable, scroll-snap carousel — no JS
   library required, native touch scrolling on mobile.
----------------------------------------------------- */
.reel-wrap{ position:relative; }
.reel{
  display:flex;
  gap:var(--space-2);
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 4px 20px;
  scrollbar-width:none;
}
.reel::-webkit-scrollbar{ display:none; }
.reel-card{
  scroll-snap-align:start;
  flex:0 0 auto;
  width:260px;
  position:relative;
}
@media (max-width:560px){ .reel-card{ width:68vw; } }
.reel-card .card-media{ aspect-ratio:4/5; }
.reel-card .badge{
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--ink); color:var(--cream); font-size:0.65rem;
  text-transform:uppercase; letter-spacing:0.08em; padding:4px 10px; border-radius:20px;
}
.reel-nav{
  position:absolute; top:38%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%;
  background:var(--cream); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; z-index:3; cursor:pointer;
}
.reel-nav.prev{ left:-14px; }
.reel-nav.next{ right:-14px; }
@media (max-width:760px){ .reel-nav{ display:none; } }

/* -----------------------------------------------------
   MOBILE APP-STYLE LAYOUT
   Bottom tab bar mimics a native app on small screens;
   generous tap targets, safe-area aware, sticky.
----------------------------------------------------- */
.app-bottom-nav{ display:none; }

@media (max-width:900px){
  body.has-app-nav{ padding-bottom:72px; }

  .app-bottom-nav{
    display:flex;
    position:fixed; left:0; right:0; bottom:0; z-index:60;
    background:var(--cream);
    border-top:1px solid var(--line);
    padding:8px 4px calc(8px + env(safe-area-inset-bottom));
    box-shadow:0 -4px 16px rgba(59,42,46,0.06);
  }
  .app-bottom-nav a{
    flex:1; display:flex; flex-direction:column; align-items:center; gap:4px;
    font-size:0.62rem; text-transform:uppercase; letter-spacing:0.04em;
    color:var(--ink-soft); padding:4px 0; position:relative;
  }
  .app-bottom-nav a .icon-outline{ width:22px; height:22px; color:var(--ink); }
  .app-bottom-nav a.is-active,
  .app-bottom-nav a.is-active .icon-outline{ color:var(--rose-gold); }
  .app-bottom-nav .icon-link .cart-count{ top:-4px; right:6px; }

  /* header tightens up on mobile to feel more like an app top bar */
  .site-header .container{ height:64px; }
  .site-logo{ max-height:38px; }
  .site-logo img,.custom-logo-link img,.site-logo .custom-logo{ max-height:34px; }
  .site-logo .logo-text{ font-size:1.05rem; }
  .header-actions{ gap:var(--space-2); }
  .header-actions .icon-link[aria-label="Wishlist"],
  .header-actions .icon-link[aria-label="Cart"],
  .header-actions .icon-link[aria-label="Account"]{ display:none; } /* live on bottom nav instead */

  .hero{ min-height:78vh; text-align:left; }
  .hero .container{ text-align:left; }
  .hero-cta{ justify-content:flex-start; }
  h1{ font-size:clamp(2rem,8vw,2.6rem); }

  .section{ padding:var(--space-5) 0; }
  .card-body h3{ font-size:1.05rem; }

  /* full-screen slide-in mobile menu */
  .primary-nav.is-open{
    display:block; position:fixed; inset:0; z-index:70;
    background:var(--cream); padding:var(--space-5) var(--space-3);
    overflow-y:auto;
  }
  .primary-nav.is-open > ul{ display:flex; flex-direction:column; gap:var(--space-3); }
  .primary-nav.is-open .menu-item-top > a{ font-size:1.1rem; color:var(--ink) !important; font-weight:600; padding:8px 0; }
  .primary-nav.is-open .mega-panel{
    display:block !important; position:static; box-shadow:none; border-top:none;
    background:none; margin:6px 0 0 var(--space-2);
  }
  .primary-nav.is-open .mega-panel-inner{ flex-direction:column; padding:0; gap:var(--space-2); }
  .primary-nav.is-open .mega-panel-links{ grid-template-columns:1fr; gap:6px; }
  .primary-nav.is-open .mega-panel-links li a{ font-size:0.95rem; }
  .primary-nav.is-open .mega-panel-feature{ display:none; }
  .primary-nav .nav-close{
    display:none;
  }
  .primary-nav.is-open .nav-close{
    display:block;
    position:absolute; top:24px; right:24px; background:none; border:none; font-size:1.6rem;
  }
}

/* -----------------------------------------------------
   FINAL FAILSAFE OVERRIDES
   Placed last on purpose: when a plugin's CSS ties our
   selector on specificity, the later rule in the cascade
   wins, so these guarantee our brand styling always shows.
----------------------------------------------------- */
html body.woocommerce button.single_add_to_cart_button,
html body.woocommerce a.single_add_to_cart_button,
html body.single-product .single_add_to_cart_button{
  background:var(--ink) !important;
  color:var(--cream) !important;
  border-color:var(--ink) !important;
  border-radius:2px !important;
  box-shadow:none !important;
}
html body.woocommerce button.single_add_to_cart_button:hover,
html body.single-product .single_add_to_cart_button:hover{
  background:var(--rose-gold) !important;
  border-color:var(--rose-gold) !important;
}
html body .icon-link svg.icon-outline{ display:inline-block !important; opacity:1 !important; visibility:visible !important; color:inherit; }
