/* ===== SECTION 1: CSS VARIABLES AND THEME DEFINITIONS ===== */

/* Default theme (Potato) */
:root, .theme-potato, [data-theme="potato"] {
  /* Primary Colors - Warm Amber/Brown (Russet Potato) */
  --primary-50: #fdf8ed;
  --primary-50-rgb: 253, 248, 237;
  --primary-100: #f8e8c8;
  --primary-200: #f3d8a3;
  --primary-300: #edc87e;
  --primary-400: #e8b859;
  --primary-500: #e3a834;  /* Main primary color - Golden Amber */
  --primary-600: #d49423;
  --primary-700: #b37919;
  --primary-800: #925f14;
  --primary-900: #704810;
  --primary-950: #422a09;

  /* Secondary Colors - Deep Burgundy (Red Potato) */
  --secondary-50: #fdf2f2;
  --secondary-50-rgb: 253, 242, 242;
  --secondary-100: #f9d9d9;
  --secondary-200: #f3b8b8;
  --secondary-300: #e88f8f;
  --secondary-400: #e06767;
  --secondary-500: #d94040;  /* Main secondary color */
  --secondary-600: #c42e2e;
  --secondary-700: #a32424;
  --secondary-800: #821d1d;
  --secondary-900: #611616;
  --secondary-950: #3f0e0e;

  /* Neutral Colors - Earthy Tones (Soil) */
  --neutral-50: #f9f7f5;
  --neutral-100: #f0ebe4;
  --neutral-200: #e2d8cc;
  --neutral-300: #d3c4b4;
  --neutral-400: #baa894;
  --neutral-500: #a08d78;
  --neutral-600: #86735f;
  --neutral-700: #6c5c4b;
  --neutral-800: #524536;
  --neutral-900: #3a3025;
  --neutral-950: #211c16;

  /* Accent Colors - Fresh Green (Potato Sprout) */
  --accent-50: #f0fdf4;
  --accent-100: #dcfce7;
  --accent-200: #bbf7d0;
  --accent-300: #86efac;
  --accent-400: #4ade80;
  --accent-500: #22c55e;
  --accent-600: #16a34a;
  --accent-700: #15803d;
  --accent-800: #166534;
  --accent-900: #14532d;
  --accent-950: #052e16;

  /* Success, Warning, Error Colors */
  --success-light: #bbf7d0;
  --success: #22c55e;
  --success-dark: #15803d;

  --warning-light: #fef3c7;
  --warning: #f59e0b;
  --warning-dark: #b45309;

  --error-light: #fee2e2;
  --error: #ef4444;
  --error-dark: #b91c1c;

  /* Background Colors */
  --bg-body: #f9f7f5;  /* Light earthy background */
  --bg-card: #ffffff;
  --bg-sidebar: linear-gradient(180deg, var(--primary-900) 0%, var(--secondary-900) 100%);

  /* Text Colors */
  --text-primary: var(--neutral-900);
  --text-secondary: var(--neutral-700);
  --text-muted: var(--neutral-500);
  --text-light: var(--neutral-50);

  /* Border Colors */
  --border-light: var(--neutral-200);
  --border-medium: var(--neutral-300);
  --border-accent: var(--primary-300);

  /* Shadow */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);

  /* Border Radius */
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.5rem;

  /* Spacing */
  --spacing-1: 0.25rem;
  --spacing-2: 0.5rem;
  --spacing-3: 0.75rem;
  --spacing-4: 1rem;
  --spacing-6: 1.5rem;
  --spacing-8: 2rem;
  --spacing-12: 3rem;
  --spacing-16: 4rem;

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-normal: 250ms ease;
  --transition-slow: 350ms ease;

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

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

/* Dark Spud Theme - Dark, sleek theme with purple and amber accents */
.theme-darkspud, [data-theme="darkspud"] {
  /* Primary Colors - Deep Purple (Purple Potato) */
  --primary-50: #f5f3ff;
  --primary-50-rgb: 245, 243, 255;
  --primary-100: #ede9fe;
  --primary-200: #ddd6fe;
  --primary-300: #c4b5fd;
  --primary-400: #a78bfa;
  --primary-500: #8b5cf6;  /* Main primary color */
  --primary-600: #7c3aed;
  --primary-700: #6d28d9;
  --primary-800: #5b21b6;
  --primary-900: #4c1d95;
  --primary-950: #2e1065;

  /* Secondary Colors - Amber (Russet Potato) */
  --secondary-50: #fffbeb;
  --secondary-50-rgb: 255, 251, 235;
  --secondary-100: #fef3c7;
  --secondary-200: #fde68a;
  --secondary-300: #fcd34d;
  --secondary-400: #fbbf24;
  --secondary-500: #f59e0b;  /* Main secondary color */
  --secondary-600: #d97706;
  --secondary-700: #b45309;
  --secondary-800: #92400e;
  --secondary-900: #78350f;
  --secondary-950: #451a03;

  /* Neutral Colors - Dark Gray */
  --neutral-50: #f6f7f9;
  --neutral-100: #eceef2;
  --neutral-200: #d5d9e2;
  --neutral-300: #b1b9c9;
  --neutral-400: #8693aa;
  --neutral-500: #66748f;
  --neutral-600: #515c75;
  --neutral-700: #434b60;
  --neutral-800: #1e222e;
  --neutral-900: #171a24;
  --neutral-950: #0d0f16;

  /* Accent Colors - Green (Potato Sprout) */
  --accent-50: #f0fdf4;
  --accent-100: #dcfce7;
  --accent-200: #bbf7d0;
  --accent-300: #86efac;
  --accent-400: #4ade80;
  --accent-500: #22c55e;
  --accent-600: #16a34a;
  --accent-700: #15803d;
  --accent-800: #166534;
  --accent-900: #14532d;
  --accent-950: #052e16;

  /* Success, Warning, Error Colors */
  --success-light: #d1fae5;
  --success: #10b981;
  --success-dark: #047857;

  --warning-light: #fef3c7;
  --warning: #f59e0b;
  --warning-dark: #b45309;

  --error-light: #fee2e2;
  --error: #ef4444;
  --error-dark: #b91c1c;

  /* Background Colors */
  --bg-body: #0d0f16;
  --bg-card: #171a24;
  --bg-sidebar: linear-gradient(180deg, var(--primary-900) 0%, var(--neutral-950) 100%);

  /* Text Colors */
  --text-primary: #f6f7f9;
  --text-secondary: #b1b9c9;
  --text-muted: #8693aa;
  --text-light: #f6f7f9;

  /* Border Colors */
  --border-light: #1e222e;
  --border-medium: #434b60;
  --border-accent: var(--primary-400);

  /* Shadow adjustments for dark theme */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.6), 0 10px 10px -5px rgba(0, 0, 0, 0.4);
  --shadow-2xl: 0 35px 60px -15px rgba(0, 0, 0, 0.7);
}

/* ===== SECTION 2: BASE STYLES ===== */

/* Import Open Iconic Bootstrap */
@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');

/* Base styles */
html, body {
  font-family: 'Inter', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  color: var(--text-primary);
  line-height: 1.5;
  background-color: var(--bg-body);
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--font-semibold);
  line-height: 1.2;
  margin-bottom: var(--spacing-4);
  color: var(--text-primary);
}

h1 {
  font-size: var(--text-4xl);
  margin-bottom: 1.5rem;
}

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

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

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

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

h6 {
  font-size: var(--text-base);
}

p {
  margin-bottom: 1rem;
  line-height: 1.6;
}

/* Focus styles for accessibility */
:focus-visible {
  outline: 2px solid var(--primary-500);
  outline-offset: 2px;
}

h1:focus {
  outline: none;
}

/* Modern scrollbar styling */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: rgba(var(--neutral-200), 0.5);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  background: var(--primary-300);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--primary-400);
}

/* Content area */
.content {
  padding-top: 1.5rem;
}

/* Link styles */
a, .btn-link {
  color: var(--primary-600);
  text-decoration: none;
  transition: color 0.3s ease;
}

a:hover, .btn-link:hover {
  color: var(--primary-700);
}

/* Logo and navigation styles */
.navbar-brand, .logo-link {
  text-decoration: none;
}

.navbar-brand:hover, .logo-link:hover {
  text-decoration: none;
}

/* ===== SECTION 3: BUTTONS ===== */

/* Modern Button Styles 2025 */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 1.75rem;
  font-weight: var(--font-medium);
  border-radius: 1rem;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  border: none;
  position: relative;
  overflow: hidden;
  font-size: 1rem;
  letter-spacing: 0.01em;
  gap: 0.5rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
  text-transform: none;
}

.btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
  opacity: 0;
  transition: opacity 0.3s ease;
}

.btn:hover::before {
  opacity: 1;
}

.btn-primary {
  background: linear-gradient(135deg, var(--primary-500), var(--primary-600));
  color: white;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08), 0 2px 5px rgba(var(--primary-500-rgb), 0.15);
}

.btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12), 0 4px 8px rgba(var(--primary-500-rgb), 0.2);
}

.btn-primary:active {
  transform: translateY(1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(var(--primary-500-rgb), 0.1);
}

.btn-secondary {
  background: linear-gradient(135deg, var(--secondary-500), var(--secondary-600));
  color: white;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08), 0 2px 5px rgba(var(--secondary-500-rgb), 0.15);
}

.btn-secondary:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12), 0 4px 8px rgba(var(--secondary-500-rgb), 0.2);
}

.btn-secondary:active {
  transform: translateY(1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(var(--secondary-500-rgb), 0.1);
}

.btn-outline {
  background: transparent;
  border: 2px solid var(--primary-400);
  color: var(--primary-600);
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.btn-outline::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background: linear-gradient(to top, var(--primary-50), transparent);
  z-index: -1;
  transition: height 0.3s ease;
}

.btn-outline:hover {
  color: var(--primary-700);
  transform: translateY(-3px);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.08);
  border-color: var(--primary-500);
}

.btn-outline:hover::after {
  height: 100%;
}

.btn-accent {
  background-color: var(--accent-600);
  color: white;
  box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.1);
}

.btn-accent:hover {
  background-color: var(--accent-700);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md), inset 0 -2px 0 rgba(0, 0, 0, 0.1);
}

/* Focus styles */
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
  box-shadow: 0 0 0 3px var(--primary-200);
  outline: none;
}

/* ===== SECTION 4: FORM ELEMENTS ===== */

/* Modern 2025 Input Styles */
input, select, textarea {
  border-radius: 1rem;
  padding: 0.85rem 1.25rem;
  border: 1.5px solid var(--border-light);
  background-color: var(--bg-card);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  font-size: 1rem;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.03);
  width: 100%;
  color: var(--text-primary);
}

input:hover, select:hover, textarea:hover {
  border-color: var(--border-medium);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.04);
}

input:focus, select:focus, textarea:focus {
  border-color: var(--primary-400);
  box-shadow: 0 0 0 3px rgba(var(--primary-500-rgb), 0.15);
  outline: none;
  transform: translateY(-2px);
}

input::placeholder, textarea::placeholder {
  color: var(--text-muted);
  opacity: 0.7;
}

.form-control {
  border-radius: var(--radius-md);
  border: 1px solid var(--border-medium);
  padding: 0.75rem 1rem;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-control:focus {
  border-color: var(--primary-400);
  box-shadow: 0 0 0 3px var(--primary-100);
  outline: none;
}

.form-check-input {
  border-color: var(--neutral-400);
  box-shadow: none;
}

.form-check-input:checked {
  background-color: var(--primary-600);
  border-color: var(--primary-600);
  box-shadow: none;
}

.form-check-input:focus {
  border-color: var(--primary-400);
  box-shadow: none;
  transform: none;
}

/* Label styles */
.form-check-label,
.form-label {
  color: var(--text-primary);
  font-weight: normal;
  transform: none;
}

/* Remove any hover effects */
.form-check-input:hover {
  border-color: var(--neutral-500);
  transform: none;
}

/* Remove the darker border override */
.darker-border-checkbox.form-check-input {
  border-color: var(--neutral-400);
}

/* Form validation */
.valid.modified:not([type=checkbox]) {
  border-color: var(--success);
}

.invalid {
  border-color: var(--error);
}

.validation-message {
  color: var(--error);
  font-size: 0.875rem;
  margin-top: 0.25rem;
}

/* ===== SECTION 5: CARDS ===== */

/* Modern 2025 Card Styles */
.card {
  border-radius: 1.25rem;
  overflow: hidden;
  background-color: var(--bg-card);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05), 0 2px 8px rgba(0, 0, 0, 0.02);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(var(--neutral-200), 0.5);
  backdrop-filter: blur(10px);
  position: relative;
}

.card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom right, rgba(255, 255, 255, 0.1), transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.card:hover {
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08), 0 5px 15px rgba(0, 0, 0, 0.03);
  transform: translateY(-5px);
}

.card:hover::before {
  opacity: 1;
}

.card-header {
  background-color: var(--primary-50);
  border-bottom: 1px solid var(--border-light);
  padding: 1rem 1.25rem;
}

.card-body {
  padding: 1.5rem;
}

.card-footer {
  background-color: var(--neutral-50);
  border-top: 1px solid var(--border-light);
  padding: 1rem 1.25rem;
}

/* Modern Glassmorphism Effects */
.glass-card {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

/* Dark mode adjustments */
.theme-darkspud .glass-card {
  background: rgba(23, 26, 36, 0.7);
  border: 1px solid rgba(30, 34, 46, 0.5);
}

/* ===== SECTION 6: TABLES ===== */

/* Modern Table Styles */
table {
  border-radius: 1rem;
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  margin-bottom: 2rem;
}

th {
  background-color: var(--primary-50);
  color: var(--primary-900);
  font-weight: var(--font-semibold);
  text-align: left;
  padding: 1rem;
  border-bottom: 1px solid var(--border-light);
}

td {
  padding: 1rem;
  border-bottom: 1px solid var(--border-light);
}

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

tr:hover td {
  background-color: rgba(var(--primary-50-rgb), 0.5);
}

thead {
  background-color: var(--primary-700);
  color: white;
}

tr:nth-child(even) {
  background-color: var(--neutral-50);
}

/* Legacy table styles for compatibility */
table.greenTable {
  font-family: "Trebuchet MS", Arial, Helvetica, sans-serif;
  border-collapse: collapse;
  width: 100%;
}

table.greenTable td, table.greenTable th {
  border: 1px solid #ddd;
  padding: 8px;
}

table.greenTable tr:nth-child(even) {
  background-color: #f2f2f2;
}

table.greenTable tr:hover {
  background-color: #ddd;
}

table.greenTable thead td {
  padding-top: 12px;
  padding-bottom: 12px;
  text-align: left;
  background-color: #4CAF50;
  color: white;
}

/* ===== SECTION 7: BADGES AND ALERTS ===== */

/* Modern Badge Styles */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.75rem;
  border-radius: 2rem;
  font-size: 0.75rem;
  font-weight: var(--font-medium);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.badge-primary {
  background-color: var(--primary-100);
  color: var(--primary-800);
  border-color: var(--primary-200);
}

.badge-secondary {
  background-color: var(--secondary-100);
  color: var(--secondary-800);
  border-color: var(--secondary-200);
}

.badge-accent {
  background-color: var(--accent-100);
  color: var(--accent-800);
  border-color: var(--accent-200);
}

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

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

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

/* On colored backgrounds */
.success-bg .badge-primary,
.alreadyexists .badge-primary {
  background-color: rgba(255, 255, 255, 0.85);
  color: var(--primary-800);
  border-color: var(--primary-300);
}

.warning-bg .badge-primary,
.alreadyrequested .badge-primary {
  background-color: white;
  color: var(--primary-800);
  border-color: var(--primary-300);
}

/* Modern Alert Styles */
.alert {
  border-radius: 1rem;
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
  border-left: 4px solid transparent;
  display: flex;
  align-items: center;
  gap: 1rem;
  border: none;
}

.alert-info {
  background-color: var(--primary-50);
  border-left-color: var(--primary-500);
  color: var(--primary-900);
}

.alert-success {
  background-color: var(--success-light);
  border-left-color: var(--success);
  color: var(--success-dark);
}

.alert-warning {
  background-color: var(--warning-light);
  border-left-color: var(--warning);
  color: var(--warning-dark);
}

.alert-danger {
  background-color: var(--error-light);
  border-left-color: var(--error);
  color: var(--error-dark);
}

/* ===== SECTION 8: COMPONENT-SPECIFIC STYLES ===== */

/* Error boundary */
.blazor-error-boundary {
  background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, var(--error);
  padding: 1rem 1rem 1rem 3.7rem;
  color: white;
  border-radius: var(--radius-md);
  margin-bottom: 1rem;
}

.blazor-error-boundary::after {
  content: "An error has occurred.";
}

/* Loading indicator */
.img-loader {
  background: url('images/ajax-loader.gif');
  background-size: 100px 100px;
  height: 100px;
  width: 100px;
  margin: 2rem auto;
  opacity: 0.7;
}

/* Authentication QR code */
.auth-qr-code {
  max-width: 300px;
  max-height: 300px;
  margin: 20px auto;
  padding: 15px;
  background-color: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.auth-qr-code img {
  max-width: 100%;
  border-radius: var(--radius-md);
}

/* Login container */
.login-wrap {
  max-width: 450px;
  margin: 2rem auto;
  background-color: var(--bg-card);
  padding: 2rem;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}

.login-element {
  max-width: 100%;
}

/* Banner images - only apply effects to specific classes */
div.banner-image {
  height: 150px;
  text-align: center;
  margin: 1.5rem auto;
}

div.banner-image img {
  max-width: 100%;
  max-height: 100%;
  vertical-align: top;
}

div.banner-image-small img {
  max-width: 100px;
  vertical-align: top;
  text-align: left;
}

/* Random image container */
.rando-container {
  width: 100%;
  text-align: center;
  margin: 1.5rem auto;
  max-width: 90%;
}

.rando-wrap {
  margin: 0 auto;
  display: inline-block;
  position: relative;
  height: auto;
  text-align: center;
}

.rando-wrap img {
  max-width: 100%;
  max-height: 550px;
  vertical-align: top;
  border-radius: 1.5rem;
  border: 2px solid #000;
  box-shadow: var(--shadow-xl);
  transition: all var(--transition-normal);
  filter: drop-shadow(0 10px 15px rgba(0, 0, 0, 0.15));
}

.rando-wrap img:hover {
  transform: translateY(-5px) scale(1.02);
  box-shadow: var(--shadow-2xl);
  filter: drop-shadow(0 20px 25px rgba(0, 0, 0, 0.2));
}

/* Theme-specific rando-wrap image styling */
.theme-potato .rando-wrap img,
[data-theme="potato"] .rando-wrap img {
  border: 2px solid #000;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  filter: drop-shadow(0 10px 15px rgba(0, 0, 0, 0.15));
  transition: all var(--transition-normal);
}

.theme-potato .rando-wrap img:hover,
[data-theme="potato"] .rando-wrap img:hover {
  transform: translateY(-5px) scale(1.02);
  box-shadow: var(--shadow-2xl);
  filter: drop-shadow(0 20px 25px rgba(0, 0, 0, 0.2));
}

.theme-darkspud .rando-wrap img,
[data-theme="darkspud"] .rando-wrap img {
  border: 2px solid #000;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  filter: drop-shadow(0 10px 15px rgba(0, 0, 0, 0.3));
  transition: all var(--transition-normal);
}

.theme-darkspud .rando-wrap img:hover,
[data-theme="darkspud"] .rando-wrap img:hover {
  transform: translateY(-5px) scale(1.02);
  box-shadow: var(--shadow-2xl);
  filter: drop-shadow(0 20px 25px rgba(0, 0, 0, 0.4));
}

/* Jellyfin section styling */
.jf-wrap-div {
  margin-bottom: 1.5rem;
  line-height: 1.6;
}

/* Main body background */
.main-body {
  background-color: var(--bg-body) !important;
}

/* Legacy component styles for compatibility */
.my-component {
  border: 2px dashed red;
  padding: 1em;
  margin: 1em 0;
  background-image: url('background.png');
}

.comp-screen {
  background-color: #1f8091;
  height: 100%;
}

.comp-splashscreen-login {
  text-align: center;
}

.comp-approvalscreen-form {
  text-align: center;
  color: #FFF;
}

.comp-approvalscreen-note {
  font-size: 30px;
  font-weight: bold;
}

.comp-approvalscreen-formfield span {
  font-weight: bold;
  display: inline-block;
  width: 100px;
  text-align: right;
  margin-right: 6px;
}

.comp-approvalscreen-formfield input {
  color: #000;
}

.comp-approvalscreen-done {
  text-align: center;
  font-size: 30px;
  font-weight: bold;
  color: #FFF;
}

/* Logo specific styles - no transitions or effects */
.logo-link img,
.navbar-brand img {
  max-height: 100%;
  vertical-align: middle;
}

/* Remove any hover effects for logos */
.logo-link:hover img,
.navbar-brand:hover img {
  transform: none;
  filter: none;
}
