/*
 Theme Name:   DamnModz Dark Theme
 Theme URI:    https://damnmodz.com
 Description:  Dark mode gaming theme for DamnModz - Child theme of Bridge
 Author:       DamnModz
 Author URI:   https://damnmodz.com
 Template:     bridge
 Version:      1.0.1
 Text Domain:  damnmodz-theme
*/

/* ==========================================================================
   CSS Custom Properties (Design Tokens)
   ========================================================================== */

:root {
  /* Core RGB values (single source of truth) */
  --bg-primary-rgb: 10, 10, 15;
  --bg-secondary-rgb: 18, 18, 26;
  --bg-tertiary-rgb: 26, 26, 40;
  --bg-card-rgb: 22, 22, 31;
  --bg-card-hover-rgb: 30, 30, 45;
  --bg-elevated-rgb: 20, 20, 24;
  --bg-hero-top-rgb: 15, 15, 18;
  --bg-hero-bottom-rgb: 10, 10, 13;

	  --accent-primary-rgb: 220, 38, 38;
	  --accent-primary-hover-rgb: 239, 68, 68;
	  --accent-primary-light-rgb: 254, 202, 202;
	  --accent-primary-dark-rgb: 185, 28, 28;

	  --accent-success-rgb: 239, 68, 68;
  --accent-gold-rgb: 245, 158, 11;
  --accent-gold-bright-rgb: 251, 191, 36;
  --accent-info-rgb: 59, 130, 246;

  --text-primary-rgb: 255, 255, 255;
  --text-secondary-rgb: 156, 163, 175;
  --text-muted-rgb: 107, 114, 128;
  --text-on-accent-rgb: 26, 26, 26;

  /* Background Colors */
  --bg-primary: rgb(var(--bg-primary-rgb));
  --bg-secondary: rgb(var(--bg-secondary-rgb));
  --bg-tertiary: rgb(var(--bg-tertiary-rgb));
  --bg-card: rgb(var(--bg-card-rgb));
  --bg-card-hover: rgb(var(--bg-card-hover-rgb));
  --bg-elevated: rgb(var(--bg-elevated-rgb));
  --bg-hero-top: rgb(var(--bg-hero-top-rgb));
  --bg-hero-bottom: rgb(var(--bg-hero-bottom-rgb));
  --bg-overlay: rgba(0, 0, 0, 0.7);
  --bg-glass: rgba(var(--bg-secondary-rgb), 0.85);

  /* Accent Colors */
  --accent-primary: rgb(var(--accent-primary-rgb));
  --accent-primary-hover: rgb(var(--accent-primary-hover-rgb));
  --accent-primary-light: rgb(var(--accent-primary-light-rgb));
  --accent-primary-dark: rgb(var(--accent-primary-dark-rgb));
  --accent-primary-glow: rgba(var(--accent-primary-rgb), 0.4);
  --accent-success: rgb(var(--accent-success-rgb));
  --accent-success-soft: rgba(var(--accent-success-rgb), 0.15);
  --accent-gold: rgb(var(--accent-gold-rgb));
  --accent-gold-soft: rgba(var(--accent-gold-rgb), 0.15);
  --accent-gold-bright: rgb(var(--accent-gold-bright-rgb));
  --accent-info: rgb(var(--accent-info-rgb));
  --accent-info-soft: rgba(var(--accent-info-rgb), 0.15);

  /* Text Colors */
  --text-primary: rgb(var(--text-primary-rgb));
  --text-secondary: rgb(var(--text-secondary-rgb));
  --text-muted: rgb(var(--text-muted-rgb));
  --text-on-accent: rgb(var(--text-on-accent-rgb));
  --text-link: var(--accent-primary);
  --text-link-hover: var(--accent-primary-hover);

  /* Border Colors */
  --border-subtle: rgba(var(--text-primary-rgb), 0.08);
  --border-medium: rgba(var(--text-primary-rgb), 0.12);
  --border-accent: rgba(var(--accent-primary-rgb), 0.5);

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 20px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 8px 40px rgba(0, 0, 0, 0.5);
  --shadow-glow: 0 0 30px var(--accent-primary-glow);
  --shadow-card-hover: 0 8px 30px rgba(var(--accent-primary-rgb), 0.15);

  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;

  /* Border Radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Typography */
  --font-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-heading: 'Outfit', 'Inter', sans-serif;

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;

  /* Z-index */
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-modal: 300;
  --z-tooltip: 400;

  /* Layout */
  --container-max: 1400px;
  --sidebar-width: 380px;
  --header-height: 80px;
}

/* ==========================================================================
   Base Resets & Dark Mode Foundation
   ========================================================================== */

html {
  scroll-behavior: smooth;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  background-color: var(--bg-primary) !important;
  color: var(--text-primary);
  font-family: var(--font-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Override Bridge theme backgrounds */
.wrapper,
.wrapper_inner,
.content,
.content_inner,
.full_width,
.container_inner {
  background-color: transparent !important;
}

/* Force hide Bridge theme preloader/transitions which can get stuck */
.q_loader,
.qodef-loader,
.ajax_loader,
.qodef-page-loading-overlay,
.qodef-page-transition-holder,
.qodef-page-transition-loader,
.loading-wheel {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  z-index: -1 !important;
}

/* Hide escaped/raw shortcode text that appears when plugin is missing */
.dm-homepage .entry-content p:empty,
.dm-homepage .entry-content br:only-child {
  display: none;
}

/* Global Container Styling */
.container {
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
  box-sizing: border-box;
  background-color: transparent !important;
}

/* Sections: consistent vertical padding */
.dm-homepage section,
.dm-categories-section,
.dm-popular-section,
.dm-process-section,
.dm-stats-banner {
  padding-top: var(--space-3xl);
  padding-bottom: var(--space-3xl);
}

/* Section Headers */
.dm-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.dm-section-title {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.dm-section-subtitle {
  color: var(--text-secondary);
  font-size: var(--text-lg);
  margin: 0;
  margin-top: var(--space-sm);
}

.dm-section-header--center {
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

.dm-section-header--center .dm-section-subtitle {
  max-width: 60ch;
}

/* Links */
a {
  color: var(--text-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--accent-primary);
}

/* Selection */
::selection {
  background-color: var(--accent-primary);
  color: var(--text-primary);
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-secondary);
}

::-webkit-scrollbar-thumb {
  background: var(--bg-tertiary);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted);
}

/* ==========================================================================
   Typography
   ========================================================================== */

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
  margin-bottom: var(--space-md);
}

h1 {
  font-size: var(--text-5xl);
}

h2 {
  font-size: var(--text-4xl);
}

h3 {
  font-size: var(--text-3xl);
}

h4 {
  font-size: var(--text-2xl);
}

h5 {
  font-size: var(--text-xl);
}

h6 {
  font-size: var(--text-lg);
}

p {
  color: var(--text-secondary);
  margin-bottom: var(--space-md);
}

/* Gradient Text */
.gradient-text {
  background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-primary-light) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ==========================================================================
   Header Overrides
   ========================================================================== */

.header_inner,
header.page_header,
.header_top,
.header_bottom,
.fixed_top_header,
.sticky_header,
.main_menu_header_inner_right_holder {
  background-color: var(--bg-secondary) !important;
  border-bottom: 1px solid var(--border-subtle);
}

.header-widget {
  background-color: transparent !important;
}

/* Logo area */
.logo_wrapper a,
.q_logo a {
  display: flex;
  align-items: center;
}

/* Navigation */
nav.main_menu>ul>li>a,
.main_menu li a,
.mobile_menu li a {
  color: var(--text-primary) !important;
  font-weight: 500;
  transition: color var(--transition-fast);
}

nav.main_menu>ul>li:hover>a,
.main_menu li:hover>a {
  color: var(--accent-primary) !important;
}

/* Dropdown menus */
.second,
.wide,
nav.main_menu ul li ul,
.main_menu .second {
  background-color: var(--bg-tertiary) !important;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-lg);
}

.main_menu ul li ul li a {
  color: var(--text-secondary) !important;
}

.main_menu ul li ul li:hover>a {
  color: var(--text-primary) !important;
  background-color: var(--bg-card-hover) !important;
}

/* ==========================================================================
   Footer Overrides
   ========================================================================== */

footer,
.footer_top,
.footer_top_holder,
.footer_bottom,
.footer_bottom_holder,
.footer_inner {
  background-color: var(--bg-secondary) !important;
  border-top: 1px solid var(--border-subtle);
}

footer h5,
footer h6,
footer .widget-title {
  color: var(--text-primary) !important;
}

footer p,
footer li,
footer a {
  color: var(--text-secondary) !important;
}

footer a:hover {
  color: var(--accent-primary) !important;
}

/* ==========================================================================
   WooCommerce Overrides
   ========================================================================== */

/* Product cards layout override */
.woocommerce ul.products,
.products,
.dm-products-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: var(--space-lg) !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Ensure list items act as grid cells, not floated columns */
.woocommerce ul.products li.product:not(.dm-product-card),
.products li.product:not(.dm-product-card),
.columns-4 ul.products li.product:not(.dm-product-card),
div.woocommerce ul.products li.product:not(.dm-product-card) {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
  max-width: none !important;
  clear: none !important;
  background-color: var(--bg-card) !important;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-lg) !important;
  transition: all var(--transition-base);
}

/* Responsive Grid Overrides */
@media (max-width: 1200px) {

  .woocommerce ul.products,
  .products,
  .dm-products-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (max-width: 768px) {

  .woocommerce ul.products,
  .products,
  .dm-products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 480px) {

  .woocommerce ul.products,
  .products,
  .dm-products-grid {
    grid-template-columns: 1fr !important;
  }
}

.products .product:not(.dm-product-card):hover,
ul.products li.product:not(.dm-product-card):hover {
  background-color: var(--bg-card-hover) !important;
  border-color: var(--border-accent);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
  z-index: 2;
  /* Ensure hover effect is on top */
}

/* Product titles */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h3 {
  color: var(--text-primary) !important;
  font-family: var(--font-heading);
  font-weight: 600;
}

/* Product prices */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--accent-primary) !important;
  font-weight: 700;
  font-size: var(--text-xl);
}

/* Add to cart buttons */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.added_to_cart {
  background-color: var(--accent-primary) !important;
  color: var(--text-primary) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  padding: var(--space-sm) var(--space-lg) !important;
  transition: all var(--transition-fast) !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background-color: var(--accent-primary-hover) !important;
  box-shadow: var(--shadow-glow);
  transform: translateY(-2px);
}

/* Single product page */
.woocommerce div.product {
  background-color: transparent;
}

.woocommerce div.product .product_title {
  color: var(--text-primary) !important;
  font-family: var(--font-heading);
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--text-secondary);
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  background-color: var(--bg-tertiary);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background-color: transparent;
  border: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  color: var(--text-secondary) !important;
  font-weight: 500;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--text-primary) !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
  background-color: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  padding: var(--space-xl);
}

/* Cart */
.woocommerce-cart table.cart,
.woocommerce table.shop_table {
  background-color: var(--bg-card) !important;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
  border-color: var(--border-subtle) !important;
  color: var(--text-primary);
}

/* Checkout */
.woocommerce form .form-row label {
  color: var(--text-secondary);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background-color: var(--bg-tertiary) !important;
  border: 1px solid var(--border-subtle) !important;
  color: var(--text-primary) !important;
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--accent-primary) !important;
  outline: none;
  box-shadow: 0 0 0 2px var(--accent-primary-glow);
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.flex {
  display: flex;
}

.flex-col {
  flex-direction: column;
}

.items-center {
  align-items: center;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.gap-sm {
  gap: var(--space-sm);
}

.gap-md {
  gap: var(--space-md);
}

.gap-lg {
  gap: var(--space-lg);
}

.gap-xl {
  gap: var(--space-xl);
}

.mt-sm {
  margin-top: var(--space-sm);
}

.mt-md {
  margin-top: var(--space-md);
}

.mt-lg {
  margin-top: var(--space-lg);
}

.mt-xl {
  margin-top: var(--space-xl);
}

.mb-sm {
  margin-bottom: var(--space-sm);
}

.mb-md {
  margin-bottom: var(--space-md);
}

.mb-lg {
  margin-bottom: var(--space-lg);
}

.mb-xl {
  margin-bottom: var(--space-xl);
}

.hidden {
  display: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
