@tailwind components;
@tailwind utilities;

@layer components {
  .all-\[unset\] {
    all: unset;
  }
}

:root {
  --app-border: rgba(230, 237, 255, 1);
  --app-primary: rgba(0, 0, 0, 1);
  --app-secondary: rgba(124, 141, 181, 1);
  --b6-medium-font-family: "Inter", Helvetica;
  --b6-medium-font-size: 16px;
  --b6-medium-font-style: normal;
  --b6-medium-font-weight: 500;
  --b6-medium-letter-spacing: 0px;
  --b6-medium-line-height: 24px;
  --backgroundsprimary: rgba(255, 255, 255, 1);
  --caption-medium-font-family: "Poppins", Helvetica;
  --caption-medium-font-size: 12px;
  --caption-medium-font-style: normal;
  --caption-medium-font-weight: 500;
  --caption-medium-letter-spacing: 0px;
  --caption-medium-line-height: 150%;
  --caption-regular-font-family: "Poppins", Helvetica;
  --caption-regular-font-size: 12px;
  --caption-regular-font-style: normal;
  --caption-regular-font-weight: 400;
  --caption-regular-letter-spacing: 0px;
  --caption-regular-line-height: 150%;
  --footnote-font-family: "Poppins", Helvetica;
  --footnote-font-size: 14px;
  --footnote-font-style: normal;
  --footnote-font-weight: 400;
  --footnote-letter-spacing: 0px;
  --footnote-line-height: 150%;
  --green: rgba(52, 199, 89, 1);
  --neutral-200: rgba(224, 227, 230, 1);
  --neutral-50: rgba(247, 247, 248, 1);
  --neutral-800: rgba(64, 69, 74, 1);
  --neutral-light-n40: rgba(223, 225, 230, 1);
  --primary-500: rgb(74, 104, 255);
  --red: rgba(255, 59, 48, 1);
  --shadow: 0px 2px 10px 0px rgba(124, 141, 181, 0.12);
  --white: rgba(255, 255, 255, 1);
}

:root {
  --animate-spin: spin 1s linear infinite;
}

.animate-fade-in {
  animation: fade-in 1s var(--animation-delay, 0s) ease forwards;
}

.animate-fade-up {
  animation: fade-up 1s var(--animation-delay, 0s) ease forwards;
}

.animate-marquee {
  animation: marquee var(--duration) infinite linear;
}

.animate-marquee-vertical {
  animation: marquee-vertical var(--duration) linear infinite;
}

.animate-shimmer {
  animation: shimmer 8s infinite;
}

.animate-spin {
  animation: var(--animate-spin);
}

@keyframes spin {
  to {
    transform: rotate(1turn);
  }
}

@keyframes image-glow {
  0% {
    opacity: 0;
    animation-timing-function: cubic-bezier(0.74, 0.25, 0.76, 1);
  }

  10% {
    opacity: 0.7;
    animation-timing-function: cubic-bezier(0.12, 0.01, 0.08, 0.99);
  }

  to {
    opacity: 0.4;
  }
}

@keyframes fade-in {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes fade-up {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes shimmer {
  0%,
  90%,
  to {
    background-position: calc(-100% - var(--shimmer-width)) 0;
  }

  30%,
  60% {
    background-position: calc(100% + var(--shimmer-width)) 0;
  }
}

@keyframes marquee {
  0% {
    transform: translate(0);
  }

  to {
    transform: translateX(calc(-100% - var(--gap)));
  }
}

@keyframes marquee-vertical {
  0% {
    transform: translateY(0);
  }

  to {
    transform: translateY(calc(-100% - var(--gap)));
  }
}

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

@layer base {
  :root {
    --background: 0 0% 100%;
    --foreground: 222.2 47.4% 11.2%;

    --muted: 210 40% 96.1%;
    --muted-foreground: 215.4 16.3% 46.9%;

    --popover: 0 0% 100%;
    --popover-foreground: 222.2 47.4% 11.2%;

    --border: 214.3 31.8% 91.4%;
    --input: 214.3 31.8% 91.4%;

    --card: transparent;
    --card-foreground: 222.2 47.4% 11.2%;

    --primary: 222.2 47.4% 11.2%;
    --primary-foreground: 210 40% 98%;

    --secondary: 210 40% 96.1%;
    --secondary-foreground: 222.2 47.4% 11.2%;

    --accent: 210 40% 96.1%;
    --accent-foreground: 222.2 47.4% 11.2%;

    --destructive: 0 100% 50%;
    --destructive-foreground: 210 40% 98%;

    --ring: 215 20.2% 65.1%;

    --radius: 0.5rem;
  }

  .dark {
    --background: 224 71% 4%;
    --foreground: 213 31% 91%;

    --muted: 223 47% 11%;
    --muted-foreground: 215.4 16.3% 56.9%;

    --accent: 216 34% 17%;
    --accent-foreground: 210 40% 98%;

    --popover: 224 71% 4%;
    --popover-foreground: 215 20.2% 65.1%;

    --border: 216 34% 17%;
    --input: 216 34% 17%;

    --card: transparent;
    --card-foreground: 213 31% 91%;

    --primary: 210 40% 98%;
    --primary-foreground: 222.2 47.4% 1.2%;

    --secondary: 222.2 47.4% 11.2%;
    --secondary-foreground: 210 40% 98%;

    --destructive: 0 63% 31%;
    --destructive-foreground: 210 40% 98%;

    --ring: 216 34% 17%;

    --radius: 0.5rem;
  }
}

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

  html, body {
    margin: 0;
    padding: 0;
    min-height: 100%;
    width: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  body {
    @apply bg-background text-foreground;
    font-feature-settings: "rlig" 1, "calt" 1;
  }

  #app {
    min-height: 100vh;
    width: 100vw;
  }
}

@layer utilities {
      /* Hide scrollbar for Chrome, Safari and Opera */
      .no-scrollbar::-webkit-scrollbar {
          display: none;
      }
     /* Hide scrollbar for IE, Edge and Firefox */
      .no-scrollbar {
          -ms-overflow-style: none;  /* IE and Edge */
          scrollbar-width: none;  /* Firefox */
    }

    /* Chrome, Edge, Safari */
    .scrollbar-thin::-webkit-scrollbar {
      width: 4px;       /* vertical scrollbar */
      height: 4px;      /* horizontal scrollbar */
    }

    .scrollbar-thin::-webkit-scrollbar-track {
      background: transparent; /* track color */
    }

    .scrollbar-thin::-webkit-scrollbar-thumb {
      background-color: #888;  /* thumb color */
      border-radius: 9999px;  /* fully rounded */
    }

    .scrollbar-thin::-webkit-scrollbar-thumb:hover {
      background-color: #555; /* hover color */
    }

    /* Firefox */
    .scrollbar-thin {
      scrollbar-width: 4px;                 /* thin scrollbar */
      scrollbar-color: #888 transparent;     /* thumb | track */
    }
  }