:host {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:host {
  /* Reset specific CSS properties */
  color: initial;

  /* Reset all CSS properties */
  all: initial;
}

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

@layer base {
  :root {
    box-sizing: border-box;
    font-family: var(--lv-font-primary);

    /* Colors */
    --lv-color-darkest-blue: hsla(226, 26%, 9%, 100%);
    --lv-color-darker-blue: hsla(226, 26%, 13%, 100%);
    --lv-color-dark-blue: hsla(226, 86%, 16%, 100%);
    --lv-color-black-100: hsla(0, 0%, 0%, 100%);
    --lv-color-black-16: hsla(0, 0%, 0%, 16%);
    --lv-color-white-100: hsla(0, 0%, 100%, 100%);
    --lv-color-white-80: hsla(0, 0%, 100%, 80%);
    --lv-color-white-60: hsla(0, 0%, 100%, 60%);
    --lv-color-white-40: hsla(0, 0%, 100%, 40%);
    --lv-color-white-16: hsla(0, 0%, 100%, 16%);
    --lv-color-white-8: hsla(0, 0%, 100%, 8%);
    --lv-color-teal: hsla(185, 94%, 41%, 100%);
    --lv-color-teal-faded: hsla(185, 94%, 41%, 16%);
    --lv-color-chat-bubble: hsla(225, 16%, 20%, 100%);
    --lv-color-blue-gray-100: hsla(226, 8%, 32%, 100%);
    --lv-color-blue-gray-200: hsla(227, 11%, 26%, 100%);
    --lv-color-gray-80: hsla(210, 6%, 80%, 100%);

    /* Font */
    --lv-font-primary: "Inter", sans-serif;
    --lv-fz-large: 16px;
    --lv-fz-medium: 14px;
    --lv-fz-small: 12px;
    --lv-fz-xsmall: 10px;

    /* Sizings */
    --lv-content-max-width: 720px;

    --background: 0 0% 100%;
    --foreground: 240 10% 3.9%;
    --card: 0 0% 100%;
    --card-foreground: 240 10% 3.9%;
    --popover: 0 0% 100%;
    --popover-foreground: 240 10% 3.9%;
    --primary: 240 5.9% 10%;
    --primary-foreground: 0 0% 98%;
    --secondary: 240 4.8% 95.9%;
    --secondary-foreground: 240 5.9% 10%;
    --muted: 240 4.8% 95.9%;
    --muted-foreground: 240 3.8% 46.1%;
    --accent: 184 94% 41%;
    --accent-foreground: 240 5.9% 10%;
    --destructive: 0 90% 65%;
    --destructive-foreground: 0 0% 98%;
    --border: 184, 94%, 41%; /* Note: Check if HSL format is needed here */
    --input: 184, 94%, 41%; /* Note: Check if HSL format is needed here */
    --ring: 240 10% 3.9%;
    --radius: 0.5rem;
    --sidebar-background: 0 0% 98%;
    --sidebar-foreground: 240 5.3% 26.1%;
    --sidebar-primary: 240 5.9% 10%;
    --sidebar-primary-foreground: 0 0% 98%;
    --sidebar-accent: 240 4.8% 95.9%;
    --sidebar-accent-foreground: 240 5.9% 10%;
    --sidebar-border: 220 13% 91%;
    --sidebar-ring: 217.2 91.2% 59.8%;
    --scrollbar-color: 240 3.7% 15.9%;
    --lagaviti-dark-blue: 206 85% 16%;
    --md-icon-font: "Material Symbols Rounded"; /* Added for Material Icons */

    /* Material Design System Color Mappings - Dark Mode */
    --md-sys-color-primary: var(--lv-color-teal);
    --md-sys-color-on-primary: var(--lv-color-darkest-blue);
    --md-sys-color-secondary: var(--lv-color-white-80);
    --md-sys-color-on-secondary: var(--lv-color-darkest-blue);
    --md-sys-color-tertiary: var(--lv-color-white-60);
    --md-sys-color-on-tertiary: var(--lv-color-darkest-blue);
    --md-sys-color-error: hsl(var(--destructive));
    --md-sys-color-on-error: hsl(var(--destructive-foreground));
    --md-sys-color-background: var(--lv-color-darkest-blue);
    --md-sys-color-on-background: var(--lv-color-white-100);
    --md-sys-color-surface: var(--lv-color-darker-blue);
    --md-sys-color-on-surface: var(--lv-color-white-100);
    --md-sys-color-surface-variant: var(--lv-color-dark-blue);
    --md-sys-color-on-surface-variant: var(--lv-color-white-80);
    --md-sys-color-outline: var(--lv-color-white-40);

    /* Newly Added Mappings - Dark Mode */
    --md-sys-color-primary-container: var(--lv-color-dark-blue);
    --md-sys-color-on-primary-container: var(--lv-color-teal);
    --md-sys-color-secondary-container: var(--lv-color-dark-blue);
    --md-sys-color-on-secondary-container: var(--lv-color-white-100);
    --md-sys-color-tertiary-container: var(--lv-color-darker-blue);
    --md-sys-color-on-tertiary-container: var(--lv-color-white-80);
    --md-sys-color-error-container: hsl(var(--muted)); /* Approximated */
    --md-sys-color-on-error-container: hsl(
      var(--muted-foreground)
    ); /* Approximated */
    --md-sys-color-outline-variant: var(--lv-color-white-16);
    --md-sys-color-shadow: var(--lv-color-black-100);
    --md-sys-color-scrim: var(--lv-color-black-16);
    --md-sys-color-inverse-surface: var(--lv-color-white-100);
    --md-sys-color-inverse-on-surface: var(--lv-color-darkest-blue);
    --md-sys-color-inverse-primary: var(--lv-color-teal);
    --md-sys-color-surface-dim: var(--lv-color-darkest-blue);
    --md-sys-color-surface-bright: var(--lv-color-dark-blue);
    --md-sys-color-surface-container-lowest: var(--lv-color-darkest-blue);
    --md-sys-color-surface-container-low: var(--lv-color-darker-blue);
    --md-sys-color-surface-container: var(--lv-color-dark-blue);
    --md-sys-color-surface-container-high: var(--lv-color-dark-blue);
    --md-sys-color-surface-container-highest: hsla(226, 26%, 20%, 100%);
  }

  html {
    font-family: var(--lv-font-primary), Helvetica, Poppins, sans-serif;
  }

  * {
    scrollbar-color: hsl(var(--scrollbar-color)) transparent;
    margin: 0px;
    padding: 0px;
  }

  *::-webkit-scrollbar-track {
    background: transparent;
  }

  *::-webkit-scrollbar {
    width: 8px;
    height: 8px;
  }

  *::-webkit-scrollbar-thumb {
    background-color: hsl(var(--scrollbar-color));
    border-radius: 4px;
  }

  body {
    background-color: var(--lv-color-darkest-blue);
    color: var(--lv-color-white-100);
    margin: 0;
    padding: 0;
    height: 100vh;
    width: 100vw;
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

/* Custom animations */
@keyframes errorPulse {
  0% {
    opacity: 0;
    border-color: hsl(var(--destructive) / 0.5);
  }
  50% {
    opacity: 0.4;
    border-color: hsl(var(--destructive));
  }
  100% {
    opacity: 0;
    border-color: hsl(var(--destructive) / 0.5);
  }
}

.error-pulse {
  animation: errorPulse 2s ease-in-out infinite;
}
