/**
 * Default Theme CSS
 * Clean, neutral design that works for any store type.
 * Grayscale aesthetic with elegant black-to-white transitions.
 *
 * All colors are driven by API theme colors (primary, secondary, neutral scales).
 * ColorManagerService injects --primary-50..900, --secondary-50..900, --neutral-50..900 on :root.
 */

:root {
  /* Primary / secondary semantics - neutral grayscale */
  --primary-main: var(--primary-500);
  --primary-hover: var(--primary-600);
  --primary-light: var(--primary-200);
  --primary-dark: var(--primary-700);

  /* Neutral gradients - subtle gray transitions */
  --primary-gradient: linear-gradient(135deg, var(--neutral-800) 0%, var(--neutral-900) 100%);
  --hero-gradient: linear-gradient(180deg, var(--neutral-900) 0%, var(--neutral-800) 100%);
  --hero-gradient-alt: linear-gradient(135deg, var(--neutral-800) 0%, var(--neutral-700) 100%);

  --secondary-main: var(--secondary-500);
  --secondary-hover: var(--secondary-600);
  --secondary-light: var(--secondary-200);
  --secondary-dark: var(--secondary-700);

  /* Feature icon - simple neutral background */
  --feature-icon-bg: var(--neutral-100);
  --feature-icon-border: var(--neutral-200);

  /* Backgrounds - clean white/gray */
  --background-primary: #FFFFFF;
  --background-secondary: var(--neutral-50);
  --background-card: #FFFFFF;
  --background-overlay: rgba(0, 0, 0, 0.5);

  /* Text - high contrast */
  --text-primary: var(--neutral-900);
  --text-secondary: var(--neutral-600);
  --text-muted: var(--neutral-400);
  --text-inverse: #FFFFFF;
  --text-link: var(--neutral-900);
  --text-link-hover: var(--neutral-600);

  /* Borders - subtle */
  --border-light: var(--neutral-200);
  --border-medium: var(--neutral-300);
  --border-dark: var(--neutral-400);
  --border-focus: var(--neutral-900);

  /* Shadows - soft and minimal */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.04);
  --shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.06), 0 1px 2px 0 rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.06), 0 2px 4px -1px rgba(0, 0, 0, 0.04);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -2px rgba(0, 0, 0, 0.03);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 10px 10px -5px rgba(0, 0, 0, 0.03);

  /* Buttons - clean black/white */
  --button-primary-background: var(--neutral-900);
  --button-primary-background-hover: var(--neutral-800);
  --button-primary-text: #FFFFFF;
  --button-primary-border: var(--neutral-900);

  --button-secondary-background: var(--neutral-100);
  --button-secondary-background-hover: var(--neutral-200);
  --button-secondary-text: var(--neutral-900);
  --button-secondary-border: var(--neutral-200);

  --button-outline-background: transparent;
  --button-outline-background-hover: var(--neutral-900);
  --button-outline-text: var(--neutral-900);
  --button-outline-text-hover: #FFFFFF;
  --button-outline-border: var(--neutral-300);

  --button-ghost-background: transparent;
  --button-ghost-background-hover: var(--neutral-100);
  --button-ghost-text: var(--neutral-700);
  --button-ghost-text-hover: var(--neutral-900);
  --button-ghost-border: transparent;

  /* Badges - subtle */
  --badge-primary-bg: var(--neutral-100);
  --badge-primary-text: var(--neutral-700);
  --badge-primary-border: var(--neutral-200);

  /* Form - clean */
  --form-input-background: #FFFFFF;
  --form-input-background-focus: #FFFFFF;
  --form-input-text: var(--neutral-900);
  --form-input-placeholder: var(--neutral-400);
  --form-input-border: var(--neutral-300);
  --form-input-border-focus: var(--neutral-900);
  --form-label-text: var(--neutral-700);

  /* Card - minimal */
  --card-background: #FFFFFF;
  --card-border: var(--neutral-200);
  --card-shadow: var(--shadow-sm);
  --card-shadow-hover: var(--shadow-md);

  /* Navigation - light and clean */
  --navigation-background: #FFFFFF;
  --navigation-text: var(--neutral-600);
  --navigation-text-hover: var(--neutral-900);
  --navigation-border: var(--neutral-200);
  --navigation-active: var(--neutral-900);

  /* Footer - dark */
  --footer-background: var(--neutral-900);
  --footer-text: #FFFFFF;
  --footer-text-secondary: var(--neutral-400);
  --footer-border: var(--neutral-800);

  /* Newsletter - dark section */
  --newsletter-gradient: var(--neutral-900);
  --newsletter-text: #FFFFFF;
  --newsletter-input-border: var(--neutral-700);
  --newsletter-cta-bg: #FFFFFF;
  --newsletter-cta-text: var(--neutral-900);

  /* Product */
  --product-price-regular: var(--neutral-900);
  --product-badge-new: var(--neutral-900);
  --product-badge-sale: #DC2626;
  --product-badge-out-of-stock: var(--neutral-400);

  /* Loading */
  --loading-spinner: var(--neutral-900);
  --loading-overlay: rgba(255, 255, 255, 0.9);

  /* Semantic */
  --error-main: #DC2626;
  --error-foreground: #FFFFFF;
  --warning-main: #D97706;
  --warning-foreground: var(--neutral-900);
  --success-main: #16A34A;
  --success-foreground: #FFFFFF;
  --info-main: var(--neutral-600);
  --info-foreground: #FFFFFF;

  /* Legacy aliases */
  --primary-color: var(--primary-main);
  --secondary-color: var(--secondary-main);
  --background-color: var(--background-primary);
  --text-linkHover: var(--text-link-hover);
  --form-input-borderError: var(--error-main);
  --form-input-borderFocus: var(--form-input-border-focus);
  --button-primary-backgroundHover: var(--button-primary-background-hover);
  --button-secondary-backgroundHover: var(--button-secondary-background-hover);
  --button-outline-textHover: var(--button-outline-text-hover);
  --navigation-textHover: var(--navigation-text-hover);
  --card-shadowHover: var(--card-shadow-hover);
}

/* ========== Theme utility classes ========== */

/* Layout & surfaces */
.theme-bg-page {
  background-color: var(--background-primary);
}

.theme-hover-bg-subtle:hover {
  background-color: var(--neutral-50);
}

.theme-bg-card {
  background-color: var(--card-background);
  border: 1px solid var(--card-border);
}

.theme-bg-hero {
  background: var(--hero-gradient);
  color: var(--text-inverse);
}

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

.theme-bg-footer {
  background-color: var(--footer-background);
  color: var(--footer-text);
}

.theme-bg-newsletter {
  background: var(--newsletter-gradient);
  color: var(--newsletter-text);
}

/* Nav - clean minimal */
.theme-nav {
  background-color: var(--navigation-background);
  border-bottom: 1px solid var(--navigation-border);
}

.theme-nav-link {
  color: var(--navigation-text);
  transition: color 0.2s ease;
}

.theme-nav-link:hover {
  color: var(--navigation-text-hover);
}

.theme-nav-link.router-link-active {
  color: var(--navigation-active);
}

.theme-nav-cart-badge {
  background-color: var(--neutral-900);
  color: #FFFFFF;
}

/* Text */
.theme-text-heading {
  color: var(--text-primary);
}

.theme-text-body {
  color: var(--text-secondary);
}

.theme-text-muted {
  color: var(--text-muted);
}

.theme-link {
  color: var(--text-link);
}

.theme-link:hover {
  color: var(--text-link-hover);
}

/* Borders & dividers */
.theme-border {
  border-color: var(--border-light);
}

.theme-border-t {
  border-top: 1px solid var(--border-light);
}

.theme-border-b {
  border-bottom: 1px solid var(--border-light);
}

/* Buttons - clean black/white */
.theme-btn-primary {
  background-color: var(--button-primary-background);
  color: var(--button-primary-text);
  border: 1px solid var(--button-primary-border);
  transition: all 0.2s ease;
}

.theme-btn-primary:hover:not(:disabled) {
  background-color: var(--button-primary-background-hover);
  border-color: var(--button-primary-background-hover);
}

.theme-btn-secondary {
  background-color: var(--button-secondary-background);
  color: var(--button-secondary-text);
  border: 1px solid var(--button-secondary-border);
  transition: all 0.2s ease;
}

.theme-btn-secondary:hover:not(:disabled) {
  background-color: var(--button-secondary-background-hover);
  border-color: var(--button-secondary-background-hover);
}

.theme-btn-outline {
  background-color: var(--button-outline-background);
  color: var(--button-outline-text);
  border: 1px solid var(--button-outline-border);
  transition: all 0.2s ease;
}

.theme-btn-outline:hover:not(:disabled) {
  background-color: var(--button-outline-background-hover);
  color: var(--button-outline-text-hover);
  border-color: var(--button-outline-background-hover);
}

.theme-btn-ghost {
  background-color: var(--button-ghost-background);
  color: var(--button-ghost-text);
  border: 1px solid var(--button-ghost-border);
  transition: all 0.2s ease;
}

.theme-btn-ghost:hover:not(:disabled) {
  background-color: var(--button-ghost-background-hover);
  color: var(--button-ghost-text-hover);
}

/* Hero outline button */
.theme-btn-hero-outline {
  background: transparent;
  color: #FFFFFF;
  border: 1px solid var(--neutral-600);
  transition: all 0.2s ease;
}

.theme-btn-hero-outline:hover {
  background: #FFFFFF;
  color: var(--neutral-900);
  border-color: #FFFFFF;
}

/* Badges - minimal */
.theme-badge {
  background-color: var(--badge-primary-bg);
  color: var(--badge-primary-text);
  border: 1px solid var(--badge-primary-border);
}

/* Cards & product - clean */
.theme-product-card {
  background-color: var(--card-background);
  border: 1px solid var(--card-border);
  box-shadow: var(--card-shadow);
  transition: all 0.2s ease;
}

.theme-product-card:hover {
  border-color: var(--neutral-300);
  box-shadow: var(--card-shadow-hover);
}

.theme-product-price {
  color: var(--product-price-regular);
  font-weight: 600;
}

.theme-add-to-cart {
  background-color: var(--button-primary-background);
  color: var(--button-primary-text);
  border: 1px solid var(--button-primary-border);
  transition: all 0.2s ease;
}

.theme-add-to-cart:hover:not(:disabled) {
  background-color: var(--button-primary-background-hover);
  border-color: var(--button-primary-background-hover);
}

.theme-add-to-cart:disabled {
  background-color: var(--neutral-200);
  color: var(--neutral-500);
  border-color: var(--neutral-200);
  cursor: not-allowed;
}

/* Form inputs - clean */
.theme-input {
  background-color: var(--form-input-background);
  color: var(--form-input-text);
  border: 1px solid var(--form-input-border);
  transition: border-color 0.2s ease;
}

.theme-input:focus {
  outline: none;
  border-color: var(--form-input-border-focus);
}

.theme-input::placeholder {
  color: var(--form-input-placeholder);
}

/* Footer - minimal */
.theme-footer-link {
  color: var(--footer-text-secondary);
  transition: color 0.2s ease;
}

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

.theme-footer-social-border {
  border: 1px solid var(--footer-border);
  transition: all 0.2s ease;
}

.theme-footer-social-border:hover {
  background-color: #FFFFFF;
  border-color: #FFFFFF;
  color: var(--neutral-900);
}

/* Section title underline - simple black line */
.theme-title-underline {
  background-color: var(--neutral-900);
  height: 2px;
}

/* Newsletter CTA */
.theme-newsletter-cta {
  background-color: var(--newsletter-cta-bg);
  color: var(--newsletter-cta-text);
  border: 1px solid var(--newsletter-cta-bg);
  transition: all 0.2s ease;
}

.theme-newsletter-cta:hover {
  background-color: var(--neutral-100);
  border-color: var(--neutral-100);
}

.theme-newsletter-input {
  background: transparent;
  border: 1px solid var(--newsletter-input-border);
  color: var(--newsletter-text);
  transition: border-color 0.2s ease;
}

.theme-newsletter-input::placeholder {
  color: var(--neutral-500);
}

.theme-newsletter-input:focus {
  border-color: var(--neutral-500);
  outline: none;
}
