/* Countdown Card — festival countdown timer + "Up Next" widget */

@layer components {
  .countdown-card {
    background: linear-gradient(135deg,
      color-mix(in oklch, oklch(var(--lch-uv)) 15%, var(--color-surface)),
      color-mix(in oklch, oklch(var(--lch-laser)) 10%, var(--color-surface))
    );
    border: 1px solid color-mix(in oklch, oklch(var(--lch-uv)) 30%, var(--color-border));
    border-radius: var(--radius-lg);
    padding: var(--block-space-l) var(--inline-space-l);
    margin-block-end: var(--block-space);
    text-align: center;
  }

  .countdown-card__header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--inline-space-s);
    position: relative;
  }

  .countdown-card__title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
    color: var(--color-ink-muted);
  }

  .countdown-card__dismiss {
    position: absolute;
    inset-inline-end: 0;
    inset-block-start: 0;
    display: grid;
    place-items: center;
    width: 1.5rem;
    height: 1.5rem;
    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: 0.875rem;
      height: 0.875rem;
    }
  }

  .countdown-card__timer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--inline-space-s);
    margin-block: var(--block-space);
  }

  .countdown-card__unit {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 3rem;
  }

  .countdown-card__value {
    font-size: 2.25rem;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    color: oklch(var(--lch-uv));
  }

  .countdown-card__label {
    font-size: 0.6875rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-ink-muted);
    margin-block-start: 0.25rem;
  }

  .countdown-card__separator {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-ink-muted);
    align-self: flex-start;
    padding-block-start: 0.25rem;
  }

  /* Up Next variant */
  .countdown-card--up-next {
    background: linear-gradient(135deg,
      color-mix(in oklch, oklch(var(--lch-flare)) 15%, var(--color-surface)),
      color-mix(in oklch, oklch(var(--lch-golden)) 10%, var(--color-surface))
    );
    border-color: color-mix(in oklch, oklch(var(--lch-flare)) 30%, var(--color-border));
  }

  .countdown-card__badge {
    display: inline-block;
    padding: 0.2em 0.6em;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: oklch(100% 0 0);
    background: oklch(var(--lch-flare));
    border-radius: var(--radius-pill);
  }

  .countdown-card__content {
    margin-block-start: var(--block-space-s);
  }

  .countdown-card__artist {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0;
  }

  .countdown-card__stage {
    font-size: 0.875rem;
    color: var(--color-ink-muted);
    margin: 0.25rem 0 0;
  }

  .countdown-card__countdown {
    margin-block-start: var(--block-space-s);
  }

  .countdown-card__timer-inline {
    font-size: 1.5rem;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    color: oklch(var(--lch-flare));
  }
}
