/**
 * ============================================================================
 * SNOOKER PRO THEME - Main Stylesheet
 * ============================================================================
 * A sophisticated, modern e-commerce theme inspired by the elegance of Snooker
 * 
 * Color Palette:
 * - Table Green: #0a6b3a (primary)
 * - Championship Gold: #d4af37 (accent)
 * - Ball Red: #d32f2f
 * - Ball Yellow: #fbc02d
 * - Ball Brown: #795548
 * - Ball Blue: #1976d2
 * - Ball Pink: #ec407a
 * - Ball Black: #121212
 * - Ball White: #fafafa
 * 
 * Typography:
 * - Headings: Sora (modern, geometric)
 * - Body: Inter (readable, clean)
 * - Accent: Space Grotesk (tech, modern)
 * 
 * @version 2.0.0
 * @author JKcuetips
 * ============================================================================
 */

/* ============================================================================
   CRITICAL RESET - Force Dark Theme Everywhere
   This section MUST come first to override all legacy CSS
   ============================================================================ */

/* Global dark background */
html {
    background: #0a0a0a !important;
    color: #e5e5e5 !important;
    font-size: 16px !important;
}

body {
    background: #0a0a0a !important;
    color: #e5e5e5 !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

/* Remove ALL white backgrounds from legacy CSS */
*, *::before, *::after {
    border-color: #333 !important;
}

/* Containers */
.container,
.container-fluid,
#container,
main,
#content,
article,
section,
aside,
.row,
[class*="col-"] {
    background: transparent !important;
}

/* Panels, wells, boxes - all dark */
.panel,
.panel-default,
.panel-body,
.panel-heading,
.panel-footer,
.well,
.jumbotron,
.thumbnail,
.card {
    background: #1a1a1a !important;
    border-color: #333 !important;
    color: #e5e5e5 !important;
}

/* Lists */
.list-group {
    background: transparent !important;
}

.list-group-item {
    background: #1a1a1a !important;
    border-color: #333 !important;
    color: #e5e5e5 !important;
}

.list-group-item:hover,
.list-group-item:focus {
    background: #252525 !important;
    color: #fff !important;
}

.list-group-item.active {
    background: #0a6b3a !important;
    border-color: #0a6b3a !important;
    color: #fff !important;
}

/* Links - clean colors */
a {
    color: #e5e5e5 !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

a:hover {
    color: #d4af37 !important;
}

a:visited {
    color: #e5e5e5 !important;
}

footer a,
.footer a {
    color: #a3a3a3 !important;
}

footer a:hover,
.footer a:hover {
    color: #d4af37 !important;
}

/* Headings - proper sizing */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    color: #fff !important;
    font-family: 'Sora', sans-serif !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
}

h1, .h1 { font-size: 2.5rem !important; }
h2, .h2 { font-size: 2rem !important; }
h3, .h3 { font-size: 1.5rem !important; }
h4, .h4 { font-size: 1.25rem !important; }
h5, .h5 { font-size: 1.1rem !important; }
h6, .h6 { font-size: 1rem !important; }

/* Paragraph and text - readable sizes */
p, span, li, td, th, label, div {
    font-size: inherit !important;
}

/* ============================================================================
   FORM ELEMENTS - Clean dark styling
   ============================================================================ */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="date"],
textarea,
select,
.form-control {
    background: #1a1a1a !important;
    border: 1px solid #404040 !important;
    color: #e5e5e5 !important;
    font-size: 1rem !important;
    padding: 0.75rem 1rem !important;
    border-radius: 8px !important;
    transition: all 0.2s ease !important;
}

input:focus,
textarea:focus,
select:focus,
.form-control:focus {
    border-color: #0a6b3a !important;
    box-shadow: 0 0 0 3px rgba(10, 107, 58, 0.2) !important;
    outline: none !important;
}

input::placeholder,
textarea::placeholder {
    color: #666 !important;
}

label {
    color: #d4d4d4 !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
}

/* ============================================================================
   BUTTONS - Modern flat design
   ============================================================================ */

.btn,
button,
input[type="submit"],
input[type="button"] {
    background: #0a6b3a !important;
    border: none !important;
    color: #fff !important;
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.btn:hover,
button:hover {
    background: #085c32 !important;
    transform: translateY(-1px) !important;
}

.btn-primary {
    background: #0a6b3a !important;
}

.btn-default,
.btn-secondary {
    background: #333 !important;
    color: #e5e5e5 !important;
}

.btn-default:hover,
.btn-secondary:hover {
    background: #444 !important;
}

.btn-danger {
    background: #dc2626 !important;
}

.btn-warning {
    background: #d4af37 !important;
    color: #000 !important;
}

/* Small buttons */
.btn-xs,
.btn-sm {
    font-size: 0.85rem !important;
    padding: 0.5rem 1rem !important;
}

/* Large buttons */
.btn-lg {
    font-size: 1.1rem !important;
    padding: 1rem 2rem !important;
}

/* ============================================================================
   NAVIGATION & MENUS - Clean horizontal layout
   ============================================================================ */

/* Main navigation container */
.megamenu,
.navigation,
nav {
    background: transparent !important;
}

/* Horizontal menu */
.sf-menu,
ul.sf-menu {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0 !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}

.sf-menu > li {
    position: relative !important;
    background: transparent !important;
}

.sf-menu > li > a {
    display: block !important;
    padding: 1rem 1.25rem !important;
    color: #d4d4d4 !important;
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    text-transform: none !important;
    white-space: nowrap !important;
    background: transparent !important;
    transition: color 0.2s ease !important;
}

.sf-menu > li > a:hover,
.sf-menu > li:hover > a,
.sf-menu > li > a.active {
    color: #d4af37 !important;
    background: transparent !important;
}

/* Dropdown menus */
.sf-mega,
.sf-menu .sf-mega,
.sf-menu ul,
.sf-menu li ul,
ul.sf-menu li ul,
.dropdown-menu {
    position: absolute !important;
    left: 0 !important;
    top: 100% !important;
    min-width: 220px !important;
    background: #1a1a1a !important;
    border: 1px solid #333 !important;
    border-radius: 12px !important;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5) !important;
    padding: 1rem !important;
    z-index: 999999 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) !important;
    transition: all 0.2s ease !important;
}

.sf-menu li:hover > ul,
.sf-menu li:hover > .sf-mega,
.sf-menu li.sfHover > ul,
.sf-menu li.sfHover > .sf-mega {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

/* Dropdown items */
.sf-mega a,
.sf-menu ul a,
.sf-menu li ul li a,
.dropdown-menu a,
.dropdown-menu li a {
    display: block !important;
    padding: 0.6rem 1rem !important;
    color: #a3a3a3 !important;
    font-size: 0.9rem !important;
    border-radius: 6px !important;
    background: transparent !important;
    transition: all 0.15s ease !important;
}

.sf-mega a:hover,
.sf-menu ul a:hover,
.sf-menu li ul li a:hover,
.dropdown-menu a:hover {
    color: #fff !important;
    background: rgba(10, 107, 58, 0.2) !important;
}

/* Submenu titles */
.submenu_title,
.submenu_category_title,
.sf-mega h3,
.sf-mega .title {
    color: #d4af37 !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    padding: 0.5rem 1rem !important;
    margin-bottom: 0.5rem !important;
    border-bottom: 1px solid #333 !important;
}

/* ============================================================================
   PRODUCT CARDS - Clean modern design
   ============================================================================ */

.product-thumb,
.product-layout,
.product-card,
.product-item {
    background: #1a1a1a !important;
    border: 1px solid #333 !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    transition: all 0.3s ease !important;
}

.product-thumb:hover,
.product-layout:hover {
    border-color: #0a6b3a !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 15px 40px rgba(10, 107, 58, 0.15) !important;
}

/* Product image */
.product-thumb .image,
.product-thumb .product-image {
    position: relative !important;
    overflow: hidden !important;
    background: #111 !important;
}

.product-thumb .image img,
.product-thumb .product-image img {
    width: 100% !important;
    height: auto !important;
    object-fit: cover !important;
    transition: transform 0.4s ease !important;
}

.product-thumb:hover .image img {
    transform: scale(1.08) !important;
}

/* Product info */
.product-thumb .caption,
.product-thumb .product-info {
    padding: 1.25rem !important;
    background: #1a1a1a !important;
}

.product-thumb .caption h4,
.product-thumb .name,
.product-thumb .title,
.product-thumb h4 a,
.product-thumb .name a {
    color: #fff !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    margin-bottom: 0.5rem !important;
}

.product-thumb .caption h4 a:hover,
.product-thumb .name a:hover {
    color: #d4af37 !important;
}

/* Price */
.product-thumb .price,
.price,
.product-price {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: #22c55e !important;
}

.product-thumb .price-old,
.price-old {
    color: #666 !important;
    font-size: 0.9rem !important;
    text-decoration: line-through !important;
    margin-right: 0.5rem !important;
}

.product-thumb .price-new,
.price-new {
    color: #22c55e !important;
}

/* Product buttons */
.product-thumb .button-group,
.product-thumb .actions {
    display: flex !important;
    gap: 0.5rem !important;
    padding: 0 1.25rem 1.25rem !important;
}

.product-thumb .button-group button,
.product-thumb .btn-cart {
    flex: 1 !important;
    padding: 0.75rem !important;
    font-size: 0.85rem !important;
}

/* Rating stars */
.rating,
.product-thumb .rating {
    display: flex !important;
    gap: 2px !important;
    margin: 0.5rem 0 !important;
}

.rating .fa-star,
.rating .fa-star-o {
    color: #d4af37 !important;
    font-size: 0.85rem !important;
}

/* Badges */
.sticker,
.badge,
.label-sale,
.label-new {
    position: absolute !important;
    top: 1rem !important;
    left: 1rem !important;
    padding: 0.35rem 0.75rem !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    border-radius: 6px !important;
    z-index: 10 !important;
}

.sticker-new,
.label-new {
    background: #0a6b3a !important;
    color: #fff !important;
}

.sticker-sale,
.label-sale {
    background: #dc2626 !important;
    color: #fff !important;
}

/* ============================================================================
   SIDEBAR - Clean category menu
   ============================================================================ */

aside,
#column-left,
#column-right,
.sidebar {
    background: transparent !important;
}

.box,
.sidebar-box {
    background: #1a1a1a !important;
    border: 1px solid #333 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    margin-bottom: 1.5rem !important;
}

.box-heading,
.box .box-heading,
.sidebar-title {
    background: #252525 !important;
    color: #d4af37 !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    padding: 1rem 1.25rem !important;
    border-bottom: 1px solid #333 !important;
    margin: 0 !important;
}

.box-content,
.box .box-content {
    padding: 0 !important;
    background: transparent !important;
}

/* Category list */
.box-category,
.box-category ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}

.box-category li {
    border-bottom: 1px solid #2a2a2a !important;
}

.box-category li:last-child {
    border-bottom: none !important;
}

.box-category a,
.box-category li a {
    display: flex !important;
    align-items: center !important;
    padding: 0.9rem 1.25rem !important;
    color: #a3a3a3 !important;
    font-size: 0.95rem !important;
    background: transparent !important;
    transition: all 0.15s ease !important;
}

.box-category a:hover,
.box-category li a:hover,
.box-category li.active > a {
    color: #fff !important;
    background: rgba(10, 107, 58, 0.15) !important;
    padding-left: 1.5rem !important;
}

/* ============================================================================
   FOOTER - Clean modern footer
   ============================================================================ */

footer,
#footer,
.footer {
    background: #0f0f0f !important;
    border-top: 1px solid #222 !important;
    color: #a3a3a3 !important;
    padding: 3rem 0 2rem !important;
}

footer h5,
footer .title,
.footer h5,
.footer-title {
    color: #fff !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    margin-bottom: 1.25rem !important;
    padding-bottom: 0.75rem !important;
    border-bottom: 2px solid #0a6b3a !important;
}

footer ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

footer li {
    margin-bottom: 0.6rem !important;
}

footer a {
    color: #888 !important;
    font-size: 0.95rem !important;
    transition: color 0.2s ease !important;
}

footer a:hover {
    color: #d4af37 !important;
}

/* ============================================================================
   CSS CUSTOM PROPERTIES (Design Tokens)
   ============================================================================ */

:root {
    /* ==========================================================================
       Color System
       ========================================================================== */
    
    /* Primary Colors - Snooker Table */
    --snooker-table: #0a6b3a;
    --snooker-table-light: #0d8247;
    --snooker-table-dark: #074d2a;
    --snooker-table-darker: #053d21;
    --snooker-felt: #1a8f4f;
    --snooker-rail: #4a2c2a;
    --snooker-cushion: #2d1810;
    
    /* Accent Colors - Championship Gold */
    --gold-primary: #d4af37;
    --gold-light: #e5c76b;
    --gold-dark: #b8922d;
    --gold-darker: #8b6914;
    
    /* Ball Colors */
    --ball-red: #d32f2f;
    --ball-yellow: #fbc02d;
    --ball-green: #388e3c;
    --ball-brown: #795548;
    --ball-blue: #1976d2;
    --ball-pink: #ec407a;
    --ball-black: #121212;
    --ball-white: #fafafa;
    
    /* Neutral Colors */
    --neutral-50: #fafafa;
    --neutral-100: #f5f5f5;
    --neutral-200: #e5e5e5;
    --neutral-300: #d4d4d4;
    --neutral-400: #a3a3a3;
    --neutral-500: #737373;
    --neutral-600: #525252;
    --neutral-700: #404040;
    --neutral-800: #262626;
    --neutral-900: #171717;
    --neutral-950: #0a0a0a;
    
    /* Semantic Colors */
    --success: #10b981;
    --success-light: #34d399;
    --success-dark: #059669;
    --warning: #f59e0b;
    --warning-light: #fbbf24;
    --warning-dark: #d97706;
    --error: #ef4444;
    --error-light: #f87171;
    --error-dark: #dc2626;
    --info: #3b82f6;
    --info-light: #60a5fa;
    --info-dark: #2563eb;
    
    /* ==========================================================================
       Typography
       ========================================================================== */
    
    --font-heading: 'Sora', sans-serif;
    --font-body: 'Inter', sans-serif;
    --font-accent: 'Space Grotesk', sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
    
    /* Font Sizes (using clamp for fluid typography) */
    --text-xs: clamp(0.625rem, 0.5rem + 0.25vw, 0.75rem);
    --text-sm: clamp(0.75rem, 0.625rem + 0.25vw, 0.875rem);
    --text-base: clamp(0.875rem, 0.75rem + 0.25vw, 1rem);
    --text-lg: clamp(1rem, 0.875rem + 0.25vw, 1.125rem);
    --text-xl: clamp(1.125rem, 1rem + 0.25vw, 1.25rem);
    --text-2xl: clamp(1.25rem, 1rem + 0.5vw, 1.5rem);
    --text-3xl: clamp(1.5rem, 1.25rem + 0.5vw, 1.875rem);
    --text-4xl: clamp(1.875rem, 1.5rem + 0.75vw, 2.25rem);
    --text-5xl: clamp(2.25rem, 1.75rem + 1vw, 3rem);
    --text-6xl: clamp(2.75rem, 2rem + 1.5vw, 3.75rem);
    
    /* Line Heights */
    --leading-none: 1;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;
    --leading-loose: 2;
    
    /* Font Weights */
    --font-thin: 100;
    --font-extralight: 200;
    --font-light: 300;
    --font-normal: 400;
    --font-medium: 500;
    --font-semibold: 600;
    --font-bold: 700;
    --font-extrabold: 800;
    --font-black: 900;
    
    /* ==========================================================================
       Spacing System (based on 4px grid)
       ========================================================================== */
    
    --space-0: 0;
    --space-px: 1px;
    --space-0-5: 0.125rem;
    --space-1: 0.25rem;
    --space-1-5: 0.375rem;
    --space-2: 0.5rem;
    --space-2-5: 0.625rem;
    --space-3: 0.75rem;
    --space-3-5: 0.875rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 1.75rem;
    --space-8: 2rem;
    --space-9: 2.25rem;
    --space-10: 2.5rem;
    --space-11: 2.75rem;
    --space-12: 3rem;
    --space-14: 3.5rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --space-28: 7rem;
    --space-32: 8rem;
    --space-36: 9rem;
    --space-40: 10rem;
    --space-44: 11rem;
    --space-48: 12rem;
    --space-52: 13rem;
    --space-56: 14rem;
    --space-60: 15rem;
    --space-64: 16rem;
    --space-72: 18rem;
    --space-80: 20rem;
    --space-96: 24rem;
    
    /* ==========================================================================
       Border Radius
       ========================================================================== */
    
    --radius-none: 0;
    --radius-sm: 0.125rem;
    --radius-default: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --radius-full: 9999px;
    
    /* ==========================================================================
       Shadows
       ========================================================================== */
    
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-default: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
    
    /* Snooker-themed shadows */
    --shadow-snooker: 0 4px 20px -2px rgba(10, 107, 58, 0.25);
    --shadow-snooker-lg: 0 10px 40px -10px rgba(10, 107, 58, 0.35);
    --shadow-gold: 0 4px 20px -2px rgba(212, 175, 55, 0.25);
    --shadow-gold-lg: 0 10px 40px -10px rgba(212, 175, 55, 0.35);
    
    /* ==========================================================================
       Transitions & Animations
       ========================================================================== */
    
    --transition-fast: 150ms;
    --transition-normal: 300ms;
    --transition-slow: 500ms;
    --transition-slower: 700ms;
    
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
    
    /* ==========================================================================
       Z-Index Scale
       ========================================================================== */
    
    --z-negative: -1;
    --z-0: 0;
    --z-10: 10;
    --z-20: 20;
    --z-30: 30;
    --z-40: 40;
    --z-50: 50;
    --z-dropdown: 100;
    --z-sticky: 200;
    --z-fixed: 300;
    --z-modal-backdrop: 400;
    --z-modal: 500;
    --z-popover: 600;
    --z-tooltip: 700;
    --z-toast: 800;
    --z-max: 9999;
    
    /* ==========================================================================
       Layout
       ========================================================================== */
    
    --container-sm: 640px;
    --container-md: 768px;
    --container-lg: 1024px;
    --container-xl: 1280px;
    --container-2xl: 1536px;
    
    /* Header heights */
    --header-height-mobile: 60px;
    --header-height-tablet: 80px;
    --header-height-desktop: 120px;
}

/* ============================================================================
   RESET & BASE STYLES
   ============================================================================ */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--neutral-100);
    background-color: var(--neutral-950);
    min-height: 100vh;
    overflow-x: hidden;
}

/* Snooker Pro Theme Class - Apply to body */
.snooker-pro {
    background: 
        linear-gradient(135deg, rgba(10, 107, 58, 0.03) 0%, transparent 50%),
        linear-gradient(225deg, rgba(212, 175, 55, 0.02) 0%, transparent 50%),
        var(--neutral-950);
    background-attachment: fixed;
}

/* ============================================================================
   TYPOGRAPHY
   ============================================================================ */

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: var(--font-bold);
    line-height: var(--leading-tight);
    color: var(--neutral-50);
    margin-bottom: var(--space-4);
}

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 {
    margin-bottom: var(--space-4);
    color: var(--neutral-300);
}

a {
    color: var(--snooker-table-light);
    text-decoration: none;
    transition: color var(--transition-fast) var(--ease-out);
}

a:hover {
    color: var(--gold-primary);
}

/* Text utilities */
.text-primary { color: var(--snooker-table) !important; }
.text-secondary { color: var(--neutral-400) !important; }
.text-muted { color: var(--neutral-500) !important; }
.text-gold { color: var(--gold-primary) !important; }
.text-success { color: var(--success) !important; }
.text-warning { color: var(--warning) !important; }
.text-danger { color: var(--error) !important; }
.text-info { color: var(--info) !important; }

/* Text Gradients */
.text-gradient-snooker {
    background: linear-gradient(135deg, var(--snooker-table-light), var(--snooker-table), var(--snooker-table-dark));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.text-gradient-gold {
    background: linear-gradient(135deg, var(--gold-light), var(--gold-primary), var(--gold-dark));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Text Glow Effects */
.text-glow-green {
    text-shadow: 0 0 20px rgba(10, 107, 58, 0.5);
}

.text-glow-gold {
    text-shadow: 0 0 20px rgba(212, 175, 55, 0.5);
}

/* ============================================================================
   BUTTONS
   ============================================================================ */

/* Base Button */
.btn,
button:not(.swal2-confirm):not(.swal2-cancel):not(.swal2-deny),
input[type="submit"],
input[type="button"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    line-height: var(--leading-normal);
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    border: 1px solid transparent;
    border-radius: var(--radius-lg);
    background: var(--neutral-800);
    color: var(--neutral-100);
    transition: all var(--transition-fast) var(--ease-out);
    outline: none;
}

.btn:hover,
button:not(.swal2-confirm):not(.swal2-cancel):not(.swal2-deny):hover {
    background: var(--neutral-700);
    transform: translateY(-1px);
}

.btn:focus-visible,
button:focus-visible {
    outline: 2px solid var(--snooker-table);
    outline-offset: 2px;
}

.btn:active,
button:active {
    transform: translateY(0);
}

.btn:disabled,
button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

/* Button Sizes */
.btn-sm {
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-xs);
}

.btn-lg {
    padding: var(--space-4) var(--space-8);
    font-size: var(--text-lg);
}

.btn-xl {
    padding: var(--space-5) var(--space-10);
    font-size: var(--text-xl);
}

/* Primary Button - Snooker Green */
.btn-primary,
.btn-snooker {
    background: linear-gradient(135deg, var(--snooker-table-light), var(--snooker-table));
    border-color: var(--snooker-table-dark);
    color: var(--neutral-50);
    box-shadow: var(--shadow-snooker);
}

.btn-primary:hover,
.btn-snooker:hover {
    background: linear-gradient(135deg, var(--snooker-table), var(--snooker-table-dark));
    box-shadow: var(--shadow-snooker-lg);
    transform: translateY(-2px);
}

/* Gold Button */
.btn-gold {
    background: linear-gradient(135deg, var(--gold-light), var(--gold-primary));
    border-color: var(--gold-dark);
    color: var(--neutral-900);
    box-shadow: var(--shadow-gold);
}

.btn-gold:hover {
    background: linear-gradient(135deg, var(--gold-primary), var(--gold-dark));
    box-shadow: var(--shadow-gold-lg);
    transform: translateY(-2px);
}

/* Danger Button */
.btn-danger {
    background: linear-gradient(135deg, var(--error-light), var(--error));
    border-color: var(--error-dark);
    color: var(--neutral-50);
}

.btn-danger:hover {
    background: linear-gradient(135deg, var(--error), var(--error-dark));
}

/* Success Button */
.btn-success {
    background: linear-gradient(135deg, var(--success-light), var(--success));
    border-color: var(--success-dark);
    color: var(--neutral-50);
}

.btn-success:hover {
    background: linear-gradient(135deg, var(--success), var(--success-dark));
}

/* Outline Button */
.btn-outline {
    background: transparent;
    border: 2px solid var(--snooker-table);
    color: var(--snooker-table-light);
}

.btn-outline:hover {
    background: var(--snooker-table);
    color: var(--neutral-50);
}

/* Ghost Button */
.btn-ghost {
    background: transparent;
    border-color: transparent;
    color: var(--neutral-300);
}

.btn-ghost:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--neutral-100);
}

/* Icon Button */
.btn-icon {
    padding: var(--space-2);
    border-radius: var(--radius-lg);
    aspect-ratio: 1;
}

.btn-icon.btn-sm {
    padding: var(--space-1-5);
}

.btn-icon.btn-lg {
    padding: var(--space-3);
}

/* ============================================================================
   CARDS & CONTAINERS
   ============================================================================ */

/* Pro Card - Main card style */
.pro-card {
    background: linear-gradient(145deg, rgba(38, 38, 38, 0.9), rgba(23, 23, 23, 0.95));
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: all var(--transition-normal) var(--ease-out);
}

.pro-card:hover {
    border-color: rgba(10, 107, 58, 0.3);
    box-shadow: var(--shadow-snooker);
}

/* Glass Panel */
.glass-panel {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-xl);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

/* Product Card Enhanced */
.product-card-enhanced {
    position: relative;
    background: var(--neutral-900);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.product-card-enhanced::before {
    content: '';
    position: absolute;
    inset: -2px;
    background: conic-gradient(
        from 0deg,
        var(--snooker-table),
        var(--gold-primary),
        var(--snooker-table-light),
        var(--gold-light),
        var(--snooker-table)
    );
    border-radius: inherit;
    z-index: -1;
    opacity: 0;
    transition: opacity var(--transition-normal) var(--ease-out);
}

.product-card-enhanced:hover::before {
    opacity: 1;
    animation: rotate-gradient 3s linear infinite;
}

@keyframes rotate-gradient {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Hover Effects */
.hover-lift {
    transition: transform var(--transition-normal) var(--ease-out);
}

.hover-lift:hover {
    transform: translateY(-4px);
}

.hover-glow-green:hover {
    box-shadow: 0 0 30px rgba(10, 107, 58, 0.3);
}

.hover-glow-gold:hover {
    box-shadow: 0 0 30px rgba(212, 175, 55, 0.3);
}

/* ============================================================================
   PRODUCT CARD - E-commerce Component
   ============================================================================ */

.product-thumb {
    position: relative;
    background: linear-gradient(145deg, rgba(38, 38, 38, 0.9), rgba(23, 23, 23, 0.95));
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: all var(--transition-normal) var(--ease-out);
}

.product-thumb:hover {
    border-color: rgba(10, 107, 58, 0.3);
    box-shadow: var(--shadow-snooker-lg);
    transform: translateY(-4px);
}

.product-thumb .image {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--neutral-800);
}

.product-thumb .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow) var(--ease-out);
}

.product-thumb:hover .image img {
    transform: scale(1.05);
}

.product-thumb .product-label {
    position: absolute;
    top: var(--space-3);
    left: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    z-index: var(--z-10);
}

.product-thumb .caption {
    padding: var(--space-4);
}

.product-thumb .caption h4 {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    margin-bottom: var(--space-2);
    line-height: var(--leading-snug);
}

.product-thumb .caption h4 a {
    color: var(--neutral-100);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.product-thumb .caption h4 a:hover {
    color: var(--gold-primary);
}

.product-thumb .rating {
    display: flex;
    gap: var(--space-1);
    color: var(--gold-primary);
    font-size: var(--text-sm);
}

.product-thumb .price {
    font-family: var(--font-accent);
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--snooker-table-light);
}

.product-thumb .price-old {
    font-size: var(--text-sm);
    color: var(--neutral-500);
    text-decoration: line-through;
    margin-right: var(--space-2);
}

.product-thumb .price-new {
    color: var(--snooker-table-light);
}

.product-thumb .button-group {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.product-thumb .button-group button {
    flex: 1;
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    background: rgba(10, 107, 58, 0.2);
    border: 1px solid rgba(10, 107, 58, 0.3);
    color: var(--snooker-table-light);
    border-radius: var(--radius-md);
}

.product-thumb .button-group button:hover {
    background: var(--snooker-table);
    color: var(--neutral-50);
}

/* Product Grid */
.grid-products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-6);
}

@media (max-width: 640px) {
    .grid-products {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-3);
    }
}

/* ============================================================================
   BADGES
   ============================================================================ */

.badge-new {
    display: inline-flex;
    align-items: center;
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, var(--snooker-table-light), var(--snooker-table));
    color: var(--neutral-50);
    border-radius: var(--radius-full);
}

.badge-sale {
    display: inline-flex;
    align-items: center;
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, var(--error-light), var(--error));
    color: var(--neutral-50);
    border-radius: var(--radius-full);
}

.badge-featured {
    display: inline-flex;
    align-items: center;
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, var(--gold-light), var(--gold-primary));
    color: var(--neutral-900);
    border-radius: var(--radius-full);
}

.championship-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: linear-gradient(135deg, var(--gold-light), var(--gold-primary), var(--gold-dark));
    color: var(--neutral-900);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-gold);
}

/* ============================================================================
   FORMS
   ============================================================================ */

.form-group {
    margin-bottom: var(--space-5);
}

.form-group label {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--neutral-300);
    margin-bottom: var(--space-2);
}

.form-group label.required::after {
    content: ' *';
    color: var(--error);
}

label.required::after {
    content: ' *';
    color: var(--error);
}

/* Pro Input */
.input-pro,
.form-control {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-lg);
    outline: none;
    transition: all var(--transition-fast) var(--ease-out);
}

.input-pro:focus,
.form-control:focus {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--snooker-table);
    box-shadow: 0 0 0 3px rgba(10, 107, 58, 0.15);
}

.input-pro::placeholder,
.form-control::placeholder {
    color: var(--neutral-500);
}

.input-pro:disabled,
.form-control:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Pro Select */
.select-pro,
select.form-control {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-lg);
    outline: none;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    background-size: 16px;
    padding-right: var(--space-10);
    transition: all var(--transition-fast) var(--ease-out);
}

.select-pro:focus,
select.form-control:focus {
    background-color: rgba(255, 255, 255, 0.05);
    border-color: var(--snooker-table);
    box-shadow: 0 0 0 3px rgba(10, 107, 58, 0.15);
}

.select-pro option,
select.form-control option {
    background: var(--neutral-900);
    color: var(--neutral-100);
}

/* Checkbox & Radio */
.checkbox-pro,
.radio-pro {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
}

.checkbox-pro input,
.radio-pro input {
    width: 18px;
    height: 18px;
    accent-color: var(--snooker-table);
    cursor: pointer;
}

/* Textarea */
textarea.input-pro,
textarea.form-control {
    min-height: 120px;
    resize: vertical;
}

/* Error state */
.input-pro.error,
.form-control.error,
.has-error .form-control {
    border-color: var(--error);
}

.input-pro.error:focus,
.form-control.error:focus,
.has-error .form-control:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}

.error-message,
.text-danger {
    font-size: var(--text-sm);
    color: var(--error);
    margin-top: var(--space-1);
}

/* ============================================================================
   ALERTS
   ============================================================================ */

.alert-pro-success {
    padding: var(--space-4) var(--space-5);
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.3);
    border-left: 4px solid var(--success);
    border-radius: var(--radius-lg);
    color: var(--success-light);
}

.alert-pro-danger,
.alert-pro-error {
    padding: var(--space-4) var(--space-5);
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-left: 4px solid var(--error);
    border-radius: var(--radius-lg);
    color: var(--error-light);
}

.alert-pro-warning {
    padding: var(--space-4) var(--space-5);
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid rgba(245, 158, 11, 0.3);
    border-left: 4px solid var(--warning);
    border-radius: var(--radius-lg);
    color: var(--warning-light);
}

.alert-pro-info {
    padding: var(--space-4) var(--space-5);
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.3);
    border-left: 4px solid var(--info);
    border-radius: var(--radius-lg);
    color: var(--info-light);
}

/* Bootstrap Alert Overrides */
.alert {
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius-lg);
    border-left: 4px solid;
}

.alert-success {
    background: rgba(16, 185, 129, 0.1);
    border-color: var(--success);
    color: var(--success-light);
}

.alert-danger {
    background: rgba(239, 68, 68, 0.1);
    border-color: var(--error);
    color: var(--error-light);
}

.alert-warning {
    background: rgba(245, 158, 11, 0.1);
    border-color: var(--warning);
    color: var(--warning-light);
}

.alert-info {
    background: rgba(59, 130, 246, 0.1);
    border-color: var(--info);
    color: var(--info-light);
}

/* ============================================================================
   NAVIGATION
   ============================================================================ */

.nav-link-pro {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--neutral-400);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast) var(--ease-out);
}

.nav-link-pro:hover {
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.05);
}

.nav-link-pro.active {
    color: var(--snooker-table-light);
    background: rgba(10, 107, 58, 0.1);
}

/* ============================================================================
   BREADCRUMB
   ============================================================================ */

.breadcrumb-pro {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-4) 0;
    list-style: none;
    font-size: var(--text-sm);
}

.breadcrumb-pro-item {
    display: flex;
    align-items: center;
}

.breadcrumb-pro-item::after {
    content: '/';
    margin-left: var(--space-2);
    color: var(--neutral-600);
}

.breadcrumb-pro-item:last-child::after {
    display: none;
}

.breadcrumb-pro-item a {
    color: var(--neutral-400);
}

.breadcrumb-pro-item a:hover {
    color: var(--snooker-table-light);
}

.breadcrumb-pro-item.active {
    color: var(--neutral-100);
}

/* Bootstrap Breadcrumb Override */
.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-4);
    list-style: none;
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.breadcrumb > li {
    display: flex;
    align-items: center;
}

.breadcrumb > li + li::before {
    content: '/';
    padding: 0 var(--space-2);
    color: var(--neutral-600);
}

.breadcrumb > li a {
    color: var(--neutral-400);
    font-size: var(--text-sm);
}

.breadcrumb > li a:hover {
    color: var(--snooker-table-light);
}

.breadcrumb > li:last-child a {
    color: var(--neutral-100);
}

/* ============================================================================
   PAGINATION
   ============================================================================ */

.pagination-pro {
    display: flex;
    justify-content: center;
    gap: var(--space-1);
    padding: var(--space-4) 0;
}

.pagination-pro-item {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--space-3);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--neutral-400);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast) var(--ease-out);
}

.pagination-pro-item:hover {
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.2);
}

.pagination-pro-item.active {
    color: var(--neutral-50);
    background: var(--snooker-table);
    border-color: var(--snooker-table);
}

/* Bootstrap Pagination Override */
.pagination {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-1);
    margin: var(--space-6) 0;
}

.pagination > li > a,
.pagination > li > span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--space-3);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--neutral-400);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast) var(--ease-out);
}

.pagination > li > a:hover {
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.2);
}

.pagination > .active > a,
.pagination > .active > span {
    color: var(--neutral-50);
    background: var(--snooker-table);
    border-color: var(--snooker-table);
}

/* ============================================================================
   TABLES
   ============================================================================ */

.table-pro {
    width: 100%;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.table-pro table {
    width: 100%;
    border-collapse: collapse;
}

.table-pro thead {
    background: rgba(10, 107, 58, 0.1);
}

.table-pro th {
    padding: var(--space-4);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    text-align: left;
    color: var(--neutral-100);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.table-pro td {
    padding: var(--space-4);
    font-size: var(--text-sm);
    color: var(--neutral-300);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.table-pro tbody tr:hover {
    background: rgba(255, 255, 255, 0.02);
}

.table-pro tbody tr:last-child td {
    border-bottom: none;
}

.table-pro tfoot {
    background: rgba(10, 107, 58, 0.05);
}

.table-pro tfoot td {
    font-weight: var(--font-semibold);
    color: var(--neutral-100);
    border-bottom: none;
}

/* Bootstrap Table Override */
.table {
    width: 100%;
    margin-bottom: var(--space-4);
    color: var(--neutral-300);
    border-collapse: collapse;
}

.table th,
.table td {
    padding: var(--space-3) var(--space-4);
    vertical-align: middle;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.table thead th {
    background: rgba(10, 107, 58, 0.1);
    color: var(--neutral-100);
    font-weight: var(--font-semibold);
    border-bottom: 2px solid rgba(10, 107, 58, 0.3);
}

.table-striped tbody tr:nth-of-type(odd) {
    background: rgba(255, 255, 255, 0.02);
}

.table-hover tbody tr:hover {
    background: rgba(10, 107, 58, 0.05);
}

.table-bordered {
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.table-bordered th,
.table-bordered td {
    border: 1px solid rgba(255, 255, 255, 0.05);
}

/* ============================================================================
   SIDEBAR
   ============================================================================ */

.sidebar-pro {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.sidebar-pro-title {
    padding: var(--space-4) var(--space-5);
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    color: var(--neutral-100);
    background: rgba(10, 107, 58, 0.1);
    border-bottom: 1px solid rgba(10, 107, 58, 0.2);
}

.sidebar-pro-list {
    padding: var(--space-2) 0;
}

.sidebar-pro-item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    font-size: var(--text-sm);
    color: var(--neutral-400);
    transition: all var(--transition-fast) var(--ease-out);
}

.sidebar-pro-item:hover {
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.03);
    padding-left: var(--space-6);
}

.sidebar-pro-item.active {
    color: var(--snooker-table-light);
    background: rgba(10, 107, 58, 0.1);
}

.sidebar-pro-item i {
    font-size: var(--text-xs);
    opacity: 0.5;
    transition: opacity var(--transition-fast);
}

.sidebar-pro-item:hover i,
.sidebar-pro-item.active i {
    opacity: 1;
}

/* ============================================================================
   LOADING & PROGRESS
   ============================================================================ */

/* Snooker Spinner */
.spinner-snooker {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(10, 107, 58, 0.2);
    border-top-color: var(--snooker-table);
    border-radius: var(--radius-full);
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Progress Bar */
.progress-pro {
    height: 8px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-full);
    overflow: hidden;
}

.progress-pro-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--snooker-table), var(--snooker-table-light));
    border-radius: var(--radius-full);
    transition: width var(--transition-slow) var(--ease-out);
}

/* ============================================================================
   DIVIDERS & DECORATIVE
   ============================================================================ */

.divider-pro {
    height: 2px;
    background: linear-gradient(
        90deg,
        transparent,
        var(--snooker-table),
        var(--gold-primary),
        var(--snooker-table),
        transparent
    );
    margin: var(--space-8) 0;
    border-radius: var(--radius-full);
}

hr {
    border: none;
    height: 1px;
    background: rgba(255, 255, 255, 0.1);
    margin: var(--space-6) 0;
}

/* ============================================================================
   PAGE PRELOADER
   ============================================================================ */

#page-preloader {
    position: fixed;
    inset: 0;
    background: var(--neutral-950);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-max);
    transition: opacity var(--transition-slow) var(--ease-out), visibility var(--transition-slow);
}

#page-preloader.hidden {
    opacity: 0;
    visibility: hidden;
}

#page-preloader .preloader {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
}

#page-preloader .loader {
    width: 60px;
    height: 60px;
    border: 4px solid rgba(10, 107, 58, 0.2);
    border-top-color: var(--snooker-table);
    border-radius: var(--radius-full);
    animation: spin 1s linear infinite;
}

/* ============================================================================
   LAYOUT COMPONENTS
   ============================================================================ */

/* Container */
.container {
    width: 100%;
    max-width: var(--container-xl);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-4);
    padding-right: var(--space-4);
}

@media (min-width: 640px) {
    .container {
        padding-left: var(--space-6);
        padding-right: var(--space-6);
    }
}

/* Main Content Area */
#content {
    min-height: 50vh;
    padding: var(--space-6) 0;
}

/* Panels */
.panel {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-6);
}

.panel-heading {
    padding: var(--space-4) var(--space-5);
    background: rgba(10, 107, 58, 0.1);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}

.panel-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--neutral-100);
    margin: 0;
}

.panel-body {
    padding: var(--space-5);
}

.panel-footer {
    padding: var(--space-4) var(--space-5);
    background: rgba(255, 255, 255, 0.02);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

/* ============================================================================
   MODAL / DIALOG
   ============================================================================ */

.modal-backdrop {
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(4px);
}

.modal-content {
    background: var(--neutral-900);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-2xl);
}

.modal-header {
    padding: var(--space-5) var(--space-6);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.modal-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--neutral-100);
    margin: 0;
}

.modal-body {
    padding: var(--space-6);
    color: var(--neutral-300);
}

.modal-footer {
    padding: var(--space-4) var(--space-6);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    justify-content: flex-end;
    gap: var(--space-3);
}

.close {
    font-size: var(--text-2xl);
    color: var(--neutral-400);
    opacity: 1;
    transition: color var(--transition-fast);
}

.close:hover {
    color: var(--neutral-100);
}

/* ============================================================================
   TABS
   ============================================================================ */

.nav-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    margin-bottom: var(--space-6);
}

.nav-tabs > li {
    margin-bottom: -1px;
}

.nav-tabs > li > a {
    display: block;
    padding: var(--space-3) var(--space-5);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--neutral-400);
    background: transparent;
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    transition: all var(--transition-fast);
}

.nav-tabs > li > a:hover {
    color: var(--neutral-100);
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.1);
}

.nav-tabs > li.active > a,
.nav-tabs > li.active > a:hover,
.nav-tabs > li.active > a:focus {
    color: var(--snooker-table-light);
    background: rgba(10, 107, 58, 0.1);
    border-color: rgba(10, 107, 58, 0.3);
    border-bottom-color: var(--neutral-950);
}

.tab-content {
    padding: var(--space-5);
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-top: none;
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

.tab-pane {
    display: none;
}

.tab-pane.active {
    display: block;
}

/* ============================================================================
   DROPDOWN
   ============================================================================ */

.dropdown-menu {
    min-width: 200px;
    padding: var(--space-2) 0;
    background: var(--neutral-900);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
}

.dropdown-menu > li > a {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    color: var(--neutral-300);
    transition: all var(--transition-fast);
}

.dropdown-menu > li > a:hover {
    color: var(--neutral-100);
    background: rgba(10, 107, 58, 0.1);
}

.dropdown-menu .divider {
    height: 1px;
    margin: var(--space-2) 0;
    background: rgba(255, 255, 255, 0.1);
}

/* ============================================================================
   TOOLTIP
   ============================================================================ */

.tooltip {
    font-family: var(--font-body);
    font-size: var(--text-xs);
}

.tooltip-inner {
    padding: var(--space-2) var(--space-3);
    background: var(--neutral-800);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
}

.tooltip.top .tooltip-arrow {
    border-top-color: var(--neutral-800);
}

.tooltip.bottom .tooltip-arrow {
    border-bottom-color: var(--neutral-800);
}

.tooltip.left .tooltip-arrow {
    border-left-color: var(--neutral-800);
}

.tooltip.right .tooltip-arrow {
    border-right-color: var(--neutral-800);
}

/* ============================================================================
   WELL / BOX
   ============================================================================ */

.well {
    padding: var(--space-5);
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
}

.well-sm {
    padding: var(--space-3);
}

.well-lg {
    padding: var(--space-8);
}

/* ============================================================================
   LABEL
   ============================================================================ */

.label {
    display: inline-flex;
    align-items: center;
    padding: var(--space-1) var(--space-2);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    border-radius: var(--radius-md);
}

.label-default {
    background: var(--neutral-700);
    color: var(--neutral-200);
}

.label-primary {
    background: var(--snooker-table);
    color: var(--neutral-50);
}

.label-success {
    background: var(--success);
    color: var(--neutral-50);
}

.label-info {
    background: var(--info);
    color: var(--neutral-50);
}

.label-warning {
    background: var(--warning);
    color: var(--neutral-900);
}

.label-danger {
    background: var(--error);
    color: var(--neutral-50);
}

/* ============================================================================
   AJAX OVERLAYS
   ============================================================================ */

.ajax-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    z-index: var(--z-modal-backdrop);
    display: none;
}

.ajax-overlay.active {
    display: flex;
    align-items: center;
    justify-content: center;
}

.ajax-quickview-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(8px);
    z-index: var(--z-modal);
    display: none;
    align-items: center;
    justify-content: center;
}

.ajax-quickview-overlay.active {
    display: flex;
}

.ajax-quickview-overlay__preloader {
    width: 60px;
    height: 60px;
    border: 4px solid rgba(10, 107, 58, 0.2);
    border-top-color: var(--snooker-table);
    border-radius: var(--radius-full);
    animation: spin 1s linear infinite;
}

/* ============================================================================
   RESPONSIVE UTILITIES
   ============================================================================ */

@media (max-width: 767px) {
    .hidden-xs { display: none !important; }
}

@media (min-width: 768px) and (max-width: 991px) {
    .hidden-sm { display: none !important; }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .hidden-md { display: none !important; }
}

@media (min-width: 1200px) {
    .hidden-lg { display: none !important; }
}

/* Mobile-first visibility */
.visible-xs,
.visible-sm,
.visible-md,
.visible-lg {
    display: none !important;
}

@media (max-width: 767px) {
    .visible-xs { display: block !important; }
}

@media (min-width: 768px) and (max-width: 991px) {
    .visible-sm { display: block !important; }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .visible-md { display: block !important; }
}

@media (min-width: 1200px) {
    .visible-lg { display: block !important; }
}

/* ============================================================================
   PRINT STYLES
   ============================================================================ */

@media print {
    body {
        background: white;
        color: black;
    }
    
    .btn,
    button,
    .no-print {
        display: none !important;
    }
    
    a {
        color: black;
        text-decoration: underline;
    }
    
    .container {
        max-width: 100%;
    }
}

/* ============================================================================
   ACCESSIBILITY
   ============================================================================ */

/* Focus visible outlines */
:focus-visible {
    outline: 2px solid var(--snooker-table);
    outline-offset: 2px;
}

/* Skip link */
.skip-link {
    position: absolute;
    top: -40px;
    left: 0;
    padding: var(--space-2) var(--space-4);
    background: var(--snooker-table);
    color: var(--neutral-50);
    z-index: var(--z-max);
    transition: top var(--transition-fast);
}

.skip-link:focus {
    top: 0;
}

/* Screen reader only */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    :root {
        --snooker-table: #00a854;
        --gold-primary: #ffd700;
    }
    
    .btn,
    button {
        border-width: 2px;
    }
}

/* ============================================
   CRITICAL OVERRIDES - Fix CSS Specificity
   Forces dark theme over old Bootstrap/theme CSS
   ============================================ */

/* Force dark background on entire page */
body,
html {
    background-color: #0a0a0a !important;
    color: #fafafa !important;
}

/* Main content wrapper */
#content,
.container,
.container-fluid,
main,
.main-content,
#common-home {
    background-color: transparent !important;
}

/* Megamenu dropdowns - force dark theme */
.sf-mega,
.sf-menu > li > .sf-mega,
.sf-menu .sf-mega,
.megamenu-wrapper,
.menu-dropdown,
.dropdown-menu,
ul.sf-menu li ul,
ul.sf-menu li ul li,
.nav-dropdown {
    background-color: #171717 !important;
    background: #171717 !important;
    border-color: #262626 !important;
    color: #fafafa !important;
}

/* Megamenu items */
.sf-mega a,
.sf-menu a,
.sf-menu > li > a,
.sf-mega li a,
.megamenu-wrapper a,
ul.sf-menu li ul li a {
    color: #d4d4d4 !important;
    background: transparent !important;
}

.sf-mega a:hover,
.sf-menu a:hover,
.sf-menu > li > a:hover,
.sf-mega li a:hover,
ul.sf-menu li ul li a:hover {
    color: #d4af37 !important;
    background-color: rgba(212, 175, 55, 0.1) !important;
}

/* Megamenu headers/titles */
.sf-mega h3,
.sf-mega .megamenu-title,
.sf-mega .title,
.megamenu-wrapper h3,
.megamenu-wrapper .title {
    color: #d4af37 !important;
    border-bottom-color: #262626 !important;
}

/* Product cards area */
.products-block,
.product-list,
.product-grid,
.products,
.featured-products,
#latest,
#featured,
.owl-carousel,
.owl-stage-outer,
.owl-stage,
.owl-item {
    background-color: transparent !important;
}

/* Product card thumbnails */
.product-thumb,
.product-layout,
.product-item,
.product-card {
    background-color: #171717 !important;
    border-color: #262626 !important;
    color: #fafafa !important;
}

.product-thumb:hover,
.product-layout:hover,
.product-item:hover {
    border-color: #0a6b3a !important;
}

/* Product card text */
.product-thumb .caption,
.product-thumb .caption h4,
.product-thumb .caption h4 a,
.product-thumb h4 a,
.product-thumb .name a,
.product-thumb .title a,
.product-card .title a {
    color: #fafafa !important;
}

.product-thumb .caption h4 a:hover,
.product-thumb h4 a:hover,
.product-thumb .name a:hover,
.product-thumb .title a:hover,
.product-card .title a:hover {
    color: #d4af37 !important;
}

/* Product prices */
.product-thumb .price,
.product-thumb .price-new,
.price-new {
    color: #22c55e !important;
}

.product-thumb .price-old,
.price-old {
    color: #737373 !important;
    text-decoration: line-through !important;
}

/* Footer overrides */
footer,
#footer,
.footer,
footer a,
#footer a,
.footer a {
    background-color: #0a0a0a !important;
    color: #d4d4d4 !important;
}

footer a:hover,
#footer a:hover,
.footer a:hover {
    color: #d4af37 !important;
}

footer h5,
#footer h5,
.footer h5,
footer .title,
#footer .title,
.footer .title {
    color: #fafafa !important;
}

/* Remove any white backgrounds from Bootstrap components */
.panel,
.panel-body,
.panel-default,
.panel-heading,
.well,
.list-group,
.list-group-item,
.thumbnail {
    background-color: #171717 !important;
    border-color: #262626 !important;
    color: #fafafa !important;
}

.list-group-item a {
    color: #d4d4d4 !important;
}

.list-group-item a:hover {
    color: #d4af37 !important;
}

/* Input fields */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
input[type="url"],
textarea,
select,
.form-control {
    background-color: #262626 !important;
    border-color: #404040 !important;
    color: #fafafa !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus,
.form-control:focus {
    border-color: #0a6b3a !important;
    box-shadow: 0 0 0 3px rgba(10, 107, 58, 0.2) !important;
}

/* Buttons override */
.btn-primary,
.btn-success {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
    color: #fafafa !important;
}

.btn-primary:hover,
.btn-success:hover {
    background-color: #085c32 !important;
    border-color: #085c32 !important;
}

.btn-default,
.btn-secondary {
    background-color: #262626 !important;
    border-color: #404040 !important;
    color: #fafafa !important;
}

.btn-default:hover,
.btn-secondary:hover {
    background-color: #404040 !important;
    border-color: #525252 !important;
}

/* Cart/wishlist buttons */
.btn-cart,
.add-to-cart,
.button-cart {
    background-color: #0a6b3a !important;
    color: #fafafa !important;
}

/* Alert boxes */
.alert {
    border-radius: 8px !important;
}

.alert-success {
    background-color: rgba(34, 197, 94, 0.15) !important;
    border-color: #22c55e !important;
    color: #22c55e !important;
}

.alert-danger,
.alert-error {
    background-color: rgba(239, 68, 68, 0.15) !important;
    border-color: #ef4444 !important;
    color: #ef4444 !important;
}

.alert-warning {
    background-color: rgba(245, 158, 11, 0.15) !important;
    border-color: #f59e0b !important;
    color: #f59e0b !important;
}

.alert-info {
    background-color: rgba(59, 130, 246, 0.15) !important;
    border-color: #3b82f6 !important;
    color: #3b82f6 !important;
}

/* Breadcrumbs */
.breadcrumb,
.breadcrumb li,
.breadcrumb a {
    background-color: transparent !important;
    color: #a3a3a3 !important;
}

.breadcrumb a:hover {
    color: #d4af37 !important;
}

/* Tables */
table,
.table {
    background-color: #171717 !important;
    color: #fafafa !important;
}

.table > thead > tr > th,
.table > tbody > tr > td,
.table > tfoot > tr > td {
    border-color: #262626 !important;
}

.table-striped > tbody > tr:nth-of-type(odd) {
    background-color: #1f1f1f !important;
}

.table-hover > tbody > tr:hover {
    background-color: rgba(10, 107, 58, 0.1) !important;
}

/* Modal dialogs */
.modal-content {
    background-color: #171717 !important;
    border-color: #262626 !important;
    color: #fafafa !important;
}

.modal-header {
    border-bottom-color: #262626 !important;
}

.modal-footer {
    border-top-color: #262626 !important;
}

/* Carousel/slider controls */
.owl-nav button,
.owl-dots button,
.carousel-control,
.slick-arrow {
    background-color: #262626 !important;
    color: #fafafa !important;
    border-color: #404040 !important;
}

.owl-nav button:hover,
.carousel-control:hover,
.slick-arrow:hover {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
}

/* Remove visited link purple color */
a:visited {
    color: inherit;
}

footer a:visited,
#footer a:visited {
    color: #d4d4d4 !important;
}

/* Pagination */
.pagination > li > a,
.pagination > li > span {
    background-color: #262626 !important;
    border-color: #404040 !important;
    color: #d4d4d4 !important;
}

.pagination > li > a:hover {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
    color: #fafafa !important;
}

.pagination > .active > a,
.pagination > .active > span {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
    color: #fafafa !important;
}

/* Sidebar/category menu */
.list-group-item.active,
.list-group-item.active:hover {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
}

/* Tabs */
.nav-tabs {
    border-bottom-color: #262626 !important;
}

.nav-tabs > li > a {
    background-color: #1f1f1f !important;
    border-color: #262626 !important;
    color: #d4d4d4 !important;
}

.nav-tabs > li.active > a,
.nav-tabs > li > a:hover {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
    color: #fafafa !important;
}

/* Tab content */
.tab-content {
    background-color: #171717 !important;
    border-color: #262626 !important;
}

/* Rating stars */
.rating .fa-star,
.rating .fa-star-o {
    color: #d4af37 !important;
}

/* Fix any remaining white text on white bg */
.text-muted {
    color: #737373 !important;
}

/* Category boxes in megamenu */
.sf-mega .box,
.sf-mega .category-box,
.megamenu-wrapper .box {
    background-color: #1f1f1f !important;
    border-color: #262626 !important;
}

/* Image hover effects */
.product-thumb .image img,
.product-image img {
    transition: transform 0.3s ease, opacity 0.3s ease !important;
}

.product-thumb:hover .image img,
.product-thumb:hover .product-image img {
    transform: scale(1.05) !important;
}

/* ============================================
   SPECIFIC JETIMPEX MEGAMENU OVERRIDES
   ============================================ */

/* Force megamenu dark background - high specificity */
.sf-menu .sf-mega,
ul.sf-menu li .sf-mega,
.sf-menu > li > .sf-mega,
nav .sf-menu .sf-mega,
header .sf-menu .sf-mega,
.header-top .sf-menu .sf-mega,
.megamenu .sf-menu .sf-mega {
    background: #171717 !important;
    background-color: #171717 !important;
    border: 1px solid #262626 !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
}

/* Megamenu section titles */
.sf-menu .sf-mega > li .submenu_title,
.sf-menu .sf-mega > li .submenu_title a,
.sf-menu .sf-mega .submenu_title a {
    color: #d4af37 !important;
    font-weight: 600 !important;
    border-bottom: 1px solid #262626 !important;
    padding-bottom: 8px !important;
    margin-bottom: 10px !important;
}

/* Megamenu links */
.sf-menu .sf-mega > li a,
.sf-menu .sf-mega li a,
.sf-menu .sf-mega ul li a {
    color: #d4d4d4 !important;
    background: transparent !important;
}

.sf-menu .sf-mega > li a:hover,
.sf-menu .sf-mega li a:hover,
.sf-menu .sf-mega ul li a:hover {
    color: #d4af37 !important;
    background: rgba(212, 175, 55, 0.1) !important;
}

/* Vertical menu items */
.sf-menu > li,
ul.sf-menu > li,
nav.sf-menu > li {
    background: transparent !important;
}

.sf-menu > li > a,
ul.sf-menu > li > a {
    color: #fafafa !important;
}

.sf-menu > li > a:hover,
.sf-menu > li:hover > a,
ul.sf-menu > li > a:hover {
    color: #d4af37 !important;
    background: rgba(10, 107, 58, 0.2) !important;
}

/* Vertical category menu */
.box-category,
.box-category ul,
.list-group.vertical-menu,
.vertical-menu {
    background-color: #171717 !important;
    border-color: #262626 !important;
}

.box-category a,
.box-category li a,
.vertical-menu a {
    color: #d4d4d4 !important;
    background: transparent !important;
    border-color: #262626 !important;
}

.box-category a:hover,
.box-category li a:hover,
.vertical-menu a:hover {
    color: #d4af37 !important;
    background: rgba(10, 107, 58, 0.2) !important;
}

/* Category list in sidebar */
.list-group-category,
.category-list {
    background: #171717 !important;
}

.list-group-category .list-group-item,
.category-list li {
    background: transparent !important;
    border-color: #262626 !important;
    color: #d4d4d4 !important;
}

/* Product thumb caption area */
.product-thumb .caption,
.product-layout .caption {
    background-color: #171717 !important;
    padding: 15px !important;
}

/* Product grid wrappers */
.products-grid,
.product-grid,
#products,
.main-products,
.featured .product-grid,
.latest .product-grid,
.bestseller .product-grid,
.special .product-grid {
    background: transparent !important;
}

/* Home page sections */
.owl-carousel-products,
.featured-products,
.latest-products,
.bestseller-products,
.special-products {
    background: transparent !important;
}

/* Section titles */
.products-block .title,
.block-title,
.section-title,
h2.title,
h3.title,
.featured .title,
.latest .title,
.bestseller .title {
    color: #fafafa !important;
    border-bottom-color: #262626 !important;
}

/* Slideshow/banner areas */
.slideshow,
.banner,
.swiper-container,
.tm-owl-carousel,
.owl-carousel {
    background: transparent !important;
}

/* Remove white backgrounds from common wrappers */
.row,
.container,
.container-fluid,
[class*="col-"] {
    background-color: transparent !important;
}

/* Content area specific */
#column-left,
#column-right,
.aside-column {
    background-color: transparent !important;
}

/* Sidebar boxes */
.box,
aside .box {
    background-color: #171717 !important;
    border-color: #262626 !important;
}

.box .box-heading,
.box .box-title,
.box-heading {
    background-color: #1f1f1f !important;
    color: #d4af37 !important;
    border-color: #262626 !important;
}

.box .box-content,
.box-content {
    background-color: #171717 !important;
}

/* Search results */
#search,
.search-results {
    background: transparent !important;
}

/* Compare/wishlist pages */
#compare,
#wishlist {
    background: transparent !important;
}

/* Account pages */
#account,
.account-page {
    background: transparent !important;
}

/* Checkout pages */
#checkout,
.checkout-page {
    background: transparent !important;
}

/* Cart page */
#cart,
.shopping-cart {
    background: transparent !important;
}

/* Fix OWL carousel navigation */
.owl-carousel .owl-nav button.owl-prev,
.owl-carousel .owl-nav button.owl-next {
    background: #262626 !important;
    color: #fafafa !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
}

.owl-carousel .owl-nav button:hover {
    background: #0a6b3a !important;
}

.owl-carousel .owl-dots .owl-dot span {
    background: #404040 !important;
}

.owl-carousel .owl-dots .owl-dot.active span {
    background: #d4af37 !important;
}

/* Fix any inline white backgrounds */
[style*="background: #fff"],
[style*="background:#fff"],
[style*="background: white"],
[style*="background:white"],
[style*="background-color: #fff"],
[style*="background-color:#fff"],
[style*="background-color: white"],
[style*="background-color:white"] {
    background: #171717 !important;
    background-color: #171717 !important;
}

/* Quickview modal */
.quickview,
.quickview-modal,
#quickview,
.mfp-content {
    background-color: #171717 !important;
    color: #fafafa !important;
}

/* Fix header dropdowns */
#cart-total,
.cart-dropdown,
.header-cart .dropdown-menu,
#cart .dropdown-menu {
    background-color: #171717 !important;
    border-color: #262626 !important;
    color: #fafafa !important;
}

/* Account dropdown */
.account-dropdown,
.header-account .dropdown-menu {
    background-color: #171717 !important;
    border-color: #262626 !important;
}

/* Language/currency dropdowns */
.language-dropdown,
.currency-dropdown,
#form-language .dropdown-menu,
#form-currency .dropdown-menu {
    background-color: #171717 !important;
    border-color: #262626 !important;
}

/* Ensure all dropdown menus are dark */
.dropdown-menu {
    background-color: #171717 !important;
    border-color: #262626 !important;
}

.dropdown-menu > li > a {
    color: #d4d4d4 !important;
}

.dropdown-menu > li > a:hover {
    background-color: rgba(10, 107, 58, 0.2) !important;
    color: #d4af37 !important;
}

/* Newsletter section */
.newsletter,
#newsletter,
.newsletter-section {
    background-color: #1f1f1f !important;
}

/* Partners/brands section */
.partners,
.brands,
.manufacturers {
    background: transparent !important;
}

/* Ensure images don't have white background */
img {
    background-color: transparent !important;
}

/* Fix common Bootstrap classes that add white bg */
.bg-white {
    background-color: #171717 !important;
}

.bg-light {
    background-color: #1f1f1f !important;
}

/* Price display */
.price,
.product-price {
    color: #22c55e !important;
}

/* Stock status */
.stock.in-stock {
    color: #22c55e !important;
}

.stock.out-of-stock {
    color: #ef4444 !important;
}

/* Wishlist/compare buttons */
.btn-wishlist,
.btn-compare,
button[data-original-title="Add to Wish List"],
button[data-original-title="Compare this Product"] {
    background-color: #262626 !important;
    color: #d4d4d4 !important;
    border-color: #404040 !important;
}

.btn-wishlist:hover,
.btn-compare:hover {
    background-color: #d4af37 !important;
    color: #0a0a0a !important;
    border-color: #d4af37 !important;
}

/* Fix NEW/SALE badges */
.sticker,
.badge,
.label-sale,
.label-new {
    font-weight: 600 !important;
}

.sticker-new,
.label-new {
    background-color: #0a6b3a !important;
    color: #fafafa !important;
}

.sticker-sale,
.label-sale {
    background-color: #ef4444 !important;
    color: #fafafa !important;
}

/* Responsive fixes */
@media (max-width: 991px) {
    .sf-menu .sf-mega {
        position: relative !important;
        left: 0 !important;
        width: 100% !important;
        margin-left: 0 !important;
        background: #171717 !important;
    }
}

/* ============================================
   MOBILE MENU DRAWER - Desktop Color Match
   ============================================ */
#mobile-menu,
.mobile-menu,
aside#mobile-menu {
    background: #1a1a1a !important;
    border-right: 1px solid #2d2d2d !important;
}

#mobile-menu nav,
#mobile-menu .mobile-nav-categories {
    background: #1a1a1a !important;
}

/* Mobile menu links - match sidebar menu style */
#mobile-menu a,
#mobile-menu nav a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    color: #e0e0e0 !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 8px !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
}

#mobile-menu a:hover,
#mobile-menu nav a:hover {
    color: #fff !important;
    background: #0a6b3a !important;
    padding-left: 20px !important;
}

#mobile-menu a:active,
#mobile-menu nav a:active {
    background: #085c32 !important;
}

/* Mobile menu icons */
#mobile-menu a i,
#mobile-menu nav a i {
    color: #0a6b3a !important;
    width: 20px !important;
    text-align: center !important;
    transition: color 0.2s ease !important;
}

#mobile-menu a:hover i,
#mobile-menu nav a:hover i {
    color: #fff !important;
}

/* Mobile menu categories section */
#mobile-menu .mobile-nav-categories {
    margin-top: 0 !important;
}

#mobile-menu .mobile-nav-categories .sf-menu,
#mobile-menu .mobile-nav-categories ul {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    background: transparent !important;
}

#mobile-menu .mobile-nav-categories .sf-menu > li,
#mobile-menu .mobile-nav-categories ul > li {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    border-bottom: 1px solid #2d2d2d !important;
}

#mobile-menu .mobile-nav-categories .sf-menu > li:last-child,
#mobile-menu .mobile-nav-categories ul > li:last-child {
    border-bottom: none !important;
}

#mobile-menu .mobile-nav-categories .sf-menu > li > a,
#mobile-menu .mobile-nav-categories ul > li > a {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 14px 16px !important;
    color: #e0e0e0 !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    transition: all 0.2s ease !important;
}

#mobile-menu .mobile-nav-categories .sf-menu > li > a:hover,
#mobile-menu .mobile-nav-categories ul > li > a:hover {
    color: #fff !important;
    background: #0a6b3a !important;
    padding-left: 24px !important;
}

/* Mobile menu phone button */
#mobile-menu .p-4 a[href^="tel:"] {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 14px 20px !important;
    background: linear-gradient(135deg, #0a6b3a, #0d8247) !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: 12px !important;
    transition: all 0.2s ease !important;
}

#mobile-menu .p-4 a[href^="tel:"]:hover {
    background: linear-gradient(135deg, #085c32, #0a6b3a) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 20px rgba(10, 107, 58, 0.3) !important;
}

/* Mobile menu close button */
#mobile-menu-close {
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid #333 !important;
    color: #a3a3a3 !important;
    transition: all 0.2s ease !important;
}

#mobile-menu-close:hover {
    background: rgba(255,255,255,0.1) !important;
    color: #fff !important;
}

/* ============================================
   VISITED LINKS FIX
   Reset browser default purple visited color
   ============================================ */

/* Global visited link reset */
a:visited,
a:link:visited,
a:any-link:visited {
    color: inherit !important;
}

/* Footer specific visited links */
footer a:visited,
#footer a:visited,
.footer a:visited,
.footer-module a:visited,
footer ul a:visited,
footer li a:visited {
    color: #a3a3a3 !important;
}

footer a:visited:hover,
#footer a:visited:hover,
.footer a:visited:hover {
    color: #d4af37 !important;
}

/* Menu visited links */
.sf-menu a:visited,
.megamenu a:visited,
nav a:visited {
    color: inherit !important;
}

/* Product links */
.product-thumb a:visited,
.product-card a:visited,
.product-layout a:visited {
    color: #fafafa !important;
}

/* Sidebar/category links */
.list-group a:visited,
.category-list a:visited,
.box-category a:visited {
    color: #d4d4d4 !important;
}

/* ============================================
   HEADER LAYOUT + SEARCH OVERRIDES
   ============================================ */
.snooker-header .header-accent-bar {
    height: 5px !important;
    min-height: 5px !important;
    background: linear-gradient(90deg, #0a6b3a, #0d8247) !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

.snooker-header .header-primary-row {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
}

.snooker-header .header-logo-area {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-shrink: 0 !important;
    width: 240px;
}

.snooker-header .header-logo-area #logo {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 1 !important;
    min-width: 0 !important;
}

.snooker-header .desktop-search {
    flex: 1 !important;
    min-width: 0 !important;
}

.snooker-header .header-actions-row {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.snooker-header .header-locale-switchers {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.snooker-header .header-locale-switchers .language-switcher,
.snooker-header .header-locale-switchers .currency-switcher {
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 999px !important;
    padding: 4px 10px !important;
}

.snooker-header #cart-total {
    background: transparent !important;
    padding: 0 !important;
    border: none !important;
    color: #fff !important;
}

#search input[name="search"] {
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}

#search .button-search {
    top: 8px !important;
    bottom: 8px !important;
    transform: none !important;
    right: 8px !important;
    width: 40px !important;
    border-radius: 12px !important;
}

#search .button-search i {
    pointer-events: none !important;
}

.snooker-search {
    position: relative !important;
    width: 100% !important;
}

.snooker-search__inner {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.snooker-search__input {
    width: 100% !important;
    padding: 12px 56px 12px 18px !important;
    border-radius: 14px !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    background: rgba(255,255,255,0.05) !important;
    color: #e5e5e5 !important;
    font-size: 14px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}

.snooker-search__input:focus {
    border-color: rgba(10,107,58,0.5) !important;
    box-shadow: 0 0 0 2px rgba(10,107,58,0.25) !important;
    background: rgba(10,107,58,0.08) !important;
}

.snooker-search__input::placeholder {
    color: rgba(229,229,229,0.45) !important;
}

.snooker-search__button {
    position: absolute !important;
    top: 8px !important;
    bottom: 8px !important;
    right: 8px !important;
    width: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px !important;
    border: none !important;
    background: linear-gradient(135deg, #0a6b3a, #0d8247) !important;
    box-shadow: none !important;
    cursor: pointer !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}

.snooker-search__button:hover,
.snooker-search__button:focus-visible {
    box-shadow: 0 8px 20px rgba(13,130,71,0.35) !important;
    transform: translateY(-1px) !important;
}

.snooker-search__button:active {
    transform: scale(0.96) !important;
}

.snooker-search__button i {
    color: #fff !important;
    font-size: 14px !important;
}

.snooker-search #livesearch_search_results {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: calc(100% + 10px) !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    background: #111 !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: 16px !important;
    box-shadow: 0 25px 60px rgba(0,0,0,0.55) !important;
    z-index: 80 !important;
    max-height: 420px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    animation: snookerSearchDropdown 0.18s ease forwards !important;
}

.snooker-search #livesearch_search_results li + li {
    border-top: 1px solid rgba(255,255,255,0.05) !important;
}

.snooker-search #livesearch_search_results li {
    transition: background 0.15s ease !important;
}

.snooker-search #livesearch_search_results li.highlighted,
.snooker-search #livesearch_search_results li:hover {
    background: rgba(10,107,58,0.2) !important;
}

.snooker-search #livesearch_search_results a,
.snooker-search #livesearch_search_results a:visited {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    color: #e5e5e5 !important;
    text-decoration: none !important;
    font-size: 14px !important;
}

.snooker-search #livesearch_search_results a:hover {
    color: #fff !important;
}

.snooker-search #livesearch_search_results img {
    width: 48px !important;
    height: 48px !important;
    border-radius: 10px !important;
    object-fit: cover !important;
    background: #1f1f1f !important;
}

@keyframes snookerSearchDropdown {
    from {
        opacity: 0;
        transform: translateY(5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 575px) {
    .snooker-search__input {
        font-size: 13px !important;
        padding: 12px 52px 12px 14px !important;
    }

    .snooker-search #livesearch_search_results {
        max-height: 320px !important;
    }
}

@media (min-width: 992px) {
    .snooker-header #mobile-menu-toggle {
        display: none !important;
    }
    .snooker-header .header-actions-row {
        margin-left: auto !important;
        justify-content: flex-end !important;
    }
}

@media (max-width: 991px) {
    /* Hide accent bar on mobile */
    .snooker-header .header-accent-bar {
        display: none !important;
    }
    
    /* Hide desktop search on mobile */
    .snooker-header .desktop-search {
        display: none !important;
    }
    
    /* Show mobile menu toggle */
    .snooker-header #mobile-menu-toggle {
        display: flex !important;
        order: -1 !important;
    }
    
    /* Hide locale switchers on mobile */
    .snooker-header .header-locale-switchers {
        display: none !important;
    }
    
    /* Adjust header height for mobile */
    .snooker-header .header-primary-row {
        height: 56px !important;
        padding: 0 !important;
    }
    
    /* Logo area adjustments */
    .snooker-header .header-logo-area {
        width: auto !important;
        gap: 8px !important;
    }
    
    .snooker-header .header-logo-area #logo img {
        height: 40px !important;
    }
    
    /* Hide phone on small screens */
    .snooker-header .header-actions-row > a[href^="tel:"] {
        display: none !important;
    }
    
    /* Show search toggle on mobile */
    .snooker-header #search-toggle {
        display: flex !important;
    }
    
    /* ============================================
       MOBILE: HIDE SIDEBAR - Use drawer instead
       ============================================ */
    #column-left,
    aside#column-left,
    .home-sidebar-left,
    #common-home #column-left,
    #common-home aside#column-left,
    #common-home .home-sidebar-left,
    .home-layout #column-left,
    .home-layout aside#column-left,
    .category-layout .category-sidebar-left,
    .category-sidebar-left {
        display: none !important;
    }
    
    /* Content takes full width when sidebar hidden */
    #common-home #content,
    #common-home .home-content,
    .home-layout #content,
    .home-layout .home-content,
    .category-layout .category-content,
    .category-content,
    #content {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 16px !important;
        margin: 0 !important;
    }
    
    /* Home layout - single column */
    #common-home > .home-layout,
    .home-layout {
        flex-direction: column !important;
    }
    
    /* Category layout - single column */
    .category-layout {
        flex-direction: column !important;
    }
}

@media (min-width: 992px) {
    /* Hide search toggle on desktop */
    .snooker-header #search-toggle {
        display: none !important;
    }
}

/* ============================================
   ADDITIONAL JETIMPEX THEME OVERRIDES
   ============================================ */

/* Category vertical menu */
.box-category ul,
.box-category ul li,
.box-category ul li a {
    background: transparent !important;
    border-color: #262626 !important;
    color: #d4d4d4 !important;
}

.box-category ul li a:hover,
.box-category ul li.active > a {
    color: #d4af37 !important;
    background: rgba(10, 107, 58, 0.15) !important;
}

/* Jetimpex specific modules */
.latest,
.featured,
.bestseller,
.special {
    background: transparent !important;
}

.latest .products-block,
.featured .products-block,
.bestseller .products-block,
.special .products-block {
    background: transparent !important;
}

/* Superfish menu specific */
ul.sf-menu,
.sf-menu ul,
.sf-menu li {
    background: transparent !important;
}

ul.sf-menu > li > ul,
.sf-menu li ul {
    background: #171717 !important;
    border: 1px solid #262626 !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
}

ul.sf-menu > li > ul > li > a,
.sf-menu li ul li a {
    color: #d4d4d4 !important;
    background: transparent !important;
}

ul.sf-menu > li > ul > li > a:hover,
.sf-menu li ul li a:hover {
    color: #d4af37 !important;
    background: rgba(10, 107, 58, 0.2) !important;
}

/* OWL Carousel override for Jetimpex */
.tm-owl-carousel,
.tm-owl-carousel .owl-stage-outer,
.tm-owl-carousel .owl-stage,
.tm-owl-carousel .owl-item {
    background: transparent !important;
}

/* Swiper carousel */
.swiper-container,
.swiper-wrapper,
.swiper-slide {
    background: transparent !important;
}

/* Content blocks */
.content-top,
.content-bottom {
    background: transparent !important;
}

/* Module wrappers */
[class*="module-"],
.module-content,
.module-container {
    background: transparent !important;
}

/* Fix text colors in various contexts */
.caption,
.description,
.product-description {
    color: #d4d4d4 !important;
}

/* Price colors */
.price,
span.price {
    color: #22c55e !important;
}

.price-old,
span.price-old {
    color: #737373 !important;
    text-decoration: line-through !important;
}

/* Ensure buttons are properly styled */
.btn-group .btn,
.button-group .btn,
.button-group button {
    background-color: #262626 !important;
    border-color: #404040 !important;
    color: #fafafa !important;
}

.btn-group .btn:hover,
.button-group .btn:hover {
    background-color: #0a6b3a !important;
    border-color: #0a6b3a !important;
}

/* Cart mini dropdown */
#cart ul,
#cart .dropdown-menu {
    background: #171717 !important;
    border: 1px solid #262626 !important;
}

#cart .mini-cart-info {
    background: transparent !important;
}

#cart .mini-cart-total {
    background: #1f1f1f !important;
    border-top: 1px solid #262626 !important;
}

/* Search suggestions dropdown */
.dropdown-menu.livesearch,
.livesearch-dropdown,
.tt-menu,
.typeahead-dropdown {
    background: #171717 !important;
    border: 1px solid #262626 !important;
}

.tt-suggestion,
.livesearch-item {
    color: #d4d4d4 !important;
}

.tt-suggestion:hover,
.livesearch-item:hover {
    background: rgba(10, 107, 58, 0.2) !important;
    color: #d4af37 !important;
}

/* Remove any hardcoded white backgrounds from inline styles (additional selectors) */
div[style*="background:#ffffff"],
div[style*="background: #ffffff"],
section[style*="background:#ffffff"],
section[style*="background: #ffffff"] {
    background: #0a0a0a !important;
}

/* Jetimpex specific wrappers */
.top_container,
.middle_container,
.bottom_container,
#container,
.container-inner {
    background: transparent !important;
}

/* Override any white background classes from Bootstrap or the theme */
.bg-white,
.bg-light,
.bg-default {
    background-color: #171717 !important;
}

.text-dark {
    color: #fafafa !important;
}

/* Final catch-all for common white background patterns */
main,
article,
section,
aside,
.main,
.content,
.wrapper,
.inner {
    background-color: transparent !important;
}

/* ============================================
   SNOOKER TABLE BACKGROUND - Page Container
   ============================================ */
#page {
    background: 
        /* Multiple noise textures with different scales to avoid patterns */
        radial-gradient(circle at 23% 37%, rgba(255,255,255,0.015) 0.8px, transparent 1px),
        radial-gradient(circle at 67% 81%, rgba(255,255,255,0.01) 0.6px, transparent 1px),
        radial-gradient(circle at 89% 13%, rgba(255,255,255,0.008) 1px, transparent 1.2px),
        radial-gradient(circle at 41% 59%, rgba(255,255,255,0.012) 0.4px, transparent 0.8px),
        
        /* Organic felt texture with irregular patterns */
        linear-gradient(47deg, 
            rgba(3, 35, 20, 0.4) 0%, 
            rgba(5, 55, 30, 0.6) 23%, 
            rgba(2, 25, 14, 0.5) 47%, 
            rgba(5, 55, 30, 0.4) 71%, 
            rgba(3, 35, 20, 0.3) 100%
        ),
        
        /* Cross-directional grain for natural felt look */
        linear-gradient(133deg, 
            rgba(6, 45, 25, 0.5) 0%, 
            transparent 17%, 
            rgba(6, 45, 25, 0.3) 31%, 
            transparent 49%, 
            rgba(6, 45, 25, 0.4) 67%, 
            transparent 83%, 
            rgba(6, 45, 25, 0.2) 100%
        ),
        
        /* Additional texture layer for depth */
        linear-gradient(197deg, 
            rgba(4, 40, 22, 0.3) 0%, 
            transparent 29%, 
            rgba(4, 40, 22, 0.25) 58%, 
            transparent 87%, 
            rgba(4, 40, 22, 0.2) 100%
        ),
        
        /* Base snooker table green - much darker */
        linear-gradient(180deg, 
            #042e18 0%, 
            #053c1f 25%, 
            #032415 50%, 
            #041a10 75%, 
            #02140c 100%
        ) !important;
    
    background-size: 
        2.7px 3.1px,
        4.3px 5.7px,
        7.1px 6.3px,
        3.9px 4.1px,
        100% 100%,
        317px 241px,
        197px 283px,
        100% 100% !important;
    
    background-position:
        0 0,
        23px 17px,
        -31px 41px,
        67px -19px,
        0 0,
        0 0,
        47px 83px,
        0 0 !important;
    
    background-attachment: fixed, fixed, fixed, fixed, fixed, scroll, scroll, fixed !important;
    
    /* Enhanced shadow for more depth */
    box-shadow: 
        inset 0 0 300px rgba(0, 0, 0, 0.4),
        inset 0 0 100px rgba(0, 0, 0, 0.3) !important;
    
    /* Smooth transitions */
    transition: all 0.3s ease !important;
}
