/** This file contains styles for components used across the application. Component templates can be found in webroot/app/components/ */

/* Alert */

.gaiola-alert {
  display: grid;
  align-items: center;
  column-gap: var(--spacing-md);
  row-gap: var(--spacing-2xs);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--spacing-md) var(--spacing-lg);

  &:has([class^="icon-"], [class*=" icon-"]) {
    grid-template-columns: var(--spacing-lg) 1fr;

    & .gaiola-alert__description {
      grid-column: 2;
    }
  }
  &:has(.gaiola-alert__title:empty) {
    display: none;
  }

  &[data-variant="destructive"] {
    & * {
      color: var(--destructive);
    }
    & img {
      stroke: red;
    }
  }
}

.gaiola-alert__title {
  font-weight: var(--font-weight-medium);
}

.gaiola-alert__description {
  color: var(--muted-foreground);
}

/* Badge */

.gaiola-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  color: var(--secondary-foreground);
  background-color: var(--secondary);
}

/* Button */

.gaiola-button {
  display: inline flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  white-space: nowrap;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  padding: var(--spacing-sm) var(--spacing-lg);

  border: none;
  outline: none;
  background-color: var(--primary);
  color: var(--primary-foreground);
  box-shadow: var(--shadow-xs);

  transition-property: box-shadow;

  cursor: pointer;

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

  &:focus-visible {
    border-color: var(--ring);
    --ring-color: oklch(from var(--ring) l c h / 0.5);
    box-shadow: var(--ring-shadow-md) var(--ring-color) !important;
  }

  &[data-size="sm"] {
    padding: var(--spacing-2xs) var(--spacing-sm);
    font-size: var(--text-xs);
  }

  &[data-size="icon"] {
    padding: 0;
    --size: 2.5rem;
    width: var(--size);
    height: var(--size);
  }

  &[data-size="icon-zero"] {
    padding: 0;
    --size: 1.5rem;
    width: var(--size);
    height: var(--size);
  }

  &[data-variant="secondary"] {
    background-color: var(--secondary);
    color: var(--secondary-foreground);
  }

  &[data-variant="destructive"] {
    background-color: var(--destructive);
    color: var(--color-white);
  }

  &[data-variant="outline"] {
    background-color: var(--background);
    color: var(--foreground);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-xs);
  }

  &[data-variant="ghost"] {
    background-color: transparent;
    color: var(--foreground);
    box-shadow: none;
  }
}

/* Box */

:where(.gaiola-box) {
  padding: var(--spacing-xl);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
}

/* Card */

:where(.gaiola-card) {
  padding: var(--spacing-xl);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background-color: var(--card);
  box-shadow: var(--shadow-sm);

  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

:where(.gaiola-card__header) {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

:where(.gaiola-card__title) {
  line-height: var(--leading-snug);
}

:where(.gaiola-card__subtitle) {
  font-size: var(--text-xs);
  color: var(--muted-foreground);
}

:where(.gaiola-card__footer) {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-sm);
  margin-top: auto;
}

/* Dialog */

.gaiola-dialog {
  background-color: var(--background);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  margin: auto;

  width: 100%;
  max-width: 25rem;
}

.gaiola-dialog::backdrop {
  background-color: oklch(from var(--color-black) l c h / 0.5);
}

.gaiola-dialog__header {
  margin-bottom: var(--spacing-md);
  display: flex;
  justify-content: space-between;
  align-items: start;
}

.gaiola-dialog__title {
  font-size: var(--text-lg);
  font-weight: var(--font-weight-bold);
}

.gaiola-dialog__body {
  margin-bottom: var(--spacing-xl);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

.gaiola-dialog__footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-sm);
}

/* Field */

.gaiola-field {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.gaiola-field__label {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
}

.gaiola-field__description {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
}

.gaiola-field__error {
  font-size: var(--text-sm);
  color: var(--destructive);

  &:empty {
    display: none;
  }
}

/* Input */

.gaiola-input {
  font-size: var(--text-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--input);
  box-shadow: var(--shadow-xs);
  border-radius: var(--radius-md);
  width: 100%;
  min-width: 0;
  outline: none;
  transition-property: box-shadow;

  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-sm);

  &:focus-visible {
    border-color: var(--ring);
    --ring-color: oklch(from var(--ring) l c h / 0.5);
    box-shadow: var(--ring-shadow-md) var(--ring-color);
  }
}

.gaiola-input:has(~ .gaiola-field__error:not(:empty)) {
  border-color: var(--destructive);
  --ring-color: oklch(from var(--destructive) l c h / 0.4);
}

/* Logo */

.gaiola-logo {
  font-size: var(--text-base);
  font-family: var(--font-display);
  font-weight: var(--font-weight-bold);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);

  & [class^="icon-"],
  [class*=" icon-"] {
    font-weight: var(--font-weight-normal);
    --size: calc(var(--text-base) + var(--spacing-xs) * 2);
    width: var(--size);
    height: var(--size);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--primary);
    color: var(--primary-foreground);
  }
}

/* Radio Group */

.gaiola-radio-group {
  display: grid;
  gap: var(--spacing-2xs) var(--spacing-sm);
  grid-template-columns: auto 1fr;
  align-items: center;
}

.gaiola-radio-group__item {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: subgrid;
  align-items: center;
}

/* Sidebar */

.gaiola-sidebar {
  --sidebar-width: 16rem;
  --sidebar-padding: var(--spacing-sm);

  display: flex;
  flex-direction: column;
  height: 100%;
  width: var(--sidebar-width);
  background-color: var(--sidebar);
  color: var(--sidebar-foreground);
  border-right: 1px solid var(--sidebar-border);
}

.gaiola-sidebar__header {
  padding: var(--sidebar-padding);
}

.gaiola-sidebar__content {
  padding: var(--sidebar-padding);
  flex-grow: 1;
  border-block: 1px solid var(--sidebar-border);
}

.gaiola-sidebar__footer {
  padding: var(--sidebar-padding);
  margin-top: auto;
}

.gaiola-sidebar__menu-button {
  width: 100%;
  padding: var(--sidebar-padding);
  border-radius: var(--radius-md);
  border: none;
  outline: none;
  text-align: left;
  background: transparent;
  display: flex;
  align-items: center;
  gap: var(--spacing-md);

  &:hover {
    background-color: var(--sidebar-accent);
  }
}

/* Textarea */

.gaiola-textarea {
  font-size: var(--text-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--input);
  box-shadow: var(--shadow-xs);
  border-radius: var(--radius-md);
  width: 100%;
  min-width: 0;
  outline: none;
  transition-property: box-shadow;
  field-sizing: content;
  min-height: 5rem;
  max-height: 10rem;

  &:focus-visible {
    border-color: var(--ring);
    --ring-color: oklch(from var(--ring) l c h / 0.5);
    box-shadow: var(--ring-shadow-md) var(--ring-color);
  }
}

.gaiola-textarea:has(~ .gaiola-field__error:not(:empty)) {
  border-color: var(--destructive);
  --ring-color: oklch(from var(--destructive) l c h / 0.4);
}

/* Timeline */

.gaiola-timeline {
  list-style-type: none;
  border-left: 1px solid var(--border);
  padding-left: var(--spacing-lg);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

.gaiola-timeline__item {
  position: relative;
  display: flex;
  align-items: center;

  &::before {
    content: "";
    position: absolute;
    left: calc(-0.25rem - var(--spacing-lg));
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background-color: var(--color-stone-300);
  }

  &[data-current="true"]::before {
    background-color: var(--color-emerald-500);
  }
}

/* Toggle Group */

.gaiola-toggle-group {
  width: 100%;
  display: grid;
  grid-auto-flow: column;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
}

.gaiola-toggle-group__item {
  display: inline flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--input);
  padding: var(--spacing-sm) var(--spacing-lg);
  cursor: pointer;

  &:first-child {
    border-top-left-radius: var(--radius-md);
    border-bottom-left-radius: var(--radius-md);
  }

  &:not(:first-child) {
    border-left: none;
  }

  &:last-child {
    border-top-right-radius: var(--radius-md);
    border-bottom-right-radius: var(--radius-md);
  }

  &:hover {
    background-color: var(--muted);
  }

  &:has(.gaiola-toggle-group__input:checked) {
    background-color: var(--accent);
    color: var(--accent-foreground);
  }

  &:has(.gaiola-toggle-group__input:focus-visible) {
    border-color: var(--ring);
    --ring-color: oklch(from var(--ring) l c h / 0.5);
    box-shadow: var(--ring-shadow-md) var(--ring-color);
  }
}

.gaiola-toggle-group__input {
  width: 0;
  height: 0;
  opacity: 0;
  position: absolute;
}
