@layer base {

  *,
  ::after,
  ::before,
  ::backdrop,
  ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }

  html,
  :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }

  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }

  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }

  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-size: inherit;
    font-weight: inherit;
  }

  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }

  b,
  strong {
    font-weight: bolder;
  }

  code,
  kbd,
  samp,
  pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }

  small {
    font-size: 80%;
  }

  sub,
  sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }

  sub {
    bottom: -0.25em;
  }

  sup {
    top: -0.5em;
  }

  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

  ol,
  ul,
  menu {
    list-style: none;
  }

  img,
  svg,
  video,
  canvas,
  audio,
  iframe,
  embed,
  object {
    display: block;
    vertical-align: middle;
  }

  img,
  video {
    max-width: 100%;
    height: auto;
  }

  button,
  input,
  select,
  optgroup,
  textarea,
  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }

  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::file-selector-button {
    margin-inline-end: 4px;
  }

  ::placeholder {
    opacity: 1;
  }

  @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;

      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }

  textarea {
    resize: vertical;
  }

  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }

  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }

  ::-webkit-datetime-edit {
    display: inline-flex;
  }

  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }

  ::-webkit-datetime-edit,
  ::-webkit-datetime-edit-year-field,
  ::-webkit-datetime-edit-month-field,
  ::-webkit-datetime-edit-day-field,
  ::-webkit-datetime-edit-hour-field,
  ::-webkit-datetime-edit-minute-field,
  ::-webkit-datetime-edit-second-field,
  ::-webkit-datetime-edit-millisecond-field,
  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  :-moz-ui-invalid {
    box-shadow: none;
  }

  button,
  input:where([type="button"], [type="reset"], [type="submit"]),
  ::file-selector-button {
    appearance: button;
  }

  ::-webkit-inner-spin-button,
  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }

  /* Additional base styles */
  html {
    overflow-x: hidden;
    font-size: var(--text-base-sm);

    @media (width >=48rem) {
      font-size: var(--text-base);
      line-height: var(--tw-leading, var(--text-base--line-height));
    }

    @media (width >=48rem) {
      font-size: var(--text-base);
    }

    scroll-behavior: smooth;
  }

  main {
    border-style: var(--tw-border-style);
    border-width: 1px;
    border-color: var(--color-border);

    &:where(.dark, .dark *) {
      border-color: var(--color-darkmode-border);
    }
  }

  body {
    background-color: var(--color-body);
    padding: calc(var(--spacing) * 2);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
    font-size: var(--text-base);
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-normal);
    color: var(--color-text);

    @media (width >=48rem) {
      padding: calc(var(--spacing) * 7);
    }

    &:where(.dark, .dark *) {
      background-color: var(--color-darkmode-body);
    }

    &:where(.dark, .dark *) {
      color: var(--color-darkmode-text);
    }
  }

  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-family: var(--font-serif);
  }

  h1,
  .h1 {
    font-size: var(--text-h1-sm);

    @media (width >=48rem) {
      font-size: var(--text-h1);
    }
  }

  h2,
  .h2 {
    font-size: var(--text-h2-sm);

    @media (width >=48rem) {
      font-size: var(--text-h2);
    }
  }

  h3,
  .h3 {
    font-size: var(--text-h3-sm);

    @media (width >=48rem) {
      font-size: var(--text-h3);
    }
  }

  h4,
  .h4 {
    font-size: var(--text-h4);
  }

  h5,
  .h5 {
    font-size: var(--text-h5);
  }

  h6,
  .h6 {
    font-size: var(--text-h6);
  }

  b,
  strong {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  code {
    &::after {
      content: var(--tw-content);
      --tw-border-style: none;
      border-style: none;
    }
  }

  input[type='checkbox'] {
    height: calc(var(--spacing) * 4);
    width: calc(var(--spacing) * 4);
    cursor: pointer;
    appearance: none;
    border-radius: 0;
    border-style: var(--tw-border-style);
    border-width: 1px;
    border-color: var(--color-border);
    color: var(--color-primary);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
    --tw-duration: 300ms;
    transition-duration: 300ms;

    &:where(.dark, .dark *) {
      border-color: var(--color-darkmode-border);
    }

    &:where(.dark, .dark *) {
      color: var(--color-darkmode-primary);
    }
  }

  input[type='checkbox']:checked {
    border-color: var(--color-primary);
    background-color: var(--color-primary);

    &:where(.dark, .dark *) {
      border-color: var(--color-darkmode-primary);
    }

    &:where(.dark, .dark *) {
      background-color: var(--color-darkmode-primary);
    }
  }

  input[type='checkbox']:focus {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    --tw-outline-style: none;
    outline-style: none;
  }

  /* Custom theme variables */
  :root {
    --text-h6: 1.3rem;
    --text-h6-sm: 1.1700000000000002rem;
    --text-h5: 1.6900000000000002rem;
    --text-h5-sm: 1.5210000000000001rem;
    --text-h4: 2.1970000000000005rem;
    --text-h4-sm: 1.9773000000000005rem;
    --text-h3: 2.856100000000001rem;
    --text-h3-sm: 2.570490000000001rem;
    --text-h2: 3.7129300000000014rem;
    --text-h2-sm: 3.3416370000000013rem;
    --text-h1: 4.826809000000002rem;
    --text-h1-sm: 4.344128100000002rem;
    --text-base: 18px;
    --text-base-sm: 12.8px;
    --color-primary: #ffc300;
    --color-body: #EDEDED;
    --color-border: #222222;
    --color-light: #f6f6f6;
    --color-dark: #222222;
    --color-text: #222222;
    --color-text-dark: #040404;
    --color-text-light: #999999;
  }

  .dark {
    --color-darkmode-primary: var(--color-primary);
    --color-darkmode-body: #191919;
    --color-darkmode-border: #999999;
    --color-darkmode-light: #222222;
    --color-darkmode-dark: #f6f6f6;
    --color-darkmode-text: #FFFFFF;
    --color-darkmode-text-dark: #f6f6f6;
    --color-darkmode-text-light: #444444;
  }
}