/*
  Easter egg: crafted by Subeedei Batzaya.
  If the gates line up, the schedule smiles back.
*/

:root {
  --bg: #f3f6fb;
  --panel: #ffffff;
  --line: #b8c0cc;
  --line-soft: #dbe1ea;
  --row-divider: #8a9db3;
  --text: #1f2937;
  --accent: #0b4f6c;
  --pattern: #4b78c8;
  --single: #ea8a2c;
  --conflict: #d14545;
  --stand-col-width: 80px;
  --board-local-day-height: 26px;
  --board-header-height: 32px;
  --board-row-height: 36px;
  --board-utc-height: 56px;
  --board-utc-band-height: 24px;
  --board-block-height: 24px;
  --board-overlap-lane-height: 18px;
  --board-overlap-lane-gap: 4px;
  --board-overlap-guard-px: 10px;
  --board-overlap-band-fill: 0.72;
  --board-overlap-min-visible-gap: 4px;
  --board-overlap-min-lane-height: 14px;
  --board-overlap-crowded-lane-height: 15px;
  --board-overlap-crowded-lane-gap: 2px;
  --board-overlap-crowded-band-fill: 0.6;
  --board-overlap-crowded-min-visible-gap: 2px;
  --board-overlap-crowded-min-lane-height: 13px;
  --board-overlap-separator-width: 0px;
  --board-overlap-center-bias: 0px;
  --board-stand-font-size: 11px;
  --board-hour-label-size: 12px;
  --board-end-label-size: 12px;
  --board-hour-label-offset: 6px;
  --board-date-font-size: 11px;
  --board-block-font-size: 12px;
  --board-utc-day-font-size: 11px;
  --board-utc-sticky-font-size: 10px;
  --lane-stand-even: #f7fbff;
  --lane-stand-odd: #dee9f6;
  --lane-track-even-a: #fdfefe;
  --lane-track-even-b: #eff5fc;
  --lane-track-odd-a: #edf4fd;
  --lane-track-odd-b: #dee8f5;
  --lane-remote-stand-even: #f7f1e6;
  --lane-remote-stand-odd: #e8dcc8;
  --lane-remote-track-even-a: #fbf6ee;
  --lane-remote-track-even-b: #f0e7da;
  --lane-remote-track-odd-a: #f3eadb;
  --lane-remote-track-odd-b: #e7dbc8;
  --lane-hover-overlay: rgba(93, 126, 167, 0.11);
  --lane-selected-edge: rgba(56, 103, 166, 0.92);
  --lane-selected-overlay-even: transparent;
  --lane-selected-overlay-odd: transparent;
  --lane-selected-rule-even: rgba(56, 103, 166, 0.26);
  --lane-selected-rule-odd: rgba(56, 103, 166, 0.30);
  --lane-selected-outline-even: rgba(56, 103, 166, 0.08);
  --lane-selected-outline-odd: rgba(56, 103, 166, 0.10);
  --lane-selected-stand-fill-even: #e8f1fb;
  --lane-selected-stand-fill-odd: #d8e6f7;
  --lane-selected-label-even: #274b78;
  --lane-selected-label-odd: #1f3f69;
  --lane-selected-overlay-remote: rgba(232, 170, 52, 0.24);
  --lane-selected-edge-remote: rgba(188, 123, 8, 0.96);
  --lane-selected-rule-remote: rgba(188, 123, 8, 0.32);
  --lane-selected-stand-fill-remote: #f1e2c2;
  --lane-selected-label-remote: #6b4308;
  --lane-search-overlay: rgba(18, 120, 68, 0.12);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #dce6f5 0%, var(--bg) 140px);
}

.topbar {
  display: flex;
  align-items: center;
  gap: 16px;
  background: #083b52;
  padding: 10px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}

.topbar a {
  color: #e7f6ff;
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 6px;
  font-weight: 600;
  white-space: nowrap;
}

.topbar a:hover { background: rgba(255, 255, 255, 0.15); }

.wip-notice {
  margin-top: 14px;
  padding: 8px 10px;
  background: rgba(255, 160, 30, 0.12);
  border-left: 3px solid rgba(255, 160, 30, 0.8);
  border-radius: 3px;
  font-size: 12px;
  color: #a07020;
  line-height: 1.4;
}

.demo-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #fff;
  background: rgba(255, 160, 30, 0.75);
  border: 1px solid rgba(255, 160, 30, 0.9);
  border-radius: 3px;
  padding: 2px 6px;
  margin-right: 8px;
  flex-shrink: 0;
  pointer-events: none;
  user-select: none;
}

.birthday-badge {
  width: 64px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 8px;
  flex-shrink: 0;
  pointer-events: none;
  user-select: none;
}

.birthday-badge-icon {
  width: 64px;
  height: 42px;
  display: block;
  overflow: hidden;
}

.birthday-bg {
  fill: #083b52;
}

.birthday-line {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.birthday-face {
  stroke: #ffde17;
  stroke-width: 4.2;
}

.birthday-horn {
  stroke: #36e4eb;
  stroke-width: 4.2;
}

.birthday-hat {
  stroke: #f25be6;
  stroke-width: 4.2;
}

.topbar-left,
.topbar-actions,
.topbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.topbar-left {
  flex: 0 0 auto;
}

.topbar-actions {
  flex: 1 1 auto;
  justify-content: flex-end;
  overflow-x: auto;
  scrollbar-width: none;
}

.topbar-actions::-webkit-scrollbar {
  display: none;
}

.topbar-right {
  flex: 0 0 auto;
  margin-left: auto;
  gap: 6px;
}

.nav-tab {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid transparent;
}

.nav-tab.active {
  background: #eef5ff;
  color: #0a3550;
  border-color: #a9bfd6;
}

.icon-action {
  min-width: 38px;
  padding: 8px 10px;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.06);
  font-size: 12px;
  letter-spacing: 0.02em;
}

.icon-action:hover {
  background: rgba(255, 255, 255, 0.18);
}

.topbar-icon {
  width: 16px;
  height: 16px;
  display: block;
}

@media (max-width: 1280px) {
  .topbar {
    gap: 6px;
    padding: 6px 8px;
    flex-wrap: wrap;
    overflow-x: hidden;
    scrollbar-width: none;
  }

  .topbar::-webkit-scrollbar {
    display: none;
  }

  .topbar a {
    padding: 7px 9px;
    font-size: 13px;
  }

  .demo-badge {
    margin-right: 2px;
  }

  .birthday-badge {
    width: 58px;
    height: 38px;
    margin-right: 2px;
  }

  .birthday-badge-icon {
    width: 58px;
    height: 38px;
  }

  .topbar-left {
    flex: 1 1 auto;
    flex-wrap: wrap;
  }

  .topbar-actions {
    order: 3;
    flex: 1 1 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    overflow: visible;
  }

  .topbar-right {
    order: 2;
    margin-left: auto;
  }

  .topbar-user {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.container {
  width: 100%;
  max-width: none;
  margin: 16px 0;
  padding: 0 12px 20px;
}

.site-footer {
  text-align: center;
  padding: 16px 12px;
  font-size: 12px;
  color: #6b7280;
  border-top: 1px solid var(--line);
  margin-top: 24px;
}

/* Manage tabs */
.manage-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid var(--line);
  margin-bottom: 0;
}
.manage-tab {
  padding: 8px 20px;
  border: none;
  background: none;
  font-size: 13px;
  font-weight: 600;
  color: #6b7280;
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  border-radius: 4px 4px 0 0;
  transition: color 0.15s;
}
.manage-tab:hover { color: #1e40af; background: #f0f5ff; }
.manage-tab.active { color: #1e3a6e; border-bottom-color: #1e3a6e; background: none; }
.tab-count {
  display: inline-block;
  background: #e5eaf5;
  color: #374151;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
  padding: 1px 7px;
  margin-left: 4px;
}
.manage-tab.active .tab-count { background: #1e3a6e; color: #fff; }
.manage-section { padding-top: 16px; }
.manage-search-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.manage-search-input {
  padding: 7px 12px;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  font-size: 13px;
  width: 300px;
  outline: none;
  transition: border-color 0.15s;
}
.manage-search-input:focus { border-color: #1e3a6e; box-shadow: 0 0 0 2px rgba(30,58,110,0.1); }
.manage-search-count { font-size: 12px; color: #6b7280; }

/* User management */
.user-toolbar { margin-bottom: 14px; }
.manage-table { width: 100%; max-width: 640px; border-collapse: collapse; font-size: 13px; }
.manage-table th, .manage-table td { padding: 8px 12px; border-bottom: 1px solid var(--line); text-align: left; }
.manage-table th { background: var(--panel); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: #4b5563; }
.manage-table tr:hover { background: #f0f5ff; }
.action-cell { display: flex; gap: 6px; align-items: center; }
.inline-form { display: inline; }
.btn-sm { font-size: 11px; padding: 3px 10px; border-radius: 4px; cursor: pointer; }
.primary-btn { display: inline-block; padding: 6px 16px; background: #2563eb; color: #fff; border: none; border-radius: 6px; font-size: 13px; font-weight: 600; text-decoration: none; cursor: pointer; }
.primary-btn:hover { background: #1d4ed8; }
.danger-btn { background: #dc2626; color: #fff; border: none; font-weight: 600; }
.danger-btn:hover { background: #b91c1c; }
.badge { display: inline-block; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 10px; text-transform: uppercase; letter-spacing: 0.04em; }
.badge-you { background: #dbeafe; color: #1e40af; margin-left: 6px; }
.badge-role { color: #fff; }
.badge-superadmin { background: #7c3aed; }
.badge-admin { background: #2563eb; }
.badge-add_charter { background: #d97706; }
.badge-viewer { background: #6b7280; }

h2 { margin: 10px 0 14px; }

.alerts { margin: 0 0 12px; }

.alert {
  padding: 10px 12px;
  border-radius: 6px;
  border: 1px solid;
}

.alert.error {
  background: #ffe3e3;
  border-color: #e18b8b;
  color: #6e1010;
}

.datepick {
  display: flex;
  align-items: end;
  gap: 10px;
  margin: 0 0 14px;
  flex-wrap: wrap;
}


.date-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.weekday-label {
  font-size: 14px;
  font-weight: 600;
  color: #50627a;
  white-space: nowrap;
}

.legend {
  display: flex;
  gap: 8px;
  margin: 0 0 12px;
}

.chip {
  display: inline-block;
  border: 1px solid #8f99aa;
  border-radius: 999px;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 700;
  background: #fff;
}

.chip.pattern { background: #d8e5fa; }
.chip.single { background: #ffe7cd; }
.chip.conflict { background: #ffd5d5; }
.chip.cancelled { background: #eef1f6; }

.timeline-wrap {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: auto;
  max-height: 78vh;
  width: 100%;
}

.monthly-toolbar,
.day-toolbar {
  display: grid;
  grid-template-columns: 1fr;
  width: 100%;
  padding: 0;
  margin: 0;
  background: #f8fafc;
  border: 1px dashed #b9c4cf;
  border-bottom: 1px solid #d7dde6;
  border-radius: 8px 8px 0 0;
}

.toolbar-board-row {
  display: block;
  min-height: 38px;
}

.toolbar-board-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
  padding: 5px 12px;
}

.day-toolbar .toolbar-board-content {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  justify-content: stretch;
  gap: 8px 12px;
}

.toolbar-testers {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  flex: 0 0 auto;
}

.monthly-toolbar-controls,
.day-toolbar-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  justify-content: flex-end;
  flex: 1 1 auto;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
}

.day-toolbar-controls {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-content: center;
  overflow: visible;
}

.toolbar-group {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
}

.toolbar-date-group,
.toolbar-zoom-group,
.toolbar-utility-group {
  flex: 0 0 auto;
}

.toolbar-filter-group {
  flex: 1 1 390px;
  justify-content: flex-end;
}

.toolbar-search-group {
  flex: 0 1 200px;
}

.toolbar-search-group .board-search-input {
  width: 100%;
  min-width: 116px;
}

.toolbar-input,
.toolbar-select {
  height: 32px;
  border: 1px solid #cbd4df;
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 12px;
  color: #263849;
  background: #fff;
}

.toolbar-auto-mode {
  min-width: 126px;
}

.toolbar-month { width: 82px; }
.toolbar-date { width: 116px; }
.toolbar-dow { width: 120px; }
.board-search-input { width: 132px; }

.toolbar-calendar-control {
  position: relative;
  display: inline-grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
}

.toolbar-calendar-control .toolbar-input {
  min-width: 0;
  width: 100%;
}

.toolbar-calendar-picker-btn {
  width: 32px;
  min-width: 32px;
  height: 32px;
  padding: 0;
}

.toolbar-native-picker {
  position: absolute;
  right: 38px;
  bottom: 0;
  width: 1px;
  min-width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.board-search-count {
  min-width: 62px;
  font-size: 12px;
  color: #5f6f82;
}

.toolbar-filter-clear {
  height: 32px;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0 10px;
  background: transparent;
  color: #6a7b8f;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease, border-color 140ms ease, opacity 140ms ease;
}

.toolbar-filter-clear:hover {
  background: #eef4f9;
  color: #264055;
}

.toolbar-filter-clear.is-active {
  border-color: #c7d8e6;
  background: #f7fbff;
  color: #1f4f73;
}

.toolbar-filter-clear:disabled {
  opacity: 0.45;
  cursor: default;
}

.toolbar-select {
  height: 32px;
  border: 1px solid #a8bfd5;
  border-radius: 6px;
  padding: 0 6px;
  background: #fff;
  color: #374151;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}

.toolbar-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  border: 1px solid #a8bfd5;
  border-radius: 999px;
  padding: 0 12px;
  background: linear-gradient(180deg, #fef9c3 0%, #fde68a 100%);
  color: #6b4f00;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
  transition: transform 140ms ease, box-shadow 140ms ease, filter 140ms ease, opacity 140ms ease;
}

.toolbar-action-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(148, 116, 8, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.94);
  filter: saturate(1.04);
}

.toolbar-action-btn:disabled {
  opacity: 0.55;
  cursor: default;
  transform: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.segmented {
  display: inline-flex;
  align-items: center;
  border: 1px solid #cbd4df;
  border-radius: 6px;
  overflow: hidden;
  background: #fff;
}

.segmented button {
  height: 32px;
  min-width: 34px;
  padding: 0 10px;
  border-radius: 0;
  border-right: 1px solid #cbd4df;
  background: #fff;
  color: #425466;
  font-size: 12px;
  font-weight: 600;
}

.segmented button:last-child {
  border-right: none;
}

.segmented button:hover {
  filter: none;
  background: #eef3f8;
}

.segmented button.active {
  background: #16324a;
  color: #fff;
}

@media (max-width: 1280px) {
  .day-toolbar .toolbar-board-content {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 6px;
    padding: 6px 10px;
  }

  .day-toolbar .toolbar-testers {
    width: 100%;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }

  .day-toolbar .toolbar-testers::-webkit-scrollbar {
    display: none;
  }

  .day-toolbar .day-toolbar-controls {
    width: 100%;
    justify-content: flex-start;
    gap: 6px;
  }

  .day-toolbar .toolbar-filter-group {
    flex: 1 1 420px;
    justify-content: flex-start;
  }

  .day-toolbar .toolbar-search-group {
    flex: 1 1 180px;
  }
}

.toolbar-divider {
  width: 1px;
  height: 20px;
  background: #ddd;
  display: inline-block;
  margin: 0 4px;
}

.toolbar-icon-btn {
  flex: 0 0 auto;
}

.toolbar-shortcut {
  min-width: 28px;
  height: 28px;
  padding: 0 8px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #eef2f6;
  border: 1px solid #cfd8e2;
  color: #425466;
}

.toolbar-shortcut:hover {
  background: #e3e9f0;
}

.board-info-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 28px;
  padding: 4px 8px;
  background: #f5f6f7;
  border: 1px solid var(--line-soft);
  border-bottom: none;
  font-size: 12px;
  line-height: 1;
}

.board-info-left,
.board-info-right {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 28px;
}

.maintenance-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding-left: 8px;
  margin-left: 2px;
  border-left: 1px solid #d8dee7;
  color: #6a5a20;
}

.maintenance-inline-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #7b6a28;
}

.maintenance-inline-pill {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  color: #5b4b14;
  background: #fff3c7;
  border: 1px solid #dfc36c;
}

.timezone-clarity-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid #bfd0e3;
  background: linear-gradient(180deg, #f7fbff 0%, #ebf3fc 100%);
  color: #41596f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.timezone-clarity-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6b7f95;
}

.timezone-clarity-value {
  font-size: 11px;
  font-weight: 800;
  color: #183d64;
  white-space: nowrap;
}

.info-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: #4d5c70;
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  display: inline-block;
}

.scheduled-dot { background: var(--pattern); }
.conflict-dot { background: var(--conflict); }
.charter-dot { background: var(--single); }

.header-tool-btn {
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 6px;
  background: #eef1f4;
  color: #425466;
  border: 1px solid #cdd5df;
  font-size: 14px;
  line-height: 1;
}

.header-scale-with-tools {
  position: relative;
}

.header-tools {
  position: absolute;
  top: 5px;
  right: 38px;
  display: flex;
  gap: 6px;
  z-index: 10;
}

.timeline-wrap {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.board-shell > .board-info-row + .timeline-wrap {
  margin-top: 0;
}

.monthly-board-shell .timeline-wrap {
  max-height: none;
}



.board-shell {
  display: grid;
  gap: 0;
  width: 100%;
}

.board-shell:fullscreen {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 8px;
  width: 100vw;
  height: 100vh;
  padding: 10px;
  overflow: hidden;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.8) 0%, rgba(255, 255, 255, 0) 38%),
    linear-gradient(180deg, #edf4fc 0%, #e4edf8 100%);
  --stand-col-width: clamp(102px, 8.8vw, 152px);
  --board-row-height: clamp(44px, calc((100vh - 168px) / var(--board-row-count, 12)), 84px);
  --board-local-day-height: clamp(28px, calc(var(--board-row-height) - 20px), 34px);
  --board-header-height: clamp(34px, calc(var(--board-row-height) - 12px), 44px);
  --board-utc-band-height: clamp(22px, calc(var(--board-row-height) - 20px), 30px);
  --board-utc-height: clamp(60px, calc(var(--board-header-height) + var(--board-utc-band-height) + 2px), 80px);
  --board-block-height: clamp(28px, calc(var(--board-row-height) - 16px), 44px);
  --board-overlap-lane-height: clamp(20px, calc(var(--board-row-height) * 0.38), 22px);
  --board-overlap-lane-gap: clamp(3px, calc(var(--board-row-height) * 0.06), 4px);
  --board-overlap-guard-px: clamp(10px, calc(var(--pxph) * 0.1), 16px);
  --board-overlap-band-fill: 0.64;
  --board-overlap-min-visible-gap: 2px;
  --board-overlap-min-lane-height: 19px;
  --board-overlap-crowded-lane-height: clamp(16px, calc(var(--board-row-height) * 0.28), 18px);
  --board-overlap-crowded-lane-gap: clamp(2px, calc(var(--board-row-height) * 0.04), 3px);
  --board-overlap-crowded-band-fill: 0.54;
  --board-overlap-crowded-min-visible-gap: 2px;
  --board-overlap-crowded-min-lane-height: 15px;
  --board-overlap-separator-width: 1px;
  --board-overlap-center-bias: 0px;
  --board-stand-font-size: 12px;
  --board-hour-label-size: 14px;
  --board-end-label-size: 14px;
  --board-hour-label-offset: clamp(5px, calc((var(--board-header-height) - var(--board-hour-label-size) - 8px) / 2), 11px);
  --board-date-font-size: 12px;
  --board-block-font-size: 14px;
  --board-utc-day-font-size: 12px;
  --board-utc-sticky-font-size: 11px;
}

.board-shell.board-fullscreen-smart:fullscreen .board-info-row {
  min-height: 34px;
  padding: 5px 10px;
  font-size: 12px;
  border-radius: 10px 10px 0 0;
  background: linear-gradient(180deg, rgba(250, 252, 255, 0.96) 0%, rgba(239, 245, 252, 0.98) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.board-shell.board-fullscreen-smart:fullscreen .board-info-left,
.board-shell.board-fullscreen-smart:fullscreen .board-info-right {
  min-height: 24px;
  gap: 6px;
}

.board-shell.board-fullscreen-smart:fullscreen .board-info-right {
  opacity: 0.84;
  font-size: 11px;
}

.board-shell.board-fullscreen-smart:fullscreen .maintenance-inline {
  gap: 4px;
  padding-left: 6px;
}

.board-shell.board-fullscreen-smart:fullscreen .maintenance-inline-pill {
  min-height: 18px;
  padding: 0 6px;
  font-size: 10px;
}

.board-shell:fullscreen .timeline-wrap {
  max-height: none;
  height: 100%;
  min-height: 0;
  border-radius: 10px;
  box-shadow:
    0 8px 24px rgba(36, 63, 97, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.68);
  --pxph: clamp(78px, calc((100vw - var(--stand-col-width) - 34px) / 24), 132px);
  --timeline-width: calc(var(--pxph) * 24);
}

.board-shell.board-fullscreen-smart:fullscreen .timeline-wrap {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.board-shell.board-fullscreen-smart:fullscreen .local-day-band {
  background: rgba(255, 255, 255, 0.98);
}

.board-shell.board-fullscreen-smart:fullscreen .board-date-label {
  letter-spacing: 0.12em;
}

.board-shell.board-wallboard-mode:fullscreen {
  position: relative;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 6px;
  padding: 8px;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.58) 0%, rgba(255, 255, 255, 0) 34%),
    linear-gradient(180deg, #e8f1fc 0%, #dfeaf8 100%);
}

.board-shell.board-wallboard-mode:fullscreen .board-info-row {
  min-height: 30px;
  padding: 4px 10px;
  border: 1px solid rgba(171, 187, 206, 0.86);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(249, 252, 255, 0.95) 0%, rgba(238, 245, 253, 0.92) 100%);
  box-shadow:
    0 3px 10px rgba(64, 90, 123, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.board-shell.board-wallboard-mode:fullscreen .board-info-left,
.board-shell.board-wallboard-mode:fullscreen .board-info-right {
  min-height: 20px;
  gap: 6px;
}

.board-shell.board-wallboard-mode:fullscreen .board-info-right {
  opacity: 0.72;
}

.board-shell.board-wallboard-mode:fullscreen .info-pill {
  font-size: 10px;
  gap: 4px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.board-shell.board-wallboard-mode:fullscreen .maintenance-inline {
  gap: 4px;
  padding-left: 6px;
}

.board-shell.board-wallboard-mode:fullscreen .maintenance-inline-label,
.board-shell.board-wallboard-mode:fullscreen .maintenance-inline-pill {
  font-size: 10px;
}

.board-shell.board-wallboard-mode:fullscreen .timezone-clarity-pill {
  min-height: 18px;
  padding: 0 6px;
}

.board-shell.board-wallboard-mode:fullscreen .timezone-clarity-label,
.board-shell.board-wallboard-mode:fullscreen .timezone-clarity-value {
  font-size: 10px;
}

.board-shell.board-wallboard-mode:fullscreen .timeline-wrap {
  border-radius: 12px;
  border: 1px solid rgba(171, 187, 206, 0.9);
  box-shadow:
    0 10px 28px rgba(36, 63, 97, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.board-shell.board-wallboard-mode:fullscreen .header-tools {
  top: 7px;
  right: 10px;
  gap: 4px;
}

.board-shell.board-wallboard-mode:fullscreen .header-tool-btn {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  background: rgba(243, 247, 252, 0.94);
  border-color: rgba(179, 191, 208, 0.9);
}

.board-shell.board-wallboard-mode:fullscreen .stand-col {
  font-weight: 700;
  letter-spacing: 0.02em;
}

.board-shell.board-wallboard-mode:fullscreen .hour-cell {
  box-shadow: inset 0 -1px 0 rgba(122, 146, 176, 0.18);
}

.board-shell.board-wallboard-mode:fullscreen .utc-day-band {
  background: rgba(248, 251, 255, 0.96);
}

.board-shell.board-wallboard-mode:fullscreen .day-action-bar,
.board-shell.board-wallboard-mode:fullscreen .monthly-action-bar {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 48;
  margin: 0;
  max-width: min(760px, calc(100vw - 40px));
  padding: 8px 10px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255, 251, 240, 0.96) 0%, rgba(255, 243, 216, 0.94) 100%);
  box-shadow:
    0 8px 20px rgba(90, 70, 27, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.board-shell.board-wallboard-mode:fullscreen .action-group {
  flex-wrap: nowrap;
  gap: 5px;
}

.board-shell.board-wallboard-mode:fullscreen .action-bar-flight {
  max-width: min(220px, 28vw);
}

.monthly-board-shell > .devtools-panel,
.board-shell > .devtools-panel {
  margin-bottom: 0;
}

.board-shell > .board-info-row {
  margin-bottom: 0;
}

.board-shell > .timeline-wrap + .day-action-bar,
.monthly-board-shell > .timeline-wrap + .monthly-action-bar {
  margin-top: 12px;
}

.day-action-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 7px 10px;
  background: linear-gradient(180deg, #fffaf0 0%, #fff3d8 100%);
  border: 1px solid #dec385;
  border-radius: 8px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 3px rgba(97, 73, 23, 0.08);
  font-size: 12px;
}

.day-action-bar[hidden] {
  display: none !important;
}

.monthly-action-bar {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 180ms ease, transform 180ms ease;
}

.monthly-action-bar.action-bar-visible {
  opacity: 1;
  transform: translateY(0);
}

.monthly-action-bar[hidden] {
  display: none !important;
}

/* Compact buttons inside both action bars */
.day-action-bar button,
.day-action-bar .secondary-btn {
  font-size: 12px;
  padding: 4px 11px;
  height: 28px;
  border-radius: 7px;
  line-height: 1;
}

.action-bar-selection {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}

.action-bar-caption {
  color: #8b6a28;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.action-bar-flight {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: min(360px, 56vw);
  min-height: 28px;
  padding: 0 12px;
  border: 1px solid rgba(224, 202, 140, 0.94);
  border-radius: 999px;
  background: linear-gradient(180deg, #fffdf6 0%, #fff7e6 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 1px 2px rgba(117, 89, 33, 0.08);
  color: #24405f;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.action-group {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
  margin-left: auto;
}

.action-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.secondary-btn.action-link-btn,
.secondary-btn.action-link-btn:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 28px;
  line-height: 1;
  background: linear-gradient(180deg, #f7fbff 0%, #e8f0fa 100%);
  color: #16324a;
  border: 1px solid #afbccd;
  border-radius: 7px;
  padding: 0 11px;
  font-size: 12px;
  font-weight: 700;
  box-sizing: border-box;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.day-action-bar .secondary-btn:hover,
.day-action-bar .secondary-btn:focus-visible,
.day-action-bar button:hover,
.day-action-bar button:focus-visible {
  background: linear-gradient(180deg, #ffffff 0%, #edf4fd 100%);
  border-color: #8da6c3;
}

#toggle-cancel-btn,
#toggle-monthly-conflict-btn {
  background: linear-gradient(180deg, #eef5ff 0%, #dbe8fb 100%);
  border-color: #91aac9;
  color: #11375b;
}

#toggle-cancel-btn:hover,
#toggle-cancel-btn:focus-visible,
#toggle-monthly-conflict-btn:hover,
#toggle-monthly-conflict-btn:focus-visible {
  background: linear-gradient(180deg, #f7fbff 0%, #e5efff 100%);
  border-color: #7897bc;
}

.action-group .danger-action {
  margin-left: 8px;
  padding-left: 14px;
  border-left: 1px solid #d8b8b8;
  background: #b42318;
  color: #fff;
}

.action-group .danger-action:hover {
  background: #c93426;
}

@media (max-width: 900px) {
  .day-action-bar {
    align-items: stretch;
  }

  .action-group {
    width: 100%;
    margin-left: 0;
  }

  .action-bar-flight {
    max-width: 100%;
  }
}

.block-selected {
  box-shadow:
    0 0 0 3px rgba(255, 212, 112, 0.98),
    0 0 0 6px rgba(33, 66, 112, 0.22),
    0 0 18px rgba(33, 66, 112, 0.24);
  z-index: 18 !important;
}

.block.cancelled.block-selected {
  opacity: 0.92;
  filter: saturate(1.18) brightness(1.04);
  box-shadow:
    0 0 0 3px rgba(255, 212, 112, 1),
    0 0 0 6px rgba(181, 83, 28, 0.34),
    0 0 22px rgba(181, 83, 28, 0.30);
}

.block.cancelled.block-selected .block-title {
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(48, 33, 18, 0.38);
}

.block-search-hit {
  box-shadow:
    0 0 0 3px rgba(18, 120, 68, 0.98),
    0 0 0 6px rgba(255, 245, 198, 0.98),
    0 0 24px rgba(18, 120, 68, 0.36);
  z-index: 12 !important;
}

.block-search-primary {
  transform: translateY(-50%) scale(1.08);
  box-shadow:
    0 0 0 4px rgba(18, 120, 68, 1),
    0 0 0 8px rgba(255, 247, 214, 1),
    0 0 32px rgba(18, 120, 68, 0.48);
  z-index: 14 !important;
}

.block-search-primary .block-title {
  font-weight: 800;
  letter-spacing: 0.02em;
}

.stand-row-search-hit .stand-col,
.stand-row-search-hit .row-track {
  box-shadow:
    inset 4px 0 0 rgba(18, 120, 68, 0.9),
    inset 0 0 0 9999px var(--lane-search-overlay);
}

.board-shell.board-search-active .block:not(.block-search-hit) {
  opacity: 0.32;
  filter: saturate(0.65) brightness(0.94);
}

.board-shell.board-search-active .stand-row:not(.stand-row-search-hit) .stand-col,
.board-shell.board-search-active .stand-row:not(.stand-row-search-hit) .row-track {
  opacity: 0.72;
}

.timeline-header,
.timeline-row {
  display: grid;
  grid-template-columns: var(--stand-col-width) var(--timeline-width);
}

.timeline-header {
  position: sticky;
  top: var(--board-local-day-height);
  z-index: 8;
  align-items: stretch;
}

.row-selected .stand-col {
  box-shadow:
    inset 5px 0 0 var(--lane-selected-row-edge, var(--lane-selected-edge)),
    inset 0 0 0 9999px var(--lane-selected-row-overlay, transparent),
    inset 0 3px 0 var(--lane-selected-row-rule, rgba(56, 103, 166, 0.18)),
    inset 0 -3px 0 var(--lane-selected-row-rule, rgba(56, 103, 166, 0.18)),
    inset 0 0 0 1px var(--lane-selected-row-outline, rgba(56, 103, 166, 0.10));
}

.row-selected .row-track {
  box-shadow:
    inset 0 3px 0 var(--lane-selected-row-rule, rgba(56, 103, 166, 0.18)),
    inset 0 -3px 0 var(--lane-selected-row-rule, rgba(56, 103, 166, 0.18));
}

.stand-row.remote-row.row-selected .stand-col,
.stand-row.remote-row.row-selected .row-track {
  box-shadow:
    inset 5px 0 0 var(--lane-selected-row-edge, var(--lane-selected-edge-remote)),
    inset 0 0 0 9999px var(--lane-selected-row-overlay, var(--lane-selected-overlay-remote)),
    inset 0 3px 0 var(--lane-selected-row-rule, var(--lane-selected-rule-remote)),
    inset 0 -3px 0 var(--lane-selected-row-rule, var(--lane-selected-rule-remote)),
    inset 0 0 0 1px var(--lane-selected-row-outline, rgba(188, 123, 8, 0.14));
}

.row-selected .stand-col {
  background: var(--lane-selected-row-stand-fill, var(--lane-stand-bg, var(--lane-stand-even)));
  color: var(--lane-selected-row-label, #274b78);
  font-weight: 700;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.38);
}

.stand-col {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--row-divider);
  padding: 0 8px 0 4px;
  white-space: nowrap;
  background: var(--lane-stand-even);
  position: sticky;
  left: 0;
  z-index: 30;
  font-weight: 600;
  min-height: var(--board-row-height);
  height: var(--board-row-height);
  font-size: var(--board-stand-font-size);
  line-height: var(--board-row-height);
}

.timeline-row .stand-col {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  vertical-align: middle;
}

.timeline-header .stand-col,
.timeline-header .time-col {
  min-height: var(--board-header-height);
  height: var(--board-header-height);
  line-height: var(--board-header-height);
}

.timeline-header .stand-col,
.utc-row .stand-col {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-top: 0;
  padding-bottom: 0;
}

.stand-row.lane-even {
  --lane-stand-bg: var(--lane-stand-even);
  --lane-track-a: var(--lane-track-even-a);
  --lane-track-b: var(--lane-track-even-b);
  --lane-overlap-gap-color: rgba(244, 249, 255, 0.98);
  --lane-selected-row-edge: var(--lane-selected-edge);
  --lane-selected-row-overlay: var(--lane-selected-overlay-even);
  --lane-selected-row-rule: var(--lane-selected-rule-even);
  --lane-selected-row-outline: var(--lane-selected-outline-even);
  --lane-selected-row-stand-fill: var(--lane-selected-stand-fill-even);
  --lane-selected-row-label: var(--lane-selected-label-even);
}

.stand-row.lane-odd {
  --lane-stand-bg: var(--lane-stand-odd);
  --lane-track-a: var(--lane-track-odd-a);
  --lane-track-b: var(--lane-track-odd-b);
  --lane-overlap-gap-color: rgba(226, 236, 247, 0.98);
  --lane-selected-row-edge: var(--lane-selected-edge);
  --lane-selected-row-overlay: var(--lane-selected-overlay-odd);
  --lane-selected-row-rule: var(--lane-selected-rule-odd);
  --lane-selected-row-outline: var(--lane-selected-outline-odd);
  --lane-selected-row-stand-fill: var(--lane-selected-stand-fill-odd);
  --lane-selected-row-label: var(--lane-selected-label-odd);
}

.stand-row.remote-row.lane-even {
  --lane-stand-bg: var(--lane-remote-stand-even);
  --lane-track-a: var(--lane-remote-track-even-a);
  --lane-track-b: var(--lane-remote-track-even-b);
  --lane-overlap-gap-color: rgba(249, 242, 231, 0.98);
  --lane-selected-row-edge: var(--lane-selected-edge-remote);
  --lane-selected-row-overlay: var(--lane-selected-overlay-remote);
  --lane-selected-row-rule: var(--lane-selected-rule-remote);
  --lane-selected-row-outline: rgba(188, 123, 8, 0.14);
  --lane-selected-row-stand-fill: var(--lane-selected-stand-fill-remote);
  --lane-selected-row-label: var(--lane-selected-label-remote);
}

.stand-row.remote-row.lane-odd {
  --lane-stand-bg: var(--lane-remote-stand-odd);
  --lane-track-a: var(--lane-remote-track-odd-a);
  --lane-track-b: var(--lane-remote-track-odd-b);
  --lane-overlap-gap-color: rgba(239, 230, 214, 0.98);
  --lane-selected-row-edge: var(--lane-selected-edge-remote);
  --lane-selected-row-overlay: var(--lane-selected-overlay-remote);
  --lane-selected-row-rule: var(--lane-selected-rule-remote);
  --lane-selected-row-outline: rgba(188, 123, 8, 0.14);
  --lane-selected-row-stand-fill: var(--lane-selected-stand-fill-remote);
  --lane-selected-row-label: var(--lane-selected-label-remote);
}

.stand-row .stand-col {
  background: var(--lane-stand-bg, var(--lane-stand-even));
}

.stand-row.stand-row-empty .stand-col {
  color: rgba(19, 50, 77, 0.72);
}

.stand-row.remote-row.row-selected .stand-col {
  color: #5d3a05;
  font-weight: 700;
}

.stand-row:hover .stand-col,
.stand-row:hover .row-track {
  box-shadow:
    inset 3px 0 0 rgba(76, 110, 150, 0.58),
    inset 0 0 0 9999px var(--lane-hover-overlay);
}

.header-cell {
  background: #b8cde1;
  font-weight: 700;
  z-index: 34;
}

.time-col {
  position: relative;
  border-bottom: 1px solid var(--row-divider);
  min-height: var(--board-row-height);
  height: var(--board-row-height);
  width: var(--timeline-width);
  min-width: var(--timeline-width);
}

.utc-scale {
  min-height: var(--board-utc-height);
  height: var(--board-utc-height);
}

.local-day-row {
  position: sticky;
  top: 0;
  z-index: 10;
}

.local-day-row .time-col,
.local-day-row .stand-col {
  min-height: var(--board-local-day-height);
  height: var(--board-local-day-height);
  border-bottom: 1px solid var(--line);
}

.local-day-spacer {
  background: #eef3f9;
}

.local-day-scale {
  background: #f7fafc;
}

.local-day-band {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  background: rgba(255, 255, 255, 0.94);
}

.board-date-label {
  color: #5b6f84;
  font-size: var(--board-date-font-size);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.utc-row {
  position: sticky;
  bottom: 0;
  z-index: 32;
}

.utc-row .time-col,
.utc-row .stand-col {
  min-height: var(--board-utc-height);
  height: var(--board-utc-height);
  border-top: 1px solid var(--row-divider);
}

.utc-stand {
  background: #eef3f9;
  text-transform: uppercase;
}

.utc-day-band {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--board-utc-band-height);
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.9);
  overflow: hidden;
}

.utc-day-sticky-label {
  position: absolute;
  top: 2px;
  left: 8px;
  display: inline-flex;
  align-items: center;
  height: 19px;
  max-width: clamp(140px, 34vw, 320px);
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(132, 150, 171, 0.9);
  background: rgba(249, 251, 254, 0.96);
  box-shadow: 0 1px 4px rgba(77, 99, 125, 0.16);
  color: #52657a;
  font-size: var(--board-utc-sticky-font-size);
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
  z-index: 4;
}

.utc-day-sticky-label[hidden] {
  display: none;
}

.utc-day-segment {
  position: absolute;
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--board-utc-day-font-size);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #6a7d92;
  border-right: 1px solid var(--line);
  text-transform: uppercase;
}

.utc-day-segment:last-child {
  border-right: none;
}

.utc-day-segment-sticky-source {
  color: transparent;
}

.utc-split-marker {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 0;
  pointer-events: none;
  z-index: 5;
}

.utc-split-marker::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 11px;
  height: 4px;
  transform: translateX(-50%);
  border-radius: 0 0 999px 999px;
  background: rgba(60, 84, 115, 0.78);
  box-shadow: 0 1px 2px rgba(48, 70, 99, 0.16);
}

.utc-split-marker-note {
  position: absolute;
  top: 3px;
  left: 8px;
  display: inline-flex;
  align-items: center;
  height: calc(var(--board-utc-band-height) - 8px);
  min-height: 14px;
  padding: 0 6px;
  border-radius: 4px;
  border: 1px solid rgba(150, 164, 183, 0.82);
  background: rgba(249, 251, 254, 0.98);
  box-shadow:
    0 1px 2px rgba(76, 98, 125, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.86);
  color: #56697d;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1;
  white-space: nowrap;
}

.board-shell.board-wallboard-mode:fullscreen .utc-split-marker::before {
  width: 13px;
  height: 5px;
}

.board-shell.board-wallboard-mode:fullscreen .utc-split-marker-note {
  top: 3px;
  left: 10px;
  height: calc(var(--board-utc-band-height) - 10px);
  min-height: 15px;
  padding: 0 7px;
  font-size: 10px;
}

.time-scale {
  position: relative;
  min-height: var(--board-header-height);
  height: var(--board-header-height);
  display: grid;
  align-items: stretch;
  grid-template-columns: repeat(24, var(--pxph));
  overflow: visible;
}

.hour-cell {
  border-left: 1px solid var(--line);
  height: var(--board-header-height);
  display: flex;
  align-items: flex-start;
  padding: var(--board-hour-label-offset) 4px 0;
  background: #dce7f4;
}

.hour-cell:nth-child(odd) { background: #d3e0ef; }

.hour-label {
  display: block;
  font-size: var(--board-hour-label-size);
  font-weight: 700;
  line-height: 1;
  color: #13324d;
}

.end-label {
  position: absolute;
  right: 0;
  top: var(--board-hour-label-offset);
  display: block;
  min-width: 58px;
  padding-right: 6px;
  text-align: right;
  font-size: var(--board-end-label-size);
  font-weight: 700;
  color: #13324d;
  letter-spacing: 0.01em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  z-index: 3;
  pointer-events: none;
}

.timeline-header .end-label {
  color: transparent !important;
}

.timeline-header .end-label::after {
  content: "00:00";
  position: absolute;
  right: 6px;
  top: 0;
  color: #13324d;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.row-track {
  overflow: hidden;
  background-image:
    repeating-linear-gradient(to right, transparent, transparent calc(var(--pxph) - 1px), var(--line) calc(var(--pxph) - 1px), var(--line) var(--pxph)),
    repeating-linear-gradient(to right, transparent, transparent calc((var(--pxph) / 6) - 1px), var(--line-soft) calc((var(--pxph) / 6) - 1px), var(--line-soft) calc(var(--pxph) / 6)),
    linear-gradient(90deg, var(--lane-track-a, var(--lane-track-even-a)) 0, var(--lane-track-b, var(--lane-track-even-b)) 100%);
}

.timeline-wrap.has-utc-day-split .time-scale::before,
.timeline-wrap.has-utc-day-split .row-track::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--utc-split-left);
  width: 10px;
  transform: translateX(-5px);
  background: linear-gradient(90deg,
    rgba(72, 99, 136, 0.00) 0%,
    rgba(72, 99, 136, 0.03) 20%,
    rgba(72, 99, 136, 0.07) 36%,
    rgba(72, 99, 136, 0.11) 50%,
    rgba(72, 99, 136, 0.07) 64%,
    rgba(72, 99, 136, 0.03) 80%,
    rgba(72, 99, 136, 0.00) 100%);
  pointer-events: none;
}

.timeline-wrap.has-utc-day-split .time-scale::after,
.timeline-wrap.has-utc-day-split .row-track::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--utc-split-left);
  width: 1px;
  transform: translateX(0);
  background: rgba(52, 78, 109, 0.54);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.24),
    0 0 6px rgba(60, 88, 125, 0.06);
  pointer-events: none;
}

.timeline-wrap.has-utc-day-split .time-scale::before,
.timeline-wrap.has-utc-day-split .time-scale::after {
  z-index: 20;
}

.timeline-wrap.has-utc-day-split .row-track::before,
.timeline-wrap.has-utc-day-split .row-track::after {
  z-index: 0;
}

.block {
  position: absolute;
  top: 50%;
  height: var(--board-block-height);
  transform: translateY(-50%);
  --block-frame-color: #2b4d7e;
  border: 1px solid #2b4d7e;
  border-radius: 4px;
  background: var(--pattern);
  color: #ffffff;
  overflow: hidden;
  display: block;
  text-align: center;
  padding: 0 8px;
  transition: transform 140ms ease, opacity 140ms ease, filter 140ms ease, box-shadow 140ms ease;
}

.block-secondary-selected {
  box-shadow: 0 0 0 3px rgba(123, 185, 255, 0.85);
}

.resize-handle {
  position: absolute;
  top: 2px;
  bottom: 2px;
  width: 12px;
  background: transparent;
  cursor: ew-resize;
  z-index: 3;
  opacity: 0.92;
  transition: opacity 140ms ease;
}

.resize-handle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1px;
  height: calc(100% - 6px);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.54);
  transform: translate(-50%, -50%);
}

.block.pattern:hover .resize-handle,
.block.single:hover .resize-handle,
.block.dummy:hover .resize-handle,
.block-selected .resize-handle {
  opacity: 1;
}

.block.pattern:hover .resize-handle::after,
.block.single:hover .resize-handle::after,
.block.dummy:hover .resize-handle::after,
.block-selected .resize-handle::after {
  background: rgba(255, 255, 255, 0.78);
}

.resize-left { left: 0; }
.resize-right { right: 0; }

.block.single {
  --block-frame-color: #8a4b07;
  background: var(--single);
  border-color: #8a4b07;
}

.block.dummy {
  --block-frame-color: #415469;
  background: linear-gradient(180deg, #7f96ad 0%, #5e748d 100%);
  border-color: #415469;
}

.block.cancelled {
  opacity: 0.38;
}

.tester-block {
  --block-frame-color: #2c7a5c;
  background: #8fd3b6;
  border-color: #2c7a5c;
  z-index: 9999 !important;
}

.block.pattern.conflict {
  --block-frame-color: #7d1111;
  background:
    repeating-linear-gradient(-45deg, rgba(255, 154, 154, 0.18), rgba(255, 154, 154, 0.18) 7px, rgba(209, 69, 69, 0.88) 7px, rgba(209, 69, 69, 0.88) 14px),
    linear-gradient(180deg, #5f8fdb 0%, var(--pattern) 100%);
  border-color: #7d1111;
  color: #ffffff;
}

.block.single.conflict {
  --block-frame-color: #7d1111;
  background:
    repeating-linear-gradient(-45deg, rgba(255, 154, 154, 0.18), rgba(255, 154, 154, 0.18) 7px, rgba(209, 69, 69, 0.88) 7px, rgba(209, 69, 69, 0.88) 14px),
    linear-gradient(180deg, #f4ae63 0%, var(--single) 100%);
  border-color: #7d1111;
  color: #ffffff;
}

.block.dummy.conflict {
  --block-frame-color: #7d1111;
  background:
    repeating-linear-gradient(-45deg, rgba(255, 154, 154, 0.18), rgba(255, 154, 154, 0.18) 7px, rgba(209, 69, 69, 0.88) 7px, rgba(209, 69, 69, 0.88) 14px),
    linear-gradient(180deg, #7f96ad 0%, #5e748d 100%);
  border-color: #7d1111;
  color: #ffffff;
}
.block.weekday-override {
  border-style: dashed;
}

.block.exception {
  --block-frame-color: #d7922d;
  border-color: #d7922d;
  box-shadow: inset 0 0 0 1px rgba(215, 146, 45, 0.22);
}

.block-badge {
  position: absolute;
  top: 1px;
  left: 3px;
  padding: 0 3px;
  border-radius: 3px;
  background: rgba(215, 146, 45, 0.92);
  color: #fff;
  font-size: 8px;
  line-height: 11px;
  font-weight: 700;
  pointer-events: none;
}

.block.has-arrival-marker .block-badge {
  left: 17px;
}


.block.block-lane {
  height: var(--block-overlap-effective-height, var(--board-overlap-lane-height)) !important;
  transform: none !important;
  border-radius: 5px;
  border: var(--board-overlap-separator-width) solid var(--lane-overlap-gap-color, transparent);
  background-clip: padding-box;
  padding: 0 10px;
}
.block.block-lane::before {
  content: "";
  position: absolute;
  inset: var(--board-overlap-separator-width);
  border: 1px solid var(--block-frame-color, #2b4d7e);
  border-radius: max(3px, calc(5px - var(--board-overlap-separator-width)));
  pointer-events: none;
  z-index: 1;
}
.block.block-lane .block-title {
  position: relative;
  z-index: 2;
}
.block.block-lane .block-direction-arrow,
.block.block-lane .block-badge {
  z-index: 2;
}
.block.block-lane .block-title {
  font-size: max(11px, calc(var(--block-overlap-effective-height, var(--board-overlap-lane-height)) - 6px));
  line-height: var(--block-overlap-effective-height, var(--board-overlap-lane-height));
}
.block.block-lane .block-direction-arrow {
  font-size: max(9px, calc(var(--block-overlap-effective-height, var(--board-overlap-lane-height)) - 7px));
  line-height: 1;
}
.block.block-lane .block-direction-arrow.arrival {
  top: 50%;
  left: 5px;
  transform: translateY(-50%);
}
.block.block-lane .block-direction-arrow.departure {
  top: 50%;
  right: 5px;
  transform: translateY(-50%);
}
.block.block-lane.has-arrival-marker .block-title { padding-left: 16px; }
.block.block-lane.has-departure-marker .block-title { padding-right: 16px; }
.block.block-lane.label-left .block-title {
  text-align: left;
  padding-left: 9px;
  padding-right: 16px;
}
.block.block-lane.label-right .block-title {
  text-align: right;
  padding-left: 16px;
  padding-right: 9px;
}
.block.block-lane.label-left.has-arrival-marker .block-title { padding-left: 18px; }
.block.block-lane.label-right.has-departure-marker .block-title { padding-right: 18px; }

.block.block-lane.block-lane-crowded {
  border-radius: 4px;
  padding: 0 7px;
}

.block.block-lane.block-lane-crowded::before {
  border-radius: max(2px, calc(4px - var(--board-overlap-separator-width)));
}

.block.block-lane.block-lane-crowded .block-title {
  font-size: max(10px, calc(var(--block-overlap-effective-height, var(--board-overlap-lane-height)) - 5px));
  font-weight: 800;
  letter-spacing: 0.01em;
}

.block.block-lane.block-lane-crowded .block-direction-arrow.arrival {
  left: 4px;
}

.block.block-lane.block-lane-crowded .block-direction-arrow.departure {
  right: 4px;
}

.block.block-lane.block-lane-crowded.has-arrival-marker .block-title { padding-left: 14px; }
.block.block-lane.block-lane-crowded.has-departure-marker .block-title { padding-right: 14px; }

.block.block-lane.block-lane-crowded.block-lane-align-left .block-title {
  text-align: left;
  padding-left: 7px;
  padding-right: 13px;
}

.block.block-lane.block-lane-crowded.block-lane-align-center .block-title {
  text-align: center;
  padding-left: 13px;
  padding-right: 13px;
}

.block.block-lane.block-lane-crowded.block-lane-align-right .block-title {
  text-align: right;
  padding-left: 13px;
  padding-right: 7px;
}

.block.block-lane.block-lane-crowded.has-arrival-marker.block-lane-align-left .block-title,
.block.block-lane.block-lane-crowded.has-arrival-marker.block-lane-align-center .block-title {
  padding-left: 15px;
}

.block.block-lane.block-lane-crowded.has-departure-marker.block-lane-align-right .block-title,
.block.block-lane.block-lane-crowded.has-departure-marker.block-lane-align-center .block-title {
  padding-right: 15px;
}

.block-title {
  font-size: var(--board-block-font-size);
  font-weight: 700;
  line-height: var(--board-block-height);
  width: 100%;
  text-align: center;
  pointer-events: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.block-direction-arrow {
  position: absolute;
  top: 1px;
  color: rgba(255, 255, 255, 0.96);
  font-size: max(10px, calc(var(--board-block-font-size) - 2px));
  font-weight: 800;
  line-height: 1;
  text-shadow: 0 1px 1px rgba(23, 36, 58, 0.35);
  pointer-events: none;
  z-index: 4;
}

.block-direction-arrow.arrival {
  left: 4px;
}

.block-direction-arrow.departure {
  right: 4px;
}

.block.resizable-block .block-direction-arrow.arrival {
  left: 10px;
}

.block.resizable-block .block-direction-arrow.departure {
  right: 10px;
}

.block.has-arrival-marker .block-title {
  padding-left: 18px;
}

.block.has-departure-marker .block-title {
  padding-right: 18px;
}

.block.resizable-block.has-arrival-marker .block-title {
  padding-left: 24px;
}

.block.resizable-block.has-departure-marker .block-title {
  padding-right: 24px;
}

.block.label-left .block-title {
  text-align: left;
  padding-left: 8px;
  padding-right: 20px;
}

.block.label-right .block-title {
  text-align: right;
  padding-left: 18px;
  padding-right: 20px;
}

.block.label-left.has-arrival-marker .block-title {
  padding-left: 20px;
}

.block.label-right.has-departure-marker .block-title {
  padding-right: 20px;
}

.block.resizable-block.label-left.has-arrival-marker .block-title {
  padding-left: 26px;
}

.block.resizable-block.label-right.has-departure-marker .block-title {
  padding-right: 26px;
}

.block-time {
  font-size: 11px;
  opacity: 0.95;
  white-space: nowrap;
}

/* ── Block time (runway maintenance) overlay ───────────────────────────── */
.blocktime-band {
  position: absolute;
  top: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 3;
  background:
    repeating-linear-gradient(
      -45deg,
      rgba(185, 28, 28, 0.18) 0px,
      rgba(185, 28, 28, 0.18) 5px,
      rgba(254, 226, 226, 0.08) 5px,
      rgba(254, 226, 226, 0.08) 11px
    ),
    linear-gradient(180deg, rgba(185, 28, 28, 0.08) 0%, rgba(185, 28, 28, 0.16) 100%);
  border-left: 2px solid rgba(153, 27, 27, 0.78);
  border-right: 2px solid rgba(153, 27, 27, 0.78);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.blocktime-header-band {
  position: absolute;
  top: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 10;
  background: linear-gradient(180deg, rgba(254, 242, 242, 0.92) 0%, rgba(254, 226, 226, 0.98) 100%);
  border-left: 2px solid rgba(153, 27, 27, 0.78);
  border-right: 2px solid rgba(153, 27, 27, 0.78);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.32),
    0 0 0 1px rgba(153, 27, 27, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  gap: 4px;
}

.blocktime-header-label {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  padding: 2px 8px;
  border-radius: 999px;
  background: #991b1b;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 1px 2px rgba(127, 29, 29, 0.22);
  font-size: 11px;
  font-weight: 700;
  color: #fff7ed;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.blocktime-banner {
  background: #fef2f2;
  border: 1px solid #fca5a5;
  border-radius: 6px;
  color: #991b1b;
  font-size: 13px;
  font-weight: 600;
  padding: 10px 14px;
  margin: 8px 0;
}

.duplicate-banner {
  background: #fffbeb;
  border: 1px solid #fbbf24;
  border-left: 4px solid #f59e0b;
  border-radius: 6px;
  color: #92400e;
  font-size: 13px;
  padding: 10px 14px;
  margin: 8px 0;
  line-height: 1.5;
}

.form {
  display: grid;
  gap: 8px;
  max-width: 520px;
  margin: 0 auto;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
}

.form input,
.form select,
.form textarea,
.datepick input,
.datepick select {
  height: 36px;
  border: 1px solid #a8b4c7;
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 14px;
}

.form textarea {
  min-height: 88px;
  resize: vertical;
  padding-top: 10px;
}

.add-pattern-form,
.add-charter-form {
  width: min(1160px, calc(100vw - 32px));
  max-width: none;
  gap: 12px;
}

.flight-legs-grid {
  display: grid;
  grid-template-columns: minmax(0, 640px);
  justify-content: center;
  gap: 16px;
  align-items: start;
}

.charter-form-shell {
  width: min(1120px, 100%);
  margin: 0 auto;
}

.scheduled-form-shell {
  width: min(1120px, 100%);
  margin: 0 auto;
}

.flight-legs-grid-charter {
  grid-template-columns: minmax(0, 1fr) 0fr;
  gap: 0;
  width: 100%;
  align-items: stretch;
  transition:
    grid-template-columns 560ms cubic-bezier(0.65, 0, 0.35, 1),
    gap 560ms cubic-bezier(0.65, 0, 0.35, 1);
}

.charter-form-shell.has-second-leg .flight-legs-grid-charter {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 22px;
}

.flight-legs-grid-scheduled {
  grid-template-columns: minmax(0, 1fr) 0fr;
  gap: 0;
  width: 100%;
  align-items: stretch;
  transition:
    grid-template-columns 560ms cubic-bezier(0.65, 0, 0.35, 1),
    gap 560ms cubic-bezier(0.65, 0, 0.35, 1);
}

.scheduled-form-shell.has-second-leg .flight-legs-grid-scheduled {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 22px;
}

.charter-panel-slot {
  min-width: 0;
}

.scheduled-panel-slot {
  min-width: 0;
}

.charter-panel-slot-secondary {
  overflow: clip;
  max-height: 0;
  visibility: hidden;
}

.scheduled-panel-slot-secondary {
  overflow: clip;
  max-height: 0;
  visibility: hidden;
}

.charter-form-shell.has-second-leg .charter-panel-slot-secondary,
.scheduled-form-shell.has-second-leg .scheduled-panel-slot-secondary {
  max-height: none;
  visibility: visible;
}

.charter-panel-slot-secondary .flight-leg-card {
  opacity: 0;
  transform: translateX(36px) scale(0.985);
  transition:
    opacity 520ms cubic-bezier(0.65, 0, 0.35, 1),
    transform 560ms cubic-bezier(0.65, 0, 0.35, 1),
    box-shadow 560ms cubic-bezier(0.65, 0, 0.35, 1);
}

.charter-form-shell.has-second-leg .charter-panel-slot-secondary .flight-leg-card {
  opacity: 1;
  transform: translateX(0) scale(1);
}

.scheduled-panel-slot-secondary .flight-leg-card {
  opacity: 0;
  transform: translateX(36px) scale(0.985);
  transition:
    opacity 520ms cubic-bezier(0.65, 0, 0.35, 1),
    transform 560ms cubic-bezier(0.65, 0, 0.35, 1),
    box-shadow 560ms cubic-bezier(0.65, 0, 0.35, 1);
}

.scheduled-form-shell.has-second-leg .scheduled-panel-slot-secondary .flight-leg-card {
  opacity: 1;
  transform: translateX(0) scale(1);
}

.charter-panel-slot-primary .flight-leg-card {
  transition:
    transform 560ms cubic-bezier(0.65, 0, 0.35, 1),
    box-shadow 560ms cubic-bezier(0.65, 0, 0.35, 1),
    border-color 560ms cubic-bezier(0.65, 0, 0.35, 1);
}

.charter-form-shell.has-second-leg .charter-panel-slot-primary .flight-leg-card {
  transform: translateX(-2px);
}

.scheduled-panel-slot-primary .flight-leg-card {
  transition:
    transform 560ms cubic-bezier(0.65, 0, 0.35, 1),
    box-shadow 560ms cubic-bezier(0.65, 0, 0.35, 1),
    border-color 560ms cubic-bezier(0.65, 0, 0.35, 1);
}

.scheduled-form-shell.has-second-leg .scheduled-panel-slot-primary .flight-leg-card {
  transform: translateX(-2px);
}

.add-pattern-form.has-second-leg .flight-legs-grid {
  grid-template-columns: repeat(2, minmax(320px, 1fr));
}

.add-pattern-form > button[type="submit"],
.add-charter-form > button[type="submit"] {
  justify-self: center;
  min-width: 220px;
}

.flight-leg-card {
  display: grid;
  gap: 8px;
  padding: 18px 20px 20px;
  border: 1px solid #d7e1ec;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow:
    0 16px 34px rgba(42, 67, 96, 0.08),
    0 3px 10px rgba(42, 67, 96, 0.04);
}

.second-leg-card {
  border-style: solid;
  border-color: #d9e3ef;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.leg-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.leg-card-header h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: #17324a;
  letter-spacing: -0.01em;
}

.leg-toggle-btn {
  min-width: 176px;
  min-height: 34px;
  padding: 0 14px;
  font-size: 12px;
  font-weight: 700;
  border-radius: 999px;
  border: 1px solid #c9d7e7;
  background: linear-gradient(180deg, #f9fbff 0%, #edf3fb 100%);
  color: #1f4f73;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
  transition:
    background 300ms ease,
    border-color 300ms ease,
    color 300ms ease,
    box-shadow 300ms ease,
    transform 300ms ease;
}

.leg-toggle-btn:hover,
.leg-toggle-btn:focus-visible {
  border-color: #afc3da;
  background: linear-gradient(180deg, #ffffff 0%, #eff5fd 100%);
  transform: translateY(-1px);
}

.leg-toggle-btn.is-remove {
  border-color: #e4c3c0;
  background: linear-gradient(180deg, #fff9f8 0%, #fceceb 100%);
  color: #8a2d25;
}

.leg-toggle-btn.is-remove:hover,
.leg-toggle-btn.is-remove:focus-visible {
  border-color: #d9aaa5;
  background: linear-gradient(180deg, #fffdfc 0%, #fdf0ee 100%);
}

.leg-header-placeholder {
  min-width: 176px;
  min-height: 34px;
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  visibility: hidden;
  white-space: nowrap;
}

.leg-copy-btn {
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  color: #1f4f73;
}

.leg-copy-placeholder {
  min-height: 30px;
  padding: 0 12px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  visibility: hidden;
  white-space: nowrap;
}

.date-copy-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.date-copy-header label {
  margin: 0;
  flex: 1 1 auto;
}

.flight-legs-toolbar {
  width: min(640px, 100%);
  margin: 0 auto 12px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  min-height: 36px;
}

.add-second-leg-btn {
  width: fit-content;
  flex: 0 0 auto;
}

.flight-legs-toolbar-copy {
  max-width: 420px;
  color: #6b7b8d;
  font-size: 12px;
  line-height: 1.35;
  text-align: right;
}

.form-action-dock {
  position: sticky;
  bottom: 14px;
  z-index: 12;
  width: min(1120px, 100%);
  margin: 18px auto 0;
  padding: 12px 14px;
  display: flex;
  justify-content: center;
  border: 1px solid rgba(203, 214, 228, 0.92);
  border-radius: 18px;
  background: rgba(250, 252, 255, 0.92);
  box-shadow:
    0 14px 28px rgba(35, 61, 92, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(10px);
}

.form-action-dock button[type="submit"] {
  min-width: 240px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.save-action-icon {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (max-width: 860px) {
  .add-pattern-form,
  .add-charter-form {
    width: 100%;
  }

  .add-pattern-form.has-second-leg .flight-legs-grid,
  .add-charter-form.has-second-leg .flight-legs-grid {
    grid-template-columns: minmax(0, 640px);
    justify-content: center;
  }

  .flight-legs-grid-charter,
  .charter-form-shell.has-second-leg .flight-legs-grid-charter {
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
  }

  .flight-legs-grid-scheduled,
  .scheduled-form-shell.has-second-leg .flight-legs-grid-scheduled {
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
  }

  .charter-panel-slot-secondary .flight-leg-card,
  .charter-form-shell.has-second-leg .charter-panel-slot-secondary .flight-leg-card,
  .charter-form-shell.has-second-leg .charter-panel-slot-primary .flight-leg-card {
    transform: none;
  }

  .scheduled-panel-slot-secondary .flight-leg-card,
  .scheduled-form-shell.has-second-leg .scheduled-panel-slot-secondary .flight-leg-card,
  .scheduled-form-shell.has-second-leg .scheduled-panel-slot-primary .flight-leg-card {
    transform: none;
  }

  .flight-legs-toolbar {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .flight-legs-toolbar-copy {
    max-width: none;
    text-align: left;
  }

  .leg-card-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .leg-toggle-btn {
    width: 100%;
    min-width: 0;
  }

  .form-action-dock {
    bottom: 10px;
    padding: 10px 12px;
  }
}

.password-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.password-field input {
  min-width: 0;
}

.password-toggle {
  width: 36px;
  height: 36px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f4f7fb;
  color: #16324a;
  border: 1px solid #a8b4c7;
}

.password-toggle:hover {
  filter: none;
  background: #dce7f5;
}

.password-toggle-icon {
  width: 18px;
  height: 18px;
}

.password-toggle .icon-hide {
  display: none;
}

.password-toggle.is-visible .icon-show {
  display: none;
}

.password-toggle.is-visible .icon-hide {
  display: block;
}


.date-field-group {
  display: grid;
  gap: 8px;
}

.date-field-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.date-field-header label {
  margin: 0;
  flex: 1 1 auto;
}

.date-field-list {
  display: grid;
  gap: 8px;
}

.date-field-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.end-date-row {
  max-height: 0;
  margin-left: 12px;
  padding-left: 10px;
  border-left: 2px solid #c9d8ea;
  opacity: 0;
  overflow: hidden;
  transform: translateY(-4px);
  transition:
    max-height 180ms ease,
    opacity 160ms ease,
    transform 180ms ease,
    margin-top 180ms ease;
}

.end-date-row.is-open {
  max-height: 44px;
  margin-top: 2px;
  opacity: 1;
  transform: translateY(0);
}

.date-field-row input {
  flex: 1;
}

.calendar-date-control {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  flex: 1 1 auto;
  min-width: 0;
}

.calendar-date-control input[data-calendar-text] {
  min-width: 0;
  width: 100%;
}

.calendar-picker-btn {
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.calendar-picker-icon {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.form .calendar-native-picker {
  position: absolute;
  right: 36px;
  bottom: 0;
  width: 1px;
  min-width: 1px;
  height: 1px;
  padding: 0;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.date-add-btn,
.date-remove-btn {
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
}

button {
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 6px;
  padding: 8px 12px;
  font-weight: 700;
  cursor: pointer;
}

button:hover { filter: brightness(1.1); }

.secondary-btn {
  background: #e8eff7;
  color: #16324a;
  border: 1px solid #a8b4c7;
}

.devtools-panel {
  margin: 0 0 12px;
  border: 1px dashed #9fb0c4;
  border-radius: 6px;
  background: rgba(248, 251, 255, 0.78);
}


/* --- Capacity heatmap panel --- */
.open-times-panel {
  display: grid;
  gap: 6px;
  margin: 0 0 10px;
  padding: 10px 12px 6px;
  border: 1px solid #d6dde8;
  border-top: none;
  background: #fbfcfe;
}

.open-times-title {
  font-size: 12px;
  font-weight: 700;
  color: #30465d;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.heatmap-grid {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.heatmap-row {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 22px;
}

.heatmap-label {
  flex: 0 0 120px;
  text-align: right;
  white-space: nowrap;
  overflow: hidden;
}

.heatmap-label-name {
  font-size: 11px;
  font-weight: 700;
  color: #486179;
}

.heatmap-label-meta {
  margin-left: 4px;
  font-size: 10px;
  font-weight: 600;
  color: #8a9bb0;
}

.heatmap-bar {
  flex: 1;
  position: relative;
  height: 18px;
  background: #f0f3f7;
  border-radius: 3px;
  overflow: hidden;
  cursor: pointer;
}

.heatmap-seg {
  position: absolute;
  top: 0;
  height: 100%;
  transition: filter 0.15s;
}

.heatmap-seg:hover {
  filter: brightness(0.88);
  z-index: 2;
}

/* Color scale: green → yellow → orange → red */
.hm-free     { background: #34c759; }
.hm-moderate { background: #f5a623; }
.hm-busy     { background: #f57c23; }
.hm-full     { background: #e04545; }

/* Swatches for legend */
.hm-swatch {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 2px;
  vertical-align: middle;
  margin-right: 3px;
}

.heatmap-tick {
  position: absolute;
  top: 0;
  width: 1px;
  height: 100%;
  background: rgba(255,255,255,0.35);
  pointer-events: none;
}

/* Legend row */
.heatmap-legend {
  display: flex;
  gap: 14px;
  padding: 2px 0 0 128px;
}

.heatmap-legend-item {
  font-size: 10px;
  font-weight: 600;
  color: #5a6e82;
  display: inline-flex;
  align-items: center;
}

/* Hour axis */
.heatmap-hour-axis {
  position: relative;
  height: 14px;
  margin-left: 128px;
}

.heatmap-hour-label {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  font-size: 9px;
  font-weight: 600;
  color: #8a9bb0;
}

.heatmap-toggle {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 6px;
}

.heatmap-toggle::-webkit-details-marker { display: none; }

.heatmap-toggle::before {
  content: "\25B6";
  font-size: 9px;
  transition: transform 0.15s;
  color: #6b7f93;
}

details[open] > .heatmap-toggle::before {
  transform: rotate(90deg);
}

.heatmap-tooltip {
  position: absolute;
  bottom: calc(100% + 4px);
  transform: translateX(-50%);
  padding: 3px 7px;
  background: #1e2a38;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  border-radius: 4px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 10;
}

.devtools-toggle {
  cursor: pointer;
  padding: 8px 12px;
  color: #56697f;
  font-size: 13px;
  font-weight: 700;
  user-select: none;
}

.devtools-toggle::marker {
  color: #75889d;
}

.tester-panel {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0;
  padding: 10px 12px 12px;
  background: transparent;
  border-top: 1px dashed #c3cedb;
}

.tester-panel-title {
  font-weight: 700;
  color: #16324a;
}

.tester-list {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.movement-flags {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
}

.movement-flags label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
}

.cancel-range-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.cancel-range-field {
  display: grid;
  gap: 6px;
}

.cancel-days-group {
  display: grid;
  gap: 6px;
}

.cancel-days-box {
  display: grid;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid #d7dfe9;
  border-radius: 6px;
  background: #f8fbff;
}

.cancel-days-flags {
  gap: 14px 18px;
}

.utc-checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

@media (max-width: 720px) {
  .cancel-range-row {
    grid-template-columns: 1fr;
  }
}



.tester-chip {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 10px;
  border-radius: 4px;
  background: #8fd3b6;
  border: 1px solid #2c7a5c;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: grab;
  user-select: none;
  -webkit-user-drag: element;
  white-space: nowrap;
}

.detail-card {
  display: grid;
  gap: 6px;
  margin-bottom: 14px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.action-btn-secondary {
  background: #fff3d9;
  color: #6a4b00;
  border-color: #d6b36d;
}

.dow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-bottom: 8px;
}
.dow-all {
  font-weight: 700;
  color: #1e3a6e;
  padding-right: 8px;
  border-right: 1px solid var(--line);
  margin-right: 4px;
}

@media (max-width: 900px) {
  :root { --stand-col-width: 80px; }
  .container { padding: 0 8px 12px; }
  .block-title { font-size: 12px; }
  .block-time { display: none; }
  .hour-label, .end-label { font-size: 11px; }
}


.hint {
  font-size: 12px;
  color: #50627a;
  margin-top: -4px;
  margin-bottom: 4px;
}

.auto-allocate-pref {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.auto-allocate-pref label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  font-weight: 600;
  color: #26425f;
}

.auto-allocate-pref select {
  min-width: 132px;
  width: auto;
}



.alert.ok {
  background: #e5f7ea;
  border-color: #85c69a;
  color: #114f23;
}

.table-wrap {
  overflow: auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 18px;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 900px;
}

.data-table th,
.data-table td {
  border-bottom: 1px solid #d7deea;
  padding: 10px 10px;
  text-align: left;
  vertical-align: middle;
  font-size: 13px;
}

.data-table th {
  position: sticky;
  top: 0;
  background: #d8e5f5;
  z-index: 1;
}

.actions-cell {
  display: flex;
  gap: 8px;
  align-items: center;
}



.badge {
  display: inline-block;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 700;
  border: 1px solid;
}

.badge.add {
  background: #e6f7eb;
  color: #14602b;
  border-color: #8fc99d;
}

.badge.update {
  background: #e7f0ff;
  color: #1d4378;
  border-color: #92afdd;
}

.badge.delete {
  background: #ffe8e8;
  color: #7a1a1a;
  border-color: #e7a2a2;
}

.json-box {
  margin: 0;
  max-width: 340px;
  max-height: 180px;
  overflow: auto;
  white-space: pre-wrap;
  background: #f7f9fc;
  border: 1px solid #d5ddea;
  border-radius: 6px;
  padding: 6px;
  font-size: 12px;
}


.data-table tbody tr:nth-child(even) {
  background: #fbfdff;
}

.data-table tbody tr:hover {
  background: #eef5ff;
}

.actions-cell {
  display: flex;
  gap: 8px;
  align-items: center;
  white-space: nowrap;
}

/* Charter log */
.charter-log-page {
  display: grid;
  gap: 16px;
}

.charter-log-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}

.charter-log-header h2 {
  margin: 0;
  font-size: 26px;
  line-height: 1.15;
  font-weight: 800;
  color: #10253d;
  letter-spacing: 0;
}

.charter-log-subtitle {
  margin: 5px 0 0;
  font-size: 13px;
  color: #64748b;
}

.charter-log-count {
  font-size: 13px;
  color: #64748b;
  white-space: nowrap;
}

.charter-log-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(203, 214, 228, 0.9);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(35, 61, 92, 0.08);
}

.charter-log-filter-card {
  padding: 14px;
}

.charter-log-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
}

.filter-label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: #53667e;
}

.charter-log-search-label {
  flex: 1 1 360px;
  min-width: min(100%, 320px);
}

.search-input-shell {
  position: relative;
  display: block;
}

.search-input-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  width: 17px;
  height: 17px;
  transform: translateY(-50%);
  fill: none;
  stroke: #6b7f99;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}

.charter-log-search,
.charter-log-select,
.charter-log-date {
  height: 38px;
  border-radius: 8px;
  border-color: #c8d5e6;
  background-color: #fff;
  font-size: 13px;
}

.charter-log-search {
  width: 100%;
  min-width: 0;
  padding-left: 38px;
}

.charter-log-select {
  min-width: 128px;
}

.charter-log-date {
  min-width: 154px;
}

.charter-log-search:focus,
.charter-log-select:focus,
.charter-log-date:focus {
  border-color: #0b5d7a;
  box-shadow: 0 0 0 3px rgba(11, 93, 122, 0.12);
  outline: none;
}

.charter-log-filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.charter-log-apply-btn,
.charter-log-reset-btn {
  height: 38px;
  padding: 0 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 800;
  transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.charter-log-apply-btn {
  border: 1px solid #07506c;
  background: #0b5d7a;
  color: #fff;
}

.charter-log-apply-btn:hover,
.charter-log-apply-btn:focus-visible {
  background: #084a62;
  box-shadow: 0 8px 18px rgba(8, 74, 98, 0.18);
  transform: translateY(-1px);
  outline: none;
}

.charter-log-reset-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  color: #426178;
  text-decoration: none;
  background: transparent;
}

.charter-log-reset-btn:hover,
.charter-log-reset-btn:focus-visible {
  border-color: #c8d5e6;
  background: #f3f7fc;
  color: #17324a;
  text-decoration: none;
  outline: none;
}

.active-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.filter-chip {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border: 1px solid #c9d8ea;
  border-radius: 999px;
  background: #f5f9fd;
  color: #36536f;
  font-size: 12px;
  font-weight: 700;
}

.charter-log-table-card {
  overflow: hidden;
}

.charter-log-table-wrap {
  max-height: min(68vh, 720px);
  overflow: auto;
}

.charter-log-table {
  min-width: 880px;
  border-collapse: separate;
  border-spacing: 0;
}

.charter-log-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f7fafd;
  border-bottom: 1px solid #d8e2ee;
  color: #53667e;
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
}

.charter-log-table tbody tr {
  transition: background 120ms ease;
}

.charter-log-table tbody tr:hover {
  background: #eef6ff;
}

.table-sort-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: inherit;
  text-decoration: none;
}

.table-sort-link:hover,
.table-sort-link:focus-visible {
  color: #0b5d7a;
  text-decoration: none;
  outline: none;
}

.table-sort-link.is-active {
  color: #0b4f6c;
}

.sort-indicator {
  color: #7a8da5;
  font-size: 11px;
}

.charter-log-table .remarks-cell {
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 900px) {
  .charter-log-header {
    align-items: flex-start;
    flex-direction: column;
    gap: 6px;
  }

  .charter-log-filters {
    align-items: stretch;
  }

  .charter-log-search-label,
  .filter-label {
    flex: 1 1 100%;
  }

  .charter-log-select,
  .charter-log-date {
    width: 100%;
  }

  .charter-log-filter-actions {
    width: 100%;
  }

  .charter-log-apply-btn,
  .charter-log-reset-btn {
    flex: 1 1 0;
  }
}
.nowrap { white-space: nowrap; }
.empty-state {
  text-align: center;
  color: var(--text-muted, #6b7a90);
  padding: 24px 0;
  font-style: italic;
}

/* Pagination */
.pagination {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  justify-content: center;
}

.end-date-add-btn {
  min-width: 120px;
  height: 36px;
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  font-size: 12px;
}
.page-btn {
  padding: 5px 14px;
  border: 1px solid var(--line, #cdd6e2);
  border-radius: 5px;
  background: #fff;
  color: var(--accent, #2563eb);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}
.page-btn:hover { background: #eef5ff; }
.page-btn-disabled {
  padding: 5px 14px;
  border: 1px solid var(--line, #cdd6e2);
  border-radius: 5px;
  background: #f5f8fc;
  color: #b0bac8;
  font-size: 13px;
  font-weight: 600;
}
.page-info {
  font-size: 13px;
  color: var(--text-muted, #6b7a90);
}

.actions-cell form {
  margin: 0;
  display: inline-flex;
}

.action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 70px;
  height: 32px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid #8fa9c9;
  background: #f2f7ff;
  color: #0c3b64;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.action-btn:hover {
  background: #e1edff;
}

.action-btn-danger {
  border-color: #b32828;
  background: #b32828;
  color: #ffffff;
}

.action-btn-danger:hover {
  background: #931f1f;
}


.history-filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: end;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  margin-bottom: 10px;
}

.filter-group {
  display: grid;
  gap: 4px;
}

.filter-group input {
  width: 180px;
  height: 34px;
  border: 1px solid #a8b4c7;
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 14px;
}

.filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.history-meta {
  display: flex;
  gap: 18px;
  margin: 6px 0 10px;
  font-size: 13px;
  color: #2f4763;
}

.pager {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 10px;
}


.history-tools {
  display: flex;
  gap: 10px;
  align-items: center;
  margin: 8px 0 10px;
}

.filter-group select {
  width: 100px;
  height: 34px;
  border: 1px solid #a8b4c7;
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 14px;
}

.badge.baseline {
  background: #f0f1f5;
  color: #444b58;
  border-color: #b7bcc7;
}

.action-btn-disabled {
  opacity: 0.45;
  pointer-events: none;
}


.monthly-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(180px, 1fr));
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: auto;
  background: #fff;
}

.month-head {
  background: #b8cde1;
  border-right: 1px solid #9fb4ca;
  border-bottom: 1px solid #9fb4ca;
  padding: 8px;
  font-weight: 700;
  text-align: center;
}

.month-cell {
  min-height: 170px;
  border-right: 1px solid #d7deea;
  border-bottom: 1px solid #d7deea;
  padding: 6px;
  background: #fcfdff;
}

.month-cell.empty {
  background: #f5f7fb;
}

.cell-date {
  font-size: 12px;
  font-weight: 700;
  color: #224365;
  margin-bottom: 5px;
}

.month-flight {
  border: 1px solid #9eb7dc;
  border-radius: 6px;
  background: #eaf2ff;
  padding: 4px 6px;
  margin-bottom: 5px;
}

.mf-line {
  font-size: 11px;
  line-height: 1.3;
  color: #153654;
}


.weekday-info {
  background: #eef5ff;
  border: 1px solid #c1d4ee;
  border-radius: 8px;
  padding: 8px 10px;
  margin: 0 0 10px;
  font-size: 13px;
  color: #173858;
}


.topbar-user {
  margin-left: auto;
  color: #d8eef9;
  font-weight: 700;
  padding: 8px 4px;
  white-space: nowrap;
}

.auth-shell {
  display: flex;
  justify-content: center;
  padding-top: 48px;
}

.auth-form {
  width: 100%;
  max-width: 420px;
}

.drag-hidden {
  opacity: 0.15;
}

.tester-block {
  cursor: grab;
}


.tester-remove {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid #2c7a5c;
  background: rgba(255, 255, 255, 0.9);
  color: #245843;
  font-size: 11px;
  line-height: 1;
  padding: 0;
}

.tester-remove:hover {
  filter: none;
  background: #ffffff;
}

.tester-block {
  cursor: move;
  min-width: 88px;
  user-select: none;
}

.tester-block .block-title {
  padding-right: 18px;
}

.tester-remove {
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 980px) {
  .topbar {
    gap: 8px;
    padding: 8px 10px;
    flex-wrap: wrap;
  }
  .topbar a {
    padding: 7px 10px;
  }
  .demo-badge {
    margin-right: 2px;
  }
  .birthday-badge {
    width: 58px;
    height: 38px;
    margin-right: 2px;
  }
  .birthday-badge-icon {
    width: 58px;
    height: 38px;
  }
  .topbar-left,
  .topbar-actions {
    flex: 1 1 auto;
  }
  .topbar-actions {
    flex: 1 1 100%;
    justify-content: flex-start;
    max-width: none;
  }
  .topbar-user {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .topbar-right {
    margin-left: auto;
  }
  .monthly-toolbar,
  .day-toolbar {
    height: auto;
  }
  .toolbar-board-row {
    min-height: 0;
  }
  .toolbar-board-content {
    padding: 6px 10px;
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
    justify-content: stretch;
    gap: 8px;
    overflow: visible;
  }
  .toolbar-testers {
    width: 100%;
    flex-wrap: nowrap;
    gap: 6px;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }
  .toolbar-testers::-webkit-scrollbar {
    display: none;
  }
  .monthly-toolbar-controls,
  .day-toolbar-controls {
    width: 100%;
    flex: 1 1 auto;
    flex-wrap: wrap;
    justify-content: flex-start;
    overflow: visible;
    gap: 6px;
  }
  .toolbar-group {
    gap: 4px;
  }
  .toolbar-date-group,
  .toolbar-zoom-group,
  .toolbar-utility-group {
    flex: 0 0 auto;
  }
  .toolbar-filter-group {
    flex: 1 1 100%;
    justify-content: flex-start;
  }
  .toolbar-search-group {
    flex: 1 1 156px;
  }
  .toolbar-input,
  .toolbar-select,
  .segmented button {
    height: 30px;
  }
  .toolbar-date {
    width: 112px;
  }
  .toolbar-select {
    flex: 1 1 112px;
    max-width: 132px;
    padding-left: 8px;
    padding-right: 8px;
  }
  .board-search-input {
    width: 124px;
  }
  .tester-chip {
    padding: 3px 9px;
    font-size: 11px;
  }
  .toolbar-filter-clear {
    height: 30px;
    padding: 0 8px;
  }
  .toolbar-divider {
    margin: 0 2px;
  }
  .board-info-row {
    flex-wrap: wrap;
    align-items: center;
  }
  .board-info-right {
    margin-left: 0;
  }
  .timeline-header {
    top: 26px;
  }
}


/* ============================================================
   CAPACITY REPORT — screen styles
   ============================================================ */

.cr-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: #f5f7fa;
  border-bottom: 1px solid #d6dde8;
  flex-wrap: wrap;
}

.cr-toolbar-form {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cr-toolbar-form label {
  font-size: 13px;
  font-weight: 600;
  color: #3a506b;
}

.cr-request-panel {
  margin: 12px 16px 0;
  padding: 12px 14px;
  border: 1px solid #d6dde8;
  border-radius: 10px;
  background: #fbfcfe;
}

.cr-request-head {
  margin-bottom: 10px;
}

.cr-request-title {
  font-size: 14px;
  font-weight: 700;
  color: #17324a;
}

.cr-request-subtitle {
  margin-top: 2px;
  font-size: 12px;
  color: #60758a;
}

.cr-request-form {
  display: flex;
  align-items: end;
  gap: 10px;
  flex-wrap: wrap;
}

.cr-request-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cr-request-field span {
  font-size: 12px;
  font-weight: 600;
  color: #425a70;
}

.cr-request-result {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #e1e7ef;
}

.cr-request-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cr-request-chip {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: #edf3fb;
  color: #21425f;
  font-size: 12px;
  font-weight: 600;
}

.cr-request-chip.ok {
  background: #e8f5eb;
  color: #1f6b3a;
}

.cr-request-chip.warn {
  background: #fff2e2;
  color: #915300;
}

.cr-request-lines {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cr-request-line {
  font-size: 13px;
  color: #29445f;
}

.cr-request-offer {
  display: inline-flex;
  align-items: center;
  margin-right: 10px;
  padding: 0 8px;
  min-height: 24px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #23405c;
  font-size: 12px;
  font-weight: 600;
}

.primary-btn {
  padding: 6px 16px;
  background: #1a73e8;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

.primary-btn:hover { background: #1557b0; }

/* Cover */
.cr-cover {
  text-align: center;
  padding: 40px 20px 30px;
  border-bottom: 2px solid #d6dde8;
  margin-bottom: 30px;
}

.cr-cover-title {
  font-size: 26px;
  font-weight: 800;
  color: #1a2a3a;
  letter-spacing: -0.02em;
}

.cr-cover-month {
  font-size: 20px;
  font-weight: 700;
  color: #1a73e8;
  margin-top: 6px;
}

.cr-cover-meta {
  font-size: 12px;
  color: #6b7f93;
  margin-top: 8px;
}

.cr-cover-disclaimer {
  margin: 12px auto 0;
  max-width: 860px;
  padding: 10px 12px;
  border: 1px solid #f0d7a6;
  border-radius: 8px;
  background: #fff7e6;
  color: #7b5b16;
  font-size: 12px;
  line-height: 1.45;
}

/* Day sections */
.cr-day-section {
  margin-bottom: 36px;
}

.cr-day-header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 10px 0 8px;
  border-bottom: 2px solid #1a73e8;
  margin-bottom: 14px;
}

.cr-day-name {
  font-size: 18px;
  font-weight: 800;
  color: #1a2a3a;
}

.cr-day-dates {
  font-size: 12px;
  color: #6b7f93;
}

.cr-section-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #5a6e82;
  margin-bottom: 8px;
}

.cr-section-help {
  margin: -2px 0 8px;
  font-size: 12px;
  color: #647688;
  line-height: 1.4;
}

/* Heatmap in report */
.cr-heatmap-section {
  margin-bottom: 18px;
}

.cr-heatmap-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cr-hm-row {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 26px;
}

.cr-hm-label {
  flex: 0 0 140px;
  text-align: right;
  font-size: 12px;
  font-weight: 700;
  color: #3a506b;
  white-space: nowrap;
}

.cr-hm-count {
  font-weight: 600;
  color: #8a9bb0;
  font-size: 11px;
}
.cr-hm-ref {
  font-size: 10px;
  font-weight: 500;
  color: #6b7280;
  font-style: italic;
}

.cr-hm-bar {
  flex: 1;
  position: relative;
  height: 22px;
  background: #eef1f5;
  border-radius: 3px;
  overflow: hidden;
}

.cr-hm-seg {
  position: absolute;
  top: 0;
  height: 100%;
}

.cr-hm-tick {
  position: absolute;
  top: 0;
  width: 1px;
  height: 100%;
  background: rgba(255,255,255,0.4);
  pointer-events: none;
}

.cr-hm-axis {
  position: relative;
  height: 16px;
  margin-left: 150px;
  margin-top: 2px;
}

.cr-hm-hour {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 600;
  color: #8a9bb0;
}

.cr-legend {
  display: flex;
  gap: 16px;
  margin: 6px 0 0 150px;
}

.cr-legend-item {
  font-size: 11px;
  font-weight: 600;
  color: #5a6e82;
  display: inline-flex;
  align-items: center;
}

.cr-swatch {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 3px;
  margin-right: 4px;
}

/* Numerical table */
.cr-table-section {
  margin-top: 16px;
}

.cr-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.cr-table th {
  text-align: left;
  padding: 6px 10px;
  background: #f0f3f7;
  border-bottom: 2px solid #d6dde8;
  font-size: 11px;
  font-weight: 700;
  color: #3a506b;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.cr-th-cat   { width: 130px; }
.cr-th-stands { width: 60px; text-align: center; }
.cr-th-slots  { }

.cr-table td {
  padding: 8px 10px;
  border-bottom: 1px solid #e8ecf1;
  vertical-align: top;
}

.cr-td-cat {
  font-weight: 700;
  color: #3a506b;
}

.cr-td-stands {
  text-align: center;
  color: #6b7f93;
  font-weight: 600;
}

.cr-td-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cr-slot {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  background: #e8f4ec;
  border: 1px solid #b8dcc5;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
}

.cr-slot-time {
  color: #1a5c2e;
  font-variant-numeric: tabular-nums;
}

.cr-slot-free {
  color: #3a8a55;
  font-size: 11px;
}

.cr-slot-none {
  color: #b04040;
  font-weight: 600;
  font-style: italic;
}

.cr-footer {
  text-align: center;
  padding: 20px 0;
  border-top: 1px solid #d6dde8;
  margin-top: 20px;
}

.cr-footer-note {
  font-size: 11px;
  color: #8a9bb0;
}

/* ============================================================
   CAPACITY REPORT — print / PDF styles
   ============================================================ */

.cr-page-break {
  page-break-before: always;
}

@media print {
  /* Hide non-print elements */
  .no-print,
  .topbar,
  .cr-toolbar,
  .site-footer {
    display: none !important;
  }

  body {
    background: #fff;
    font-size: 11px;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .container {
    max-width: none;
    padding: 0;
    margin: 0;
  }

  .cr-page {
    padding: 0;
  }

  .cr-cover {
    padding: 24px 0 18px;
    margin-bottom: 16px;
  }

  .cr-cover-title { font-size: 22px; }
  .cr-cover-month { font-size: 17px; }

  .cr-day-section {
    margin-bottom: 20px;
  }

  .cr-day-header {
    padding: 6px 0 4px;
  }

  .cr-hm-bar, .cr-hm-seg,
  .hm-free, .hm-moderate, .hm-busy, .hm-full,
  .cr-swatch, .cr-slot {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .cr-table th {
    background: #f0f3f7 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .cr-footer {
    margin-top: 10px;
  }

  @page {
    size: A4 landscape;
    margin: 12mm 10mm;
  }
}

/* ── Conflict Scan / Stand Report shared ───────────────────────────────────── */
.log-date-link {
  color: #1e3a5f;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}
.log-date-link:hover { text-decoration: underline; }

