/* Outfit Coordination — gallery, themes, comments */

@layer components {
  /* ── Header ── */
  .outfit-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--inline-space);
  }

  /* ── Gallery grid ── */
  .outfit-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 16rem), 1fr));
    gap: var(--block-space);
  }

  .outfit-day {
    margin-block-end: var(--block-space-l);
  }

  .outfit-day__label {
    font-size: 1rem;
    font-weight: 600;
    margin-block-end: var(--block-space-s);
    color: var(--color-ink-muted);
  }

  /* ── Outfit card ── */
  .outfit-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
  }

  .outfit-card__photo {
    aspect-ratio: 3 / 4;
    overflow: hidden;

    & img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
  }

  .outfit-card__body {
    padding: var(--block-space) var(--inline-space);
  }

  .outfit-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--inline-space-s);
    margin-block-end: var(--block-space-s);
  }

  .outfit-card__author {
    display: flex;
    align-items: center;
    gap: var(--inline-space-s);
    font-size: 0.875rem;
    font-weight: 500;
  }

  .outfit-card__day {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.15em 0.5em;
    border-radius: var(--radius-pill);
    background: color-mix(in oklch, oklch(var(--lch-uv)) 15%, var(--color-surface));
    color: oklch(var(--lch-uv));
  }

  .outfit-card__caption {
    font-size: 0.875rem;
    margin: 0 0 var(--block-space-s);
    color: var(--color-ink-muted);
  }

  /* ── Reactions (adapted from messages) ── */
  .outfit-card__reactions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin-block-end: var(--block-space-s);
  }

  .outfit-card__reaction {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.15rem 0.4rem;
    font-size: 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    background: none;
    cursor: pointer;

    &:hover {
      border-color: oklch(var(--lch-uv));
    }
  }

  .outfit-card__reaction--active {
    border-color: oklch(var(--lch-uv));
    background: color-mix(in oklch, oklch(var(--lch-uv)) 10%, transparent);
  }

  .outfit-card__reaction-count {
    font-weight: 600;
  }

  .outfit-card__actions {
    position: relative;
  }

  .outfit-card__react-btn {
    display: grid;
    place-items: center;
    width: 1.75rem;
    height: 1.75rem;
    padding: 0;
    border: none;
    background: none;
    color: var(--color-ink-muted);
    cursor: pointer;
    border-radius: var(--radius-sm);

    &:hover {
      color: var(--color-ink);
      background: color-mix(in oklch, var(--color-ink) 10%, transparent);
    }

    & svg {
      width: 1rem;
      height: 1rem;
    }
  }

  .outfit-card__reaction-picker {
    position: absolute;
    bottom: 100%;
    left: 0;
    display: flex;
    gap: 0.25rem;
    padding: 0.25rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 12px color-mix(in oklch, oklch(0% 0 0) 15%, transparent);
    z-index: 10;
  }

  .outfit-card__reaction-picker-btn {
    font-size: 1.25rem;
    padding: 0.25rem;
    border: none;
    background: none;
    cursor: pointer;
    border-radius: var(--radius-sm);

    &:hover {
      background: color-mix(in oklch, var(--color-ink) 10%, transparent);
    }
  }

  .outfit-card__admin {
    margin-block-start: var(--block-space-s);
    padding-block-start: var(--block-space-s);
    border-top: 1px solid var(--color-border);
  }

  .outfit-card__delete-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0;
    border: none;
    background: none;
    color: var(--color-ink-muted);
    font-size: 0.75rem;
    cursor: pointer;

    &:hover { color: oklch(var(--lch-flare)); }

    & svg { width: 0.875rem; height: 0.875rem; }
  }

  /* ── Comments ── */
  .outfit-card__comments {
    margin-block-start: var(--block-space-s);
    padding-block-start: var(--block-space-s);
    border-top: 1px solid var(--color-border);
  }

  .outfit-comment {
    display: flex;
    align-items: flex-start;
    gap: var(--inline-space-s);
    margin-block-end: 0.4rem;
    font-size: 0.8125rem;
  }

  .outfit-comment__author {
    font-weight: 600;
    margin-inline-end: 0.25rem;
  }

  .outfit-comment-form {
    display: flex;
    gap: var(--inline-space-s);
    margin-block-start: var(--block-space-s);
  }

  .outfit-comment-form__input {
    flex: 1;
    min-width: 0;
  }

  /* ── Theme proposals ── */
  .outfit-themes {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--block-space) var(--inline-space-l);
    margin-block-end: var(--block-space-l);
  }

  .outfit-themes__title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 var(--block-space-s);
  }

  .outfit-themes__list {
    display: flex;
    flex-direction: column;
    gap: var(--block-space-s);
  }

  .outfit-theme {
    display: flex;
    align-items: center;
    gap: var(--inline-space);
    padding: var(--block-space-s) var(--inline-space);
    background: color-mix(in oklch, var(--color-ink) 3%, var(--color-surface));
    border-radius: var(--radius-md);
  }

  .outfit-theme__content {
    flex: 1;
    min-width: 0;
  }

  .outfit-theme__title {
    font-weight: 600;
    display: block;
  }

  .outfit-theme__author {
    font-size: 0.75rem;
    color: var(--color-ink-muted);
  }

  .outfit-theme__votes {
    display: flex;
    gap: 0.4rem;
    flex-shrink: 0;
  }

  .outfit-theme__vote-btn {
    padding: 0.25rem 0.6rem;
    font-size: 0.75rem;
    font-weight: 600;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    background: none;
    cursor: pointer;

    &:hover {
      border-color: oklch(var(--lch-laser));
    }
  }

  .outfit-theme__vote-btn--active {
    border-color: oklch(var(--lch-laser));
    background: color-mix(in oklch, oklch(var(--lch-laser)) 15%, transparent);
    color: oklch(var(--lch-laser));
  }

  .outfit-theme__vote-btn--pass {
    &:hover {
      border-color: oklch(var(--lch-flare));
    }

    &.outfit-theme__vote-btn--active {
      border-color: oklch(var(--lch-flare));
      background: color-mix(in oklch, oklch(var(--lch-flare)) 15%, transparent);
      color: oklch(var(--lch-flare));
    }
  }

  .outfit-theme__delete {
    display: grid;
    place-items: center;
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    border: none;
    background: none;
    color: var(--color-ink-muted);
    cursor: pointer;

    &:hover { color: oklch(var(--lch-flare)); }
  }

  .outfit-theme-form {
    display: flex;
    gap: var(--inline-space-s);
    margin-block-start: var(--block-space-s);
  }

  .outfit-theme-form__input {
    flex: 1;
    min-width: 0;
  }

  /* ── New outfit form ── */
  .outfit-form__preview {
    position: relative;
    display: inline-block;
    margin-block-start: var(--block-space-s);
  }

  .outfit-form__preview-img {
    max-width: 12rem;
    border-radius: var(--radius-md);
  }

  .outfit-form__preview-remove {
    position: absolute;
    top: 0.25rem;
    right: 0.25rem;
    width: 1.5rem;
    height: 1.5rem;
    display: grid;
    place-items: center;
    border: none;
    border-radius: 50%;
    background: oklch(0% 0 0 / 50%);
    color: oklch(100% 0 0);
    font-size: 1rem;
    cursor: pointer;
  }

  /* ── The Looks gallery ── */
  .outfit-looks-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
    gap: var(--block-space);
  }

  .outfit-looks__item {
    margin: 0;
  }

  .outfit-looks__photo {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    border-radius: var(--radius-lg);
  }

  .outfit-looks__caption {
    padding: var(--block-space-s) 0;
    font-size: 0.875rem;

    & p {
      margin: 0.25rem 0 0;
      color: var(--color-ink-muted);
    }
  }
}
