/* ─────────────────────────────────────────────────────────────────────────
   Liminal Events — calendar view stylesheet

   Scope: the calendar view at /events/calendar/ — the alternate to the
   archive list, surfaced via the View toggle.

   Visual language: a month grid where each event renders as a tinted
   block on its day. Multi-day events repeat on each day in the range.
   Ongoing programs do not appear in the calendar (they have no date) —
   the list view's Ongoing section covers them. The view toggle remains
   visible so users can swap back.

   Honors the same --le-* Customizer variables as archive.css and
   single-event.css. Category accent colors are derived server-side from
   --le-accent via OKLCH and emitted as --le-cat-{n}-{tint|fg|bar}.

   No JS. Pure HTML/CSS. Mobile breakpoint collapses the grid to a
   stacked agenda (only days with events render).
   ───────────────────────────────────────────────────────────────────────── */

.liminal-events--calendar {
  /* Customizer defaults — overridden by theme.json / Customizer */
  --le-heading: #1a1a1a;
  --le-accent: #2a2a2a;
  --le-ongoing-border: var(--le-accent);
  --le-card-bg: #f6f4ef;
  --le-card-border: rgba(0, 0, 0, 0.12);
  --le-card-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
  --le-muted: rgba(0, 0, 0, 0.55);
  --le-rule: rgba(0, 0, 0, 0.12);
  --le-radius: 0px;
  --le-gap: 16px;

  /* Derived tokens */
  --le-rule-strong: color-mix(in oklab, var(--le-heading) 28%, transparent);
  --le-faint: color-mix(in oklab, var(--le-heading) 5%, transparent);
  --le-mono: "JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;

  /* Fallback category palette — overwritten inline by the plugin from
     the active accent. Same generator as archive.css. */
  --le-cat-0-tint: color-mix(in oklab, var(--le-accent) 14%, var(--le-card-bg));
  --le-cat-0-fg:   color-mix(in oklab, var(--le-accent) 70%, var(--le-heading));
  --le-cat-0-bar:  var(--le-accent);

  max-width: 1180px;
  margin: 0 auto;
  padding: 32px 24px 64px;
  color: var(--le-heading);
}

/* ─────────────────────────────────────────────────────────────────────────
   Page header — shared with archive
   ───────────────────────────────────────────────────────────────────────── */
.liminal-events__archive-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 28px;
}
.liminal-events__overline {
  font-family: var(--le-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--le-muted);
  margin-bottom: 12px;
}
.liminal-events__page-title {
  font-family: inherit;
  font-size: clamp(40px, 5vw, 56px);
  font-weight: 700;
  letter-spacing: -0.022em;
  line-height: 1.02;
  margin: 0;
  color: var(--le-heading);
}
.liminal-events__view-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.liminal-events__view-toggle-label {
  font-family: var(--le-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--le-muted);
}
.liminal-events__view-toggle-pill {
  display: inline-flex;
  padding: 3px;
  background: var(--le-faint);
  border-radius: 999px;
  border: 1px solid var(--le-rule);
  font-family: var(--le-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.liminal-events__view-toggle-pill a {
  padding: 6px 14px;
  border-radius: 999px;
  color: var(--le-muted);
  text-decoration: none;
}
.liminal-events__view-toggle-pill a[aria-current="page"] {
  background: var(--le-accent);
  color: var(--le-card-bg);
}

/* ─────────────────────────────────────────────────────────────────────────
   Filter form — shared with archive
   ───────────────────────────────────────────────────────────────────────── */
.liminal-events__filters {
  display: flex;
  gap: 14px;
  align-items: stretch;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--le-rule-strong);
  margin-bottom: 8px;
}
.liminal-events__search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--le-rule);
  border-radius: 999px;
  padding: 8px 18px;
  background: var(--le-faint);
}
.liminal-events__search svg { flex: 0 0 auto; opacity: 0.5; }
.liminal-events__search input {
  appearance: none; border: 0; background: transparent;
  color: var(--le-heading); font: inherit; font-size: 14px;
  outline: none; width: 100%;
}
.liminal-events__search input::placeholder { color: var(--le-muted); }
.liminal-events__select {
  appearance: none;
  border: 1px solid var(--le-rule);
  background: transparent;
  padding: 10px 36px 10px 16px;
  border-radius: 999px;
  color: var(--le-heading);
  font: inherit; font-size: 14px; font-weight: 500;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='currentColor' d='M0 0h10L5 6z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  cursor: pointer;
}
/* Structural rules — high specificity to outweigh host-theme global
 * `button` resets. Color rules wrapped in :where() so the theme's
 * `.button` Customizer settings win when present. */
.liminal-events--calendar button.liminal-events__filter-submit,
.liminal-events--calendar .liminal-events__filter-submit {
  appearance: none;
  border: 0;
  padding: 10px 22px;
  border-radius: 999px;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-shadow: none;
  box-shadow: none;
  line-height: 1.2;
}
:where(.liminal-events--calendar .liminal-events__filter-submit) {
  background: var(--le-accent);
  color: var(--le-card-bg);
}
:where(.liminal-events--calendar .liminal-events__filter-submit:hover),
:where(.liminal-events--calendar .liminal-events__filter-submit:focus) {
  background: color-mix(in oklab, var(--le-accent) 85%, var(--le-heading));
  color: var(--le-card-bg);
  opacity: 1;
}

/* ─────────────────────────────────────────────────────────────────────────
   Month nav
   ───────────────────────────────────────────────────────────────────────── */
.liminal-events__cal-nav {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  padding: 20px 0 18px;
  border-bottom: 1px solid var(--le-rule-strong);
  margin-top: 16px;
}
.liminal-events__cal-nav-controls {
  display: flex;
  align-items: baseline;
  gap: 18px;
}
.liminal-events__cal-nav-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border: 1px solid var(--le-rule);
  border-radius: 999px;
  background: transparent;
  color: var(--le-heading);
  font-family: var(--le-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
}
.liminal-events__cal-nav-btn:hover { background: var(--le-faint); }
.liminal-events__cal-nav-month {
  font-family: inherit;
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 700;
  letter-spacing: -0.022em;
  line-height: 1;
  margin: 0;
  color: var(--le-heading);
}
.liminal-events__cal-nav-month-year {
  opacity: 0.5;
  font-weight: 500;
  margin-left: 8px;
}
.liminal-events__cal-nav-count {
  font-family: var(--le-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--le-muted);
}

/* ─────────────────────────────────────────────────────────────────────────
   Calendar grid
   ───────────────────────────────────────────────────────────────────────── */
.liminal-events__cal-grid {
  margin-top: 24px;
  border: 1px solid var(--le-rule);
  border-radius: var(--le-radius);
}

.liminal-events__cal-daynames {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--le-rule);
}
.liminal-events__cal-dayname {
  padding: 12px 14px;
  font-family: var(--le-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--le-muted);
  border-right: 1px solid var(--le-rule);
}
.liminal-events__cal-dayname:last-child { border-right: 0; }

.liminal-events__cal-cells {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.liminal-events__cal-cell {
  position: relative;
  min-height: 140px;
  padding: 10px 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-right: 1px solid var(--le-rule);
  border-bottom: 1px solid var(--le-rule);
}
/* Last column / last row trim */
.liminal-events__cal-cell:nth-child(7n) { border-right: 0; }
.liminal-events__cal-cell:nth-last-child(-n+7):nth-child(n) { /* may be a partial row */ }

/* Out-of-month padding cells — render faintly */
.liminal-events__cal-cell--empty {
  background: var(--le-faint);
  pointer-events: none;
}
.liminal-events__cal-cell--empty .liminal-events__cal-daynum {
  opacity: 0;
}

/* Day number */
.liminal-events__cal-daynum {
  font-family: var(--le-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--le-heading);
  opacity: 0.55;
  margin-bottom: 2px;
}
/* Today */
.liminal-events__cal-cell--today {
  background: color-mix(in oklab, var(--le-accent) 6%, transparent);
}
.liminal-events__cal-cell--today .liminal-events__cal-daynum {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 22px;
  border-radius: 11px;
  background: var(--le-accent);
  color: var(--le-card-bg);
  opacity: 1;
  font-weight: 600;
  align-self: flex-start;
}

/* Events container — wraps event tiles inside a day cell so flexbox can
   reflow at the mobile breakpoint without restructuring markup */
.liminal-events__cal-events {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

/* Event tile */
.liminal-events__cal-event {
  display: block;
  background: var(--le-cat-tint, var(--le-cat-0-tint));
  color: var(--le-cat-fg, var(--le-cat-0-fg));
  border-left: 2px solid var(--le-cat-bar, var(--le-cat-0-bar));
  padding: 6px 8px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.28;
  text-decoration: none;
  letter-spacing: -0.002em;
  overflow-wrap: anywhere;
  transition: transform 0.15s;
}
.liminal-events__cal-event:hover,
.liminal-events__cal-event:focus,
.liminal-events__cal-event:active {
  transform: translateX(2px);
  text-decoration: none;
}
/* Range bookends — subtle visual cue for the start/end of a multi-day event */
.liminal-events__cal-event-prefix {
  font-family: var(--le-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
  display: inline-block;
  margin-right: 4px;
}

/* Legend / key */
.liminal-events__cal-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: center;
  margin-top: 24px;
  font-family: var(--le-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--le-muted);
}
.liminal-events__cal-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.liminal-events__cal-legend-swatch {
  width: 10px; height: 10px;
  border-left: 2px solid var(--le-cat-bar, var(--le-cat-0-bar));
  background: var(--le-cat-tint, var(--le-cat-0-tint));
}

/* ─────────────────────────────────────────────────────────────────────────
   Mobile — collapse grid into a stacked agenda.
   Only days with events render; empty days disappear.
   ───────────────────────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  .liminal-events--calendar { padding: 20px 18px 48px; }

  .liminal-events__filters { flex-direction: column; gap: 10px; }

  .liminal-events__cal-grid { border: none; }
  .liminal-events__cal-daynames { display: none; }

  .liminal-events__cal-cells {
    display: flex;
    flex-direction: column;
  }
  .liminal-events__cal-cell--empty,
  .liminal-events__cal-cell:not(:has(.liminal-events__cal-event)) {
    display: none;
  }
  .liminal-events__cal-cell {
    flex-direction: row;
    align-items: baseline;
    gap: 16px;
    min-height: 0;
    padding: 14px 0;
    border: none;
    border-bottom: 1px solid var(--le-rule);
  }
  .liminal-events__cal-cell:nth-child(7n) { border-right: 0; border-bottom: 1px solid var(--le-rule); }

  .liminal-events__cal-daynum {
    flex: 0 0 64px;
    font-size: 18px;
    font-weight: 600;
    color: var(--le-heading);
    opacity: 1;
    letter-spacing: -0.005em;
  }
  .liminal-events__cal-cell--today .liminal-events__cal-daynum {
    width: auto;
    height: auto;
    padding: 0;
    background: transparent;
    color: var(--le-accent);
  }
  .liminal-events__cal-events { flex: 1; gap: 6px; }
  .liminal-events__cal-event {
    font-size: 14px;
    padding: 8px 12px;
    -webkit-line-clamp: 3;
  }
}
