@layer reset, defaults, components;

@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  * {
    font: inherit;
  }

  img,
  picture,
  svg,
  video {
    display: block;
    max-width: 100%;
  }

  button {
    cursor: pointer;
  }

  html {
    color-scheme: dark light;
  }

  body {
    min-height: 100vh;
    min-height: 100svh;
  }

  html,
  body {
    margin: 0;
    padding: 0;
  }

  @media (prefers-reduced-motion: no-preference) {
    :has(:target) {
      scroll-behavior: smooth;
      scroll-padding-block: 2rem;
    }
  }

  ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }

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

  a:visited {
    color: inherit;
  }

  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    margin: 0;
  }

  pre {
    text-align: left;
    white-space: pre-wrap;
    word-wrap: break-word;
  }

  strong {
    font-weight: var(--sl-font-weight-bold);
  }
}

@layer defaults {
  :root {
    font-family: var(--sl-font-sans);
  }

  body {
    display: flex;

    flex-direction: column;
  }

  @layer tables {
    th {
      text-align: left;
      font-weight: var(--sl-font-weight-semibold);
    }

    td {
      vertical-align: center;

      &:last-child {
        text-align: right;
      }
    }

    td,
    th {
      padding: var(--sl-spacing-x-small);

      &:not(:last-child) {
        border-inline-end: 1px solid var(--sl-color-neutral-0);
      }
    }

    table {
      border-collapse: collapse;
      width: 100%;
    }

    tr {
      background: var(--sl-color-neutral-100);

      &:nth-child(even) {
        background: var(--sl-color-neutral-50);
      }
    }

    thead,
    tfoot {
      tr {
        background: none;
      }
    }

    tr[hx-get] {
      cursor: pointer;

      &:hover {
        background: var(--sl-color-primary-50);
      }
    }

    tr a:hover,
    tr a:focus {
      text-decoration: underline;
      text-decoration-color: var(--sl-color-primary-500);
    }

    sl-details > table {
      margin-inline: calc(var(--sl-spacing-medium) * -1);
      width: calc(100% + var(--sl-spacing-medium) * 2);
    }
  }

  ul[slot='help-text'],
  [slot='help-text'] ul {
    list-style: disc;
    margin-inline-start: var(--sl-spacing-medium);
  }

  a[slot='help-text'],
  [slot='help-text'] a {
    color: var(--sl-color-neutral-1000);

    &:hover {
      text-decoration: underline;
      text-decoration-color: var(--sl-color-primary-500);
    }
  }
}

@layer components {
  :root {
    --sidebar-size: 12rem;
    --header-size: calc(
      var(--sl-font-size-small) * var(--sl-line-height-normal)
    );
  }

  @layer PageHeader {
    .PageHeader {
      position: fixed;
      inset: 0 0 auto 0;

      z-index: var(--sl-z-index-drawer);

      padding: 0 var(--sl-spacing-x-small);

      background-color: var(--sl-color-neutral-0);
      border-block-end: 1px solid var(--sl-color-neutral-200);
    }
  }

  @layer Column {
    .Column {
      display: flex;
      flex-direction: column;

      gap: var(--sl-spacing-medium);
    }
  }

  @layer Row {
    .Row {
      display: flex;
      flex-direction: row;

      gap: var(--sl-spacing-medium);
    }
  }

  @layer Fill {
    .Fill {
      flex: 1 1 auto;
    }
  }

  @layer Centered {
    .Centered {
      display: grid;
      place-content: center;
    }
  }

  @layer Sidebar {
    .Sidebar {
      display: flex;
      flex-direction: column;

      position: fixed;
      inset: var(--header-size) auto 0 0;
      width: var(--sidebar-size);

      background-color: var(--sl-color-neutral-0);
      border-inline-end: 1px solid var(--sl-color-neutral-200);

      padding: var(--sl-spacing-medium);

      h1 {
        font-size: var(--sl-font-size-large);
        font-weight: var(--sl-font-weight-light);

        strong {
          color: var(--sl-color-primary-500);
          font-weight: var(--sl-font-weight-bold);

          [data-env='staging'] & {
            color: var(--sl-color-green-500);
          }

          [data-env='development'] & {
            color: var(--sl-color-pink-500);
          }
        }

        & a::after {
          color: var(--sl-color-neutral-400);
          font-weight: var(--sl-font-weight-light);
        }

        [data-env='staging'] & a::after {
          content: ' (stage)';
        }

        [data-env='development'] & a::after {
          content: ' (dev)';
        }
      }

      h2 {
        font-size: var(--sl-font-size-medium);
        font-weight: var(--sl-font-weight-bold);
        color: var(--sl-color-neutral-700);
        margin-block-end: var(--sl-spacing-x-small);
      }

      li {
        margin-block-end: var(--sl-spacing-x-small);

        &.deprecated {
          opacity: 0.7;
        }

        & > span {
          font-weight: var(--sl-font-weight-bold);
          color: var(--sl-color-neutral-700);
        }
      }

      a {
        font-weight: var(--sl-font-weight-semibold);
        text-decoration: none;

        &:hover {
          text-decoration: underline;
          text-decoration-color: var(--sl-color-primary-500);

          [data-env='staging'] & {
            text-decoration-color: var(--sl-color-green-500);
          }

          [data-env='development'] & {
            text-decoration-color: var(--sl-color-pink-500);
          }
        }
      }

      nav {
        flex: 1 0 auto;

        display: flex;
        flex-direction: column;

        justify-content: space-between;
      }
    }
  }

  @layer MainContent {
    .MainContent {
      display: flex;
      flex-direction: column;

      gap: var(--sl-spacing-x-small);

      min-height: calc(100vh - var(--header-size));
      min-height: calc(100svh - var(--header-size));

      margin-block-start: var(--header-size);

      padding: var(--sl-spacing-x-small);
    }

    .Sidebar + .MainContent {
      margin-inline-start: var(--sidebar-size);
    }
  }

  @layer DetailCard {
    .DetailCard {
      width: 100%;

      h1 {
        font-size: var(--sl-font-size-large);

        flex: 1 1 auto;
      }

      &::part(footer) {
        display: flex;
        gap: var(--sl-spacing-x-small);
      }

      &::part(header) {
        display: flex;
        gap: var(--sl-spacing-x-small);
      }

      table {
        margin-inline: calc(var(--padding) * -1);
        width: calc(100% + var(--padding) * 2);
      }
    }
  }

  @layer Pagination {
    .Pagination {
      display: flex;
      justify-content: space-between;
    }
  }

  @layer PreformattedField {
    .PreformattedField {
      border: solid 1px var(--sl-color-neutral-200);
      border-radius: var(--sl-border-radius-medium);
      background-color: var(--sl-color-neutral-0);
      padding: var(--sl-spacing-medium);
      margin: 0;
    }
  }

  @layer Label {
    .Label {
      display: inline-block;

      margin-bottom: var(--sl-spacing-3x-small);

      font-size: var(--sl-input-label-font-size-medium);
      color: var(--sl-input-label-color);
    }
  }

  @layer UploadButton {
    .UploadButton {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;

      min-height: var(--sl-input-height-medium);
      padding: 0 var(--sl-spacing-medium);

      font-family: var(--sl-input-font-family);
      font-size: var(--sl-input-font-size-medium);
      font-weight: var(--sl-font-weight-normal);
      line-height: var(--sl-line-height-normal);

      color: var(--sl-color-neutral-700);
      background-color: var(--sl-color-neutral-0);

      border: solid var(--sl-input-border-width) var(--sl-input-border-color);
      border-radius: var(--sl-input-border-radius-medium);

      cursor: pointer;
      transition: var(--sl-transition-fast) color,
                  var(--sl-transition-fast) border-color,
                  var(--sl-transition-fast) background-color,
                  var(--sl-transition-fast) box-shadow;

      &:hover:not(:disabled) {
        color: var(--sl-color-primary-700);
        border-color: var(--sl-color-primary-300);
        background-color: var(--sl-color-primary-50);
      }

      &:focus-visible {
        outline: var(--sl-focus-ring);
        outline-offset: var(--sl-focus-ring-offset);
      }

      &:disabled {
        opacity: 0.5;
        cursor: not-allowed;
      }

      input[type='file'] {
        position: absolute;
        inset: 0;
        opacity: 0;
        cursor: pointer;

        &:disabled {
          cursor: not-allowed;
        }
      }
    }
  }
}
