/* ==========================================================================
   Rath & Blume Theme — Main Stylesheet
   Design: Dark theme, #00fc72 primary, #5400fe secondary
   Font: Saira, Saira Condensed
   ========================================================================== */

/* ---------- CSS Variables ---------- */
:root {
  --rb-background: #101010;
  --rb-background-alt: #0a0a0a;
  --rb-foreground: #ededed;
  --rb-primary: #00fc72;
  --rb-secondary: #5400fe;
  --rb-accent: #54008e;
  --rb-surface: #252525;
  --rb-surface-light: #434343;
  --rb-surface-dark: #1a1a1a;
  --rb-white-10: rgba(255, 255, 255, 0.1);
  --rb-white-20: rgba(255, 255, 255, 0.2);
  --rb-white-30: rgba(255, 255, 255, 0.3);
  --rb-white-40: rgba(255, 255, 255, 0.4);
  --rb-white-50: rgba(255, 255, 255, 0.5);
  --rb-white-60: rgba(255, 255, 255, 0.6);
  --rb-white-70: rgba(255, 255, 255, 0.7);
  --rb-font-sans: "Saira", Arial, Helvetica, sans-serif;
  --rb-font-condensed: "Saira Condensed", Arial, Helvetica, sans-serif;
  --rb-container: 1280px;
  --rb-radius: 0.5rem;
  --rb-radius-lg: 1rem;
  --rb-radius-xl: 1.5rem;
  --rb-transition: 0.3s ease;
}

/* ---------- Reset & Base ---------- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  background: var(--rb-background);
  color: var(--rb-foreground);
  font-family: var(--rb-font-sans);
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden;
}

::selection {
  background: var(--rb-primary);
  color: var(--rb-background);
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background: var(--rb-surface);
}
::-webkit-scrollbar-thumb {
  background: var(--rb-primary);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--rb-secondary);
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: var(--rb-primary);
  text-decoration: none;
  transition: color var(--rb-transition);
}
a:hover {
  color: var(--rb-foreground);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  line-height: 1.1;
  color: #fff;
}

/* ---------- Utilities ---------- */
.rb-container {
  width: 100%;
  max-width: var(--rb-container);
  margin: 0 auto;
  padding: 0 1.5rem;
}
@media (min-width: 768px) {
  .rb-container {
    padding: 0 3rem;
  }
}

.rb-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.gradient-text {
  background: linear-gradient(
    135deg,
    var(--rb-primary) 0%,
    var(--rb-secondary) 50%,
    var(--rb-accent) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ---------- Header ---------- */
.rb-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  transition:
    background 0.5s ease,
    backdrop-filter 0.5s ease;
  background: transparent;
}
.rb-header.scrolled {
  background: rgba(16, 16, 16, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.rb-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 0;
}

.rb-header__logo img,
.rb-header__logo svg {
  width: 48px;
  height: 48px;
  transition: transform var(--rb-transition);
}
.rb-header__logo:hover img,
.rb-header__logo:hover svg {
  transform: scale(1.05) rotate(6deg);
}

/* Desktop Nav */
.rb-nav {
  display: none;
  align-items: center;
  gap: 3rem;
}
@media (min-width: 768px) {
  .rb-nav {
    display: flex;
  }
}
.rb-nav a {
  position: relative;
  color: var(--rb-white-60);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  transition: color var(--rb-transition);
}
.rb-nav a::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--rb-primary);
  transition: width var(--rb-transition);
}
.rb-nav a:hover {
  color: #fff;
}
.rb-nav a:hover::after {
  width: 100%;
}
.rb-nav a.current-menu-item,
.rb-nav a.current_page_item {
  color: #fff;
}
.rb-nav a.current-menu-item::after,
.rb-nav a.current_page_item::after {
  width: 100%;
}

/* Header CTA */
.rb-header__cta {
  display: none;
  padding: 0.75rem 1.5rem;
  background: #fff;
  color: #000;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 500;
  transition:
    background var(--rb-transition),
    color var(--rb-transition);
}
@media (min-width: 768px) {
  .rb-header__cta {
    display: inline-block;
  }
}
.rb-header__cta:hover {
  background: var(--rb-primary);
  color: #000;
}

/* Cart icon in header */
.rb-header__cart {
  position: relative;
  display: inline-flex;
  align-items: center;
  color: #fff;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  gap: 0.5rem;
}
.rb-header__cart:hover {
  color: var(--rb-primary);
}
.rb-cart-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  background: var(--rb-primary);
  color: #000;
  font-size: 0.7rem;
  font-weight: 700;
  border-radius: 10px;
}

/* Mobile Menu Toggle */
.rb-menu-toggle {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 0.5rem;
  background: none;
  border: none;
  cursor: pointer;
}
@media (min-width: 768px) {
  .rb-menu-toggle {
    display: none;
  }
}
.rb-menu-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: #fff;
  transition:
    transform var(--rb-transition),
    opacity var(--rb-transition);
}
.rb-menu-toggle.active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.rb-menu-toggle.active span:nth-child(2) {
  opacity: 0;
}
.rb-menu-toggle.active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Menu */
.rb-mobile-nav {
  position: fixed;
  inset: 0;
  background: var(--rb-background);
  z-index: 99;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 2rem;
  transform: translateX(100%);
  transition: transform 0.4s ease;
}
.rb-mobile-nav.open {
  transform: translateX(0);
}
.rb-mobile-nav a {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  padding: 1rem 0;
  transition: color var(--rb-transition);
}
.rb-mobile-nav a:hover {
  color: var(--rb-primary);
}

/* ---------- Main Content ---------- */
.rb-main {
  padding-top: 100px;
  min-height: 60vh;
}

.rb-page-header {
  padding: 3rem 0 2rem;
}
.rb-page-header h1 {
  font-size: 2.5rem;
  font-weight: 700;
}
@media (min-width: 768px) {
  .rb-page-header h1 {
    font-size: 3.5rem;
  }
}

/* ---------- Hero Section (Front Page) ---------- */
.rb-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--rb-background);
  padding-top: 5rem;
}

.rb-hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.rb-hero__shape {
  position: absolute;
  top: 15%;
  right: 5%;
  width: 35vw;
  height: 35vw;
  background: linear-gradient(
    135deg,
    var(--rb-primary),
    rgba(0, 252, 114, 0.8),
    var(--rb-secondary)
  );
  border-radius: 3rem;
  transform: rotate(12deg);
  opacity: 0.7;
  box-shadow: 0 25px 60px rgba(0, 252, 114, 0.2);
  animation: rb-float 12s ease-in-out infinite;
}
@media (max-width: 768px) {
  .rb-hero__shape {
    width: 50vw;
    height: 50vw;
    right: -5%;
    top: 10%;
  }
}

.rb-hero__circle {
  position: absolute;
  top: 10%;
  right: -5%;
  width: 55vw;
  height: 55vw;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.03);
}

@keyframes rb-float {
  0%,
  100% {
    transform: rotate(12deg) translateY(-8px);
  }
  50% {
    transform: rotate(14deg) translateY(8px);
  }
}

.rb-hero__content {
  position: relative;
  z-index: 10;
  max-width: 56rem;
}

.rb-hero h1 {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
}
@media (min-width: 768px) {
  .rb-hero h1 {
    font-size: 4rem;
  }
}
@media (min-width: 1024px) {
  .rb-hero h1 {
    font-size: 5rem;
  }
}

.rb-hero h1 .highlight {
  font-style: italic;
  font-weight: 300;
  color: var(--rb-primary);
}

.rb-hero__sub {
  color: var(--rb-white-50);
  font-size: 1rem;
  max-width: 28rem;
  margin-bottom: 2.5rem;
  line-height: 1.7;
}
@media (min-width: 768px) {
  .rb-hero__sub {
    font-size: 1.125rem;
  }
}

.rb-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Buttons */
.rb-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  transition: all var(--rb-transition);
  cursor: pointer;
  border: none;
  font-family: var(--rb-font-sans);
}

.rb-btn--primary {
  background: var(--rb-primary);
  color: #000;
}
.rb-btn--primary:hover {
  background: #fff;
  color: #000;
  transform: scale(1.02);
}

.rb-btn--outline {
  background: transparent;
  color: #fff;
  border: 1px solid var(--rb-white-20);
}
.rb-btn--outline:hover {
  background: #fff;
  color: var(--rb-background);
  border-color: #fff;
}

.rb-btn--secondary {
  background: var(--rb-secondary);
  color: #fff;
}
.rb-btn--secondary:hover {
  background: var(--rb-primary);
  color: #000;
}

.rb-btn--small {
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
}

.rb-btn--large {
  padding: 1rem 2rem;
  font-size: 1rem;
}

/* ---------- Shop / Product Grid ---------- */
.rb-shop-header {
  padding: 2rem 0 1rem;
  border-bottom: 1px solid var(--rb-white-10);
  margin-bottom: 2rem;
}
.rb-shop-header h1 {
  font-size: 2rem;
}
@media (min-width: 768px) {
  .rb-shop-header h1 {
    font-size: 3rem;
  }
}

/* WooCommerce product grid overrides */
.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
  list-style: none;
  padding: 0;
  margin: 0 0 3rem;
}
@media (min-width: 640px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(3, 1fr);
  }
}

.woocommerce ul.products li.product {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  overflow: hidden;
  transition:
    border-color var(--rb-transition),
    transform var(--rb-transition);
  margin: 0;
  padding: 0;
  width: 100%;
  float: none;
}
.woocommerce ul.products li.product:hover {
  border-color: rgba(0, 252, 114, 0.3);
  transform: translateY(-4px);
}

.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  margin: 0;
  border-radius: 0;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 1.1rem;
  font-weight: 600;
  color: #fff;
  padding: 1rem 1.25rem 0.25rem;
  margin: 0;
  transition: color var(--rb-transition);
}
.woocommerce ul.products li.product:hover .woocommerce-loop-product__title {
  color: var(--rb-primary);
}

.woocommerce ul.products li.product .price {
  padding: 0 1.25rem;
  color: var(--rb-white-60);
  font-size: 1rem;
  font-weight: 500;
}
.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--rb-primary);
  font-weight: 700;
}
.woocommerce ul.products li.product .price del {
  color: var(--rb-white-30);
  font-size: 0.875rem;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.woocommerce ul.products li.product .product_type_variable {
  display: block;
  margin: 1rem 1.25rem 1.25rem;
  padding: 0.75rem 1.25rem;
  background: var(--rb-primary);
  color: #000;
  text-align: center;
  font-family: var(--rb-font-sans);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border-radius: var(--rb-radius);
  transition: all var(--rb-transition);
  border: none;
  cursor: pointer;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
  background: #fff;
  color: #000;
}

/* Sale Badge */
.rb-sale-badge,
.woocommerce span.onsale {
  position: absolute;
  top: 1rem;
  left: 1rem;
  background: var(--rb-primary);
  color: #000;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.25rem 0.75rem;
  border-radius: 2rem;
  z-index: 5;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  min-width: auto;
  min-height: auto;
  line-height: 1.5;
}

/* Star rating */
.woocommerce .star-rating {
  color: var(--rb-primary);
}
.woocommerce .star-rating::before {
  color: var(--rb-white-20);
}

/* ---------- Single Product ---------- */
.woocommerce div.product {
  padding: 2rem 0;
}

.woocommerce div.product div.images {
  background: var(--rb-surface-dark);
  border-radius: var(--rb-radius-xl);
  overflow: hidden;
  border: 1px solid var(--rb-white-10);
}

.woocommerce div.product .product_title {
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.5rem;
}

.woocommerce div.product p.price {
  font-size: 1.5rem;
  color: var(--rb-primary);
  font-weight: 700;
  margin-bottom: 1.5rem;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--rb-white-60);
  line-height: 1.7;
  margin-bottom: 2rem;
}

.woocommerce div.product form.cart {
  margin-bottom: 2rem;
}

.woocommerce div.product form.cart .quantity input[type="number"] {
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-20);
  color: #fff;
  padding: 0.75rem;
  font-family: var(--rb-font-sans);
  font-size: 1rem;
  width: 80px;
  border-radius: var(--rb-radius);
}

.woocommerce div.product form.cart .single_add_to_cart_button {
  background: var(--rb-primary);
  color: #000;
  font-family: var(--rb-font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.85rem 2rem;
  border: none;
  border-radius: var(--rb-radius);
  cursor: pointer;
  transition: all var(--rb-transition);
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  background: #fff;
  color: #000;
  transform: scale(1.02);
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs {
  margin-top: 3rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  list-style: none;
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--rb-white-10);
  padding: 0;
  margin: 0 0 2rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after {
  display: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: none;
  border: none;
  margin: 0;
  padding: 0;
  border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
  display: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 1rem 1.5rem;
  color: var(--rb-white-50);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 500;
  border-bottom: 2px solid transparent;
  transition: all var(--rb-transition);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: #fff;
  border-bottom-color: var(--rb-primary);
}
.woocommerce div.product .woocommerce-tabs .panel {
  color: var(--rb-white-70);
  line-height: 1.7;
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}

/* Related products */
.woocommerce .related.products h2,
.woocommerce .upsells.products h2 {
  font-size: 1.75rem;
  margin-bottom: 1.5rem;
}

/* ---------- Cart ---------- */
.woocommerce-cart .woocommerce table.shop_table {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  overflow: hidden;
  border-collapse: collapse;
}
.woocommerce table.shop_table th {
  background: var(--rb-surface);
  color: var(--rb-white-50);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--rb-white-10);
}
.woocommerce table.shop_table td {
  padding: 1rem 1.25rem;
  color: var(--rb-white-70);
  border-bottom: 1px solid var(--rb-white-10);
  vertical-align: middle;
}
.woocommerce table.shop_table td.product-name a {
  color: #fff;
  font-weight: 600;
}
.woocommerce table.shop_table td.product-name a:hover {
  color: var(--rb-primary);
}

.woocommerce table.shop_table td.product-quantity input[type="number"] {
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-20);
  color: #fff;
  padding: 0.5rem;
  width: 60px;
  border-radius: var(--rb-radius);
  font-family: var(--rb-font-sans);
}

.woocommerce table.shop_table td.product-remove a {
  color: var(--rb-white-40) !important;
  font-size: 1.5rem;
}
.woocommerce table.shop_table td.product-remove a:hover {
  color: #ff4444 !important;
}

.woocommerce .cart_totals {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  padding: 2rem;
}
.woocommerce .cart_totals h2 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
.woocommerce .cart_totals table {
  border: none;
}
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
  padding: 0.75rem 0;
  color: var(--rb-white-70);
  border-bottom: 1px solid var(--rb-white-10);
}
.woocommerce .cart_totals .order-total td {
  color: var(--rb-primary);
  font-size: 1.25rem;
  font-weight: 700;
}

.woocommerce .wc-proceed-to-checkout .checkout-button,
.woocommerce a.checkout-button {
  display: block;
  width: 100%;
  background: var(--rb-primary) !important;
  color: #000 !important;
  font-family: var(--rb-font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 2rem !important;
  text-align: center;
  border-radius: var(--rb-radius);
  transition: all var(--rb-transition);
}
.woocommerce .wc-proceed-to-checkout .checkout-button:hover {
  background: #fff !important;
  color: #000 !important;
}

/* Update Cart button */
.woocommerce button[name="update_cart"],
.woocommerce input[name="update_cart"] {
  background: var(--rb-surface) !important;
  color: #fff !important;
  border: 1px solid var(--rb-white-20) !important;
  font-family: var(--rb-font-sans);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.75rem 1.5rem !important;
  border-radius: var(--rb-radius);
  cursor: pointer;
  transition: all var(--rb-transition);
}
.woocommerce button[name="update_cart"]:hover {
  background: var(--rb-white-20) !important;
}

/* Coupon */
.woocommerce .coupon input[type="text"] {
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-20);
  color: #fff;
  padding: 0.65rem 1rem;
  font-family: var(--rb-font-sans);
  border-radius: var(--rb-radius);
}
.woocommerce .coupon button {
  background: var(--rb-surface);
  color: #fff;
  border: 1px solid var(--rb-white-20);
  padding: 0.65rem 1.25rem;
  font-family: var(--rb-font-sans);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  cursor: pointer;
  border-radius: var(--rb-radius);
  transition: all var(--rb-transition);
}
.woocommerce .coupon button:hover {
  background: var(--rb-white-20);
}

/* ---------- Checkout ---------- */
.woocommerce-checkout .woocommerce {
  color: var(--rb-white-70);
}

.woocommerce form .form-row label {
  color: var(--rb-white-50);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.5rem;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout #payment .form-row input.input-text {
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-20);
  color: #fff;
  padding: 0.75rem 1rem;
  font-family: var(--rb-font-sans);
  font-size: 0.95rem;
  border-radius: var(--rb-radius);
  transition: border-color var(--rb-transition);
  width: 100%;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--rb-primary);
  outline: none;
  box-shadow: 0 0 0 2px rgba(0, 252, 114, 0.1);
}

.woocommerce form .form-row select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23ededed' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

.woocommerce-checkout #payment {
  background: var(--rb-surface-dark) !important;
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
}
.woocommerce-checkout #payment ul.payment_methods {
  border-bottom: 1px solid var(--rb-white-10);
  padding: 1.5rem;
}
.woocommerce-checkout #payment ul.payment_methods li {
  color: var(--rb-white-70);
}
.woocommerce-checkout #payment div.place-order {
  padding: 1.5rem;
}

#place_order {
  background: var(--rb-primary) !important;
  color: #000 !important;
  font-family: var(--rb-font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 2rem !important;
  border: none;
  border-radius: var(--rb-radius);
  cursor: pointer;
  width: 100%;
  transition: all var(--rb-transition);
}
#place_order:hover {
  background: #fff !important;
}

/* ---------- My Account ---------- */
.woocommerce-account .woocommerce-MyAccount-navigation {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  padding: 1rem 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 0.75rem 1.5rem;
  color: var(--rb-white-50);
  font-size: 0.875rem;
  transition: all var(--rb-transition);
  border-left: 2px solid transparent;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: #fff;
  background: var(--rb-white-10);
  border-left-color: var(--rb-primary);
}

/* ---------- Notices ---------- */
.woocommerce-message,
.woocommerce-info {
  background: var(--rb-surface-dark) !important;
  border-top-color: var(--rb-primary) !important;
  color: var(--rb-white-70);
}
.woocommerce-message::before {
  color: var(--rb-primary);
}

.woocommerce-error {
  background: var(--rb-surface-dark) !important;
  border-top-color: #ff4444 !important;
  color: var(--rb-white-70);
}

.woocommerce-message a.button,
.woocommerce-info a.button {
  background: var(--rb-primary);
  color: #000;
  font-family: var(--rb-font-sans);
  border-radius: var(--rb-radius);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ---------- Pagination ---------- */
.woocommerce nav.woocommerce-pagination {
  margin: 3rem 0;
}
.woocommerce nav.woocommerce-pagination ul {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  border: none;
}
.woocommerce nav.woocommerce-pagination ul li {
  border: none;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-10);
  color: var(--rb-white-60);
  border-radius: var(--rb-radius);
  font-size: 0.875rem;
  transition: all var(--rb-transition);
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--rb-primary);
  color: #000;
  border-color: var(--rb-primary);
}
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--rb-primary);
  color: #000;
  border-color: var(--rb-primary);
  font-weight: 600;
}

/* ---------- Ordering / Results ---------- */
.woocommerce .woocommerce-ordering,
.woocommerce .woocommerce-result-count {
  color: var(--rb-white-50);
  font-size: 0.875rem;
}
.woocommerce .woocommerce-ordering select {
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-20);
  color: #fff;
  padding: 0.5rem 1rem;
  border-radius: var(--rb-radius);
  font-family: var(--rb-font-sans);
  font-size: 0.875rem;
}

/* ---------- Breadcrumbs ---------- */
.woocommerce .woocommerce-breadcrumb {
  color: var(--rb-white-40);
  font-size: 0.875rem;
  padding: 1.5rem 0 0;
}
.woocommerce .woocommerce-breadcrumb a {
  color: var(--rb-white-50);
}
.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--rb-primary);
}

/* ---------- Footer ---------- */
.rb-footer {
  background: var(--rb-background);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding: 4rem 0 0;
}

.rb-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  margin-bottom: 4rem;
}
@media (min-width: 768px) {
  .rb-footer__grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }
}

.rb-footer__brand {
  max-width: 24rem;
}
.rb-footer__brand img,
.rb-footer__brand svg {
  width: 80px;
  height: 80px;
  margin-bottom: 1.5rem;
}
.rb-footer__brand p {
  color: var(--rb-white-40);
  line-height: 1.7;
}

.rb-footer__col h3 {
  color: var(--rb-white-40);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 1.5rem;
  font-weight: 400;
}

.rb-footer__col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.rb-footer__col ul li {
  margin-bottom: 0.75rem;
}
.rb-footer__col ul li a {
  color: var(--rb-white-70);
  transition: color var(--rb-transition);
}
.rb-footer__col ul li a:hover {
  color: var(--rb-primary);
}

.rb-footer__address p {
  color: var(--rb-white-70);
  margin-bottom: 0.25rem;
}
.rb-footer__address + .rb-footer__address {
  margin-top: 1rem;
}

.rb-footer__bottom {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
  padding: 2rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}
@media (min-width: 768px) {
  .rb-footer__bottom {
    flex-direction: row;
  }
}

.rb-footer__copyright {
  color: var(--rb-white-30);
  font-size: 0.875rem;
}

.rb-footer__legal {
  display: flex;
  gap: 2rem;
}
.rb-footer__legal a {
  color: var(--rb-white-30);
  font-size: 0.875rem;
  transition: color var(--rb-transition);
}
.rb-footer__legal a:hover {
  color: var(--rb-white-60);
}

/* ---------- Widget Styles ---------- */
.rb-widget {
  margin-bottom: 2rem;
}
.rb-widget__title {
  color: var(--rb-white-50);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--rb-white-10);
}
.rb-widget ul {
  list-style: none;
  padding: 0;
}
.rb-widget ul li {
  margin-bottom: 0.5rem;
}
.rb-widget ul li a {
  color: var(--rb-white-60);
  font-size: 0.9rem;
}

.rb-footer-widget__title {
  color: var(--rb-white-40);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 1rem;
  font-weight: 400;
}

/* ---------- Blog / Posts ---------- */
.rb-posts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  margin-bottom: 3rem;
}
@media (min-width: 640px) {
  .rb-posts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .rb-posts-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.rb-post-card {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  overflow: hidden;
  transition:
    border-color var(--rb-transition),
    transform var(--rb-transition);
}
.rb-post-card:hover {
  border-color: rgba(0, 252, 114, 0.3);
  transform: translateY(-4px);
}

.rb-post-card__image {
  aspect-ratio: 4/3;
  overflow: hidden;
}
.rb-post-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.rb-post-card:hover .rb-post-card__image img {
  transform: scale(1.05);
}

.rb-post-card__content {
  padding: 1.5rem;
}
.rb-post-card__meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--rb-white-40);
  font-size: 0.75rem;
  margin-bottom: 0.75rem;
}
.rb-post-card__title {
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
}
.rb-post-card__title a {
  color: #fff;
  transition: color var(--rb-transition);
}
.rb-post-card__title a:hover {
  color: var(--rb-primary);
}
.rb-post-card__excerpt {
  color: var(--rb-white-50);
  font-size: 0.875rem;
  line-height: 1.6;
  margin-bottom: 1rem;
}
.rb-post-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--rb-primary);
  font-size: 0.875rem;
  font-weight: 600;
}

/* Single Post */
.rb-single-post {
  max-width: 48rem;
  margin: 0 auto;
  padding: 2rem 0 4rem;
}
.rb-single-post__header {
  margin-bottom: 2rem;
}
.rb-single-post__title {
  font-size: 2.5rem;
  margin-bottom: 1rem;
}
.rb-single-post__meta {
  color: var(--rb-white-40);
  font-size: 0.875rem;
}
.rb-single-post__content {
  color: var(--rb-white-70);
  line-height: 1.8;
  font-size: 1.05rem;
}
.rb-single-post__content h2 {
  font-size: 1.75rem;
  margin: 2rem 0 1rem;
}
.rb-single-post__content h3 {
  font-size: 1.375rem;
  margin: 1.5rem 0 0.75rem;
}
.rb-single-post__content p {
  margin-bottom: 1.25rem;
}
.rb-single-post__content img {
  border-radius: var(--rb-radius-lg);
  margin: 2rem 0;
}
.rb-single-post__content blockquote {
  border-left: 3px solid var(--rb-primary);
  padding-left: 1.5rem;
  margin: 2rem 0;
  color: var(--rb-white-60);
  font-style: italic;
}
.rb-single-post__content ul,
.rb-single-post__content ol {
  padding-left: 1.5rem;
  margin-bottom: 1.25rem;
}
.rb-single-post__content li {
  margin-bottom: 0.5rem;
}

/* ==========================================================================
   Global Form Elements — Dark Theme
   ========================================================================== */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="number"],
input[type="search"],
input[type="date"],
input[type="datetime-local"],
input[type="month"],
input[type="week"],
input[type="time"],
textarea,
select {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: #fff !important;
  padding: 0.75rem 1rem;
  font-family: var(--rb-font-sans);
  font-size: 0.95rem;
  border-radius: var(--rb-radius) !important;
  transition: border-color var(--rb-transition);
  width: 100%;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus {
  border-color: var(--rb-primary) !important;
  outline: none;
  box-shadow: 0 0 0 2px rgba(0, 252, 114, 0.15);
}
input::placeholder,
textarea::placeholder {
  color: var(--rb-white-30) !important;
}

select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23ededed' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 1rem center !important;
  padding-right: 2.5rem;
  cursor: pointer;
}

select option {
  background: var(--rb-surface);
  color: #fff;
}

/* Global button resets */
button,
input[type="submit"],
input[type="button"],
.button,
.wp-element-button,
.wp-block-button__link {
  font-family: var(--rb-font-sans);
  cursor: pointer;
  transition: all var(--rb-transition);
}

/* Checkbox & Radio */
input[type="checkbox"],
input[type="radio"] {
  width: 1.15rem !important;
  height: 1.15rem !important;
  accent-color: var(--rb-primary);
  cursor: pointer;
  border: 1px solid var(--rb-white-30) !important;
  border-radius: 3px !important;
  background: var(--rb-surface) !important;
  padding: 0;
}
input[type="checkbox"]:checked,
input[type="radio"]:checked {
  background: var(--rb-primary) !important;
  border-color: var(--rb-primary) !important;
}

label {
  color: var(--rb-white-60);
  font-size: 0.875rem;
}

/* ==========================================================================
   WooCommerce Blocks — Checkout & Cart
   ========================================================================== */

/* -- Layout -- */
.wc-block-checkout,
.wc-block-cart {
  color: var(--rb-white-70);
}

.wc-block-checkout .wp-block-woocommerce-checkout-fields-block {
  color: var(--rb-foreground);
}

/* -- Section headings -- */
.wc-block-components-checkout-step__title,
.wc-block-components-checkout-step__heading,
.wc-block-components-checkout-step__heading span,
.wc-block-components-checkout-step h2,
.wc-block-components-checkout-step h3,
.wc-block-checkout h2,
.wc-block-checkout h3,
.wc-block-checkout h4,
.wc-block-checkout .wc-block-components-title,
.wp-block-woocommerce-checkout h1,
.wp-block-woocommerce-checkout h2,
.wp-block-woocommerce-checkout h3,
.wp-block-woocommerce-checkout h4,
.wp-block-woocommerce-checkout p,
.wp-block-woocommerce-checkout label,
.wp-block-woocommerce-checkout legend,
.wp-block-woocommerce-checkout span,
.wc-block-checkout__sidebar
  .wc-block-components-order-summary
  .wc-block-components-panel__button,
.wc-block-components-totals-wrapper .wc-block-components-totals-item__label {
  color: #fff !important;
  font-family: var(--rb-font-sans);
  font-weight: 700;
}

.wc-block-components-checkout-step__description,
.wc-block-checkout .wc-block-components-checkout-step__description {
  color: var(--rb-white-50) !important;
}

/* Force all checkout text white */
.wc-block-checkout,
.wc-block-checkout
  *:not(input):not(textarea):not(select):not(option):not(button):not(
    .wc-block-components-button__text
  ) {
  color: #ededed !important;
}
.wc-block-checkout a {
  color: var(--rb-primary) !important;
}

/* -- Text inputs (Block Checkout) -- */
.wc-block-components-text-input input[type="text"],
.wc-block-components-text-input input[type="email"],
.wc-block-components-text-input input[type="tel"],
.wc-block-components-text-input input[type="password"],
.wc-block-components-text-input input[type="url"],
.wc-block-components-text-input input[type="number"],
.wc-block-components-textarea textarea,
.wc-block-components-text-input input,
.wc-block-components-address-form input {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: #fff !important;
  padding: 0.85rem 1rem !important;
  font-family: var(--rb-font-sans) !important;
  font-size: 0.95rem !important;
  border-radius: var(--rb-radius) !important;
  height: auto !important;
  line-height: 1.4 !important;
}
.wc-block-components-text-input input:focus,
.wc-block-components-text-input input:active,
.wc-block-components-address-form input:focus {
  border-color: var(--rb-primary) !important;
  box-shadow: 0 0 0 2px rgba(0, 252, 114, 0.15) !important;
  outline: none !important;
}

/* Floating label */
.wc-block-components-text-input label,
.wc-block-components-address-form label {
  color: var(--rb-white-40) !important;
  font-family: var(--rb-font-sans) !important;
  font-size: 0.85rem !important;
}
.wc-block-components-text-input.is-active label,
.wc-block-components-text-input:focus-within label {
  color: var(--rb-primary) !important;
  font-size: 0.7rem !important;
}

/* -- Select / Combobox (Block Checkout) -- */
.wc-block-components-combobox .wc-block-components-combobox-control,
.wc-block-components-combobox input,
.wc-block-components-combobox .components-combobox-control input,
.wc-block-components-state-input select,
.wc-block-components-country-input select,
.wc-block-components-country-input input,
.wc-block-components-state-input input {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: #fff !important;
  font-family: var(--rb-font-sans) !important;
  font-size: 0.95rem !important;
  border-radius: var(--rb-radius) !important;
  padding: 0.85rem 1rem !important;
}
.wc-block-components-combobox .components-combobox-control input:focus,
.wc-block-components-combobox input:focus {
  border-color: var(--rb-primary) !important;
  box-shadow: 0 0 0 2px rgba(0, 252, 114, 0.15) !important;
  outline: none !important;
}

/* Combobox label */
.wc-block-components-combobox label,
.wc-block-components-country-input label,
.wc-block-components-state-input label {
  color: var(--rb-white-40) !important;
}

/* Combobox dropdown */
.wc-block-components-combobox .components-form-token-field__suggestions-list,
.wc-block-components-combobox ul[role="listbox"] {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  border-radius: var(--rb-radius) !important;
  max-height: 200px;
  overflow-y: auto;
}
.wc-block-components-combobox .components-form-token-field__suggestions-list li,
.wc-block-components-combobox ul[role="listbox"] li {
  color: var(--rb-white-70) !important;
  padding: 0.5rem 1rem !important;
  font-size: 0.9rem !important;
}
.wc-block-components-combobox
  .components-form-token-field__suggestions-list
  li:hover,
.wc-block-components-combobox
  .components-form-token-field__suggestions-list
  li[aria-selected="true"],
.wc-block-components-combobox ul[role="listbox"] li:hover {
  background: var(--rb-primary) !important;
  color: #000 !important;
}

/* -- Order Summary Sidebar -- */
.wc-block-components-order-summary {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  padding: 1.5rem;
}

.wc-block-checkout__sidebar .wc-block-components-order-summary {
  background: var(--rb-surface-dark);
}

.wc-block-components-order-summary
  .wc-block-components-order-summary-item__image {
  border-radius: var(--rb-radius);
  overflow: hidden;
  border: 1px solid var(--rb-white-10);
}

.wc-block-components-order-summary
  .wc-block-components-order-summary-item__description {
  color: var(--rb-white-60);
  font-size: 0.85rem;
}

.wc-block-components-order-summary
  .wc-block-components-order-summary-item__individual-price,
.wc-block-components-order-summary
  .wc-block-components-order-summary-item__total-price {
  color: var(--rb-white-70);
}

.wc-block-components-order-summary-item__description
  .wc-block-components-product-name {
  color: #fff !important;
  font-weight: 600;
}

/* Quantity badge */
.wc-block-components-order-summary-item__quantity {
  background: var(--rb-primary) !important;
  color: #000 !important;
  border: none !important;
  font-weight: 700;
  box-shadow: 0 2px 6px rgba(0, 252, 114, 0.3);
}

/* -- Totals -- */
.wc-block-components-totals-wrapper {
  border-color: var(--rb-white-10) !important;
}

.wc-block-components-totals-item__label {
  color: var(--rb-white-60) !important;
}

.wc-block-components-totals-item__value {
  color: #fff !important;
  font-weight: 600;
}

.wc-block-components-totals-footer-item
  .wc-block-components-totals-item__label {
  color: #fff !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
}

.wc-block-components-totals-footer-item
  .wc-block-components-totals-item__value {
  color: var(--rb-primary) !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
}

/* -- Discount / Coupon -- */
.wc-block-components-totals-discount__coupon-list .wc-block-components-chip {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: var(--rb-white-70) !important;
  border-radius: 2rem !important;
  font-size: 0.8rem;
}
.wc-block-components-chip__remove {
  color: var(--rb-white-50) !important;
}
.wc-block-components-chip__remove:hover {
  color: #ff4444 !important;
}

/* Coupon panel */
.wc-block-components-totals-coupon .wc-block-components-panel__button {
  color: var(--rb-white-50) !important;
  font-size: 0.875rem;
}
.wc-block-components-totals-coupon .wc-block-components-panel__button:hover {
  color: var(--rb-primary) !important;
}

.wc-block-components-totals-coupon__content input[type="text"] {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: #fff !important;
  border-radius: var(--rb-radius) !important;
}

.wc-block-components-totals-coupon__content .wc-block-components-button {
  background: var(--rb-surface) !important;
  color: #fff !important;
  border: 1px solid var(--rb-white-20) !important;
  border-radius: var(--rb-radius) !important;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.wc-block-components-totals-coupon__content .wc-block-components-button:hover {
  background: var(--rb-white-20) !important;
  border-color: var(--rb-white-30) !important;
}

/* -- Place Order Button -- */
.wc-block-checkout__actions .wc-block-components-checkout-place-order-button,
.wc-block-components-checkout-place-order-button,
.wc-block-checkout__actions button {
  background: var(--rb-primary) !important;
  color: #000 !important;
  font-family: var(--rb-font-sans) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  padding: 1rem 2.5rem !important;
  border: none !important;
  border-radius: var(--rb-radius) !important;
  cursor: pointer;
  transition: all var(--rb-transition);
  min-height: 0 !important;
}
.wc-block-checkout__actions
  .wc-block-components-checkout-place-order-button:hover,
.wc-block-components-checkout-place-order-button:hover {
  background: #fff !important;
  color: #000 !important;
  transform: scale(1.02);
}

/* -- Return to Cart link -- */
.wc-block-checkout__actions .wc-block-components-checkout-return-to-cart-button,
.wc-block-components-checkout-return-to-cart-button {
  color: var(--rb-white-50) !important;
  font-family: var(--rb-font-sans);
  font-size: 0.875rem;
  text-decoration: none !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
.wc-block-checkout__actions
  .wc-block-components-checkout-return-to-cart-button:hover,
.wc-block-components-checkout-return-to-cart-button:hover {
  color: var(--rb-primary) !important;
}

/* -- Checkout Steps -- */
.wc-block-components-checkout-step {
  border-color: var(--rb-white-10) !important;
  padding-bottom: 1.5rem;
}

.wc-block-components-checkout-step::after {
  border-color: var(--rb-white-10) !important;
}

/* -- Shipping / Payment Methods -- */
.wc-block-components-radio-control__option,
.wc-block-components-payment-method-label {
  color: var(--rb-white-70) !important;
}

.wc-block-components-radio-control .wc-block-components-radio-control__input {
  border-color: var(--rb-white-30) !important;
}
.wc-block-components-radio-control
  .wc-block-components-radio-control__input:checked {
  border-color: var(--rb-primary) !important;
  background: var(--rb-primary) !important;
}

.wc-block-components-radio-control__option--checked {
  background: var(--rb-surface) !important;
  border-color: var(--rb-primary) !important;
}

/* Shipping options panel */
.wc-block-components-shipping-rates-control__package {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  padding: 1rem;
}

/* -- Notes / Additional Fields -- */
.wc-block-checkout__add-note .wc-block-components-textarea,
.wc-block-checkout__add-note textarea {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: #fff !important;
  border-radius: var(--rb-radius) !important;
  font-family: var(--rb-font-sans);
  padding: 0.75rem 1rem;
}

.wc-block-checkout__add-note .wc-block-components-checkbox__label,
.wc-block-components-checkbox__label {
  color: var(--rb-white-60) !important;
  font-size: 0.9rem;
}

/* -- Terms & Privacy -- */
.wc-block-checkout__terms,
.wc-block-components-checkout-policies {
  color: var(--rb-white-40) !important;
  font-size: 0.85rem;
}
.wc-block-checkout__terms a,
.wc-block-components-checkout-policies a {
  color: var(--rb-primary) !important;
}
.wc-block-checkout__terms a:hover,
.wc-block-components-checkout-policies a:hover {
  color: #fff !important;
}

/* -- Error / Validation States -- */
.wc-block-components-text-input.has-error input,
.wc-block-components-text-input.has-error
  .wc-block-components-text-input__input {
  border-color: #ff4444 !important;
}
.wc-block-components-validation-error {
  color: #ff4444 !important;
  font-size: 0.8rem;
  margin-top: 0.25rem;
}

/* -- Notices (Block Cart/Checkout) -- */
.wc-block-components-notice-banner {
  background: var(--rb-surface-dark) !important;
  border: 1px solid var(--rb-white-10) !important;
  border-radius: var(--rb-radius) !important;
  color: var(--rb-white-70) !important;
  padding: 1rem 1.25rem !important;
}
.wc-block-components-notice-banner.is-error {
  border-color: #ff4444 !important;
}
.wc-block-components-notice-banner.is-success {
  border-color: var(--rb-primary) !important;
}
.wc-block-components-notice-banner .wc-block-components-notice-banner__content {
  color: var(--rb-white-70) !important;
}

/* ==========================================================================
   WooCommerce Blocks — Cart Page
   ========================================================================== */
.wc-block-cart .wc-block-cart-items {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  overflow: hidden;
}

.wc-block-cart .wc-block-cart-items__row {
  border-bottom: 1px solid var(--rb-white-10) !important;
  padding: 1.25rem !important;
}

.wc-block-cart .wc-block-cart-items__header {
  color: var(--rb-white-40);
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
}

.wc-block-cart .wc-block-components-product-name {
  color: #fff !important;
  font-weight: 600;
}
.wc-block-cart .wc-block-components-product-name:hover {
  color: var(--rb-primary) !important;
}

.wc-block-cart .wc-block-components-product-metadata {
  color: var(--rb-white-50) !important;
  font-size: 0.8rem;
}

.wc-block-cart .wc-block-components-product-price {
  color: var(--rb-white-70) !important;
}

/* Cart quantity selector */
.wc-block-components-quantity-selector {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  border-radius: var(--rb-radius) !important;
  overflow: hidden;
}
.wc-block-components-quantity-selector input {
  background: transparent !important;
  color: #fff !important;
  border: none !important;
  text-align: center;
  font-family: var(--rb-font-sans);
}
.wc-block-components-quantity-selector button {
  background: transparent !important;
  color: var(--rb-white-60) !important;
  border: none !important;
}
.wc-block-components-quantity-selector button:hover {
  color: var(--rb-primary) !important;
  background: var(--rb-white-10) !important;
}

/* Remove item */
.wc-block-cart-item__remove-link {
  color: var(--rb-white-40) !important;
  font-size: 0.8rem;
}
.wc-block-cart-item__remove-link:hover {
  color: #ff4444 !important;
}

/* Cart totals sidebar */
.wc-block-cart .wc-block-cart__totals-title {
  color: #fff !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Cart proceed to checkout button */
.wc-block-cart__submit-container .wc-block-cart__submit-button,
.wc-block-cart__submit-button {
  background: var(--rb-primary) !important;
  color: #000 !important;
  font-family: var(--rb-font-sans) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  padding: 1rem 2rem !important;
  border: none !important;
  border-radius: var(--rb-radius) !important;
  width: 100%;
  transition: all var(--rb-transition);
}
.wc-block-cart__submit-container .wc-block-cart__submit-button:hover,
.wc-block-cart__submit-button:hover {
  background: #fff !important;
  color: #000 !important;
}

/* Cart item image */
.wc-block-cart-items .wc-block-components-product-image {
  border-radius: var(--rb-radius);
  overflow: hidden;
  border: 1px solid var(--rb-white-10);
}
.wc-block-cart-items .wc-block-components-product-image img {
  border-radius: var(--rb-radius);
}

/* ==========================================================================
   WooCommerce General Block Overrides
   ========================================================================== */

/* Panel toggles (coupons, order notes, etc.) */
.wc-block-components-panel__button {
  color: var(--rb-white-50) !important;
  font-family: var(--rb-font-sans);
}
.wc-block-components-panel__button:hover {
  color: var(--rb-primary) !important;
}
.wc-block-components-panel__button svg {
  fill: var(--rb-white-40);
}

/* Block sidebar dividers */
.wc-block-components-sidebar .wc-block-components-panel,
.wc-block-checkout__sidebar .wc-block-components-panel {
  border-color: var(--rb-white-10) !important;
}

/* Loading/spinner states */
.wc-block-components-spinner::after {
  border-color: var(--rb-primary) transparent transparent !important;
}

/* Block product table links */
.wc-block-components-product-name {
  color: #fff !important;
}

/* Payment methods in blocks */
.wc-block-components-express-payment,
.wc-block-components-express-payment-continue-rule {
  color: var(--rb-white-40) !important;
}
.wc-block-components-express-payment-continue-rule::before,
.wc-block-components-express-payment-continue-rule::after {
  border-color: var(--rb-white-10) !important;
}

/* Local pickup / shipping toggle */
.wc-block-components-shipping-method__option {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: var(--rb-white-70) !important;
  border-radius: var(--rb-radius) !important;
}
.wc-block-components-shipping-method__option--selected {
  border-color: var(--rb-primary) !important;
  background: var(--rb-surface-dark) !important;
}

/* Form row (WC block) */
.wc-block-components-address-form
  .wc-block-components-address-form__address_1-toggle {
  color: var(--rb-primary) !important;
  font-size: 0.85rem;
}

/* Various WC block elements text color fix */
.wc-block-checkout p,
.wc-block-cart p {
  color: var(--rb-white-60);
}

/* Select2 / WC enhanced select */
.select2-container--default .select2-selection--single {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  border-radius: var(--rb-radius) !important;
  height: auto !important;
  padding: 0.5rem 1rem;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  color: #fff !important;
  line-height: 1.6;
  font-family: var(--rb-font-sans);
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%);
  right: 0.75rem;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: var(--rb-white-50) transparent transparent !important;
}
.select2-dropdown {
  background: var(--rb-surface) !important;
  border: 1px solid var(--rb-white-20) !important;
  border-radius: var(--rb-radius) !important;
}
.select2-search--dropdown .select2-search__field {
  background: var(--rb-surface-dark) !important;
  border: 1px solid var(--rb-white-20) !important;
  color: #fff !important;
  border-radius: var(--rb-radius) !important;
  padding: 0.5rem;
}
.select2-results__option {
  color: var(--rb-white-70) !important;
  padding: 0.5rem 1rem !important;
}
.select2-results__option--highlighted,
.select2-results__option[aria-selected="true"] {
  background: var(--rb-primary) !important;
  color: #000 !important;
}

/* ==========================================================================
   WooCommerce My Account Block Styles
   ========================================================================== */
.woocommerce-form-login,
.woocommerce-form-register,
.woocommerce form.login,
.woocommerce form.register {
  background: var(--rb-surface-dark);
  border: 1px solid var(--rb-white-10);
  border-radius: var(--rb-radius-lg);
  padding: 2rem;
}

.woocommerce form.login .form-row label,
.woocommerce form.register .form-row label {
  color: var(--rb-white-60);
}

.woocommerce form .form-row .woocommerce-form__label-for-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--rb-white-50);
  font-size: 0.875rem;
}

.woocommerce .woocommerce-form-login__submit,
.woocommerce .woocommerce-form-register__submit,
.woocommerce form .button,
.woocommerce .button {
  background: var(--rb-primary) !important;
  color: #000 !important;
  font-family: var(--rb-font-sans);
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.85rem 2rem !important;
  border: none !important;
  border-radius: var(--rb-radius) !important;
  cursor: pointer;
  transition: all var(--rb-transition);
}
.woocommerce .button:hover {
  background: #fff !important;
  color: #000 !important;
}

/* Lost password link */
.woocommerce .lost_password a {
  color: var(--rb-white-40);
  font-size: 0.85rem;
}
.woocommerce .lost_password a:hover {
  color: var(--rb-primary);
}

/* ---------- Pages ---------- */
.rb-page-content {
  padding: 2rem 0 4rem;
  color: var(--rb-white-70);
  line-height: 1.8;
}
.rb-page-content h1,
.rb-page-content h2,
.rb-page-content h3 {
  margin-bottom: 1rem;
}
.rb-page-content p {
  margin-bottom: 1.25rem;
}

/* ---------- Search ---------- */
.rb-search-form {
  display: flex;
  gap: 0.5rem;
  max-width: 32rem;
  margin-bottom: 2rem;
}
.rb-search-form input[type="search"] {
  flex: 1;
  background: var(--rb-surface);
  border: 1px solid var(--rb-white-20);
  color: #fff;
  padding: 0.75rem 1rem;
  font-family: var(--rb-font-sans);
  border-radius: var(--rb-radius);
}
.rb-search-form input[type="search"]:focus {
  border-color: var(--rb-primary);
  outline: none;
}
.rb-search-form button {
  background: var(--rb-primary);
  color: #000;
  border: none;
  padding: 0.75rem 1.5rem;
  font-family: var(--rb-font-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.8rem;
  cursor: pointer;
  border-radius: var(--rb-radius);
  transition: background var(--rb-transition);
}
.rb-search-form button:hover {
  background: #fff;
}

/* ---------- 404 ---------- */
.rb-404 {
  text-align: center;
  padding: 6rem 0;
}
.rb-404 h1 {
  font-size: 8rem;
  line-height: 1;
  margin-bottom: 1rem;
}
.rb-404 p {
  color: var(--rb-white-50);
  font-size: 1.125rem;
  margin-bottom: 2rem;
}

/* ---------- Loading animation override for WC ---------- */
.woocommerce .blockUI.blockOverlay {
  background: var(--rb-background) !important;
  opacity: 0.7 !important;
}

/* ---------- Responsive helpers ---------- */
@media (max-width: 767px) {
  .rb-hide-mobile {
    display: none !important;
  }
}
@media (min-width: 768px) {
  .rb-hide-desktop {
    display: none !important;
  }
}

/* ---------- WooCommerce widgets overrides ---------- */
.woocommerce .widget_price_filter .ui-slider {
  background: var(--rb-surface);
}
.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
  background: var(--rb-primary);
}
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  background: var(--rb-primary);
  border: none;
}
.woocommerce .widget_price_filter .price_slider_amount .button {
  background: var(--rb-primary);
  color: #000;
  border-radius: var(--rb-radius);
  font-family: var(--rb-font-sans);
}
