/* Weather — festival weather widget */

@layer components {
  .weather-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: var(--block-space);
  }

  .weather-card__current {
    display: flex;
    align-items: center;
    gap: var(--inline-space);
    padding: var(--block-space) var(--inline-space-l);
  }

  .weather-card__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    color: var(--color-accent);

    & svg {
      width: 100%;
      height: 100%;
    }
  }

  .weather-card__main {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
  }

  .weather-card__temp {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
  }

  .weather-card__label {
    font-size: 0.8125rem;
    color: var(--color-ink-muted);
  }

  .weather-card__details {
    margin-left: auto;
    display: flex;
    gap: var(--inline-space);
  }

  .weather-card__detail {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.125rem;
  }

  .weather-card__detail-label {
    font-size: 0.6875rem;
    color: var(--color-ink-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  .weather-card__detail-value {
    font-weight: 600;
  }

  /* ── Meta row ── */

  .weather-card__meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.375rem var(--inline-space-l);
    border-top: 1px solid var(--color-border);
    background: color-mix(in oklch, var(--color-surface) 95%, var(--color-ink));
  }

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

  .weather-card__expand {
    all: unset;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--color-link);

    & svg {
      width: 14px;
      height: 14px;
    }
  }

  /* ── Hourly forecast ── */

  .weather-card__forecast {
    border-top: 1px solid var(--color-border);
  }

  .weather-card__forecast--hidden {
    display: none;
  }

  .weather-card__hours {
    display: flex;
    overflow-x: auto;
    gap: 0;
    padding: 0.5rem 0;
  }

  .weather-card__hour {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    min-width: 4rem;
    padding: 0.375rem 0.5rem;
    flex-shrink: 0;
    border-right: 1px solid var(--color-border);

    &:last-child {
      border-right: none;
    }
  }

  .weather-card__hour-time {
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--color-ink-muted);
  }

  .weather-card__hour-icon {
    width: 20px;
    height: 20px;
    color: var(--color-ink-muted);

    & svg {
      width: 100%;
      height: 100%;
    }
  }

  .weather-card__hour-temp {
    font-size: 0.8125rem;
    font-weight: 600;
  }

  .weather-card__hour-rain {
    font-size: 0.6875rem;
    color: var(--color-accent);
  }
}
