/* Animation Classes for Home Page */

/* Define keyframes that might not be in Tailwind */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideInUp {
  from {
    transform: translateY(100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes scaleIn {
  from {
    transform: scale(0.9);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

/* Reveal Animation */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger Animation */
.stagger-item {
  opacity: 0;
  transform: translateY(20px);
  animation: staggerReveal 0.5s ease-out forwards;
}

@keyframes staggerReveal {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Ensure animations from design system are available */
.animate-fade-in {
  animation: fadeIn 0.6s ease-out forwards;
}

.animate-slide-up {
  animation: slideInUp 0.6s ease-out forwards;
}

.animate-scale-in {
  animation: scaleIn 0.4s ease-out forwards;
}

.animate-float {
  animation: float 3s ease-in-out infinite;
}

@keyframes float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}

/* Animated Gradient */
.animated-gradient {
  background-size: 400% 400%;
  animation: gradientShift 15s ease infinite;
}

@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* Hover Scale */
.hover-scale {
  transition: transform 0.2s ease-in-out;
}

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

/* Hover Elevate */
.hover-elevate {
  transition: box-shadow 0.3s ease-in-out, transform 0.3s ease-in-out;
}

.hover-elevate:hover {
  transform: translateY(-4px);
}

/* Hover Lift - Transform only, no shadow */
.hover-lift {
  transition: transform 0.2s ease-in-out;
}

.hover-lift:hover {
  transform: translateY(-2px);
}
/* Design System - Authentication Components */

/* Auth Container */
.auth-container {
  min-height: calc(100vh - 4rem); /* Subtract navbar height */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: linear-gradient(135deg, var(--color-primary-50) 0%, var(--color-secondary-50) 100%);
}

/* Auth Card */
.auth-card {
  width: 100%;
  max-width: 28rem;
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  /* box-shadow: var(--shadow-xl); */
  /* border: 1px solid var(--color-border); */
  overflow: hidden;
  position: relative;
}

.auth-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-primary-500) 0%, var(--color-secondary-500) 100%);
}

/* Auth Header */
.auth-header {
  padding: var(--space-8) var(--space-6) var(--space-6);
  text-align: center;
  background: linear-gradient(135deg, 
    rgba(255, 255, 255, 0.9) 0%, 
    rgba(255, 255, 255, 0.7) 100%);
  backdrop-filter: blur(10px);
}

.auth-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin: 0 0 var(--space-2) 0;
  letter-spacing: -0.025em;
}

.auth-subtitle {
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  margin: 0;
  font-weight: var(--font-weight-normal);
}

/* Auth Form */
.auth-form {
  padding: var(--space-6);
}

.auth-form .form-group:last-of-type {
  margin-bottom: var(--space-6);
}

.auth-form .form-actions {
  margin-top: var(--space-8);
  margin-bottom: 0;
}

/* Auth Footer */
.auth-footer {
  padding: var(--space-6);
  border-top: 1px solid var(--color-border);
  background-color: var(--color-gray-25);
  text-align: center;
}

.auth-footer .auth-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.auth-footer .auth-links .link {
  font-size: var(--font-size-small);
  text-decoration: none;
  transition: var(--transition-all);
}

.auth-footer .auth-links .link:hover {
  text-decoration: underline;
}

/* Error Banner */
.error-banner {
  background-color: var(--color-error-50);
  border: 1px solid var(--color-error-200);
  border-left: 4px solid var(--color-error-500);
  color: var(--color-error-800);
  padding: var(--space-4);
}

.error-banner-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.error-banner-icon {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-error-500);
  flex-shrink: 0;
  margin-top: 0.125rem;
}

.error-banner-title {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-semibold);
  margin: 0;
  color: var(--color-error-800);
}

.error-banner-content {
  margin-left: 2.25rem;
}

.error-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.error-list-item {
  font-size: var(--font-size-small);
  color: var(--color-error-700);
  position: relative;
  padding-left: var(--space-4);
  margin-bottom: var(--space-1);
}

.error-list-item::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-error-500);
  font-weight: bold;
}

.error-list-item:last-child {
  margin-bottom: 0;
}

/* Notification Component */
.notification {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
}

.notification-info {
  background-color: var(--color-info-50);
  border-color: var(--color-info-500);
  color: var(--color-info-800);
}

.notification-success {
  background-color: var(--color-success-50);
  border-color: var(--color-success-500);
  color: var(--color-success-800);
}

.notification-warning {
  background-color: var(--color-warning-50);
  border-color: var(--color-warning-500);
  color: var(--color-warning-800);
}

.notification-error {
  background-color: var(--color-error-50);
  border-color: var(--color-error-500);
  color: var(--color-error-800);
}

.notification-icon {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
  margin-top: 0.125rem;
}

.notification-info .notification-icon {
  color: var(--color-info-500);
}

.notification-success .notification-icon {
  color: var(--color-success-500);
}

.notification-warning .notification-icon {
  color: var(--color-warning-500);
}

.notification-error .notification-icon {
  color: var(--color-error-500);
}

.notification-content {
  font-size: var(--font-size-small);
  line-height: 1.5;
}

/* Links Component */
.link {
  color: var(--color-primary-600);
  text-decoration: none;
  font-weight: var(--font-weight-medium);
  transition: var(--transition-all);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.link:hover {
  color: var(--color-primary-700);
  text-decoration: underline;
}

.link:focus {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.link-primary {
  color: var(--color-primary-600);
}

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

.link-secondary {
  color: var(--color-text-secondary);
  font-weight: var(--font-weight-normal);
}

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

.link-error {
  color: var(--color-error-600);
}

.link-error:hover {
  color: var(--color-error-700);
}

/* Responsive Adjustments */
@media (max-width: 480px) {
  .auth-container {
    min-height: calc(100vh - 4rem); /* Keep consistent height calculation */
    padding: var(--space-2);
    align-items: flex-start;
    padding-top: var(--space-8);
  }
  
  .auth-card {
    max-width: none;
  }
  
  .auth-header {
    padding: var(--space-6) var(--space-4) var(--space-4);
  }
  
  .auth-form {
    padding: var(--space-4);
  }
  
  .auth-footer {
    padding: var(--space-4);
  }
  
  .auth-title {
    font-size: var(--font-size-xl);
  }
}

/* Dark Mode Support */
[data-theme="dark"] .auth-container {
  background: linear-gradient(135deg, var(--color-gray-900) 0%, var(--color-gray-800) 100%);
}

[data-theme="dark"] .auth-card {
  background-color: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .auth-header {
  background: linear-gradient(135deg, 
    rgba(255, 255, 255, 0.05) 0%, 
    rgba(255, 255, 255, 0.02) 100%);
}

[data-theme="dark"] .auth-footer {
  background-color: var(--color-surface-variant);
  border-color: var(--color-border);
}

[data-theme="dark"] .error-banner {
  background-color: rgba(239, 68, 68, 0.1);
  border-color: var(--color-error-800);
  color: var(--color-error-200);
}

[data-theme="dark"] .error-banner-title {
  color: var(--color-error-300);
}

[data-theme="dark"] .error-list-item {
  color: var(--color-error-200);
}

[data-theme="dark"] .notification-info {
  background-color: rgba(59, 130, 246, 0.1);
  color: var(--color-info-200);
}

[data-theme="dark"] .notification-success {
  background-color: rgba(34, 197, 94, 0.1);
  color: var(--color-success-200);
}

[data-theme="dark"] .notification-warning {
  background-color: rgba(245, 158, 11, 0.1);
  color: var(--color-warning-200);
}

[data-theme="dark"] .notification-error {
  background-color: rgba(239, 68, 68, 0.1);
  color: var(--color-error-200);
}
/* Design System - Button Components */

/* Base Button Styles */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-primary);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  user-select: none;
  transition: var(--transition-all);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  vertical-align: middle;
  gap: 0.5rem;
}

/* Ripple Effect on Click */
.btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
  pointer-events: none;
}

.btn:active::after {
  width: 300px;
  height: 300px;
}

.btn:focus {
  outline: none;
  box-shadow: var(--focus-ring);
}

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

/* Ensure consistent icon sizing in buttons */
.btn svg {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
}

.btn-xs svg {
  width: 1rem;
  height: 1rem;
}

.btn-sm svg {
  width: 1.125rem;
  height: 1.125rem;
}

.btn-lg svg {
  width: 1.5rem;
  height: 1.5rem;
}

.btn-xl svg {
  width: 1.75rem;
  height: 1.75rem;
}

/* Button Sizes */
.btn-xs {
  padding: 0.25rem 0.75rem;
  font-size: var(--font-size-xs);
  line-height: 1rem;
  border-radius: var(--radius-md);
  min-height: 1.75rem;
}

.btn-sm {
  padding: 0.375rem 1rem;
  font-size: var(--font-size-small);
  line-height: 1.25rem;
  border-radius: var(--radius-md);
  min-height: 2rem;
}

.btn-md {
  padding: 0.5rem 1.25rem;
  font-size: var(--font-size-body);
  line-height: 1.5rem;
  border-radius: var(--radius-lg);
  min-height: 2.5rem;
}

.btn-lg {
  padding: 0.75rem 1.5rem;
  font-size: clamp(1rem, 1.8vw, 1.125rem);
  line-height: 1.75rem;
  border-radius: var(--radius-lg);
  min-height: 3rem;
}

.btn-xl {
  padding: 1rem 2rem;
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  line-height: 1.75rem;
  border-radius: var(--radius-xl);
  min-height: 3.5rem;
}

/* Button Variants */
.btn-primary {
  background: linear-gradient(135deg, var(--color-primary-600) 0%, var(--color-primary-700) 100%);
  color: white;
  border-color: var(--color-primary-600);
  box-shadow: var(--shadow-sm), var(--shadow-primary);
}

.btn-primary:hover {
  background: linear-gradient(135deg, var(--color-primary-700) 0%, var(--color-primary-800) 100%);
  color: white;
  border-color: var(--color-primary-700);
  box-shadow: var(--shadow-md), var(--shadow-primary);
  transform: translateY(-1px);
}

.btn-primary:active {
  background: var(--color-primary-800);
  color: white;
  box-shadow: var(--shadow-xs);
  transform: translateY(0);
}

.btn-secondary {
  background: transparent;
  color: var(--color-primary-600);
  border-color: var(--color-primary-600);
}

.btn-secondary:hover {
  background: var(--color-primary-50);
  color: var(--color-primary-700);
  border-color: var(--color-primary-700);
  box-shadow: var(--shadow-sm);
}

.btn-secondary:active {
  background: var(--color-primary-100);
}

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

.btn-ghost:hover {
  background: var(--color-gray-100);
  color: var(--color-text-primary);
}

.btn-ghost:active {
  background: var(--color-gray-200);
}

.btn-success {
  background: linear-gradient(135deg, var(--color-success-600) 0%, var(--color-success-700) 100%);
  color: white;
  border-color: var(--color-success-600);
  box-shadow: var(--shadow-sm), var(--shadow-success);
}

.btn-success:hover {
  background: linear-gradient(135deg, var(--color-success-700) 0%, var(--color-success-800) 100%);
  color: white;
  border-color: var(--color-success-700);
  box-shadow: var(--shadow-md), var(--shadow-success);
  transform: translateY(-1px);
}

.btn-warning {
  background: linear-gradient(135deg, var(--color-warning-500) 0%, var(--color-warning-600) 100%);
  color: white;
  border-color: var(--color-warning-500);
  box-shadow: var(--shadow-sm), var(--shadow-warning);
}

.btn-warning:hover {
  background: linear-gradient(135deg, var(--color-warning-600) 0%, var(--color-warning-700) 100%);
  color: white;
  border-color: var(--color-warning-600);
  box-shadow: var(--shadow-md), var(--shadow-warning);
  transform: translateY(-1px);
}

.btn-error {
  background: linear-gradient(135deg, var(--color-error-600) 0%, var(--color-error-700) 100%);
  color: white;
  border-color: var(--color-error-600);
  box-shadow: var(--shadow-sm), var(--shadow-error);
}

.btn-error:hover {
  background: linear-gradient(135deg, var(--color-error-700) 0%, var(--color-error-800) 100%);
  color: white;
  border-color: var(--color-error-700);
  box-shadow: var(--shadow-md), var(--shadow-error);
  transform: translateY(-1px);
}

/* Danger Button (alias for error) */
.btn-danger {
  background: linear-gradient(135deg, var(--color-error-600) 0%, var(--color-error-700) 100%);
  color: white;
  border-color: var(--color-error-600);
  box-shadow: var(--shadow-sm), var(--shadow-error);
}

.btn-danger:hover {
  background: linear-gradient(135deg, var(--color-error-700) 0%, var(--color-error-800) 100%);
  color: white;
  border-color: var(--color-error-700);
  box-shadow: var(--shadow-md), var(--shadow-error);
  transform: translateY(-1px);
}

/* Icon Buttons */
.btn-icon {
  padding: 0.5rem;
  min-width: 2.5rem;
  min-height: 2.5rem;
  gap: 0;
}

.btn-icon.btn-xs {
  padding: 0.25rem;
  min-width: 1.75rem;
  min-height: 1.75rem;
}

.btn-icon.btn-sm {
  padding: 0.375rem;
  min-width: 2rem;
  min-height: 2rem;
}

.btn-icon.btn-lg {
  padding: 0.75rem;
  min-width: 3rem;
  min-height: 3rem;
}

.btn-icon.btn-xl {
  padding: 1rem;
  min-width: 3.5rem;
  min-height: 3.5rem;
}

/* Button with Icon - DEPRECATED: Icon spacing is now handled automatically by .btn */
.btn-with-icon {
  /* Kept for backward compatibility */
}

/* Dark buttons need dark ripple */
.btn-secondary::after,
.btn-ghost::after {
  background: rgba(0, 0, 0, 0.1);
}

/* Ensure button text visibility */
.btn-primary span,
.btn-primary svg {
  color: white;
}

.btn-primary:hover span,
.btn-primary:hover svg {
  color: white;
}

.btn-primary:active span,
.btn-primary:active svg {
  color: white;
}

/* Full Width Button */
.btn-full {
  width: 100%;
}

/* Button Groups */
.btn-group {
  display: inline-flex;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.btn-group .btn {
  border-radius: 0;
  border-right-width: 0;
}

.btn-group .btn:first-child {
  border-top-left-radius: var(--radius-lg);
  border-bottom-left-radius: var(--radius-lg);
}

.btn-group .btn:last-child {
  border-top-right-radius: var(--radius-lg);
  border-bottom-right-radius: var(--radius-lg);
  border-right-width: 1px;
}

/* Loading State */
.btn-loading {
  color: transparent;
  pointer-events: none;
}

.btn-loading::after {
  content: "";
  position: absolute;
  width: 1rem;
  height: 1rem;
  top: 50%;
  left: 50%;
  margin-left: -0.5rem;
  margin-top: -0.5rem;
  border: 2px solid white;
  border-radius: 50%;
  border-top-color: transparent;
  animation: spin 0.8s linear infinite;
}

/* Ripple Effect */
.btn-ripple {
  position: relative;
  overflow: hidden;
}

.btn-ripple::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.btn-ripple:active::before {
  width: 300px;
  height: 300px;
}

/* Floating Action Button */
.fab {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  transition: var(--transition-all);
}

.fab:hover {
  box-shadow: var(--shadow-xl);
  transform: translateY(-2px);
}

.fab-mini {
  width: 2.5rem;
  height: 2.5rem;
}

/* Tailwind-style Button Classes */
.btn-primary-xs { @apply btn btn-primary btn-xs; }
.btn-primary-sm { @apply btn btn-primary btn-sm; }
.btn-primary-md { @apply btn btn-primary btn-md; }
.btn-primary-lg { @apply btn btn-primary btn-lg; }
.btn-primary-xl { @apply btn btn-primary btn-xl; }

.btn-secondary-xs { @apply btn btn-secondary btn-xs; }
.btn-secondary-sm { @apply btn btn-secondary btn-sm; }
.btn-secondary-md { @apply btn btn-secondary btn-md; }
.btn-secondary-lg { @apply btn btn-secondary btn-lg; }
.btn-secondary-xl { @apply btn btn-secondary btn-xl; }

.btn-ghost-xs { @apply btn btn-ghost btn-xs; }
.btn-ghost-sm { @apply btn btn-ghost btn-sm; }
.btn-ghost-md { @apply btn btn-ghost btn-md; }
.btn-ghost-lg { @apply btn btn-ghost btn-lg; }
.btn-ghost-xl { @apply btn btn-ghost btn-xl; }

/* Dark Mode Adjustments */
[data-theme="dark"] .btn-primary {
  background: linear-gradient(135deg, var(--color-primary-500) 0%, var(--color-primary-600) 100%);
  border-color: var(--color-primary-500);
}

[data-theme="dark"] .btn-primary:hover {
  background: linear-gradient(135deg, var(--color-primary-600) 0%, var(--color-primary-700) 100%);
  border-color: var(--color-primary-600);
}

[data-theme="dark"] .btn-secondary {
  color: var(--color-primary-400);
  border-color: var(--color-primary-400);
}

[data-theme="dark"] .btn-secondary:hover {
  background: rgba(59, 130, 246, 0.1);
  color: var(--color-primary-300);
  border-color: var(--color-primary-300);
}

[data-theme="dark"] .btn-ghost:hover {
  background: var(--color-surface-variant);
}
/* Design System - Card Components */

/* Base Card Styles */
.card {
  background: var(--color-surface);
  border-radius: var(--card-radius);
  /* border: 1px solid var(--color-border); */
  overflow: hidden;
  transition: var(--transition-all);
  position: relative;
}

/* Card Variants */
.card-elevated {
  box-shadow: var(--shadow-md);
  border-color: transparent;
}

.card-elevated:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}

.card-flat {
  box-shadow: none;
  background: var(--color-surface-variant);
}

.card-outlined {
  box-shadow: none;
  border-width: 2px;
}

.card-gradient {
  background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-gray-50) 100%);
  border-color: transparent;
  box-shadow: var(--shadow-sm);
}

/* Glass Card */
.card-glass {
  background: var(--glass-background);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-glass);
}

.card-glass:hover {
  box-shadow: var(--shadow-glass-hover);
  transform: translateY(-2px);
}

/* Card Sections */
.card-header {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

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

.card-footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border);
  background: var(--color-gray-50);
}

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

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

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

/* Card Without Sections */
.card-simple {
  padding: var(--space-6);
}

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

/* Interactive Cards */
.card-interactive {
  cursor: pointer;
  transition: var(--transition-all);
}

.card-interactive:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
  border-color: var(--color-primary-200);
}

.card-interactive:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

/* Card Colors */
.card-primary {
  background: var(--color-primary-50);
  border-color: var(--color-primary-200);
}

.card-primary .card-header {
  background: var(--color-primary-100);
  border-color: var(--color-primary-200);
}

.card-success {
  background: var(--color-success-50);
  border-color: var(--color-success-200);
}

.card-success .card-header {
  background: var(--color-success-100);
  border-color: var(--color-success-200);
}

.card-warning {
  background: var(--color-warning-50);
  border-color: var(--color-warning-200);
}

.card-warning .card-header {
  background: var(--color-warning-100);
  border-color: var(--color-warning-200);
}

.card-error {
  background: var(--color-error-50);
  border-color: var(--color-error-200);
}

.card-error .card-header {
  background: var(--color-error-100);
  border-color: var(--color-error-200);
}

/* Card Grid */
.card-grid {
  display: grid;
  gap: var(--space-6);
}

.card-grid-2 {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.card-grid-3 {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.card-grid-4 {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Metric Card */
.card-metric {
  padding: var(--space-6);
  text-align: center;
}

.card-metric-value {
  font-size: var(--font-size-h1);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.card-metric-label {
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

.card-metric-trend {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-3);
  font-size: var(--font-size-small);
}

.card-metric-trend.positive {
  color: var(--color-success-600);
}

.card-metric-trend.negative {
  color: var(--color-error-600);
}

/* Event Card */
.card-event {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-4);
  align-items: flex-start;
}

.card-event-icon {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background: var(--color-gray-100);
}

.card-event-content {
  flex: 1;
  min-width: 0;
}

.card-event-title {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-1);
}

.card-event-time {
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
}

.card-event-description {
  margin-top: var(--space-2);
  color: var(--color-text-secondary);
}

/* Child Card */
.card-child {
  text-align: center;
  padding: var(--space-6);
  transition: var(--transition-all);
}

.card-child-avatar {
  width: 5rem;
  height: 5rem;
  margin: 0 auto var(--space-4);
  border-radius: var(--radius-full);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.card-child-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card-child-name {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.card-child-info {
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
}

.card-child:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

/* Profile Card */
.card-profile {
  position: relative;
  overflow: visible;
}

.card-profile-cover {
  height: 8rem;
  background: linear-gradient(135deg, var(--color-primary-400) 0%, var(--color-primary-600) 100%);
  border-radius: var(--card-radius) var(--card-radius) 0 0;
}

.card-profile-avatar {
  position: absolute;
  top: 4rem;
  left: 50%;
  transform: translateX(-50%);
  width: 6rem;
  height: 6rem;
  border-radius: var(--radius-full);
  border: 4px solid var(--color-surface);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.card-profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card-profile-body {
  padding-top: 3.5rem;
  text-align: center;
}

/* Card Loading State */
.card-loading {
  position: relative;
  overflow: hidden;
}

.card-loading::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--color-surface);
  opacity: 0.7;
  z-index: 1;
}

.card-loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 2rem;
  height: 2rem;
  border: 3px solid var(--color-primary-200);
  border-top-color: var(--color-primary-600);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  z-index: 2;
}

/* Responsive Adjustments */
@media (max-width: 640px) {
  .card-header,
  .card-body,
  .card-footer,
  .card-simple {
    padding: var(--space-4);
  }
  
  .card-grid {
    gap: var(--space-4);
  }
  
  .card-event {
    flex-direction: column;
    text-align: center;
  }
  
  .card-event-icon {
    margin: 0 auto;
  }
}

/* Dark Mode Adjustments */
[data-theme="dark"] .card {
  background: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .card-flat {
  background: var(--color-surface-variant);
}

[data-theme="dark"] .card-footer {
  background: var(--color-surface-variant);
}

[data-theme="dark"] .card-glass {
  background: rgba(30, 41, 59, 0.8);
  border-color: rgba(71, 85, 105, 0.2);
}

[data-theme="dark"] .card-primary {
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.3);
}

[data-theme="dark"] .card-success {
  background: rgba(34, 197, 94, 0.1);
  border-color: rgba(34, 197, 94, 0.3);
}

[data-theme="dark"] .card-warning {
  background: rgba(245, 158, 11, 0.1);
  border-color: rgba(245, 158, 11, 0.3);
}

[data-theme="dark"] .card-error {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.3);
}
/* Design System - Child Header Component */

/* Container */
.child-header {
  background: var(--color-surface);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-6);
}

@media (min-width: 768px) {
  .child-header {
    padding: var(--space-6);
  }
}

/* Main Layout */
.child-header-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .child-header-content {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }
}

/* Info Section */
.child-header-info {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}

/* Avatar wrapper for structure module - includes age on mobile */
.child-header-avatar-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  text-align: center;
}

/* Avatar */
.child-header-avatar {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  border-radius: var(--radius-full);
  overflow: hidden;
  background: var(--color-primary-100);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-600);
}

@media (min-width: 768px) {
  .child-header-avatar {
    width: 4rem;
    height: 4rem;
  }
}

.child-header-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.child-header-avatar-icon {
  width: 1.5rem;
  height: 1.5rem;
}

@media (min-width: 768px) {
  .child-header-avatar-icon {
    width: 2rem;
    height: 2rem;
  }
}

/* Details */
.child-header-details {
  flex: 1;
  min-width: 0; /* Enable text truncation */
}

/* Name Container */
.child-header-name-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-1);
}

@media (min-width: 768px) {
  .child-header-name-container {
    flex-direction: row;
    align-items: baseline;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
  }
}

/* Hide age inline on mobile for structure module */
@media (max-width: 767px) {
  .child-header-age-inline-mobile-hide {
    display: none !important;
  }
}

/* Child Name with responsive sizing */
.child-header-name {
  font-family: 'Crafty Girls', cursive;
  font-size: clamp(1.25rem, 4vw, 1.5rem);
  font-weight: var(--font-weight-normal);
  color: var(--color-primary-600);
  line-height: 1.2;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
  max-width: 100%;
}

/* Age Badge */
.child-header-age {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  background: var(--color-gray-100);
  color: var(--color-text-secondary);
  border-radius: var(--radius-full);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  align-self: flex-start;
}

/* Age below avatar on mobile for structure module */
.child-header-age-below {
  display: inline-flex;
  font-size: var(--font-size-xs);
  padding: 0 var(--space-1);
}

@media (min-width: 768px) {
  .child-header-age {
    font-size: var(--font-size-body);
    margin-left: var(--space-2);
  }
  
  .child-header-age-below {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .child-header-age-below {
    display: inline-flex !important;
  }
}

/* Meta Information */
.child-header-meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
}

/* Hide on mobile for parent module */
@media (max-width: 767px) {
  .child-header-meta-mobile-hide {
    display: none;
  }
}

.child-header-meta-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
}

.child-header-meta-icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-text-disabled);
  margin-top: 0.125rem; /* 2px - align with text baseline */
}

/* Daycare Badge */
.child-header-daycare {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  background: var(--color-info-100);
  color: var(--color-info-800);
  border-radius: var(--radius-full);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  max-width: 100%;
  width: fit-content;
}

/* Hide daycare on mobile for structure module */
@media (max-width: 767px) {
  .child-header-daycare-mobile-hide {
    display: none;
  }
}

.child-header-daycare-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Actions Section */
.child-header-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

@media (max-width: 767px) {
  .child-header-actions {
    width: 100%;
  }
}

/* Action Buttons */
.child-header-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: 0.625rem 0.75rem; /* 10px 12px */
  border-radius: var(--radius-md);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: var(--transition-all);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
}

@media (min-width: 360px) {
  .child-header-action {
    padding: 0.625rem 1rem; /* 10px 16px */
  }
}

@media (min-width: 768px) {
  .child-header-action {
    padding: 0.5rem 0.75rem; /* 8px 12px - original spacing */
    flex: initial;
  }
}

/* Mobile: Smaller text on very small screens */
@media (max-width: 359px) {
  .child-header-action {
    font-size: 0.75rem; /* 12px */
    gap: 0.25rem;
  }
  
  .child-header-action-icon {
    width: 0.875rem;
    height: 0.875rem;
  }
}

.child-header-action-icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

/* Show/hide text based on screen size */
.child-header-action-text-short {
  display: inline;
}

.child-header-action-text-full {
  display: none;
}

@media (min-width: 400px) {
  .child-header-action-text-short {
    display: none;
  }
  
  .child-header-action-text-full {
    display: inline;
  }
}

/* Action Variants */
.child-header-action-primary {
  background: var(--color-primary-600);
  color: white;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.child-header-action-primary:hover {
  background: var(--color-primary-700);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  transform: translateY(-1px);
}

.child-header-action-edit {
  background: var(--color-warning-500);
  color: white;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.child-header-action-edit:hover {
  background: var(--color-warning-600);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  transform: translateY(-1px);
}

.child-header-action-danger {
  background: var(--color-error-500);
  color: white;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.child-header-action-danger:hover {
  background: var(--color-error-600);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  transform: translateY(-1px);
}

.child-header-action-success {
  background: var(--color-success-500);
  color: white;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.child-header-action-success:hover {
  background: var(--color-success-600);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);
  transform: translateY(-1px);
}

/* Icon colors for better contrast */
.child-header-action-primary .child-header-action-icon,
.child-header-action-edit .child-header-action-icon,
.child-header-action-danger .child-header-action-icon,
.child-header-action-success .child-header-action-icon {
  color: white;
}

/* Navigation Tabs */
.child-header-nav {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.child-header-nav-tabs {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.child-header-nav-tab {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-md);
  background: var(--color-gray-100);
  border: 1px solid var(--color-gray-200);
  transition: var(--transition-all);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.child-header-nav-tab:hover {
  background: var(--color-gray-200);
  color: var(--color-text-primary);
  border-color: var(--color-gray-300);
  transform: translateY(-1px);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);
}

.child-header-nav-tab-active {
  background: var(--color-primary-600);
  color: white;
  font-weight: var(--font-weight-medium);
  border-color: var(--color-primary-700);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.child-header-nav-tab-active:hover {
  background: var(--color-primary-700);
  border-color: var(--color-primary-800);
}

/* Tooltip for truncated text */
.child-header-tooltip {
  position: relative;
}

.child-header-tooltip-content {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  padding: var(--space-2);
  background: var(--color-gray-900);
  color: white;
  font-size: var(--font-size-small);
  border-radius: var(--radius-md);
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-all);
  z-index: var(--z-tooltip);
  margin-bottom: var(--space-1);
}

.child-header-tooltip:hover .child-header-tooltip-content {
  opacity: 1;
  visibility: visible;
}

/* Status badges for daily handling */
.child-header-status-present {
  background: var(--color-success-100);
  color: var(--color-success-800);
}

.child-header-status-absent {
  background: var(--color-gray-100);
  color: var(--color-gray-600);
}

/* Secondary action button */
.child-header-action-secondary {
  background: var(--color-gray-200);
  color: var(--color-gray-700);
}

.child-header-action-secondary:hover {
  background: var(--color-gray-300);
  transform: translateY(-1px);
}

/* Dark Mode Support */
[data-theme="dark"] .child-header {
  background: var(--color-surface);
}

[data-theme="dark"] .child-header-avatar {
  background: var(--color-primary-900);
  color: var(--color-primary-300);
}

[data-theme="dark"] .child-header-age {
  background: var(--color-surface-variant);
  color: var(--color-text-secondary);
}

[data-theme="dark"] .child-header-daycare {
  background: rgba(59, 130, 246, 0.2);
  color: var(--color-info-300);
}

[data-theme="dark"] .child-header-action-primary {
  background: var(--color-primary-600);
}

[data-theme="dark"] .child-header-action-primary:hover {
  background: var(--color-primary-500);
}

[data-theme="dark"] .child-header-action-edit {
  background: var(--color-warning-600);
  color: white;
}

[data-theme="dark"] .child-header-action-edit:hover {
  background: var(--color-warning-700);
}

[data-theme="dark"] .child-header-action-danger {
  background: var(--color-error-600);
  color: white;
}

[data-theme="dark"] .child-header-action-danger:hover {
  background: var(--color-error-700);
}

[data-theme="dark"] .child-header-action-success {
  background: var(--color-success-600);
  color: white;
}

[data-theme="dark"] .child-header-action-success:hover {
  background: var(--color-success-700);
}

[data-theme="dark"] .child-header-action-secondary {
  background: var(--color-gray-700);
  color: var(--color-gray-200);
}

[data-theme="dark"] .child-header-action-secondary:hover {
  background: var(--color-gray-600);
}

[data-theme="dark"] .child-header-nav-tab {
  background: var(--color-gray-700);
  color: var(--color-gray-200);
  border-color: var(--color-gray-600);
}

[data-theme="dark"] .child-header-nav-tab:hover {
  background: var(--color-gray-600);
  color: var(--color-gray-100);
  border-color: var(--color-gray-500);
}

[data-theme="dark"] .child-header-nav-tab-active {
  background: var(--color-primary-600);
  color: white;
  border-color: var(--color-primary-700);
}

[data-theme="dark"] .child-header-nav-tab-active:hover {
  background: var(--color-primary-500);
  border-color: var(--color-primary-600);
}
/* frozen_string_literal: true */

/* Daily Handling Module Specific Styles */

/* Event Type Colors - Matching event list colors */
:root {
  /* Event Colors - Same as event list icons/dots */
  --event-arrival: #3B82F6;        /* Blue-500 */
  --event-departure: #A855F7;      /* Purple-500 */
  --event-eat: #22C55E;            /* Green-500 (actual event type is 'eat') */
  --event-nap-start: #6366F1;      /* Indigo-500 */
  --event-nap-end: #818CF8;        /* Indigo-400 */
  --event-medication: #EF4444;     /* Red-500 */
  --event-daily-care: #14B8A6;     /* Teal-500 (actual event type is 'daily_care') */
  --event-other: #EAB308;          /* Yellow-500 */
  
  /* Event Hover Colors - Darker variants */
  --event-arrival-hover: #2563eb;   /* Blue-600 */
  --event-departure-hover: #9333ea; /* Purple-600 */
  --event-eat-hover: #16a34a;       /* Green-600 */
  --event-nap-start-hover: #4f46e5; /* Indigo-600 */
  --event-nap-end-hover: #6366f1;   /* Indigo-500 */
  --event-medication-hover: #dc2626; /* Red-600 */
  --event-daily-care-hover: #0f766e; /* Teal-600 */
  --event-other-hover: #ca8a04;     /* Yellow-600 */
}

/* Touch-Optimized Event Buttons */
.event-btn {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem;
  border-radius: 0.75rem;
  color: white;
  font-weight: 600; /* Increased weight for better contrast */
  transition: all 200ms;
  min-height: 80px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5); /* Add text shadow for better readability */
}

.event-btn:active {
  transform: scale(0.95);
}

.event-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.event-btn:active {
  transform: scale(0.95);
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
}

/* Event Button Icons */
.event-btn i {
  font-size: 1.5rem; /* 24px - text-2xl */
}

/* Event Button Text */
.event-btn span {
  font-size: 0.875rem; /* 14px - text-sm */
  font-weight: 600; /* Increase weight for better readability */
}

/* Event Type Specific Styles */
.event-btn-arrival {
  background-color: var(--event-arrival);
}

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

.event-btn-departure {
  background-color: var(--event-departure);
}

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

.event-btn-eat {
  background-color: var(--event-eat);
}

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

.event-btn-nap-start {
  background-color: var(--event-nap-start);
}

.event-btn-nap-start:hover {
  background-color: var(--event-nap-start-hover);
}

.event-btn-nap-end {
  background-color: var(--event-nap-end);
}

.event-btn-nap-end:hover {
  background-color: var(--event-nap-end-hover);
}

.event-btn-medication {
  background-color: var(--event-medication);
}

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

.event-btn-daily-care {
  background-color: var(--event-daily-care);
}

.event-btn-daily-care:hover {
  background-color: var(--event-daily-care-hover);
}

.event-btn-other {
  background-color: var(--event-other);
}

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

/* Enhanced Child Cards */
.child-card {
  position: relative;
  background-color: white;
  border-radius: 0.5rem;
  padding: 1rem;
  transition: all 200ms;
  cursor: pointer;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
}

.child-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

.child-card-present {
  border: 2px solid #4ade80; /* border-green-400 */
}

.child-card-absent {
  border: 1px solid #d1d5db; /* border-gray-300 */
}

.child-card-header {
  position: relative;
}

.child-card-name {
  font-size: 1rem; /* text-base */
  font-weight: 600; /* font-semibold */
  color: #111827; /* text-gray-900 */
  margin-top: 0.5rem; /* mt-2 */
}

.child-card-status {
  position: absolute;
  top: -0.5rem; /* -top-2 */
  right: -0.5rem; /* -right-2 */
  font-size: 1.125rem; /* text-lg */
}

.child-card-status-present {
  color: #16a34a; /* text-green-600 */
}

.child-card-status-absent {
  color: #9ca3af; /* text-gray-400 */
}

.child-card-info {
  font-size: 0.875rem; /* text-sm */
  color: #4b5563; /* text-gray-600 */
  margin-top: 0.25rem; /* mt-1 */
}

/* Loading States */
.event-btn-loading {
  pointer-events: none;
  opacity: 0.75;
  position: relative;
}

.event-btn-loading::after {
  content: "";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.9);
  border-radius: inherit;
}

.event-btn-loading::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.5rem; /* w-6 */
  height: 1.5rem; /* h-6 */
  border: 2px solid #d1d5db; /* border-gray-300 */
  border-top-color: #4b5563; /* border-t-gray-600 */
  border-radius: 50%; /* rounded-full */
  animation: spin 1s linear infinite; /* animate-spin */
  margin-left: -12px;
  margin-top: -12px;
  z-index: 10;
}

/* Success Animation */
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes success-pulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.8;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.event-success {
  animation: success-pulse 0.5s ease-in-out;
}

/* Mobile Optimizations */
@media (max-width: 768px) {
  .event-btn {
    min-height: 90px;
    /* Removed font-weight override - using desktop styling */
  }
  
  /* Removed icon size override - using desktop styling */
  /* Removed text font-weight override - using desktop styling */
  
  .child-card {
    padding: 1rem; /* p-4 */
  }
}

/* Grid Layout for Event Buttons */
.event-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* grid-cols-2 */
  gap: 1rem; /* gap-4 */
}

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

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

/* Toast Notifications */
.toast {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  min-width: 300px;
  max-width: 28rem;
  position: relative;
  animation: toast-slide-in 0.3s ease-out;
  opacity: 0;
  transform: translateX(100%);
}

.toast.show {
  opacity: 1;
  transform: translateX(0);
}

@keyframes toast-slide-in {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes toast-slide-out {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}

.toast-dismissing {
  animation: toast-slide-out 0.3s ease-in forwards;
}

.toast-success {
  background-color: #f0fdf4;
  border: 1px solid #bbf7d0;
}

.toast-error {
  background-color: #fef2f2;
  border: 1px solid #fecaca;
}

.toast-info {
  background-color: #eff6ff;
  border: 1px solid #bfdbfe;
}

.toast-icon {
  flex-shrink: 0;
}

.toast-content {
  flex: 1;
}

.toast-message {
  font-size: 0.875rem;
  font-weight: 500;
  color: #111827;
}

.toast-close {
  margin-left: 1rem;
  color: #9ca3af;
  transition: color 150ms;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-size: 1rem;
}

.toast-close:hover {
  color: #4b5563;
}

/* Quick Actions Floating Button */
.quick-actions {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 40;
}

.quick-actions-btn {
  width: 3.5rem;
  height: 3.5rem;
  background-color: #2563eb;
  color: white;
  border-radius: 50%;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 300ms;
}

.quick-actions-btn:hover {
  background-color: #1d4ed8;
  transform: scale(1.1);
}

.quick-actions-btn:active {
  transform: scale(0.95);
}

.quick-actions-menu {
  position: absolute;
  bottom: 4rem;
  right: 0;
  background-color: white;
  border-radius: 0.5rem;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  padding: 0.5rem;
  min-width: 180px;
  animation: fade-in-up 0.2s ease-out;
}

@keyframes fade-in-up {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.quick-action-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  color: #374151;
  border-radius: 0.5rem;
  transition: background-color 150ms;
}

.quick-action-item:hover {
  background-color: #f9fafb;
}

.quick-action-item i {
  color: #6b7280;
  width: 1.25rem;
  text-align: center;
}

.quick-action-item span {
  font-size: 0.875rem;
  font-weight: 500;
}

/* Enhanced Recording Feedback */
.recording-active {
  position: relative;
  overflow: hidden;
}

.recording-active::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(239, 68, 68, 0.15);
  animation: recording-pulse 1.5s ease-in-out infinite;
}

@keyframes recording-pulse {
  0%, 100% {
    opacity: 0.3;
  }
  50% {
    opacity: 0.6;
  }
}

/* Recording indicator overlay */
.recording-indicator {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.9);
  border-radius: inherit;
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease-in-out;
}

.recording-indicator.active {
  opacity: 1;
  pointer-events: auto;
}

/* Microphone animation */
.recording-mic {
  font-size: 2.5rem;
  color: white;
  animation: mic-pulse 1s ease-in-out infinite;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}

@keyframes mic-pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.8;
  }
}

/* Sound waves animation */
.sound-waves {
  position: absolute;
  width: 100px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sound-wave {
  position: absolute;
  width: 80px;
  height: 80px;
  border: 3px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  animation: sound-wave 1.5s ease-out infinite;
}

.sound-wave:nth-child(2) {
  animation-delay: 0.3s;
}

.sound-wave:nth-child(3) {
  animation-delay: 0.6s;
}

@keyframes sound-wave {
  0% {
    transform: scale(1);
    opacity: 0.4;
  }
  100% {
    transform: scale(1.5);
    opacity: 0;
  }
}

/* Recording text */
.recording-text {
  color: white;
  font-size: 0.75rem;
  font-weight: 600;
  margin-top: 8px;
  animation: fade-in 0.3s ease-out;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* Prevent interaction with other elements while recording */
.recording-mode .event-grid {
  pointer-events: none;
  opacity: 0.5;
  filter: blur(2px);
  transition: all 0.3s ease-out;
}

/* Recording button specific style */
.event-button.recording {
  animation: recording-border 1.5s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4);
}

@keyframes recording-border {
  0% {
    box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(239, 68, 68, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(239, 68, 68, 0);
  }
}

/* Collapsible Help Sections - Remove all browser default markers */
details summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
}

details summary::-webkit-details-marker {
  display: none;
}

details summary::-moz-list-bullet {
  list-style: none;
}

details summary::marker {
  display: none;
}

details summary::before {
  display: none;
}

/* Specific help section styling */
.help-section details summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
}

/* Smooth arrow rotation for collapsible sections */
.help-section details summary svg {
  transition: transform 0.2s ease-in-out;
}

.help-section details[open] summary svg {
  transform: rotate(180deg);
}

/* Enhance visual feedback for collapsible sections */
.help-section details summary:hover {
  background-color: rgba(59, 130, 246, 0.1);
}

.help-section details summary:focus {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
  border-radius: 0.5rem;
}

/* Smooth content expansion */
.help-section details[open] > summary + * {
  animation: expand-content 0.3s ease-out;
}

@keyframes expand-content {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Footer Component */
.footer {
  background-color: white;
  border-top: 1px solid rgb(229 231 235);
  padding: 1.5rem 0;
  margin-top: auto;
}

@media (min-width: 768px) {
  .footer {
    padding: 2rem 0;
  }
}

.footer-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1rem;
}

.footer-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  text-align: center;
}

@media (min-width: 768px) {
  .footer-content {
    gap: 1.5rem;
  }
}

/* Footer sections */
.footer-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

@media (min-width: 768px) {
  .footer-main {
    flex-direction: row;
    gap: 2rem;
  }
}

.footer-copyright {
  font-size: 0.875rem;
  color: rgb(75 85 99);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.footer-links {
  display: flex;
  align-items: center;
  gap: 1rem;
}

@media (min-width: 768px) {
  .footer-links {
    gap: 1.5rem;
  }
}

.footer-link {
  font-size: 0.875rem;
  color: var(--color-primary-600);
  text-underline-offset: 4px;
  transition: color var(--duration-base) var(--ease-in-out);
}

.footer-link:hover {
  color: var(--color-primary-700);
  text-decoration: underline;
}

.footer-link.admin {
  color: var(--color-admin);
}

.footer-link.admin:hover {
  color: var(--color-admin);
  opacity: 0.8;
}

/* Footer badge */
.footer-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  background-color: rgba(239, 68, 68, 0.1);
  color: var(--color-admin);
  font-size: 0.875rem;
  font-weight: 700;
}

/* Logo in footer */
.footer-logo {
  display: inline-flex;
  align-items: center;
  font-family: 'Crafty Girls', cursive;
  font-size: 1.25rem;
  color: #4285F4;
  letter-spacing: 0.05em;
}

.footer-logo .u-smile {
  color: #FFBFAE;
  margin-left: 2px;
  margin-right: 2px;
}

/* Responsive adjustments */
@media (max-width: 640px) {
  .footer {
    padding: 1rem 0;
  }
  
  .footer-content {
    gap: 0.75rem;
  }
  
  .footer-main {
    gap: 0.75rem;
  }
  
  .footer-links {
    gap: 0.75rem;
  }
}
/* Design System - Form Components */

/* Form Groups */
.form-group {
  margin-bottom: var(--space-6);
}

.form-group:last-child {
  margin-bottom: 0;
}

/* Labels */
.form-label {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
}

.form-label-required::after {
  content: " *";
  color: var(--color-error-600);
}

/* Base Input Styles */
.form-input,
.form-textarea,
.form-select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-primary);
  font-size: var(--font-size-body);
  line-height: 1.5;
  color: var(--color-text-primary);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--input-radius);
  transition: var(--transition-all);
  appearance: none;
}

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

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-text-disabled);
}

/* Input Sizes */
.form-input-sm,
.form-select-sm {
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-small);
}

.form-input-lg,
.form-select-lg {
  padding: var(--space-4) var(--space-5);
  font-size: clamp(1rem, 1.8vw, 1.125rem);
}

/* Input States */
.form-input-success,
.form-textarea-success,
.form-select-success {
  border-color: var(--color-success-500);
}

.form-input-success:focus,
.form-textarea-success:focus,
.form-select-success:focus {
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.1);
}

.form-input-error,
.form-textarea-error,
.form-select-error {
  border-color: var(--color-error-500);
}

.form-input-error:focus,
.form-textarea-error:focus,
.form-select-error:focus {
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

.form-input:disabled,
.form-textarea:disabled,
.form-select:disabled {
  background-color: var(--color-surface);
  color: var(--color-text-disabled);
  cursor: not-allowed;
  opacity: 0.6;
  border-color: var(--color-gray-300);
}

/* Textarea */
.form-textarea {
  min-height: 6rem;
  resize: vertical;
}

.form-textarea-auto {
  resize: none;
  overflow: hidden;
}

/* Select */
.form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  padding-right: 2.5rem;
}

/* Input with Icon */
.form-input-group {
  position: relative;
  display: flex;
  align-items: stretch;
}

.form-input-icon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-text-secondary);
  pointer-events: none;
}

.form-input-icon-left {
  left: var(--space-3);
}

.form-input-icon-right {
  right: var(--space-3);
}

.form-input-with-icon-left {
  padding-left: 2.75rem;
}

.form-input-with-icon-right {
  padding-right: 2.75rem;
}

/* Input Addon */
.form-input-addon {
  display: flex;
  align-items: center;
  padding: 0 var(--space-4);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
}

.form-input-addon-left {
  border-right: 0;
  border-radius: var(--input-radius) 0 0 var(--input-radius);
}

.form-input-addon-right {
  border-left: 0;
  border-radius: 0 var(--input-radius) var(--input-radius) 0;
}

.form-input-group .form-input {
  border-radius: 0;
}

.form-input-group .form-input:first-child {
  border-radius: var(--input-radius) 0 0 var(--input-radius);
}

.form-input-group .form-input:last-child {
  border-radius: 0 var(--input-radius) var(--input-radius) 0;
}

/* Floating Labels */
.form-floating {
  position: relative;
}

.form-floating .form-input {
  padding-top: 1.625rem;
  padding-bottom: 0.625rem;
}

.form-floating .form-label {
  position: absolute;
  top: 50%;
  left: var(--space-4);
  transform: translateY(-50%);
  transition: var(--transition-all);
  pointer-events: none;
  margin: 0;
}

.form-floating .form-input:focus ~ .form-label,
.form-floating .form-input:not(:placeholder-shown) ~ .form-label {
  top: 0.625rem;
  transform: translateY(0);
  font-size: var(--font-size-xs);
  color: var(--color-primary-600);
}

/* Checkbox and Radio */
.form-checkbox,
.form-radio {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  user-select: none;
}

.form-checkbox input[type="checkbox"],
.form-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.form-checkbox-input,
.form-radio-input {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid var(--color-border);
  background-color: var(--color-surface);
  transition: var(--transition-all);
  flex-shrink: 0;
}

.form-checkbox-input {
  border-radius: var(--radius-sm);
}

.form-radio-input {
  border-radius: var(--radius-full);
}

.form-checkbox input[type="checkbox"]:checked ~ .form-checkbox-input,
.form-radio input[type="radio"]:checked ~ .form-radio-input {
  background-color: var(--color-primary-600);
  border-color: var(--color-primary-600);
}

.form-checkbox-input::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
  background-size: 100%;
  opacity: 0;
  transform: scale(0);
  transition: var(--transition-all);
}

.form-checkbox input[type="checkbox"]:checked ~ .form-checkbox-input::after {
  opacity: 1;
  transform: scale(1);
}

.form-radio-input::after {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  margin: 0.25rem;
  border-radius: var(--radius-full);
  background-color: white;
  opacity: 0;
  transform: scale(0);
  transition: var(--transition-all);
}

.form-radio input[type="radio"]:checked ~ .form-radio-input::after {
  opacity: 1;
  transform: scale(1);
}

.form-checkbox-label,
.form-radio-label {
  margin-left: var(--space-2);
  font-size: var(--font-size-body);
  color: var(--color-text-primary);
}

/* Switch */
.form-switch {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  user-select: none;
}

.form-switch input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.form-switch-input {
  display: inline-block;
  width: 3rem;
  height: 1.5rem;
  background-color: var(--color-gray-300);
  border-radius: var(--radius-full);
  transition: var(--transition-all);
  position: relative;
  border: 2px solid var(--color-gray-300);
}

.form-switch-input::after {
  content: "";
  position: absolute;
  top: 0.125rem;
  left: 0.125rem;
  width: 1.25rem;
  height: 1.25rem;
  background-color: white;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-all);
}

.form-switch input[type="checkbox"]:checked ~ .form-switch-input {
  background-color: var(--color-primary-600);
}

.form-switch input[type="checkbox"]:checked ~ .form-switch-input::after {
  transform: translateX(1.5rem);
}

.form-switch-label {
  margin-left: var(--space-2);
  font-size: var(--font-size-body);
  color: var(--color-text-primary);
}

/* File Input */
.form-file {
  position: relative;
  display: inline-block;
  cursor: pointer;
  overflow: hidden;
}

.form-file input[type="file"] {
  position: absolute;
  left: -9999px;
}

.form-file-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--input-radius);
  font-size: var(--font-size-body);
  color: var(--color-text-primary);
  transition: var(--transition-all);
}

.form-file:hover .form-file-label {
  background-color: var(--color-surface);
  border-color: var(--color-primary-500);
}

/* Range Slider */
.form-range {
  width: 100%;
  height: 0.5rem;
  background-color: var(--color-gray-200);
  border-radius: var(--radius-full);
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid var(--color-gray-200);
}

.form-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1.5rem;
  height: 1.5rem;
  background-color: var(--color-primary-600);
  border-radius: var(--radius-full);
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: var(--transition-all);
}

.form-range::-webkit-slider-thumb:hover {
  transform: scale(1.1);
  box-shadow: var(--shadow-lg);
}

/* Form Messages */
.form-message {
  margin-top: var(--space-2);
  font-size: var(--font-size-small);
}

.form-message-error {
  color: var(--color-error-600);
}

.form-message-success {
  color: var(--color-success-600);
}

.form-message-info {
  color: var(--color-info);
}

/* Form Actions */
.form-actions {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-8);
}

.form-actions-right {
  justify-content: flex-end;
}

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

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

/* Inline Forms */
.form-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}

.form-inline .form-group {
  margin-bottom: 0;
}

/* Dark Mode Adjustments */
[data-theme="dark"] .form-input,
[data-theme="dark"] .form-textarea,
[data-theme="dark"] .form-select {
  background-color: var(--color-surface);
  border-color: var(--color-border);
  color: var(--color-text-primary);
}

[data-theme="dark"] .form-input:focus,
[data-theme="dark"] .form-textarea:focus,
[data-theme="dark"] .form-select:focus {
  border-color: var(--color-primary-400);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}

[data-theme="dark"] .form-input-addon {
  background-color: var(--color-surface-variant);
  border-color: var(--color-border);
}

[data-theme="dark"] .form-checkbox-input,
[data-theme="dark"] .form-radio-input {
  background-color: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .form-switch-input {
  background-color: var(--color-gray-600);
}

[data-theme="dark"] .form-range {
  background-color: var(--color-gray-600);
}
/* Design System - Modal Components */

/* Modal Container */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  z-index: var(--z-modal);
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-all);
}

.modal-open {
  opacity: 1;
  visibility: visible;
}

/* Modal Backdrop */
.modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: var(--z-modal-backdrop);
  transition: var(--transition-all);
}

[data-theme="dark"] .modal-backdrop {
  background: rgba(0, 0, 0, 0.7);
}

/* Modal Content */
.modal-content {
  position: relative;
  width: 100%;
  max-width: 32rem;
  max-height: 90vh;
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  overflow: hidden;
  z-index: var(--z-modal);
  transform: scale(0.9) translateY(20px);
  transition: var(--transition-all);
}

.modal-open .modal-content {
  transform: scale(1) translateY(0);
}

/* Modal Sizes */
.modal-sm .modal-content {
  max-width: 24rem;
}

.modal-lg .modal-content {
  max-width: 48rem;
}

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

.modal-full .modal-content {
  max-width: 100%;
  max-height: 100%;
  height: 100%;
  border-radius: 0;
}

/* Modal Header */
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.modal-title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin: 0;
}

.modal-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: var(--transition-all);
}

.modal-close:hover {
  background: var(--color-gray-100);
  color: var(--color-text-primary);
}

/* Modal Body */
.modal-body {
  padding: var(--space-6);
  overflow-y: auto;
  max-height: calc(90vh - 8rem);
}

/* Modal Footer */
.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border);
  background: var(--color-gray-50);
}

/* Sheet Modal (Slide from side) */
.modal-sheet .modal-content {
  max-width: 24rem;
  height: 100%;
  max-height: 100%;
  border-radius: 0;
  transform: translateX(100%);
}

.modal-sheet.modal-open .modal-content {
  transform: translateX(0);
}

.modal-sheet-left .modal-content {
  transform: translateX(-100%);
}

.modal-sheet-left.modal-open .modal-content {
  transform: translateX(0);
}

/* Bottom Sheet (Mobile) */
.modal-bottom-sheet .modal-content {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  max-width: 100%;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  transform: translateY(100%);
}

.modal-bottom-sheet.modal-open .modal-content {
  transform: translateY(0);
}

.modal-bottom-sheet .modal-header {
  position: relative;
  padding-top: var(--space-4);
}

.modal-bottom-sheet .modal-header::before {
  content: "";
  position: absolute;
  top: var(--space-2);
  left: 50%;
  transform: translateX(-50%);
  width: 3rem;
  height: 0.25rem;
  background: var(--color-gray-300);
  border-radius: var(--radius-full);
}

/* Alert Modal */
.modal-alert .modal-content {
  max-width: 24rem;
  text-align: center;
}

.modal-alert .modal-body {
  padding: var(--space-8);
}

.modal-alert-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  margin: 0 auto var(--space-4);
  border-radius: var(--radius-full);
}

.modal-alert-icon-success {
  background: var(--color-success-100);
  color: var(--color-success-600);
}

.modal-alert-icon-warning {
  background: var(--color-warning-100);
  color: var(--color-warning-600);
}

.modal-alert-icon-error {
  background: var(--color-error-100);
  color: var(--color-error-600);
}

.modal-alert-icon-info {
  background: var(--color-primary-100);
  color: var(--color-primary-600);
}

.modal-alert-title {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.modal-alert-description {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
}

/* Confirmation Modal */
.modal-confirm .modal-footer {
  justify-content: center;
}

/* Loading Modal */
.modal-loading .modal-content {
  max-width: 16rem;
  text-align: center;
}

.modal-loading .modal-body {
  padding: var(--space-8);
}

.modal-spinner {
  display: inline-block;
  width: 3rem;
  height: 3rem;
  margin: 0 auto var(--space-4);
  border: 3px solid var(--color-gray-200);
  border-top-color: var(--color-primary-600);
  border-radius: var(--radius-full);
  animation: spin 1s linear infinite;
}

/* Image Modal */
.modal-image .modal-content {
  max-width: 90vw;
  max-height: 90vh;
  background: transparent;
  box-shadow: none;
}

.modal-image .modal-body {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-image img {
  max-width: 100%;
  max-height: 90vh;
  object-fit: contain;
  border-radius: var(--radius-lg);
}

/* Popover */
.popover {
  position: absolute;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--space-4);
  z-index: var(--z-popover);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: var(--transition-all);
}

.popover-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.popover-arrow {
  position: absolute;
  width: 0.75rem;
  height: 0.75rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  transform: rotate(45deg);
}

.popover-top .popover-arrow {
  bottom: -0.375rem;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  border-top: none;
  border-left: none;
}

.popover-bottom .popover-arrow {
  top: -0.375rem;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  border-bottom: none;
  border-right: none;
}

.popover-left .popover-arrow {
  right: -0.375rem;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  border-left: none;
  border-bottom: none;
}

.popover-right .popover-arrow {
  left: -0.375rem;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  border-right: none;
  border-top: none;
}

/* Tooltip */
.tooltip {
  position: absolute;
  background: var(--color-gray-900);
  color: white;
  font-size: var(--font-size-small);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  white-space: nowrap;
  z-index: var(--z-tooltip);
  pointer-events: none;
  opacity: 0;
  transform: translateY(-5px);
  transition: var(--transition-all);
}

.tooltip-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Toast/Notification */
.toast-container {
  position: fixed;
  top: var(--space-4);
  right: var(--space-4);
  z-index: var(--z-notification);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 18rem;
  padding: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  pointer-events: auto;
  animation: slideInRight var(--duration-slow) var(--ease-out);
}

.toast-success {
  border-color: var(--color-success-200);
  background: var(--color-success-50);
}

.toast-warning {
  border-color: var(--color-warning-200);
  background: var(--color-warning-50);
}

.toast-error {
  border-color: var(--color-error-200);
  background: var(--color-error-50);
}

.toast-info {
  border-color: var(--color-primary-200);
  background: var(--color-primary-50);
}

.toast-icon {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
}

.toast-content {
  flex: 1;
}

.toast-title {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-1);
}

.toast-message {
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
}

.toast-close {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: var(--transition-all);
}

.toast-close:hover {
  background: var(--color-gray-100);
  color: var(--color-text-primary);
}

/* Responsive */
@media (max-width: 640px) {
  .modal-content {
    max-width: calc(100vw - 2rem);
  }
  
  .toast-container {
    left: var(--space-4);
    right: var(--space-4);
  }
  
  .toast {
    min-width: auto;
    width: 100%;
  }
}

/* Dark Mode Adjustments */
[data-theme="dark"] .modal-content {
  background: var(--color-surface);
}

[data-theme="dark"] .modal-footer {
  background: var(--color-surface-variant);
}

[data-theme="dark"] .popover {
  background: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .tooltip {
  background: var(--color-gray-800);
}

[data-theme="dark"] .toast {
  background: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .toast-success {
  background: rgba(34, 197, 94, 0.1);
  border-color: rgba(34, 197, 94, 0.3);
}

[data-theme="dark"] .toast-warning {
  background: rgba(245, 158, 11, 0.1);
  border-color: rgba(245, 158, 11, 0.3);
}

[data-theme="dark"] .toast-error {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.3);
}

[data-theme="dark"] .toast-info {
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.3);
}
/* Design System - Navigation Components */

/* Navbar */
.navbar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  transition: var(--transition-all);
}

/* Sticky Navbar with Glassmorphism */
.navbar-sticky {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
}

.navbar-glass {
  background: var(--glass-background);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: var(--shadow-sm);
}

/* Navbar Brand */
.navbar-brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  text-decoration: none;
  transition: var(--transition-all);
}

.navbar-brand:hover {
  color: var(--color-primary-600);
  transform: translateY(-1px);
}

.navbar-brand-logo {
  height: 2rem;
  width: auto;
}

/* Navbar Menu */
.navbar-menu {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.navbar-item {
  position: relative;
}

.navbar-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: var(--transition-all);
  position: relative;
}

.navbar-link:hover {
  color: var(--color-text-primary);
  background: var(--color-gray-100);
}

.navbar-link-active {
  color: var(--color-primary-600);
  background: var(--color-primary-50);
}

.navbar-link-active::after {
  content: "";
  position: absolute;
  bottom: -1rem;
  left: 50%;
  transform: translateX(-50%);
  width: 2rem;
  height: 3px;
  background: var(--color-primary-600);
  border-radius: var(--radius-full);
}

/* Navbar Actions */
.navbar-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* Mobile Menu Toggle */
.navbar-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  gap: 4px;
}

.navbar-toggle-line {
  width: 100%;
  height: 2px;
  background: var(--color-text-primary);
  transition: var(--transition-all);
  transform-origin: center;
}

.navbar-toggle-active .navbar-toggle-line:first-child {
  transform: rotate(45deg) translate(5px, 5px);
}

.navbar-toggle-active .navbar-toggle-line:nth-child(2) {
  opacity: 0;
}

.navbar-toggle-active .navbar-toggle-line:last-child {
  transform: rotate(-45deg) translate(5px, -5px);
}

/* Dropdown Menu */
.navbar-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 12rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: var(--transition-all);
  z-index: var(--z-dropdown);
  margin-top: var(--space-2);
}

.navbar-item:hover .navbar-dropdown,
.navbar-dropdown:hover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.navbar-dropdown-item {
  display: block;
  padding: var(--space-3) var(--space-4);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: var(--transition-colors);
}

.navbar-dropdown-item:hover {
  color: var(--color-text-primary);
  background: var(--color-gray-50);
}

.navbar-dropdown-divider {
  height: 1px;
  margin: var(--space-2) 0;
  background: var(--color-border);
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  list-style: none;
  padding: var(--space-3) 0;
  margin: 0;
  font-size: var(--font-size-small);
}

.breadcrumb-item {
  display: flex;
  align-items: center;
}

.breadcrumb-item + .breadcrumb-item::before {
  content: "/";
  margin: 0 var(--space-2);
  color: var(--color-text-disabled);
}

.breadcrumb-link {
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: var(--transition-colors);
}

.breadcrumb-link:hover {
  color: var(--color-primary-600);
}

.breadcrumb-item-active {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-medium);
}

/* Tabs */
.tabs {
  display: flex;
  border-bottom: 1px solid var(--color-border);
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.tabs::-webkit-scrollbar {
  display: none;
}

.tab {
  position: relative;
  flex-shrink: 0;
}

.tab-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: var(--transition-all);
  white-space: nowrap;
}

.tab-link:hover {
  color: var(--color-text-primary);
  border-bottom-color: var(--color-gray-300);
}

.tab-link-active {
  color: var(--color-primary-600);
  border-bottom-color: var(--color-primary-600);
}

.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 var(--space-1);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: white;
  background: var(--color-primary-600);
  border-radius: var(--radius-full);
}

/* Pills Navigation */
.nav-pills {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-2);
  background: var(--color-gray-100);
  border-radius: var(--radius-lg);
  list-style: none;
  margin: 0;
}

.nav-pill {
  position: relative;
}

.nav-pill-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: var(--transition-all);
}

.nav-pill-link:hover {
  color: var(--color-text-primary);
  background: var(--color-gray-200);
}

.nav-pill-link-active {
  color: var(--color-primary-600);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

/* Sidebar Navigation */
.sidebar {
  width: 16rem;
  height: 100%;
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  overflow-y: auto;
}

.sidebar-header {
  padding: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.sidebar-menu {
  padding: var(--space-4);
  list-style: none;
  margin: 0;
}

.sidebar-item {
  margin-bottom: var(--space-2);
}

.sidebar-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: var(--transition-all);
}

.sidebar-link:hover {
  color: var(--color-text-primary);
  background: var(--color-gray-100);
}

.sidebar-link-active {
  color: var(--color-primary-600);
  background: var(--color-primary-50);
  font-weight: var(--font-weight-medium);
}

.sidebar-icon {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
}

.sidebar-section {
  margin-top: var(--space-6);
  margin-bottom: var(--space-2);
}

.sidebar-section-title {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-disabled);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

/* Bottom Navigation (Mobile) */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-around;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-sticky);
}

.bottom-nav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-2);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: var(--transition-all);
}

.bottom-nav-item:hover {
  color: var(--color-text-primary);
  background: var(--color-gray-50);
}

.bottom-nav-item-active {
  color: var(--color-primary-600);
}

.bottom-nav-icon {
  width: 1.5rem;
  height: 1.5rem;
  margin-bottom: var(--space-1);
}

.bottom-nav-label {
  font-size: var(--font-size-xs);
}

/* Pagination */
.pagination {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.pagination-item {
  display: flex;
}

.pagination-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 2.5rem;
  padding: 0 var(--space-3);
  font-size: var(--font-size-body);
  color: var(--color-text-secondary);
  text-decoration: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: var(--transition-all);
}

.pagination-link:hover {
  color: var(--color-text-primary);
  background: var(--color-gray-100);
  border-color: var(--color-border-hover);
}

.pagination-link-active {
  color: white;
  background: var(--color-primary-600);
  border-color: var(--color-primary-600);
}

.pagination-link:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.pagination-ellipsis {
  padding: 0 var(--space-2);
  color: var(--color-text-disabled);
}

/* Responsive */
@media (max-width: 768px) {
  .navbar-toggle {
    display: flex;
  }
  
  .navbar-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    padding: var(--space-4);
    margin: var(--space-2);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: var(--transition-all);
  }
  
  .navbar-menu-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  
  .navbar-item {
    width: 100%;
  }
  
  .navbar-link {
    width: 100%;
    justify-content: flex-start;
  }
  
  .navbar-link-active::after {
    display: none;
  }
  
  .navbar-dropdown {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    margin-top: 0;
    margin-left: var(--space-4);
  }
}

/* Logo Easter Egg Animations */
.logo-text {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-primary-600);
  position: relative;
  cursor: pointer;
}

.u-smile {
  display: inline-block;
  color: var(--color-accent-500);
  transition: all 0.3s ease;
  cursor: help;
  position: relative;
}

/* Add a subtle hint on hover */
.u-smile:hover {
  color: var(--color-accent-600);
  transform: scale(1.1);
}

/* Wink animation on hover */
.logo-text:hover .u-smile {
  animation: wink 0.6s ease-in-out;
}

@keyframes wink {
  0%, 100% { 
    transform: scale(1) rotateY(0);
    color: var(--color-accent-500);
  }
  25% { 
    transform: scale(0.3, 1) rotateY(0);
    color: var(--color-accent-600);
  }
  50% { 
    transform: scale(1.1) rotateY(0);
    color: var(--color-accent-400);
  }
  75% { 
    transform: scale(1) rotateY(360deg);
    color: var(--color-accent-500);
  }
}

/* Rainbow effect on multiple clicks */
@keyframes rainbow {
  0% { color: #ff0000; }
  16.66% { color: #ff8800; }
  33.33% { color: #ffff00; }
  50% { color: #00ff00; }
  66.66% { color: #0088ff; }
  83.33% { color: #8800ff; }
  100% { color: #ff0000; }
}

.u-smile.rainbow-active {
  animation: rainbow 2s linear infinite;
}

/* Pulse effect for hover hint */
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

/* Bounce effect on page load */
@keyframes logoBounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-10px);
  }
  60% {
    transform: translateY(-5px);
  }
}

.logo-text {
  animation: logoBounce 2s ease-in-out;
}

/* Dark Mode Adjustments */
[data-theme="dark"] .navbar {
  background: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .navbar-glass {
  background: rgba(30, 41, 59, 0.8);
  border-color: rgba(71, 85, 105, 0.2);
}

[data-theme="dark"] .navbar-link:hover {
  background: var(--color-surface-variant);
}

[data-theme="dark"] .navbar-link-active {
  background: rgba(37, 99, 235, 0.1);
}

[data-theme="dark"] .navbar-dropdown {
  background: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .sidebar {
  background: var(--color-surface);
  border-color: var(--color-border);
}

[data-theme="dark"] .bottom-nav {
  background: var(--color-surface);
  border-color: var(--color-border);
}
/* Design System - Rotating Text Component */

.rotating-text-container {
  position: relative;
  display: inline-block;
  min-height: 1.5em;
  line-height: 1.5;
}

.rotating-text {
  display: inline-block;
  position: relative;
  color: var(--color-primary-600);
  font-weight: var(--font-weight-bold);
  transition: all var(--duration-fast) var(--ease-in-out);
  min-height: 1.2em;
  vertical-align: baseline;
}

.rotating-text-fade-out {
  opacity: 0;
  transform: translateY(-10px);
}

.rotating-text-fade-in {
  opacity: 1;
  transform: translateY(0);
}

/* Typing cursor effect */
.rotating-text::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 1em;
  background-color: var(--color-primary-600);
  margin-left: 0.1em;
  animation: blink 1s infinite;
  vertical-align: baseline;
}

@keyframes blink {
  0%, 50% {
    opacity: 1;
  }
  51%, 100% {
    opacity: 0;
  }
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .rotating-text {
    display: block;
    margin-top: var(--space-2);
  }
  
  .rotating-text::after {
    display: none;
  }
}

/* Alternative styles */
.rotating-text-underline {
  position: relative;
}

.rotating-text-underline::before {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary-500), var(--color-accent-500));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--duration-base) var(--ease-out);
}

.rotating-text-underline:not(.rotating-text-fade-out)::before {
  transform: scaleX(1);
}

/* Gradient text effect */
.rotating-text-gradient {
  background: linear-gradient(135deg, var(--color-primary-600), var(--color-accent-600));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Box highlight effect */
.rotating-text-box {
  background: linear-gradient(135deg, var(--color-primary-100), var(--color-accent-100));
  padding: 0.2em 0.4em;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-primary-200);
}

/* Dark mode support */
[data-theme="dark"] .rotating-text {
  color: var(--color-primary-400);
}

[data-theme="dark"] .rotating-text::after {
  background-color: var(--color-primary-400);
}

[data-theme="dark"] .rotating-text-box {
  background: linear-gradient(135deg, var(--color-primary-900), var(--color-accent-900));
  border-color: var(--color-primary-700);
}
/* frozen_string_literal: true */

/* Structure Module Specific Styles */

/* Override link styles inside buttons */
.btn a,
a.btn,
button a {
  color: inherit !important;
  text-decoration: none !important;
}

/* Colorful badges and elements */
.badge-role {
  @apply inline-flex items-center px-3 py-1 rounded-full text-sm font-medium;
}

.badge-director {
  @apply bg-purple-100 text-purple-800;
}

.badge-educator {
  @apply bg-emerald-100 text-emerald-800;
}

.badge-admin {
  @apply bg-pink-100 text-pink-800;
}

.badge-supervisor {
  @apply bg-amber-100 text-amber-800;
}

/* Colorful child status badges */
.status-present {
  @apply bg-emerald-100 text-emerald-800;
}

.status-absent {
  @apply bg-gray-100 text-gray-600;
}

/* Joyful card styles */
.structure-card {
  @apply bg-white rounded-xl shadow-sm hover:shadow-lg transition-all duration-300 border border-gray-100 overflow-hidden;
}

.structure-card:hover {
  @apply transform -translate-y-1;
}

/* Colorful icons */
.icon-primary {
  @apply text-indigo-500;
}

.icon-success {
  @apply text-emerald-500;
}

.icon-warning {
  @apply text-amber-500;
}

.icon-danger {
  @apply text-rose-500;
}

.icon-info {
  @apply text-sky-500;
}

/* Joyful backgrounds */
.bg-pattern {
  background-image: 
    radial-gradient(circle at 20% 80%, rgba(139, 92, 246, 0.05) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(236, 72, 153, 0.05) 0%, transparent 50%),
    radial-gradient(circle at 40% 40%, rgba(34, 197, 94, 0.05) 0%, transparent 50%);
}

/* Colorful hover states */
.hover-lift {
  @apply transition-all duration-300;
}

.hover-lift:hover {
  @apply transform -translate-y-1 shadow-lg;
}

/* Playful section headers */
.section-header {
  @apply relative;
}

.section-header::after {
  content: '';
  @apply absolute bottom-0 left-0 w-16 h-1 bg-gradient-to-r from-indigo-500 to-purple-500 rounded-full;
}
/* Design System - Main Index */

/* Import Design Tokens */
@import 'tokens/colors.css';
@import 'tokens/typography.css';
@import 'tokens/spacing.css';
@import 'tokens/shadows.css';
@import 'tokens/animations.css';

/* Import Components */
@import 'components/buttons.css';
@import 'components/cards.css';
@import 'components/forms.css';
@import 'components/navigation.css';
@import 'components/modals.css';
@import 'components/auth.css';
@import 'components/rotating-text.css';
@import 'components/footer.css';
@import 'components/daily-handling.css';
@import 'components/structure.css';
@import 'components/child-header.css';

/* Import Utilities */
@import 'utilities/helpers.css';
@import 'utilities/effects.css';

/* Base Styles */
* {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-primary);
  font-size: var(--font-size-body);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  background-color: var(--color-background);
  transition: background-color var(--duration-slow) var(--ease-in-out),
              color var(--duration-slow) var(--ease-in-out);
}

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

/* Selection */
::selection {
  background-color: var(--color-primary-200);
  color: var(--color-primary-900);
}

/* Scrollbar Styling */
::-webkit-scrollbar {
  width: 0.5rem;
  height: 0.5rem;
}

::-webkit-scrollbar-track {
  background: var(--color-gray-100);
}

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

::-webkit-scrollbar-thumb:hover {
  background: var(--color-gray-500);
}

/* Dark Mode Scrollbar */
[data-theme="dark"] ::-webkit-scrollbar-track {
  background: var(--color-surface-variant);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: var(--color-gray-600);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
  background: var(--color-gray-500);
}

/* Links */
a {
  color: var(--color-primary-600);
  text-decoration: none;
  transition: color var(--duration-base) var(--ease-in-out);
}

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

/* Child names - Global style */
.child-name {
  font-family: 'Crafty Girls', cursive;
  color: var(--color-primary-600);
}

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

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

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

/* Headings */
h1, h2, h3, h4, h5, h6 {
  margin: 0 0 var(--space-4) 0;
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
}

h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); }
h3 { font-size: var(--font-size-h3); }
h4 { font-size: var(--font-size-h4); }

/* Paragraphs */
p {
  margin: 0 0 var(--space-4) 0;
}

/* Code */
code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  padding: 0.125rem 0.25rem;
  background-color: var(--color-gray-100);
  border-radius: var(--radius-sm);
}

pre {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  padding: var(--space-4);
  background-color: var(--color-gray-100);
  border-radius: var(--radius-md);
  overflow-x: auto;
}

pre code {
  padding: 0;
  background-color: transparent;
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-4) 0;
}

th, td {
  padding: var(--space-3);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}

th {
  font-weight: var(--font-weight-semibold);
  background-color: var(--color-gray-50);
}

/* Blockquote */
blockquote {
  margin: var(--space-4) 0;
  padding: var(--space-4);
  border-left: 4px solid var(--color-primary-500);
  background-color: var(--color-gray-50);
  font-style: italic;
}

/* HR */
hr {
  margin: var(--space-8) 0;
  border: none;
  border-top: 1px solid var(--color-border);
}

/* Utility Classes for Common Patterns */
.container-fluid {
  width: 100%;
  padding-left: var(--container-padding-mobile);
  padding-right: var(--container-padding-mobile);
}

@media (min-width: 768px) {
  .container-fluid {
    padding-left: var(--container-padding-tablet);
    padding-right: var(--container-padding-tablet);
  }
}

@media (min-width: 1280px) {
  .container-fluid {
    padding-left: var(--container-padding-desktop);
    padding-right: var(--container-padding-desktop);
  }
}

/* Page Wrapper */
.page-wrapper {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.page-content {
  flex: 1;
  padding: var(--section-spacing-mobile) 0;
}

@media (min-width: 768px) {
  .page-content {
    padding: var(--section-spacing-tablet) 0;
  }
}

@media (min-width: 1280px) {
  .page-content {
    padding: var(--section-spacing-desktop) 0;
  }
}

/* Section */
.section {
  margin-bottom: var(--section-spacing-mobile);
}

@media (min-width: 768px) {
  .section {
    margin-bottom: var(--section-spacing-tablet);
  }
}

@media (min-width: 1280px) {
  .section {
    margin-bottom: var(--section-spacing-desktop);
  }
}

/* Print Styles */
@media print {
  body {
    background: white;
    color: black;
  }
  
  .no-print {
    display: none !important;
  }
  
  a {
    color: black;
    text-decoration: underline;
  }
  
  .navbar,
  .sidebar,
  .bottom-nav,
  .modal,
  .toast-container {
    display: none !important;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* Design System - Animation Tokens */

:root {
  /* Transition Durations */
  --duration-instant: 0ms;
  --duration-fast: 150ms;
  --duration-base: 200ms;
  --duration-slow: 300ms;
  --duration-slower: 400ms;
  --duration-slowest: 500ms;

  /* Transition Timing Functions */
  --ease-linear: linear;
  --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-spring: cubic-bezier(0.68, -0.55, 0.265, 1.55);
  --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);

  /* Common Transitions */
  --transition-all: all var(--duration-base) var(--ease-in-out);
  --transition-colors: background-color var(--duration-base) var(--ease-in-out),
                      border-color var(--duration-base) var(--ease-in-out),
                      color var(--duration-base) var(--ease-in-out),
                      fill var(--duration-base) var(--ease-in-out),
                      stroke var(--duration-base) var(--ease-in-out);
  --transition-opacity: opacity var(--duration-base) var(--ease-in-out);
  --transition-shadow: box-shadow var(--duration-base) var(--ease-in-out);
  --transition-transform: transform var(--duration-base) var(--ease-in-out);
}

/* Keyframe Animations */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

@keyframes slideInUp {
  from {
    transform: translateY(100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes slideInDown {
  from {
    transform: translateY(-100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes slideInLeft {
  from {
    transform: translateX(-100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes scaleIn {
  from {
    transform: scale(0.9);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes scaleOut {
  from {
    transform: scale(1);
    opacity: 1;
  }
  to {
    transform: scale(0.9);
    opacity: 0;
  }
}

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

@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-25%);
  }
}

@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-10px);
  }
  20%, 40%, 60%, 80% {
    transform: translateX(10px);
  }
}

@keyframes shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}

@keyframes ripple {
  0% {
    transform: scale(0);
    opacity: 1;
  }
  100% {
    transform: scale(4);
    opacity: 0;
  }
}

/* Loading Animations */
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes skeleton {
  0% {
    background-position: -200px 0;
  }
  100% {
    background-position: calc(200px + 100%) 0;
  }
}

/* Animation Classes */
.animate-fade-in {
  animation: fadeIn var(--duration-slow) var(--ease-out);
}

.animate-fade-out {
  animation: fadeOut var(--duration-slow) var(--ease-in);
}

.animate-slide-up {
  animation: slideInUp var(--duration-slow) var(--ease-out);
}

.animate-slide-down {
  animation: slideInDown var(--duration-slow) var(--ease-out);
}

.animate-slide-left {
  animation: slideInLeft var(--duration-slow) var(--ease-out);
}

.animate-slide-right {
  animation: slideInRight var(--duration-slow) var(--ease-out);
}

.animate-scale-in {
  animation: scaleIn var(--duration-base) var(--ease-spring);
}

.animate-scale-out {
  animation: scaleOut var(--duration-base) var(--ease-in);
}

.animate-pulse {
  animation: pulse 2s var(--ease-in-out) infinite;
}

.animate-bounce {
  animation: bounce 1s var(--ease-bounce) infinite;
}

.animate-shake {
  animation: shake 0.5s var(--ease-in-out);
}

.animate-spin {
  animation: spin 1s var(--ease-linear) infinite;
}

/* Transition Utilities */
.transition-all {
  transition: var(--transition-all);
}

.transition-colors {
  transition: var(--transition-colors);
}

.transition-opacity {
  transition: var(--transition-opacity);
}

.transition-shadow {
  transition: var(--transition-shadow);
}

.transition-transform {
  transition: var(--transition-transform);
}

.transition-none {
  transition: none;
}

/* Duration Modifiers */
.duration-fast {
  transition-duration: var(--duration-fast);
}

.duration-base {
  transition-duration: var(--duration-base);
}

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

.duration-slower {
  transition-duration: var(--duration-slower);
}

/* Delay Utilities */
.delay-75 {
  transition-delay: 75ms;
}

.delay-100 {
  transition-delay: 100ms;
}

.delay-150 {
  transition-delay: 150ms;
}

.delay-200 {
  transition-delay: 200ms;
}

.delay-300 {
  transition-delay: 300ms;
}

/* Skeleton Loading */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--color-gray-200) 25%,
    var(--color-gray-100) 50%,
    var(--color-gray-200) 75%
  );
  background-size: 200% 100%;
  animation: skeleton 1.5s ease-in-out infinite;
}

/* Shimmer Effect */
.shimmer {
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.3) 50%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
}

/* Ripple Effect */
.ripple {
  position: relative;
  overflow: hidden;
}

.ripple::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.ripple:active::before {
  width: 300px;
  height: 300px;
}

/* Hover Scale */
.hover-scale {
  transition: transform var(--duration-base) var(--ease-in-out);
}

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

.hover-scale-sm:hover {
  transform: scale(1.02);
}

.hover-scale-lg:hover {
  transform: scale(1.1);
}

/* Focus Scale */
.focus-scale {
  transition: transform var(--duration-base) var(--ease-in-out);
}

.focus-scale:focus {
  transform: scale(1.05);
}

/* Active Scale */
.active-scale:active {
  transform: scale(0.95);
}

/* Smooth Scroll */
.smooth-scroll {
  scroll-behavior: smooth;
}

/* GPU Acceleration */
.gpu-accelerated {
  transform: translateZ(0);
  will-change: transform;
}
/* Design System - Color Tokens */

:root {
  /* Brand Colors */
  --color-primary-50: #eff6ff;
  --color-primary-100: #dbeafe;
  --color-primary-200: #bfdbfe;
  --color-primary-300: #93c5fd;
  --color-primary-400: #60a5fa;
  --color-primary-500: #3b82f6;
  --color-primary-600: #2563eb;
  --color-primary-700: #1d4ed8;
  --color-primary-800: #1e40af;
  --color-primary-900: #1e3a8a;

  /* Accent Colors */
  --color-accent-50: #fdf2f8;
  --color-accent-100: #fce7f3;
  --color-accent-200: #fbcfe8;
  --color-accent-300: #f9a8d4;
  --color-accent-400: #f472b6;
  --color-accent-500: #ec4899;
  --color-accent-600: #db2777;
  --color-accent-700: #be185d;
  --color-accent-800: #9d174d;
  --color-accent-900: #831843;

  /* Role-Based Colors */
  --color-director: #7c3aed;
  --color-educator: #2563eb;
  --color-parent: #059669;
  --color-admin: #475569;

  /* Semantic Colors */
  --color-success-50: #f0fdf4;
  --color-success-100: #dcfce7;
  --color-success-200: #bbf7d0;
  --color-success-300: #86efac;
  --color-success-400: #4ade80;
  --color-success-500: #22c55e;
  --color-success-600: #16a34a;
  --color-success-700: #15803d;
  --color-success-800: #166534;
  --color-success-900: #14532d;

  --color-warning-50: #fffbeb;
  --color-warning-100: #fef3c7;
  --color-warning-200: #fde68a;
  --color-warning-300: #fcd34d;
  --color-warning-400: #fbbf24;
  --color-warning-500: #f59e0b;
  --color-warning-600: #d97706;
  --color-warning-700: #b45309;
  --color-warning-800: #92400e;
  --color-warning-900: #78350f;

  --color-error-50: #fef2f2;
  --color-error-100: #fee2e2;
  --color-error-200: #fecaca;
  --color-error-300: #fca5a5;
  --color-error-400: #f87171;
  --color-error-500: #ef4444;
  --color-error-600: #dc2626;
  --color-error-700: #b91c1c;
  --color-error-800: #991b1b;
  --color-error-900: #7f1d1d;

  --color-info: #0ea5e9;
  --color-development: #a855f7;
  --color-archived: #94a3b8;

  /* Neutral Colors */
  --color-gray-50: #f9fafb;
  --color-gray-100: #f3f4f6;
  --color-gray-200: #e5e7eb;
  --color-gray-300: #d1d5db;
  --color-gray-400: #9ca3af;
  --color-gray-500: #6b7280;
  --color-gray-600: #4b5563;
  --color-gray-700: #374151;
  --color-gray-800: #1f2937;
  --color-gray-900: #111827;

  /* Background Colors */
  --color-background: #ffffff;
  --color-surface: #ffffff;
  --color-surface-variant: #ffffff;
  
  /* Text Colors */
  --color-text-primary: var(--color-gray-900);
  --color-text-secondary: var(--color-gray-600);
  --color-text-disabled: var(--color-gray-400);
  --color-text-inverse: #ffffff;

  /* Border Colors */
  --color-border: var(--color-gray-200);
  --color-border-hover: var(--color-gray-300);
  --color-border-focus: var(--color-primary-500);

  /* Glassmorphism */
  --glass-background: rgba(255, 255, 255, 0.8);
  --glass-border: rgba(255, 255, 255, 0.2);
  --glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.1);
}

/* Dark Mode Colors */
[data-theme="dark"] {
  /* Background Colors */
  --color-background: #0f172a;
  --color-surface: #1e293b;
  --color-surface-variant: #334155;
  
  /* Text Colors */
  --color-text-primary: #f1f5f9;
  --color-text-secondary: #cbd5e1;
  --color-text-disabled: #64748b;
  
  /* Border Colors */
  --color-border: #334155;
  --color-border-hover: #475569;
  
  /* Glassmorphism Dark */
  --glass-background: rgba(30, 41, 59, 0.8);
  --glass-border: rgba(71, 85, 105, 0.2);
  --glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.3);

  /* Adjust semantic colors for dark mode */
  --color-success-500: #10b981;
  --color-warning-500: #f59e0b;
  --color-error-500: #f87171;
  --color-info: #38bdf8;
}
/* Design System - Shadow Tokens */

:root {
  /* Base Shadow Scale */
  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 2px 4px -1px rgba(0, 0, 0, 0.06), 0 1px 2px -1px rgba(0, 0, 0, 0.03);
  --shadow-md: 0 4px 6px -2px rgba(0, 0, 0, 0.08), 0 2px 4px -2px rgba(0, 0, 0, 0.04);
  --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.12), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
  --shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
  --shadow-none: none;

  /* Colored Shadows */
  --shadow-primary: 0 4px 14px 0 rgba(37, 99, 235, 0.2);
  --shadow-success: 0 4px 14px 0 rgba(34, 197, 94, 0.2);
  --shadow-warning: 0 4px 14px 0 rgba(245, 158, 11, 0.2);
  --shadow-error: 0 4px 14px 0 rgba(239, 68, 68, 0.2);

  /* Glassmorphism Shadows */
  --shadow-glass: 0 8px 32px 0 rgba(31, 38, 135, 0.1);
  --shadow-glass-hover: 0 8px 40px 0 rgba(31, 38, 135, 0.15);

  /* Component Shadows */
  --button-shadow: var(--shadow-sm);
  --button-shadow-hover: var(--shadow-md);
  --button-shadow-active: var(--shadow-xs);
  
  --card-shadow: var(--shadow-sm);
  --card-shadow-hover: var(--shadow-lg);
  
  --dropdown-shadow: var(--shadow-xl);
  --modal-shadow: var(--shadow-2xl);
  --tooltip-shadow: var(--shadow-lg);

  /* Focus Shadows */
  --focus-ring: 0 0 0 3px rgba(37, 99, 235, 0.5);
  --focus-ring-primary: 0 0 0 3px rgba(37, 99, 235, 0.5);
  --focus-ring-success: 0 0 0 3px rgba(34, 197, 94, 0.5);
  --focus-ring-warning: 0 0 0 3px rgba(245, 158, 11, 0.5);
  --focus-ring-error: 0 0 0 3px rgba(239, 68, 68, 0.5);

  /* Text Shadows */
  --text-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.1);
  --text-shadow-md: 0 2px 4px rgba(0, 0, 0, 0.15);
  --text-shadow-lg: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Dark Mode Shadows */
[data-theme="dark"] {
  /* Adjusted shadows for dark mode */
  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
  --shadow-sm: 0 2px 4px -1px rgba(0, 0, 0, 0.4), 0 1px 2px -1px rgba(0, 0, 0, 0.2);
  --shadow-md: 0 4px 6px -2px rgba(0, 0, 0, 0.5), 0 2px 4px -2px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.6), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.7), 0 10px 10px -5px rgba(0, 0, 0, 0.3);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.8);
  
  /* Colored shadows with higher opacity for dark mode */
  --shadow-primary: 0 4px 14px 0 rgba(37, 99, 235, 0.4);
  --shadow-success: 0 4px 14px 0 rgba(34, 197, 94, 0.4);
  --shadow-warning: 0 4px 14px 0 rgba(245, 158, 11, 0.4);
  --shadow-error: 0 4px 14px 0 rgba(239, 68, 68, 0.4);
  
  /* Glassmorphism shadows for dark mode */
  --shadow-glass: 0 8px 32px 0 rgba(0, 0, 0, 0.3);
  --shadow-glass-hover: 0 8px 40px 0 rgba(0, 0, 0, 0.4);
}

/* Shadow Utilities */
.shadow-xs { box-shadow: var(--shadow-xs); }
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }
.shadow-2xl { box-shadow: var(--shadow-2xl); }
.shadow-inner { box-shadow: var(--shadow-inner); }
.shadow-none { box-shadow: var(--shadow-none); }

/* Colored Shadow Utilities */
.shadow-primary { box-shadow: var(--shadow-primary); }
.shadow-success { box-shadow: var(--shadow-success); }
.shadow-warning { box-shadow: var(--shadow-warning); }
.shadow-error { box-shadow: var(--shadow-error); }

/* Glassmorphism Shadow */
.shadow-glass { box-shadow: var(--shadow-glass); }
.shadow-glass-hover { box-shadow: var(--shadow-glass-hover); }

/* Focus Ring Utilities */
.focus-ring:focus { box-shadow: var(--focus-ring); }
.focus-ring-primary:focus { box-shadow: var(--focus-ring-primary); }
.focus-ring-success:focus { box-shadow: var(--focus-ring-success); }
.focus-ring-warning:focus { box-shadow: var(--focus-ring-warning); }
.focus-ring-error:focus { box-shadow: var(--focus-ring-error); }

/* Text Shadow Utilities */
.text-shadow-sm { text-shadow: var(--text-shadow-sm); }
.text-shadow-md { text-shadow: var(--text-shadow-md); }
.text-shadow-lg { text-shadow: var(--text-shadow-lg); }
.text-shadow-none { text-shadow: none; }

/* Elevation Classes - Combines shadows with subtle transforms */
.elevation-0 {
  box-shadow: var(--shadow-none);
  transform: translateY(0);
}

.elevation-1 {
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.elevation-2 {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.elevation-3 {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.elevation-4 {
  box-shadow: var(--shadow-xl);
  transform: translateY(-4px);
}

/* Hover Elevation Transitions */
.hover-elevate {
  transition: box-shadow 200ms ease-in-out, transform 200ms ease-in-out;
}

.hover-elevate:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}
/* Design System - Spacing Tokens */

:root {
  /* Base 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.5rem;   /* 24px */
  --space-6: 2rem;     /* 32px */
  --space-7: 2.5rem;   /* 40px */
  --space-8: 3rem;     /* 48px */
  --space-9: 3.5rem;   /* 56px */
  --space-10: 4rem;    /* 64px */
  --space-11: 5rem;    /* 80px */
  --space-12: 6rem;    /* 96px */
  --space-14: 8rem;    /* 128px */
  --space-16: 10rem;   /* 160px */

  /* Component Spacing */
  --space-xs: var(--space-2);
  --space-sm: var(--space-3);
  --space-md: var(--space-4);
  --space-lg: var(--space-6);
  --space-xl: var(--space-8);
  --space-2xl: var(--space-12);

  /* Layout Spacing */
  --container-padding-mobile: var(--space-4);
  --container-padding-tablet: var(--space-6);
  --container-padding-desktop: var(--space-8);
  
  --section-spacing-mobile: var(--space-8);
  --section-spacing-tablet: var(--space-10);
  --section-spacing-desktop: var(--space-12);

  /* Component-Specific Spacing */
  --button-padding-x: var(--space-4);
  --button-padding-y: var(--space-2);
  
  --card-padding: var(--space-6);
  --card-padding-mobile: var(--space-4);
  
  --form-spacing: var(--space-4);
  --form-group-spacing: var(--space-6);
  
  --nav-item-spacing: var(--space-3);
  --nav-section-spacing: var(--space-6);

  /* Border Radius Scale */
  --radius-none: 0;
  --radius-xs: 0.25rem;   /* 4px */
  --radius-sm: 0.5rem;    /* 8px */
  --radius-md: 0.75rem;   /* 12px */
  --radius-lg: 1rem;      /* 16px */
  --radius-xl: 1.25rem;   /* 20px */
  --radius-2xl: 1.5rem;   /* 24px */
  --radius-3xl: 2rem;     /* 32px */
  --radius-full: 9999px;

  /* Component Border Radius */
  --button-radius: var(--radius-lg);
  --card-radius: var(--radius-xl);
  --input-radius: var(--radius-md);
  --badge-radius: var(--radius-full);
  --avatar-radius: var(--radius-full);

  /* Z-Index Scale */
  --z-negative: -1;
  --z-0: 0;
  --z-10: 10;
  --z-20: 20;
  --z-30: 30;
  --z-40: 40;
  --z-50: 50;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-modal-backdrop: 300;
  --z-modal: 400;
  --z-popover: 500;
  --z-tooltip: 600;
  --z-notification: 700;
  --z-max: 9999;
}

/* 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); }
.p-10 { padding: var(--space-10); }
.p-12 { padding: var(--space-12); }

.px-0 { padding-left: var(--space-0); padding-right: var(--space-0); }
.px-1 { padding-left: var(--space-1); padding-right: var(--space-1); }
.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-5 { padding-left: var(--space-5); padding-right: var(--space-5); }
.px-6 { padding-left: var(--space-6); padding-right: var(--space-6); }
.px-8 { padding-left: var(--space-8); padding-right: var(--space-8); }

.py-0 { padding-top: var(--space-0); padding-bottom: var(--space-0); }
.py-1 { padding-top: var(--space-1); padding-bottom: var(--space-1); }
.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-5 { padding-top: var(--space-5); padding-bottom: var(--space-5); }
.py-6 { padding-top: var(--space-6); padding-bottom: var(--space-6); }
.py-8 { padding-top: var(--space-8); padding-bottom: var(--space-8); }

/* Margin utilities follow same pattern */
.m-0 { margin: var(--space-0); }
.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-3 { margin: var(--space-3); }
.m-4 { margin: var(--space-4); }
.m-5 { margin: var(--space-5); }
.m-6 { margin: var(--space-6); }
.m-8 { margin: var(--space-8); }

.mx-auto { margin-left: auto; margin-right: auto; }
.my-auto { margin-top: auto; margin-bottom: auto; }

/* Gap utilities for flexbox/grid */
.gap-0 { gap: var(--space-0); }
.gap-1 { gap: var(--space-1); }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-5 { gap: var(--space-5); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

/* Border Radius Utilities */
.rounded-none { border-radius: var(--radius-none); }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-2xl { border-radius: var(--radius-2xl); }
.rounded-full { border-radius: var(--radius-full); }

/* Responsive Container */
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-padding-mobile);
  padding-right: var(--container-padding-mobile);
}

@media (min-width: 640px) {
  .container {
    max-width: 640px;
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 768px;
    padding-left: var(--container-padding-tablet);
    padding-right: var(--container-padding-tablet);
  }
}

@media (min-width: 1024px) {
  .container {
    max-width: 1024px;
  }
}

@media (min-width: 1280px) {
  .container {
    max-width: 1280px;
    padding-left: var(--container-padding-desktop);
    padding-right: var(--container-padding-desktop);
  }
}

@media (min-width: 1536px) {
  .container {
    max-width: 1536px;
  }
}
/* Design System - Typography Tokens */

:root {
  /* Font Families */
  --font-primary: 'Nunito', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
  --font-display: 'Nunito', var(--font-primary);
  --font-accent: 'Kalam', 'Crafty Girls', cursive;
  --font-mono: 'JetBrains Mono', 'Fira Code', Consolas, 'Courier New', monospace;

  /* Font Sizes - Fluid Typography */
  --font-size-display: clamp(2rem, 5vw, 3rem);
  --font-size-h1: clamp(1.875rem, 4vw, 2.25rem);
  --font-size-h2: clamp(1.5rem, 3vw, 1.875rem);
  --font-size-h3: clamp(1.25rem, 2.5vw, 1.5rem);
  --font-size-h4: clamp(1.125rem, 2vw, 1.25rem);
  --font-size-body: clamp(0.875rem, 1.5vw, 1rem);
  --font-size-small: clamp(0.75rem, 1.2vw, 0.875rem);
  --font-size-xs: 0.75rem;

  /* 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;

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

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

  /* Text Decoration */
  --text-decoration-underline-offset: 0.2em;
  --text-decoration-thickness: 0.1em;
}

/* Typography Classes */
.text-display {
  font-family: var(--font-display);
  font-size: var(--font-size-display);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

.text-h1 {
  font-family: var(--font-display);
  font-size: var(--font-size-h1);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

.text-h2 {
  font-family: var(--font-display);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
}

.text-h3 {
  font-family: var(--font-primary);
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-snug);
}

.text-h4 {
  font-family: var(--font-primary);
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-normal);
}

.text-body {
  font-family: var(--font-primary);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
}

.text-small {
  font-family: var(--font-primary);
  font-size: var(--font-size-small);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
}

.text-xs {
  font-family: var(--font-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
}

.text-accent {
  font-family: var(--font-accent);
}

.text-mono {
  font-family: var(--font-mono);
  font-size: 0.875em;
}

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

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

.text-disabled {
  color: var(--color-text-disabled);
}

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

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

/* Text Transform */
.uppercase { text-transform: uppercase; }
.lowercase { text-transform: lowercase; }
.capitalize { text-transform: capitalize; }

/* Text Decoration */
.underline {
  text-decoration: underline;
  text-underline-offset: var(--text-decoration-underline-offset);
  text-decoration-thickness: var(--text-decoration-thickness);
}

.line-through {
  text-decoration: line-through;
}

/* Truncation */
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Font Loading Optimization */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');
}

@font-face {
  font-family: 'Fredoka';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&display=swap');
}

@font-face {
  font-family: 'Kalam';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://fonts.googleapis.com/css2?family=Kalam&display=swap');
}
/* Design System - Modern Visual Effects */

/* Glassmorphism Base Classes */
.glass {
  background: var(--glass-background);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-glass);
}

.glass-sm {
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.glass-lg {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.glass-xl {
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

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

/* Frosted Glass Variants */
.glass-white {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.glass-dark {
  background: rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.glass-primary {
  background: rgba(37, 99, 235, 0.1);
  border: 1px solid rgba(37, 99, 235, 0.2);
}

/* Neumorphism */
.neumorphic {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  box-shadow: 
    6px 6px 12px rgba(0, 0, 0, 0.1),
    -6px -6px 12px rgba(255, 255, 255, 0.8);
}

.neumorphic-pressed {
  box-shadow: 
    inset 4px 4px 8px rgba(0, 0, 0, 0.1),
    inset -4px -4px 8px rgba(255, 255, 255, 0.8);
}

.neumorphic-flat {
  box-shadow: 
    3px 3px 6px rgba(0, 0, 0, 0.08),
    -3px -3px 6px rgba(255, 255, 255, 0.6);
}

/* Gradient Overlays */
.gradient-overlay {
  position: relative;
  overflow: hidden;
}

.gradient-overlay::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.1) 0%,
    rgba(255, 255, 255, 0) 100%
  );
  pointer-events: none;
}

.gradient-mesh {
  background-image: 
    radial-gradient(at 40% 20%, hsla(211, 92%, 62%, 0.3) 0px, transparent 50%),
    radial-gradient(at 80% 0%, hsla(268, 71%, 63%, 0.2) 0px, transparent 50%),
    radial-gradient(at 0% 50%, hsla(355, 85%, 71%, 0.2) 0px, transparent 50%),
    radial-gradient(at 80% 50%, hsla(340, 82%, 69%, 0.1) 0px, transparent 50%),
    radial-gradient(at 0% 100%, hsla(203, 89%, 64%, 0.1) 0px, transparent 50%),
    radial-gradient(at 80% 100%, hsla(242, 75%, 60%, 0.1) 0px, transparent 50%),
    radial-gradient(at 0% 0%, hsla(343, 80%, 72%, 0.1) 0px, transparent 50%);
}

/* Animated Gradients */
.animated-gradient {
  background: linear-gradient(
    -45deg,
    var(--color-primary-400),
    var(--color-accent-400),
    var(--color-primary-600),
    var(--color-accent-600)
  );
  background-size: 400% 400%;
  animation: gradientShift 15s ease infinite;
}

@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* Glow Effects */
.glow {
  box-shadow: 0 0 20px rgba(37, 99, 235, 0.3);
}

.glow-sm {
  box-shadow: 0 0 10px rgba(37, 99, 235, 0.3);
}

.glow-lg {
  box-shadow: 0 0 30px rgba(37, 99, 235, 0.3);
}

.glow-primary {
  box-shadow: 0 0 20px var(--color-primary-400);
}

.glow-success {
  box-shadow: 0 0 20px var(--color-success-400);
}

.glow-warning {
  box-shadow: 0 0 20px var(--color-warning-400);
}

.glow-error {
  box-shadow: 0 0 20px var(--color-error-400);
}

/* Text Glow */
.text-glow {
  text-shadow: 0 0 10px currentColor;
}

.text-glow-sm {
  text-shadow: 0 0 5px currentColor;
}

.text-glow-lg {
  text-shadow: 0 0 20px currentColor;
}

/* Neon Effect */
.neon {
  color: var(--color-primary-400);
  text-shadow: 
    0 0 5px currentColor,
    0 0 10px currentColor,
    0 0 20px currentColor,
    0 0 40px currentColor;
}

.neon-pink {
  color: var(--color-accent-400);
  text-shadow: 
    0 0 5px currentColor,
    0 0 10px currentColor,
    0 0 20px currentColor,
    0 0 40px currentColor;
}

/* Holographic Effect */
.holographic {
  background: linear-gradient(
    135deg,
    #ff0080,
    #ff8c00,
    #ffd700,
    #00ff00,
    #00ffff,
    #0080ff,
    #8000ff
  );
  background-size: 200% 200%;
  animation: holographicShift 3s ease-in-out infinite;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

@keyframes holographicShift {
  0%, 100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

/* Iridescent Effect */
.iridescent {
  background: linear-gradient(
    to right,
    #e0c3fc 0%,
    #8ec5fc 50%,
    #e0c3fc 100%
  );
  background-size: 200% 100%;
  animation: iridescentShift 3s linear infinite;
}

@keyframes iridescentShift {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 200% 50%;
  }
}

/* Parallax Scrolling */
.parallax {
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

/* 3D Transform Effects */
.perspective {
  perspective: 1000px;
}

.rotate-3d {
  transform: rotateX(10deg) rotateY(-10deg);
  transform-style: preserve-3d;
}

.card-3d {
  transform-style: preserve-3d;
  transition: transform 0.6s;
}

.card-3d:hover {
  transform: rotateY(180deg);
}

.card-3d-front,
.card-3d-back {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
}

.card-3d-back {
  transform: rotateY(180deg);
}

/* Morphing Shapes */
.blob {
  border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
  animation: blobMorph 8s ease-in-out infinite;
}

@keyframes blobMorph {
  0%, 100% {
    border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
  }
  33% {
    border-radius: 70% 30% 30% 70% / 70% 70% 30% 30%;
  }
  66% {
    border-radius: 30% 70% 70% 30% / 50% 30% 70% 50%;
  }
}

/* Noise Texture */
.noise {
  position: relative;
}

.noise::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' /%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(/%23noise)' opacity='0.02'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: 0.03;
}

/* Grain Effect */
.grain {
  position: relative;
}

.grain::after {
  content: "";
  position: absolute;
  top: -100%;
  left: -100%;
  right: -100%;
  bottom: -100%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(/%23noiseFilter)' opacity='0.02'/%3E%3C/svg%3E");
  pointer-events: none;
  opacity: 0.1;
  animation: grain 8s steps(10) infinite;
}

@keyframes grain {
  0%, 100% { transform: translate(0, 0); }
  10% { transform: translate(-5%, -10%); }
  20% { transform: translate(-15%, 5%); }
  30% { transform: translate(7%, -25%); }
  40% { transform: translate(20%, 25%); }
  50% { transform: translate(-15%, 10%); }
  60% { transform: translate(15%, 0%); }
  70% { transform: translate(0%, 15%); }
  80% { transform: translate(-10%, 10%); }
  90% { transform: translate(10%, 0%); }
}

/* Spotlight Effect */
.spotlight {
  position: relative;
  overflow: hidden;
}

.spotlight::before {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(
    circle,
    rgba(255, 255, 255, 0.1) 0%,
    transparent 70%
  );
  animation: spotlightMove 5s ease-in-out infinite;
}

@keyframes spotlightMove {
  0%, 100% {
    transform: translate(-30%, -30%);
  }
  33% {
    transform: translate(30%, -30%);
  }
  66% {
    transform: translate(0%, 30%);
  }
}

/* Floating Animation */
.float {
  animation: float 3s ease-in-out infinite;
}

@keyframes float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}

/* Tilt Effect */
.tilt {
  transition: transform 0.3s ease;
}

.tilt:hover {
  transform: rotateX(10deg) rotateY(-10deg) scale(1.05);
}

/* Reveal on Scroll */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger Animation */
.stagger-item {
  opacity: 0;
  transform: translateY(20px);
  animation: staggerReveal 0.5s ease-out forwards;
}

@keyframes staggerReveal {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.stagger-item:nth-child(1) { animation-delay: 0.1s; }
.stagger-item:nth-child(2) { animation-delay: 0.2s; }
.stagger-item:nth-child(3) { animation-delay: 0.3s; }
.stagger-item:nth-child(4) { animation-delay: 0.4s; }
.stagger-item:nth-child(5) { animation-delay: 0.5s; }

/* Magnetic Button Effect */
.magnetic {
  position: relative;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Ken Burns Effect */
.ken-burns {
  animation: kenBurns 20s ease-out infinite alternate;
}

@keyframes kenBurns {
  0% {
    transform: scale(1);
    transform-origin: top left;
  }
  100% {
    transform: scale(1.2);
    transform-origin: bottom right;
  }
}

/* Liquid Button */
.liquid {
  position: relative;
  overflow: hidden;
}

.liquid::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  transform: translate(-50%, -50%);
  transition: width 0.6s ease-out, height 0.6s ease-out;
}

.liquid:hover::before {
  width: 300px;
  height: 300px;
}

/* Infinity Border */
.infinity-border {
  position: relative;
  overflow: hidden;
}

.infinity-border::before {
  content: "";
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(
    45deg,
    var(--color-primary-500),
    var(--color-accent-500),
    var(--color-primary-500)
  );
  z-index: -1;
  animation: infinityBorder 3s linear infinite;
  background-size: 200% 200%;
}

@keyframes infinityBorder {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: 200% 200%;
  }
}
/* Design System - Utility Helpers */

/* Display Utilities */
.hidden { display: none !important; }
.block { display: block !important; }
.inline-block { display: inline-block !important; }
.inline { display: inline !important; }
.flex { display: flex !important; }
.inline-flex { display: inline-flex !important; }
.grid { display: grid !important; }

/* Visibility */
.visible { visibility: visible !important; }
.invisible { visibility: hidden !important; }

/* Opacity */
.opacity-0 { opacity: 0 !important; }
.opacity-25 { opacity: 0.25 !important; }
.opacity-50 { opacity: 0.5 !important; }
.opacity-75 { opacity: 0.75 !important; }
.opacity-100 { opacity: 1 !important; }

/* Position */
.static { position: static !important; }
.relative { position: relative !important; }
.absolute { position: absolute !important; }
.fixed { position: fixed !important; }
.sticky { position: sticky !important; }

/* Positioning */
.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }
.top-0 { top: 0 !important; }
.right-0 { right: 0 !important; }
.bottom-0 { bottom: 0 !important; }
.left-0 { left: 0 !important; }

/* Flexbox */
.flex-row { flex-direction: row !important; }
.flex-col { flex-direction: column !important; }
.flex-wrap { flex-wrap: wrap !important; }
.flex-nowrap { flex-wrap: nowrap !important; }
.flex-1 { flex: 1 1 0% !important; }
.flex-auto { flex: 1 1 auto !important; }
.flex-none { flex: none !important; }
.flex-grow { flex-grow: 1 !important; }
.flex-shrink { flex-shrink: 1 !important; }
.flex-shrink-0 { flex-shrink: 0 !important; }

/* Flexbox Alignment */
.items-start { align-items: flex-start !important; }
.items-center { align-items: center !important; }
.items-end { align-items: flex-end !important; }
.items-baseline { align-items: baseline !important; }
.items-stretch { align-items: stretch !important; }

.justify-start { justify-content: flex-start !important; }
.justify-center { justify-content: center !important; }
.justify-end { justify-content: flex-end !important; }
.justify-between { justify-content: space-between !important; }
.justify-around { justify-content: space-around !important; }
.justify-evenly { justify-content: space-evenly !important; }

.self-auto { align-self: auto !important; }
.self-start { align-self: flex-start !important; }
.self-center { align-self: center !important; }
.self-end { align-self: flex-end !important; }
.self-stretch { align-self: stretch !important; }

/* Grid */
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)) !important; }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
.grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)) !important; }
.grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }

/* Width */
.w-full { width: 100% !important; }
.w-auto { width: auto !important; }
.w-screen { width: 100vw !important; }
.w-min { width: min-content !important; }
.w-max { width: max-content !important; }

/* Max Width */
.max-w-none { max-width: none !important; }
.max-w-xs { max-width: 20rem !important; }
.max-w-sm { max-width: 24rem !important; }
.max-w-md { max-width: 28rem !important; }
.max-w-lg { max-width: 32rem !important; }
.max-w-xl { max-width: 36rem !important; }
.max-w-2xl { max-width: 42rem !important; }
.max-w-3xl { max-width: 48rem !important; }
.max-w-4xl { max-width: 56rem !important; }
.max-w-5xl { max-width: 64rem !important; }
.max-w-6xl { max-width: 72rem !important; }
.max-w-7xl { max-width: 80rem !important; }
.max-w-full { max-width: 100% !important; }

/* Height */
.h-full { height: 100% !important; }
.h-auto { height: auto !important; }
.h-screen { height: 100vh !important; }
.h-min { height: min-content !important; }
.h-max { height: max-content !important; }

/* Min Height */
.min-h-0 { min-height: 0 !important; }
.min-h-full { min-height: 100% !important; }
.min-h-screen { min-height: 100vh !important; }

/* Overflow */
.overflow-auto { overflow: auto !important; }
.overflow-hidden { overflow: hidden !important; }
.overflow-visible { overflow: visible !important; }
.overflow-scroll { overflow: scroll !important; }
.overflow-x-auto { overflow-x: auto !important; }
.overflow-y-auto { overflow-y: auto !important; }
.overflow-x-hidden { overflow-x: hidden !important; }
.overflow-y-hidden { overflow-y: hidden !important; }

/* Cursor */
.cursor-auto { cursor: auto !important; }
.cursor-default { cursor: default !important; }
.cursor-pointer { cursor: pointer !important; }
.cursor-wait { cursor: wait !important; }
.cursor-text { cursor: text !important; }
.cursor-move { cursor: move !important; }
.cursor-not-allowed { cursor: not-allowed !important; }

/* User Select */
.select-none { user-select: none !important; }
.select-text { user-select: text !important; }
.select-all { user-select: all !important; }
.select-auto { user-select: auto !important; }

/* Pointer Events */
.pointer-events-none { pointer-events: none !important; }
.pointer-events-auto { pointer-events: auto !important; }

/* Aspect Ratio */
.aspect-square { aspect-ratio: 1 / 1 !important; }
.aspect-video { aspect-ratio: 16 / 9 !important; }

/* Object Fit */
.object-contain { object-fit: contain !important; }
.object-cover { object-fit: cover !important; }
.object-fill { object-fit: fill !important; }
.object-none { object-fit: none !important; }
.object-scale-down { object-fit: scale-down !important; }

/* Backgrounds */
.bg-transparent { background-color: transparent !important; }
.bg-current { background-color: currentColor !important; }
.bg-white { background-color: white !important; }
.bg-black { background-color: black !important; }

/* Borders */
.border-0 { border-width: 0 !important; }
.border { border-width: 1px !important; }
.border-2 { border-width: 2px !important; }
.border-4 { border-width: 4px !important; }
.border-t { border-top-width: 1px !important; }
.border-r { border-right-width: 1px !important; }
.border-b { border-bottom-width: 1px !important; }
.border-l { border-left-width: 1px !important; }

/* Border Styles */
.border-solid { border-style: solid !important; }
.border-dashed { border-style: dashed !important; }
.border-dotted { border-style: dotted !important; }
.border-none { border-style: none !important; }

/* Divide (for child elements) */
.divide-y > * + * { border-top-width: 1px; }
.divide-x > * + * { border-left-width: 1px; }

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

.not-sr-only {
  position: static !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: normal !important;
}

/* Focus Within */
.focus-within\:sr-only:focus-within {
  position: static !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: normal !important;
}

/* Responsive Utilities */
@media (min-width: 640px) {
  .sm\:hidden { display: none !important; }
  .sm\:block { display: block !important; }
  .sm\:inline-block { display: inline-block !important; }
  .sm\:flex { display: flex !important; }
  .sm\:grid { display: grid !important; }
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .sm\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
}

@media (min-width: 768px) {
  .md\:hidden { display: none !important; }
  .md\:block { display: block !important; }
  .md\:inline-block { display: inline-block !important; }
  .md\:flex { display: flex !important; }
  .md\:grid { display: grid !important; }
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}

@media (min-width: 1024px) {
  .lg\:hidden { display: none !important; }
  .lg\:block { display: block !important; }
  .lg\:inline-block { display: inline-block !important; }
  .lg\:flex { display: flex !important; }
  .lg\:grid { display: grid !important; }
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
  .lg\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)) !important; }
}

/* Print Utilities */
@media print {
  .print\:hidden { display: none !important; }
  .print\:block { display: block !important; }
}

/* Loading States */
.loading {
  position: relative;
  pointer-events: none;
  opacity: 0.6;
}

.loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1.5rem;
  height: 1.5rem;
  border: 2px solid var(--color-primary-200);
  border-top-color: var(--color-primary-600);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

/* Skeleton Loading */
.skeleton-box {
  background: linear-gradient(
    90deg,
    var(--color-gray-200) 25%,
    var(--color-gray-100) 50%,
    var(--color-gray-200) 75%
  );
  background-size: 200% 100%;
  animation: skeleton 1.5s ease-in-out infinite;
  border-radius: var(--radius-md);
}

/* Glassmorphism */
.glass {
  background: var(--glass-background);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
}

/* No Scroll */
.no-scroll {
  overflow: hidden !important;
}

/* Sticky Top */
.sticky-top {
  position: sticky !important;
  top: 0 !important;
  z-index: var(--z-sticky) !important;
}

/* Center Absolute */
.center-absolute {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
}

/* Full Overlay */
.full-overlay {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
}

/* Image Cover */
.img-cover {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Clearfix */
.clearfix::after {
  content: "" !important;
  display: table !important;
  clear: both !important;
}
@tailwind base;
@tailwind components;
@tailwind utilities;

@layer base {
  html {
    font-family: 'Nunito', system-ui, sans-serif;
  }
}
/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
 * vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS
 * files in this directory. Styles in this file should be added after the last require_* statement.
 * It is generally better to create a new file per style scope.
 *


 */

/* Import Google Fonts - Only loading fonts that work without sanitizer issues */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kalam:wght@400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Crafty+Girls&display=swap');

/* Import Design System - Must be after require statements for proper cascade */

/* Apply Nunito as the main font */
html, body {
  font-family: 'Nunito', sans-serif;
}

/* Use Crafty Girls for the logo only */
.logo-text {
  font-family: 'Crafty Girls', cursive;
  font-size: 2.2rem;
  color: #4285F4;
  letter-spacing: 0.05em;
  position: relative;
  text-shadow: 0 1px 4px rgba(68,71,91,0.04);
}
.logo-text .u-smile {
  color: #FFBFAE;
  margin-left: 2px;
  margin-right: 2px;
  position: relative;
  display: inline-block;
}

/* Add padding to all form elements */
input:not([type="checkbox"]):not([type="radio"]),
select,
textarea {
  padding: 0.5rem !important; /* p-2 equivalent */
}

/* Child name styling with Crafty Girls font */
.child-name {
  font-family: 'Crafty Girls', cursive;
  color: #4f46e5; /* Indigo-600 */
}

/* Mobile Link Improvements */

/* Make navigation links larger on mobile */
@media (max-width: 767px) {
  .mobile-link {
    font-size: 1rem !important;
    padding: 0.5rem 0.75rem !important;
    margin: 0.25rem 0 !important;
    display: inline-block !important;
    min-height: 44px !important;
    min-width: 44px !important;
    display: flex !important;
    align-items: center !important;
  }
  
  /* Make list item links take the full width of their container */
  .mobile-list-item {
    padding: 0.75rem 1rem !important;
    display: flex !important;
    width: 100% !important;
  }

  /* Increase spacing between actionable items */
  .mobile-action-group {
    display: flex !important;
    flex-direction: column !important; 
    gap: 0.5rem !important;
  }
  
  /* Make buttons and actionable items larger */
  .mobile-action {
    min-height: 44px !important;
    min-width: 44px !important;
    padding: 0.5rem 0.75rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  /* Special styling for icon-only links */
  .mobile-icon-link {
    min-height: 44px !important;
    min-width: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  /* Make entire card/row clickable for navigation */
  .mobile-card-link {
    position: relative !important;
  }
  
  .mobile-card-link::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  
  /* Fix positioning within clickable cards */
  .mobile-card-link > * {
    position: relative;
    z-index: 2;
  }
}

/* Import Design System - Placed at end for proper cascade */
@import 'design-system/index.css';

/* Global fix for link colors in buttons - MUST be after design system import */
/* Dark backgrounds get white text */
a[class*="bg-indigo-"][class*="600"],
a[class*="bg-indigo-"][class*="700"],
a[class*="bg-purple-"][class*="600"],
a[class*="bg-purple-"][class*="700"],
a[class*="bg-green-"][class*="600"],
a[class*="bg-green-"][class*="700"],
a[class*="bg-blue-"][class*="600"],
a[class*="bg-blue-"][class*="700"],
a[class*="bg-red-"][class*="600"],
a[class*="bg-red-"][class*="700"],
a[class*="bg-pink-"][class*="600"],
a[class*="bg-pink-"][class*="700"],
a[class*="bg-gradient"],
a.text-white,
.text-white a {
  color: white !important;
}

/* Light backgrounds get black text */
a[class*="bg-indigo-50"],
a[class*="bg-indigo-100"],
a[class*="bg-purple-50"],
a[class*="bg-purple-100"],
a[class*="bg-green-50"],
a[class*="bg-green-100"],
a[class*="bg-blue-50"],
a[class*="bg-blue-100"],
a[class*="bg-amber-50"],
a[class*="bg-amber-100"],
a[class*="bg-gray-50"],
a[class*="bg-gray-100"],
a[class*="bg-yellow-50"],
a[class*="bg-yellow-100"],
a[class*="bg-red-50"],
a[class*="bg-red-100"],
a[class*="bg-pink-50"],
a[class*="bg-pink-100"] {
  color: black !important;
}

/* Ensure no underlines on button links and card links */
a.inline-flex,
a.btn,
button a,
a[class*="rounded"],
a.block.group {
  text-decoration: none !important;
}

/* Prevent underline on hover for block group links */
a.block.group:hover {
  text-decoration: none !important;
}

/* Fix icon link colors - override default blue */
a i.fas,
a i.far,
a i.fab {
  color: inherit !important;
}

/* Specific icon colors */
a.text-gray-500 { color: #6b7280 !important; }
a.text-gray-500:hover { color: #374151 !important; }
a.text-amber-600 { color: #d97706 !important; }
a.text-red-600 { color: #dc2626 !important; }

/* Ensure icons inherit parent color */
.text-gray-500 i { color: #6b7280 !important; }
.text-gray-700 i { color: #374151 !important; }
.text-amber-600 i { color: #d97706 !important; }
.text-red-600 i { color: #dc2626 !important; }

/* Remove unwanted borders from timeline items and any list items */
.space-y-3 > div:last-child,
.space-y-4 > div:last-child,
li:last-child,
ul li:last-child,
ol li:last-child {
  border-bottom: none !important;
  border-top: none !important;
}

/* Global fix for input fields and selects with icons */
/* Force proper left padding for all input types that might have icons */
input[type="text"].pl-10,
input[type="email"].pl-10,
input[type="tel"].pl-10,
input[type="search"].pl-10,
input[type="datetime-local"].pl-10,
input[type="date"].pl-10,
input[type="time"].pl-10,
input[type="number"].pl-10,
input[type="password"].pl-10,
select.pl-10 {
  padding-left: 2.5rem !important; /* 40px - equivalent to pl-10 */
}

/* For pl-12 inputs (like datetime-local that need more space) */
input[type="text"].pl-12,
input[type="email"].pl-12,
input[type="tel"].pl-12,
input[type="search"].pl-12,
input[type="datetime-local"].pl-12,
input[type="date"].pl-12,
input[type="time"].pl-12,
input[type="number"].pl-12,
input[type="password"].pl-12,
select.pl-12 {
  padding-left: 3rem !important; /* 48px - equivalent to pl-12 */
}

/* Specific fix for datetime-local inputs which often ignore padding */
input[type="datetime-local"],
input[type="date"],
input[type="time"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* Specific fix for select elements to ensure padding is respected */
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  padding-right: 2.5rem !important;
}

/* Ensure the icon containers are properly positioned */
.relative > .absolute.left-0.pl-3 {
  left: 0;
  padding-left: 0.75rem;
  z-index: 10;
}

/* Alert System */
.alert {
  border-radius: 0.5rem;
  padding: 1.25rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(4px);
  border: 1px solid;
}

.alert-success {
  background-color: #f0fdf4;
  border-color: #bbf7d0;
}

.alert-error {
  background-color: #fef2f2;
  border-color: #fecaca;
}

.alert-warning {
  background-color: #fffbeb;
  border-color: #fed7aa;
}

.alert-info {
  background-color: #eff6ff;
  border-color: #bfdbfe;
}
