: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);
    color-scheme: dark;

    /* 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%;
    --input: 184 94% 41%;
    --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%);
  }

  :root.light-theme {
    color-scheme: light;
    --lv-color-darkest-blue: hsla(213, 45%, 97%, 100%);
    --lv-color-darker-blue: hsla(213, 38%, 94%, 100%);
    --lv-color-dark-blue: hsla(213, 30%, 90%, 100%);
    --lv-color-white-100: hsla(228, 20%, 12%, 100%);
    --lv-color-white-80: hsla(228, 16%, 24%, 100%);
    --lv-color-white-60: hsla(228, 14%, 38%, 100%);
    --lv-color-white-40: hsla(228, 12%, 52%, 100%);
    --lv-color-white-16: hsla(228, 20%, 12%, 16%);
    --lv-color-white-8: hsla(228, 20%, 12%, 8%);
    --lv-color-chat-bubble: hsla(213, 32%, 92%, 100%);
    --lv-color-blue-gray-100: hsla(229, 20%, 36%, 100%);
    --lv-color-blue-gray-200: hsla(229, 18%, 52%, 100%);
    --lv-color-gray-80: hsla(216, 12%, 46%, 100%);
    --lv-color-teal-faded: hsla(185, 94%, 41%, 24%);
    --background: 214 43% 97%;
    --foreground: 231 20% 15%;
    --card: 0 0% 100%;
    --card-foreground: 231 20% 15%;
    --popover: 0 0% 100%;
    --popover-foreground: 231 20% 15%;
    --primary: 185 68% 38%;
    --primary-foreground: 0 0% 100%;
    --secondary: 213 28% 92%;
    --secondary-foreground: 231 20% 15%;
    --muted: 213 28% 92%;
    --muted-foreground: 226 18% 40%;
    --accent: 185 94% 41%;
    --accent-foreground: 0 0% 100%;
    --destructive: 0 65% 50%;
    --destructive-foreground: 0 0% 100%;
    --border: 215 24% 85%;
    --input: 215 24% 85%;
    --ring: 185 94% 41%;
    --sidebar-background: 0 0% 100%;
    --sidebar-foreground: 231 20% 22%;
    --sidebar-primary: 185 94% 41%;
    --sidebar-primary-foreground: 0 0% 100%;
    --sidebar-accent: 213 28% 94%;
    --sidebar-accent-foreground: 231 20% 20%;
    --sidebar-border: 215 24% 88%;
    --sidebar-ring: 185 94% 41%;
    --scrollbar-color: 228 16% 70%;
    --lagaviti-dark-blue: 213 80% 25%;

    /* Material Design System Color Mappings - Light Mode */
    --md-sys-color-primary: var(--lv-color-teal);
    --md-sys-color-on-primary: hsla(229, 64%, 8%, 100%);
    --md-sys-color-secondary: hsla(213, 28%, 86%, 100%);
    --md-sys-color-on-secondary: hsla(229, 22%, 16%, 100%);
    --md-sys-color-tertiary: hsla(229, 17%, 42%, 100%);
    --md-sys-color-on-tertiary: hsla(0, 0%, 100%, 100%);
    --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-60);
    --md-sys-color-outline: hsla(225, 24%, 78%, 100%);

    --md-sys-color-primary-container: hsla(185, 66%, 92%, 100%);
    --md-sys-color-on-primary-container: hsla(226, 61%, 12%, 100%);
    --md-sys-color-secondary-container: hsla(213, 36%, 90%, 100%);
    --md-sys-color-on-secondary-container: hsla(229, 22%, 16%, 100%);
    --md-sys-color-tertiary-container: hsla(229, 30%, 92%, 100%);
    --md-sys-color-on-tertiary-container: hsla(229, 22%, 16%, 100%);
    --md-sys-color-error-container: hsla(9, 80%, 90%, 100%);
    --md-sys-color-on-error-container: hsla(0, 70%, 30%, 100%);
    --md-sys-color-outline-variant: hsla(225, 28%, 90%, 100%);
    --md-sys-color-shadow: hsla(225, 22%, 20%, 0.2);
    --md-sys-color-scrim: hsla(225, 22%, 20%, 0.4);
    --md-sys-color-inverse-surface: hsla(229, 44%, 12%, 100%);
    --md-sys-color-inverse-on-surface: hsla(0, 0%, 100%, 100%);
    --md-sys-color-inverse-primary: hsla(185, 94%, 41%, 100%);
    --md-sys-color-surface-dim: hsla(213, 32%, 92%, 100%);
    --md-sys-color-surface-bright: hsla(0, 0%, 100%, 100%);
    --md-sys-color-surface-container-lowest: hsla(0, 0%, 100%, 100%);
    --md-sys-color-surface-container-low: hsla(213, 40%, 96%, 100%);
    --md-sys-color-surface-container: hsla(213, 36%, 94%, 100%);
    --md-sys-color-surface-container-high: hsla(213, 32%, 92%, 100%);
    --md-sys-color-surface-container-highest: hsla(213, 26%, 90%, 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;
  }

  body.document-route {
    height: auto;
    min-height: 100vh;
    width: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    background-color: #f5f6f8;
    color: #202124;
  }
}

/* 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;
}
