.calendar-view-block { display: grid; gap: 14px; justify-items: start; }
.calendar-title-layer { width: 100%; border-bottom: 1px solid var(--border); padding: 0 0 10px; }
.calendar-title-layer h2 { margin: 0; font-size: clamp(22px, 2.4vw, 30px); }
.calendar-view-tabs { margin: 0; justify-content: flex-start; width: 100%; }
.calendar-range-hint { margin: -4px 0 0; max-width: 860px; font-size: clamp(12px, 1.25vw, 14px); line-height: 1.6; }
.calendar-filter-bar { gap: 12px; margin-top: 6px; }
.calendar-filter-grid { grid-template-columns: repeat(2, minmax(156px, 180px)) repeat(2, minmax(132px, 180px)) auto; }
.calendar-filter-actions { display: flex; gap: 10px; align-items: end; justify-content: flex-start; }
.calendar-special-nav { align-items: center; justify-content: flex-start; }
.calendar-special-nav .btn { min-width: 52px; }
.calendar-view-tabs .btn.is-active { border-color: rgba(83, 217, 255, 0.62); color: var(--white); background: rgba(83, 217, 255, 0.12); }
.calendar-month-stack { display: grid; gap: 14px; }
.calendar-special-legend { display: inline-flex; flex-wrap: nowrap; align-items: center; gap: 10px 16px; width: fit-content; max-width: 100%; overflow-x: auto; scrollbar-width: none; padding: 8px 10px; border: 1px solid rgba(83, 217, 255, 0.12); border-radius: 12px; background: rgba(255, 255, 255, 0.02); }
.calendar-special-legend::-webkit-scrollbar { display: none; }
.calendar-special-legend-item { display: inline-flex; align-items: center; gap: 7px; color: var(--muted); font-size: 12px; line-height: 1.3; white-space: nowrap; }
.calendar-special-legend-swatch { width: 12px; height: 12px; border-radius: 4px; border: 1px solid currentColor; box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.04) inset; }
.calendar-special-legend-swatch.is-holiday { background: rgba(148, 163, 184, 0.78); border-color: rgba(148, 163, 184, 0.92); }
.calendar-special-legend-swatch.is-important { background: rgba(250, 204, 21, 0.78); border-color: rgba(250, 204, 21, 0.95); }
.calendar-month-card { display: grid; gap: 10px; padding: 14px; border: 1px solid rgba(83, 217, 255, 0.12); border-radius: 14px; background: rgba(8, 14, 20, 0.82); }
.calendar-month-head { display: flex; align-items: center; justify-content: space-between; }
.calendar-month-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 8px; }
.calendar-month-grid > strong { color: var(--muted); font-size: 12px; text-align: center; }
.calendar-month-cell { min-height: 78px; padding: 8px; border-radius: 12px; border: 1px solid rgba(83, 217, 255, 0.08); background: rgba(255, 255, 255, 0.02); display: grid; align-content: start; gap: 6px; }
.calendar-month-cell strong { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.calendar-month-cell.is-empty { border-color: transparent; background: transparent; }
.calendar-month-cell.is-holiday { border-color: rgba(148, 163, 184, 0.42); background: rgba(71, 85, 105, 0.28); }
.calendar-month-cell.is-important { border-color: rgba(250, 204, 21, 0.42); background: rgba(113, 63, 18, 0.24); }
.calendar-month-cell span { color: var(--muted); font-size: 11px; line-height: 1.35; }
.calendar-day-markers,
.calendar-event-markers { display: inline-flex; align-items: center; gap: 4px; }
.calendar-event-marker { width: 10px; height: 10px; border-radius: 3px; border: 1px solid currentColor; }
.calendar-event-marker.is-holiday { color: rgba(148, 163, 184, 0.92); background: rgba(148, 163, 184, 0.78); }
.calendar-event-marker.is-important { color: rgba(250, 204, 21, 0.95); background: rgba(250, 204, 21, 0.78); }
.calendar-liquidity-dot { width: 12px; height: 12px; border: 0; border-radius: 999px; padding: 0; cursor: help; box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.06); }
.calendar-liquidity-dot.is-high { background: #ef4444; }
.calendar-liquidity-dot.is-medium { background: #a855f7; }
.calendar-liquidity-dot.is-low { background: #22c55e; }
.calendar-special-legend-swatch.is-liquidity { border-radius: 999px; background: linear-gradient(90deg, #ef4444 0 33%, #a855f7 33% 66%, #22c55e 66% 100%); }
.calendar-liquidity-pairs { display: flex; flex-wrap: wrap; gap: 4px; }
.calendar-liquidity-pairs button,
.calendar-liquidity-pairs span { border: 0; border-radius: 999px; padding: 2px 5px; background: rgba(245, 158, 11, 0.14); color: #fbbf24; font-size: 10px; font-weight: 800; }
.calendar-liquidity-pairs button { cursor: pointer; }
.calendar-liquidity-legend-dot { display: inline-flex; cursor: default; flex: 0 0 auto; }

html[data-theme="light"] .calendar-view-tabs .btn.is-active { color: var(--text); border-color: rgba(108, 146, 173, 0.34); background: #e8f2fa; box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35); }

html[data-theme="light"] .calendar-month-card,
html[data-theme="light"] .calendar-month-cell,
html[data-theme="light"] .calendar-month-grid > strong,
html[data-theme="light"] .calendar-month-cell.is-empty { border-color: rgba(108, 146, 173, 0.22); background: var(--soft-panel); color: var(--text); }
html[data-theme="light"] .calendar-month-cell span,
html[data-theme="light"] .calendar-month-grid > strong { color: var(--muted); }
html[data-theme="light"] .calendar-month-cell.is-holiday { border-color: rgba(100, 116, 139, 0.28); background: #f1f5f9; }
html[data-theme="light"] .calendar-month-cell.is-empty { border-color: transparent; background: transparent; }
html[data-theme="light"] .calendar-month-cell.is-important { border-color: rgba(217, 119, 6, 0.28); background: #fffbeb; }

@media (max-width: 1080px) {
  .calendar-view-block { display: block; }
  .calendar-view-tabs { margin: 12px 0 16px; justify-content: flex-start; width: 100%; }
  .calendar-filter-grid { grid-template-columns: repeat(2, minmax(156px, 1fr)); }
}

@media (max-width: 720px) {
  .calendar-view-block { display: grid; gap: 10px; }
  .calendar-view-tabs { display: grid; grid-template-columns: 1fr; margin: 8px 0 10px; justify-content: stretch; width: 100%; gap: 8px; }
  .calendar-view-tabs .btn { width: 100%; min-height: 42px; padding: 10px 12px; font-size: 15px; }
  .calendar-filter-grid { display: grid; grid-template-columns: 1fr; width: 100%; gap: 12px; padding-bottom: 4px; }
  .calendar-filter-grid > label,
  .calendar-filter-grid .text-input { width: 100%; min-width: 0; }
  .calendar-filter-actions { width: 100%; justify-content: stretch; }
  .calendar-filter-actions .btn { width: 100%; min-height: 42px; padding: 10px 14px; }
  .calendar-special-nav { display: grid; grid-template-columns: 44px minmax(0, 1fr) 44px; gap: 8px; width: 100%; }
  .calendar-special-nav .btn { min-width: 0; width: 100%; min-height: 42px; padding: 8px 10px; }
  #calendarSpecialRangeLabel { text-align: center; min-width: 0; }
  #calendarSpecialCurrentBtn { grid-column: 1 / -1; }
  .calendar-special-legend { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); width: 100%; gap: 8px; padding: 8px; overflow: visible; }
  .calendar-special-legend-item { min-width: 0; white-space: normal; font-size: 11px; }
  .calendar-month-card { padding: 10px; border-radius: 12px; overflow: hidden; }
  .calendar-month-grid { grid-template-columns: 1fr; gap: 8px; }
  .calendar-month-grid > strong,
  .calendar-month-cell.is-empty { display: none; }
  .calendar-month-cell { min-height: auto; padding: 10px; }
  .calendar-month-cell span { overflow-wrap: anywhere; }
  .calendar-liquidity-pairs { gap: 3px; }
  .calendar-liquidity-pairs button,
  .calendar-liquidity-pairs span { padding: 2px 5px; font-size: 9px; }
  .calendar-pagination { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; width: 100%; }
}
