@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Montserrat:wght@400;500;700&display=swap');

/* Global box-sizing rules */
html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

:root {
  /* Default to a dark theme as primary */
  --foreground-rgb: 240, 240, 240; /* Off-white text */
  --background-start-rgb: 26, 26, 26; /* #1A1A1A Dark Gray */
  --background-end-rgb: 26, 26, 26;   /* #1A1A1A Dark Gray */

  --primary-accent-rgb: 0, 168, 232; /* NEW: #00A8E8 Electric Blue */
  --secondary-accent-rgb: 0, 126, 167; /* NEW: #007EA7 Deeper Blue */
  --primary-action-hover-rgb: 0, 144, 199; /* NEW: #0090C7 Darker Blue for hover */
  --golden-accent-rgb: 255, 215, 0; /* NEW: #FFD700 Golden Yellow */

  /* For any light theme sections if needed later */
  --light-background-rgb: 248, 249, 250; /* #f8f9fa Light grey */
  --light-foreground-rgb: 26, 26, 26; /* Dark text for light backgrounds */

  /* === Colors === */
  --color-primary-accent: #00A8E8; /* NEW: Electric Blue */
  --color-primary-accent-hover: #0090C7; /* NEW: Darker Blue for hover */
  --color-primary-text-on-accent: #FFFFFF; /* Adjusted for better contrast with blue */
  --color-golden-accent: #FFD700; /* NEW: Golden Yellow */

  --color-background-nav: #1F1F1F;
  --color-background-mobile-menu: #181818;
  --color-background-page: #121212; /* Assuming a general very dark page background */
  --color-background-card: #1e1e1e; /* Example for cards */

  --color-text-light: #e0e0e0;
  --color-text-links: #c0c0c0;
  --color-text-secondary: #a0a0a0;
  --color-text-headings: #ffffff;

  --color-destructive: #ff6b6b;
  --color-destructive-hover: #ff8282;

  --color-border-subtle: #333333;
  --color-shadow-rgb: 0, 0, 0; /* For use like rgba(var(--color-shadow-rgb), 0.3) */

  /* === Fonts === */
  --font-family-headings: 'Bebas Neue', sans-serif;
  --font-family-body: 'Montserrat', sans-serif;

  /* === Font Sizes === */
  --font-size-base: 1rem; /* 16px */
  --font-size-sm: 0.875rem; /* 14px */
  --font-size-lg: 1.125rem; /* 18px */
  --font-size-xl: 1.25rem; /* 20px */
  --font-size-xxl: 1.5rem; /* 24px */
  --font-size-display: 2.5rem; /* For large headings */
  --font-size-logo: 2rem;

  /* === Spacing === */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;

  /* === Border Radius === */
  --border-radius-sm: 3px;
  --border-radius-md: 5px;
  --border-radius-lg: 8px;

  /* === Transitions === */
  --transition-short: 0.2s ease-in-out;
  --transition-base: 0.3s ease-in-out;
  --transition-long: 0.4s cubic-bezier(0.23, 1, 0.32, 1);

  /* === Z-Indexes === */
  --z-index-dropdown: 500;
  --z-index-navbar: 1000;
  --z-index-modal-backdrop: 1500;
  --z-index-modal: 1501;
  --z-index-tooltip: 2000;
}

/* Force dark theme variables irrespective of OS preference for this brash style */
/* We can remove the @media (prefers-color-scheme: dark) block or ensure it matches above */

body {
  color: var(--color-text-light);
  background-color: var(--color-background-page);
  font-family: var(--font-family-body);
  font-size: var(--font-size-base);
  line-height: 1.6;
  margin: 0;
  padding: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Remove the default gradient background if it was applied directly to body before */
/* body {
  background: linear-gradient(
      to bottom,
      transparent,
      rgb(var(--background-end-rgb))
    )
    rgb(var(--background-start-rgb));
} */

@layer utilities {
  .text-balance {
    text-wrap: balance;
  }
}

/* Sticky Footer Support */
/* Applied to body in layout.tsx */
.siteLayout {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Applied to the div wrapping Navbar and main content in layout.tsx */
.siteContent {
  flex: 1 0 auto; 
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-headings);
  color: var(--color-text-headings);
  margin-top: var(--space-lg);
  margin-bottom: var(--space-md);
  line-height: 1.2;
}

a {
  color: var(--color-primary-accent);
  text-decoration: none;
  transition: color var(--transition-short);
}

a:hover {
  color: var(--color-primary-accent-hover);
}

/* Basic reset for box-sizing */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Print-specific styles for the body */
@media print {
  body {
    background-color: white !important;
    color: black !important;
    font-size: 10pt;
  }
}

/* Modern Image Format Support with Progressive Enhancement */
/* These classes will be used when WebP/AVIF images are available */

/* Hero Section - Modern Image Format Support */
.heroSection.webp-support {
  background-image: url('/images/default-hero.webp') !important;
}

.heroSection.avif-support {
  background-image: url('/images/default-hero.avif') !important;
}

/* Features Section - Modern Image Format Support */
.featuresSection.webp-support {
  background-image: url('/images/tuddy-fan-bg.webp') !important;
}

.featuresSection.avif-support {
  background-image: url('/images/tuddy-fan-bg.avif') !important;
}

/* Championship Section - Modern Image Format Support */
.championshipSection.webp-support {
  background-image: url('/images/tuddy-fan-bg.webp') !important;
}

.championshipSection.avif-support {
  background-image: url('/images/tuddy-fan-bg.avif') !important;
}

/* CSS Feature Detection for Modern Image Formats */
@supports (background-image: url('data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA')) {
  .heroSection {
    background-image: url('/images/default-hero.webp') !important;
  }
  
  .featuresSection,
  .championshipSection {
    background-image: url('/images/tuddy-fan-bg.webp') !important;
  }
}

/* AVIF support (even better compression) */
@supports (background-image: url('data:image/avif;base64,AAAAIGZ0eXBhdmlmAAAAAGF2aWZtaWYxbWlhZk1BMUIAAADybWV0YQAAAAAAAAAoaGRscgAAAAAAAAAAcGljdAAAAAAAAAAAAAAAAGxpYmF2aWYAAAAADnBpdG0AAAAAAAEAAAAeaWxvYwAAAABEAAABAAEAAAABAAABGgAAAB0AAAAoaWluZgAAAAAAAQAAABppbmZlAgAAAAABAABhdjAxQ29sb3IAAAAAamlwcnAAAABLaXBjbwAAABRpc3BlAAAAAAAAAAIAAAACAAAAEHBpeGkAAAAAAwgICAAAAAxhdjFDgQ0MAAAAABNjb2xybmNseAACAAIAAYAAAAAXaXBtYQAAAAAAAAABAAEEAQKDBAAAACVtZGF0EgAKCBgABogQEAwgMg8f8D///8WfhwB8+ErK42A=')) {
  .heroSection {
    background-image: url('/images/default-hero.avif') !important;
  }
  
  .featuresSection,
  .championshipSection {
    background-image: url('/images/tuddy-fan-bg.avif') !important;
  }
} 