/*
 * AllDigitalKeys.com — Gaming Dark Theme
 * Deep navy + electric violet + emerald green
 * NOT a copy of any existing store
 */

/* ============================================================
   FONTS (loaded via functions.php)
   ============================================================ */
/* Space Grotesk = headings | Inter = body */

/* ============================================================
   CSS VARIABLES
   ============================================================ */
:root {
  --bg:         #08080f;
  --bg-2:       #0e0e1c;
  --surface:    #131324;
  --surface-2:  #1a1a30;
  --surface-3:  #202040;
  --border:     #1e1e38;
  --border-2:   #2a2a4a;

  --purple:     #7c3aed;
  --purple-2:   #9f67f8;
  --purple-glow:rgba(124,58,237,.25);
  --green:      #10b981;
  --green-2:    #34d399;
  --red:        #ef4444;
  --yellow:     #f59e0b;
  --orange:     #f97316;

  --text:       #f1f5f9;
  --text-2:     #cbd5e1;
  --text-3:     #94a3b8;
  --text-4:     #475569;

  --radius:     10px;
  --radius-lg:  16px;
  --radius-xl:  24px;

  --transition: .2s ease;
  --shadow:     0 4px 24px rgba(0,0,0,.5);
  --shadow-purple: 0 0 30px var(--purple-glow);
}

/* ============================================================
   RESET + BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg) !important;
  color: var(--text) !important;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* Links */
a { color: var(--purple-2); transition: color var(--transition); }
a:hover { color: var(--green); text-decoration: none; }

h1,h2,h3,h4,h5,h6 {
  font-family: 'Space Grotesk', 'Inter', sans-serif !important;
  color: var(--text) !important;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

/* ============================================================
   ANNOUNCEMENT BAR (above header)
   ============================================================ */
.adk-announcement {
  background: linear-gradient(90deg, var(--purple) 0%, #5b21b6 50%, var(--purple) 100%);
  background-size: 200% 100%;
  animation: adk-slide 4s linear infinite;
  text-align: center;
  padding: 9px 20px;
  font-size: 13px;
  font-weight: 500;
  color: #fff;
  letter-spacing: .01em;
}
@keyframes adk-slide {
  0%   { background-position: 0% 0%; }
  100% { background-position: 200% 0%; }
}
.adk-announcement a { color: var(--green-2); font-weight: 600; }
.adk-announcement span { margin: 0 16px; opacity: .6; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header,
header.site-header {
  background: rgba(8,8,15,.95) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border) !important;
  position: sticky !important;
  top: 0;
  z-index: 1000;
  box-shadow: 0 1px 0 var(--border), 0 4px 20px rgba(0,0,0,.4) !important;
  padding: 0 !important;
}

.site-header .container,
.site-header .site-header-inner {
  display: flex !important;
  align-items: center !important;
  min-height: 70px;
  gap: 20px;
  padding: 0 24px;
  max-width: 1400px;
  margin: 0 auto;
}

/* Logo */
.site-logo a, .custom-logo-link,
.site-branding .site-title a {
  color: #fff !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 800 !important;
  font-size: 22px !important;
  text-decoration: none;
  letter-spacing: -0.03em;
}
.site-branding .site-title a span { color: var(--purple-2); }

/* Search bar in header */
.dgwt-wcas-search-wrapp .dgwt-wcas-sf-wrapp {
  background: var(--surface) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 8px !important;
  transition: border-color var(--transition);
}
.dgwt-wcas-search-wrapp .dgwt-wcas-sf-wrapp:focus-within {
  border-color: var(--purple) !important;
  box-shadow: 0 0 0 3px rgba(124,58,237,.15) !important;
}
.dgwt-wcas-sf-wrapp input[type=search],
.dgwt-wcas-sf-wrapp input {
  background: transparent !important;
  color: var(--text) !important;
  font-size: 14px;
}
.dgwt-wcas-sf-wrapp input::placeholder { color: var(--text-4); }

/* Header icons */
.header-cart-icon a, .header-my-account a,
.header-wishlist a, a.cart-contents {
  color: var(--text-2) !important;
  transition: color var(--transition);
}
.header-cart-icon a:hover, .header-my-account a:hover,
a.cart-contents:hover { color: var(--purple-2) !important; }

.amount-cart, .cart-count {
  background: var(--purple) !important;
  color: #fff !important;
  border-radius: 50px;
  font-size: 11px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-menu,
.site-menu.menu-header,
div.site-menu.menu-header {
  border: none !important;
  border-bottom: none !important;
  outline: none !important;
}
.site-menu .navbar-nav,
.main-navigation ul.menu {
  background: transparent !important;
}

.site-menu .navbar-nav > li > a,
.main-navigation ul.menu > li > a {
  color: var(--text-2) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  padding: 24px 14px !important;
  transition: color var(--transition) !important;
  border: none !important;
  background: transparent !important;
  letter-spacing: .01em;
}
.site-menu .navbar-nav > li > a:hover,
.site-menu .navbar-nav > li.current-menu-item > a,
.main-navigation ul.menu > li > a:hover {
  color: var(--purple-2) !important;
}

/* Dropdown */
.dropdown-menu, .sub-menu {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  margin-top: 0 !important;
  padding: 8px !important;
}
.dropdown-menu a, .sub-menu a {
  color: var(--text-2) !important;
  padding: 8px 14px !important;
  border-radius: 6px !important;
  font-size: 13px !important;
}
.dropdown-menu a:hover, .sub-menu a:hover {
  background: var(--purple) !important;
  color: #fff !important;
}

/* ============================================================
   HERO SECTION (homepage)
   ============================================================ */
.adk-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(124,58,237,.25) 0%, transparent 60%),
              linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
  padding: 80px 24px;
}

.adk-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(124,58,237,.15) 0%, transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(16,185,129,.1) 0%, transparent 40%);
  pointer-events: none;
}

.adk-hero-inner {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
}

.adk-hero h1 {
  font-size: clamp(36px, 5vw, 68px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin: 0 0 16px;
  background: linear-gradient(135deg, #fff 0%, var(--purple-2) 60%, var(--green) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.adk-hero p {
  font-size: 18px;
  color: var(--text-3);
  max-width: 540px;
  margin: 0 0 32px;
}

.adk-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.adk-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--surface);
  border: 1px solid var(--border-2);
  border-radius: 50px;
  padding: 7px 14px;
  font-size: 13px;
  color: var(--text-2);
  font-weight: 500;
}
.adk-badge svg, .adk-badge .icon { color: var(--green); }

/* ============================================================
   PLATFORM ICONS NAV (homepage)
   ============================================================ */
.adk-platforms {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding: 24px 0;
}

.adk-platform-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 16px 24px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  color: var(--text-2);
  text-decoration: none;
  font-size: 12px;
  font-weight: 600;
  transition: all var(--transition);
  letter-spacing: .05em;
  text-transform: uppercase;
  flex: 1;
  min-width: 80px;
  max-width: 120px;
}
.adk-platform-btn:hover {
  background: var(--surface-2);
  border-color: var(--purple);
  color: var(--purple-2);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(124,58,237,.2);
}
.adk-platform-btn img, .adk-platform-btn svg {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.adk-section-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 20px;
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  gap: 10px;
}
.adk-section-title::before {
  content: '';
  display: block;
  width: 4px;
  height: 24px;
  background: linear-gradient(180deg, var(--purple), var(--green));
  border-radius: 2px;
  flex-shrink: 0;
}
.adk-section-link {
  margin-left: auto;
  font-size: 13px;
  color: var(--purple-2);
  font-weight: 500;
}

/* ============================================================
   PRODUCT CARDS (WooCommerce)
   ============================================================ */
ul.products, .products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 14px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

ul.products li.product,
.product-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition) !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  margin: 0 !important;
}

ul.products li.product:hover,
.product-card:hover {
  transform: translateY(-4px) !important;
  border-color: var(--purple) !important;
  box-shadow: 0 12px 40px rgba(124,58,237,.2) !important;
}

/* Product image */
ul.products li.product .woocommerce-loop-product__link,
ul.products li.product > a:first-child {
  display: block;
  overflow: hidden;
  background: var(--surface-2);
  aspect-ratio: 16/9;
}

ul.products li.product .attachment-woocommerce_thumbnail,
ul.products li.product .wp-post-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform .4s ease !important;
}
ul.products li.product:hover .attachment-woocommerce_thumbnail,
ul.products li.product:hover .wp-post-image {
  transform: scale(1.06) !important;
}

/* Product info area */
ul.products li.product .product-info,
ul.products li.product .woocommerce-loop-product__title + * {
  padding: 14px !important;
}

/* Product title */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2 {
  font-family: 'Space Grotesk', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  line-height: 1.3 !important;
  margin: 12px 14px 6px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

/* Price */
ul.products li.product .price,
.woocommerce .price {
  color: var(--green) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  font-family: 'Space Grotesk', sans-serif !important;
  margin: 0 14px 12px !important;
}
ul.products li.product .price del,
.woocommerce .price del {
  color: var(--text-4) !important;
  font-size: 13px !important;
  margin-right: 4px !important;
}
ul.products li.product .price ins,
.woocommerce .price ins {
  text-decoration: none !important;
}

/* Add to Cart button */
ul.products li.product .button,
ul.products li.product .add_to_cart_button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: calc(100% - 28px) !important;
  margin: 0 14px 14px !important;
  padding: 11px 16px !important;
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  transition: background var(--transition), transform var(--transition) !important;
  cursor: pointer !important;
  letter-spacing: .02em !important;
  text-decoration: none !important;
}
ul.products li.product .button:hover,
ul.products li.product .add_to_cart_button:hover {
  background: var(--purple-2) !important;
  transform: none !important;
}
ul.products li.product .button.added,
ul.products li.product .add_to_cart_button.added {
  background: var(--green) !important;
}

/* Sale badge */
ul.products li.product .onsale,
span.onsale {
  background: var(--red) !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 8px !important;
  position: absolute !important;
  top: 10px !important;
  left: 10px !important;
  z-index: 2 !important;
  border: none !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}

/* Platform badge on product */
.adk-platform-badge {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  background: rgba(8,8,15,.8);
  border: 1px solid var(--border-2);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-3);
  backdrop-filter: blur(8px);
}

/* Wishlist button */
.yith-wcwl-add-to-wishlist .yith-wcwl-add-button a,
.add_to_wishlist {
  position: absolute !important;
  top: 46px !important;
  right: 10px !important;
  width: 30px !important;
  height: 30px !important;
  background: rgba(8,8,15,.8) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: 6px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--text-3) !important;
  font-size: 14px !important;
  z-index: 2 !important;
  backdrop-filter: blur(8px);
  transition: all var(--transition) !important;
}
.add_to_wishlist:hover {
  border-color: var(--red) !important;
  color: var(--red) !important;
}

/* ============================================================
   PRODUCT SINGLE PAGE
   ============================================================ */
.woocommerce div.product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
  background: var(--surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  padding: 32px;
  margin-top: 20px;
}

.woocommerce div.product div.images img {
  border-radius: var(--radius-lg);
  width: 100%;
}

.woocommerce div.product div.summary .product_title {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 12px;
  color: var(--text);
}

.woocommerce div.product p.price {
  font-size: 36px !important;
  font-weight: 800;
  color: var(--green) !important;
  margin: 16px 0;
}

/* Add to cart */
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button {
  background: linear-gradient(135deg, var(--purple), var(--purple-2)) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  padding: 16px 32px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: .01em !important;
  transition: all var(--transition) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  box-shadow: 0 4px 20px rgba(124,58,237,.3) !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 30px rgba(124,58,237,.4) !important;
}

/* Trust badges under button */
.adk-trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}
.adk-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-3);
  font-weight: 500;
}
.adk-trust-item .icon { color: var(--green); font-size: 16px; }

/* Product tabs */
.woocommerce-tabs .tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border) !important;
  padding: 0 !important;
  background: transparent !important;
  list-style: none;
  margin: 0 !important;
}
.woocommerce-tabs .tabs li a {
  padding: 12px 20px !important;
  color: var(--text-3) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  border-radius: 6px 6px 0 0 !important;
  transition: all var(--transition) !important;
  border: none !important;
  background: transparent !important;
}
.woocommerce-tabs .tabs li.active a {
  color: var(--purple-2) !important;
  background: rgba(124,58,237,.1) !important;
  border-bottom: 2px solid var(--purple) !important;
}
.woocommerce-tabs .panel {
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  border-top: none !important;
  border-radius: 0 0 var(--radius) var(--radius) !important;
  padding: 24px !important;
  color: var(--text-2) !important;
}

/* ============================================================
   SHOP / ARCHIVE PAGE
   ============================================================ */
.woocommerce-page .site-content,
.archive .site-content {
  background: var(--bg) !important;
}

.adk-shop-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  max-width: 1400px;
  margin: 24px auto;
  padding: 0 24px;
}

/* Sidebar filters */
.widget, .widget_product_categories, .berocket_aapf_widget,
aside.widget-area, .sidebar {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 20px !important;
  margin-bottom: 16px !important;
  color: var(--text-2) !important;
}

.widget-title, .widgettitle {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--text-3) !important;
  margin: 0 0 14px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid var(--border) !important;
}

.widget ul li a {
  color: var(--text-2) !important;
  font-size: 13px !important;
  padding: 4px 0 !important;
  display: block;
  transition: color var(--transition) !important;
}
.widget ul li a:hover { color: var(--purple-2) !important; }

/* Price filter */
.price_slider { background: var(--border-2) !important; }
.price_slider .ui-slider-range { background: var(--purple) !important; }
.price_slider .ui-slider-handle {
  background: var(--purple-2) !important;
  border: 2px solid #fff !important;
  border-radius: 50% !important;
  box-shadow: var(--shadow-purple) !important;
}

/* Sort / toolbar */
.woocommerce-ordering select {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
  font-size: 14px !important;
}

.woocommerce-result-count { color: var(--text-3) !important; font-size: 14px !important; }

/* ============================================================
   PAGINATION
   ============================================================ */
.woocommerce-pagination ul, nav.woocommerce-pagination ul {
  display: flex !important;
  gap: 6px !important;
  justify-content: center !important;
  padding: 20px 0 !important;
  list-style: none !important;
}
.woocommerce-pagination li a,
.woocommerce-pagination li span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--text-2) !important;
  font-weight: 600 !important;
  transition: all var(--transition) !important;
  text-decoration: none !important;
}
.woocommerce-pagination li a:hover,
.woocommerce-pagination li span.current {
  background: var(--purple) !important;
  border-color: var(--purple) !important;
  color: #fff !important;
}

/* ============================================================
   CART & CHECKOUT
   ============================================================ */
.woocommerce-cart-form table,
.shop_table {
  background: var(--surface) !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border) !important;
  overflow: hidden;
  width: 100%;
  border-collapse: separate !important;
}

.woocommerce-cart-form th,
.shop_table th {
  background: var(--surface-2) !important;
  color: var(--text-3) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  padding: 14px 16px !important;
  border: none !important;
  border-bottom: 1px solid var(--border) !important;
}

.woocommerce-cart-form td,
.shop_table td {
  padding: 16px !important;
  border: none !important;
  border-bottom: 1px solid var(--border) !important;
  color: var(--text) !important;
  vertical-align: middle !important;
  background: transparent !important;
}

/* Cart totals */
.cart_totals, .order-total {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 24px !important;
}

/* Coupon */
.coupon .input-text {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  border-radius: 8px !important;
  padding: 12px 16px !important;
}

/* Checkout */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-account-fields,
.woocommerce-additional-fields {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 24px !important;
}

.woocommerce-checkout h3 {
  font-size: 16px !important;
  color: var(--text) !important;
  margin-bottom: 20px !important;
}

.woocommerce-checkout input[type=text],
.woocommerce-checkout input[type=email],
.woocommerce-checkout input[type=tel],
.woocommerce-checkout textarea,
.woocommerce-checkout select {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  border-radius: 8px !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
  transition: border-color var(--transition) !important;
  width: 100% !important;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus {
  border-color: var(--purple) !important;
  box-shadow: 0 0 0 3px rgba(124,58,237,.15) !important;
  outline: none !important;
}

/* Payment methods */
#payment ul.payment_methods {
  list-style: none !important;
  padding: 0 !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden;
}
#payment ul.payment_methods li {
  padding: 14px 20px !important;
  border-bottom: 1px solid var(--border) !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
#payment ul.payment_methods li label {
  color: var(--text-2) !important;
  font-weight: 500 !important;
  cursor: pointer !important;
}

/* Place order button */
#place_order {
  background: linear-gradient(135deg, var(--green), #059669) !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  padding: 18px 40px !important;
  border-radius: var(--radius-lg) !important;
  border: none !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  box-shadow: 0 4px 24px rgba(16,185,129,.3) !important;
  letter-spacing: .02em !important;
}
#place_order:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 32px rgba(16,185,129,.4) !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer, footer.site-footer {
  background: var(--bg-2) !important;
  border-top: 1px solid var(--border) !important;
  color: var(--text-3) !important;
  padding: 60px 0 24px !important;
  margin-top: 60px !important;
}

.site-footer .footer-widgets {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px 40px;
}

.site-footer .widget-title {
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--text-4) !important;
  margin-bottom: 16px !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

.site-footer .widget ul li a {
  color: var(--text-3) !important;
  font-size: 13px !important;
  padding: 4px 0 !important;
  transition: color var(--transition) !important;
}
.site-footer .widget ul li a:hover { color: var(--text) !important; }

.site-footer .footer-bottom {
  border-top: 1px solid var(--border);
  padding: 20px 24px 0;
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--text-4);
}

/* ============================================================
   WOOCOMMERCE NOTICES + MESSAGES
   ============================================================ */
.woocommerce-message, .woocommerce-info {
  background: rgba(124,58,237,.1) !important;
  border-left: 4px solid var(--purple) !important;
  color: var(--text) !important;
  border-radius: 0 var(--radius) var(--radius) 0 !important;
  padding: 14px 20px !important;
}
.woocommerce-error {
  background: rgba(239,68,68,.1) !important;
  border-left: 4px solid var(--red) !important;
  color: var(--text) !important;
  border-radius: 0 var(--radius) var(--radius) 0 !important;
  padding: 14px 20px !important;
}

/* ============================================================
   MY ACCOUNT
   ============================================================ */
.woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden;
}
.woocommerce-MyAccount-navigation li a {
  display: block;
  padding: 13px 20px !important;
  color: var(--text-2) !important;
  font-size: 14px !important;
  border-bottom: 1px solid var(--border) !important;
  transition: all var(--transition) !important;
}
.woocommerce-MyAccount-navigation li a:hover,
.woocommerce-MyAccount-navigation li.is-active a {
  background: rgba(124,58,237,.1) !important;
  color: var(--purple-2) !important;
  padding-left: 24px !important;
}

/* ============================================================
   DEAL CARDS (custom section)
   ============================================================ */
.adk-deal-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition);
}
.adk-deal-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--purple), var(--green));
}
.adk-deal-card:hover {
  border-color: var(--purple);
  transform: translateY(-2px);
  box-shadow: var(--shadow-purple);
}

/* Hot deal badge */
.adk-hot {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: linear-gradient(135deg, #dc2626, var(--orange));
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: 4px;
}

/* ============================================================
   STATS BAR (homepage)
   ============================================================ */
.adk-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: 40px 0;
}
.adk-stat {
  background: var(--surface);
  padding: 24px;
  text-align: center;
}
.adk-stat-value {
  font-size: 32px;
  font-weight: 800;
  color: var(--purple-2);
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.03em;
  display: block;
}
.adk-stat-label {
  font-size: 12px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 4px;
  display: block;
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.adk-cta {
  background: linear-gradient(135deg, var(--surface-2), rgba(124,58,237,.15));
  border: 1px solid var(--border-2);
  border-radius: var(--radius-xl);
  padding: 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
  margin: 48px 0;
}
.adk-cta::before {
  content: '';
  position: absolute;
  top: -50%;
  left: 50%;
  transform: translateX(-50%);
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(124,58,237,.2), transparent 70%);
  pointer-events: none;
}
.adk-cta h2 { font-size: 32px; margin-bottom: 12px; }
.adk-cta p { color: var(--text-3); font-size: 16px; margin-bottom: 24px; }

/* Primary CTA button */
.adk-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: var(--radius);
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  transition: all var(--transition);
  cursor: pointer;
  border: none;
  letter-spacing: .01em;
}
.adk-btn-primary {
  background: linear-gradient(135deg, var(--purple), var(--purple-2));
  color: #fff;
  box-shadow: 0 4px 20px rgba(124,58,237,.3);
}
.adk-btn-primary:hover {
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 8px 30px rgba(124,58,237,.4);
}
.adk-btn-green {
  background: linear-gradient(135deg, var(--green), #059669);
  color: #fff;
  box-shadow: 0 4px 20px rgba(16,185,129,.25);
}
.adk-btn-outline {
  background: transparent;
  color: var(--text-2);
  border: 1px solid var(--border-2);
}
.adk-btn-outline:hover {
  border-color: var(--purple);
  color: var(--purple-2);
}

/* ============================================================
   SEARCH PAGE
   ============================================================ */
.woocommerce-search .site-content { background: var(--bg); }
.dgwt-wcas-suggestion { color: var(--text) !important; }
.dgwt-wcas-pd-title { color: var(--text) !important; }
.dgwt-wcas-suggestions-wrapp {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  border-radius: var(--radius) !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .adk-shop-layout { grid-template-columns: 1fr; }
  .site-footer .footer-widgets { grid-template-columns: 1fr 1fr; }
  .woocommerce div.product { grid-template-columns: 1fr; }
  .adk-stats { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  .adk-hero h1 { font-size: 32px; }
  .site-footer .footer-widgets { grid-template-columns: 1fr; }
  .adk-stats { grid-template-columns: repeat(2, 1fr); }
  .adk-platforms { display: grid; grid-template-columns: repeat(3, 1fr); }
  .adk-platform-btn { max-width: 100%; }
}

@media (max-width: 480px) {
  ul.products { grid-template-columns: 1fr !important; }
  .adk-stats { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   ELEMENTOR OVERRIDES
   ============================================================ */
.elementor-section, .elementor-container { max-width: 1400px !important; }
.elementor-widget-heading .elementor-heading-title { color: var(--text) !important; }
.elementor-widget-text-editor { color: var(--text-2) !important; }

/* ============================================================
   SCROLLBAR (dark)
   ============================================================ */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb {
  background: var(--border-2);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: var(--purple); }

/* ============================================================
   LOADING ANIMATION
   ============================================================ */
.adk-skeleton {
  background: linear-gradient(90deg, var(--surface) 25%, var(--surface-2) 50%, var(--surface) 75%);
  background-size: 200% 100%;
  animation: adk-shimmer 1.5s infinite;
  border-radius: var(--radius);
}
@keyframes adk-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ============================================================
   MISC WP OVERRIDES
   ============================================================ */
.content-area, main.site-main, #main { background: transparent !important; }
.page-title, .archive-title { color: var(--text) !important; }

input[type=text], input[type=email], input[type=search],
input[type=password], input[type=number], textarea, select {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--purple) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(124,58,237,.12) !important;
}

/* Stars ratings */
.star-rating span::before,
.woocommerce-product-rating .star-rating span::before {
  color: var(--yellow) !important;
}

/* WooCommerce breadcrumb */
.woocommerce-breadcrumb {
  color: var(--text-4) !important;
  font-size: 13px !important;
}
.woocommerce-breadcrumb a { color: var(--text-3) !important; }

/* Stock */
.in-stock { color: var(--green) !important; }
.out-of-stock { color: var(--red) !important; }

/* Remove white backgrounds from WC */
.woocommerce,
.woocommerce-page {
  background: transparent !important;
}

/* ============================================================
   CONTAINER UTILITY
   ============================================================ */
.adk-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}

/* ============================================================
   HERO — GUTENBERG VERSION
   ============================================================ */
.adk-hero-content {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}
.adk-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(124,58,237,.15);
  border: 1px solid rgba(124,58,237,.35);
  color: var(--purple-2);
  border-radius: 50px;
  padding: 6px 16px;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 24px;
  letter-spacing: .02em;
}
.adk-hero-title {
  font-size: clamp(36px, 5vw, 68px) !important;
  font-weight: 800 !important;
  line-height: 1.05 !important;
  letter-spacing: -0.03em !important;
  margin: 0 0 16px !important;
  color: var(--text) !important;
}
.adk-gradient-text {
  background: linear-gradient(135deg, var(--purple-2) 0%, var(--green) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.adk-hero-sub {
  font-size: 18px;
  color: var(--text-3);
  margin: 0 0 32px;
}
.adk-hero-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.adk-btn-ghost {
  background: transparent;
  color: var(--text-2);
  border: 1px solid var(--border-2);
}
.adk-btn-ghost:hover {
  border-color: var(--purple);
  color: var(--purple-2);
  background: rgba(124,58,237,.08);
}
.adk-hero-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
}
.adk-trust-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.adk-trust-stat strong {
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  font-family: 'Space Grotesk', sans-serif;
}
.adk-trust-stat span {
  font-size: 12px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.adk-trust-divider {
  width: 1px;
  height: 36px;
  background: var(--border-2);
}

/* ============================================================
   PLATFORMS SECTION — GUTENBERG VERSION
   ============================================================ */
.adk-platforms-section {
  padding: 64px 24px;
  background: var(--bg-2);
}
.adk-platforms-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 12px;
  margin-top: 32px;
}
@media (max-width: 1024px) {
  .adk-platforms-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
  .adk-platforms-grid { grid-template-columns: repeat(3, 1fr); }
}
.adk-platform-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  color: var(--text-2);
  text-decoration: none;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  transition: all var(--transition);
}
.adk-platform-card:hover {
  background: var(--surface-2);
  border-color: var(--purple);
  color: var(--purple-2);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(124,58,237,.2);
}
.adk-platform-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  background: var(--surface-2);
}
.adk-platform-icon.steam-icon  { background: #1b2838; }
.adk-platform-icon.ps-icon     { background: #003087; font-size: 12px; }
.adk-platform-icon.xbox-icon   { background: #107c10; }
.adk-platform-icon.nintendo-icon { background: #e4000f; font-size: 22px; }
.adk-platform-icon.google-icon { background: #34a853; }
.adk-platform-icon.apple-icon  { background: #555; }
.adk-platform-icon.amazon-icon { background: #ff9900; color: #111; font-weight: 900; font-style: italic; font-size: 22px; }
.adk-platform-icon.more-icon   { background: var(--purple); font-size: 22px; }

/* ============================================================
   FEATURES SECTION — GUTENBERG VERSION
   ============================================================ */
.adk-features-section {
  padding: 80px 24px;
  background: var(--bg);
}
.adk-features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 16px;
}
@media (max-width: 900px) {
  .adk-features-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .adk-features-grid { grid-template-columns: 1fr; }
}
.adk-feature-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 24px;
  text-align: center;
  transition: all var(--transition);
}
.adk-feature-card:hover {
  border-color: var(--purple);
  box-shadow: 0 8px 32px rgba(124,58,237,.15);
  transform: translateY(-2px);
}
.adk-feature-icon {
  font-size: 36px;
  margin-bottom: 16px;
  display: block;
}
.adk-feature-card h3 {
  font-size: 17px !important;
  font-weight: 700 !important;
  margin: 0 0 10px !important;
  color: var(--text) !important;
}
.adk-feature-card p {
  font-size: 14px;
  color: var(--text-3);
  margin: 0;
  line-height: 1.6;
}

/* ============================================================
   FEATURED PRODUCTS SECTION
   ============================================================ */
.adk-featured-section {
  padding: 80px 24px;
  background: var(--bg-2);
}
.adk-section-header {
  text-align: center;
  margin-bottom: 40px;
}
.adk-section-label {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--purple-2);
  margin-bottom: 12px;
}
.adk-section-title {
  font-size: clamp(24px, 3vw, 36px) !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  margin: 0 0 12px !important;
}
.adk-section-sub {
  color: var(--text-3);
  font-size: 16px;
  margin: 0;
}

/* WooCommerce grid inside adk-featured-section */
.adk-featured-section .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
@media (max-width: 1024px) {
  .adk-featured-section .products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 700px) {
  .adk-featured-section .products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 400px) {
  .adk-featured-section .products { grid-template-columns: 1fr !important; }
}

.adk-featured-section .products li.product {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden;
  transition: all var(--transition);
  display: flex !important;
  flex-direction: column !important;
}
.adk-featured-section .products li.product:hover {
  border-color: var(--purple) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,.18) !important;
  transform: translateY(-3px);
}
.adk-featured-section .products li.product a.woocommerce-loop-product__link {
  display: flex !important;
  flex-direction: column !important;
  flex: 1;
  text-decoration: none !important;
}
.adk-featured-section .products li.product img {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  border-radius: 0 !important;
  margin: 0 !important;
  display: block !important;
}
.adk-featured-section .products li.product .woocommerce-loop-product__title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  padding: 12px 14px 4px !important;
  margin: 0 !important;
  line-height: 1.4 !important;
  flex: 1;
}
.adk-featured-section .products li.product .price {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: var(--green) !important;
  padding: 4px 14px 12px !important;
  display: block !important;
}
.adk-featured-section .products li.product .price del {
  color: var(--text-3) !important;
  font-weight: 400 !important;
  font-size: 13px !important;
}
.adk-featured-section .products li.product .button,
.adk-featured-section .products li.product .add_to_cart_button {
  display: block !important;
  width: calc(100% - 28px) !important;
  margin: 0 14px 14px !important;
  padding: 10px !important;
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-align: center !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
}
.adk-featured-section .products li.product .button:hover,
.adk-featured-section .products li.product .add_to_cart_button:hover {
  background: var(--purple-2) !important;
  box-shadow: 0 4px 16px rgba(124,58,237,.4) !important;
}
.adk-featured-section .adk-view-all {
  text-align: center;
  margin-top: 40px;
}
.adk-featured-section .adk-view-all a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 32px;
  background: transparent;
  border: 1px solid var(--border-2);
  border-radius: var(--radius);
  color: var(--text-2);
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition);
}
.adk-featured-section .adk-view-all a:hover {
  border-color: var(--purple);
  color: var(--purple-2);
  background: rgba(124,58,237,.08);
}

/* ============================================================
   WOOCOMMERCE ARCHIVE + PRODUCT PAGES — FORCE FULL WIDTH
   Hide sidebar, expand content to 100%
   ============================================================ */
body.woocommerce-page #sidebar,
body.woocommerce #sidebar,
body.post-type-archive-product #sidebar,
body.single-product #sidebar {
  display: none !important;
}
body.woocommerce-page .envo-content.col-md-9,
body.woocommerce .envo-content.col-md-9,
body.post-type-archive-product .envo-content,
body.single-product .envo-content,
body.woocommerce-page .woo-content,
body.woocommerce .woo-content {
  width: 100% !important;
  max-width: 100% !important;
  flex: 0 0 100% !important;
  float: none !important;
  padding-right: 15px !important;
}
/* Fix WooCommerce product archive grid — force 4 columns */
body.woocommerce-page ul.products,
body.woocommerce ul.products,
body.post-type-archive-product ul.products,
ul.products.columns-5,
ul.products.columns-4,
ul.products.columns-3 {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  margin: 0 0 24px !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
  width: 100% !important;
}
@media (max-width: 1100px) {
  body.woocommerce-page ul.products,
  body.woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 700px) {
  body.woocommerce-page ul.products,
  body.woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
body.woocommerce-page ul.products li.product,
body.woocommerce ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden;
  transition: all var(--transition);
  display: flex !important;
  flex-direction: column !important;
}
body.woocommerce-page ul.products li.product:hover,
body.woocommerce ul.products li.product:hover {
  border-color: var(--purple) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,.18) !important;
  transform: translateY(-3px);
}
body.woocommerce-page ul.products li.product img,
body.woocommerce ul.products li.product img {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  margin: 0 !important;
  border-radius: 0 !important;
  display: block !important;
}
body.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
body.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  padding: 12px 14px 4px !important;
  margin: 0 !important;
  flex: 1;
}
body.woocommerce-page ul.products li.product .price,
body.woocommerce ul.products li.product .price {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: var(--green) !important;
  padding: 4px 14px 8px !important;
  display: block !important;
}
body.woocommerce-page ul.products li.product .button,
body.woocommerce ul.products li.product .button {
  display: block !important;
  width: calc(100% - 28px) !important;
  margin: 0 14px 14px !important;
  padding: 10px !important;
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}
body.woocommerce-page ul.products li.product .button:hover,
body.woocommerce ul.products li.product .button:hover {
  background: var(--purple-2) !important;
}
/* WooCommerce page header & breadcrumb */
body.woocommerce-page .woocommerce-products-header__title {
  font-size: 32px !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  margin: 32px 0 24px !important;
  border-left: none !important;
  padding-left: 0 !important;
}
body.woocommerce-page .woocommerce-breadcrumb {
  color: var(--text-3) !important;
  font-size: 13px !important;
}
body.woocommerce-page .woocommerce-breadcrumb a {
  color: var(--purple-2) !important;
  text-decoration: none !important;
}
body.woocommerce-page .woocommerce-ordering select {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: 8px 12px !important;
}
body.woocommerce-page .woocommerce-result-count {
  color: var(--text-3) !important;
}

/* ============================================================
   PAGE-BUILDERS TEMPLATE — BASE RESET
   ============================================================ */
.page-builders {
  background: var(--bg);
  min-height: 100vh;
}
.page-builders-content-area {
  width: 100%;
}
.page-builders-content-area > * {
  max-width: 100%;
}

/* ============================================================
   GLOBAL WooCommerce RESET (shop, category pages)
   ============================================================ */
.woocommerce-page .products,
.woocommerce .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
@media (max-width: 1024px) {
  .woocommerce-page .products,
  .woocommerce .products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 700px) {
  .woocommerce-page .products,
  .woocommerce .products { grid-template-columns: repeat(2, 1fr) !important; }
}
.woocommerce-page .products li.product,
.woocommerce .products li.product {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden;
  transition: all var(--transition);
}
.woocommerce-page .products li.product:hover,
.woocommerce .products li.product:hover {
  border-color: var(--purple) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,.18) !important;
  transform: translateY(-3px);
}
.woocommerce-page .products li.product img,
.woocommerce .products li.product img {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
.woocommerce-page .products li.product .woocommerce-loop-product__title,
.woocommerce .products li.product .woocommerce-loop-product__title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  padding: 12px 14px 4px !important;
  margin: 0 !important;
}
.woocommerce-page .products li.product .price,
.woocommerce .products li.product .price {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: var(--green) !important;
  padding: 4px 14px 12px !important;
  display: block !important;
}
.woocommerce-page .products li.product .button,
.woocommerce .products li.product .button {
  display: block !important;
  width: calc(100% - 28px) !important;
  margin: 0 14px 14px !important;
  padding: 10px !important;
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
}
.woocommerce-page .products li.product .button:hover,
.woocommerce .products li.product .button:hover {
  background: var(--purple-2) !important;
}

/* Hero background fix */
.adk-hero {
  background: var(--bg) !important;
}

/* ============================================================
   HERO STATS — horizontal row
   ============================================================ */
.adk-hero-stats {
  display: flex !important;
  gap: 40px !important;
  justify-content: center !important;
  align-items: center !important;
  margin-top: 48px !important;
  flex-wrap: wrap !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
.adk-hero-stats .adk-stat {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 4px !important;
}
.adk-hero-stats .adk-stat strong {
  font-size: 28px !important;
  font-weight: 900 !important;
  color: var(--purple-2) !important;
  display: block !important;
  line-height: 1 !important;
}
.adk-hero-stats .adk-stat span {
  font-size: 12px !important;
  color: var(--text-3) !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* ============================================================
   OVERRIDE ENTR THEME h2 BORDER inside ADK sections
   ============================================================ */
.adk-section-header h2,
.adk-featured-section h2,
.adk-platforms-section h2,
.adk-features-section h2 {
  border-left: none !important;
  padding-left: 0 !important;
  text-align: center !important;
  display: block !important;
  color: var(--text) !important;
  font-size: clamp(24px, 3vw, 36px) !important;
  font-weight: 800 !important;
  margin: 0 0 12px !important;
}
.adk-section-header h2::before,
.adk-featured-section h2::before,
.adk-platforms-section h2::before,
.adk-features-section h2::before {
  display: none !important;
}

/* ============================================================
   WOOCOMMERCE PRODUCT GRID OVERRIDE — stronger selectors
   ============================================================ */
.adk-featured-section ul.products,
.adk-featured-section ul.products.columns-4,
.adk-featured-section ul.products.columns-3,
.adk-featured-section ul.products.columns-2 {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
  width: 100% !important;
}
@media (max-width: 1024px) {
  .adk-featured-section ul.products,
  .adk-featured-section ul.products.columns-4 {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 700px) {
  .adk-featured-section ul.products,
  .adk-featured-section ul.products.columns-4 {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
.adk-featured-section ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
}

/* ============================================================
   HERO BUTTON STYLES
   ============================================================ */
.adk-hero .adk-btn {
  display: inline-flex;
  align-items: center;
  padding: 14px 32px;
  background: var(--purple);
  color: #fff !important;
  border-radius: var(--radius);
  font-weight: 700;
  font-size: 15px;
  text-decoration: none !important;
  transition: all var(--transition);
  border: 1px solid var(--purple);
}
.adk-hero .adk-btn:hover {
  background: var(--purple-2);
  box-shadow: 0 8px 24px rgba(124,58,237,.4);
  transform: translateY(-2px);
  color: #fff !important;
}
.adk-hero .adk-btn-ghost {
  background: transparent;
  border-color: var(--border-2);
  color: var(--text-2) !important;
}
.adk-hero .adk-btn-ghost:hover {
  border-color: var(--purple);
  color: var(--purple-2) !important;
  background: rgba(124,58,237,.08);
  box-shadow: none;
}
.adk-hero-badge {
  display: inline-block;
  background: rgba(124,58,237,.15);
  border: 1px solid rgba(124,58,237,.35);
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--purple-2) !important;
  margin-bottom: 24px;
}
.adk-hero h1,
.adk-gradient-text {
  font-size: clamp(36px, 5vw, 64px) !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  margin: 0 0 20px !important;
  background: linear-gradient(135deg, var(--purple-2), var(--green)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  display: block !important;
  text-align: center !important;
}
.adk-hero-sub {
  color: var(--text-2) !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  margin: 0 0 32px !important;
  text-align: center !important;
}
.adk-hero-actions {
  display: flex !important;
  gap: 16px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  margin-bottom: 48px !important;
}
.adk-hero-content {
  max-width: 800px !important;
  margin: 0 auto !important;
  text-align: center !important;
  padding: 100px 0 80px !important;
}

/* ============================================================
   FIX YELLOW NAV BOTTOM LINE (entr theme navbar)
   ============================================================ */
.navbar-default,
#site-navigation,
.navbar,
nav.navbar {
  border-bottom: none !important;
  border-top: none !important;
}
.navbar-default .navbar-nav > li > a::after,
.navbar-default .navbar-nav > li > a::before {
  background: none !important;
  border: none !important;
}
/* Remove any gold/amber highlight on nav items */
.nav-bottom-line,
.menu-item.current-menu-item > a::before,
.menu-item.current-menu-item > a::after {
  background-color: transparent !important;
  border-color: transparent !important;
}

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */
.woocommerce div.product {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 40px !important;
  align-items: start !important;
  padding: 40px !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  margin: 32px auto !important;
  max-width: 1100px !important;
}
.woocommerce div.product .woocommerce-product-gallery {
  grid-column: 1 !important;
}
.woocommerce div.product .summary.entry-summary {
  grid-column: 2 !important;
}
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .up-sells,
.woocommerce div.product .related {
  grid-column: 1 / -1 !important;
}
.woocommerce div.product .woocommerce-product-gallery__image img {
  border-radius: var(--radius) !important;
  max-height: 400px !important;
  object-fit: cover !important;
  width: 100% !important;
}
/* Fix gallery thumbnails */
.woocommerce div.product .flex-control-thumbs {
  display: flex !important;
  gap: 8px !important;
  margin-top: 12px !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce div.product .flex-control-thumbs li {
  width: 60px !important;
  height: 60px !important;
  flex-shrink: 0 !important;
}
.woocommerce div.product .flex-control-thumbs li img {
  width: 60px !important;
  height: 60px !important;
  object-fit: cover !important;
  border-radius: 6px !important;
  border: 2px solid var(--border) !important;
  cursor: pointer !important;
  max-height: none !important;
}
.woocommerce div.product .flex-control-thumbs li img.flex-active {
  border-color: var(--purple) !important;
}
/* Product summary styling */
.woocommerce div.product .product_title {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  margin: 0 0 16px !important;
  border-left: none !important;
  padding-left: 0 !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: 32px !important;
  font-weight: 900 !important;
  color: var(--green) !important;
  margin: 0 0 20px !important;
}
.woocommerce div.product .cart { margin: 16px 0 !important; }
.woocommerce div.product .cart .qty {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: 10px 14px !important;
  width: 70px !important;
  font-size: 16px !important;
}
.woocommerce div.product .single_add_to_cart_button {
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  padding: 14px 32px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: all var(--transition) !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  margin-left: 12px !important;
}
.woocommerce div.product .single_add_to_cart_button:hover {
  background: var(--purple-2) !important;
  box-shadow: 0 4px 20px rgba(124,58,237,.4) !important;
}
/* Product tabs */
.woocommerce-tabs ul.tabs {
  display: flex !important;
  gap: 4px !important;
  border-bottom: 2px solid var(--border) !important;
  margin: 32px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce-tabs ul.tabs li {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}
.woocommerce-tabs ul.tabs li a {
  display: block !important;
  padding: 12px 20px !important;
  color: var(--text-3) !important;
  font-weight: 600 !important;
  border-radius: var(--radius) var(--radius) 0 0 !important;
  text-decoration: none !important;
  transition: color .2s !important;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
  color: var(--purple-2) !important;
  background: var(--surface-2) !important;
}
.woocommerce-tabs .panel {
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  border-top: none !important;
  border-radius: 0 var(--radius) var(--radius) var(--radius) !important;
  padding: 24px !important;
  color: var(--text-2) !important;
}

/* ============================================================
   CART PAGE
   ============================================================ */
.woocommerce-cart .woocommerce-cart-form table.cart {
  width: 100% !important;
  border-collapse: collapse !important;
  background: var(--surface) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  border: 1px solid var(--border) !important;
}
.woocommerce-cart .woocommerce-cart-form table.cart th {
  background: var(--surface-2) !important;
  color: var(--text-3) !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--border) !important;
}
.woocommerce-cart .woocommerce-cart-form table.cart td {
  padding: 16px !important;
  border-bottom: 1px solid var(--border) !important;
  color: var(--text) !important;
  vertical-align: middle !important;
}
.woocommerce-cart .woocommerce-cart-form table.cart td.product-name a {
  color: var(--text) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}
.woocommerce-cart .woocommerce-cart-form table.cart td.product-price,
.woocommerce-cart .woocommerce-cart-form table.cart td.product-subtotal {
  color: var(--green) !important;
  font-weight: 700 !important;
}
.cart-collaterals { margin-top: 40px !important; }
.cart_totals { background: var(--surface) !important; border: 1px solid var(--border) !important; border-radius: var(--radius-lg) !important; padding: 24px !important; }
.cart_totals h2 { color: var(--text) !important; font-size: 20px !important; font-weight: 700 !important; margin: 0 0 20px !important; border: none !important; padding: 0 !important; }
.cart_totals table { width: 100% !important; }
.cart_totals table th, .cart_totals table td { padding: 10px 0 !important; color: var(--text-2) !important; border-bottom: 1px solid var(--border) !important; }
.cart_totals .order-total td { color: var(--green) !important; font-weight: 800 !important; font-size: 20px !important; }
.wc-proceed-to-checkout .checkout-button {
  display: block !important;
  width: 100% !important;
  padding: 16px !important;
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  margin-top: 16px !important;
}
.wc-proceed-to-checkout .checkout-button:hover { background: var(--purple-2) !important; }

/* ============================================================
   CHECKOUT PAGE
   ============================================================ */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  margin: 0 0 20px !important;
  border: none !important;
  padding: 0 !important;
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-2) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: 12px 14px !important;
  width: 100% !important;
  font-size: 14px !important;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus {
  border-color: var(--purple) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(124,58,237,.15) !important;
}
.woocommerce-checkout .form-row label {
  color: var(--text-2) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}
.woocommerce-checkout #payment {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 24px !important;
}
.woocommerce-checkout #payment ul.payment_methods li label {
  color: var(--text) !important;
}
.woocommerce-checkout #place_order {
  width: 100% !important;
  padding: 16px !important;
  background: var(--purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}
.woocommerce-checkout #place_order:hover { background: var(--purple-2) !important; }

/* ============================================================
   WC PAGINATION
   ============================================================ */
.woocommerce-pagination ul {
  display: flex !important;
  gap: 6px !important;
  justify-content: center !important;
  margin: 40px 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  color: var(--text-2) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  transition: all var(--transition) !important;
}
.woocommerce-pagination ul li a:hover {
  background: var(--purple) !important;
  border-color: var(--purple) !important;
  color: #fff !important;
}
.woocommerce-pagination ul li span.current {
  background: var(--purple) !important;
  border-color: var(--purple) !important;
  color: #fff !important;
}

/* ============================================================
   FOOTER — dark theme
   ============================================================ */
.site-footer {
  background: #06060e !important;
  border-top: 1px solid var(--border) !important;
  color: var(--text-3) !important;
  margin-top: 0 !important;
}
.site-footer .footer-widgets {
  padding: 60px 24px 40px !important;
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 40px !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
}
.site-footer .widget-title {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  margin: 0 0 16px !important;
  border: none !important;
}
.site-footer a {
  color: var(--text-3) !important;
  text-decoration: none !important;
  font-size: 14px !important;
  transition: color .2s !important;
}
.site-footer a:hover { color: var(--purple-2) !important; }
.site-footer ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.site-footer ul li { margin-bottom: 8px !important; }
.footer-bottom,
.site-info {
  background: #04040a !important;
  border-top: 1px solid var(--border) !important;
  padding: 16px 24px !important;
  text-align: center !important;
  color: var(--text-4) !important;
  font-size: 13px !important;
}
@media (max-width: 900px) {
  .site-footer .footer-widgets { grid-template-columns: repeat(2, 1fr) !important; }
  .woocommerce div.product { grid-template-columns: 1fr !important; }
}
@media (max-width: 600px) {
  .site-footer .footer-widgets { grid-template-columns: 1fr !important; }
  .woocommerce div.product { padding: 20px !important; }
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.woocommerce-breadcrumb,
.woocommerce nav.woocommerce-breadcrumb {
  padding: 12px 0 !important;
  margin: 0 !important;
  color: var(--text-4) !important;
  font-size: 13px !important;
}
.woocommerce-breadcrumb a { color: var(--text-3) !important; text-decoration: none !important; }
.woocommerce-breadcrumb a:hover { color: var(--purple-2) !important; }

/* ============================================================
   NOTICES & MESSAGES
   ============================================================ */
.woocommerce-message,
.woocommerce-info {
  background: rgba(124,58,237,.1) !important;
  border-top: 3px solid var(--purple) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: 16px 20px !important;
}
.woocommerce-error {
  background: rgba(239,68,68,.1) !important;
  border-top: 3px solid var(--red) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: 16px 20px !important;
  list-style: none !important;
}
.woocommerce-message a.button,
.woocommerce-info a.button {
  background: var(--purple) !important;
  color: #fff !important;
  border-radius: var(--radius) !important;
  padding: 8px 16px !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}

/* ============================================================
   GLOBAL BODY DARK BACKGROUND
   ============================================================ */
body { background: var(--bg) !important; }
.page-wrap { background: var(--bg) !important; }
#site-content.main-container { background: var(--bg) !important; }

/* ============================================================
   REMOVE ALL OUTLINES / STRAY BORDERS (yellow line fix)
   ============================================================ */
.adk-hero,
.adk-hero *,
.page-builders,
.page-builders-content-area,
article.page-builders,
.envo-content,
.woo-content,
.page-wrap,
.main-container,
#site-navigation,
.navbar,
.navbar-default,
nav { outline: none !important; outline-width: 0 !important; }
/* Remove any lingering border from entry/article elements */
article, .entry-content, .post, .hentry { border: none !important; outline: none !important; }
/* The adk-hero section itself */
section.adk-hero { outline: none !important; border: none !important; box-shadow: none !important; }
/* Catch-all for any pseudo-elements adding lines */
.page-builders-content-area::before,
.page-builders-content-area::after,
article.page-builders::before,
article.page-builders::after,
.envo-content::before,
.envo-content::after { display: none !important; content: none !important; }

/* ============================================================
   CUSTOM FOOTER
   ============================================================ */
.adk-footer {
  background: var(--surface) !important;
  border-top: 1px solid var(--border) !important;
  padding: 48px 0 0 !important;
  margin-top: 0 !important;
  font-family: var(--font-body) !important;
}
.adk-footer-inner {
  max-width: 1170px;
  margin: 0 auto;
  padding: 0 24px 40px;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
}
.adk-footer-brand {
  font-family: var(--font-head) !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  margin-bottom: 12px !important;
  background: linear-gradient(135deg, var(--purple-2), var(--green));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.adk-footer-desc {
  font-size: 13px !important;
  color: var(--text-3) !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}
.adk-footer-heading {
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--purple-2) !important;
  margin-bottom: 16px !important;
}
.adk-footer ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.adk-footer ul li { margin-bottom: 8px !important; }
.adk-footer ul li a {
  color: var(--text-3) !important;
  font-size: 13px !important;
  text-decoration: none !important;
  transition: color var(--transition) !important;
}
.adk-footer ul li a:hover { color: var(--text) !important; }
.adk-footer-bottom {
  border-top: 1px solid var(--border) !important;
  padding: 16px 24px !important;
  max-width: 1170px;
  margin: 0 auto;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  font-size: 12px !important;
  color: var(--text-3) !important;
}
.adk-footer-pay { color: var(--text-3) !important; }
@media(max-width:900px) { .adk-footer-inner { grid-template-columns: 1fr 1fr; } }
@media(max-width:600px) { .adk-footer-inner { grid-template-columns: 1fr; } .adk-footer-bottom { flex-direction: column; gap: 8px; text-align: center; } }
