/*
Theme Name: Harvang
Theme URI: https://harvang.com
Author: Tony Marma
Author URI: https://tonymarma.com
Description: Premium WooCommerce theme for digital products, business accounts, and ecommerce services.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.1
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: harvang
Tags: ecommerce, woocommerce, dark-mode, responsive, digital-products, custom-theme
*/

:root {
  --black: #06050a;
  --navy: #0a0812;
  --navy2: #0f0c1a;
  --purple: #7c3aed;
  --purple-light: #a78bfa;
  --purple-deep: #5b21b6;
  --purple-mid: #8b5cf6;
  --neon: #c4b5fd;
  --neon2: #a78bfa;
  --white: #f5f0ff;
  --muted: #7c6f9a;
  --glass: rgba(139,92,246,0.06);
  --glass-border: rgba(139,92,246,0.15);
  --gradient: linear-gradient(135deg, #a78bfa 0%, #7c3aed 50%, #5b21b6 100%);
  --gradient2: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 50%, #6d28d9 100%);
  --gradient-logo: linear-gradient(90deg, #a78bfa 0%, #8b5cf6 30%, #7c3aed 60%, #6d28d9 100%);
  --font-head: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--white);font-family:var(--font-body);overflow-x:hidden;line-height:1.6}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--navy)}
::-webkit-scrollbar-thumb{background:var(--purple);border-radius:2px}

/* ── NAV ── */
nav#site-navigation{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:1000;width:calc(100% - 32px);max-width:1280px;padding:12px 22px;min-height:64px;border-radius:20px;background:rgba(10,10,20,.65);backdrop-filter:blur(14px);border:1px solid rgba(138,92,246,.18);box-shadow:0 10px 40px rgba(0,0,0,.25);display:flex;align-items:center;justify-content:space-between;transition:all .3s}
nav#site-navigation.scrolled{background:rgba(10,10,20,.88);backdrop-filter:blur(24px);border-color:rgba(138,92,246,.28);box-shadow:0 15px 50px rgba(0,0,0,.35);min-height:58px;padding:10px 22px}
.nav-logo{display:flex;align-items:center;font-family:var(--font-body);font-size:1.6rem;font-weight:700;color:var(--white);text-decoration:none;letter-spacing:-.5px}
.nav-logo span{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.custom-logo-link{display:flex;align-items:center;text-decoration:none}
.custom-logo-link img.custom-logo{max-height:50px;width:auto;height:auto;display:block}
.nav-links,.main-navigation ul{display:flex;gap:2.5rem;list-style:none;align-items:center;margin:0;padding:0}
.main-navigation ul li a,.nav-links a{color:var(--muted);text-decoration:none;font-size:1.05rem;font-weight:500;transition:.2s;letter-spacing:.01em;padding:8px 14px;border-radius:12px}
.main-navigation ul li a:hover,.main-navigation ul li.current-menu-item a,.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(138,92,246,.08)}
.nav-right{display:flex;align-items:center;gap:1.2rem}
.nav-cta{background:var(--gradient);border:none;color:#fff!important;padding:.65rem 1.6rem;border-radius:50px;font-family:var(--font-body);font-size:.95rem;font-weight:600;cursor:pointer;transition:.2s;text-decoration:none;display:inline-block;box-shadow:0 0 24px rgba(108,59,255,.35)}
.nav-cta:hover{opacity:.85;transform:translateY(-1px)}
.nav-cart{position:relative;color:var(--muted);text-decoration:none;font-size:1rem;font-weight:500;transition:.2s;display:flex;align-items:center;gap:.4rem}
.nav-cart:hover{color:var(--white)}
.cart-count{background:var(--gradient);color:#fff;border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px;position:relative;z-index:1001;width:36px;height:36px;align-items:center;justify-content:center}
.ham-bar{width:22px;height:2px;background:var(--white);border-radius:2px;transition:transform .3s ease, opacity .2s ease, top .3s ease;display:block;position:absolute}
.ham-bar:nth-child(1){top:10px}
.ham-bar:nth-child(2){top:17px}
.ham-bar:nth-child(3){top:24px}
/* Open state — morphs into × */
.hamburger.is-open .ham-bar:nth-child(1){top:17px;transform:rotate(45deg)}
.hamburger.is-open .ham-bar:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.is-open .ham-bar:nth-child(3){top:17px;transform:rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(5,5,8,.97);backdrop-filter:blur(24px);z-index:1000;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:0;padding:88px 6% 2rem;overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--white);text-decoration:none;font-family:var(--font-body);font-size:1.3rem;font-weight:500;padding:.55rem 0;line-height:1.4;transition:color .2s;display:block}
.mobile-menu a:hover{color:var(--neon)}
.mobile-menu .mobile-menu-divider{width:40px;height:1px;background:var(--glass-border);margin:.6rem 0 .4rem}
.close-btn{display:none}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:160px 5% 32px}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 60% 40%, rgba(124,58,237,.22) 0%, transparent 60%), radial-gradient(ellipse 50% 40% at 15% 75%, rgba(167,139,250,.1) 0%, transparent 55%), radial-gradient(ellipse 40% 30% at 80% 80%, rgba(91,33,182,.12) 0%, transparent 50%)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px}
.hero-content{position:relative;z-index:2;max-width:660px}
.hero-badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--glass);border:1px solid var(--glass-border);padding:.2rem .65rem;border-radius:50px;font-size:.68rem;color:var(--neon);margin-bottom:.45rem;backdrop-filter:blur(10px)}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--neon);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-family:var(--font-head);font-size:clamp(2.4rem,5.5vw,4rem);font-weight:700;line-height:1.12;letter-spacing:-1px;margin-bottom:.35rem}
.hero h1 .grad{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero p{color:var(--muted);font-size:.9rem;max-width:480px;margin-bottom:.65rem;line-height:1.5}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--gradient);border:none;color:#fff;padding:.85rem 2rem;border-radius:50px;font-family:var(--font-body);font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:.25s;box-shadow:0 0 30px rgba(108,59,255,.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 50px rgba(108,59,255,.6);color:#fff}
.btn-outline{background:transparent;border:1px solid var(--glass-border);color:var(--white);padding:.85rem 2rem;border-radius:50px;font-family:var(--font-body);font-size:.95rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:.25s;backdrop-filter:blur(10px)}
.btn-outline:hover{border-color:var(--neon);color:var(--neon);transform:translateY(-2px)}
.trust-badges{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1rem;align-items:center}
.trust-badges span{color:var(--muted);font-size:.8rem;font-weight:500;display:flex;align-items:center;gap:.4rem}
.trust-badges span::before{content:'✓';color:var(--neon);font-weight:700}
.hero-stats{display:flex;gap:1.5rem;margin-top:1.3rem;flex-wrap:wrap}
.hero-stat .num{font-family:var(--font-head);font-size:2.2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-stat .label{font-size:.78rem;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}
.hero-visual{position:absolute;right:4%;top:50%;transform:translateY(-50%);width:42%;max-width:580px;z-index:1}
.hero-mockup{width:100%;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;backdrop-filter:blur(20px);box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 60px rgba(108,59,255,.15)}
.mockup-topbar{display:flex;gap:.5rem;margin-bottom:1rem}
.mockup-dot{width:10px;height:10px;border-radius:50%}
.mockup-dot:nth-child(1){background:#ff5f57}
.mockup-dot:nth-child(2){background:#febc2e}
.mockup-dot:nth-child(3){background:#28c840}
.mockup-chart{background:rgba(108,59,255,.1);border-radius:12px;height:120px;display:flex;align-items:flex-end;gap:6px;padding:.8rem;margin-bottom:.8rem;border:1px solid rgba(108,59,255,.2)}
.chart-bar{flex:1;border-radius:4px 4px 0 0;background:var(--gradient);opacity:.7;transition:.3s}
.chart-bar:hover{opacity:1}
.mockup-metrics{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.metric-card{background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:10px;padding:.6rem .8rem}
.metric-card .m-val{font-family:var(--font-head);font-size:1.3rem;font-weight:700;color:var(--neon)}
.metric-card .m-lbl{font-size:.72rem;color:var(--muted)}
.metric-card .m-up{font-size:.72rem;color:#4ade80;margin-left:.3rem}

/* ── SECTIONS COMMON ── */
section{padding:42px 5%}
.section-label{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--neon);font-weight:600;margin-bottom:.3rem}
.section-title{font-family:var(--font-head);font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-.5px;line-height:1.15;margin-bottom:.35rem}
.section-sub{color:var(--muted);font-size:1rem;max-width:520px;line-height:1.7}
.section-head{margin-bottom:1.5rem}
.center{text-align:center}
.center .section-sub{margin:0 auto}

/* ── WHY CHOOSE ── */
.why{background:var(--navy)}
.benefits-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.benefit-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:.8rem;transition:.3s;position:relative;overflow:hidden}
.benefit-card::before{content:'';position:absolute;inset:0;background:var(--gradient);opacity:0;transition:.3s}
.benefit-card:hover{border-color:rgba(108,59,255,.4);transform:translateY(-4px);box-shadow:0 20px 60px rgba(108,59,255,.15)}
.benefit-card:hover::before{opacity:.05}
.benefit-icon{width:28px;height:28px;border-radius:7px;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:.9rem;margin-bottom:.45rem;position:relative}
.benefit-card h3{font-family:var(--font-head);font-size:.85rem;font-weight:700;margin-bottom:.15rem;position:relative}
.benefit-card p{color:var(--muted);font-size:.85rem;line-height:1.55;position:relative}

/* ── RESULTS ── */
.results{background:var(--black);position:relative;overflow:hidden}
.results::before{content:'';position:absolute;top:-100px;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(108,59,255,.08) 0%,transparent 70%)}
.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}
.result-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:.8rem .6rem;text-align:center;backdrop-filter:blur(10px)}
.result-card .r-num{font-family:var(--font-head);font-size:2.8rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.result-card .r-label{color:var(--muted);font-size:.78rem;margin-top:.3rem;text-transform:uppercase;letter-spacing:.08em}
.case-placeholder{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:1rem;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.9rem}
.case-info h3{font-family:var(--font-head);font-size:1rem;font-weight:700;margin-bottom:.3rem}
.case-info p{color:var(--muted);font-size:.82rem;margin-bottom:.45rem}
.case-tag{display:inline-block;background:rgba(108,59,255,.15);border:1px solid rgba(108,59,255,.3);color:var(--purple-light);padding:.3rem .8rem;border-radius:50px;font-size:.75rem;margin-right:.5rem;margin-bottom:.5rem}
.case-chart-area{background:rgba(0,212,255,.05);border:1px solid rgba(0,212,255,.1);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;justify-content:flex-end;min-height:180px;position:relative;overflow:hidden}
.case-chart-area::after{content:'Revenue Growth →';position:absolute;top:1rem;left:1.5rem;font-size:.75rem;color:var(--neon);opacity:.7}
.mini-bars{display:flex;align-items:flex-end;gap:5px;height:100px}
.mini-bar{flex:1;border-radius:3px 3px 0 0;background:var(--gradient);opacity:.8}

/* ── TESTIMONIALS ── */
.testimonials{background:var(--navy);position:relative}

.testi-wrapper{position:relative;padding:0 80px}

.testi-track-wrap{overflow:hidden}

.testi-track{display:flex;gap:24px;transition:transform .4s cubic-bezier(.25,.1,.25,1);will-change:transform}

.testi-card{flex:0 0 calc((100% - 48px)/3);min-width:0;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:2rem 1.5rem;display:flex;flex-direction:column;transition:transform .3s,border-color .3s}
.testi-card:hover{border-color:rgba(108,59,255,.3);transform:translateY(-4px)}

.testi-card .stars{color:#f59e0b;font-size:1rem;margin-bottom:1rem;letter-spacing:3px;flex-shrink:0}

.testi-card p{color:var(--muted);font-size:.9rem;line-height:1.75;font-style:italic;flex:1;margin-bottom:1.5rem}

.testi-author{display:flex;align-items:center;gap:.75rem;margin-top:auto;flex-shrink:0}
.author-avatar{width:44px;height:44px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}
.author-name{font-weight:700;font-size:.9rem;line-height:1.3}
.author-role{color:var(--muted);font-size:.78rem;line-height:1.3}

/* Navigation buttons — absolute left/right */
.testi-btn{position:absolute;top:35%;transform:translateY(-50%);z-index:2;width:64px;height:64px;border-radius:999px;border:1px solid var(--glass-border);background:var(--glass);color:var(--white);cursor:pointer;font-size:1.4rem;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);transition:all .3s}
.testi-btn-prev{left:0}
.testi-btn-next{right:0}
.testi-btn:hover{transform:translateY(-50%) scale(1.06);border-color:var(--purple);background:rgba(108,59,255,.3);box-shadow:0 0 30px rgba(108,59,255,.4)}

/* Dots pagination */
.testi-dots{display:none;justify-content:center;gap:10px;margin-top:24px}
.testi-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;transition:background .3s,transform .3s;padding:0}
.testi-dot.active{background:var(--purple);transform:scale(1.3)}
.testi-dot:hover{background:rgba(108,59,255,.5)}

/* ── FINAL CTA ── */
.final-cta{background:var(--black);text-align:center;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(108,59,255,.12) 0%,transparent 70%)}
.final-cta .section-title{font-size:clamp(2.2rem,5vw,3.8rem)}
.cta-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:.75rem}

/* ── SERVICES PAGE ── */
.services-hero{min-height:60vh;display:flex;align-items:center;padding:140px 5% 80px;position:relative;overflow:hidden;background:var(--black)}
.services-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 30% 50%,rgba(108,59,255,.15) 0%,transparent 60%)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:4rem}
.service-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:2.5rem;transition:.3s;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient)}
.service-card:hover{transform:translateY(-6px);box-shadow:0 30px 80px rgba(108,59,255,.15);border-color:rgba(108,59,255,.3)}
.service-icon{font-size:2.5rem;margin-bottom:1.2rem}
.service-card h3{font-family:var(--font-head);font-size:1.4rem;font-weight:700;margin-bottom:.8rem}
.service-card p{color:var(--muted);font-size:.9rem;line-height:1.7;margin-bottom:1.5rem}
.service-features{list-style:none}
.service-features li{color:var(--muted);font-size:.85rem;padding:.35rem 0;display:flex;align-items:center;gap:.5rem}
.service-features li::before{content:'→';color:var(--neon);font-size:.8rem}
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:3rem}
.step{text-align:center;padding:2rem 1.5rem}
.step-num{font-family:var(--font-head);font-size:3rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;opacity:.4;line-height:1}
.step h4{font-family:var(--font-head);font-size:1rem;font-weight:700;margin:.5rem 0}
.step p{color:var(--muted);font-size:.85rem}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--glass-border);padding:1.2rem 0}
.faq-q{font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q:hover{color:var(--neon)}
.faq-a{color:var(--muted);font-size:.9rem;line-height:1.7;max-height:0;overflow:hidden;transition:.3s}
.faq-item.open .faq-a{max-height:200px;margin-top:.8rem}
.faq-arrow{transition:.3s;font-size:.8rem}
.faq-item.open .faq-arrow{transform:rotate(180deg)}

/* ── STORE ── */
.store-filters{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{background:var(--glass);border:1px solid var(--glass-border);color:var(--muted);padding:14px 24px;border-radius:999px;cursor:pointer;font-size:.88rem;font-weight:600;transition:.25s;font-family:var(--font-body);min-height:50px;display:inline-flex;align-items:center;text-decoration:none;letter-spacing:.01em;line-height:1}
.filter-btn.active{background:linear-gradient(135deg,#7c3aed,#6c3bff);border-color:transparent;color:#fff;box-shadow:0 4px 28px rgba(108,59,255,.45)}
.filter-btn:hover{background:rgba(124,58,237,.2);border-color:var(--purple);color:var(--white);transform:translateY(-1px);box-shadow:0 4px 20px rgba(108,59,255,.2)}

/* Shop trust badges */
.shop-trust{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1.25rem;margin-top:2.5rem}
.shop-trust__item{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem 1.25rem;text-align:center;transition:.3s}
.shop-trust__item:hover{transform:translateY(-3px);border-color:rgba(108,59,255,.28);box-shadow:0 12px 40px rgba(108,59,255,.12)}
.shop-trust__icon{font-size:1.8rem;margin-bottom:.65rem;display:block}
.shop-trust__label{font-weight:600;font-size:.85rem;margin-bottom:.35rem;letter-spacing:.02em}
.shop-trust__desc{color:var(--muted);font-size:.78rem;line-height:1.5}

/* ── BLOG ── */
.blog-hero{padding:140px 5% 60px;background:var(--black)}
.blog-cats{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:3rem}
.cat-pill{background:var(--glass);border:1px solid var(--glass-border);color:var(--muted);padding:.45rem 1rem;border-radius:50px;cursor:pointer;font-size:.82rem;transition:.2s}
.cat-pill.active,.cat-pill:hover{background:rgba(108,59,255,.2);border-color:var(--purple);color:var(--white)}
.blog-search{background:var(--glass);border:1px solid var(--glass-border);border-radius:50px;display:flex;align-items:center;padding:.5rem 1.2rem;max-width:360px;margin-bottom:2rem;gap:.5rem}
.blog-search input{background:none;border:none;color:var(--white);font-family:var(--font-body);font-size:.9rem;outline:none;width:100%}
.blog-search input::placeholder{color:var(--muted)}
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}
.post-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;transition:.3s;cursor:pointer}
.post-card:hover{transform:translateY(-4px);border-color:rgba(108,59,255,.3)}
.post-img{height:180px;background:var(--gradient2);display:flex;align-items:center;justify-content:center;font-size:2.5rem;position:relative}
.post-cat-badge{position:absolute;bottom:.8rem;left:.8rem;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border:1px solid var(--glass-border);color:var(--neon);padding:.25rem .7rem;border-radius:50px;font-size:.7rem;font-weight:600}
.post-body{padding:1.4rem}
.post-meta{display:flex;gap:1rem;color:var(--muted);font-size:.75rem;margin-bottom:.7rem}
.post-title{font-family:var(--font-head);font-weight:700;font-size:1.05rem;line-height:1.3;margin-bottom:.6rem}
.post-excerpt{color:var(--muted);font-size:.85rem;line-height:1.6}
.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.8rem}
.tag{background:rgba(108,59,255,.1);color:var(--purple-light);padding:.2rem .6rem;border-radius:50px;font-size:.7rem}

/* ── CASE STUDIES ── */
.case-study-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:2.5rem;margin-bottom:2rem;transition:.3s}
.case-study-card:hover{border-color:rgba(108,59,255,.3)}
.cs-header{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start;margin-bottom:2rem}
.cs-brand h3{font-family:var(--font-head);font-size:1.5rem;font-weight:700;margin-bottom:.4rem}
.cs-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}
.cs-metric .val{font-family:var(--font-head);font-size:2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.cs-metric .lbl{font-size:.72rem;color:var(--muted);text-transform:uppercase}
.cs-body{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}
.cs-section h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--neon);margin-bottom:.6rem}
.cs-section p{color:var(--muted);font-size:.88rem;line-height:1.6}

/* ── ABOUT ── */
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-bottom:5rem}
.about-visual{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:3rem;text-align:center}
.about-visual .big-num{font-family:var(--font-head);font-size:5rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}
.team-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:2rem 1.5rem;text-align:center;transition:.3s}
.team-card:hover{transform:translateY(-4px);border-color:rgba(108,59,255,.3)}
.team-avatar{width:72px;height:72px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:1.5rem;color:#fff;margin:0 auto 1rem}
.team-card h4{font-family:var(--font-head);font-weight:700;font-size:1rem;margin-bottom:.3rem}
.team-card p{color:var(--muted);font-size:.82rem}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:3rem}
.value-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;text-align:center}
.value-icon{font-size:2rem;margin-bottom:1rem}
.value-card h4{font-family:var(--font-head);font-weight:700;margin-bottom:.5rem}
.value-card p{color:var(--muted);font-size:.85rem}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info h3{font-family:var(--font-head);font-size:1.6rem;font-weight:700;margin-bottom:1rem}
.contact-info p{color:var(--muted);line-height:1.7;margin-bottom:2rem}
.contact-links{display:flex;flex-direction:column;gap:1rem}
.contact-link{display:flex;align-items:center;gap:1rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;padding:1rem 1.2rem;text-decoration:none;color:var(--white);transition:.2s}
.contact-link:hover{border-color:var(--purple);transform:translateX(4px)}
.contact-link-icon{width:40px;height:40px;border-radius:10px;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.contact-form{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:2.5rem}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.4rem;font-weight:500}
.form-group input,.form-group textarea,.form-group select{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:10px;padding:.8rem 1rem;color:var(--white);font-family:var(--font-body);font-size:.9rem;outline:none;transition:.2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--purple);background:rgba(108,59,255,.06)}
.form-group textarea{height:120px;resize:vertical}
.form-group select{cursor:pointer}
.form-group select option{background:var(--navy2);color:var(--white)}
.wa-btn{display:inline-flex;align-items:center;gap:.7rem;background:#25d366;border:none;color:#fff;padding:.85rem 1.8rem;border-radius:50px;font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;margin-top:1rem;transition:.2s}
.wa-btn:hover{background:#20bd5a;transform:translateY(-2px)}
.cal-embed{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;text-align:center;margin-top:1.5rem}

/* ── LEGAL ── */
.legal-content{max-width:800px;margin:0 auto;padding:140px 5% 80px}
.legal-content h1{font-family:var(--font-head);font-size:2.5rem;font-weight:800;margin-bottom:.5rem}
.legal-content .last-updated{color:var(--muted);font-size:.85rem;margin-bottom:3rem}
.legal-content h2{font-family:var(--font-head);font-size:1.3rem;font-weight:700;margin:2rem 0 .8rem;color:var(--neon)}
.legal-content p,.legal-content li{color:var(--muted);line-height:1.8;font-size:.92rem;margin-bottom:.8rem}
.legal-content ul{padding-left:1.5rem}
.legal-content li{margin-bottom:.4rem}

/* ── FOOTER ── */
footer{background:var(--navy2);border-top:1px solid var(--glass-border);padding:2.25rem 5% 1.25rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:1.75rem}
.footer-brand .nav-logo{display:inline-block;margin-bottom:1rem}
.footer-brand .custom-logo-link{display:inline-block;margin-bottom:1rem}
.footer-brand .custom-logo-link img.custom-logo{max-height:50px;width:auto;height:auto}
.footer-brand p{color:var(--muted);font-size:.88rem;line-height:1.7;max-width:280px}
.footer-social{display:flex;gap:.65rem;margin-top:1.25rem}
.social-icon{width:38px;height:38px;border-radius:10px;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.25s;font-size:.9rem;color:rgba(255,255,255,.35)}.social-icon svg{width:18px;height:18px;display:block;transition:inherit}.social-icon:hover{color:#fff;border-color:var(--purple-mid);background:rgba(108,59,255,.15);transform:translateY(-2px);box-shadow:0 4px 20px rgba(108,59,255,.18)}
.footer-col h4{font-family:var(--font-body);font-weight:600;font-size:.88rem;margin-bottom:1rem;letter-spacing:.3px;color:rgba(255,255,255,.6)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.65rem}
.footer-col ul a{color:var(--muted);text-decoration:none;font-size:.85rem;transition:.2s;display:inline-block}
.footer-col ul a:hover{color:var(--white);transform:translateX(3px)}
.footer-bottom{border-top:1px solid var(--glass-border);padding-top:1.25rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{color:var(--muted);font-size:.82rem}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{color:var(--muted);text-decoration:none;font-size:.82rem;transition:.2s}
.footer-bottom-links a:hover{color:var(--white)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(-50%) translateX(0)}50%{transform:translateY(-52%) translateX(-5px)}}
.animate{animation:fadeUp .7s ease forwards;opacity:0}
.delay-1{animation-delay:.1s}
.delay-2{animation-delay:.2s}
.delay-3{animation-delay:.3s}
.delay-4{animation-delay:.4s}
.delay-5{animation-delay:.5s}
.hero-visual{animation:float 6s ease-in-out infinite}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-visual{display:none}
  .about-story{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cs-body{grid-template-columns:1fr;gap:1rem}
  .cs-header{grid-template-columns:1fr}

  /* ── Testimonials tablet ── */
  .testi-wrapper{padding:0 68px}
  .testi-card{flex:0 0 calc((100% - 24px)/2);padding:1.5rem 1.25rem}
  .testi-btn{width:52px;height:52px;font-size:1.2rem}

  /* ── Nav tablet ── */
  nav#site-navigation{padding:10px 18px;min-height:58px}
  .nav-links,.main-navigation ul{gap:1.5rem}
  .nav-links a,.main-navigation ul li a{font-size:.95rem;padding:6px 12px}
  .nav-right{gap:.8rem}
  .nav-icon-btn{width:40px;height:40px}

  /* ── Shop tablet ── */
  .woo-shop-wrap{padding:100px 5% 28px}
  .shop-trust{grid-template-columns:repeat(2, 1fr)}
  .woocommerce ul.products{gap:1.25rem !important}
}
@media(max-width:768px){
  .main-navigation,.nav-links{display:none}
  .hamburger{display:flex}
  nav#site-navigation{padding:10px 16px;min-height:56px;top:12px}
  .nav-right{gap:.8rem}
  .hero{padding-top:140px}
  .hero-stat .num{font-size:1.8rem}
  .case-placeholder{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .footer-brand{grid-column:1/-1}
  section{padding:29px 5%}
  .cs-metrics{grid-template-columns:1fr 1fr}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}

  /* ── Mobile text alignment ── */
  .hero,.hero-content{text-align:center;align-items:center}
  .hero-content{max-width:100%}
  .hero p{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .trust-badges{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-stat{text-align:center}
  .section-head{text-align:center}
  .section-sub{margin-left:auto;margin-right:auto}
  .benefit-card,.result-card,.testi-card{text-align:left}
  .results-grid{align-items:stretch;text-align:center}
  .testi-wrapper{padding:0 54px}
  .testi-btn{width:44px;height:44px;font-size:1rem}
  .testi-card{flex:0 0 calc((100% - 24px)/2);padding:1.25rem 1rem}
  .testi-dots{display:flex}
  .footer-grid{text-align:left}

  /* ── Shop mobile ── */
  .woo-shop-wrap{padding:95px 4% 24px}
  .shop-breadcrumb{margin-bottom:1rem}
  .store-filters{margin-bottom:1.5rem}
  .woo-shop-top{margin-bottom:1.25rem}
  .filter-btn{padding:12px 18px;font-size:.84rem;min-height:46px}
  .woocommerce-result-count{font-size:.78rem}
  .harvang-pagination{margin-top:2rem}
}
@media(max-width:480px){
  .hero h1{font-size:2.2rem}
  .hero-btns{flex-direction:column}
  .btn-primary,.btn-outline{text-align:center}
  .benefits-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .benefit-card{padding:14px}
  .benefit-card h3{font-size:14px}
  .benefit-card p{font-size:12px;line-height:1.5}
  .benefit-icon{width:22px;height:22px;font-size:.75rem;margin-bottom:.35rem}
}

/* ── NEON GLOW ── */
.neon-text{color:var(--neon);text-shadow:0 0 20px rgba(0,212,255,.5)}
.purple-glow{box-shadow:0 0 30px rgba(108,59,255,.3)}
.divider{height:1px;background:var(--glass-border);margin:0 5%}

/* ─────────────────────────────────────────────
   WOOCOMMERCE OVERRIDES
   ───────────────────────────────────────────── */

/* ── CRITICAL: kill WooCommerce float layout ──
   WooCommerce's woocommerce.css sets float:left
   + percentage widths on li.product which breaks
   our CSS grid. Force-reset every variant. */
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none !important; }
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 1.5rem !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: both !important;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  clear: none !important;
}

/* Shop page wrapper */
.woocommerce-page .site-content,
.woocommerce .site-content {
  padding-top: 0;
}

/* WooCommerce shop header */
.woocommerce-products-header {
  padding: 140px 5% 40px;
  background: var(--navy);
  position: relative;
  overflow: hidden;
}
.woocommerce-products-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 50% 80% at 80% 40%, rgba(167,139,250,.08) 0%, transparent 60%);
}
.woocommerce-products-header__title {
  font-family: var(--font-head);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -2px;
  margin-bottom: 1rem;
  position: relative;
  z-index: 2;
}



/* Product grid on shop page */
.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.woocommerce ul.products li.product {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  overflow: hidden;
  transition: .3s;
  margin: 0;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  border-color: rgba(108,59,255,.3);
  box-shadow: 0 20px 60px rgba(108,59,255,.12);
}
.woocommerce ul.products li.product .woocommerce-loop-product__link {
  display: block;
  text-decoration: none;
  color: var(--white);
}
.woocommerce ul.products li.product img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  background: var(--gradient2);
  display: block;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .95rem;
  padding: 1.2rem 1.2rem .4rem;
  color: var(--white);
  letter-spacing: -.2px;
}
.woocommerce ul.products li.product .price {
  font-family: var(--font-body);
  font-size: 1.2rem;
  font-weight: 700;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  padding: 0 1.2rem 1rem;
  display: block;
  letter-spacing: -.3px;
}
.woocommerce ul.products li.product .price del {
  opacity: .5;
  font-size: .9rem;
  -webkit-text-fill-color: var(--muted);
}
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button {
  display: block;
  background: var(--gradient);
  color: #fff;
  border: none;
  padding: .6rem 1.2rem;
  border-radius: 0 0 16px 16px;
  font-size: .85rem;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: .2s;
  font-family: var(--font-body);
  margin: 0 1.2rem 1.2rem;
  border-radius: 50px;
}
.woocommerce ul.products li.product .button:hover {
  opacity: .85;
}
.woocommerce-ordering select,
.woocommerce .widget_layered_nav ul li a {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  color: var(--white);
  border-radius: 50px;
  padding: .5rem 2.2rem .5rem 1.1rem;
  font-family: var(--font-body);
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='rgba(255,255,255,.45)' d='M0 0l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .85rem center;
  background-size: 10px 6px;
  transition: .2s;
}
.woocommerce-ordering select:hover,
.woocommerce-ordering select:focus {
  border-color: var(--purple);
  background-color: rgba(124,58,237,.08);
  outline: none;
}

/* Single product page — base reset (layout handled by #product-wrap below) */
.woocommerce div.product {
  padding: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  width: 100% !important;
}
.woocommerce div.product .product_title {
  font-family: var(--font-body);
  font-size: clamp(1.4rem, 2.2vw, 1.9rem) !important;
  font-weight: 600;
  letter-spacing: -.3px;
  line-height: 1.25;
  color: var(--white);
  margin-bottom: .5rem;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--font-body);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -.3px;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 1rem;
  display: block;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.7;
  margin-bottom: 1.2rem;
}
.woocommerce div.product form.cart {
  display: flex;
  align-items: center;
  gap: .8rem;
  flex-wrap: wrap;
  margin-bottom: 1.2rem;
}
.woocommerce div.product form.cart .qty {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  color: var(--white);
  border-radius: 10px;
  padding: .7rem 1rem;
  font-family: var(--font-body);
  width: 80px;
}
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--gradient);
  color: #fff !important;
  border: none;
  padding: .85rem 2rem;
  border-radius: 50px;
  font-family: var(--font-body);
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  transition: .25s;
  text-decoration: none;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  opacity: .85;
  transform: translateY(-2px);
}
.woocommerce div.product .woocommerce-tabs {
  margin-top: 1.5rem;
}
/* Kill WooCommerce's default tab decorators — ::before only, keep ::after for our underline */
.woocommerce div.product .woocommerce-tabs ul.tabs li::before { display: none !important; }
.woocommerce div.product .woocommerce-Tabs-panel {
  color: var(--muted);
  line-height: 1.8;
}
/* Force WooCommerce's high-specificity tab rules to our design */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  background: transparent !important;
  border: none !important;
  border-bottom: none !important;
  padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  color: var(--muted) !important;
  margin: 0 !important;
  padding: .7rem 1.4rem !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  color: inherit !important;
  background: transparent !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce div.product .woocommerce-tabs ul.tabs li:hover {
  background: transparent !important;
  border: none !important;
  color: var(--white) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li:hover a {
  color: var(--white) !important;
  background: transparent !important;
}

/* Cart page */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
  padding: 140px 5% 80px;
  max-width: 1100px;
  margin: 0 auto;
}
.woocommerce table.shop_table {
  width: 100%;
  border-collapse: collapse;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  overflow: hidden;
}
.woocommerce table.shop_table th {
  background: rgba(108,59,255,.1);
  color: var(--neon);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 1rem 1.5rem;
  text-align: left;
  font-family: var(--font-head);
}
.woocommerce table.shop_table td {
  padding: 1.2rem 1.5rem;
  border-top: 1px solid var(--glass-border);
  color: var(--white);
  font-size: .9rem;
}
.woocommerce table.shop_table td.product-name a {
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
}
.woocommerce table.shop_table td.product-price,
.woocommerce table.shop_table td.product-total {
  font-family: var(--font-body);
  font-weight: 700;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.woocommerce .cart-collaterals {
  margin-top: 2rem;
}
.woocommerce .cart_totals,
.woocommerce-page .cart_totals {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 2rem;
  float: right;
  width: 100%;
  max-width: 420px;
}
.woocommerce .cart_totals h2 {
  font-family: var(--font-head);
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  color: var(--white);
}
.woocommerce .cart_totals table {
  width: 100%;
}
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
  color: var(--muted);
  font-size: .9rem;
  padding: .6rem 0;
  border-top: 1px solid var(--glass-border);
}
.woocommerce .cart_totals table .order-total td strong {
  font-family: var(--font-body);
  font-size: 1.2rem;
  font-weight: 700;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Checkout */
.woocommerce-checkout #payment {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 2rem;
}
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin-bottom: 1.5rem;
}
.woocommerce-checkout #payment ul.payment_methods li {
  padding: .8rem 0;
  border-bottom: 1px solid var(--glass-border);
  color: var(--white);
}
.woocommerce form .form-row {
  margin-bottom: 1.2rem;
}
.woocommerce form .form-row label {
  display: block;
  font-size: .82rem;
  color: var(--muted);
  margin-bottom: .4rem;
  font-weight: 500;
}
.woocommerce form .form-row input,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  width: 100%;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: .8rem 1rem;
  color: var(--white);
  font-family: var(--font-body);
  font-size: .9rem;
  outline: none;
  transition: .2s;
}
.woocommerce form .form-row input:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--purple);
}

/* Pagination */
.woocommerce nav.woocommerce-pagination {
  margin-top: 3.5rem;
  text-align: center;
}
/* ── Custom WooCommerce pagination (loop/pagination.php) ── */
.harvang-pagination {
  margin-top: 2.5rem;
  text-align: center;
}
.harvang-pagination__inner {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
  justify-content: center;
}
/* Shared circle style for ALL items */
.hpag-item {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head);
  font-size: .95rem;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  transition: .25s;
  box-sizing: border-box;
  cursor: pointer;
}
.hpag-item:hover {
  transform: translateY(-2px);
}
/* Default number / arrow */
.hpag-num,
.hpag-arrow {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.55);
}
.hpag-num:hover,
.hpag-arrow:hover {
  background: rgba(124,58,237,.2);
  border-color: var(--purple);
  color: #fff;
}
/* Active / current page */
.hpag-current {
  background: linear-gradient(135deg, #7c3aed, #6c3bff);
  border: 1px solid transparent;
  color: #fff;
  font-weight: 700;
  box-shadow: 0 0 22px rgba(108,59,255,.55);
  cursor: default;
  transform: scale(1.05);
}
/* Arrows slightly larger icon */
.hpag-arrow {
  font-size: 1.1rem;
  color: rgba(196,181,253,.85);
}
/* Dots — no circle border */
.hpag-dots {
  background: none;
  border: none;
  color: rgba(255,255,255,.3);
  font-size: 1rem;
  cursor: default;
  letter-spacing: .05em;
  width: auto;
  padding: 0 .3rem;
}
/* Hide the default WooCommerce pagination element (we replaced it) */
.woocommerce nav.woocommerce-pagination { display: none; }

/* WordPress core pagination (blog/archive) — same individual-circle style */
.pagination,
.nav-pagination {
  display: flex;
  justify-content: center;
  margin-top: 3rem;
}
.pagination .nav-links,
.nav-pagination .nav-links {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}
.page-numbers {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  color: var(--muted);
  text-decoration: none;
  font-size: .95rem;
  font-weight: 600;
  font-family: var(--font-head);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: .2s;
}
.page-numbers:hover {
  background: rgba(124,58,237,.18);
  border-color: var(--purple);
  color: var(--white);
}
.page-numbers.current {
  background: var(--gradient);
  border-color: transparent;
  color: #fff;
  font-weight: 700;
  box-shadow: 0 0 22px rgba(108,59,255,.5);
}
.page-numbers.dots {
  background: none;
  border: none;
  color: var(--muted);
  cursor: default;
  width: auto;
}

/* Product badges — Sale! hidden, not needed for digital products */
.woocommerce span.onsale {
  display: none !important;
}

/* Stars */
.woocommerce .star-rating { color: #f59e0b; }
.woocommerce .star-rating span { color: #f59e0b; }
.woocommerce .star-rating span::before { color: #f59e0b !important; }
/* Interactive star selector in review form */
.woocommerce #review_form .stars span a { color: var(--muted) !important; }
.woocommerce #review_form .stars span a:hover,
.woocommerce #review_form .stars span a.active { color: #f59e0b !important; }

/* Account pages */
.woocommerce-account .woocommerce {
  padding: 140px 5% 80px;
  max-width: 900px;
  margin: 0 auto;
}
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  padding: 0;
  margin-bottom: 2rem;
}
.woocommerce-MyAccount-navigation ul li a {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  color: var(--muted);
  padding: .5rem 1.2rem;
  border-radius: 50px;
  text-decoration: none;
  font-size: .85rem;
  transition: .2s;
  display: block;
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover {
  background: rgba(108,59,255,.2);
  border-color: var(--purple);
  color: var(--white);
}

/* ── Custom product card (content-product.php) ── */
.harvang-product-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  overflow: hidden;
  transition: .3s;
  display: block !important;
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative;
}
.harvang-product-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient);
  opacity: 0;
  transition: .3s;
  z-index: 3;
}
.harvang-product-card:hover {
  transform: translateY(-6px);
  border-color: rgba(108,59,255,.4);
  box-shadow: 0 28px 80px rgba(108,59,255,.2);
}
.harvang-product-card:hover::before {
  opacity: 1;
}
.hpc-inner {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--white);
  height: 100%;
}
.hpc-img {
  background: linear-gradient(145deg, #160730 0%, #27094f 45%, #1a063a 100%);
  height: 190px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.hpc-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 60% at 50% 60%, rgba(124,58,237,.18) 0%, transparent 70%);
  transition: .4s;
}
.hpc-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  transition: transform .5s ease, filter .5s ease;
}
.harvang-product-card:hover .hpc-img img {
  transform: scale(1.06);
}
.hpc-placeholder-icon {
  font-size: 3.4rem;
  z-index: 1;
  filter: drop-shadow(0 0 18px rgba(167,139,250,.4));
  transition: transform .4s ease;
}
.harvang-product-card:hover .hpc-placeholder-icon {
  transform: scale(1.12);
}
.harvang-product-card:hover .hpc-img::after {
  opacity: 1.3;
}
.hpc-badge {
  position: absolute;
  top: .9rem;
  right: .9rem;
  background: rgba(0,212,255,.1);
  border: 1px solid rgba(0,212,255,.22);
  color: var(--neon);
  padding: .25rem .8rem;
  border-radius: 50px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .04em;
  z-index: 2;
  backdrop-filter: blur(8px);
}
.hpc-sale {
  position: absolute;
  top: .9rem;
  left: .9rem;
  background: linear-gradient(135deg, #7c3aed, #a855f7);
  color: #fff;
  padding: .25rem .8rem;
  border-radius: 50px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: 0 0 18px rgba(108,59,255,.55);
  animation: salePulse 2s ease-in-out infinite;
}
@keyframes salePulse {
  0%, 100% { box-shadow: 0 0 18px rgba(108,59,255,.55); }
  50% { box-shadow: 0 0 28px rgba(168,85,247,.7); }
}
.hpc-body {
  padding: 1.5rem 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.hpc-cat {
  font-size: .68rem;
  color: var(--neon);
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 700;
  display: block;
  margin-bottom: .45rem;
}
.hpc-title {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.35;
  margin-bottom: .5rem;
  color: var(--white);
  letter-spacing: -.2px;
}
.hpc-desc {
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.6;
  margin-bottom: auto;
  padding-bottom: .5rem;
}
.price-buy-row,
.hpc-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding: 14px 0 0;
  border-top: 1px solid var(--glass-border);
  gap: 10px;
  width: 100%;
}
.price-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
}
.hpc-price {
  font-family: var(--font-body);
  font-size: clamp(1.05rem, 1.8vw, 1.375rem);
  font-weight: 700;
  letter-spacing: -.3px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.15;
}
.hpc-price .woocommerce-Price-amount {
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hpc-price del {
  display: block;
  line-height: 1;
}
.hpc-price del .woocommerce-Price-amount {
  -webkit-text-fill-color: var(--muted);
  background: none;
  opacity: .5;
  font-size: .68rem;
  font-weight: 500;
  text-decoration: line-through;
}
.hpc-price ins {
  text-decoration: none;
  display: block;
  line-height: 1;
}
.buy-btn,
.hpc-btn {
  background: var(--gradient);
  color: #fff;
  height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: .8125rem;
  font-weight: 600;
  white-space: nowrap;
  transition: .25s;
  display: inline-flex;
  align-items: center;
  letter-spacing: .02em;
  flex-shrink: 0;
}
.harvang-product-card:hover .hpc-btn {
  opacity: 1;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(108,59,255,.4);
}

/* Shop page wrapper section */
.woo-shop-wrap {
  background: var(--black);
  padding: 110px 5% 32px;
}
.woo-shop-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.75rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.woocommerce-result-count {
  color: var(--muted);
  font-size: .85rem;
  font-weight: 500;
}

/* Breadcrumb */
.woocommerce-breadcrumb {
  color: var(--muted);
  font-size: .78rem;
  padding: .6rem 0;
  background: transparent;
}
.woocommerce-breadcrumb a {
  color: var(--neon);
  text-decoration: none;
  font-weight: 500;
}
.woocommerce-breadcrumb a:hover { text-decoration: underline; }

/* Breadcrumb on shop/archive page */
.shop-breadcrumb { margin-bottom: 1.5rem; }
.shop-breadcrumb .woocommerce-breadcrumb { padding: 0; }

/* ══════════════════════════════════════════
   SERVICES PAGE — REDESIGN
══════════════════════════════════════════ */

/* Hero */
.srv-hero {
  min-height: 60vh;
  display: flex;
  align-items: center;
  padding: 140px 5% 80px;
  background: var(--black);
  position: relative;
  overflow: hidden;
}
.srv-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 70% at 30% 50%, rgba(108,59,255,.18) 0%, transparent 60%);
  pointer-events: none;
}
.srv-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 700px;
}
.srv-hero-title {
  font-family: var(--font-head);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800;
  letter-spacing: -2px;
  line-height: 1.08;
  margin-bottom: 1rem;
}
.srv-hero-sub {
  color: var(--muted);
  font-size: 1.05rem;
  max-width: 520px;
  line-height: 1.7;
  margin-bottom: 2rem;
}

/* Category pills */
.srv-category-pills {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
}
.srv-pill {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  color: var(--muted);
  padding: .55rem 1.4rem;
  border-radius: 50px;
  cursor: pointer;
  font-size: .9rem;
  font-weight: 500;
  font-family: var(--font-body);
  transition: .2s;
}
.srv-pill.active,
.srv-pill:hover {
  background: rgba(124,58,237,.2);
  border-color: var(--purple);
  color: var(--white);
}

/* Platform tab bar */
.srv-platforms-section {
  background: var(--navy);
  padding: 0 0 80px;
}
.srv-tab-bar {
  display: flex;
  gap: 0;
  overflow-x: auto;
  border-bottom: 2px solid var(--glass-border);
  padding: 0 5%;
  scrollbar-width: none;
  background: var(--navy2);
}
.srv-tab-bar::-webkit-scrollbar { display: none; }
.srv-tab {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--muted);
  padding: 1.4rem 2rem;
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: .2s;
  margin-bottom: -2px;
  letter-spacing: .01em;
}
.srv-tab:hover {
  color: var(--white);
  background: rgba(139,92,246,.06);
}
.srv-tab.active {
  color: var(--neon);
  border-bottom-color: var(--purple);
  background: rgba(124,58,237,.1);
  text-shadow: 0 0 20px rgba(196,181,253,.4);
}

/* Panels */
.srv-tab-panels {
  padding: 60px 5% 0;
}
.srv-panel {
  display: none;
}
.srv-panel.active {
  display: block;
}
.srv-panel-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.srv-platform-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  padding: .35rem 1rem;
  border-radius: 50px;
  font-size: .78rem;
  color: var(--neon);
  margin-bottom: 1.2rem;
}
.srv-panel-title {
  font-family: var(--font-head);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -1px;
  margin-bottom: 1rem;
}
.srv-panel-desc {
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 1.5rem;
  font-size: .95rem;
}
.srv-feature-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.srv-feature-list li {
  color: var(--muted);
  font-size: .88rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}
.srv-feature-list li::before {
  content: '→';
  color: var(--neon);
  font-size: .8rem;
  flex-shrink: 0;
}

/* Platform mockup visual */
.srv-panel-visual {
  display: flex;
  justify-content: center;
}
.srv-mockup {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 1.8rem;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 30px 80px rgba(108,59,255,.12);
}
.srv-mockup-bar {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: 1.4rem;
}
.srv-mockup-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--glass-border);
  display: inline-block;
}
.srv-mockup-label {
  font-size: .72rem;
  color: var(--muted);
  margin-left: .4rem;
}
.srv-mockup-stat-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .8rem;
  margin-bottom: 1.4rem;
}
.srv-mockup-stat {
  background: rgba(139,92,246,.08);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: .8rem .5rem;
  text-align: center;
}
.srv-ms-val {
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 800;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.srv-ms-lbl {
  font-size: .65rem;
  color: var(--muted);
  margin-top: .3rem;
}
.srv-mockup-chart {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  height: 90px;
  margin-bottom: 1rem;
}
.srv-bar {
  flex: 1;
  background: var(--gradient);
  border-radius: 4px 4px 0 0;
  opacity: .7;
  transition: height .5s ease;
}
.srv-mockup-foot {
  font-size: .72rem;
  color: var(--neon);
  text-align: center;
  padding-top: .8rem;
  border-top: 1px solid var(--glass-border);
}

/* Pricing section */
.srv-pricing-section {
  background: var(--black);
  padding: 80px 5% 100px;
}
.srv-pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
  align-items: start;
}
.srv-price-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2.5rem 2rem;
  position: relative;
  transition: .3s;
}
.srv-price-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 80px rgba(108,59,255,.15);
  border-color: rgba(108,59,255,.3);
}
.srv-price-popular {
  border-color: var(--purple);
  box-shadow: 0 0 40px rgba(108,59,255,.2);
  transform: scale(1.04);
}
.srv-price-popular:hover {
  transform: scale(1.04) translateY(-6px);
}
.srv-popular-badge {
  display: inline-block;
  background: var(--gradient);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  padding: .25rem .8rem;
  border-radius: 50px;
  margin-bottom: 1.2rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.srv-price-duration {
  font-family: var(--font-head);
  font-size: .85rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .5rem;
}
.srv-price-amount {
  font-family: var(--font-head);
  font-size: 3rem;
  font-weight: 800;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
  margin-bottom: .8rem;
}
.srv-price-period {
  font-size: 1rem;
  font-weight: 500;
}
.srv-price-desc {
  color: var(--muted);
  font-size: .85rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
}
.srv-price-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  margin-bottom: 2rem;
}
.srv-price-features li {
  color: var(--muted);
  font-size: .85rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.srv-price-features li::before {
  content: '✓';
  color: var(--neon);
  font-weight: 700;
  font-size: .8rem;
  flex-shrink: 0;
}
.srv-price-btn {
  width: 100%;
  text-align: center;
  display: block;
}

/* FAQ section */
.srv-faq-section {
  background: var(--navy);
  padding: 80px 5% 100px;
}

/* Save badge (lead gen pricing) */
.srv-save-badge {
  display: inline-block;
  background: rgba(124,58,237,.25);
  border: 1px solid var(--purple);
  color: var(--purple-light);
  font-size: .72rem;
  font-weight: 700;
  padding: .2rem .7rem;
  border-radius: 50px;
  margin-bottom: 1rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* ── LEAD GENERATION STYLES ── */
.srv-lead-intro {
  background: var(--navy);
  padding: 80px 5%;
}
.srv-lead-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  margin-bottom: 4rem;
}
.srv-lead-intro-visual {
  display: flex;
  justify-content: center;
}
.srv-lead-visual-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2.5rem 2rem;
  text-align: center;
  box-shadow: 0 30px 80px rgba(108,59,255,.12);
  width: 100%;
  max-width: 380px;
}
.srv-lead-target {
  font-size: 4rem;
  margin-bottom: 1.5rem;
}
.srv-lead-visual-stats {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.srv-lead-stat {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(139,92,246,.08);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: .8rem 1.2rem;
}
.srv-lead-stat-val {
  font-family: var(--font-head);
  font-size: 1.3rem;
  font-weight: 800;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.srv-lead-stat-lbl {
  color: var(--muted);
  font-size: .82rem;
}

/* Trust bar */
.srv-lead-trust-bar {
  background: rgba(124,58,237,.06);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2rem 2.5rem;
}
.srv-lead-trust-label {
  font-size: .88rem;
  font-weight: 600;
  color: var(--neon);
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.srv-lead-trust-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.2rem;
}
.srv-lead-trust-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  padding: 1.4rem 1rem;
  text-align: center;
  transition: .2s;
}
.srv-lead-trust-card:hover {
  border-color: rgba(108,59,255,.3);
  transform: translateY(-3px);
}
.srv-ltc-icon {
  font-size: 1.8rem;
  margin-bottom: .6rem;
}
.srv-ltc-title {
  font-family: var(--font-head);
  font-size: .88rem;
  font-weight: 700;
  margin-bottom: .4rem;
}
.srv-ltc-desc {
  color: var(--muted);
  font-size: .75rem;
  line-height: 1.5;
}

/* Responsive */
@media (max-width: 1024px) {
  .srv-panel-content {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .srv-pricing-grid {
    grid-template-columns: 1fr;
    max-width: 440px;
    margin-left: auto;
    margin-right: auto;
  }
  .srv-price-popular {
    transform: none;
  }
  .srv-price-popular:hover {
    transform: translateY(-6px);
  }
  .srv-lead-intro-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .srv-lead-trust-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .srv-tab {
    padding: 1rem 1.2rem;
    font-size: .88rem;
  }
  .srv-mockup-stat-row {
    grid-template-columns: repeat(3, 1fr);
    gap: .5rem;
  }
  .srv-lead-trust-cards {
    grid-template-columns: 1fr 1fr;
  }
}

/* ═══════════════════════════════════════════════════
   CART PAGE
═══════════════════════════════════════════════════ */
.woocommerce-cart .woocommerce,
.woocommerce-cart .woo-shop-wrap {
  padding: 120px 5% 80px;
  max-width: 1200px;
  margin: 0 auto;
}
.woocommerce-cart h1,
.woocommerce-cart .page-title {
  font-family: var(--font-head);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  letter-spacing: -1px;
  margin-bottom: 2rem;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Cart table */
.woocommerce-cart-form table.shop_table,
.woocommerce table.shop_table {
  width: 100%;
  border-collapse: collapse;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 2rem;
}
.woocommerce-cart-form table.shop_table thead th,
.woocommerce table.shop_table thead th {
  background: rgba(108,59,255,.1);
  color: var(--neon);
  font-family: var(--font-head);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 1rem 1.2rem;
  border-bottom: 1px solid var(--glass-border);
  text-align: left;
}
.woocommerce-cart-form table.shop_table tbody td,
.woocommerce table.shop_table tbody td {
  padding: 1.2rem;
  border-bottom: 1px solid var(--glass-border);
  vertical-align: middle;
  color: var(--white);
  font-size: .9rem;
}
.woocommerce-cart-form table.shop_table tbody tr:last-child td {
  border-bottom: none;
}
.woocommerce-cart-form table.shop_table tbody tr:hover td {
  background: rgba(255,255,255,.02);
}

/* Product image in cart */
.woocommerce-cart-form .product-thumbnail img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
}

/* Product name link */
.woocommerce-cart-form .product-name a {
  color: var(--white);
  text-decoration: none;
  font-weight: 500;
  font-family: var(--font-body);
  transition: .2s;
}
.woocommerce-cart-form .product-name a:hover { color: var(--neon); }

/* Remove item button */
.woocommerce-cart-form a.remove {
  color: rgba(255,255,255,.3) !important;
  font-size: 1.3rem;
  line-height: 1;
  transition: .2s;
  text-decoration: none;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.1);
}
.woocommerce-cart-form a.remove:hover {
  color: #f87171 !important;
  border-color: rgba(248,113,113,.4);
  background: rgba(248,113,113,.08);
}

/* Quantity input */
.woocommerce .quantity .qty,
.woocommerce input.qty {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  color: var(--white);
  padding: .5rem .8rem;
  width: 70px;
  text-align: center;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .95rem;
  transition: .2s;
}
.woocommerce .quantity .qty:focus,
.woocommerce input.qty:focus {
  border-color: var(--purple);
  outline: none;
  background: rgba(108,59,255,.08);
}

/* Price cells */
.woocommerce-cart-form .product-price,
.woocommerce-cart-form .product-subtotal {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--white);
}
.woocommerce-cart-form .product-subtotal { color: var(--neon); }

/* Coupon + update row */
.woocommerce-cart-form .actions {
  padding: 1.2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  background: rgba(255,255,255,.02);
}
.woocommerce-cart-form .coupon { display: flex; gap: .6rem; flex-wrap: wrap; }
.woocommerce-cart-form .coupon input#coupon_code {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--glass-border);
  border-radius: 50px;
  color: var(--white);
  padding: .6rem 1.2rem;
  font-size: .88rem;
  width: 200px;
  transition: .2s;
}
.woocommerce-cart-form .coupon input#coupon_code::placeholder { color: rgba(255,255,255,.3); }
.woocommerce-cart-form .coupon input#coupon_code:focus {
  border-color: var(--purple);
  outline: none;
  background: rgba(108,59,255,.08);
}

/* Cart totals box */
.cart_totals {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2rem;
  max-width: 440px;
  margin-left: auto;
  position: relative;
}
.cart_totals::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient);
  border-radius: 20px 20px 0 0;
}
.cart_totals h2 {
  font-family: var(--font-head);
  font-size: 1.3rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
  color: var(--white);
}
.cart_totals table.shop_table_responsive {
  background: none;
  border: none;
  border-radius: 0;
  margin-bottom: 1.5rem;
}
.cart_totals table.shop_table_responsive tr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .8rem 0;
  border-bottom: 1px solid var(--glass-border);
}
.cart_totals table.shop_table_responsive tr:last-child { border-bottom: none; }
.cart_totals table.shop_table_responsive th {
  color: var(--muted);
  font-size: .88rem;
  font-weight: 500;
  background: none;
  padding: 0;
  border: none;
  letter-spacing: 0;
  text-transform: none;
}
.cart_totals table.shop_table_responsive td {
  color: var(--white);
  font-family: var(--font-body);
  font-weight: 600;
  background: none;
  padding: 0;
  border: none;
  text-align: right;
}
.cart_totals .order-total th,
.cart_totals .order-total td {
  font-size: 1.1rem;
  color: var(--white);
}
.cart_totals .order-total td { color: var(--neon); font-size: 1.3rem; }

/* Proceed to checkout button */
.wc-proceed-to-checkout .checkout-button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--gradient) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: .85rem 2rem !important;
  font-family: var(--font-body) !important;
  font-size: .95rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: .25s !important;
  text-decoration: none !important;
  display: inline-block !important;
  box-shadow: 0 0 28px rgba(108,59,255,.35) !important;
  width: 100% !important;
  text-align: center !important;
}
.wc-proceed-to-checkout .checkout-button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  opacity: .88 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 0 45px rgba(108,59,255,.55) !important;
}
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: var(--gradient) !important;
}

/* Empty cart */
.woocommerce-cart .cart-empty {
  text-align: center;
  padding: 5rem 0;
  color: var(--muted);
  font-size: 1.1rem;
}
.woocommerce-cart .return-to-shop {
  text-align: center;
  margin-top: 1.5rem;
}

/* ═══════════════════════════════════════════════════
   CHECKOUT PAGE
═══════════════════════════════════════════════════ */
.woocommerce-checkout .woocommerce {
  padding: 120px 5% 80px;
  max-width: 1200px;
  margin: 0 auto;
}
.woocommerce-checkout h3 {
  font-family: var(--font-head);
  font-size: 1.2rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
  padding-bottom: .8rem;
  border-bottom: 1px solid var(--glass-border);
  color: var(--white);
}
.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review_heading {
  color: var(--white);
}
.woocommerce-checkout .col2-set {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2rem;
}

/* Checkout form layout */
.woocommerce form .form-row {
  margin-bottom: 1.2rem;
}
.woocommerce form .form-row label {
  display: block;
  color: rgba(255,255,255,.7);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .04em;
  margin-bottom: .45rem;
  text-transform: uppercase;
}
.woocommerce form .form-row label .required { color: var(--neon); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  color: var(--white) !important;
  padding: .75rem 1rem !important;
  font-family: var(--font-body) !important;
  font-size: .9rem !important;
  width: 100% !important;
  transition: .2s !important;
  -webkit-appearance: none;
  box-sizing: border-box;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--purple) !important;
  outline: none !important;
  background: rgba(108,59,255,.08) !important;
  box-shadow: 0 0 0 3px rgba(108,59,255,.15) !important;
}
.woocommerce form .form-row input.input-text::placeholder,
.woocommerce form .form-row textarea::placeholder { color: rgba(255,255,255,.25) !important; }
.woocommerce form .form-row select option { background: #1a0a2e; color: var(--white); }

/* Select2 dropdowns */
.select2-container--default .select2-selection--single {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  height: 44px !important;
  padding: .65rem 1rem !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--white) !important;
  line-height: 1.4 !important;
  padding: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 44px !important;
  top: 0 !important;
  right: .5rem !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: var(--muted) transparent transparent !important;
}
.select2-dropdown {
  background: #1a0a2e !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  overflow: hidden;
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background: rgba(108,59,255,.3) !important;
  color: var(--white) !important;
}
.select2-container--default .select2-results__option {
  color: var(--muted) !important;
  padding: .6rem 1rem !important;
}

/* Order review panel */
#order_review {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2rem;
  position: relative;
}
#order_review::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient);
  border-radius: 20px 20px 0 0;
}
#order_review_heading {
  font-family: var(--font-head);
  font-size: 1.2rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
  color: var(--white);
}
table#order_review,
.woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5rem;
  background: none;
  border: none;
}
.woocommerce-checkout-review-order-table thead th {
  color: var(--neon);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .6rem 0;
  border-bottom: 1px solid var(--glass-border);
  background: none;
}
.woocommerce-checkout-review-order-table tbody td,
.woocommerce-checkout-review-order-table tfoot td,
.woocommerce-checkout-review-order-table tfoot th {
  padding: .8rem 0;
  border-bottom: 1px solid var(--glass-border);
  color: var(--white);
  font-size: .9rem;
  background: none;
}
.woocommerce-checkout-review-order-table tfoot .order-total td {
  font-family: var(--font-body);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--neon);
  border-bottom: none;
}
.woocommerce-checkout-review-order-table tfoot .order-total th {
  font-size: .95rem;
  border-bottom: none;
}

/* Payment methods */
#payment {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1.5rem;
  margin-top: 1.5rem;
}
#payment .wc_payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
}
#payment .wc_payment_methods li {
  padding: .8rem;
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  margin-bottom: .6rem;
  transition: .2s;
}
#payment .wc_payment_methods li:has(input:checked),
#payment .wc_payment_methods li.payment_method_selected {
  border-color: var(--purple);
  background: rgba(108,59,255,.08);
}
#payment .wc_payment_methods li label {
  color: var(--white) !important;
  font-weight: 500;
  cursor: pointer;
  text-transform: none !important;
  font-size: .95rem !important;
  letter-spacing: 0 !important;
}
#payment .payment_box {
  background: rgba(255,255,255,.03);
  border-radius: 10px;
  padding: .8rem;
  margin-top: .8rem;
  color: var(--muted);
  font-size: .85rem;
}
#payment div.place-order {
  padding: 0;
  background: none;
  margin-top: 1.2rem;
}

/* Terms & conditions checkbox */
.woocommerce-terms-and-conditions-wrapper {
  margin-bottom: 1.2rem;
  color: var(--muted);
  font-size: .85rem;
}
.woocommerce-terms-and-conditions-wrapper a {
  color: var(--neon);
  text-decoration: none;
}

/* Checkbox inputs */
.woocommerce form .form-row input[type="checkbox"] {
  width: auto !important;
  border-radius: 4px !important;
  accent-color: var(--purple);
}

/* ═══════════════════════════════════════════════════
   MY ACCOUNT — ENHANCED
═══════════════════════════════════════════════════ */
.woocommerce-account .woocommerce {
  padding: 100px 5% 80px;
  max-width: 1100px;
  margin: 0 auto;
}

/* Page title (Orders, Downloads, etc.) */
.woocommerce-account .woocommerce ~ h1,
.woocommerce-account h1.entry-title,
.woocommerce-account .page-title {
  font-family: var(--font-head);
  font-size: 1.4rem !important;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 1.5rem;
  letter-spacing: -.3px;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
  margin-bottom: 2.5rem;
}
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  padding: 0;
  margin: 0;
}
.woocommerce-MyAccount-navigation ul li a {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  color: var(--muted);
  padding: .6rem 1.4rem;
  border-radius: 50px;
  text-decoration: none;
  font-size: .88rem;
  font-weight: 500;
  transition: .2s;
  display: block;
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover {
  background: rgba(108,59,255,.18);
  border-color: var(--purple);
  color: var(--white);
}

/* Account content area */
.woocommerce-MyAccount-content {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 2.5rem;
  position: relative;
  min-height: 200px;
}
.woocommerce-MyAccount-content::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient);
  border-radius: 20px 20px 0 0;
}
.woocommerce-MyAccount-content p { color: var(--muted); line-height: 1.7; font-size: .9rem; }
.woocommerce-MyAccount-content a { color: var(--neon); text-decoration: none; }
.woocommerce-MyAccount-content a:hover { color: var(--white); }

/* Orders table */
.woocommerce-account table.woocommerce-orders-table,
.woocommerce-account table.woocommerce-MyAccount-orders {
  width: 100%;
  border-collapse: collapse;
  background: none;
  border: none;
}
.woocommerce-account table.woocommerce-orders-table thead th,
.woocommerce-account table.woocommerce-MyAccount-orders thead th {
  color: var(--neon);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .7rem 1rem;
  border-bottom: 1px solid var(--glass-border);
  background: rgba(108,59,255,.06);
  text-align: left;
}
.woocommerce-account table.woocommerce-orders-table tbody td,
.woocommerce-account table.woocommerce-MyAccount-orders tbody td {
  padding: 1rem;
  border-bottom: 1px solid var(--glass-border);
  color: var(--muted);
  font-size: .9rem;
  vertical-align: middle;
}
.woocommerce-account table.woocommerce-orders-table tbody tr:last-child td,
.woocommerce-account table.woocommerce-MyAccount-orders tbody tr:last-child td {
  border-bottom: none;
}
.woocommerce-account table.woocommerce-orders-table tbody tr:hover td,
.woocommerce-account table.woocommerce-MyAccount-orders tbody tr:hover td {
  background: rgba(255,255,255,.02);
}

/* Order status badges */
.woocommerce-account .woocommerce-orders-table__cell-order-status mark,
.woocommerce-account mark.order-status {
  background: rgba(108,59,255,.15);
  color: var(--neon);
  padding: .25rem .75rem;
  border-radius: 50px;
  font-size: .75rem;
  font-weight: 700;
}
.woocommerce-account mark.order-status.complete,
.woocommerce-account mark.order-status.completed {
  background: rgba(34,197,94,.12);
  color: #4ade80;
}
.woocommerce-account mark.order-status.processing {
  background: rgba(59,130,246,.12);
  color: #60a5fa;
}
.woocommerce-account mark.order-status.on-hold {
  background: rgba(245,158,11,.12);
  color: #fbbf24;
}
.woocommerce-account mark.order-status.cancelled,
.woocommerce-account mark.order-status.refunded,
.woocommerce-account mark.order-status.failed {
  background: rgba(248,113,113,.12);
  color: #f87171;
}

/* Account forms */
.woocommerce-account .woocommerce-EditAccountForm fieldset {
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.woocommerce-account .woocommerce-EditAccountForm legend {
  color: var(--neon);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 0 .5rem;
}



/* Breadcrumb spans both columns */
.product-breadcrumb {
  grid-column: 1 / -1;
  padding: .5rem 0 .6rem;
  border-bottom: 1px solid var(--glass-border);
  margin-bottom: 1.2rem;
}
.product-breadcrumb .woocommerce-breadcrumb { padding: 0; margin: 0; }

/* Gallery column */
.product-gallery-col {
  grid-column: 1;
  grid-row: 2;
}

/* Summary column */
.single-product .summary.entry-summary {
  grid-column: 2;
  grid-row: 2;
  padding-top: 0;
}

/* Gallery */
.woocommerce-product-gallery {
  position: sticky;
  top: 96px;
}
.woocommerce-product-gallery__wrapper img {
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  width: 100%;
  object-fit: cover;
  background: var(--navy2);
}
/* No-image placeholder */
.woocommerce-product-gallery .woocommerce-product-gallery__image--placeholder,
.woocommerce-product-gallery img.wp-post-image[src*="placeholder"] {
  background: var(--glass) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 16px !important;
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.woocommerce-product-gallery .woocommerce-product-gallery__image a {
  display: block;
  background: var(--navy2);
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
}
.flex-control-thumbs {
  display: flex;
  gap: .5rem;
  margin-top: .7rem;
  flex-wrap: wrap;
}
.flex-control-thumbs li { list-style: none; }
.flex-control-thumbs li img {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--glass-border);
  cursor: pointer;
  opacity: .6;
  transition: .2s;
}
.flex-control-thumbs li img.flex-active,
.flex-control-thumbs li img:hover {
  opacity: 1;
  border-color: var(--purple);
}

/* ── Product title — bigger, bolder ── */
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  font-family: var(--font-body) !important;
  font-size: clamp(1.4rem, 2.2vw, 1.9rem) !important;
  font-weight: 600 !important;
  letter-spacing: -.3px !important;
  line-height: 1.25 !important;
  margin-bottom: .5rem !important;
  color: var(--white) !important;
}

/* Category label above title */
.single-product .summary .posted_in {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--neon);
  font-weight: 600;
  margin-bottom: .4rem;
  display: block;
}

/* Rating row */
.single-product .summary .woocommerce-product-rating {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-bottom: .8rem;
}
.single-product .summary .woocommerce-review-link {
  color: var(--muted);
  font-size: .8rem;
  text-decoration: none;
}

/* Price */
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--font-body) !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  letter-spacing: -.3px !important;
  margin-bottom: .8rem !important;
  display: block !important;
}
.single-product .summary .price ins {
  color: var(--neon);
  text-decoration: none;
  background: none;
  -webkit-text-fill-color: var(--neon);
}
.single-product .summary .price del {
  color: rgba(255,255,255,.3);
  font-size: 1rem;
  margin-right: .4rem;
  -webkit-text-fill-color: rgba(255,255,255,.3);
}

/* Short description */
.single-product .summary .woocommerce-product-details__short-description {
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 1.2rem;
  font-size: .88rem;
  border-left: 3px solid rgba(108,59,255,.5);
  padding-left: .8rem;
}

/* Add to cart row */
.single-product .summary form.cart {
  display: flex;
  gap: .8rem;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 1rem;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1rem 1.2rem;
}
.single-product .summary .single_add_to_cart_button {
  flex: 1;
  min-width: 160px;
  background: var(--gradient) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: .85rem 1.8rem !important;
  font-family: var(--font-body) !important;
  font-size: .95rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: .25s !important;
  box-shadow: 0 0 24px rgba(108,59,255,.4) !important;
  text-align: center !important;
  width: auto !important;
}
.single-product .summary .single_add_to_cart_button:hover {
  opacity: .88 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 0 40px rgba(108,59,255,.6) !important;
}

/* ── Variable product — refined variations section ── */
.single-product .summary form.cart.variations_form {
  flex-direction: column;
  align-items: stretch;
  gap: 1.2rem;
  padding: 1.4rem 1.5rem;
}
/* Reset for simple product forms */
.single-product .summary form.cart:not(.variations_form) {
  padding: 1rem 1.4rem;
}

/* Variation table */
.single-product .summary table.variations {
  width: 100%;
  margin: 0;
  border: none;
  background: transparent;
}
.single-product .summary table.variations tbody,
.single-product .summary table.variations tr {
  display: block;
}
.single-product .summary table.variations tr + tr {
  margin-top: 1rem;
}
.single-product .summary table.variations td {
  display: block;
  padding: 0;
  border: none;
  background: transparent;
}

/* Variation label */
.single-product .summary table.variations td.label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  padding-bottom: .35rem;
}
.single-product .summary table.variations td.label label {
  font-size: inherit;
  font-weight: inherit;
  text-transform: inherit;
  letter-spacing: inherit;
  color: inherit;
}

/* Variation dropdown — themed */
.single-product .summary table.variations td.value select {
  width: 100%;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: .75rem 1rem;
  color: var(--white);
  font-family: var(--font-body);
  font-size: .92rem;
  outline: none;
  cursor: pointer;
  transition: border-color .2s, background .2s;
}
.single-product .summary table.variations td.value select:hover {
  border-color: rgba(255,255,255,.15);
}
.single-product .summary table.variations td.value select:focus {
  border-color: var(--purple);
  background: rgba(108,59,255,.06);
}
.single-product .summary table.variations td.value select option {
  background: var(--navy2);
  color: var(--white);
}

/* Reset link */
.single-product .summary .reset_variations {
  display: inline-block;
  font-size: .75rem;
  color: var(--muted);
  text-decoration: none;
  margin-top: .45rem;
  transition: color .2s;
}
.single-product .summary .reset_variations:hover {
  color: var(--neon);
}

/* Variation wrapper & price */
.single-product .summary .single_variation_wrap {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.single-product .summary .woocommerce-variation-price {
  min-height: 2.2rem;
}
.single-product .summary .woocommerce-variation-price .price {
  margin-bottom: 0 !important;
}

/* Variation add-to-cart row */
.single-product .summary .woocommerce-variation-add-to-cart {
  display: flex;
  align-items: center;
  gap: .9rem;
  flex-wrap: wrap;
}
.single-product .summary .woocommerce-variation-add-to-cart .quantity {
  flex-shrink: 0;
}

/* Product meta */
.single-product .summary .product_meta {
  border-top: 1px solid var(--glass-border);
  padding-top: .8rem;
  font-size: .78rem;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: .4rem .8rem;
}
.single-product .summary .product_meta span { display: inline-flex; align-items: center; gap: .3rem; }
.single-product .summary .product_meta span a { color: var(--neon); text-decoration: none; }

/* Tabs */
.woocommerce-tabs {
  padding: 0 6% 30px;
  max-width: none;
  margin: 0;
}
.woocommerce-tabs ul.tabs {
  display: flex !important;
  gap: .3rem !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  border-bottom: none !important;
  background: transparent !important;
  position: relative;
}
/* Underline track */
.woocommerce-tabs ul.tabs::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--glass-border);
  z-index: 0;
}
.woocommerce-tabs ul.tabs li {
  padding: .7rem 1.4rem !important;
  border-radius: 0 !important;
  cursor: pointer;
  color: var(--muted) !important;
  font-weight: 500 !important;
  font-size: .88rem !important;
  transition: color .2s;
  border: none !important;
  background: transparent !important;
  position: relative;
  z-index: 1;
  margin: 0 !important;
}
/* Animated underline indicator */
.woocommerce-tabs ul.tabs li::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 50% !important;
  right: 50% !important;
  height: 2px !important;
  background: var(--gradient) !important;
  border-radius: 2px 2px 0 0 !important;
  transition: left .25s ease, right .25s ease, opacity .25s ease !important;
  opacity: 0 !important;
  z-index: 2 !important;
}
.woocommerce-tabs ul.tabs li::before { display: none !important; }
.woocommerce-tabs ul.tabs li a {
  color: inherit !important;
  text-decoration: none !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  background: transparent !important;
}
.woocommerce-tabs ul.tabs li:hover {
  color: var(--white) !important;
  background: transparent !important;
  border: none !important;
}
.woocommerce-tabs ul.tabs li:hover::after {
  left: 20% !important;
  right: 20% !important;
  opacity: .35 !important;
}
.woocommerce-tabs ul.tabs li.active {
  color: var(--white) !important;
  font-weight: 600 !important;
  background: transparent !important;
  border: none !important;
}
.woocommerce-tabs ul.tabs li.active a {
  color: var(--white) !important;
  background: transparent !important;
}
.woocommerce-tabs ul.tabs li.active::after {
  left: 0 !important;
  right: 0 !important;
  opacity: 1 !important;
}

/* Panel */
.woocommerce-tabs .panel {
  background: var(--glass) !important;
  border: 1px solid var(--glass-border) !important;
  border-top: none !important;
  border-radius: 0 0 16px 16px !important;
  padding: 2rem !important;
  color: var(--muted) !important;
  line-height: 1.75;
  animation: tabFadeIn .25s ease forwards;
}
@keyframes tabFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.woocommerce-tabs .panel h2 {
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--white);
}

/* ── Review / comment form inside tabs ── */
.woocommerce-Reviews #reviews { color: var(--muted); }
.woocommerce-Reviews #reviews h3,
.woocommerce-Reviews #reviews #reply-title {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: .8rem;
}
/* Star rating selector */
.woocommerce-Reviews .stars a,
.woocommerce #review_form .stars a {
  color: var(--muted) !important;
  font-size: 1.2rem;
  text-decoration: none;
  transition: .15s;
}
.woocommerce-Reviews .stars a:hover,
.woocommerce-Reviews .stars a.active,
.woocommerce #review_form .stars a:hover,
.woocommerce #review_form .stars a.active,
.woocommerce #review_form .stars.selected a {
  color: #f59e0b !important;
}
/* Review textarea & inputs */
.woocommerce-Reviews textarea,
.woocommerce #review_form textarea,
.woocommerce-Reviews input[type="text"],
.woocommerce-Reviews input[type="email"],
.woocommerce #review_form input[type="text"],
.woocommerce #review_form input[type="email"] {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  color: var(--white) !important;
  font-family: var(--font-body) !important;
  font-size: .88rem !important;
  padding: .8rem 1rem !important;
  width: 100% !important;
  outline: none !important;
  transition: border-color .2s !important;
  resize: vertical;
}
.woocommerce-Reviews textarea:focus,
.woocommerce #review_form textarea:focus,
.woocommerce-Reviews input:focus,
.woocommerce #review_form input:focus {
  border-color: var(--purple) !important;
  background: rgba(108,59,255,.06) !important;
}
/* Submit button */
.woocommerce-Reviews #submit,
.woocommerce #review_form #submit {
  background: var(--gradient) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: .75rem 2rem !important;
  font-family: var(--font-body) !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: .2s !important;
  box-shadow: 0 0 20px rgba(108,59,255,.35) !important;
  width: auto !important;
}
.woocommerce-Reviews #submit:hover,
.woocommerce #review_form #submit:hover {
  opacity: .88 !important;
  transform: translateY(-1px) !important;
}
/* Form labels */
.woocommerce-Reviews label,
.woocommerce #review_form label {
  color: var(--muted) !important;
  font-size: .8rem !important;
  font-weight: 500 !important;
  display: block !important;
  margin-bottom: .35rem !important;
}
/* "No reviews yet" text */
.woocommerce-Reviews #reviews p { color: var(--muted); font-size: .88rem; }
/* Star rating display (existing reviews) */
.woocommerce .star-rating,
.woocommerce .star-rating span::before {
  color: #f59e0b !important;
}
/* Required asterisk */
.woocommerce-Reviews .required { color: var(--neon); }

/* Related products */
.related.products {
  padding: 0 6% 40px;
  max-width: none;
  margin: 0;
}
.related.products h2 {
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 800;
  margin-bottom: 1rem;
  color: var(--white);
}
.related.products ul.products {
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
}

/* ═══════════════════════════════════════════════════
   COMPREHENSIVE MOBILE RESPONSIVE
═══════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  /* Checkout columns stack */
  .woocommerce-checkout .col2-set {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .woocommerce-product-gallery { position: static; }
  /* Cart totals full width */
  .cart_totals { max-width: 100%; }
}

@media (max-width: 768px) {
  /* Nav */
  nav#site-navigation { height: 70px; padding: 0 4%; }
  .nav-logo { font-size: 1.4rem; }
  .custom-logo-link img.custom-logo { max-height: 42px; }
  .main-navigation, .nav-links { display: none !important; }
  .hamburger { display: flex; }

  /* Store filters scroll */
  .store-filters {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: .75rem;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
  }
  .store-filters::-webkit-scrollbar { display: none; }
  .filter-btn { white-space: nowrap; flex-shrink: 0; font-size: .82rem; padding: 12px 18px; min-height: 44px; }
  .store-filters { gap: .5rem; margin-bottom: 1.5rem; }

  /* Shop toolbar — tighter spacing */
  .woo-shop-top { margin-bottom: 1.25rem; gap: .7rem; }
  .woocommerce-ordering select {
    font-size: .82rem;
    padding: .45rem 2rem .45rem .85rem;
  }
  .woocommerce-result-count { font-size: .8rem; }

  /* Product grid — 2 columns */
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1rem !important;
  }

  /* Cart table scrollable on mobile */
  .woocommerce-cart-form { overflow-x: auto; }
  .woocommerce-cart-form table.shop_table { min-width: 560px; }

  /* Account nav wraps */
  .woocommerce-MyAccount-navigation ul { gap: .4rem; }
  .woocommerce-MyAccount-navigation ul li a { padding: .5rem 1rem; font-size: .82rem; }
  .woocommerce-MyAccount-content { padding: 1.5rem; }

  /* Account orders table scroll */
  .woocommerce-account .woocommerce-orders-table,
  .woocommerce-account .woocommerce-MyAccount-orders {
    overflow-x: auto;
    display: block;
  }

  /* Checkout col padding */
  .woocommerce-checkout .col2-set .col-1,
  .woocommerce-checkout .col2-set .col-2 {
    padding: 1.5rem;
  }

  /* Single product — keep title readable on tablet */
  .single-product .summary .product_title { font-size: 1.5rem !important; }
  .single-product .summary .price { font-size: 1.4rem !important; }
  .woocommerce-tabs { padding: 0 4% 30px; }

  /* Hero padding adjustment for smaller nav */
  .hero { padding-top: 100px; }
  section { padding: 26px 4%; }

  /* Trust badges in shop */
  .shop-trust { grid-template-columns: repeat(2, 1fr); }

  /* Pagination circles slightly smaller */
  .hpag-item, .page-numbers { width: 40px; height: 40px; font-size: .85rem; }
  .hpag-current { transform: none; }
}

@media (max-width: 480px) {
  /* Product grid — 1 column on very small */
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr !important;
  }

  /* Hero */
  .hero h1 { font-size: 2rem; letter-spacing: -1px; }
  .hero-btns { flex-direction: column; }
  .btn-primary, .btn-outline { text-align: center; }
  .hero-stats { flex-direction: row; gap: .5rem; text-align: center; justify-content: center; }
  .hero-stat { flex: 1; min-width: 0; }
  .hero-stat .num { font-size: 1.4rem; }
  .hero-stat .label { font-size: .65rem; }

  /* Footer — 3 link columns side-by-side, brand full-width */
  .footer-grid { grid-template-columns: 1fr 1fr 1fr !important; }
  .footer-brand { grid-column: 1 / -1; }

  /* Cart / checkout single column */
  .woocommerce-cart-form table.shop_table { min-width: 420px; }
  .woocommerce-checkout h3 { font-size: 1rem; }

  /* Shop trust single column on small phones */
  .shop-trust { grid-template-columns: 1fr; margin-top: 1.5rem; }
  .shop-trust__item { padding: 1.25rem 1rem; }
  .shop-trust__icon { font-size: 1.5rem; }

  /* Product card price / button row */
  .hpc-price { font-size: 1.1rem; }
  .hpc-price del .woocommerce-Price-amount { font-size: .65rem; }
  .hpc-btn { height: 38px; padding: 0 14px; font-size: .8rem; }

  /* Nav */
  nav#site-navigation { height: 64px; }
  .nav-logo { font-size: 1.2rem; }
  .nav-cta { display: none; }

  /* Single product */
  .single-product .summary form.cart { flex-direction: column; }
  .single-product .summary .single_add_to_cart_button { min-width: 0; width: 100% !important; }

  /* Tabs horizontal scroll */
  .woocommerce-tabs ul.tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    scrollbar-width: none;
  }
  .woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
  .woocommerce-tabs ul.tabs li { white-space: nowrap; }

  /* Account */
  .woocommerce-account .woocommerce { padding: 100px 4% 60px; }
  .woocommerce-MyAccount-content { padding: 1.2rem; }

  /* Service page */
  .srv-lead-trust-cards { grid-template-columns: 1fr !important; }
}

/* ═══════════════════════════════════════════════════
   SINGLE PRODUCT — TRUST BAR & RESPONSIVE
═══════════════════════════════════════════════════ */
.single-product-trust {
  background: var(--navy);
  padding: 20px 6% 30px;
}
.single-product-trust__inner {
  max-width: none;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  padding: 1.2rem 1.5rem;
}
.spt-item {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .3rem;
}
.spt-icon  { font-size: 1.4rem; }
.spt-label { font-weight: 700; font-size: .82rem; font-family: var(--font-head); }
.spt-sub   { color: var(--muted); font-size: .72rem; }

@media (max-width: 900px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 1rem 0;
    padding: 88px 5% 20px;
  }
  .product-gallery-col  { grid-column: 1; grid-row: 2; }
  .single-product .summary.entry-summary { grid-column: 1; grid-row: 3; }
  .woocommerce-product-gallery { position: static; }
  .single-product-trust__inner { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .single-product-trust__inner { grid-template-columns: 1fr 1fr; gap: .8rem; padding: 1rem; }
  .single-product .summary .product_title,
  .woocommerce div.product .product_title { font-size: 1.3rem !important; }
}

/* ═══════════════════════════════════════════════════
   NAV — ICON BUTTONS (cart + account)
═══════════════════════════════════════════════════ */
.nav-icon-btn {
  position: relative;
  background: rgba(138,92,246,.06);
  border: 1px solid var(--glass-border);
  color: var(--muted);
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: .25s;
  flex-shrink: 0;
}
.nav-icon-btn:hover,
.nav-icon-btn[aria-expanded="true"] {
  color: var(--white);
  border-color: var(--purple);
  background: rgba(124,58,237,.15);
}
/* Cart count badge on the button */
.nav-cart-btn .cart-count {
  position: absolute;
  top: -6px;
  right: -6px;
  width: 18px;
  height: 18px;
  font-size: .62rem;
  background: var(--gradient);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  border: 2px solid var(--black);
  line-height: 1;
}
.nav-cart-btn .cart-count:empty,
.nav-cart-btn .cart-count[data-count="0"] { display: none; }

/* ── Dropdown shared base ── */
.nav-account,
.nav-cart-wrap {
  position: relative;
}
.nav-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 240px;
  background: rgba(10,8,18,.97);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 1rem;
  box-shadow: 0 24px 60px rgba(0,0,0,.6), 0 0 40px rgba(108,59,255,.1);
  backdrop-filter: blur(24px);
  z-index: 1100;
  opacity: 0;
  transform: translateY(8px) scale(.97);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.nav-dropdown.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* ── Account dropdown ── */
.account-dropdown { min-width: 220px; }
.dropdown-header {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding-bottom: .8rem;
}
.dropdown-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--gradient);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head);
  font-weight: 700;
  font-size: .9rem;
  color: #fff;
  flex-shrink: 0;
}
.dropdown-name {
  font-weight: 600;
  font-size: .88rem;
  color: var(--white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 150px;
}
.dropdown-email {
  font-size: .75rem;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 150px;
}
.dropdown-divider {
  height: 1px;
  background: var(--glass-border);
  margin: .5rem 0;
}
.dropdown-item {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .55rem .6rem;
  border-radius: 8px;
  color: var(--muted);
  text-decoration: none;
  font-size: .85rem;
  font-weight: 500;
  transition: .15s;
}
.dropdown-item svg { flex-shrink: 0; opacity: .7; }
.dropdown-item:hover {
  background: rgba(124,58,237,.12);
  color: var(--white);
}
.dropdown-item:hover svg { opacity: 1; }
.dropdown-item--danger { color: #f87171; }
.dropdown-item--danger:hover { background: rgba(248,113,113,.1); color: #f87171; }

/* ── Cart dropdown ── */
.cart-dropdown { min-width: 300px; padding: 0; overflow: hidden; }
.cart-dropdown-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.2rem .8rem;
  border-bottom: 1px solid var(--glass-border);
}
.cart-dropdown-title {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: .95rem;
  color: var(--white);
}
.cart-dropdown-header .harvang-cart-count-label {
  font-size: .75rem;
  color: var(--muted);
}
.cart-dropdown-items {
  max-height: 260px;
  overflow-y: auto;
  padding: .6rem .8rem;
  scrollbar-width: thin;
  scrollbar-color: var(--purple) transparent;
}
.cart-dropdown-items::-webkit-scrollbar { width: 3px; }
.cart-dropdown-items::-webkit-scrollbar-thumb { background: var(--purple); border-radius: 2px; }
.cart-item {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .6rem .4rem;
  border-bottom: 1px solid rgba(139,92,246,.08);
}
.cart-item:last-child { border-bottom: none; }
.cart-item-img {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
  font-size: 1.2rem;
}
.cart-item-img img { width: 100%; height: 100%; object-fit: cover; }
.cart-item-name {
  font-size: .82rem;
  font-weight: 600;
  color: var(--white);
  line-height: 1.3;
  margin-bottom: .2rem;
}
.cart-item-meta { font-size: .75rem; color: var(--muted); }
.cart-empty {
  text-align: center;
  padding: 2rem 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
}
.cart-empty p { color: var(--muted); font-size: .88rem; margin-bottom: .8rem; }
.cart-dropdown-footer {
  padding: .8rem 1.2rem 1rem;
  border-top: 1px solid var(--glass-border);
}
.cart-subtotal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .85rem;
  margin-bottom: .8rem;
}
.cart-subtotal span:first-child { color: var(--muted); }
.cart-subtotal .harvang-cart-subtotal {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--neon);
}

/* ── Mobile menu divider ── */
.mobile-menu-divider {
  width: 60px;
  height: 1px;
  background: var(--glass-border);
  margin: .5rem auto;
}

/* ═══════════════════════════════════════════════════
   PRODUCT TABLE LAYOUT
   Used on Business Accounts & Social Media categories
   Premium, scannable, dark theme
═══════════════════════════════════════════════════ */
.harvang-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 0 2rem;
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  box-shadow: 0 8px 40px rgba(0,0,0,.3), 0 0 0 1px rgba(108,59,255,.06);
  backdrop-filter: blur(12px);
}
.harvang-product-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  min-width: 560px;
}
/* ── Sticky header ── */
.harvang-product-table thead {
  position: sticky;
  top: 0;
  z-index: 2;
  background: rgba(15,15,22,.98);
  backdrop-filter: blur(12px);
}
.harvang-product-table th {
  padding: 1rem 1.2rem;
  text-align: left;
  font-size: .7rem;
  font-weight: 600;
  color: rgba(255,255,255,.45);
  text-transform: uppercase;
  letter-spacing: .08em;
  border-bottom: 1px solid rgba(255,255,255,.06);
  white-space: nowrap;
  user-select: none;
}
.harvang-product-table th:last-child,
.harvang-product-table td:last-child {
  text-align: right;
}
/* ── Body cells ── */
.harvang-product-table td {
  padding: 1rem 1.2rem;
  font-size: .88rem;
  color: var(--white);
  border-bottom: 1px solid rgba(255,255,255,.04);
  vertical-align: middle;
}
.harvang-product-table tbody tr:last-child td {
  border-bottom: none;
}
.harvang-product-table tbody tr {
  transition: background .2s;
}
/* Zebra alternating */
.harvang-product-table tbody tr:nth-child(even) {
  background: rgba(255,255,255,.02);
}
.harvang-product-table tbody tr:hover {
  background: rgba(108,59,255,.08);
}
/* ── Product cell (thumbnail + title) ── */
.hpt-product-cell {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.hpt-thumb {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.06);
}
.hpt-placeholder {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: rgba(108,59,255,.12);
  border: 1px solid rgba(108,59,255,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.hpt-title {
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
  font-size: .95rem;
  line-height: 1.35;
  transition: color .2s;
}
.hpt-title:hover {
  color: var(--neon);
}
/* ── Category ── */
.hpt-category {
  color: var(--muted);
  font-size: .8rem;
}
/* ── Stock badge ── */
.hpt-stock-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .8rem;
  font-weight: 500;
  padding: .25rem .65rem;
  border-radius: 50px;
  white-space: nowrap;
}
.hpt-stock-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.hpt-instock {
  background: rgba(34,197,94,.1);
  color: #4ade80;
}
.hpt-instock .hpt-stock-dot {
  background: #4ade80;
  box-shadow: 0 0 6px rgba(74,222,128,.5);
}
.hpt-outofstock {
  background: rgba(239,68,68,.08);
  color: #f87171;
}
.hpt-outofstock .hpt-stock-dot {
  background: #f87171;
}
/* ── Price ── */
.hpt-price {
  font-weight: 700;
  font-size: 1.05rem;
  white-space: nowrap;
  color: var(--white);
  font-family: var(--font-body);
  letter-spacing: -.02em;
}
/* ── Buy button ── */
.hpt-btn {
  display: inline-block;
  background: var(--gradient);
  color: #fff !important;
  text-decoration: none;
  font-size: .8rem;
  font-weight: 600;
  padding: .55rem 1.3rem;
  border-radius: 50px;
  transition: .25s;
  white-space: nowrap;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 15px rgba(108,59,255,.3);
}
.hpt-btn:hover {
  opacity: .9;
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(108,59,255,.4);
}
.hpt-btn--disabled {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.35) !important;
  cursor: default;
  box-shadow: none;
  pointer-events: none;
}
/* ── Mobile: Card layout (replaces table on <768px) ── */
@media (max-width: 768px) {
  .harvang-table-wrap {
    overflow: visible;
    background: transparent;
    border: none;
    box-shadow: none;
    backdrop-filter: none;
    border-radius: 0;
    margin: 0 0 1.5rem;
  }
  .harvang-product-table {
    min-width: 0;
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
  }
  .harvang-product-table thead {
    display: none;
  }
  .harvang-product-table tbody,
  .harvang-product-table tr,
  .harvang-product-table td {
    display: block;
  }
  .harvang-product-table tbody tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .4rem .65rem;
    background: var(--glass);
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: .75rem .9rem;
    margin-bottom: .6rem;
    transition: border-color .2s, background .2s;
    box-shadow: 0 2px 14px rgba(0,0,0,.15);
  }
  .harvang-product-table tbody tr:last-child {
    margin-bottom: 3.5rem;
  }
  .harvang-product-table tbody tr:nth-child(even) {
    background: var(--glass);
  }
  .harvang-product-table tbody tr:hover {
    background: rgba(108,59,255,.1);
    border-color: rgba(108,59,255,.2);
  }
  .harvang-product-table td {
    border: none;
    padding: 0;
    vertical-align: middle;
  }

  /* Hide category on mobile */
  .hpt-category { display: none; }

  /* ── Row 1: thumbnail + title (fill) ── */
  .hpt-name {
    flex: 1 1 auto;
    min-width: 0;
    order: 1;
  }
  .hpt-product-cell {
    display: flex;
    align-items: center;
    gap: .65rem;
  }
  .hpt-thumb,
  .hpt-placeholder {
    width: 40px;
    height: 40px;
    font-size: 1.05rem;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(108,59,255,.12);
  }
  .hpt-title {
    font-size: .92rem;
    font-weight: 600;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  /* ── Row 2: stock badge (left) + price (right) ── */
  .hpt-stock {
    flex: 0 0 auto;
    order: 2;
  }
  .hpt-price {
    flex: 1 1 auto;
    order: 2;
    margin-left: 0;
    text-align: right;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--white);
  }
  .hpt-stock-badge {
    font-size: .75rem;
    padding: .18rem .55rem;
  }

  /* ── Row 3: full-width action button ── */
  .hpt-action {
    flex: 0 0 100%;
    order: 3;
    margin-top: .35rem;
  }
  .hpt-btn {
    width: 100%;
    text-align: center;
    padding: .6rem .8rem;
    font-size: .84rem;
    font-weight: 600;
    border-radius: 10px;
    box-shadow: 0 4px 18px rgba(108,59,255,.3);
    transition: transform .15s, box-shadow .15s;
  }
  .hpt-btn:active {
    transform: scale(.97);
    box-shadow: 0 2px 10px rgba(108,59,255,.25);
  }
  .hpt-btn--disabled {
    box-shadow: none;
    transform: none !important;
  }
}

@media (max-width: 480px) {
  .harvang-product-table tbody tr {
    padding: .7rem .8rem;
    margin-bottom: .55rem;
    gap: .35rem .55rem;
    border-radius: 13px;
  }
  .harvang-product-table tbody tr:last-child {
    margin-bottom: 3.5rem;
  }
  .hpt-thumb,
  .hpt-placeholder {
    width: 36px;
    height: 36px;
    font-size: .95rem;
  }
  .hpt-product-cell { gap: .55rem; }
  .hpt-title { font-size: .86rem; }
  .hpt-price { font-size: .98rem; }
  .hpt-stock-badge { font-size: .72rem; padding: .16rem .5rem; }
  .hpt-btn { font-size: .82rem; padding: .55rem .75rem; }
  /* Tighter sort dropdown */
  .woocommerce-ordering select {
    font-size: .82rem;
    padding: .4rem .7rem;
  }
}

@media (max-width: 375px) {
  .harvang-product-table tbody tr {
    padding: .6rem .7rem;
    margin-bottom: .5rem;
    gap: .3rem .5rem;
    border-radius: 12px;
  }
  .harvang-product-table tbody tr:last-child {
    margin-bottom: 3.5rem;
  }
  .hpt-thumb,
  .hpt-placeholder {
    width: 30px;
    height: 30px;
    font-size: .85rem;
    border-radius: 8px;
  }
  .hpt-product-cell { gap: .5rem; }
  .hpt-title { font-size: .8rem; }
  .hpt-price { font-size: .9rem; }
  .hpt-stock-badge { font-size: .68rem; padding: .14rem .45rem; }
  .hpt-btn { font-size: .78rem; padding: .5rem .7rem; border-radius: 9px; }
}

/* ═══════════════════════════════════════════════════
   WOOCOMMERCE NOTICES — TOAST SYSTEM
   Notices are hidden on shop/product/cart/checkout
   and converted to toasts by JS.
   Account pages keep inline notices visible.
═══════════════════════════════════════════════════ */

/* Hide inline notices only on shop/product/cart/checkout pages */
.woocommerce-page:not(.woocommerce-account) .woocommerce-message,
.woocommerce-page:not(.woocommerce-account) .woocommerce-info,
.woocommerce-page:not(.woocommerce-account) .woocommerce-error,
.single-product .woocommerce-message,
.single-product .woocommerce-info,
.single-product .woocommerce-error {
  display: none !important;
}

/* Account page notices — show inline, styled to match theme */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error {
  display: block !important;
  background: rgba(108,59,255,.1) !important;
  border: 1px solid rgba(108,59,255,.25) !important;
  border-left: 3px solid var(--purple) !important;
  border-radius: 10px !important;
  color: var(--white) !important;
  padding: .8rem 1.2rem !important;
  margin-bottom: 1.2rem !important;
  font-size: .85rem !important;
  list-style: none !important;
}
.woocommerce-account .woocommerce-error {
  border-left-color: #f87171 !important;
  background: rgba(248,113,113,.08) !important;
  border-color: rgba(248,113,113,.2) !important;
}
.woocommerce-account .woocommerce-message::before,
.woocommerce-account .woocommerce-info::before { display: none !important; }

/* Toast container — fixed bottom-right */
.harvang-toast-wrap {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  pointer-events: none;
  max-width: 320px;
  width: calc(100vw - 3rem);
}

/* Individual toast */
.harvang-toast {
  pointer-events: auto;
  background: rgba(12, 9, 22, 0.97);
  border: 1px solid var(--glass-border);
  border-left: 3px solid var(--purple);
  border-radius: 12px;
  padding: .85rem 1rem .85rem 1rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.5), 0 0 20px rgba(108,59,255,.12);
  backdrop-filter: blur(20px);
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  animation: toastIn .25s ease forwards;
  position: relative;
  overflow: hidden;
}
.harvang-toast.toast-error  { border-left-color: #f87171; }
.harvang-toast.toast-info   { border-left-color: #60a5fa; }

@keyframes toastIn {
  from { opacity: 0; transform: translateX(20px) scale(.97); }
  to   { opacity: 1; transform: translateX(0)   scale(1);   }
}
@keyframes toastOut {
  from { opacity: 1; transform: translateX(0)   scale(1);   max-height: 120px; margin-bottom: 0; }
  to   { opacity: 0; transform: translateX(20px) scale(.97); max-height: 0;    margin-bottom: -.6rem; }
}
.harvang-toast.removing {
  animation: toastOut .25s ease forwards;
}

/* Icon */
.harvang-toast-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
  margin-top: .05rem;
}

/* Text area */
.harvang-toast-body { flex: 1; min-width: 0; }
.harvang-toast-text {
  font-size: .82rem;
  color: var(--white);
  line-height: 1.4;
  margin-bottom: .5rem;
  word-break: break-word;
}
.harvang-toast-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.harvang-toast-btn {
  font-size: .75rem;
  font-weight: 600;
  padding: .3rem .8rem;
  border-radius: 50px;
  text-decoration: none;
  transition: .15s;
  display: inline-block;
  white-space: nowrap;
}
.harvang-toast-btn-primary {
  background: var(--gradient);
  color: #fff;
  border: none;
}
.harvang-toast-btn-primary:hover { opacity: .85; color: #fff; }
.harvang-toast-btn-outline {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--glass-border);
}
.harvang-toast-btn-outline:hover { color: var(--white); border-color: var(--purple); }

/* Close button */
.harvang-toast-close {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 1rem;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  flex-shrink: 0;
  transition: .15s;
  margin-top: -.1rem;
}
.harvang-toast-close:hover { color: var(--white); }

/* Progress bar */
.harvang-toast-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  background: var(--gradient);
  border-radius: 0 0 0 12px;
  animation: toastProgress linear forwards;
}
@keyframes toastProgress {
  from { width: 100%; }
  to   { width: 0%; }
}

/* ── Responsive: hide account dropdown on mobile (use mobile menu instead) ── */
@media (max-width: 768px) {
  .nav-account { display: none; }
  .nav-cart-wrap .cart-dropdown { min-width: 280px; right: -10px; }
  .harvang-toast-wrap { bottom: 1rem; right: 1rem; max-width: 280px; }
}
@media (max-width: 380px) {
  .nav-cart-wrap .cart-dropdown { min-width: 260px; right: -4px; }
}

/* ═══════════════════════════════════════════════════
   QUANTITY INPUT — single product & cart
═══════════════════════════════════════════════════ */

/* Wrapper WooCommerce puts around qty + add-to-cart button */
.woocommerce .quantity,
form.cart .quantity {
	display: inline-flex !important;
	align-items: center !important;
	background: var(--glass) !important;
	border: 1px solid var(--glass-border) !important;
	border-radius: 50px !important;
	overflow: hidden !important;
	height: 48px !important;
	margin-right: .8rem !important;
}

/* The number input itself */
.woocommerce .quantity input.qty,
form.cart .quantity input.qty {
	width: 52px !important;
	height: 100% !important;
	background: transparent !important;
	border: none !important;
	color: var(--white) !important;
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  text-align: center !important;
  outline: none !important;
	-moz-appearance: textfield !important;
	padding: 0 !important;
}
.woocommerce .quantity input.qty::-webkit-inner-spin-button,
.woocommerce .quantity input.qty::-webkit-outer-spin-button {
	-webkit-appearance: none !important;
	margin: 0 !important;
}

/* ── Custom +/- buttons injected by JS ── */
.harvang-qty-btn {
	width: 38px;
	height: 100%;
	background: transparent;
	border: none;
	color: var(--muted);
	font-size: 1.2rem;
	font-weight: 700;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: .15s;
	flex-shrink: 0;
	line-height: 1;
	padding: 0;
	font-family: var(--font-body);
}
.harvang-qty-btn:hover { color: var(--white); background: rgba(124,58,237,.15); }
.harvang-qty-btn:active { background: rgba(124,58,237,.25); }

/* Cart page qty input (table row) */
.woocommerce-cart-form .quantity {
	border-radius: 10px !important;
	height: 42px !important;
}

/* ═══════════════════════════════════════════════════
   FLOATING WHATSAPP BUTTON
═══════════════════════════════════════════════════ */
.wa-float {
  position: fixed;
  bottom: 5rem;
  right: 1.8rem;
  left: auto;
  z-index: 9998;
  display: flex;
  align-items: center;
  gap: .6rem;
  background: #25d366;
  color: #fff;
  text-decoration: none;
  border-radius: 50px;
  padding: .75rem 1.2rem .75rem .9rem;
  box-shadow: 0 4px 24px rgba(37,211,102,.45), 0 2px 8px rgba(0,0,0,.3);
  transition: transform .25s ease, box-shadow .25s ease, padding .25s ease;
  max-width: 52px;
  overflow: hidden;
  white-space: nowrap;
}
.wa-float:hover {
  max-width: 200px;
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(37,211,102,.55), 0 4px 12px rgba(0,0,0,.3);
  color: #fff;
}
.wa-float-icon {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
}
.wa-float-label {
  font-family: var(--font-body);
  font-size: .88rem;
  font-weight: 600;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .2s ease .05s, transform .2s ease .05s;
  pointer-events: none;
}
.wa-float:hover .wa-float-label {
  opacity: 1;
  transform: translateX(0);
}

/* Pulse ring animation */
.wa-float::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50px;
  background: #25d366;
  animation: waPulse 2.5s ease-out infinite;
  z-index: -1;
}
@keyframes waPulse {
  0%   { transform: scale(1);   opacity: .6; }
  70%  { transform: scale(1.35); opacity: 0; }
  100% { transform: scale(1.35); opacity: 0; }
}

/* Don't overlap the toast notifications */
@media (max-width: 768px) {
  .wa-float {
    bottom: 1.2rem;
    right: 1.2rem;
    left: auto;
    padding: .7rem;
    max-width: 46px;
  }
  .wa-float:hover { max-width: 46px; }
  .wa-float-label { display: none; }
}


/* PREMIUM SINGLE PRODUCT REFRESH */
.single-product div.product {
  background: radial-gradient(ellipse 70% 45% at 20% 0%, rgba(124,58,237,.14), transparent 62%), var(--black);
}
.single-product #product-wrap {
  width: min(1440px, 100%);
  margin: 0 auto !important;
  padding: 112px 5% 26px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 45%) minmax(0, 55%) !important;
  gap: 20px 52px !important;
  align-items: start !important;
}
.single-product .product-breadcrumb {
  grid-column: 1 / -1 !important;
  padding: 0 0 12px !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(139,92,246,.14) !important;
}
.single-product .product-gallery-col,
.single-product .summary.entry-summary {
  min-width: 0;
}
.single-product .product-gallery-col {
  grid-column: 1 !important;
  grid-row: 2 !important;
}
.single-product .summary.entry-summary {
  grid-column: 2 !important;
  grid-row: 2 !important;
  padding: 6px 0 0 !important;
}
.single-product .woocommerce-product-gallery {
  position: sticky;
  top: 108px;
  width: 100% !important;
}
.single-product .woocommerce-product-gallery .woocommerce-product-gallery__image a,
.single-product .woocommerce-product-gallery__wrapper img {
  border-radius: 18px !important;
  border: 1px solid rgba(167,139,250,.18) !important;
  background: linear-gradient(145deg, #12091f, #07050d) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.35), 0 0 50px rgba(124,58,237,.12) !important;
}
.single-product .woocommerce-product-gallery__wrapper img {
  width: 100% !important;
  min-height: clamp(440px, 54vw, 720px) !important;
  object-fit: cover !important;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs {
  gap: 10px !important;
  margin: 12px 0 0 !important;
  padding: 0 !important;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs li {
  width: 72px !important;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs li img {
  width: 72px !important;
  height: 72px !important;
  border-radius: 12px !important;
}
.single-product .summary .posted_in {
  margin: 0 0 10px !important;
  color: var(--neon) !important;
  font-size: .72rem !important;
  letter-spacing: .14em !important;
}
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  font-size: clamp(2.15rem, 3.2vw, 3.6rem) !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
  margin: 0 0 18px !important;
  max-width: 760px;
}
.single-product .summary .woocommerce-product-rating {
  margin: 0 0 18px !important;
}
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: clamp(1.9rem, 2.4vw, 2.55rem) !important;
  line-height: 1 !important;
  margin: 0 0 22px !important;
}
.single-product .summary .woocommerce-product-details__short-description {
  max-width: 690px;
  margin: 0 0 26px !important;
  padding: 0 0 0 18px !important;
  border-left: 2px solid rgba(196,181,253,.45) !important;
  color: rgba(245,240,255,.72) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
}
.single-product .summary form.cart {
  display: grid !important;
  grid-template-columns: auto minmax(220px, 1fr) !important;
  gap: 14px !important;
  align-items: stretch !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
}
.single-product .summary form.cart .quantity,
.single-product .summary form.cart .qty {
  height: 54px !important;
}
.single-product .summary form.cart .qty {
  width: 92px !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.045) !important;
}
.single-product .summary .single_add_to_cart_button {
  min-height: 54px !important;
  border-radius: 12px !important;
  font-size: 1rem !important;
  box-shadow: 0 18px 42px rgba(124,58,237,.28) !important;
}
.single-product .single-product-trust {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 0 20px !important;
}
.single-product .single-product-trust__inner {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 12px !important;
  border-radius: 14px !important;
  background: rgba(139,92,246,.055) !important;
  border: 1px solid rgba(139,92,246,.14) !important;
}
.single-product .spt-item {
  min-height: 58px;
  padding: 10px 8px;
  border-radius: 10px;
  background: rgba(255,255,255,.025);
  text-align: left !important;
  align-items: flex-start !important;
  justify-content: center;
  gap: 4px !important;
}
.single-product .spt-icon {
  width: 6px;
  height: 6px;
  margin-bottom: 4px;
  border-radius: 999px;
  overflow: hidden;
  color: transparent;
  background: var(--neon);
  box-shadow: 0 0 14px rgba(196,181,253,.7);
}
.single-product .spt-label {
  font-family: var(--font-body) !important;
  font-size: .75rem !important;
  line-height: 1.25 !important;
  color: var(--white) !important;
}
.single-product .spt-sub { display: none !important; }
.single-product .summary .product_meta {
  margin-top: 0 !important;
  padding-top: 16px !important;
}
.single-product .woocommerce-tabs {
  width: min(1440px, 100%);
  margin: 0 auto !important;
  padding: 10px 5% 34px !important;
}
.single-product .woocommerce-tabs ul.tabs {
  gap: 10px !important;
  margin: 0 0 0 !important;
  padding: 0 !important;
}
.single-product .woocommerce-tabs ul.tabs::after { display: none !important; }
.single-product .woocommerce-tabs ul.tabs li {
  border: 1px solid rgba(139,92,246,.16) !important;
  background: rgba(255,255,255,.035) !important;
  border-radius: 999px !important;
  padding: 0 !important;
  overflow: hidden;
}
.single-product .woocommerce-tabs ul.tabs li a {
  display: block !important;
  padding: 12px 22px !important;
  font-weight: 700 !important;
  color: rgba(245,240,255,.66) !important;
}
.single-product .woocommerce-tabs ul.tabs li.active,
.single-product .woocommerce-tabs ul.tabs li:hover {
  background: rgba(139,92,246,.14) !important;
  border-color: rgba(196,181,253,.32) !important;
}
.single-product .woocommerce-tabs ul.tabs li.active a,
.single-product .woocommerce-tabs ul.tabs li:hover a {
  color: var(--white) !important;
}
.single-product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.single-product .woocommerce-tabs .panel {
  margin-top: 12px !important;
  padding: clamp(22px, 3vw, 36px) !important;
  border: 1px solid rgba(139,92,246,.14) !important;
  border-radius: 18px !important;
  background: rgba(139,92,246,.045) !important;
}
.single-product .woocommerce-tabs .panel h2 {
  font-size: clamp(1.25rem, 1.8vw, 1.7rem) !important;
  margin-bottom: 14px !important;
}
.single-product .related.products {
  width: min(1440px, 100%);
  margin: 0 auto !important;
  padding: 4px 5% 72px !important;
}
.single-product .related.products h2 {
  font-size: clamp(1.45rem, 2vw, 2rem) !important;
  margin-bottom: 18px !important;
}
.single-product .related.products ul.products {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
  gap: 16px !important;
}
.single-product .related.products .harvang-product-card {
  border-radius: 14px !important;
  min-height: 0 !important;
}
.single-product .related.products .harvang-product-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 18px 48px rgba(108,59,255,.16) !important;
}
.single-product .related.products .hpc-img {
  height: 132px !important;
}
.single-product .related.products .hpc-body {
  padding: 14px !important;
}
.single-product .related.products .hpc-cat,
.single-product .related.products .hpc-desc {
  display: none !important;
}
.single-product .related.products .hpc-title {
  min-height: 2.6em;
  margin-bottom: 10px !important;
  font-size: .96rem !important;
  line-height: 1.3 !important;
}
.single-product .related.products .hpc-footer {
  margin-top: auto !important;
  padding-top: 10px !important;
}
.single-product .related.products .hpc-price {
  font-size: 1.12rem !important;
}
.single-product .related.products .hpc-btn {
  padding: .38rem .78rem !important;
  font-size: .74rem !important;
}
@media (max-width: 1080px) {
  .single-product #product-wrap {
    grid-template-columns: minmax(0, 48%) minmax(0, 52%) !important;
    gap: 20px 32px !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 820px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto !important;
    padding: 92px 4% 20px !important;
    gap: 18px !important;
  }
  .single-product .product-gallery-col,
  .single-product .summary.entry-summary {
    grid-column: 1 !important;
  }
  .single-product .summary.entry-summary {
    grid-row: 3 !important;
  }
  .single-product .woocommerce-product-gallery {
    position: static !important;
  }
  .single-product .woocommerce-product-gallery__wrapper img {
    min-height: clamp(320px, 84vw, 560px) !important;
  }
  .single-product .woocommerce-tabs,
  .single-product .related.products {
    padding-left: 4% !important;
    padding-right: 4% !important;
  }
}
@media (max-width: 560px) {
  .single-product .summary .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(1.75rem, 9vw, 2.35rem) !important;
  }
  .single-product .summary form.cart {
    grid-template-columns: 1fr !important;
  }
  .single-product .summary form.cart .qty,
  .single-product .summary .single_add_to_cart_button {
    width: 100% !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: 1fr 1fr !important;
  }
  .single-product .woocommerce-tabs ul.tabs {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    scrollbar-width: none;
  }
  .single-product .woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
  .single-product .woocommerce-tabs ul.tabs li { flex: 0 0 auto; }
  .single-product .woocommerce-tabs .panel {
    padding: 20px !important;
  }
  .single-product .related.products ul.products {
    grid-template-columns: 1fr !important;
  }
}


/* SINGLE PRODUCT HERO REFINEMENT */
.single-product #product-wrap {
  width: min(1420px, 100%) !important;
  padding: 104px 5% 18px !important;
  grid-template-columns: minmax(0, 48%) minmax(0, 52%) !important;
  gap: 16px clamp(34px, 4vw, 64px) !important;
  align-items: center !important;
}
.single-product .product-breadcrumb {
  margin-bottom: 4px !important;
}
.single-product .summary.entry-summary {
  align-self: center !important;
  width: 100% !important;
  max-width: 760px !important;
  padding-top: 0 !important;
}
.single-product .woocommerce-product-gallery {
  align-self: center !important;
}
.single-product .woocommerce-product-gallery__wrapper img {
  min-height: clamp(430px, 45vw, 640px) !important;
}
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  max-width: 720px !important;
  font-size: clamp(38px, 3vw, 56px) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 16px !important;
}
.single-product .summary .woocommerce-product-rating {
  display: none !important;
}
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  margin-bottom: 20px !important;
}
.single-product .summary .woocommerce-product-details__short-description {
  max-width: 740px !important;
  margin-bottom: 24px !important;
  font-size: 1.02rem !important;
  line-height: 1.82 !important;
}
.single-product .summary form.cart {
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: min(100%, 560px) !important;
  margin-bottom: 16px !important;
}
.single-product .summary form.cart .quantity {
  width: 142px !important;
  height: 58px !important;
  margin: 0 !important;
  border-radius: 14px 0 0 14px !important;
  border-color: rgba(196,181,253,.22) !important;
  background: rgba(255,255,255,.045) !important;
  border-right: 0 !important;
  flex: 0 0 142px !important;
}
.single-product .summary form.cart .qty {
  width: 52px !important;
  height: 58px !important;
  font-size: 1.05rem !important;
  background: transparent !important;
}
.single-product .summary form.cart .harvang-qty-btn {
  width: 44px !important;
  color: rgba(245,240,255,.7) !important;
}
.single-product .summary form.cart .harvang-qty-btn:hover {
  color: var(--white) !important;
  background: rgba(124,58,237,.18) !important;
}
.single-product .summary .single_add_to_cart_button {
  min-height: 58px !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
  border-radius: 0 14px 14px 0 !important;
  padding: 0 30px !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  box-shadow: 0 18px 44px rgba(124,58,237,.3) !important;
}
.single-product .single-product-trust {
  width: min(100%, 720px) !important;
  margin-bottom: 18px !important;
}
.single-product .single-product-trust__inner {
  grid-template-columns: repeat(4, minmax(128px, 1fr)) !important;
  gap: 10px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.single-product .spt-item {
  min-height: 72px !important;
  padding: 14px 13px !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  border: 1px solid rgba(139,92,246,.16) !important;
  border-radius: 14px !important;
  background: rgba(139,92,246,.07) !important;
}
.single-product .spt-icon {
  width: 34px !important;
  height: 34px !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 34px !important;
  border-radius: 10px !important;
  color: transparent !important;
  font-size: 0 !important;
  background: rgba(196,181,253,.13) !important;
  box-shadow: inset 0 0 0 1px rgba(196,181,253,.22), 0 10px 24px rgba(124,58,237,.16) !important;
}
.single-product .spt-icon::before {
  content: '✓';
  color: var(--neon);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
}
.single-product .spt-label {
  font-size: .9rem !important;
  line-height: 1.22 !important;
  font-weight: 800 !important;
}
.single-product .summary .product_meta {
  width: min(100%, 720px) !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
  padding-top: 16px !important;
  border-top: 1px solid rgba(139,92,246,.14) !important;
  color: rgba(245,240,255,.54) !important;
  font-size: .76rem !important;
  line-height: 1.3 !important;
}
.single-product .summary .product_meta .posted_in,
.single-product .summary .product_meta .tagged_as,
.single-product .summary .product_meta .sku_wrapper {
  margin: 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: rgba(245,240,255,.54) !important;
}
.single-product .summary .product_meta > span {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  max-width: 100% !important;
  padding: 7px 10px !important;
  border: 1px solid rgba(139,92,246,.13) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.025) !important;
}
.single-product .summary .product_meta a,
.single-product .summary .product_meta .sku {
  color: rgba(245,240,255,.78) !important;
  text-decoration: none !important;
}
@media (max-width: 1080px) {
  .single-product #product-wrap {
    grid-template-columns: minmax(0, 48%) minmax(0, 52%) !important;
    gap: 18px 30px !important;
    align-items: start !important;
  }
  .single-product .summary.entry-summary {
    align-self: start !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 820px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr !important;
    padding: 92px 4% 18px !important;
  }
  .single-product .summary.entry-summary {
    max-width: none !important;
  }
  .single-product .woocommerce-product-gallery__wrapper img {
    min-height: clamp(320px, 80vw, 540px) !important;
  }
}
@media (max-width: 560px) {
  .single-product .summary .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(32px, 9vw, 42px) !important;
    line-height: 1.08 !important;
  }
  .single-product .summary form.cart {
    width: 100% !important;
  }
  .single-product .summary form.cart .quantity {
    flex-basis: 132px !important;
    width: 132px !important;
  }
  .single-product .summary .single_add_to_cart_button {
    padding: 0 18px !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: 1fr !important;
  }
  .single-product .spt-item {
    min-height: 62px !important;
  }
}


/* SINGLE PRODUCT HERO POLISH */
.single-product #product-wrap {
  width: min(1380px, 100%) !important;
  padding: 100px 5% 16px !important;
  grid-template-columns: minmax(0, 50%) minmax(0, 50%) !important;
  gap: 14px clamp(32px, 3.6vw, 56px) !important;
  align-items: center !important;
}
.single-product .product-breadcrumb {
  margin-bottom: 0 !important;
  padding-bottom: 10px !important;
}
.single-product .summary.entry-summary {
  align-self: stretch !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  max-width: 700px !important;
  min-height: clamp(390px, 41vw, 590px) !important;
}
.single-product .woocommerce-product-gallery {
  align-self: center !important;
}
.single-product .woocommerce-product-gallery__wrapper img {
  min-height: clamp(390px, 41vw, 590px) !important;
  max-height: 640px !important;
}
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  max-width: 670px !important;
  font-size: clamp(34px, 3vw, 48px) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.03em !important;
  margin-bottom: 14px !important;
}
.single-product .summary .woocommerce-product-rating,
.single-product .summary .woocommerce-review-link,
.single-product .product-gallery-col .woocommerce-product-rating,
.single-product .product-gallery-col .woocommerce-review-link {
  display: none !important;
}
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  margin-bottom: 18px !important;
}
.single-product .summary .woocommerce-product-details__short-description {
  max-width: 680px !important;
  margin-bottom: 22px !important;
  font-size: 1rem !important;
  line-height: 1.84 !important;
  color: rgba(245,240,255,.74) !important;
}
.single-product .summary form.cart {
  width: min(100%, 540px) !important;
  height: 58px !important;
  margin-bottom: 18px !important;
  border-radius: 16px !important;
  box-shadow: 0 18px 46px rgba(0,0,0,.24), 0 0 0 1px rgba(196,181,253,.08) !important;
}
.single-product .summary form.cart .quantity {
  width: 140px !important;
  height: 58px !important;
  flex: 0 0 140px !important;
  border-radius: 16px 0 0 16px !important;
  border-color: rgba(196,181,253,.2) !important;
  background: rgba(18,9,31,.78) !important;
}
.single-product .summary form.cart .qty {
  height: 58px !important;
}
.single-product .summary form.cart .harvang-qty-btn {
  width: 44px !important;
  font-size: 1.1rem !important;
}
.single-product .summary .single_add_to_cart_button {
  min-height: 58px !important;
  border-radius: 0 16px 16px 0 !important;
  padding: 0 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 16px 38px rgba(124,58,237,.26) !important;
}
.single-product .single-product-trust {
  width: min(100%, 680px) !important;
  margin-bottom: 18px !important;
}
.single-product .single-product-trust__inner {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}
.single-product .spt-item {
  min-height: 68px !important;
  padding: 14px 16px !important;
  gap: 12px !important;
  border-radius: 16px !important;
  background: linear-gradient(145deg, rgba(139,92,246,.105), rgba(255,255,255,.028)) !important;
  border-color: rgba(196,181,253,.18) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035) !important;
}
.single-product .spt-icon {
  width: 38px !important;
  height: 38px !important;
  flex-basis: 38px !important;
  border-radius: 12px !important;
}
.single-product .spt-label {
  font-size: .94rem !important;
  line-height: 1.18 !important;
  letter-spacing: 0 !important;
}
.single-product .summary .product_meta {
  width: min(100%, 680px) !important;
  gap: 10px !important;
  padding-top: 15px !important;
  font-size: .74rem !important;
  border-top-color: rgba(196,181,253,.13) !important;
}
.single-product .summary .product_meta > span {
  padding: 8px 11px !important;
  gap: 7px !important;
  border-color: rgba(196,181,253,.12) !important;
  background: rgba(255,255,255,.018) !important;
  color: rgba(245,240,255,.5) !important;
}
.single-product .summary .product_meta a,
.single-product .summary .product_meta .sku {
  color: rgba(245,240,255,.72) !important;
}
@media (max-width: 1080px) {
  .single-product #product-wrap {
    grid-template-columns: minmax(0, 49%) minmax(0, 51%) !important;
    gap: 16px 28px !important;
  }
  .single-product .summary.entry-summary {
    min-height: auto !important;
    justify-content: flex-start !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 820px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr !important;
    padding: 92px 4% 16px !important;
  }
  .single-product .summary.entry-summary {
    max-width: none !important;
  }
  .single-product .woocommerce-product-gallery__wrapper img {
    min-height: clamp(310px, 76vw, 510px) !important;
  }
}
@media (max-width: 560px) {
  .single-product .summary .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(30px, 8.5vw, 38px) !important;
    line-height: 1.06 !important;
  }
  .single-product .summary form.cart {
    height: auto !important;
    width: 100% !important;
  }
  .single-product .summary form.cart .quantity {
    flex: 0 0 128px !important;
    width: 128px !important;
  }
  .single-product .summary .single_add_to_cart_button {
    padding: 0 16px !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: 1fr !important;
  }
}


/* SINGLE PRODUCT HERO FINAL BALANCE */
.single-product #product-wrap {
  width: min(1340px, 100%) !important;
  padding: 96px 5% 14px !important;
  grid-template-columns: minmax(0, 48%) minmax(0, 52%) !important;
  gap: 12px clamp(34px, 4vw, 58px) !important;
  align-items: center !important;
}
.single-product .summary.entry-summary {
  align-self: center !important;
  justify-content: center !important;
  min-height: clamp(355px, 37vw, 535px) !important;
  max-width: 690px !important;
}
.single-product .woocommerce-product-gallery__wrapper img {
  min-height: clamp(355px, 37vw, 535px) !important;
  max-height: 585px !important;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs li,
.single-product .woocommerce-product-gallery .flex-control-thumbs li img {
  width: 62px !important;
  height: 62px !important;
}
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  max-width: 640px !important;
  font-size: clamp(32px, 2.6vw, 44px) !important;
  line-height: .98 !important;
  letter-spacing: -0.03em !important;
  margin-bottom: 13px !important;
}
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  margin-bottom: 16px !important;
}
.single-product .summary .woocommerce-product-details__short-description {
  max-width: 660px !important;
  margin-bottom: 20px !important;
  line-height: 1.78 !important;
}
.single-product .summary form.cart {
  width: min(100%, 520px) !important;
  height: 56px !important;
  margin-bottom: 16px !important;
  border-radius: 14px !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.2), 0 0 0 1px rgba(196,181,253,.07) !important;
}
.single-product .summary form.cart .quantity {
  width: 134px !important;
  height: 56px !important;
  flex-basis: 134px !important;
  border-radius: 14px 0 0 14px !important;
}
.single-product .summary form.cart .qty {
  height: 56px !important;
}
.single-product .summary form.cart .harvang-qty-btn {
  width: 41px !important;
}
.single-product .summary .single_add_to_cart_button {
  min-height: 56px !important;
  border-radius: 0 14px 14px 0 !important;
  padding: 0 26px !important;
  box-shadow: 0 14px 32px rgba(124,58,237,.24) !important;
}
.single-product .single-product-trust {
  width: min(100%, 660px) !important;
  margin-bottom: 16px !important;
}
.single-product .single-product-trust__inner {
  gap: 10px !important;
}
.single-product .spt-item {
  min-height: 58px !important;
  padding: 11px 14px !important;
  gap: 10px !important;
  border-radius: 14px !important;
  background: linear-gradient(145deg, rgba(139,92,246,.085), rgba(255,255,255,.024)) !important;
}
.single-product .spt-icon {
  width: 32px !important;
  height: 32px !important;
  flex-basis: 32px !important;
  border-radius: 10px !important;
}
.single-product .spt-icon::before {
  font-size: .9rem !important;
}
.single-product .spt-label {
  font-size: .84rem !important;
  line-height: 1.16 !important;
}
.single-product .summary .product_meta {
  width: min(100%, 660px) !important;
  gap: 8px !important;
  padding-top: 13px !important;
  font-size: .72rem !important;
}
.single-product .summary .product_meta > span {
  padding: 7px 10px !important;
  gap: 6px !important;
  max-width: 100% !important;
  white-space: normal !important;
}
.single-product .summary .product_meta .tagged_as {
  flex-basis: 100% !important;
  border-radius: 12px !important;
  line-height: 1.45 !important;
}
.single-product .woocommerce-tabs {
  width: min(1340px, 100%) !important;
  padding: 12px 5% 34px !important;
}
.single-product .woocommerce-tabs ul.tabs {
  display: inline-flex !important;
  gap: 6px !important;
  padding: 5px !important;
  margin: 0 0 18px !important;
  border: 1px solid rgba(196,181,253,.12) !important;
  border-bottom: 1px solid rgba(196,181,253,.12) !important;
  border-radius: 16px !important;
  background: rgba(139,92,246,.06) !important;
  backdrop-filter: blur(8px) !important;
  position: relative !important;
}
.single-product .woocommerce-tabs ul.tabs::before,
.single-product .woocommerce-tabs ul.tabs::after {
  display: none !important;
  content: none !important;
}
.single-product .woocommerce-tabs ul.tabs li::before,
.single-product .woocommerce-tabs ul.tabs li::after {
  display: none !important;
  content: none !important;
}
.single-product .woocommerce-tabs ul.tabs li {
  border: 0 !important;
  border-radius: 11px !important;
  background: transparent !important;
  overflow: hidden !important;
  transition: all .25s ease !important;
}
.single-product .woocommerce-tabs ul.tabs li a {
  padding: 11px 24px !important;
  color: rgba(245,240,255,.55) !important;
  font-size: .85rem !important;
  font-weight: 600 !important;
  letter-spacing: .02em !important;
  transition: color .25s ease !important;
}
.single-product .woocommerce-tabs ul.tabs li:hover {
  background: rgba(196,181,253,.1) !important;
}
.single-product .woocommerce-tabs ul.tabs li:hover a {
  color: var(--neon) !important;
}
.single-product .woocommerce-tabs ul.tabs li.active {
  background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%) !important;
  box-shadow: 0 8px 28px rgba(124,58,237,.35), inset 0 1px 0 rgba(255,255,255,.12) !important;
}
.single-product .woocommerce-tabs ul.tabs li.active a {
  color: #fff !important;
  font-weight: 700 !important;
}
.single-product .woocommerce-tabs .panel {
  margin-top: 0 !important;
  border-radius: 16px !important;
  background: linear-gradient(145deg, rgba(139,92,246,.05), rgba(255,255,255,.018)) !important;
}
@media (max-width: 1080px) {
  .single-product #product-wrap {
    grid-template-columns: minmax(0, 49%) minmax(0, 51%) !important;
    gap: 14px 28px !important;
  }
  .single-product .summary.entry-summary {
    min-height: auto !important;
  }
}
@media (max-width: 820px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr !important;
    padding: 92px 4% 14px !important;
  }
  .single-product .woocommerce-product-gallery__wrapper img {
    min-height: clamp(295px, 72vw, 480px) !important;
  }
  .single-product .woocommerce-tabs {
    padding-left: 4% !important;
    padding-right: 4% !important;
  }
}
@media (max-width: 560px) {
  .single-product .summary .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(29px, 8vw, 36px) !important;
    line-height: 1.04 !important;
  }
  .single-product .summary form.cart {
    width: 100% !important;
  }
  .single-product .summary form.cart .quantity {
    flex-basis: 124px !important;
    width: 124px !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: 1fr !important;
  }
  .single-product .woocommerce-tabs ul.tabs {
    display: flex !important;
    width: 100% !important;
  }
  .single-product .woocommerce-tabs ul.tabs li {
    flex: 1 1 0 !important;
    text-align: center !important;
  }
}


/* SINGLE PRODUCT HERO RECOVERY */
.single-product #product-wrap {
  width: min(1380px, 100%) !important;
  padding: 102px 5% 28px !important;
  grid-template-columns: minmax(0, 49%) minmax(0, 51%) !important;
  gap: 24px clamp(38px, 4vw, 64px) !important;
  align-items: center !important;
}
.single-product .product-breadcrumb {
  padding-bottom: 12px !important;
  margin-bottom: 6px !important;
}
.single-product .product-gallery-col,
.single-product .summary.entry-summary {
  align-self: center !important;
}
.single-product .woocommerce-product-gallery__wrapper img {
  min-height: clamp(390px, 42vw, 600px) !important;
  max-height: 650px !important;
}
.single-product .summary.entry-summary {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: clamp(390px, 42vw, 600px) !important;
  max-width: 720px !important;
  padding-top: 0 !important;
}
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  max-width: 680px !important;
  font-size: clamp(34px, 2.8vw, 46px) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.03em !important;
  margin: 0 0 18px !important;
}
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  margin: 0 0 22px !important;
}
.single-product .summary .woocommerce-product-details__short-description {
  max-width: 690px !important;
  margin: 0 0 26px !important;
  font-size: 1rem !important;
  line-height: 1.82 !important;
}
.single-product .summary form.cart {
  width: min(100%, 560px) !important;
  height: 58px !important;
  margin: 0 0 22px !important;
  border-radius: 15px !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.22), 0 0 0 1px rgba(196,181,253,.08) !important;
}
.single-product .summary form.cart .quantity {
  width: 140px !important;
  height: 58px !important;
  flex: 0 0 140px !important;
  border-radius: 15px 0 0 15px !important;
}
.single-product .summary form.cart .qty {
  height: 58px !important;
}
.single-product .summary form.cart .harvang-qty-btn {
  width: 44px !important;
}
.single-product .summary .single_add_to_cart_button {
  min-height: 58px !important;
  border-radius: 0 15px 15px 0 !important;
  padding: 0 28px !important;
}
.single-product .single-product-trust {
  width: min(100%, 690px) !important;
  margin: 0 0 22px !important;
}
.single-product .single-product-trust__inner {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 11px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.single-product .spt-item {
  min-height: 60px !important;
  padding: 12px 15px !important;
  gap: 11px !important;
  border-radius: 14px !important;
  background: rgba(139,92,246,.055) !important;
  border: 1px solid rgba(196,181,253,.14) !important;
  box-shadow: none !important;
}
.single-product .spt-icon {
  width: 32px !important;
  height: 32px !important;
  flex: 0 0 32px !important;
  border-radius: 10px !important;
  background: rgba(196,181,253,.1) !important;
}
.single-product .spt-label {
  font-size: .86rem !important;
  line-height: 1.2 !important;
}
.single-product .summary .product_meta {
  width: min(100%, 690px) !important;
  gap: 10px !important;
  padding-top: 16px !important;
  margin: 0 !important;
  border-top: 1px solid rgba(196,181,253,.12) !important;
  font-size: .74rem !important;
}
.single-product .summary .product_meta > span {
  padding: 7px 10px !important;
  gap: 7px !important;
  background: rgba(255,255,255,.018) !important;
  border: 1px solid rgba(196,181,253,.1) !important;
  border-radius: 999px !important;
}
.single-product .summary .product_meta .tagged_as {
  flex-basis: auto !important;
  max-width: 100% !important;
  line-height: 1.45 !important;
}
.single-product .woocommerce-tabs {
  width: min(1380px, 100%) !important;
  margin: 0 auto !important;
  padding: 24px 5% 64px !important;
}
.single-product .woocommerce-tabs .panel h2,
.single-product .woocommerce-tabs .woocommerce-Tabs-panel h2 {
  font-family: var(--font-head) !important;
  font-size: clamp(1.25rem, 1.8vw, 1.7rem) !important;
  line-height: 1.15 !important;
  margin: 0 0 16px !important;
  color: var(--white) !important;
}
@media (max-width: 1080px) {
  .single-product #product-wrap {
    grid-template-columns: minmax(0, 49%) minmax(0, 51%) !important;
    gap: 22px 32px !important;
  }
  .single-product .summary.entry-summary {
    min-height: clamp(360px, 42vw, 560px) !important;
    justify-content: center !important;
  }
}
@media (max-width: 820px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr !important;
    padding: 92px 4% 24px !important;
    gap: 20px !important;
  }
  .single-product .summary.entry-summary {
    min-height: auto !important;
    max-width: none !important;
  }
  .single-product .woocommerce-product-gallery__wrapper img {
    min-height: clamp(310px, 76vw, 520px) !important;
  }
  .single-product .woocommerce-tabs {
    padding: 18px 4% 52px !important;
  }
}
@media (max-width: 560px) {
  .single-product .summary .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(30px, 8.5vw, 38px) !important;
    line-height: 1.05 !important;
  }
  .single-product .summary form.cart {
    width: 100% !important;
  }
  .single-product .summary form.cart .quantity {
    flex: 0 0 128px !important;
    width: 128px !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: 1fr !important;
  }
}


/* SINGLE PRODUCT HERO INSPECTED FIX */
.single-product #product-wrap {
  width: min(1400px, 100%) !important;
  padding: 102px 5% 30px !important;
  grid-template-columns: minmax(0, 46%) minmax(0, 54%) !important;
  gap: 24px clamp(42px, 4.4vw, 68px) !important;
  align-items: center !important;
}
.single-product .product-gallery-col,
.single-product .summary.entry-summary {
  align-self: center !important;
}
.single-product .woocommerce-product-gallery__wrapper img {
  min-height: clamp(390px, 42vw, 600px) !important;
  max-height: 640px !important;
}
.single-product .summary.entry-summary {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: clamp(390px, 42vw, 600px) !important;
  max-width: none !important;
  padding-top: 0 !important;
}
.single-product .summary .product_title,
.woocommerce div.product .product_title {
  max-width: 760px !important;
  font-size: clamp(30px, 2.45vw, 40px) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.03em !important;
  margin: 0 0 16px !important;
}
.single-product .summary .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: clamp(1.55rem, 2vw, 2.1rem) !important;
  margin: 0 0 18px !important;
}
.single-product .summary .woocommerce-product-details__short-description {
  max-width: 720px !important;
  margin: 0 0 22px !important;
  font-size: .98rem !important;
  line-height: 1.72 !important;
}
.single-product .summary form.cart {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 16px !important;
  width: min(100%, 540px) !important;
  height: auto !important;
  padding: 1rem 1.2rem !important;
  margin: 0 0 18px !important;
  border-radius: 16px !important;
  background: var(--glass) !important;
  border: 1px solid var(--glass-border) !important;
  box-shadow: 0 16px 38px rgba(0,0,0,.22), 0 0 0 1px rgba(196,181,253,.08) !important;
}
.single-product .summary form.cart .quantity {
  width: 128px !important;
  height: 48px !important;
  flex: 0 0 128px !important;
  margin: 0 !important;
  border-radius: 12px !important;
  border-color: rgba(196,181,253,.2) !important;
  background: rgba(255,255,255,.045) !important;
}
.single-product .summary form.cart .qty {
  height: 48px !important;
}
.single-product .summary form.cart .harvang-qty-btn {
  width: 40px !important;
}
.single-product .summary .single_add_to_cart_button {
  min-height: 52px !important;
  border-radius: 14px !important;
  flex: 1 !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  padding: 0 32px !important;
  box-shadow: 0 18px 42px rgba(124,58,237,.3) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
@media (max-width: 560px) {
  .single-product .summary form.cart {
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 1rem !important;
  }
  .single-product .summary form.cart .quantity {
    width: 100% !important;
    flex: none !important;
  }
  .single-product .summary .single_add_to_cart_button {
    width: 100% !important;
    min-height: 50px !important;
  }
}
.single-product .single-product-trust {
  width: min(100%, 720px) !important;
  margin: 0 0 18px !important;
}
.single-product .single-product-trust__inner {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
.single-product .spt-item {
  min-height: 50px !important;
  padding: 9px 10px !important;
  gap: 8px !important;
  border-radius: 12px !important;
  background: rgba(139,92,246,.04) !important;
  border-color: rgba(196,181,253,.11) !important;
}
.single-product .spt-icon {
  width: 26px !important;
  height: 26px !important;
  flex: 0 0 26px !important;
  border-radius: 8px !important;
  background: rgba(196,181,253,.08) !important;
}
.single-product .spt-icon::before {
  font-size: .78rem !important;
}
.single-product .spt-label {
  font-size: .76rem !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
}
.single-product .summary .product_meta {
  width: min(100%, 720px) !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  gap: 8px 12px !important;
  padding-top: 14px !important;
  font-size: .72rem !important;
  line-height: 1.35 !important;
}
.single-product .summary .product_meta > span {
  display: inline !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  color: rgba(245,240,255,.48) !important;
}
.single-product .summary .product_meta .sku_wrapper,
.single-product .summary .product_meta .posted_in {
  grid-column: auto !important;
}
.single-product .summary .product_meta .tagged_as {
  grid-column: 1 / -1 !important;
  max-width: 100% !important;
  line-height: 1.45 !important;
}
.single-product .summary .product_meta a,
.single-product .summary .product_meta .sku {
  color: rgba(245,240,255,.68) !important;
}
.single-product .woocommerce-tabs {
  padding-top: 30px !important;
}
.woocommerce div.product .woocommerce-tabs .panel,
.single-product .woocommerce-tabs .panel,
.single-product .woocommerce-tabs .woocommerce-Tabs-panel {
  padding: clamp(22px, 2.6vw, 34px) !important;
  margin-bottom: 18px !important;
  border-radius: 16px !important;
  background: rgba(139,92,246,.04) !important;
  border-color: rgba(196,181,253,.12) !important;
}
@media (max-width: 1180px) {
  .single-product #product-wrap {
    grid-template-columns: minmax(0, 47%) minmax(0, 53%) !important;
    gap: 22px 34px !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 820px) {
  .single-product #product-wrap {
    grid-template-columns: 1fr !important;
  }
  .single-product .summary.entry-summary {
    min-height: auto !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px) {
  .single-product .summary .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(28px, 8vw, 36px) !important;
  }
  .single-product .single-product-trust__inner {
    grid-template-columns: 1fr !important;
  }
  .single-product .summary .product_meta {
    grid-template-columns: 1fr !important;
  }
}


/* SINGLE PRODUCT HERO GALLERY ALIGNMENT FIX */
.single-product .woocommerce-product-gallery {
  position: static !important;
  top: auto !important;
}
.single-product .product-gallery-col {
  display: flex !important;
  align-items: center !important;
}
.single-product .product-gallery-col .woocommerce-product-gallery {
  width: 100% !important;
}

/* ═══════════════════════════════════════════════════
   MOBILE RESPONSIVE — REFINEMENTS
   Covers 320px–480px without redesigning
═══════════════════════════════════════════════════ */

/* Tablet / small desktop — tighter nav */
@media (max-width: 820px) {
  nav#site-navigation { padding: 10px 16px; min-height: 56px; }
  .nav-right { gap: .6rem; }
  .nav-icon-btn { width: 36px; height: 36px; }
  .hero-content { max-width: 100%; }
  .hero-visual { display: none; }
}

/* Mobile */
@media (max-width: 480px) {
  /* ── Global ── */
  html, body { overflow-x: hidden; width: 100%; }
  img, svg, video { max-width: 100%; height: auto; }

  /* ── Nav ── */
  nav#site-navigation { padding: 8px 14px; min-height: 54px; top: 8px; width: calc(100% - 16px); }
  .nav-logo { font-size: 1.1rem; }
  .custom-logo-link img.custom-logo { max-height: 36px; }
  .nav-links, .main-navigation ul { gap: 1.2rem; }
  .nav-right { gap: .4rem; }
  .nav-icon-btn { width: 34px; height: 34px; }
  .hamburger { width: 32px; height: 32px; }
  .mobile-menu { padding: 72px 5% 1.5rem; }
  .mobile-menu a { font-size: 1.15rem; padding: .45rem 0; }
  .mobile-menu .mobile-menu-divider { margin: .4rem 0 .3rem; width: 32px; }

  /* ── Typography ── */
  .hero h1 { font-size: 1.7rem; letter-spacing: -.5px; }
  .hero p { font-size: .85rem; max-width: 100%; }
  .section-title { font-size: 1.6rem; }
  .section-sub { font-size: .88rem; max-width: 100%; }
  .section-label { font-size: .68rem; }

  /* ── Hero ── */
  .hero { padding: 100px 4% 30px; min-height: auto; }
  .hero-badge { font-size: .65rem; padding: .2rem .6rem; margin-bottom: .5rem; }
  .hero-btns { flex-direction: column; gap: .7rem; }
  .hero-btns .btn-primary,
  .hero-btns .btn-outline { width: 100%; text-align: center; padding: .75rem 1.2rem; font-size: .85rem; }
  .trust-badges { gap: .6rem; margin-top: 1rem; }
  .trust-badges span { font-size: .72rem; }
  .hero-stats { gap: .6rem; margin-top: 1rem; }
  .hero-stat { flex: 1; min-width: 0; }
  .hero-stat .num { font-size: 1.3rem; }
  .hero-stat .label { font-size: .62rem; letter-spacing: .04em; }

  /* ── Sections ── */
  section { padding: 24px 4%; }
  .section-head { margin-bottom: 1.2rem; }

  /* ── Benefit cards ── */
  .benefits-grid { grid-template-columns: 1fr; gap: .6rem; }
  .benefit-card { padding: .8rem; }
  .benefit-icon { width: 28px; height: 28px; font-size: .85rem; margin-bottom: .4rem; }

  /* ── Results ── */
  .results-grid { grid-template-columns: 1fr 1fr; gap: .6rem; margin-bottom: 1rem; }
  .result-card { padding: .8rem .6rem; }
  .result-card .r-num { font-size: 1.8rem; }
  .result-card .r-label { font-size: .68rem; }
  .case-placeholder { grid-template-columns: 1fr; padding: 1rem; gap: .8rem; }
  .case-info h3 { font-size: 1rem; }
  .case-chart-area { min-height: 120px; padding: 1rem; }

  /* ── Testimonials ── */
  .testi-wrapper { padding: 0 48px; }
  .testi-card { flex: 0 0 100%; padding: 1rem 0.9rem; }
  .testi-card p { font-size: .82rem; margin-bottom: 1rem; }
  .testi-author { gap: .6rem; }
  .author-avatar { width: 38px; height: 38px; font-size: .75rem; }
  .author-name { font-size: .82rem; }
  .author-role { font-size: .7rem; }
  .testi-btn { width: 36px; height: 36px; font-size: .9rem; }
  .testi-btn-prev { left: 6px; }
  .testi-btn-next { right: 6px; }
  .testi-dots { margin-top: 16px; gap: 8px; }
  .testi-dot { width: 8px; height: 8px; }

  /* ── CTA ── */
  .final-cta .section-title { font-size: 1.6rem; }
  .cta-btns { flex-direction: column; gap: .6rem; margin-top: 1rem; }
  .cta-btns .btn-primary { width: 100%; text-align: center; }

  /* ── Footer ── */
  footer { padding: 1.2rem 4% .8rem; }
  .footer-grid { gap: .7rem; margin-bottom: .8rem; }
  .footer-col h4 { margin-bottom: .4rem; font-size: .8rem; letter-spacing: .25px; }
  .footer-col ul li { margin-bottom: .3rem; }
  .footer-col ul a { font-size: .77rem; }
  .footer-bottom { flex-direction: column; text-align: center; gap: .4rem; padding-top: .7rem; }
  .footer-bottom p { font-size: .75rem; }
  .footer-bottom-links { gap: .7rem; }
  .footer-bottom-links a { font-size: .75rem; }
  .footer-brand .nav-logo { margin-bottom: .6rem; }
  .footer-brand .custom-logo-link img.custom-logo { max-height: 36px; }
  .footer-brand p { font-size: .78rem; max-width: 100%; line-height: 1.55; }
  .footer-social { margin-top: .6rem; gap: .5rem; }
  .social-icon { width: 28px; height: 28px; font-size: .78rem; border-radius: 6px; }
  .social-icon svg { width: 14px; height: 14px; }

  /* ── Shop / store page ── */
  .woocommerce-products-header { padding: 90px 4% 30px; }
  .woocommerce-products-header__title { font-size: 1.6rem; }
  .woo-shop-wrap { padding: 82px 4% 24px; }
  .shop-breadcrumb { margin-bottom: .85rem; }
  .store-filters { gap: .5rem; margin-bottom: 1.25rem; }
  .filter-btn { padding: 10px 16px; font-size: .8rem; min-height: 42px; }
  .woocommerce-ordering { margin-bottom: 1rem; }
  .woocommerce-ordering select {
    width: 100%;
    font-size: .82rem;
    padding: .5rem 2rem .5rem .85rem;
  }
  .woo-shop-top { flex-direction: column; align-items: flex-start; margin-bottom: 1rem; gap: .5rem; }
  .woocommerce-result-count { font-size: .78rem; }
  .harvang-pagination { margin-top: 1.5rem; }
  .woocommerce ul.products { gap: .8rem !important; }
  .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .88rem; padding: .8rem .8rem .3rem; }
  .woocommerce ul.products li.product .price { font-size: 1.05rem; padding: 0 .8rem .8rem; }
  .woocommerce ul.products li.product img { height: 140px; }
  .woocommerce ul.products li.product .button,
  .woocommerce ul.products li.product a.button { font-size: .8rem; padding: .5rem .8rem; }
  .hpag-item, .page-numbers { width: 34px; height: 34px; font-size: .78rem; }
  .woocommerce-pagination { padding-top: 1rem; }

  /* ── Custom product cards ── */
  .hpc-price { font-size: 1.05rem; }
  .hpc-price del .woocommerce-Price-amount { font-size: .62rem; }
  .hpc-btn { height: 38px; padding: 0 14px; font-size: .8rem; }

  /* ── Single product page ── */
  .single-product #product-wrap { padding: 68px 4% 16px; }
  .woocommerce-product-gallery__wrapper img { border-radius: 12px; max-height: 320px; object-fit: contain; }
  .single-product .summary .product_title { font-size: 1.2rem !important; }
  .single-product .summary .price { font-size: 1.3rem !important; }
  .single-product .summary .single_add_to_cart_button { min-width: 0; width: 100% !important; padding: .75rem 1rem !important; font-size: .88rem !important; }
  .single-product .summary form.cart { padding: .8rem 1rem; gap: .6rem; }
  .single-product .summary form.cart.variations_form { padding: .8rem 1rem; }
  .woocommerce-variation-add-to-cart { gap: .6rem; }
  .woocommerce .quantity .qty { width: 56px; padding: .4rem .5rem; font-size: .85rem; }
  .harvang-qty-btn { width: 32px; height: 32px; font-size: 1rem; }
  .single-product .summary .woocommerce-product-details__short-description { font-size: .82rem; margin-bottom: .8rem; }
  .woocommerce-tabs { padding: 0 4% 20px; }
  .single-product-trust { padding: 0 4% 20px; }
  .single-product-trust__inner { padding: .8rem; gap: .5rem; }
  .spt-icon { font-size: 1.1rem; }
  .spt-label { font-size: .72rem; }
  .spt-sub { font-size: .65rem; }

  /* ── Related products on single product ── */
  .single-product .related.products .hpc-title { font-size: .88rem !important; }

  /* ── Cart page ── */
  .woocommerce-cart .woocommerce { padding: 80px 4% 40px; }
  .woocommerce-cart .page-title { font-size: 1.5rem; }
  .woocommerce-cart-form table.shop_table { min-width: 380px; }
  .cart_totals { padding: 1rem; }
  .cart_totals h2 { font-size: 1rem; }
  .woocommerce-cart .coupon { flex-direction: column; gap: .5rem; }
  .woocommerce-cart .coupon input { width: 100%; }
  .checkout-button { font-size: .88rem !important; padding: .7rem 1rem !important; }

  /* ── Checkout ── */
  .woocommerce-checkout .woocommerce { padding: 80px 4% 40px; }
  .woocommerce-checkout .col2-set .col-1,
  .woocommerce-checkout .col2-set .col-2 { padding: 1rem; }

  /* ── Buttons / forms ── */
  .btn-primary, .btn-outline { font-size: .85rem; padding: .7rem 1.2rem; }
}

/* Very small phones (320px–375px) */
@media (max-width: 375px) {
  nav#site-navigation { height: 54px; }
  .nav-logo { font-size: 1rem; }
  .custom-logo-link img.custom-logo { max-height: 30px; }
  .nav-icon-btn { width: 30px; height: 30px; }
  .nav-right { gap: .3rem; }

  .hero h1 { font-size: 1.4rem; }
  .hero p { font-size: .78rem; }
  .hero-badge { font-size: .58rem; padding: .15rem .5rem; }
  .section-title { font-size: 1.3rem; }
  .hero-stats { gap: .35rem; }
  .hero-stat .num { font-size: 1.1rem; }
  .hero-stat .label { font-size: .58rem; }
  section { padding: 20px 4%; }

  .benefits-grid { gap: .5rem; }
  .results-grid { gap: .5rem; }
  .result-card .r-num { font-size: 1.4rem; }

  .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: .82rem; padding: .6rem .6rem .2rem; }
  .woocommerce ul.products li.product .price { font-size: .95rem; padding: 0 .6rem .6rem; }
  .woocommerce ul.products li.product img { height: 120px; }
  .woocommerce ul.products { gap: .6rem !important; }

  .hpc-price { font-size: .9rem; }
  .hpc-price del .woocommerce-Price-amount { font-size: .55rem; }
  .hpc-btn { height: 34px; padding: 0 12px; font-size: .75rem; }

  /* Shop spacing */
  .woo-shop-wrap { padding: 76px 4% 20px; }
  .shop-breadcrumb { margin-bottom: .75rem; }
  .store-filters { margin-bottom: 1rem; }
  .filter-btn { padding: 8px 14px; font-size: .76rem; min-height: 38px; }
  .woo-shop-top { margin-bottom: .85rem; }
  .woocommerce-result-count { font-size: .72rem; }
  .harvang-pagination { margin-top: 1.25rem; }
  .hpag-item { width: 32px; height: 32px; font-size: .78rem; }
  .shop-trust { margin-top: 1.25rem; gap: .75rem; }
  .shop-trust__item { padding: 1rem .75rem; }
  .shop-trust__icon { font-size: 1.3rem; }
  .shop-trust__label { font-size: .78rem; }
  .shop-trust__desc { font-size: .72rem; }

  .single-product .summary .product_title { font-size: 1.1rem !important; }
  .single-product .summary .price { font-size: 1.15rem !important; }
  .single-product #product-wrap { padding: 56px 4% 12px; }
  .woocommerce-product-gallery__wrapper img { max-height: 260px; }
  .woocommerce-tabs ul.tabs li { padding: .5rem .8rem !important; font-size: .78rem !important; }

  .mobile-menu { padding: 60px 5% 1rem; }
  .mobile-menu a { font-size: 1rem; padding: .35rem 0; }
  .mobile-menu .mobile-menu-divider { margin: .3rem 0 .2rem; width: 24px; }
  .footer-grid { gap: .5rem; margin-bottom: .6rem; }
  footer { padding: 1rem 4% .6rem; }
  .footer-col h4 { margin-bottom: .3rem; font-size: .75rem; }
  .footer-col ul li { margin-bottom: .2rem; }
  .footer-col ul a { font-size: .73rem; }
  .footer-bottom { padding-top: .5rem; gap: .3rem; }
  .footer-brand p { font-size: .73rem; line-height: 1.45; }
  .footer-brand .custom-logo-link img.custom-logo { max-height: 28px; }
  .social-icon { width: 22px; height: 22px; font-size: .65rem; }
  .social-icon svg { width: 11px; height: 11px; }
}
