/**
 * 188BET VIETNAM - MASTER CSS
 * Premium Casino Design System
 * Version: 1.0
 * Market: Vietnam
 * Device Priority: Mobile-First
 *
 * WARNING: DO NOT MODIFY THIS FILE
 * This is the unified Master CSS used across all 12 pages.
 * Any changes here will affect the entire website.
 */

/* ============================================
   CSS CUSTOM PROPERTIES (Design Tokens)
   ============================================ */

:root {
  /* ===== PRIMARY COLORS ===== */
  --color-primary-dark: #1a1f35;
  --color-primary-blue: #2c3e50;
  --color-primary-gold: #ffa726;
  --color-primary-gold-light: #ffb74d;
  --color-primary-gold-dark: #f57c00;

  /* ===== ACCENT COLORS ===== */
  --color-accent-red: #d32f2f;
  --color-accent-green: #388e3c;
  --color-accent-blue: #1976d2;

  /* ===== NEUTRAL COLORS ===== */
  --color-white: #ffffff;
  --color-gray-50: #f8f9fa;
  --color-gray-100: #e9ecef;
  --color-gray-200: #dee2e6;
  --color-gray-300: #ced4da;
  --color-gray-400: #adb5bd;
  --color-gray-500: #6c757d;
  --color-gray-600: #495057;
  --color-gray-700: #343a40;
  --color-gray-800: #212529;
  --color-gray-900: #0d0f14;

  /* ===== SEMANTIC COLORS ===== */
  --color-success: #388e3c;
  --color-warning: #f57c00;
  --color-error: #d32f2f;
  --color-info: #1976d2;

  /* ===== TEXT COLORS ===== */
  --text-primary-on-dark: #ffffff;
  --text-secondary-on-dark: rgba(255, 255, 255, 0.7);
  --text-muted-on-dark: rgba(255, 255, 255, 0.5);
  --text-primary-on-light: #212529;
  --text-secondary-on-light: #495057;
  --text-muted-on-light: #6c757d;
  --text-gold: #ffa726;
  --text-link: #42a5f5;
  --text-link-hover: #64b5f6;

  /* ===== BACKGROUND COLORS ===== */
  --bg-primary: #1a1f35;
  --bg-secondary: #2c3e50;
  --bg-tertiary: #455a64;
  --bg-card: #243447;
  --bg-card-hover: #2d3f54;
  --bg-input: #1e2837;
  --bg-overlay: rgba(0, 0, 0, 0.7);

  /* ===== TYPOGRAPHY ===== */
  --font-primary: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto',
                  'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  --font-secondary: 'Inter', 'SF Pro Display', -apple-system, sans-serif;
  --font-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', monospace;

  /* Font Sizes */
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 1.875rem;
  --font-size-4xl: 2.25rem;
  --font-size-5xl: 3rem;
  --font-size-6xl: 3.75rem;

  /* Font Weights */
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;

  /* Line Heights */
  --line-height-tight: 1.2;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;

  /* Letter Spacing */
  --letter-spacing-tight: -0.02em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.025em;
  --letter-spacing-wider: 0.05em;
  --letter-spacing-widest: 0.1em;

  /* ===== SPACING (8px Grid) ===== */
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;

  /* Section Padding */
  --section-padding-y: 3rem;

  /* ===== LAYOUT ===== */
  --container-sm: 640px;
  --container-md: 768px;
  --container-lg: 1024px;
  --container-xl: 1280px;
  --container-2xl: 1536px;
  --content-max-width: 65ch;

  /* Grid */
  --grid-gap: 1rem;

  /* ===== BORDERS & SHADOWS ===== */
  --radius-none: 0;
  --radius-sm: 0.125rem;
  --radius-base: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
  --radius-2xl: 1rem;
  --radius-full: 9999px;

  /* Border Widths */
  --border-width-1: 1px;
  --border-width-2: 2px;
  --border-width-4: 4px;

  /* Box Shadows */
  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --shadow-base: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --shadow-2xl: 0 50px 100px -20px rgba(0, 0, 0, 0.5);
  --shadow-gold: 0 0 20px rgba(255, 167, 38, 0.3);
  --shadow-gold-strong: 0 0 30px rgba(255, 167, 38, 0.5);
  --shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);

  /* ===== ANIMATIONS ===== */
  --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-smooth: cubic-bezier(0.25, 0.46, 0.45, 0.94);

  --duration-fast: 150ms;
  --duration-base: 300ms;
  --duration-slow: 500ms;

  --transition-all: all var(--duration-base) var(--ease-in-out);
  --transition-colors: color var(--duration-base) var(--ease-in-out),
                       background-color var(--duration-base) var(--ease-in-out),
                       border-color var(--duration-base) var(--ease-in-out);
  --transition-transform: transform var(--duration-base) var(--ease-smooth);
}

/* Responsive Typography */
@media (min-width: 768px) {
  :root {
    --font-size-4xl: 2.5rem;
    --font-size-5xl: 3.5rem;
    --font-size-6xl: 4.5rem;
    --section-padding-y: 4rem;
    --grid-gap: 1.5rem;
  }
}

@media (min-width: 1024px) {
  :root {
    --section-padding-y: 6rem;
  }
}

/* ============================================
   RESET & BASE STYLES
   ============================================ */

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

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
  overflow-x: hidden;
  width: 100%;
}

body {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
  color: var(--text-primary-on-dark);
  background-color: var(--bg-primary);
  min-height: 100vh;
  overflow-x: hidden;
  width: 100%;
  position: relative;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-secondary);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary-on-dark);
  margin-bottom: var(--space-4);
}

h1 {
  font-size: clamp(2.25rem, 5vw, var(--font-size-6xl));
  margin-bottom: var(--space-6);
}

h2 {
  font-size: clamp(1.875rem, 4vw, var(--font-size-5xl));
  margin-bottom: var(--space-5);
}

h3 {
  font-size: clamp(1.5rem, 3.5vw, var(--font-size-4xl));
}

h4 {
  font-size: var(--font-size-3xl);
}

h5 {
  font-size: var(--font-size-2xl);
}

h6 {
  font-size: var(--font-size-xl);
}

p {
  margin-bottom: var(--space-4);
  max-width: var(--content-max-width);
}

a {
  color: var(--text-link);
  text-decoration: none;
  transition: var(--transition-colors);
}

a:hover {
  color: var(--text-link-hover);
  text-decoration: underline;
}

strong, b {
  font-weight: var(--font-weight-bold);
}

em, i {
  font-style: italic;
}

small {
  font-size: var(--font-size-sm);
}

/* Lists */
ul, ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-6);
}

li {
  margin-bottom: var(--space-2);
  line-height: var(--line-height-relaxed);
}

/* ============================================
   LAYOUT UTILITIES
   ============================================ */

.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);
  }
}

.container-sm { max-width: var(--container-sm); }
.container-md { max-width: var(--container-md); }
.container-lg { max-width: var(--container-lg); }
.container-xl { max-width: var(--container-xl); }
.container-2xl { max-width: var(--container-2xl); }

/* Section */
.section {
  padding-top: var(--section-padding-y);
  padding-bottom: var(--section-padding-y);
}

.section-dark {
  background-color: var(--bg-primary);
}

.section-secondary {
  background-color: var(--bg-secondary);
}

/* Grid System */
.grid {
  display: grid;
  gap: var(--grid-gap);
}

.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (min-width: 640px) {
  .sm\\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sm\\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 768px) {
  .md\\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
  .lg\\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lg\\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* Flex Utilities */
.flex {
  display: flex;
}

.flex-col {
  flex-direction: column;
}

.items-center {
  align-items: center;
}

.justify-between {
  justify-content: space-between;
}

.justify-center {
  justify-content: center;
}

.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

/* ============================================
   COMPONENT STYLES
   ============================================ */

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  border-radius: var(--radius-lg);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition-all);
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  min-height: 48px; /* Touch target */
}

.btn-primary {
  background: linear-gradient(135deg, var(--color-primary-gold) 0%, var(--color-primary-gold-dark) 100%);
  color: var(--color-white);
  box-shadow: var(--shadow-md), var(--shadow-gold);
}

.btn-primary:hover {
  background: linear-gradient(135deg, var(--color-primary-gold-light) 0%, var(--color-primary-gold) 100%);
  box-shadow: var(--shadow-lg), var(--shadow-gold-strong);
  transform: translateY(-2px);
  text-decoration: none;
}

.btn-primary:active {
  transform: translateY(0);
}

.btn-secondary {
  background: transparent;
  border: 2px solid var(--color-primary-gold);
  color: var(--color-primary-gold);
}

.btn-secondary:hover {
  background: var(--color-primary-gold);
  color: var(--color-white);
  text-decoration: none;
}

.btn-large {
  padding: var(--space-4) var(--space-8);
  font-size: var(--font-size-lg);
}

.btn-small {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm);
  min-height: 36px;
}

/* Cards */
.card {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-base);
  border: 1px solid rgba(255, 255, 255, 0.05);
  transition: var(--transition-all);
}

.card:hover {
  background: var(--bg-card-hover);
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

.card-header {
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.card-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary-on-dark);
  margin: 0;
}

/* Light Background Card Fix - For cards with light backgrounds (#f8f9fa, white, etc) */
.card[style*="background: #f8f9fa"],
.card[style*="background:#f8f9fa"],
.card[style*="background: rgb(248, 249, 250)"],
.card[style*="background:rgb(248, 249, 250)"],
.card.card-light {
  color: var(--text-primary-on-light) !important;
}

.card[style*="background: #f8f9fa"] p,
.card[style*="background:#f8f9fa"] p,
.card[style*="background: rgb(248, 249, 250)"] p,
.card[style*="background:rgb(248, 249, 250)"] p,
.card.card-light p {
  color: var(--text-primary-on-light);
}

.card[style*="background: #f8f9fa"] strong,
.card[style*="background:#f8f9fa"] strong,
.card[style*="background: rgb(248, 249, 250)"] strong,
.card[style*="background:rgb(248, 249, 250)"] strong,
.card.card-light strong {
  color: var(--color-gray-900);
}

.card[style*="background: #f8f9fa"] a,
.card[style*="background:#f8f9fa"] a,
.card[style*="background: rgb(248, 249, 250)"] a,
.card[style*="background:rgb(248, 249, 250)"] a,
.card.card-light a {
  color: var(--color-accent-blue);
  font-weight: var(--font-weight-semibold);
}

.card[style*="background: #f8f9fa"] a:hover,
.card[style*="background:#f8f9fa"] a:hover,
.card[style*="background: rgb(248, 249, 250)"] a:hover,
.card[style*="background:rgb(248, 249, 250)"] a:hover,
.card.card-light a:hover {
  color: var(--color-primary-blue);
  text-decoration: underline;
}

/* Tables */
.table-container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-base);
}

table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-card);
}

thead {
  background: var(--bg-secondary);
}

th {
  padding: var(--space-4);
  text-align: left;
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary-gold);
  border-bottom: 2px solid var(--color-primary-gold);
}

td {
  padding: var(--space-4);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

tr:last-child td {
  border-bottom: none;
}

tr:hover {
  background: var(--bg-card-hover);
}

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

.badge-success {
  background: var(--color-success);
  color: var(--color-white);
}

.badge-warning {
  background: var(--color-warning);
  color: var(--color-white);
}

.badge-error {
  background: var(--color-error);
  color: var(--color-white);
}

.badge-gold {
  background: var(--color-primary-gold);
  color: var(--color-gray-900);
}

/* ============================================
   VIETNAM-SPECIFIC COMPONENTS
   ============================================ */

/* Legal Warning Banner */
.legal-warning {
  background: linear-gradient(135deg, var(--color-accent-red) 0%, #c62828 100%);
  color: var(--color-white);
  padding: var(--space-4) var(--space-6);
  border-left: 4px solid #ffeb3b;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-md);
}

.legal-warning strong {
  color: #ffeb3b;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

/* Payment Method Badges */
.payment-badge {
  background: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-lg);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  box-shadow: var(--shadow-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary-on-light);
  transition: var(--transition-transform);
}

.payment-badge:hover {
  transform: scale(1.05);
}

.payment-badge img {
  height: 24px;
  width: auto;
}

/* Trust Indicators */
.trust-badge {
  background: linear-gradient(135deg, var(--color-success) 0%, #2e7d32 100%);
  color: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  box-shadow: var(--shadow-sm);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

/* Rating Display */
.rating-card {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%);
  border: 2px solid var(--color-primary-gold);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  text-align: center;
  box-shadow: var(--shadow-lg), var(--shadow-gold);
}

.rating-score {
  font-size: var(--font-size-6xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-primary-gold);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.rating-label {
  font-size: var(--font-size-lg);
  color: var(--text-secondary-on-dark);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

/* Pros/Cons Lists */
.pros-cons-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .pros-cons-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.pros-list li::before {
  content: '✅ ';
  margin-right: var(--space-2);
}

.cons-list li::before {
  content: '❌ ';
  margin-right: var(--space-2);
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

/* Spacing */
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }
.my-6 { margin-top: var(--space-6); margin-bottom: var(--space-6); }
.my-8 { margin-top: var(--space-8); margin-bottom: var(--space-8); }

.p-4 { padding: var(--space-4); }
.p-6 { padding: var(--space-6); }
.p-8 { padding: var(--space-8); }
.px-4 { padding-left: var(--space-4); padding-right: var(--space-4); }
.px-6 { padding-left: var(--space-6); padding-right: var(--space-6); }
.py-4 { padding-top: var(--space-4); padding-bottom: var(--space-4); }
.py-6 { padding-top: var(--space-6); padding-bottom: var(--space-6); }

/* Text Alignment */
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }

/* Text Colors */
.text-primary { color: var(--text-primary-on-dark); }
.text-secondary { color: var(--text-secondary-on-dark); }
.text-muted { color: var(--text-muted-on-dark); }
.text-gold { color: var(--color-primary-gold); }
.text-success { color: var(--color-success); }
.text-error { color: var(--color-error); }

/* Font Weights */
.font-normal { font-weight: var(--font-weight-normal); }
.font-medium { font-weight: var(--font-weight-medium); }
.font-semibold { font-weight: var(--font-weight-semibold); }
.font-bold { font-weight: var(--font-weight-bold); }

/* Visibility */
.hidden { display: none; }

@media (max-width: 639px) {
  .hidden-mobile { display: none; }
}

@media (min-width: 640px) {
  .hidden-desktop { display: none; }
}

/* ============================================
   ACCESSIBILITY
   ============================================ */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

*:focus-visible {
  outline: 2px solid var(--color-primary-gold);
  outline-offset: 2px;
}

/* ============================================
   RESPONSIVE IMAGES
   ============================================ */

img {
  max-width: 100%;
  height: auto;
  display: block;
}

picture {
  display: block;
}

/* ============================================
   PRINT STYLES
   ============================================ */

@media print {
  body {
    background: white;
    color: black;
  }

  .no-print {
    display: none !important;
  }
}

/* ============================================
   SITE HEADER & NAVIGATION
   ============================================ */

/* Top Legal Warning Bar */
.top-bar {
  background: var(--color-accent-red);
  padding: var(--space-2) 0;
  font-size: var(--font-size-sm);
  border-bottom: 2px solid #ffeb3b;
}

.legal-warning-compact {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  text-align: center;
  color: var(--color-white);
  font-weight: var(--font-weight-medium);
}

.legal-warning-compact strong {
  color: #ffeb3b;
}

/* Main Site Header */
.site-header {
  background: var(--bg-primary);
  border-bottom: 1px solid rgba(255, 167, 38, 0.2);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow-md);
}

/* Main Navigation */
.main-nav {
  background: var(--bg-secondary);
  padding: var(--space-4) 0;
}

.main-nav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

/* Logo */
.logo {
  flex-shrink: 0;
}

.logo img {
  height: 40px;
  width: auto;
}

/* Desktop Navigation Links */
.nav-links {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--space-2);
}

.nav-links li {
  margin: 0;
}

.nav-links a {
  display: block;
  padding: var(--space-2) var(--space-3);
  color: var(--text-primary-on-dark);
  text-decoration: none;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-md);
  transition: var(--transition-all);
  white-space: nowrap;
}

.nav-links a:hover {
  background: rgba(255, 167, 38, 0.1);
  color: var(--color-primary-gold);
  text-decoration: none;
}

.nav-links a.active {
  background: var(--color-primary-gold);
  color: var(--color-gray-900);
  font-weight: var(--font-weight-semibold);
}

/* Show desktop nav on larger screens */
@media (min-width: 1024px) {
  .nav-links {
    display: flex;
  }
}

/* Mobile Menu Toggle Button */
.mobile-menu-toggle {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  width: 40px;
  height: 40px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  border-radius: var(--radius-md);
  transition: var(--transition-all);
}

.mobile-menu-toggle:hover {
  background: rgba(255, 167, 38, 0.1);
}

.mobile-menu-toggle span {
  width: 100%;
  height: 3px;
  background: var(--color-primary-gold);
  border-radius: var(--radius-full);
  transition: var(--transition-all);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

/* Hide mobile toggle on desktop */
@media (min-width: 1024px) {
  .mobile-menu-toggle {
    display: none;
  }
}

/* Mobile Menu */
.mobile-menu {
  background: var(--bg-secondary);
  border-top: 1px solid rgba(255, 167, 38, 0.2);
  padding: var(--space-4);
  max-height: calc(100vh - 150px);
  overflow-y: auto;
}

.mobile-menu[hidden] {
  display: none;
}

.mobile-nav-links {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mobile-nav-links li {
  margin: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.mobile-nav-links li:last-child {
  border-bottom: none;
}

.mobile-nav-links a {
  display: block;
  padding: var(--space-3) var(--space-2);
  color: var(--text-primary-on-dark);
  text-decoration: none;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  transition: var(--transition-colors);
}

.mobile-nav-links a:hover {
  color: var(--color-primary-gold);
  padding-left: var(--space-4);
  text-decoration: none;
}

.mobile-nav-links a.active {
  color: var(--color-primary-gold);
  font-weight: var(--font-weight-semibold);
}

.mobile-menu .btn-block {
  width: 100%;
  margin-top: var(--space-4);
}

/* Hide mobile menu on desktop */
@media (min-width: 1024px) {
  .mobile-menu {
    display: none !important;
  }
}

/* Quick Links Bar (Payment Icons & Trust Indicators) */
.quick-links-bar {
  background: var(--bg-primary);
  border-top: 1px solid rgba(255, 167, 38, 0.1);
  padding: var(--space-3) 0;
}

.quick-links-bar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.payment-icons {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.payment-icons img {
  height: 32px;
  width: auto;
  opacity: 0.8;
  transition: var(--transition-all);
}

.payment-icons img:hover {
  opacity: 1;
  transform: scale(1.1);
}

.trust-indicators {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--font-size-xs);
}

.trust-indicators .badge {
  background: rgba(255, 167, 38, 0.15);
  color: var(--color-primary-gold);
  border: 1px solid rgba(255, 167, 38, 0.3);
}

/* Responsive visibility helpers */
.desktop-nav {
  display: none;
}

@media (min-width: 1024px) {
  .desktop-nav {
    display: flex;
  }
}

/* ============================================
   SITE FOOTER
   ============================================ */

.site-footer {
  background: var(--bg-secondary);
  border-top: 2px solid var(--color-primary-gold);
  padding: var(--space-8) 0 var(--space-6);
  margin-top: var(--space-12);
}

.footer-content {
  text-align: center;
  color: var(--text-secondary-on-dark);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
}

.footer-content p {
  margin-bottom: var(--space-3);
  max-width: none;
}

.footer-content strong {
  color: var(--text-primary-on-dark);
}

.footer-license {
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-license img {
  display: inline-block;
  vertical-align: middle;
  margin-right: var(--space-2);
}

.footer-license a {
  color: var(--text-link);
}

.footer-license a:hover {
  color: var(--text-link-hover);
}

/* ============================================
   HERO SECTION
   ============================================ */

.hero {
  background: linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
  padding: var(--space-12) 0 var(--space-8);
  text-align: center;
}

.hero h1 {
  color: var(--color-primary-gold);
  margin-bottom: var(--space-6);
}

.hero .lead {
  font-size: var(--font-size-lg);
  color: var(--text-secondary-on-dark);
  max-width: 800px;
  margin: 0 auto var(--space-8);
}

.cta-buttons {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

.btn-outline {
  background: transparent;
  border: 2px solid var(--text-secondary-on-dark);
  color: var(--text-primary-on-dark);
}

.btn-outline:hover {
  border-color: var(--color-primary-gold);
  color: var(--color-primary-gold);
  text-decoration: none;
}

/* ============================================
   MAIN CONTENT
   ============================================ */

.main-content {
  min-height: 60vh;
}

.highlight {
  border-left: 4px solid var(--color-primary-gold);
  padding-left: var(--space-4);
  background: rgba(255, 167, 38, 0.05);
}

/* ============================================
   TABLE IMPROVEMENTS
   ============================================ */

.table {
  width: 100%;
  margin-bottom: var(--space-6);
}

.table th {
  text-align: left;
  white-space: nowrap;
}

.table td {
  vertical-align: top;
}

.table tr.highlight {
  background: rgba(255, 167, 38, 0.1);
  border-left: 4px solid var(--color-primary-gold);
  font-weight: var(--font-weight-semibold);
}

/* Responsive table on mobile */
@media (max-width: 767px) {
  .table-container {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  .table {
    min-width: 600px;
  }
}

/* ============================================
   MISSING CONTENT CLASSES
   ============================================ */

/* Header Spacer */
.header-spacer {
  height: var(--space-8);
}

/* Hero Content */
.hero-content {
  max-width: 900px;
  margin: 0 auto;
}

.hero-subtitle {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  color: var(--text-secondary-on-dark);
  margin-bottom: var(--space-6);
}

.hero-cta {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-8);
}

/* Section Variants */
.section-alt {
  background: var(--bg-secondary);
}

/* CTA Box */
.cta-box {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%);
  border: 2px solid var(--color-primary-gold);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
  margin: var(--space-8) 0;
  box-shadow: var(--shadow-lg), var(--shadow-gold);
}

.cta-box h2, .cta-box h3 {
  color: var(--color-primary-gold);
  margin-bottom: var(--space-4);
}

.cta-box p {
  color: var(--text-secondary-on-dark);
  margin-bottom: var(--space-6);
  max-width: none;
}

/* FAQ List */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.faq-item {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  border-left: 4px solid var(--color-primary-gold);
  transition: var(--transition-all);
}

.faq-item:hover {
  background: var(--bg-card-hover);
  transform: translateX(4px);
}

.faq-item h3 {
  color: var(--color-primary-gold);
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-3);
}

.faq-item p {
  color: var(--text-primary-on-dark);
  line-height: var(--line-height-relaxed);
}

.faq-item ul {
  margin-top: var(--space-3);
}

/* Footer Sections */
.footer-main {
  display: grid;
  gap: var(--space-8);
  margin-bottom: var(--space-6);
}

@media (min-width: 768px) {
  .footer-main {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .footer-main {
    grid-template-columns: repeat(4, 1fr);
  }
}

.footer-section {
  color: var(--text-secondary-on-dark);
}

.footer-section h3 {
  color: var(--color-primary-gold);
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-4);
  border-bottom: 2px solid rgba(255, 167, 38, 0.3);
  padding-bottom: var(--space-2);
}

.footer-section ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-section ul li {
  margin-bottom: var(--space-2);
}

.footer-section a {
  color: var(--text-secondary-on-dark);
  text-decoration: none;
  transition: var(--transition-colors);
}

.footer-section a:hover {
  color: var(--color-primary-gold);
  padding-left: var(--space-2);
}

/* Review Quick Section */
#review-quick .table {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

#review-quick .table th {
  background: var(--bg-secondary);
  color: var(--color-primary-gold);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  font-size: var(--font-size-sm);
}

/* Steps/Process Lists */
.steps-list {
  counter-reset: step-counter;
  list-style: none;
  padding: 0;
}

.steps-list li {
  counter-increment: step-counter;
  position: relative;
  padding-left: var(--space-12);
  margin-bottom: var(--space-6);
}

.steps-list li::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 0;
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--color-primary-gold) 0%, var(--color-primary-gold-dark) 100%);
  color: var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-lg);
  box-shadow: var(--shadow-md), var(--shadow-gold);
}

/* Image Wrappers */
.image-wrapper {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  margin: var(--space-6) 0;
}

.image-wrapper img {
  width: 100%;
  height: auto;
  display: block;
}

/* Blockquotes */
blockquote {
  border-left: 4px solid var(--color-primary-gold);
  padding-left: var(--space-4);
  margin: var(--space-6) 0;
  font-style: italic;
  color: var(--text-secondary-on-dark);
  background: rgba(255, 167, 38, 0.05);
  padding: var(--space-4);
  border-radius: var(--radius-md);
}

blockquote p {
  margin-bottom: var(--space-2);
}

blockquote cite {
  display: block;
  text-align: right;
  font-size: var(--font-size-sm);
  color: var(--color-primary-gold);
  font-style: normal;
  margin-top: var(--space-2);
}

/* Pre/Code blocks */
pre {
  background: var(--bg-input);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--text-primary-on-dark);
  margin: var(--space-4) 0;
}

code {
  background: rgba(255, 167, 38, 0.1);
  color: var(--color-primary-gold);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 0.9em;
}

pre code {
  background: none;
  padding: 0;
  color: inherit;
}

/* Comparison Grids */
.comparison-grid {
  display: grid;
  gap: var(--space-6);
  margin: var(--space-8) 0;
}

@media (min-width: 768px) {
  .comparison-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .comparison-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.comparison-card {
  background: var(--bg-card);
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  text-align: center;
  transition: var(--transition-all);
}

.comparison-card:hover {
  border-color: var(--color-primary-gold);
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg), var(--shadow-gold);
}

.comparison-card h3 {
  color: var(--color-primary-gold);
  margin-bottom: var(--space-4);
}

.comparison-card .rating {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-primary-gold);
  margin: var(--space-4) 0;
}

/* Alert Boxes */
.alert {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin: var(--space-4) 0;
  border-left: 4px solid;
}

.alert-info {
  background: rgba(25, 118, 210, 0.1);
  border-color: var(--color-info);
  color: var(--text-primary-on-dark);
}

.alert-success {
  background: rgba(56, 142, 60, 0.1);
  border-color: var(--color-success);
  color: var(--text-primary-on-dark);
}

.alert-warning {
  background: rgba(245, 124, 0, 0.1);
  border-color: var(--color-warning);
  color: var(--text-primary-on-dark);
}

.alert-error {
  background: rgba(211, 47, 47, 0.1);
  border-color: var(--color-error);
  color: var(--text-primary-on-dark);
}

/* ============================================
   MISSING CSS CLASSES - FINAL FIX
   ============================================ */

/* Button Variants */
.btn-lg {
  padding: var(--space-5) var(--space-8);
  font-size: var(--font-size-lg);
  min-height: 60px;
}

/* CTA Groups and Sections */
.cta-section {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%);
  border: 2px solid var(--color-primary-gold);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
  margin: var(--space-8) 0;
}

.cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  align-items: center;
  margin: var(--space-6) 0;
}

/* Error Page Styles */
.error-container {
  min-height: 60vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-8);
  text-align: center;
}

.error-code {
  font-size: 120px;
  font-weight: 900;
  color: var(--color-primary-gold);
  text-shadow: 0 4px 20px rgba(255, 167, 38, 0.4);
  line-height: 1;
  margin-bottom: var(--space-4);
}

.error-message {
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--text-primary-on-dark);
  margin-bottom: var(--space-4);
}

.error-description {
  font-size: var(--font-size-lg);
  color: var(--text-secondary-on-dark);
  max-width: 600px;
  margin: 0 auto var(--space-8) auto;
  line-height: var(--line-height-relaxed);
}

.error-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
}

/* FAQ Grid */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .faq-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Grid Layouts */
.grid-2-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .grid-2-col {
    grid-template-columns: repeat(2, 1fr);
  }
}

.grid-3-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .grid-3-col {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .grid-3-col {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Hero Variants */
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  align-items: center;
  margin-top: var(--space-6);
}

.hero-alt {
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-primary) 100%);
  border-bottom: 2px solid rgba(255, 167, 38, 0.2);
}

/* Link Cards and Grids */
.link-card {
  display: block;
  background: var(--bg-card);
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-decoration: none;
  transition: var(--transition-all);
  text-align: center;
}

.link-card:hover {
  border-color: var(--color-primary-gold);
  transform: translateY(-4px);
  box-shadow: var(--shadow-gold);
  background: linear-gradient(135deg, var(--bg-card) 0%, rgba(255, 167, 38, 0.05) 100%);
}

.link-grid,
.links-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin: var(--space-6) 0;
}

@media (min-width: 768px) {
  .link-grid,
  .links-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .link-grid,
  .links-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.popular-links {
  background: var(--bg-secondary);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin: var(--space-6) 0;
}

/* Rating Styles */
.rating-overall {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-primary-gold);
  margin: var(--space-4) 0;
}

.rating-stars {
  display: flex;
  gap: var(--space-1);
  color: var(--color-primary-gold);
  font-size: var(--font-size-xl);
}

/* Table Responsive Wrapper */
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  margin: var(--space-6) 0;
}

.table-responsive::-webkit-scrollbar {
  height: 8px;
}

.table-responsive::-webkit-scrollbar-track {
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
}

.table-responsive::-webkit-scrollbar-thumb {
  background: var(--color-primary-gold);
  border-radius: var(--radius-sm);
}

.table-responsive::-webkit-scrollbar-thumb:hover {
  background: var(--color-gold-light);
}

/* Text Highlighting */
.text-highlight {
  background: linear-gradient(135deg, rgba(255, 167, 38, 0.2) 0%, rgba(255, 167, 38, 0.1) 100%);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  color: var(--color-primary-gold);
  font-weight: 600;
  border: 1px solid rgba(255, 167, 38, 0.3);
}

/* Tips Grid */
.tips-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin: var(--space-6) 0;
}

@media (min-width: 768px) {
  .tips-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .tips-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================
   END OF MISSING CSS CLASSES
   ============================================ */

/* ============================================
   PAGE-SPECIFIC HERO BACKGROUNDS
   ============================================ */

/* Hero背景图片基础样式 */
.hero {
  position: relative;
  background-size: cover;
  background-position: center;
  background-attachment: fixed; /* 视差效果 */
}

/* 深色遮罩层确保文字可读 */
.hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(26, 31, 53, 0.75) 0%, rgba(44, 62, 80, 0.65) 100%);
  z-index: 1;
}

.hero .container {
  position: relative;
  z-index: 2;
}

/* 页面特定Hero背景 - 使用data属性选择器 */

/* 1. 首页 */
body[data-page="home"] .hero,
.page-home .hero {
  background-image: url('/images/heroes/01-home.webp');
}

/* 2. 注册页 */
body[data-page="register"] .hero,
.page-register .hero {
  background-image: url('/images/heroes/02-register.webp');
}

/* 3. 充值页 */
body[data-page="deposit"] .hero,
.page-deposit .hero {
  background-image: url('/images/heroes/03-deposit.webp');
}

/* 4. 提款页 */
body[data-page="withdraw"] .hero,
.page-withdraw .hero {
  background-image: url('/images/heroes/04-withdraw.webp');
}

/* 5. 支付页 */
body[data-page="payment"] .hero,
.page-payment .hero {
  background-image: url('/images/heroes/05-payment.webp');
}

/* 6. 足球博彩 */
body[data-page="football"] .hero,
.page-football .hero {
  background-image: url('/images/heroes/06-football.webp');
}

/* 7. 移动应用 */
body[data-page="app"] .hero,
.page-app .hero {
  background-image: url('/images/heroes/07-app.webp');
}

/* 8. 促销活动 */
body[data-page="promo"] .hero,
.page-promo .hero {
  background-image: url('/images/heroes/08-promo.webp');
}

/* 9. 安全合法 */
body[data-page="safety"] .hero,
.page-safety .hero {
  background-image: url('/images/heroes/09-safety.webp');
}

/* 10. 客户服务 */
body[data-page="support"] .hero,
.page-support .hero {
  background-image: url('/images/heroes/10-support.webp');
}

/* 11. FAQ */
body[data-page="faq"] .hero,
.page-faq .hero {
  background-image: url('/images/heroes/11-faq.webp');
}

/* 12. 对比页 */
body[data-page="compare"] .hero,
.page-compare .hero {
  background-image: url('/images/heroes/12-compare.webp');
}

/* JPG fallback for browsers that don't support WebP */
@supports not (background-image: url('/images/heroes/01-home.webp')) {
  body[data-page="home"] .hero, .page-home .hero { background-image: url('/images/heroes/01-home.jpg'); }
  body[data-page="register"] .hero, .page-register .hero { background-image: url('/images/heroes/02-register.jpg'); }
  body[data-page="deposit"] .hero, .page-deposit .hero { background-image: url('/images/heroes/03-deposit.jpg'); }
  body[data-page="withdraw"] .hero, .page-withdraw .hero { background-image: url('/images/heroes/04-withdraw.jpg'); }
  body[data-page="payment"] .hero, .page-payment .hero { background-image: url('/images/heroes/05-payment.jpg'); }
  body[data-page="football"] .hero, .page-football .hero { background-image: url('/images/heroes/06-football.jpg'); }
  body[data-page="app"] .hero, .page-app .hero { background-image: url('/images/heroes/07-app.jpg'); }
  body[data-page="promo"] .hero, .page-promo .hero { background-image: url('/images/heroes/08-promo.jpg'); }
  body[data-page="safety"] .hero, .page-safety .hero { background-image: url('/images/heroes/09-safety.jpg'); }
  body[data-page="support"] .hero, .page-support .hero { background-image: url('/images/heroes/10-support.jpg'); }
  body[data-page="faq"] .hero, .page-faq .hero { background-image: url('/images/heroes/11-faq.jpg'); }
  body[data-page="compare"] .hero, .page-compare .hero { background-image: url('/images/heroes/12-compare.jpg'); }
}

/* 移动端优化 */
@media (max-width: 768px) {
  .hero {
    background-attachment: scroll; /* 移动端禁用parallax */
  }
}

/* ============================================
   END OF HERO BACKGROUNDS
   ============================================ */

/* ============================================
   MOBILE RESPONSIVE FIXES
   移动端响应式修复 - 防止水平滚动
   ============================================ */

/* 移动端专用修复 (max-width: 767px) */
@media (max-width: 767px) {

  /* 确保所有元素不超出viewport */
  * {
    max-width: 100%;
  }

  /* 允许特定元素超出的情况 */
  html,
  body,
  .container,
  .section,
  .hero {
    max-width: none;
  }

  /* 确保body和main不产生水平滚动 */
  body {
    overflow-x: hidden;
    width: 100vw;
    max-width: 100%;
  }

  main {
    overflow-x: hidden;
    width: 100%;
  }

  /* 容器在小屏幕上减少padding */
  .container {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
    width: 100%;
    max-width: 100%;
  }

  /* 确保图片不超出 */
  img,
  picture,
  video,
  canvas,
  svg {
    max-width: 100%;
    height: auto;
  }

  /* 表格响应式处理 */
  .table-container {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  table {
    min-width: 100%;
    display: block;
    overflow-x: auto;
  }

  /* Pre和Code块防止溢出 */
  pre,
  code {
    max-width: 100%;
    overflow-x: auto;
    word-wrap: break-word;
    white-space: pre-wrap;
  }

  /* 长文本自动换行 */
  h1, h2, h3, h4, h5, h6,
  p, li, td, th {
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
  }

  /* 卡片和内容块 */
  .card,
  .content-block,
  .info-box {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  /* Hero section在移动端的调整 */
  .hero {
    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
  }

  .hero-content {
    width: 100%;
    max-width: 100%;
    padding-left: var(--space-4);
    padding-right: var(--space-4);
  }

  /* 按钮组在移动端堆叠 */
  .hero-cta,
  .button-group {
    flex-direction: column;
    width: 100%;
  }

  .hero-cta .btn,
  .button-group .btn {
    width: 100%;
    max-width: 100%;
  }

  /* Section确保不溢出 */
  .section {
    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
  }

  /* 列表项不超出 */
  ul, ol {
    padding-left: var(--space-5);
    width: 100%;
  }

  /* 引用块 */
  blockquote {
    width: 100%;
    max-width: 100%;
    padding-left: var(--space-4);
    padding-right: var(--space-4);
  }

  /* 导航确保不溢出 */
  .nav-links,
  .mobile-menu {
    width: 100%;
    max-width: 100%;
  }

  /* iframe响应式 */
  iframe {
    max-width: 100%;
    width: 100%;
  }

  /* 评分卡片在移动端堆叠 */
  .rating-grid,
  .comparison-grid {
    grid-template-columns: 1fr;
    width: 100%;
  }
}

/* 极小屏幕额外修复 (<375px) */
@media (max-width: 374px) {
  .container {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
  }

  /* 减小字体避免溢出 */
  h1 {
    font-size: 1.75rem;
  }

  h2 {
    font-size: 1.5rem;
  }

  /* 按钮在极小屏幕上调整 */
  .btn {
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-sm);
  }
}

/* ============================================
   DESKTOP OPTIMIZATIONS
   PC端优化 - 确保内容居中
   ============================================ */

/* 平板及以上设备 (768px+) */
@media (min-width: 768px) {
  /* 确保容器正确居中 */
  .container {
    max-width: var(--container-xl);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }

  /* Section增加垂直间距 */
  .section {
    padding-top: var(--space-16);
    padding-bottom: var(--space-16);
  }
}

/* 大屏桌面 (1280px+) */
@media (min-width: 1280px) {
  /* 在超宽屏上增加左右padding，避免内容过于靠近边缘 */
  .container {
    padding-left: var(--space-12);
    padding-right: var(--space-12);
  }

  /* 增加section间距 */
  .section {
    padding-top: var(--space-20);
    padding-bottom: var(--space-20);
  }
}

/* 超宽屏 (1536px+) */
@media (min-width: 1536px) {
  /* 限制最大宽度并居中，避免内容过于分散 */
  .container {
    max-width: var(--container-2xl);
  }
}
