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

@tailwind base;
@tailwind components;
@tailwind utilities;

@layer base {
  :root {
    --background: 210 50% 99%;
    --foreground: 210 50% 10%;
    
    --card: 0 0% 100%;
    --card-foreground: 210 50% 10%;

    --popover: 0 0% 100%;
    --popover-foreground: 210 50% 10%;

    --primary: 210 100% 15%;  /* Navy #0A2540 */
    --primary-foreground: 0 0% 100%;

    --secondary: 210 20% 96%;
    --secondary-foreground: 28 28% 18%;

    --muted: 210 20% 92%;
    --muted-foreground: 215 20% 45%;

    --accent: 210 90% 65%;
    --accent-foreground: 0 0% 100%;

    --destructive: 0 84% 60%;
    --destructive-foreground: 0 0% 100%;

    --border: 214 32% 90%;
    --input: 214 32% 90%;
    --ring: 215 20% 65%;

    --radius: 0.5rem;
    
    /* UltraData Brand Colors - Navy #0A2540 + Baby Blue #A7C7E7 */
    --brand-25: 210 40% 98%;      /* Near white with navy tint */
    --brand-50: 210 50% 96%;      /* Very light navy tint */
    --brand-100: 210 40% 90%;     /* Light navy tint */
    --brand-200: 210 50% 82%;     /* Baby blue #A7C7E7 territory */
    --brand-300: 210 60% 75%;     /* Lighter baby blue */
    --brand-400: 210 65% 68%;     /* Baby blue #A7C7E7 */
    --brand-500: 210 70% 50%;     /* Medium blue */
    --brand-600: 210 80% 35%;     /* Deeper blue */
    --brand-700: 210 90% 25%;     /* Navy blue */
    --brand-800: 210 95% 20%;     /* Dark navy */
    --brand-900: 210 100% 15%;    /* Deep navy #0A2540 */
    
    /* Accent colors - Baby blue variations */
    --accent1: 210 65% 68%;       /* Baby blue #A7C7E7 */
    --accent1-light: 210 60% 75%;
    --accent1-dark: 210 70% 60%;
    
    /* Slate for secondary text */
    --slate: 215 25% 40%;         /* Slate #64748B */
  }
}

@layer base {
  * {
    @apply border-border;
  }

  body {
    @apply bg-background text-foreground font-sans text-base leading-relaxed;
  }

  h1, h2, h3, h4, h5, h6 {
    @apply font-heading font-semibold tracking-tight text-brand-800;
  }

  h1 {
    @apply text-4xl md:text-5xl lg:text-6xl mb-6;
  }

  h2 {
    @apply text-3xl md:text-4xl lg:text-5xl mb-5;
  }

  h3 {
    @apply text-2xl md:text-3xl mb-4;
  }

  h4 {
    @apply text-xl md:text-2xl mb-3;
  }

  .container {
    @apply px-8 sm:px-12 lg:px-16 xl:px-20 2xl:px-24 max-w-[1440px] mx-auto;
  }

  .section {
    @apply py-8 sm:py-12 md:py-16 lg:py-20;
  }

  .cta-button {
    @apply bg-brand-900 hover:bg-brand-800 text-white font-medium 
           rounded-md text-base px-6 py-3 min-h-[48px] min-w-[48px]
           transform transition-all duration-200 ease-in-out 
           hover:scale-[1.02] active:scale-[0.98]
           will-change-transform touch-manipulation;
  }

  .secondary-button {
    @apply bg-white border border-brand-300 hover:bg-brand-50 text-brand-700 font-medium
           rounded-md text-base px-6 py-3 min-h-[48px] min-w-[48px]
           transform transition-all duration-200 ease-in-out
           hover:scale-[1.02] active:scale-[0.98]
           will-change-transform touch-manipulation;
  }

  .navbar-brand {
    @apply flex-shrink-0;
  }

  .navbar-brand img {
    height: 40px;
    width: auto;
    object-fit: contain;
    image-rendering: -webkit-optimize-contrast;
  }

  .fade-in-section {
    opacity: 0;
    transform: translateY(20px);
    visibility: hidden;
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
    will-change: opacity, transform, visibility;
  }
  
  .fade-in-section.is-visible {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
  }

  /* Card shimmer animation */
  .shimmer {
    @apply relative overflow-hidden before:absolute before:inset-0 
           before:translate-x-[-100%] before:animate-[shimmer_2s_infinite]
           before:bg-gradient-to-r before:from-transparent before:via-white/20 before:to-transparent;
  }

  /* Hero text animation */
  .hero-text {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.6s ease-out forwards;
  }

  .hero-text-delay-1 {
    animation-delay: 0.2s;
  }

  .hero-text-delay-2 {
    animation-delay: 0.4s;
  }
  
  @keyframes shimmer {
    100% {
      transform: translateX(100%);
    }
  }

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