@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap');

@custom-variant dark (&:is(.dark *));

:root {
  --font-size: 14px;
  --background: #ffffff;
  --foreground: oklch(0.145 0 0);
  --card: #ffffff;
  --card-foreground: oklch(0.145 0 0);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.145 0 0);
  --primary: #030213;
  --primary-foreground: oklch(1 0 0);
  --secondary: oklch(0.95 0.0058 264.53);
  --secondary-foreground: #030213;
  --muted: #ececf0;
  --muted-foreground: #717182;
  --accent: #e9ebef;
  --accent-foreground: #030213;
  --destructive: #d4183d;
  --destructive-foreground: #ffffff;
  --border: rgba(0, 0, 0, 0.1);
  --input: transparent;
  --input-background: #f3f3f5;
  --switch-background: #cbced4;
  --font-weight-medium: 500;
  --font-weight-normal: 400;
  --ring: oklch(0.708 0 0);
  --chart-1: oklch(0.646 0.222 41.116);
  --chart-2: oklch(0.6 0.118 184.704);
  --chart-3: oklch(0.398 0.07 227.392);
  --chart-4: oklch(0.828 0.189 84.429);
  --chart-5: oklch(0.769 0.188 70.08);
  --radius: 0.625rem;
  --sidebar: oklch(0.985 0 0);
  --sidebar-foreground: oklch(0.145 0 0);
  --sidebar-primary: #030213;
  --sidebar-primary-foreground: oklch(0.985 0 0);
  --sidebar-accent: oklch(0.97 0 0);
  --sidebar-accent-foreground: oklch(0.205 0 0);
  --sidebar-border: oklch(0.922 0 0);
  --sidebar-ring: oklch(0.708 0 0);
  
  /* MMP White, Orange & Brown Brand Colors */
  --mmp-white: #FFFFFF;
  --mmp-off-white: #FAFAFA;
  --mmp-light-gray: #F5F5F5;
  --mmp-cream: #FFF8F0;
  --mmp-black: #000000;
  --mmp-near-black: #0A0A0A;
  --mmp-charcoal: #1A1A1A;
  --mmp-dark-gray: #2A2A2A;
  --mmp-brown-darkest: #1A0F0A;
  --mmp-brown-dark: #2D1810;
  --mmp-brown-deep: #4A2C1A;
  --mmp-brown-medium: #6B3E2A;
  --mmp-brown: #8B4513;
  --mmp-brown-light: #A0522D;
  --mmp-brown-lighter: #CD853F;
  --mmp-tan-dark: #B8860B;
  --mmp-tan: #D2B48C;
  --mmp-tan-light: #DDB892;
  --mmp-orange-darkest: #B8400A;
  --mmp-orange-dark: #CC5500;
  --mmp-orange: #FF6600;
  --mmp-orange-medium: #FF7F33;
  --mmp-orange-light: #FF8533;
  --mmp-orange-lighter: #FFB366;
  --mmp-orange-pale: #FFE5CC;
  --mmp-orange-cream: #FFF2E5;
  /* High-contrast text colors for accessibility */
  --mmp-text-primary: #0A0A0A;
  --mmp-text-secondary: #1A1A1A;
  --mmp-text-tertiary: #2A2A2A;
  --mmp-text-muted: #4A4A4A;
  --mmp-text-light: #6A6A6A;
  /* White text for dark backgrounds */
  --mmp-text-white: #FFFFFF;
  --mmp-text-off-white: #FAFAFA;
  --mmp-text-light-gray: #F0F0F0;
}

.dark {
  --background: var(--mmp-charcoal);
  --foreground: #FFFFFF;
  --card: var(--mmp-near-black);
  --card-foreground: #FFFFFF;
  --popover: var(--mmp-near-black);
  --popover-foreground: #FFFFFF;
  --primary: #FFFFFF;
  --primary-foreground: var(--mmp-charcoal);
  --secondary: var(--mmp-dark-gray);
  --secondary-foreground: #FFFFFF;
  --muted: var(--mmp-dark-gray);
  --muted-foreground: rgba(255, 255, 255, 0.7);
  --accent: var(--mmp-dark-gray);
  --accent-foreground: #FFFFFF;
  --destructive: oklch(0.396 0.141 25.723);
  --destructive-foreground: oklch(0.637 0.237 25.331);
  --border: #3A3A3A;
  --input: var(--mmp-dark-gray);
  --input-background: var(--mmp-dark-gray);
  --switch-background: var(--mmp-dark-gray);
  --ring: oklch(0.439 0 0);
  --font-weight-medium: 500;
  --font-weight-normal: 400;
  --chart-1: oklch(0.488 0.243 264.376);
  --chart-2: oklch(0.696 0.17 162.48);
  --chart-3: oklch(0.769 0.188 70.08);
  --chart-4: oklch(0.627 0.265 303.9);
  --chart-5: oklch(0.645 0.246 16.439);
  --sidebar: var(--mmp-near-black);
  --sidebar-foreground: #FFFFFF;
  --sidebar-primary: var(--mmp-orange);
  --sidebar-primary-foreground: var(--mmp-text-white);
  --sidebar-accent: var(--mmp-dark-gray);
  --sidebar-accent-foreground: #FFFFFF;
  --sidebar-border: #3A3A3A;
  --sidebar-ring: oklch(0.439 0 0);

  /* Dark mode adjustments for brand colors */
  --mmp-cream: var(--mmp-brown-darkest);
  --mmp-orange-cream: rgba(255, 102, 0, 0.1);
  --mmp-light-gray: var(--mmp-dark-gray);
  
  /* White text hierarchy for dark mode */
  --text-white-primary: #FFFFFF;
  --text-white-secondary: rgba(255, 255, 255, 0.9);
  --text-white-tertiary: rgba(255, 255, 255, 0.7);
  --text-white-muted: rgba(255, 255, 255, 0.6);
  --text-white-placeholder: rgba(255, 255, 255, 0.5);
}

@theme inline {
  --color-background: var(--background);
  --color-foreground: var(--foreground);
  --color-card: var(--card);
  --color-card-foreground: var(--card-foreground);
  --color-popover: var(--popover);
  --color-popover-foreground: var(--popover-foreground);
  --color-primary: var(--primary);
  --color-primary-foreground: var(--primary-foreground);
  --color-secondary: var(--secondary);
  --color-secondary-foreground: var(--secondary-foreground);
  --color-muted: var(--muted);
  --color-muted-foreground: var(--muted-foreground);
  --color-accent: var(--accent);
  --color-accent-foreground: var(--accent-foreground);
  --color-destructive: var(--destructive);
  --color-destructive-foreground: var(--destructive-foreground);
  --color-border: var(--border);
  --color-input: var(--input);
  --color-input-background: var(--input-background);
  --color-switch-background: var(--switch-background);
  --color-ring: var(--ring);
  --color-chart-1: var(--chart-1);
  --color-chart-2: var(--chart-2);
  --color-chart-3: var(--chart-3);
  --color-chart-4: var(--chart-4);
  --color-chart-5: var(--chart-5);
  --radius-sm: calc(var(--radius) - 4px);
  --radius-md: calc(var(--radius) - 2px);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) + 4px);
  --color-sidebar: var(--sidebar);
  --color-sidebar-foreground: var(--sidebar-foreground);
  --color-sidebar-primary: var(--sidebar-primary);
  --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
  --color-sidebar-accent: var(--sidebar-accent);
  --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
  --color-sidebar-border: var(--sidebar-border);
  --color-sidebar-ring: var(--sidebar-ring);
  
  /* MMP Brand Colors */
  --color-mmp-white: var(--mmp-white);
  --color-mmp-off-white: var(--mmp-off-white);
  --color-mmp-light-gray: var(--mmp-light-gray);
  --color-mmp-cream: var(--mmp-cream);
  --color-mmp-black: var(--mmp-black);
  --color-mmp-near-black: var(--mmp-near-black);
  --color-mmp-charcoal: var(--mmp-charcoal);
  --color-mmp-dark-gray: var(--mmp-dark-gray);
  --color-mmp-brown-darkest: var(--mmp-brown-darkest);
  --color-mmp-brown-dark: var(--mmp-brown-dark);
  --color-mmp-brown-deep: var(--mmp-brown-deep);
  --color-mmp-brown-medium: var(--mmp-brown-medium);
  --color-mmp-brown: var(--mmp-brown);
  --color-mmp-brown-light: var(--mmp-brown-light);
  --color-mmp-brown-lighter: var(--mmp-brown-lighter);
  --color-mmp-tan-dark: var(--mmp-tan-dark);
  --color-mmp-tan: var(--mmp-tan);
  --color-mmp-tan-light: var(--mmp-tan-light);
  --color-mmp-orange-darkest: var(--mmp-orange-darkest);
  --color-mmp-orange-dark: var(--mmp-orange-dark);
  --color-mmp-orange: var(--mmp-orange);
  --color-mmp-orange-medium: var(--mmp-orange-medium);
  --color-mmp-orange-light: var(--mmp-orange-light);
  --color-mmp-orange-lighter: var(--mmp-orange-lighter);
  --color-mmp-orange-pale: var(--mmp-orange-pale);
  --color-mmp-orange-cream: var(--mmp-orange-cream);
  --color-mmp-text-primary: var(--mmp-text-primary);
  --color-mmp-text-secondary: var(--mmp-text-secondary);
  --color-mmp-text-tertiary: var(--mmp-text-tertiary);
  --color-mmp-text-muted: var(--mmp-text-muted);
  --color-mmp-text-light: var(--mmp-text-light);
  --color-mmp-text-white: var(--mmp-text-white);
  --color-mmp-text-off-white: var(--mmp-text-off-white);
  --color-mmp-text-light-gray: var(--mmp-text-light-gray);
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }

  body {
    @apply bg-background text-foreground transition-colors duration-300;
    font-family: 'Inter', sans-serif;
  }
  
  .font-heading {
    font-family: 'Montserrat', sans-serif;
  }
  
  .font-logo {
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
  }
}

/**
 * Base typography with white text hierarchy in dark mode
 */
@layer base {
  :where(:not(:has([class*=" text-"]), :not(:has([class^="text-"])))) {
    h1 {
      font-size: var(--text-2xl);
      font-weight: 700;
      line-height: 1.4;
      font-family: 'Montserrat', sans-serif;
      color: var(--foreground);
    }

    h2 {
      font-size: var(--text-xl);
      font-weight: 600;
      line-height: 1.4;
      font-family: 'Montserrat', sans-serif;
      color: var(--foreground);
    }

    h3 {
      font-size: var(--text-lg);
      font-weight: 600;
      line-height: 1.4;
      font-family: 'Montserrat', sans-serif;
      color: var(--foreground);
    }

    h4 {
      font-size: var(--text-base);
      font-weight: 600;
      line-height: 1.4;
      font-family: 'Montserrat', sans-serif;
      color: var(--foreground);
    }

    p {
      font-size: var(--text-base);
      font-weight: 400;
      line-height: 1.6;
      font-family: 'Inter', sans-serif;
      color: var(--muted-foreground);
    }

    label {
      font-size: var(--text-base);
      font-weight: 500;
      line-height: 1.5;
      font-family: 'Inter', sans-serif;
      color: var(--foreground);
    }

    button {
      font-size: var(--text-base);
      font-weight: 500;
      line-height: 1.5;
      font-family: 'Montserrat', sans-serif;
    }

    input {
      font-size: var(--text-base);
      font-weight: 400;
      line-height: 1.5;
      font-family: 'Inter', sans-serif;
      color: var(--foreground);
    }
  }
}

html {
  font-size: var(--font-size);
  scroll-behavior: smooth;
}

/* Enhanced Animations */
.floating-particle {
  animation: floatParticle 4s ease-in-out infinite;
}

@keyframes floatParticle {
  0%, 100% { transform: translateY(0px) translateX(0px) scale(1); opacity: 0.4; }
  33% { transform: translateY(-15px) translateX(5px) scale(1.1); opacity: 0.6; }
  66% { transform: translateY(-5px) translateX(-5px) scale(0.9); opacity: 0.8; }
}

/* Fade In Animations */
.fade-in {
  animation: fadeIn 0.8s ease-out forwards;
  opacity: 0;
}

.fade-in-up {
  animation: fadeInUp 0.8s ease-out forwards;
  opacity: 0;
  transform: translateY(30px);
}

.fade-in-left {
  animation: fadeInLeft 0.8s ease-out forwards;
  opacity: 0;
  transform: translateX(-30px);
}

.fade-in-right {
  animation: fadeInRight 0.8s ease-out forwards;
  opacity: 0;
  transform: translateX(30px);
}

.fade-in-scale {
  animation: fadeInScale 0.8s ease-out forwards;
  opacity: 0;
  transform: scale(0.9);
}

/* Staggered animations */
.fade-in-delay-100 { animation-delay: 0.1s; }
.fade-in-delay-200 { animation-delay: 0.2s; }
.fade-in-delay-300 { animation-delay: 0.3s; }
.fade-in-delay-400 { animation-delay: 0.4s; }
.fade-in-delay-500 { animation-delay: 0.5s; }
.fade-in-delay-600 { animation-delay: 0.6s; }
.fade-in-delay-700 { animation-delay: 0.7s; }
.fade-in-delay-800 { animation-delay: 0.8s; }

@keyframes fadeIn {
  to { opacity: 1; }
}

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

@keyframes fadeInLeft {
  to { 
    opacity: 1; 
    transform: translateX(0);
  }
}

@keyframes fadeInRight {
  to { 
    opacity: 1; 
    transform: translateX(0);
  }
}

@keyframes fadeInScale {
  to { 
    opacity: 1; 
    transform: scale(1);
  }
}

/* Hover Animations */
.hover-lift {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.hover-lift:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(255, 102, 0, 0.15);
}

.hover-scale {
  transition: transform 0.3s ease;
}

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

/* Smooth scrollbar - Dark mode friendly */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--muted);
}

::-webkit-scrollbar-thumb {
  background: var(--mmp-orange);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--mmp-orange-dark);
}

/* Page transition */
.page-transition {
  animation: pageLoad 1s ease-out;
}

@keyframes pageLoad {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Loading spinner */
.spinner {
  animation: spin 1s linear infinite;
}

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

/* Subtle animations for special elements */
.breathe {
  animation: breathe 4s ease-in-out infinite;
}

@keyframes breathe {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.02); }
}

/* Logo-specific typography classes */
.text-logo-primary {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.text-logo-secondary {
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
}

/* Dark mode specific enhancements */
.dark .hover-lift:hover {
  box-shadow: 0 12px 30px rgba(255, 102, 0, 0.25);
}

/* White text with visual hierarchy in dark mode */
.dark {
  /* Primary text - Pure white for headings and important content */
  --foreground: #FFFFFF;
  --card-foreground: #FFFFFF;
  --primary: #FFFFFF;
  --secondary-foreground: #FFFFFF;
  --accent-foreground: #FFFFFF;
  --sidebar-foreground: #FFFFFF;
  --sidebar-accent-foreground: #FFFFFF;
  
  /* Secondary text - Slightly reduced opacity for body text */
  --muted-foreground: rgba(255, 255, 255, 0.7);
}

/* Dark mode text hierarchy classes */
.dark .text-white-primary {
  color: #FFFFFF !important;
}

.dark .text-white-secondary {
  color: rgba(255, 255, 255, 0.9) !important;
}

.dark .text-white-tertiary {
  color: rgba(255, 255, 255, 0.7) !important;
}

.dark .text-white-muted {
  color: rgba(255, 255, 255, 0.6) !important;
}

/* Smooth transitions for dark mode */
* {
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

/* Dark mode form elements with white text */
.dark input,
.dark textarea,
.dark select {
  background-color: var(--input-background);
  border-color: var(--border);
  color: #FFFFFF;
}

.dark input::placeholder,
.dark textarea::placeholder {
  color: rgba(255, 255, 255, 0.5);
  opacity: 1;
}

/* Dark mode button improvements with white text */
.dark button:not([class*="bg-"]) {
  background-color: var(--accent);
  color: #FFFFFF;
}

/* Dark mode card enhancements with white text */
.dark .card,
.dark [class*="card"] {
  background-color: var(--card);
  border-color: var(--border);
  color: #FFFFFF;
}

/* Dark mode dropdown and popover white text */
.dark [role="menu"],
.dark [role="menuitem"],
.dark [data-radix-collection-item] {
  color: #FFFFFF;
}

/* Dark mode navigation white text */
.dark nav,
.dark nav * {
  color: #FFFFFF;
}

.dark nav a:hover,
.dark nav button:hover {
  color: var(--mmp-orange) !important;
}

/* Ensure all headings are pure white in dark mode */
.dark h1,
.dark h2,
.dark h3,
.dark h4,
.dark h5,
.dark h6 {
  color: #FFFFFF !important;
}

/* Ensure all paragraph text has proper hierarchy in dark mode */
.dark p {
  color: rgba(255, 255, 255, 0.85) !important;
}

/* Ensure all labels are white in dark mode */
.dark label {
  color: #FFFFFF !important;
}

/* Dark mode link styles */
.dark a {
  color: #FFFFFF;
}

.dark a:hover {
  color: var(--mmp-orange);
}

/* Dark mode list items */
.dark li {
  color: rgba(255, 255, 255, 0.85);
}

/* Dark mode spans and small text */
.dark span,
.dark small {
  color: rgba(255, 255, 255, 0.75);
}

/* Dark mode strong and emphasized text */
.dark strong,
.dark em,
.dark b {
  color: #FFFFFF;
}