/* ── Calendar ─────────────────────────────────────────── */

.calendar-hero {
  display: grid;
  gap: 16px;
  background: color-mix(in srgb, var(--panel) 94%, var(--ghost-bg));
}

.calendar-hero-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: end;
  flex-wrap: wrap;
}

.calendar-hero h1 {
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1;
}

.calendar-hero p {
  margin-top: 6px;
  max-width: 56ch;
}

.calendar-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}

.calendar-nav {
  display: flex;
  align-items: center;
  gap: 12px;
}

.calendar-nav h2 {
  margin: 0;
  font-size: clamp(20px, 3vw, 32px);
  min-width: 200px;
  text-align: center;
}

.calendar-nav .btn {
  font-size: 22px;
  padding: 8px 14px;
  line-height: 1;
}

.calendar-month-summary {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.calendar-summary-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 9px 12px;
  border: 1px solid color-mix(in srgb, var(--brand) 16%, var(--line));
  background: color-mix(in srgb, var(--ghost-bg) 72%, var(--panel));
  font-size: 13px;
  font-weight: 600;
}

.calendar-summary-pill strong {
  font-size: 14px;
}

.calendar-filter-bar {
  margin-bottom: 0;
}

.calendar-featured-rail {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.calendar-featured-card,
.calendar-featured-empty {
  min-width: 0;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--brand) 12%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ghost-bg) 64%, var(--panel)) 0%, color-mix(in srgb, var(--ghost-bg) 38%, var(--panel)) 100%);
  padding: 14px;
}

.calendar-featured-card {
  appearance: none;
  display: grid;
  align-content: space-between;
  gap: 10px;
  min-height: 108px;
  text-align: left;
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.calendar-featured-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--brand) 34%, var(--line));
  box-shadow: 0 18px 28px color-mix(in srgb, var(--brand) 10%, transparent);
  background: color-mix(in srgb, var(--brand) 8%, var(--ghost-bg));
}

.calendar-featured-card.is-active,
.calendar-upcoming-item.is-active {
  border-color: color-mix(in srgb, var(--brand) 40%, var(--line));
  background: color-mix(in srgb, var(--brand) 10%, var(--ghost-bg));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 18%, transparent);
}

.calendar-featured-empty {
  color: var(--muted);
  font-size: 13px;
}

.calendar-featured-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-featured-title {
  min-width: 0;
  font-size: 15px;
  line-height: 1.18;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.calendar-featured-date {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.35;
}

.calendar-featured-chip {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand) 10%, var(--ghost-bg));
  color: var(--brand);
  font-size: 12px;
  font-weight: 700;
}

.calendar-shell {
  display: block;
}

.calendar-board,
.calendar-side {
  min-width: 0;
}

.calendar-board {
  position: relative;
  overflow: hidden;
  margin-top: 2px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--brand) 14%, var(--line));
  background: color-mix(in srgb, var(--panel) 94%, var(--ghost-bg));
}

.calendar-side {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(300px, .92fr) minmax(0, 1.08fr);
  align-content: start;
  align-items: start;
  position: static;
}

.calendar-board-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.calendar-board-head h2 {
  margin: 0;
  font-size: 22px;
  line-height: 1.15;
}

.calendar-board-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.calendar-legend {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-board-caption {
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

.calendar-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  align-items: start;
  min-width: 0;
}

.calendar-agenda-panel,
.calendar-month-panel {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 42%, var(--panel));
  border-radius: 18px;
}

.calendar-agenda-panel {
  display: grid;
  gap: 12px;
  padding: 14px;
  max-height: 340px;
  overflow: hidden;
}

.calendar-agenda-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.calendar-section-kicker {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.calendar-agenda-head strong {
  color: var(--brand);
  font-size: 13px;
  white-space: nowrap;
}

.calendar-month-panel {
  padding: 14px;
}

.calendar-month-panel .calendar-legend {
  margin-bottom: 10px;
}

.calendar-grid {
  min-width: 0;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
}

.calendar-month-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
  min-width: 1120px;
}

.calendar-weekday-cell {
  min-height: 26px;
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.calendar-day-card {
  position: relative;
  min-height: 196px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 16px;
  background: color-mix(in srgb, var(--ghost-bg) 34%, var(--panel));
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
  display: grid;
  align-content: start;
  gap: 8px;
  overflow: hidden;
}

.calendar-day-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--brand) 84%, white 16%) 0%, transparent 100%);
  opacity: 0;
}

.calendar-day-card.has-events::before,
.calendar-day-card-selected::before {
  opacity: .9;
}

.calendar-day-card.has-events:hover,
.calendar-day-card-selected {
  border-color: color-mix(in srgb, var(--brand) 34%, var(--line));
  box-shadow: 0 12px 22px color-mix(in srgb, var(--brand) 8%, transparent);
}

.calendar-day-card-other {
  opacity: .56;
}

.calendar-day-card-today {
  border-color: color-mix(in srgb, var(--brand) 26%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--brand) 7%, var(--ghost-bg)) 0%, color-mix(in srgb, var(--ghost-bg) 34%, var(--panel)) 100%);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 12%, transparent);
}

.calendar-day-card-today::before {
  opacity: .42;
}

.calendar-day-card-today .calendar-day-anchor {
  background: color-mix(in srgb, var(--brand) 6%, var(--ghost-bg));
}

.calendar-day-anchor {
  width: 100%;
  appearance: none;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "date count"
    "today count";
  align-items: start;
  gap: 6px 8px;
  margin: -10px -10px 0;
  padding: 10px 10px 11px;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 56%, var(--panel));
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.calendar-day-head-left,
.calendar-day-head-right {
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.calendar-day-head-left {
  grid-area: weekday;
  align-self: center;
  text-transform: uppercase;
  letter-spacing: .08em;
  display: none;
}

.calendar-day-today-pill {
  grid-area: today;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand) 14%, var(--ghost-bg));
  border: 1px solid color-mix(in srgb, var(--brand) 26%, var(--line));
  color: var(--brand);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.calendar-day-head-right {
  grid-area: date;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  white-space: nowrap;
  justify-self: start;
}

.calendar-day-head-right strong {
  font-size: 22px;
  line-height: 1;
}

.calendar-day-head-right small {
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.calendar-day-count {
  grid-area: count;
  align-self: start;
  justify-self: end;
  min-width: 24px;
  min-height: 24px;
  padding: 0 7px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--brand) 10%, var(--ghost-bg));
  color: var(--brand);
  font-size: 12px;
  font-weight: 800;
}

.calendar-day-card-today .calendar-day-head-left,
.calendar-day-card-today .calendar-day-head-right,
.calendar-day-card-today .calendar-day-count {
  color: var(--brand);
}

.calendar-day-card-today.calendar-day-card-selected,
.calendar-day-card-today.has-events:hover {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--brand) 18%, transparent),
    0 18px 30px color-mix(in srgb, var(--brand) 8%, transparent);
}

.calendar-day-list {
  display: grid;
  gap: 6px;
}

.calendar-day-event,
.calendar-day-rollup {
  appearance: none;
  width: 100%;
  text-align: left;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 74%, var(--panel));
  color: var(--text);
  font: inherit;
  cursor: pointer;
}

.calendar-day-event {
  min-height: 48px;
  display: grid;
  gap: 5px;
  padding: 8px 9px 8px 10px;
  border-radius: 12px;
  border-left-width: 4px;
  background: color-mix(in srgb, var(--ghost-bg) 64%, var(--panel));
  transition: border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}

.calendar-day-event:hover,
.calendar-day-event:focus-visible,
.calendar-detail-item:hover,
.calendar-detail-item:focus-visible,
.calendar-upcoming-item:hover,
.calendar-upcoming-item:focus-visible {
  outline: none;
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--brand) 30%, var(--line));
}

.calendar-day-event.is-active,
.calendar-detail-item.is-active {
  border-color: color-mix(in srgb, var(--brand) 42%, var(--line));
  background: color-mix(in srgb, var(--brand) 10%, var(--ghost-bg));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 18%, transparent);
}

.calendar-day-event-meta {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  color: var(--muted);
}

.calendar-day-event-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.calendar-day-event.macro { border-left-color: #62b8d7; }
.calendar-day-event.bond { border-left-color: #efb44d; }
.calendar-day-event.exchange { border-left-color: #89949b; }
.calendar-day-event.dividend { border-left-color: #6bc76b; }

.calendar-day-event-title {
  min-width: 0;
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.25;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.calendar-day-event-time,
.calendar-day-event-type {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.calendar-day-event-type {
  color: var(--text);
  opacity: .72;
}

.calendar-day-rollup {
  min-height: 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border-radius: 14px;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  background: color-mix(in srgb, var(--brand) 7%, var(--ghost-bg));
  transition: border-color .16s ease, background .16s ease;
}

.calendar-day-rollup strong {
  color: var(--text);
  font-size: 12px;
}

.calendar-day-empty-slot {
  min-height: 6px;
}

.calendar-day-card-skeleton {
  pointer-events: none;
}

.shimmer {
  background: linear-gradient(90deg, var(--ghost-bg) 25%, color-mix(in srgb, var(--ghost-bg) 60%, var(--panel)) 50%, var(--ghost-bg) 75%);
  background-size: 200% 100%;
  animation: shimmer-move 1.4s ease infinite;
  border-radius: 6px;
  min-height: 14px;
}

@keyframes shimmer-move {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.calendar-error {
  padding: 32px;
  text-align: center;
  color: var(--muted);
  border: 1px dashed var(--line);
  border-radius: 16px;
}

.calendar-event-preview {
  position: absolute;
  top: 0;
  left: 0;
  width: min(360px, calc(100% - 24px));
  z-index: 5;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}

.calendar-event-preview.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.calendar-preview-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--brand) 24%, var(--line));
  background: color-mix(in srgb, var(--panel) 92%, white);
  box-shadow: 0 26px 44px color-mix(in srgb, rgba(25, 37, 31, 0.14) 86%, transparent);
}

.calendar-preview-meta,
.calendar-focus-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-preview-time,
.calendar-focus-time,
.calendar-detail-time {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.calendar-preview-card h4,
.calendar-focus-card h4 {
  margin: 0;
  font-size: 18px;
  line-height: 1.28;
}

.calendar-preview-card p,
.calendar-focus-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.calendar-preview-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-modal-card {
  width: min(860px, 100%);
  max-height: min(88dvh, 920px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 18px;
  padding: 20px;
  border-radius: 24px;
  border-color: color-mix(in srgb, var(--brand) 18%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ghost-bg) 74%, var(--panel)) 0%, color-mix(in srgb, var(--panel) 92%, transparent) 100%);
  overflow: hidden;
}

.calendar-modal-card .close {
  right: 14px;
  top: 12px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 72%, var(--panel));
  color: var(--muted);
  font-size: 28px;
}

.calendar-modal-head,
.calendar-modal-intro,
.calendar-modal-body,
.calendar-modal-events {
  display: grid;
  gap: 12px;
}

.calendar-modal-head {
  padding-right: 44px;
}

.calendar-modal-intro h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 32px);
  line-height: 1.08;
}

.calendar-modal-intro .page-kicker {
  justify-self: start;
}

.calendar-modal-meta {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.calendar-modal-body {
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.calendar-modal-events {
  align-content: start;
}

.calendar-modal-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.calendar-modal-stat {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 68%, var(--panel));
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}

.calendar-modal-stat strong {
  color: var(--brand);
}

.calendar-modal-event {
  display: grid;
  gap: 12px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ghost-bg) 70%, var(--panel)) 0%, color-mix(in srgb, var(--ghost-bg) 42%, var(--panel)) 100%);
}

.calendar-modal-event.is-active {
  border-color: color-mix(in srgb, var(--brand) 36%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 16%, transparent);
}

.calendar-modal-event-head,
.calendar-modal-event-meta,
.calendar-modal-event-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.calendar-modal-event-time,
.calendar-modal-event-source,
.calendar-modal-event-relative,
.calendar-modal-event-ticker {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.calendar-modal-event-source,
.calendar-modal-event-relative,
.calendar-modal-event-ticker {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ghost-bg) 78%, var(--panel));
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
}

.calendar-modal-event-link {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand) 22%, var(--line));
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  background: color-mix(in srgb, var(--brand) 8%, var(--ghost-bg));
}

.calendar-modal-event-title {
  margin: 0;
  font-size: clamp(18px, 2.2vw, 24px);
  line-height: 1.18;
}

.calendar-modal-event-subtitle,
.calendar-modal-event-summary {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.calendar-modal-event-subtitle {
  font-size: 14px;
  font-weight: 700;
}

.calendar-modal-event-summary {
  font-size: 15px;
}

.calendar-modal-empty {
  min-height: 220px;
  display: grid;
  place-items: center;
  gap: 8px;
  padding: 24px;
  text-align: center;
  border-radius: 20px;
  border: 1px dashed color-mix(in srgb, var(--brand) 20%, var(--line));
  color: var(--muted);
}

.calendar-modal-empty strong {
  color: var(--text);
  font-size: 18px;
}

.calendar-upcoming,
.calendar-day-detail {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--brand) 14%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ghost-bg) 66%, var(--panel)) 0%, color-mix(in srgb, var(--ghost-bg) 40%, var(--panel)) 100%);
  box-shadow: 0 14px 28px color-mix(in srgb, rgba(25, 37, 31, 0.08) 80%, transparent);
}

.calendar-upcoming {
  position: sticky;
  top: calc(var(--topbar-offset, 64px) + 14px);
}

.calendar-card-head,
.calendar-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.calendar-card-head h3,
.calendar-detail-header h3 {
  margin: 0;
  font-size: 19px;
  text-transform: capitalize;
}

.calendar-card-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.calendar-upcoming-list,
.calendar-detail-list {
  display: grid;
  gap: 8px;
}

.calendar-upcoming-item,
.calendar-detail-item {
  appearance: none;
  width: 100%;
  text-align: left;
  display: grid;
  gap: 7px;
  padding: 11px 12px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 16px;
  background: color-mix(in srgb, var(--ghost-bg) 60%, var(--panel));
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.calendar-upcoming-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-upcoming-date {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted);
}

.calendar-upcoming-time {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
}

.calendar-upcoming-title,
.calendar-detail-title {
  font-weight: 700;
  font-size: 15px;
  color: var(--text);
}

.calendar-upcoming-subtitle,
.calendar-detail-subtitle,
.calendar-day-empty,
.calendar-upcoming-empty {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.45;
}

.calendar-detail-subtitle {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.calendar-agenda-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 10px;
  min-height: 0;
  overflow-y: auto;
  padding-right: 2px;
  scrollbar-gutter: stable;
}

.calendar-agenda-day {
  display: grid;
  gap: 9px;
  padding: 11px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 48%, var(--panel));
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.calendar-agenda-day.is-active {
  border-color: color-mix(in srgb, var(--brand) 28%, var(--line));
  background: color-mix(in srgb, var(--brand) 8%, var(--ghost-bg));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 18%, transparent);
}

.calendar-agenda-day-head {
  appearance: none;
  width: 100%;
  padding: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.calendar-agenda-day-title {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.calendar-agenda-day-title strong {
  font-size: 15px;
  line-height: 1.2;
}

.calendar-agenda-day-title span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}

.calendar-agenda-day-badge,
.calendar-focus-chip {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand) 10%, var(--ghost-bg));
  color: var(--brand);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.calendar-agenda-dots,
.calendar-day-category-summary {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}

.calendar-day-category-summary {
  min-height: 22px;
}

.calendar-day-category-summary {
  gap: 6px;
}

.calendar-agenda-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--muted);
}

.calendar-agenda-dot.macro { background: #62b8d7; }
.calendar-agenda-dot.bond { background: #efb44d; }
.calendar-agenda-dot.exchange { background: #89949b; }
.calendar-agenda-dot.dividend { background: #6bc76b; }

.calendar-day-category-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 70%, var(--panel));
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.calendar-day-category-pill strong {
  color: var(--text);
  font-size: 10px;
}

.calendar-day-category-pill.macro {
  border-color: color-mix(in srgb, #62b8d7 42%, var(--line));
  background: color-mix(in srgb, #62b8d7 13%, var(--ghost-bg));
}

.calendar-day-category-pill.bond {
  border-color: color-mix(in srgb, #efb44d 42%, var(--line));
  background: color-mix(in srgb, #efb44d 14%, var(--ghost-bg));
}

.calendar-day-category-pill.exchange {
  border-color: color-mix(in srgb, #89949b 38%, var(--line));
  background: color-mix(in srgb, #89949b 12%, var(--ghost-bg));
}

.calendar-day-category-pill.dividend {
  border-color: color-mix(in srgb, #6bc76b 42%, var(--line));
  background: color-mix(in srgb, #6bc76b 13%, var(--ghost-bg));
}

.calendar-agenda-events {
  display: grid;
  gap: 6px;
}

.calendar-agenda-event {
  appearance: none;
  width: 100%;
  min-height: 34px;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 7px 8px;
  border-radius: 11px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 66%, var(--panel));
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color .16s ease, transform .16s ease, background .16s ease;
}

.calendar-agenda-event:hover,
.calendar-agenda-event:focus-visible {
  outline: none;
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--brand) 30%, var(--line));
}

.calendar-agenda-event.is-active {
  border-color: color-mix(in srgb, var(--brand) 38%, var(--line));
  background: color-mix(in srgb, var(--brand) 8%, var(--ghost-bg));
}

.calendar-agenda-event-time {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.calendar-agenda-event-title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 800;
}

.calendar-agenda-empty {
  min-height: 160px;
  display: grid;
  place-items: center;
  padding: 18px;
  border-radius: 14px;
  border: 1px dashed color-mix(in srgb, var(--line) 84%, transparent);
  color: var(--muted);
  text-align: center;
  font-size: 13px;
  line-height: 1.45;
}

.calendar-agenda-more,
.calendar-detail-expand {
  appearance: none;
  width: 100%;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--brand) 18%, var(--line));
  background: color-mix(in srgb, var(--brand) 8%, var(--ghost-bg));
  color: var(--text);
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.calendar-agenda-more:hover,
.calendar-detail-expand:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--brand) 28%, var(--line));
  background: color-mix(in srgb, var(--brand) 12%, var(--ghost-bg));
}

.calendar-detail-summary {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-detail-stat {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  background: color-mix(in srgb, var(--ghost-bg) 62%, var(--panel));
  font-size: 12px;
  font-weight: 700;
}

.calendar-detail-stat strong {
  font-size: 13px;
}

.calendar-detail-stat.macro {
  border-color: color-mix(in srgb, #62b8d7 45%, var(--line));
}

.calendar-detail-stat.bond {
  border-color: color-mix(in srgb, #efb44d 45%, var(--line));
}

.calendar-detail-stat.exchange {
  border-color: color-mix(in srgb, var(--muted) 40%, var(--line));
}

.calendar-detail-stat.dividend {
  border-color: color-mix(in srgb, #6bc76b 45%, var(--line));
}

.calendar-focus-card {
  display: grid;
  gap: 10px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--brand) 20%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--brand) 8%, var(--ghost-bg)) 0%, color-mix(in srgb, var(--ghost-bg) 52%, var(--panel)) 100%);
  box-shadow: 0 18px 30px color-mix(in srgb, rgba(25, 37, 31, 0.08) 78%, transparent);
}

.calendar-focus-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  color: var(--brand);
  text-decoration: none;
  font-size: 13px;
  font-weight: 700;
}

.calendar-focus-link:hover {
  text-decoration: underline;
}

.calendar-detail-main {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.calendar-detail-list-shell {
  position: relative;
}

.calendar-detail-list-shell.is-collapsed::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 44px;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 0%, color-mix(in srgb, var(--panel) 92%, var(--ghost-bg) 8%) 100%);
}

.calendar-detail-empty-secondary {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px dashed color-mix(in srgb, var(--line) 84%, transparent);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.calendar-detail-close {
  min-width: 40px;
  min-height: 40px;
}

.cal-chip-count {
  margin-left: 6px;
  font-size: 11px;
  opacity: .7;
}
