/* Last War universal / local clock — shared across all pages (no auth). */

.app-header .top-bar:has(#server-clock-wrap) {
  display: grid;
  align-items: center;
  gap: 0.75rem 1rem;
  min-height: 3.55rem;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
}

.app-header .top-bar:has(#server-clock-wrap):not(:has(.top-links)):not(:has(.article-header-actions)) {
  grid-template-columns: minmax(0, 1fr) auto;
}

.app-header .top-bar:has(#server-clock-wrap) > .top-bar-brand {
  justify-self: start;
  min-width: 0;
}

.app-header .top-bar:has(#server-clock-wrap) > #server-clock-wrap {
  justify-self: center;
  min-width: 0;
}

.app-header .top-bar:has(#server-clock-wrap) > .top-bar-actions,
.app-header .top-bar:has(#server-clock-wrap) > .article-header-actions {
  justify-self: end;
}

.app-header .top-bar:has(#server-clock-wrap) > .article-header-actions {
  flex-wrap: nowrap;
  min-width: 0;
}

/* Wide: staff links + super menu left of username (same row, end-aligned). ≤720px: display:contents + grid stacks username above nav. */
.app-header .top-bar:has(#server-clock-wrap) > .top-bar-actions {
  display: flex;
  flex-direction: row;
  /* nowrap: wrapping put the username row under the whole .top-links block at mid widths */
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.4rem 0.75rem;
  min-width: 0;
}

.app-header .top-bar > .top-bar-actions > .top-links {
  flex: 0 1 auto;
  min-width: 0;
  margin-left: 0; /* override page CSS (e.g. stats-page) margin-left: auto so links stay left of username with flex-end */
}

.app-header .top-bar > .top-bar-actions > .nav-account-wrap {
  flex: 0 0 auto;
  min-width: 0;
}

/* Mid-width: clocks on their own row so nav/super controls never paint over the timer strip (721px–1280px). */
@media (min-width: 721px) and (max-width: 1280px) {
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links),
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    align-items: center;
    column-gap: 1rem;
    row-gap: 0.5rem;
  }

  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > .top-bar-brand,
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) > .top-bar-brand {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
  }

  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > .top-bar-actions,
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) > .article-header-actions {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    min-width: 0;
  }

  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > #server-clock-wrap,
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) > #server-clock-wrap {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: center;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
}

/* Tablet/desktop: one horizontal line for permission-varying nav; clip/scroll inside the bar so nothing draws over clocks. */
@media (min-width: 721px) {
  .app-header .top-bar > .top-bar-actions > .top-links {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: visible;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
  }

  .app-header .top-links .nav-staff-links:not([hidden]) {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem 0.55rem;
    min-width: 0;
    flex: 1 1 auto;
  }

  .app-header .top-links .nav-super-alliance-wrap:not([hidden]) {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    flex: 0 0 auto;
    min-width: 0;
  }

  .app-header .nav-super-alliance-wrap select {
    max-width: min(13rem, 42vw);
    min-width: 0;
  }

  .app-header .top-bar:has(#server-clock-wrap) > .article-header-actions {
    overflow-x: auto;
    overflow-y: visible;
    overscroll-behavior-x: contain;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
  }

  .app-header .article-header-actions .nav-staff-links:not([hidden]) {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem 0.55rem;
    min-width: 0;
    flex: 1 1 auto;
  }

  .app-header .article-header-actions .nav-super-alliance-wrap:not([hidden]) {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    flex: 0 0 auto;
    min-width: 0;
  }
}

@media (max-width: 920px) {
  /* Minimal header (e.g. index login): brand and clocks were one row → overlap; stack full-width */
  .app-header .top-bar:has(#server-clock-wrap):not(:has(.top-links)):not(:has(.article-header-actions)) {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: stretch;
    gap: 0.5rem 0;
  }
  .app-header .top-bar:has(#server-clock-wrap):not(:has(.top-links)):not(:has(.article-header-actions)) > .top-bar-brand {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    width: 100%;
    min-width: 0;
  }
  .app-header .top-bar:has(#server-clock-wrap):not(:has(.top-links)):not(:has(.article-header-actions)) > #server-clock-wrap {
    grid-column: 1;
    grid-row: 2;
    justify-self: stretch;
    width: 100%;
    max-width: 100%;
    margin-top: 0;
  }

  .app-header .top-bar:has(#server-clock-wrap) .top-bar-brand h1 {
    font-size: clamp(0.92rem, 4.2vw, 1.35rem);
    line-height: 1.15;
  }
  .app-header .nav-account-menu {
    left: auto;
    right: 0;
    width: min(220px, calc(100vw - 2rem));
    min-width: 0;
    max-width: calc(100vw - 2rem);
  }
  .top-bar-clocks {
    gap: 0.28rem 0.45rem;
    max-width: 100%;
  }
  .top-bar-clock {
    padding-left: 0.2rem;
    padding-right: 0.2rem;
  }
  .top-bar-clocks .top-bar-clock-label {
    font-size: clamp(0.5rem, 2.2vw, 0.58rem);
  }
  .top-bar-clock .top-bar-clock-secondary-time {
    font-size: clamp(0.48rem, 2.1vw, 0.58rem);
    letter-spacing: 0.08em;
  }
  .top-bar-clocks .top-bar-clock-value,
  .top-bar-clock > time {
    font-size: clamp(0.88rem, 3.2vw, 1.15rem);
  }
}

/* Phones/small tablets: stack username above full-width nav (721–920px keeps one nav row next to username). */
@media (max-width: 720px) {
  /* Brand + username row 1; staff nav row 2 (right); clocks row 3 */
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links),
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto auto;
    align-items: start;
    gap: 0.5rem 0;
  }
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > .top-bar-brand,
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) > .top-bar-brand {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    width: auto;
    max-width: 100%;
    min-width: 0;
  }
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > .top-bar-actions {
    display: contents;
  }
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > .top-bar-actions > .nav-account-wrap {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    align-self: center;
    min-width: 0;
  }
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > .top-bar-actions > .top-links,
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) > .article-header-actions {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: stretch;
    width: 100%;
    min-width: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 0.45rem 0.65rem;
  }
  .app-header .top-bar:has(#server-clock-wrap):has(.top-links) > #server-clock-wrap,
  .app-header .top-bar:has(#server-clock-wrap):has(.article-header-actions) > #server-clock-wrap {
    grid-column: 1 / -1;
    grid-row: 3;
    margin-top: 0.15rem;
    justify-self: center;
    max-width: 100%;
    width: 100%;
  }
  .app-header .nav-staff-links:not([hidden]) {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem 0.55rem;
    min-width: 0;
    order: 1;
    flex: 0 1 auto;
    max-width: 100%;
  }
  .app-header .nav-super-alliance-wrap:not([hidden]) {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem 0.5rem;
    min-width: 0;
  }
  .app-header .nav-super-alliance-wrap select {
    max-width: min(100%, 11rem);
    min-width: 0;
    align-self: center;
  }

  .app-header .top-links .nav-site-link,
  .app-header .article-header-actions > .nav-site-link,
  .app-header .nav-staff-links .nav-site-link,
  .app-header .nav-super-stats-link {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    line-height: 1.2;
    box-sizing: border-box;
  }

  .app-header .nav-account-trigger {
    max-width: 100%;
    min-width: 0;
  }
  .app-header .nav-account-trigger .username-display,
  .app-header .nav-account-trigger .admin-nav-username {
    max-width: min(46vw, 12.5rem);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  /* Logged-in article header: keep account above inline links when both sit in one flex row */
  .app-header .article-header-actions .nav-account-wrap {
    order: -1;
    flex: 0 0 100%;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    display: flex;
    justify-content: flex-end;
    margin-left: 0;
    flex-shrink: 0;
  }
  .app-header .top-links > .nav-site-link,
  .app-header .article-header-actions > .nav-site-link {
    order: 1;
  }
  .app-header .top-links > .nav-super-alliance-wrap,
  .app-header .article-header-actions > .nav-super-alliance-wrap {
    order: 1;
  }
  .app-header .top-links .nav-save-msg,
  .app-header .article-header-actions .nav-save-msg {
    order: 2;
    text-align: right;
    flex: 0 1 auto;
    max-width: 100%;
  }
}

/* Narrow phones: three clock columns are too tight (ellipsis); stack panels full width */
@media (max-width: 640px) {
  .top-bar-clocks {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 0.45rem;
    max-width: 100%;
    width: 100%;
  }

  .top-bar-clocks > .top-bar-clock,
  .top-bar-clocks > button.top-bar-clock-slot,
  .top-bar-clocks > .top-bar-clock-slot {
    width: 100%;
    max-width: 100%;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding-left: 0.35rem;
    padding-right: 0.35rem;
  }

  .top-bar-clocks .top-bar-clock-label,
  .top-bar-clocks .top-bar-clock-label--arms-race,
  .top-bar-clocks .top-bar-clock-label--vs-day {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    max-width: 100%;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: none;
  }

  .top-bar-clocks .top-bar-clock-value,
  .top-bar-clock > time {
    font-size: clamp(0.8rem, 4.5vw, 1.05rem);
  }

  .top-bar-clocks .top-bar-clock-label {
    font-size: clamp(0.48rem, 2.8vw, 0.56rem);
  }

  .top-bar-clock .top-bar-clock-secondary-time {
    font-size: clamp(0.46rem, 2.5vw, 0.56rem);
    letter-spacing: 0.06em;
  }
}

/* Arms Race modal — matches site .modal-overlay / .modal-dialog (home). Centered; dialog max-height + scroll avoids mobile “middle only” clipping. */
.wf-arms-race-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 10050;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(1rem, env(safe-area-inset-top, 0px))
    max(1rem, env(safe-area-inset-right, 0px))
    max(1rem, env(safe-area-inset-bottom, 0px))
    max(1rem, env(safe-area-inset-left, 0px));
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  box-sizing: border-box;
}

@supports (align-items: safe center) {
  .wf-arms-race-overlay {
    align-items: safe center;
  }
}

.wf-arms-race-overlay[hidden] {
  display: none !important;
}

.wf-arms-race-dialog {
  box-sizing: border-box;
  background: var(--panel-gradient, linear-gradient(165deg, #182230 0%, #1a2430 55%, #101820 100%));
  border: 1px solid var(--border, rgba(42, 63, 82, 0.95));
  border-radius: 14px;
  padding: 1.35rem 1.5rem;
  width: 100%;
  max-width: min(34rem, calc(100vw - 2rem));
  /* Cap height so flex centering never hides the top; scroll inside the panel */
  max-height: min(90vh, calc(100vh - 2rem - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)));
  margin: 0;
  flex-shrink: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(232, 135, 48, 0.08);
  color: var(--text, rgba(220, 232, 245, 0.96));
  font-family: 'Rajdhani', system-ui, sans-serif;
  font-size: 0.82rem;
  line-height: 1.4;
  text-align: left;
  text-shadow: none;
  letter-spacing: normal;
}

@supports (height: 100dvh) {
  .wf-arms-race-dialog {
    max-height: min(90vh, calc(100dvh - 2rem - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)));
  }
}

.wf-arms-race-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.65rem;
  margin: 0 0 0.65rem 0;
}

.wf-arms-race-header h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 0.9rem;
  color: var(--accent, #e88730);
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  line-height: 1.25;
  flex: 1;
  min-width: 0;
}

.wf-arms-race-close-btn {
  flex-shrink: 0;
  margin: 0;
  margin-top: -0.12rem;
  background: transparent;
  border: 1px solid var(--border, rgba(60, 80, 100, 0.9));
  color: var(--text-dim, rgba(180, 200, 220, 0.95));
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  font-family: 'Orbitron', sans-serif;
  font-size: 0.68rem;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.2;
}

.wf-arms-race-close-btn:hover {
  border-color: var(--accent-dim, #c47024);
  color: var(--accent, #e88730);
}

.wf-arms-race-status {
  margin: 0 0 0.25rem;
  font-size: 0.8rem;
  color: var(--text, rgba(210, 222, 238, 0.98));
}

.wf-arms-race-countdown {
  margin: 0 0 0.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--accent, #e88730);
}

.wf-arms-race-table-toolbar {
  margin: 0 0 0.45rem;
}

.wf-arms-race-table-toolbar .btn.btn-secondary {
  background: transparent;
  border: 1px solid var(--border, rgba(60, 80, 100, 0.9));
  color: var(--text-dim, rgba(180, 200, 220, 0.95));
  padding: 0.4rem 0.85rem;
  border-radius: 6px;
  font-family: 'Orbitron', sans-serif;
  font-size: 0.68rem;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0.03em;
  max-width: 100%;
  white-space: normal;
  text-align: left;
  line-height: 1.35;
}

.wf-arms-race-table-toolbar .btn.btn-secondary:hover {
  border-color: var(--accent-dim, #c47024);
  color: var(--accent, #e88730);
}

.wf-arms-race-tablewrap {
  margin-top: 0.35rem;
  padding-top: 0.35rem;
  border-top: 1px solid var(--border, rgba(42, 63, 82, 0.75));
}

.server-clock-arms-race-table {
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.7rem;
}

.server-clock-arms-race-table tbody.server-clock-arms-race-day-spacer td {
  padding: 0;
  height: 0.42rem;
  border: none !important;
  line-height: 0;
  font-size: 0;
  vertical-align: middle;
  background: transparent;
}

.server-clock-arms-race-table tbody.server-clock-arms-race-day-block {
  background: rgba(22, 32, 44, 0.72);
  outline: 1px solid rgba(126, 184, 236, 0.38);
  outline-offset: -1px;
  border-radius: 7px;
}

.server-clock-arms-race-table tbody.server-clock-arms-race-day-block tr:first-child td {
  border-top-color: rgba(126, 184, 236, 0.2);
}

.server-clock-arms-race-table tbody.server-clock-arms-race-day-block tr:last-child td {
  border-bottom-color: rgba(126, 184, 236, 0.18);
}

.server-clock-arms-race-table th,
.server-clock-arms-race-table td {
  padding: 0.28rem 0.35rem;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid rgba(126, 184, 236, 0.12);
}

.server-clock-arms-race-table th {
  background: rgba(28, 38, 54, 0.98);
  font-weight: 700;
  color: rgba(200, 220, 240, 0.95);
}

.server-clock-arms-race-table th:nth-child(1),
.server-clock-arms-race-table td:nth-child(1) {
  width: 5.75rem;
}

.server-clock-arms-race-table th:nth-child(2),
.server-clock-arms-race-table td:nth-child(2) {
  width: 3.35rem;
}

/* Reserve space for live d/h/m/s countdown so Theme column does not shift on hover. */
.server-clock-arms-race-table th:nth-child(3),
.server-clock-arms-race-table td:nth-child(3) {
  width: 12.25rem;
  min-width: 12.25rem;
  max-width: 12.25rem;
}

.server-clock-arms-race-td-day {
  color: var(--text-dim, rgba(160, 186, 212, 0.95));
  line-height: 1.35;
}

.server-clock-arms-race-td-day--label {
  font-weight: 700;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--accent, #e88730);
  text-shadow: 0 0 14px rgba(232, 135, 48, 0.35);
}

.server-clock-arms-race-td-time code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.68rem;
  color: rgba(200, 230, 255, 0.95);
  background: transparent;
}

.server-clock-arms-race-td-eta {
  font-size: 0.66rem;
  color: var(--text-dim, rgba(150, 175, 200, 0.92));
  white-space: nowrap;
}

.server-clock-arms-race-table th:nth-child(4),
.server-clock-arms-race-table td:nth-child(4) {
  width: auto;
  min-width: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* Narrow modals: col 3 was locked at 12.25rem, leaving ~0px for Theme → vertical letter stacking. */
@media (max-width: 540px) {
  .wf-arms-race-dialog {
    padding-left: 1rem;
    padding-right: 1rem;
    max-width: calc(100vw - 1rem);
  }

  .wf-arms-race-tablewrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }

  .server-clock-arms-race-table th:nth-child(1),
  .server-clock-arms-race-table td:nth-child(1) {
    width: 4.6rem;
  }

  .server-clock-arms-race-table th:nth-child(2),
  .server-clock-arms-race-table td:nth-child(2) {
    width: 3rem;
  }

  .server-clock-arms-race-table th:nth-child(3),
  .server-clock-arms-race-table td:nth-child(3) {
    width: auto;
    min-width: 0;
    max-width: none;
  }

  .server-clock-arms-race-table th:nth-child(4),
  .server-clock-arms-race-table td:nth-child(4) {
    min-width: 7.5rem;
    width: 34%;
    word-break: normal;
    overflow-wrap: break-word;
  }

  .server-clock-arms-race-td-eta {
    white-space: normal;
    line-height: 1.35;
  }
}

.server-clock-arms-race-td-eta--live {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.64rem;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  color: rgba(200, 230, 255, 0.96);
}

.server-clock-arms-race-tr--current {
  background: rgba(232, 135, 48, 0.16);
  outline: 1px solid rgba(232, 135, 48, 0.35);
}

.server-clock-arms-race-tr--current td {
  border-bottom-color: rgba(232, 135, 48, 0.2);
}

.server-clock-arms-race-tr--theme-hover {
  background: rgba(126, 184, 236, 0.14);
  outline: 1px solid rgba(126, 184, 236, 0.35);
}

.server-clock-arms-race-tr--theme-hover td {
  border-bottom-color: rgba(126, 184, 236, 0.22);
}

.server-clock-arms-race-tr--current.server-clock-arms-race-tr--theme-hover {
  background: rgba(232, 135, 48, 0.22);
  outline-color: rgba(126, 184, 236, 0.5);
}

.server-clock-arms-race-tr--vs.server-clock-arms-race-tr--current {
  box-shadow: inset 3px 0 0 rgba(126, 184, 236, 0.65);
}

.server-clock-arms-race-star {
  display: inline-block;
  margin-left: 0.12rem;
  font-size: 0.72rem;
  line-height: 1;
  vertical-align: 0.08em;
  color: rgba(255, 255, 255, 0.95);
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.25);
}

.server-clock-arms-race-vs-pill {
  display: inline-block;
  margin-right: 0.2rem;
  padding: 0.05rem 0.28rem;
  border-radius: 4px;
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  vertical-align: 0.05em;
  color: rgba(18, 26, 38, 0.95);
  background: rgba(126, 184, 236, 0.9);
}

.top-bar-clocks {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  justify-items: stretch;
  gap: 0.35rem 0.85rem;
  width: 100%;
  max-width: 36rem;
  position: relative;
  z-index: 5;
  pointer-events: auto;
}

.top-bar-clocks > .top-bar-clock-slot {
  text-align: center;
  font-family: 'Orbitron', sans-serif;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.12rem;
  min-width: 0;
  padding: 0.15rem 0.35rem 0.2rem;
  box-sizing: border-box;
  pointer-events: none;
  line-height: 1.2;
}

.top-bar-clocks > button.top-bar-clock-slot {
  pointer-events: auto;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  border: none;
  background: transparent;
  border-radius: 8px;
  color: inherit;
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: 100%;
}

.top-bar-clocks > button.top-bar-clock-slot:hover {
  background: rgba(126, 184, 236, 0.08);
}

.top-bar-clocks > button.top-bar-clock-slot:hover .top-bar-clock-value {
  color: rgba(220, 235, 248, 1);
}

.top-bar-clocks > button.top-bar-clock-slot:focus-visible {
  outline: 2px solid var(--accent, #e88730);
  outline-offset: 2px;
}

/* Geometric mono (Space Mono) reads like Orbitron for fixed-width digits */
.top-bar-clocks .top-bar-clock-value,
.top-bar-clock > time {
  font-family: 'Space Mono', 'Orbitron', ui-monospace, monospace;
  font-size: 1.3rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.06em;
  color: rgba(200, 220, 238, 0.95);
  text-shadow: 0 0 20px rgba(126, 184, 236, 0.12);
  white-space: nowrap;
  line-height: 1;
  display: block;
  margin: 0;
  padding: 0;
  pointer-events: none;
}

.top-bar-clock {
  text-align: center;
  font-family: 'Orbitron', sans-serif;
  /* Kill phantom line box inside <button> so flex gap matches .top-bar-clock-slot columns */
  font-size: 0;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.12em;
  color: rgba(200, 220, 238, 0.95);
  text-shadow: 0 0 20px rgba(126, 184, 236, 0.12);
  white-space: nowrap;
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  /* Match .top-bar-clocks > .top-bar-clock-slot (not UA button padding) */
  padding: 0.15rem 0.35rem 0.2rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.12rem;
  position: relative;
  z-index: 5;
  pointer-events: auto;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.top-bar-clock::-moz-focus-inner {
  border: 0;
  padding: 0;
}

.top-bar-clock:hover {
  color: rgba(220, 235, 248, 1);
  background: rgba(126, 184, 236, 0.08);
}

.top-bar-clock:focus-visible {
  outline: 2px solid var(--accent, #e88730);
  outline-offset: 2px;
}

.top-bar-clock-label {
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(126, 184, 236, 0.9);
  line-height: 1.1;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  pointer-events: none;
}

.top-bar-clock-label--arms-race {
  color: var(--accent, #e88730);
  text-shadow: 0 0 12px rgba(232, 135, 48, 0.25);
}

/* VS day name: same typography as Alliance Duel line (.top-bar-clock-label), red accent */
.top-bar-clock-label--vs-day {
  color: rgba(255, 130, 130, 0.95);
  text-shadow: 0 0 10px rgba(220, 72, 72, 0.35);
}

/* Other-zone time: same vertical rhythm as Arms race theme / Alliance Duel line (slot gap 0.12rem only; no extra margin) */
.top-bar-clock-secondary {
  display: block;
  margin: 0;
  padding: 0;
  pointer-events: none;
  max-width: 100%;
  width: 100%;
  text-align: center;
}

.top-bar-clock-secondary-time {
  font-family: 'Space Mono', 'Orbitron', ui-monospace, monospace;
  font-size: 0.58rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.1em;
  line-height: 1.1;
  color: rgba(200, 220, 238, 0.94);
  text-shadow: 0 0 14px rgba(126, 184, 236, 0.14);
  white-space: nowrap;
}

.top-bar-clock[data-clock-mode="local"] .top-bar-clock-secondary-time {
  color: rgba(210, 228, 246, 0.95);
  text-shadow: 0 0 12px rgba(126, 184, 236, 0.18);
}

.top-bar-clock[data-clock-mode="local"] .top-bar-clock-label {
  color: var(--accent-dim, #c47024);
}

.top-bar-clock[data-clock-mode="local"] time {
  color: rgba(248, 210, 170, 0.98);
}

/* Legacy wrapper inside .top-bar-clock-slot: children lay out as slot flex items */
.top-bar-clock-arms-race {
  display: contents;
  pointer-events: none;
}
