/**
 * PopRace.org Design System
 * Week 2 - Day 6: October 6, 2025
 * 
 * This file establishes our design system foundations:
 * - Color system with semantic naming
 * - Spacing scale
 * - Typography system
 * - Component patterns
 * - Utility classes
 */

/* ============================================
   BASE DESIGN TOKENS
   ============================================ */

:root {
  /* === EXTENDED COLOR PALETTE === */
  
  /* Semantic Colors */
  --color-background: var(--color-surface);
  --color-background-alt: var(--color-surface-secondary);
  --color-foreground: var(--color-text);
  --color-foreground-muted: var(--color-text-secondary);
  
  /* Interactive States */
  --color-hover: var(--color-surface-tertiary);
  --color-active: var(--color-primary-light);
  --color-focus-ring: var(--color-primary);
  --color-disabled: var(--color-text-tertiary);
  --color-disabled-bg: var(--color-surface-tertiary);
  
  /* Card & Surface */
  --color-card-bg: var(--color-surface);
  --color-card-border: var(--color-border);
  --color-card-shadow: rgba(0, 0, 0, 0.08);
  
  /* === ENHANCED SPACING SCALE === */
  --space-0: 0;
  --space-1: 0.25rem;   /* 4px */
  --space-2: 0.5rem;    /* 8px */
  --space-3: 0.75rem;   /* 12px */
  --space-4: 1rem;      /* 16px */
  --space-5: 1.25rem;   /* 20px */
  --space-6: 1.5rem;    /* 24px */
  --space-8: 2rem;      /* 32px */
  --space-10: 2.5rem;   /* 40px */
  --space-12: 3rem;     /* 48px */
  --space-16: 4rem;     /* 64px */
  --space-20: 5rem;     /* 80px */
  --space-24: 6rem;     /* 96px */
  
  /* === TYPOGRAPHY SCALE === */
  --text-xs: 0.75rem;      /* 12px */
  --text-sm: 0.875rem;     /* 14px */
  --text-base: 1rem;       /* 16px */
  --text-lg: 1.125rem;     /* 18px */
  --text-xl: 1.25rem;      /* 20px */
  --text-2xl: 1.5rem;      /* 24px */
  --text-3xl: 1.875rem;    /* 30px */
  --text-4xl: 2.25rem;     /* 36px */
  --text-5xl: 3rem;        /* 48px */
  --text-6xl: 3.75rem;     /* 60px */
  
  /* === COMPONENT-SPECIFIC === */
  
  /* Buttons */
  --button-height-sm: 2rem;      /* 32px */
  --button-height-md: 2.5rem;    /* 40px */
  --button-height-lg: 3rem;      /* 48px */
  --button-padding-x-sm: 0.75rem;
  --button-padding-x-md: 1rem;
  --button-padding-x-lg: 1.5rem;
  
  /* Input Fields */
  --input-height-sm: 2rem;
  --input-height-md: 2.5rem;
  --input-height-lg: 3rem;
  --input-padding-x: 0.75rem;
  --input-border-width: 1px;
  
  /* Cards */
  --card-padding: var(--space-6);
  --card-radius: var(--radius-lg);
  --card-border-width: 1px;
  
  /* Model Cards (specific to PopRace) */
  --model-card-image-height: 12rem;  /* 192px */
  --model-card-padding: var(--space-4);
  --model-card-gap: var(--space-3);
  
  /* === ANIMATIONS === */
  --animation-duration-fast: 150ms;
  --animation-duration-normal: 250ms;
  --animation-duration-slow: 350ms;
  
  --animation-easing: cubic-bezier(0.4, 0, 0.2, 1);
  --animation-easing-in: cubic-bezier(0.4, 0, 1, 1);
  --animation-easing-out: cubic-bezier(0, 0, 0.2, 1);
}

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

/* === SPACING UTILITIES === */
.p-0 { padding: var(--space-0); }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-5 { padding: var(--space-5); }
.p-6 { padding: var(--space-6); }
.p-8 { padding: var(--space-8); }

.px-2 { padding-left: var(--space-2); padding-right: var(--space-2); }
.px-3 { padding-left: var(--space-3); padding-right: var(--space-3); }
.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-2 { padding-top: var(--space-2); padding-bottom: var(--space-2); }
.py-3 { padding-top: var(--space-3); padding-bottom: var(--space-3); }
.py-4 { padding-top: var(--space-4); padding-bottom: var(--space-4); }
.py-6 { padding-top: var(--space-6); padding-bottom: var(--space-6); }

.m-0 { margin: var(--space-0); }
.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-4 { margin: var(--space-4); }

.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }

.mb-2 { margin-bottom: var(--space-2); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }

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

/* === TEXT UTILITIES === */
.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }
.text-4xl { font-size: var(--text-4xl); }

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

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

/* Color Utilities */
.text-primary { color: var(--color-text); }
.text-secondary { color: var(--color-text-secondary); }
.text-tertiary { color: var(--color-text-tertiary); }
.text-accent { color: var(--color-primary); }
.text-error { color: var(--color-error); }
.text-success { color: var(--color-success); }

/* Font family utilities */
.font-mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Roboto Mono", "Helvetica Neue", monospace;
}

.font-inter {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Background Utilities */
.bg-surface { background-color: var(--color-surface); }
.bg-surface-secondary { background-color: var(--color-surface-secondary); }
.bg-surface-tertiary { background-color: var(--color-surface-tertiary); }
.bg-primary { background-color: var(--color-primary); }

/* === COMPONENT PATTERNS === */

/* Card Pattern */
.card {
  background-color: var(--color-card-bg);
  border: var(--card-border-width) solid var(--color-card-border);
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--animation-duration-normal) var(--animation-easing);
}

.card:hover {
  box-shadow: var(--shadow-md);
}

.card-compact {
  padding: var(--space-4);
}

.card-spacious {
  padding: var(--space-8);
}

/* Button Pattern */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: var(--button-height-md);
  padding: 0 var(--button-padding-x-md);
  font-size: var(--text-base);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  transition: all var(--animation-duration-normal) var(--animation-easing);
  text-decoration: none;
  white-space: nowrap;
}

.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-text-inverse);
}

.btn-primary:hover {
  background-color: var(--color-primary-hover);
  box-shadow: var(--shadow-md);
}

.btn-secondary {
  background-color: var(--color-surface-secondary);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}

.btn-secondary:hover {
  background-color: var(--color-surface-tertiary);
}

.btn-ghost {
  background-color: transparent;
  color: var(--color-text);
}

.btn-ghost:hover {
  background-color: var(--color-hover);
}

.btn-sm {
  height: var(--button-height-sm);
  padding: 0 var(--button-padding-x-sm);
  font-size: var(--text-sm);
}

.btn-lg {
  height: var(--button-height-lg);
  padding: 0 var(--button-padding-x-lg);
  font-size: var(--text-lg);
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Input Pattern */
.input {
  width: 100%;
  height: var(--input-height-md);
  padding: 0 var(--input-padding-x);
  font-size: var(--text-base);
  color: var(--color-text);
  background-color: var(--color-surface);
  border: var(--input-border-width) solid var(--color-border);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--animation-duration-fast) var(--animation-easing);
}

.input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.input::placeholder {
  color: var(--color-text-tertiary);
}

.input-sm {
  height: var(--input-height-sm);
  font-size: var(--text-sm);
}

.input-lg {
  height: var(--input-height-lg);
  font-size: var(--text-lg);
}

/* Badge Pattern */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.badge-primary {
  background-color: var(--color-chip-bg);
  color: var(--color-chip-text);
}

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

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

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

/* Chip Pattern (for filters) */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  height: var(--chip-height);
  padding: 0 var(--chip-padding-x);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  background-color: var(--color-chip-bg);
  color: var(--color-chip-text);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background-color var(--animation-duration-fast) var(--animation-easing);
}

.chip:hover {
  background-color: var(--color-chip-hover);
}

.chip-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  margin-left: var(--space-1);
  border-radius: var(--radius-full);
  background-color: transparent;
  transition: background-color var(--animation-duration-fast) var(--animation-easing);
}

.chip-remove:hover {
  background-color: rgba(0, 0, 0, 0.1);
}

/* 
 * Note: Model Card styling is handled by model-cards-navy.css
 * The .model-card-enhanced class is the primary card component
 * These generic .model-card patterns are kept as base fallback only
 */

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

.container {
  width: 100%;
  max-width: var(--max-content-width);
  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);
  }
}

@media (min-width: 1024px) {
  .container {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }
}

/* Grid System - Base classes defined in utilities.css */
/* Responsive grid variants only */
@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

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

/* Flex Utilities - Base classes defined in utilities.css */
/* Additional semantic flex utilities */

/* === SHADOW UTILITIES === */
.shadow-none { box-shadow: none; }
.shadow-xs { box-shadow: var(--shadow-xs); }
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }

/* === BORDER UTILITIES === */
.border { border: 1px solid var(--color-border); }
.border-t { border-top: 1px solid var(--color-border); }
.border-b { border-bottom: 1px solid var(--color-border); }
.border-l { border-left: 1px solid var(--color-border); }
.border-r { border-right: 1px solid var(--color-border); }

.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius-md); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: var(--radius-full); }

/* === ANIMATION UTILITIES === */
.transition {
  transition-property: all;
  transition-duration: var(--animation-duration-normal);
  transition-timing-function: var(--animation-easing);
}

.transition-fast {
  transition-duration: var(--animation-duration-fast);
}

.transition-slow {
  transition-duration: var(--animation-duration-slow);
}

.transition-colors {
  transition-property: color, background-color, border-color;
  transition-duration: var(--animation-duration-normal);
  transition-timing-function: var(--animation-easing);
}

.transition-transform {
  transition-property: transform;
  transition-duration: var(--animation-duration-normal);
  transition-timing-function: var(--animation-easing);
}

/* Hover Effects */
.hover\:scale-105:hover {
  transform: scale(1.05);
}

.hover\:shadow-lg:hover {
  box-shadow: var(--shadow-lg);
}

/* === 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 Styles */
.focus-ring:focus {
  outline: 2px solid var(--color-focus-ring);
  outline-offset: 2px;
}

.focus-ring-inset:focus {
  outline: 2px solid var(--color-focus-ring);
  outline-offset: -2px;
}

/* === RESPONSIVE UTILITIES === */
.hidden { display: none; }
.block { display: block; }
.inline-block { display: inline-block; }

@media (min-width: 640px) {
  .sm\:block { display: block; }
  .sm\:hidden { display: none; }
  .sm\:flex { display: flex; }
}

@media (min-width: 768px) {
  .md\:block { display: block; }
  .md\:hidden { display: none; }
  .md\:flex { display: flex; }
}

@media (min-width: 1024px) {
  .lg\:block { display: block; }
  .lg\:hidden { display: none; }
  .lg\:flex { display: flex; }
}

/* === SCROLLBAR STYLING === */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-surface-secondary);
}

::-webkit-scrollbar-thumb {
  background: var(--color-border-dark);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-tertiary);
}

/* === PRINT STYLES === */
@media print {
  .no-print {
    display: none !important;
  }
  
  .card {
    box-shadow: none;
    border: 1px solid #000;
  }
}

/* === PERFORMANCE OPTIMIZATIONS === */
.will-change-transform {
  will-change: transform;
}

.will-change-opacity {
  will-change: opacity;
}

/* GPU Acceleration */
.gpu-accelerated {
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
}

/* ============================================
   SITE-WIDE LAYOUT COMPONENTS
   ============================================ */

/* Page body - dark theme */
.model-detail-page {
  background: var(--dark-navy);
  color: var(--cream);
  font-family: var(--font-family);
  min-height: 100vh;
}

/* Site Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: rgba(15, 30, 46, 0.95);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--gold);
}

.site-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--gold);
}

/* Navigation Links */
.nav-link {
  color: var(--cream);
  opacity: 0.8;
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast) ease;
}

.nav-link:hover {
  color: var(--gold);
  opacity: 1;
}

/* Breadcrumbs */
.breadcrumb-list {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
}

.breadcrumb-link {
  color: var(--cream);
  opacity: 0.7;
  transition: all var(--transition-fast) ease;
}

.breadcrumb-link:hover {
  color: var(--gold);
  opacity: 1;
}

.breadcrumb-separator {
  color: var(--light-blue-gray);
  opacity: 0.5;
}

.breadcrumb-current {
  color: var(--gold);
  font-weight: var(--font-weight-medium);
}

/* Site Footer */
.site-footer {
  text-align: center;
  padding: var(--space-6);
  margin-top: var(--space-8);
  border-top: 1px solid rgba(212, 165, 116, 0.3);
}

.footer-text {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
}

.footer-text a {
  color: var(--gold);
  text-decoration: underline;
}

.footer-text a:hover {
  color: var(--bright-gold);
}

/* ============================================
   MODAL COMPONENTS
   ============================================ */

/* Modal Backdrop */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal-backdrop);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: rgba(15, 30, 46, 0.9);
}

.modal-backdrop.hidden {
  display: none;
}

/* Modal Container */
.modal-container {
  background: linear-gradient(135deg, var(--navy), var(--dark-navy));
  border: 2px solid var(--gold);
  border-radius: var(--radius-xl);
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.4);
  width: 100%;
  max-width: 80rem;
  max-height: 90vh;
  overflow-y: auto;
}

.comparison-modal-content {
  max-width: 64rem;
}

/* Modal Header */
.modal-header {
  position: sticky;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4);
  background: rgba(30, 58, 95, 0.95);
  border-bottom: 1px solid var(--gold);
  z-index: 10;
}

.modal-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--bright-gold);
}

.modal-close-btn {
  padding: var(--space-2);
  border-radius: var(--radius-full);
  color: var(--cream);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.modal-close-btn:hover {
  background: rgba(212, 165, 116, 0.2);
  color: var(--gold);
}

/* Modal Tabs */
.modal-tab {
  padding: var(--space-3) var(--space-6);
  font-weight: var(--font-weight-semibold);
  color: var(--light-blue-gray);
  border-bottom: 2px solid transparent;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.modal-tab:hover {
  color: var(--cream);
}

.modal-tab-active {
  color: var(--bright-gold);
  border-bottom-color: var(--bright-gold);
}

/* ============================================
   EMPTY STATES & MESSAGES
   ============================================ */

.no-results-message {
  text-align: center;
  padding: var(--space-12) var(--space-4);
}

.no-results-text {
  font-size: var(--font-size-xl);
  color: var(--light-blue-gray);
}

/* Tab inactive state */
.modal-tab-inactive {
  color: var(--light-blue-gray);
  border-bottom-color: transparent;
}

/* ============================================
   ACTION BUTTONS
   ============================================ */

.btn-action {
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-lg);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

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

.btn-success:hover {
  background: #059669;
}

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

.btn-danger:hover {
  background: #dc2626;
}

/* ============================================
   COLLECTION CARDS (Modal)
   ============================================ */

.collection-card {
  background: var(--navy);
  border: 1px solid rgba(212, 165, 116, 0.3);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition-base) ease;
}

.collection-card:hover {
  border-color: var(--gold);
  transform: scale(1.02);
}

.collection-card-image {
  width: 100%;
  height: 10rem;
  object-fit: cover;
}

.collection-card-body {
  padding: var(--space-4);
}

.collection-card-title {
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  color: var(--cream);
  margin-bottom: var(--space-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.collection-card-meta {
  font-size: var(--font-size-xs);
  color: var(--light-blue-gray);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-3);
}

/* Utility: margin-right */
.mr-2 {
  margin-right: var(--space-2);
}

/* ============================================
   HELP MODAL (Search Operators)
   ============================================ */

.help-modal-content {
  background: linear-gradient(135deg, var(--navy), var(--dark-navy));
  border: 2px solid var(--gold);
  border-radius: var(--radius-xl);
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.4);
  max-width: 42rem;
  width: 100%;
  padding: var(--space-6);
}

.help-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.help-modal-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--bright-gold);
}

.help-modal-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--cream);
}

.help-example {
  padding-top: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--light-blue-gray);
}

/* Code inline style */
.code-inline {
  background: rgba(212, 165, 116, 0.15);
  border: 1px solid rgba(212, 165, 116, 0.3);
  color: var(--gold);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-family: 'Courier New', monospace;
  font-size: 0.875em;
}

/* ============================================
   MODEL DETAIL TABS & SECTIONS
   ============================================ */

.model-detail-tabs {
  border-bottom: 1px solid rgba(212, 165, 116, 0.3);
  margin-bottom: var(--space-6);
}

.detail-info-section {
  background: rgba(30, 58, 95, 0.3);
  border: 1px solid rgba(212, 165, 116, 0.3);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.section-heading {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--gold);
  margin-bottom: var(--space-4);
}

.chart-placeholder {
  height: 16rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.muted-text {
  color: var(--light-blue-gray);
}

/* Similar Models Grid */
.similar-models-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: var(--space-4);
}

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

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

.similar-model-card {
  display: block;
  padding: var(--space-4);
  background: var(--navy);
  border: 1px solid rgba(212, 165, 116, 0.3);
  border-radius: var(--radius-lg);
  transition: all var(--transition-base) ease;
}

.similar-model-card:hover {
  border-color: var(--gold);
  box-shadow: var(--shadow-lg);
}

.similar-model-image {
  width: 100%;
  height: 8rem;
  object-fit: cover;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
}

.similar-model-title {
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  color: var(--cream);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.similar-model-meta {
  font-size: var(--font-size-xs);
  color: var(--light-blue-gray);
  margin-top: var(--space-1);
}

/* ============================================
   MODEL DETAIL BUTTONS
   ============================================ */

.detail-btn {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-medium);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.detail-btn-primary {
  background: var(--gold);
  color: var(--dark-navy);
}

.detail-btn-primary:hover {
  background: var(--bright-gold);
}

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

.detail-btn-success:hover {
  background: #059669;
}

.detail-btn-secondary {
  background: var(--navy-light);
  color: var(--cream);
}

.detail-btn-secondary:hover {
  background: var(--navy);
  border: 1px solid var(--gold);
}

/* ============================================
   ERROR PAGE
   ============================================ */

.error-page {
  text-align: center;
  padding: var(--space-12) var(--space-4);
}

.error-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-4);
}

.error-message {
  font-size: var(--font-size-lg);
  color: var(--light-blue-gray);
  margin-bottom: var(--space-6);
}

/* ============================================
   QUICK VIEW MODAL - Info Sections
   (Used by script.js, server-pagination.js)
   ============================================ */

/* Info box - generic panel container */
.info-box {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  background: rgba(30, 58, 95, 0.5);
  border: 1px solid rgba(212, 165, 116, 0.3);
  margin-bottom: var(--space-6);
}

.info-box-header {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--gold);
  margin-bottom: var(--space-3);
}

.info-box-text {
  color: var(--cream);
  font-size: var(--font-size-sm);
}

.info-box-muted {
  color: var(--light-blue-gray);
  font-size: var(--font-size-sm);
}

/* Key-value info row */
.info-row {
  display: flex;
  align-items: center;
}

.info-row-stacked {
  display: flex;
  align-items: flex-start;
}

.info-label {
  font-weight: var(--font-weight-semibold);
  width: 7rem;
  flex-shrink: 0;
  color: var(--light-blue-gray);
}

.info-value {
  color: var(--cream);
}

/* Feature list */
.feature-list {
  list-style: disc;
  list-style-position: inside;
  color: var(--cream);
}

.feature-list li {
  margin-bottom: var(--space-1);
}

/* ============================================
   VARIANT SECTION (Packaging Versions)
   ============================================ */

.variant-section {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  background: rgba(30, 58, 95, 0.5);
  border: 1px solid rgba(212, 165, 116, 0.3);
  margin-bottom: var(--space-6);
}

.variant-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.variant-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--gold);
}

.variant-reset-btn {
  padding: var(--space-1) var(--space-3);
  font-size: var(--font-size-sm);
  border-radius: var(--radius-md);
  background: var(--navy-light);
  color: var(--cream);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.variant-reset-btn:hover {
  background: var(--navy);
  border: 1px solid var(--gold);
}

/* Variant item button */
.variant-item {
  text-align: left;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid rgba(212, 165, 116, 0.3);
  background: var(--navy);
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.variant-item:hover {
  border-color: var(--gold);
}

.variant-item:focus {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

.variant-item-title {
  font-weight: var(--font-weight-semibold);
  color: var(--cream);
}

.variant-item-meta {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
}

/* Variant table */
.variant-table {
  width: 100%;
  font-size: var(--font-size-sm);
  border: 1px solid rgba(212, 165, 116, 0.3);
  border-radius: var(--radius-md);
  border-collapse: collapse;
}

.variant-table thead {
  background: var(--navy-light);
  color: var(--cream);
}

.variant-table th {
  padding: var(--space-2) var(--space-3);
  text-align: left;
  font-weight: var(--font-weight-semibold);
}

.variant-table td {
  padding: var(--space-2) var(--space-3);
  color: var(--cream);
}

.variant-row {
  cursor: pointer;
  border-top: 1px solid rgba(212, 165, 116, 0.2);
  transition: background var(--transition-fast) ease;
}

.variant-row:hover {
  background: rgba(212, 165, 116, 0.1);
}

.variant-row-selected {
  background: rgba(212, 165, 116, 0.15);
}

/* ============================================
   QUICK VIEW MODAL HEADER
   ============================================ */

.modal-model-title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
}

.modal-model-subtitle {
  font-size: var(--font-size-xl);
  color: var(--light-blue-gray);
}

.modal-model-id {
  font-size: var(--font-size-sm);
  font-family: monospace;
  color: var(--light-blue-gray);
}

.modal-copy-btn {
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-sm);
  border-radius: var(--radius-md);
  background: var(--navy-light);
  color: var(--cream);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.modal-copy-btn:hover {
  background: var(--navy);
  border: 1px solid var(--gold);
}

.modal-permalink {
  font-size: var(--font-size-sm);
  color: var(--gold);
  transition: color var(--transition-fast) ease;
}

.modal-permalink:hover {
  color: var(--bright-gold);
}

.modal-close-icon {
  color: var(--light-blue-gray);
  font-size: var(--font-size-2xl);
  transition: color var(--transition-fast) ease;
}

.modal-close-icon:hover {
  color: var(--cream);
}

/* ============================================
   GALLERY SECTIONS
   ============================================ */

.gallery-heading {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--gold);
  margin-bottom: var(--space-3);
}

.gallery-heading-mt {
  margin-top: var(--space-6);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

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

.gallery-image {
  width: 100%;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.gallery-empty {
  grid-column: span 2;
  color: var(--light-blue-gray);
}

/* Variant selected badge */
.variant-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  background: rgba(212, 165, 116, 0.2);
  color: var(--gold);
  margin-bottom: var(--space-2);
}

.variant-notes {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  margin-bottom: var(--space-2);
}

/* ============================================
   LOADING INDICATOR
   ============================================ */

.loading-spinner {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  border: 2px solid transparent;
  border-top-color: var(--gold);
  border-bottom-color: var(--gold);
  border-radius: var(--radius-full);
  animation: spin 1s linear infinite;
  margin-bottom: var(--space-2);
}

.loading-spinner-lg {
  width: 3rem;
  height: 3rem;
}

.loading-text {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
}

.loading-text-lg {
  font-size: var(--font-size-lg);
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ============================================
   ERROR DISPLAY
   ============================================ */

.error-display {
  text-align: center;
  padding: var(--space-8);
}

.error-heading {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-2);
}

.error-text {
  font-size: var(--font-size-lg);
  color: var(--light-blue-gray);
  margin-bottom: var(--space-4);
}

.error-detail {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  opacity: 0.7;
}

/* ============================================
   SIMILAR MODELS CAROUSEL
   ============================================ */

.similar-carousel {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.carousel-arrow {
  flex-shrink: 0;
  width: 6rem;
  height: 6rem;
  border-radius: var(--radius-full);
  background: var(--gold);
  color: var(--dark-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.carousel-arrow:hover {
  background: var(--bright-gold);
  transform: scale(1.05);
}

.carousel-track {
  flex: 1;
  height: 4px;
  background: var(--gold);
  margin-left: var(--space-4);
}

.similar-model-item {
  background: var(--navy);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  transition: all var(--transition-base) ease;
}

.similar-model-item:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}

.similar-model-item-in-collection {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  background: var(--color-success);
  color: white;
  font-size: var(--font-size-xs);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
}

.similar-model-item-title {
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-1);
}

.similar-model-item-series {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
}

.similar-model-item-date {
  font-size: var(--font-size-xs);
  color: var(--light-blue-gray);
  margin-top: var(--space-2);
}

/* ============================================
   COLLECTION TOGGLE BUTTON STATES
   (Button styles for Add/Remove from Collection)
   ============================================ */

.btn-collection-active {
  background: var(--color-success);
  color: white;
}

.btn-collection-active:hover {
  background: #059669;
}

.btn-collection-inactive {
  background: var(--navy-light);
  color: var(--cream);
}

.btn-collection-inactive:hover {
  background: var(--navy);
}

/* Owned badge on cards */
.owned-badge {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-success);
}

/* Model card separator dot */
.separator-dot {
  font-size: var(--font-size-xs);
  color: var(--light-blue-gray);
}

/* Model ID row */
.model-id-row {
  font-size: var(--font-size-xs);
  font-family: monospace;
  color: var(--light-blue-gray);
  margin-top: var(--space-1);
}

/* ============================================
   SHARE BUTTON
   ============================================ */

.btn-share {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--navy-light);
  color: var(--cream);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast) ease;
}

.btn-share:hover {
  background: var(--navy);
  color: var(--gold);
}

/* ============================================
   MODEL DETAIL PAGE - Full Page Layout
   ============================================ */

.detail-page-card {
  background: var(--navy);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

.detail-page-header {
  padding: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: flex-start;
  justify-content: space-between;
}

.detail-page-title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-2);
}

@media (min-width: 640px) {
  .detail-page-title {
    font-size: var(--font-size-4xl);
  }
}

.detail-page-subtitle {
  font-size: var(--font-size-xl);
  color: var(--light-blue-gray);
}

.detail-page-meta {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  margin-top: var(--space-2);
}

.detail-page-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

/* ============================================
   MODEL DETAIL - Specification Tables
   ============================================ */

.spec-section {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: rgba(30, 58, 95, 0.5);
  border: 1px solid rgba(212, 165, 116, 0.3);
}

.spec-heading {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--gold);
  margin-bottom: var(--space-4);
}

.spec-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.spec-row {
  display: flex;
}

.spec-label {
  font-weight: var(--font-weight-semibold);
  width: 8rem;
  color: var(--light-blue-gray);
}

.spec-value {
  color: var(--cream);
}

/* Spec table (for variants) */
.spec-table {
  width: 100%;
  font-size: var(--font-size-sm);
  border-collapse: collapse;
}

.spec-table thead {
  background: var(--navy-light);
}

.spec-table th,
.spec-table td {
  padding: var(--space-2) var(--space-3);
  text-align: left;
}

.spec-table th {
  color: var(--cream);
  font-weight: var(--font-weight-semibold);
}

.spec-table td {
  color: var(--cream);
}

.spec-table tr {
  border-top: 1px solid rgba(212, 165, 116, 0.2);
}

/* ============================================
   PRICING SECTION (Model Detail)
   ============================================ */

.pricing-section {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(139, 92, 246, 0.1));
  border: 1px solid rgba(212, 165, 116, 0.3);
}

.pricing-heading {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-4);
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: var(--space-4);
}

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

.pricing-card {
  background: var(--navy);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

.pricing-card-label {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  margin-bottom: var(--space-1);
}

.pricing-card-value {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--gold);
}

.pricing-card-value-success {
  color: var(--color-success);
}

.pricing-trend-up {
  color: var(--color-success);
}

.pricing-trend-down {
  color: var(--color-error);
}

.pricing-trend-stable {
  color: var(--light-blue-gray);
}

/* Price history table */
.price-table {
  width: 100%;
  border-collapse: collapse;
}

.price-table thead {
  background: rgba(30, 58, 95, 0.5);
}

.price-table th {
  padding: var(--space-2) var(--space-4);
  text-align: left;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--cream);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.price-table td {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
}

.price-table tbody {
  border-top: 1px solid rgba(212, 165, 116, 0.2);
}

.price-table tbody tr {
  border-bottom: 1px solid rgba(212, 165, 116, 0.1);
}

/* Condition badges */
.condition-badge {
  display: inline-block;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.condition-mint {
  background: rgba(16, 185, 129, 0.2);
  color: #10b981;
}

.condition-excellent {
  background: rgba(59, 130, 246, 0.2);
  color: #3b82f6;
}

.condition-good {
  background: rgba(245, 158, 11, 0.2);
  color: #f59e0b;
}

.condition-fair {
  background: rgba(249, 115, 22, 0.2);
  color: #f97316;
}

/* ============================================
   BACK LINK
   ============================================ */

.btn-back {
  display: inline-flex;
  align-items: center;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-md);
  background: transparent;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast) ease;
}

.btn-back:hover {
  background: var(--gold);
  color: var(--dark-navy);
}

/* ============================================
   MODEL DETAIL PAGE COMPONENTS
   ============================================ */

/* Main detail content container */
.detail-content-container {
  background: var(--navy);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

/* Detail header section */
.detail-header {
  padding: var(--space-6);
  background: linear-gradient(to bottom, rgba(212, 165, 116, 0.1), transparent);
}

/* Detail title */
.detail-title {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-2);
}

@media (min-width: 640px) {
  .detail-title {
    font-size: 2.5rem;
  }
}

/* Detail subtitle */
.detail-subtitle {
  font-size: var(--font-size-xl);
  color: var(--light-blue-gray);
}

/* Detail ID display */
.detail-id {
  font-size: var(--font-size-sm);
  color: var(--gold);
  font-family: monospace;
}

/* Share button */
.btn-share {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  background: rgba(212, 165, 116, 0.2);
  color: var(--gold);
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast) ease;
}

.btn-share:hover {
  background: rgba(212, 165, 116, 0.3);
}

/* Detail content area */
.detail-content {
  padding: var(--space-6);
}

/* Section headings in detail page */
.detail-section-heading {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-4);
}

/* Gallery grid for detail page */
.detail-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

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

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

/* Specifications grid */
.specs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

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

/* Specification panel */
.spec-panel {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: rgba(30, 58, 95, 0.5);
  border: 1px solid rgba(212, 165, 116, 0.2);
}

/* Panel title */
.panel-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--cream);
  margin-bottom: var(--space-4);
}

/* Definition list for specs */
.spec-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
}

.spec-row {
  display: flex;
}

.spec-label {
  font-weight: var(--font-weight-semibold);
  width: 8rem;
  color: var(--light-blue-gray);
}

.spec-value {
  color: var(--light-blue-gray);
}

/* Features list */
.feature-list {
  list-style: disc;
  list-style-position: inside;
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* Notes text */
.notes-text {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  white-space: pre-line;
}

/* Detail variants table */
.detail-variants-table {
  width: 100%;
  font-size: var(--font-size-sm);
}

.detail-variants-table thead {
  background: rgba(30, 58, 95, 0.7);
}

.detail-variants-table th {
  padding: var(--space-2) var(--space-4);
  text-align: left;
  color: var(--cream);
}

.detail-variants-table td {
  padding: var(--space-3) var(--space-4);
  color: var(--light-blue-gray);
}

.detail-variants-table tbody tr {
  border-top: 1px solid rgba(212, 165, 116, 0.2);
}

/* Pricing section container */
.pricing-section-container {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(30, 58, 95, 0.8), rgba(42, 82, 135, 0.6));
  border: 1px solid rgba(212, 165, 116, 0.2);
}

/* Pricing title */
.pricing-section-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--cream);
  margin-bottom: var(--space-4);
}

/* Pricing stats grid */
.pricing-stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

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

/* Stat label */
.stat-label {
  font-size: var(--font-size-sm);
  color: var(--light-blue-gray);
  margin-bottom: var(--space-1);
}

/* Large pricing value */
.pricing-value-large {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--bright-gold);
}

/* Price range value */
.pricing-value-range {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: #10b981;
}

/* Price chart container */
.price-chart-container {
  background: var(--navy);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-4);
}

.price-chart-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--cream);
  margin-bottom: var(--space-4);
}

/* Price history container */
.price-history-container {
  background: var(--navy);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

/* Small notes text in table */
.table-note {
  color: var(--light-blue-gray);
  font-size: var(--font-size-xs);
}

/* ============================================
   UTILITY CLASSES (replacing Tailwind utilities)
   ============================================ */

/* Flex utilities */
.flex-row-center {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.flex-row-start {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.flex-justify-end {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

/* Text alignment */
.text-right {
  text-align: right;
}

/* Spacing */
.space-y-2 > * + * {
  margin-top: var(--space-2);
}

.space-y-4 > * + * {
  margin-top: var(--space-4);
}

.ml-4 {
  margin-left: var(--space-4);
}

.mt-2 {
  margin-top: var(--space-2);
}

.mb-6 {
  margin-bottom: var(--space-6);
}

.mb-8 {
  margin-bottom: var(--space-8);
}

/* Modal padding */
.modal-body-padding {
  padding: var(--space-6);
}

/* Card padding */
.card-padding {
  padding: var(--space-4);
}

/* Status badge base */
.status-badge {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-md);
}

/* Text size utilities */
.text-sm {
  font-size: var(--font-size-sm);
}

.text-xs {
  font-size: var(--font-size-xs);
}

/* Info list - vertical spacing for info rows */
.info-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

/* Info box stack - vertical spacing between boxes */
.info-box-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* Modal header row */
.modal-header-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

/* Timeline image */
.timeline-img {
  width: 100%;
  height: 10rem;
  object-fit: cover;
}

/* Detail header row - responsive layout */
.detail-header-row {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-6);
}

@media (min-width: 1024px) {
  .detail-header-row {
    flex-direction: row;
  }
}

/* Detail header actions */
.detail-header-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

@media (min-width: 1024px) {
  .detail-header-actions {
    margin-top: 0;
  }
}

/* ============================================
   GRID LAYOUTS FOR MODAL/QUICKVIEW
   ============================================ */

/* Two-column grid for variants/gallery split */
.modal-two-col-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

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

/* Variants list grid */
.variants-list-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
}

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

/* Timeline models grid */
.timeline-models-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-left: 7rem;
}

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

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

/* ============================================
   REMAINING COMPONENT FIXES (Dec 4, 2025)
   ============================================ */

/* Modal container - quickview/detail modal */
.modal-content-container {
  background: var(--navy);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 64rem;
  max-height: 90vh;
  overflow-y: auto;
  transform: scale(0.95);
}

/* Image viewer close button */
.image-viewer-close {
  position: fixed;
  top: 1rem;
  right: 1rem;
  color: white;
  font-size: 1.875rem;
  padding: 0.5rem;
  border-radius: var(--radius-full);
  background: rgba(0, 0, 0, 0.5);
  transition: background var(--transition-fast) ease;
  z-index: 10000;
}

.image-viewer-close:hover {
  background: rgba(0, 0, 0, 0.75);
}

/* Stats dashboard grid */
.stats-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

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

/* Collection/Wishlist modal grid */
.collection-modal-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

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

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

/* Empty state for search results */
.empty-search-result {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-8) 0;
  color: var(--light-blue-gray);
}

/* Active filter indicator */
.active-filter-indicator {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.active-filter-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--bright-gold);
}

.active-filter-badge {
  font-size: var(--font-size-xs);
  background: rgba(212, 165, 116, 0.2);
  color: var(--gold);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-md);
}

/* Help icon for search */
.search-help-icon {
  width: 1rem;
  height: 1rem;
  color: var(--light-blue-gray);
  transition: color var(--transition-fast) ease;
}

.search-help-icon:hover {
  color: var(--bright-gold);
}

/* Comparison table cells */
.comparison-cell {
  padding: var(--space-3) var(--space-4);
  font-weight: var(--font-weight-medium);
  color: var(--light-blue-gray);
}

.comparison-cell-highlight {
  background: rgba(245, 158, 11, 0.15);
}

/* Comparison thumbnail */
.comparison-thumbnail {
  width: 8rem;
  height: 6rem;
  object-fit: cover;
  border-radius: var(--radius-lg);
}

/* Responsive container - max-w-5xl */
.container-5xl {
  max-width: 64rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

@media (min-width: 640px) {
  .container-5xl {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .container-5xl {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }
}

/* Responsive container - max-w-7xl */
.container-7xl {
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

@media (min-width: 640px) {
  .container-7xl {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .container-7xl {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }
}

/* Header container with height */
.header-container {
  height: 4rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Desktop nav visibility */
.desktop-nav {
  display: none;
  align-items: center;
  gap: var(--space-4);
}

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

/* Breadcrumb container */
.breadcrumb-container {
  padding-top: var(--space-4);
  padding-bottom: var(--space-4);
}

/* Main content container */
.main-content-container {
  padding-top: var(--space-6);
  padding-bottom: var(--space-6);
}


