* { box-sizing: border-box; }

/* ARTEMIS Design System (baseline, hardening phase)
   - Tokens: colors, typography, spacing, radius, shadows, blur, motion.
   - Core patterns: .glass-panel / .ui-button / .ui-badge / .form-field / .status-block.
   - States matrix: default, :hover, :active, .is-selected, :focus-visible, [disabled],
     .is-loading, .is-success, .is-warning, .is-error.
   - Usage: prefer tokens and shared helpers over one-off values to preserve visual consistency.
*/
:root {
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --top-header-offset-top: calc(8px + var(--safe-top));
  --top-header-height: 52px;
  --workspace-strip-height: 78px;
  --workspace-top-offset: calc(var(--top-header-offset-top) + var(--top-header-height) + var(--workspace-strip-height) + 8px);
  --map-controls-gap: 8px;
  --map-controls-safe-top: calc(var(--workspace-top-offset) + var(--map-controls-gap));
  --map-rail-width: 52px;
  --detail-panel-width: clamp(360px, 28vw, 440px);
  --detail-preview-width: clamp(300px, 23vw, 352px);
  --detail-panel-gap: 0px;
  --bottom-panel-side-gap: 12px;
  --bottom-panel-right-reserve: 0px;
  --bottom-panel-center-shift: 0px;
  --bottom-panel-max-width: 860px;
  --bottom-panel-height: 88px;
  --status-panel-bottom-offset: calc(var(--bottom-panel-height) + 28px + var(--safe-bottom));
  /* Palette contract tokens (owner-doc aligned) */
  --bg-root: #0F141B;
  --bg-surface-1: #151C24;
  --bg-surface-2: #1B2430;
  --bg-surface-3: #243140;
  --border-soft: #344356;
  --border-strong: #4A5B70;
  --text-primary: #E8EDF2;
  --text-secondary: #B8C2CF;
  --text-muted: #7F8B99;
  --accent-primary: #4DA3FF;
  --accent-primary-hover: #6BB5FF;
  --accent-primary-deep: #2F7EDB;
  --accent-secondary: #7C8CF8;
  --accent-archive: #C49A6C;
  --accent-archive-soft: #A9855D;
  --state-success: #3FAE7A;
  --state-warning: #D6A449;
  --state-error: #D36B6B;
  --state-info: #5AA7D9;

  /* Runtime compatibility mapping */
  --color-bg: var(--bg-root);
  --color-surface: var(--bg-surface-1);
  --motion-fast: 120ms;
  --motion-normal: 180ms;
  --motion-soft: 240ms;
  --ease-standard: cubic-bezier(0.2, 0.72, 0.2, 1);
  --color-glass-bg: rgba(16, 24, 38, 0.74);
  --glass-bg-strong: rgba(16, 24, 38, 0.84);
  --color-glass-border: rgba(203, 213, 225, 0.18);
  --color-text-primary: var(--text-primary);
  --color-text-secondary: var(--text-secondary);
  --color-text-muted: var(--text-muted);
  --color-accent: var(--accent-primary);
  --color-success: var(--state-success);
  --color-warning: var(--state-warning);
  --color-error: var(--state-error);
  --color-info: var(--state-info);
  /* Radius tokens */
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-panel: 16px;
  --radius-pill: 999px;
  /* Spacing tokens */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 24px;
  /* Shadows + blur */
  --shadow-subtle: 0 4px 12px rgba(2, 6, 23, 0.14);
  --shadow-medium: 0 6px 16px rgba(2, 6, 23, 0.18);
  --shadow-elevated: 0 6px 14px rgba(2, 6, 23, 0.16);
  --blur-sm: 12px;
  --blur-md: 16px;
  --blur-lg: 12px;
  /* Typography contract tokens */
  --font-family-ui: "IBM Plex Sans", Inter, Arial, sans-serif;
  --font-family-editorial: "Source Serif 4", Georgia, serif;
  --font-app-title: 700 14px/1.1429 var(--font-family-ui);
  --font-panel-title: 600 14px/1.2857 var(--font-family-ui);
  --font-card-title: 600 14px/1.2857 var(--font-family-ui);
  --font-body: 400 13px/1.4615 var(--font-family-ui);
  --font-meta: 500 12px/1.3333 var(--font-family-ui);
  --font-caption: 500 11px/1.2727 var(--font-family-ui);
  --accent-glow: 0 0 0 3px rgba(56, 189, 248, 0.22);
  --state-info-bg: rgba(30, 64, 175, 0.2);
  --state-info-border: rgba(96, 165, 250, 0.42);
  --state-info-text: #bfdbfe;
  --state-success-bg: rgba(6, 78, 59, 0.34);
  --state-success-border: rgba(52, 211, 153, 0.42);
  --state-success-text: #bbf7d0;
  --state-warning-bg: rgba(120, 53, 15, 0.3);
  --state-warning-border: rgba(251, 191, 36, 0.42);
  --state-warning-text: #fde68a;
  --state-error-bg: rgba(127, 29, 29, 0.34);
  --state-error-border: rgba(248, 113, 113, 0.45);
  --state-error-text: #fecaca;
  --state-muted-bg: rgba(148, 163, 184, 0.12);
  --state-muted-bg-soft: rgba(148, 163, 184, 0.08);
  --state-muted-border: rgba(148, 163, 184, 0.35);
  --state-selected-bg: rgba(14, 116, 144, 0.22);
  --state-selected-border: rgba(56, 189, 248, 0.72);
  --state-selected-outline: rgba(186, 230, 253, 0.44);
  --panel-overlay-bg: rgba(11, 15, 20, 0.62);
  --panel-overlay-bg-strong: rgba(11, 15, 20, 0.78);
  --badge-bg: rgba(30, 41, 59, 0.55);
  --badge-border: rgba(148, 163, 184, 0.45);
  --badge-text: #dbeafe;
  /* Backward-compat aliases */
  --glass-bg: var(--color-glass-bg);
  --glass-border: var(--color-glass-border);
  --glass-radius: var(--radius-panel);
  --glass-shadow: var(--shadow-elevated);
  --text-main: var(--color-text-primary);
  --text-soft: var(--color-text-secondary);
  --text-muted: var(--color-text-muted);
  /* Overlay layering scale (UI hardening) */
  --z-map-base: 1;
  --z-map-controls: 6;
  --z-bottom-panel: 8;
  --z-top-header: 12;
  --z-top-dropdown: 13;
  --z-detail-panel: 14;
  --z-workspace: 15;
  --z-modal: 18;
  --z-system-banner: 20;
  --z-system-toast: 21;
}

html, body {
  margin: 0;
  width: 100%;
  height: 100%;
  font-family: var(--font-family-ui);
  background: radial-gradient(circle at 20% 20%, var(--bg-surface-2) 0%, var(--color-bg) 55%);
  color: var(--text-main);
}
body { overflow: hidden; }

.glass-panel {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(var(--blur-lg));
  box-shadow: var(--glass-shadow), inset 0 1px 0 rgba(226, 232, 240, 0.04);
  border-radius: var(--glass-radius);
}

.panel-header,
.detail-panel-head,
.ugc-panel-head,
.moderation-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.status-block,
.app-state-block,
.app-system-message {
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--state-info-border);
  background: var(--state-info-bg);
  color: var(--state-info-text);
}

#app-shell { position: relative; width: 100%; height: 100%; }
#workspace-frame {
  position: relative;
  z-index: var(--z-map-base);
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 0;
  padding: calc(8px + var(--safe-top)) calc(10px + var(--safe-right)) calc(8px + var(--safe-bottom)) calc(10px + var(--safe-left));
}
#workspace-top-dock {
  min-height: 0;
  display: grid;
  grid-template-rows: auto auto;
  gap: 0;
  z-index: var(--z-top-header);
  background: rgba(16, 24, 36, 0.88);
  border: 1px solid rgba(74, 91, 112, 0.5);
  border-radius: 10px;
  box-shadow: 0 1px 3px rgba(2, 6, 23, 0.16);
  overflow: clip;
}
#workspace-main {
  min-height: 0;
  display: grid;
  grid-template-columns: var(--map-rail-width) minmax(0, 1fr);
  align-items: stretch;
  column-gap: 10px;
}
#workspace-bottom-dock {
  min-height: 0;
  z-index: var(--z-bottom-panel);
  background: rgba(14, 21, 33, 0.86);
  border-top: 1px solid rgba(74, 91, 112, 0.52);
  border-radius: 0 0 10px 10px;
}
#map-container, #map {
  position: relative;
  inset: auto;
  width: 100%;
  height: 100%;
}
#map-container::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(120% 70% at 50% 100%, rgba(8, 16, 28, 0.32) 0%, rgba(8, 16, 28, 0.1) 42%, rgba(8, 16, 28, 0) 76%),
    radial-gradient(140% 70% at 20% 0%, rgba(8, 16, 28, 0.28) 0%, rgba(8, 16, 28, 0.06) 46%, rgba(8, 16, 28, 0) 80%);
}
#app-shell.has-right-detail #workspace-main {
  grid-template-columns: var(--map-rail-width) minmax(0, 1fr) auto;
}
#explore-toolbar-shell {
  grid-column: 1;
  position: relative;
  min-width: 0;
  z-index: var(--z-map-controls);
  padding-top: 8px;
}
#map-container {
  grid-column: 2;
}
#app-shell.has-right-detail #map-container {
  grid-column: 2;
}
#app-shell.has-right-detail .detail-panel {
  grid-column: 3;
}
.global-data-loading {
  position: absolute;
  inset: 0;
  z-index: calc(var(--z-top-header) + 1);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
  background: var(--panel-overlay-bg);
}
.global-data-loading[hidden] { display: none; }
.onboarding-overlay {
  position: absolute;
  top: calc(var(--workspace-top-offset) + 6px);
  left: calc(14px + var(--safe-left));
  z-index: calc(var(--z-top-header) - 1);
  display: block;
  max-width: min(460px, calc(100vw - 28px - var(--safe-left) - var(--safe-right)));
  pointer-events: none;
}
.onboarding-overlay[hidden] { display: none; }
.onboarding-card {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(2, 6, 23, 0.34);
  pointer-events: auto;
}
.onboarding-title {
  margin: 0;
  flex: 1;
  font: var(--font-body);
  color: var(--color-text-secondary);
}
.onboarding-dismiss-btn {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  line-height: 1;
}
.global-data-loading-text {
  margin: 0;
  color: var(--color-text-primary);
  font: var(--font-panel-title);
}
.global-data-error {
  position: absolute;
  inset: 0;
  z-index: calc(var(--z-top-header) + 1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  padding: 24px;
  text-align: center;
  background: var(--panel-overlay-bg-strong);
}
.global-data-error[hidden] { display: none; }
.global-data-error-text {
  margin: 0;
  color: var(--color-text-primary);
  font: var(--font-panel-title);
}

#top-header {
  position: relative;
  z-index: auto;
  min-height: 50px;
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(320px, 1.35fr) minmax(360px, 1fr);
  align-items: center;
  column-gap: 12px;
  row-gap: 8px;
  padding: 6px 10px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(74, 91, 112, 0.46);
  border-radius: 0;
  backdrop-filter: none;
  box-shadow: none;
  overflow: visible;
  isolation: isolate;
}
.top-shell-left {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  min-width: 0;
}
.brand {
  font: var(--font-app-title);
  letter-spacing: 0.08em;
  white-space: nowrap;
}
.project-nav {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
}
.project-nav-link {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--state-muted-border);
  background: var(--state-muted-bg-soft);
  color: var(--color-text-secondary);
  text-decoration: none;
  font: var(--font-meta);
  white-space: nowrap;
  transition: background var(--motion-normal) var(--ease-standard), border-color var(--motion-normal) var(--ease-standard), color var(--motion-normal) var(--ease-standard);
}
.project-nav-link:hover {
  color: var(--color-text-primary);
  border-color: var(--badge-border);
  background: var(--badge-bg);
}
.project-nav-link:focus-visible {
  outline: none;
  color: var(--color-text-primary);
  border-color: rgba(148, 163, 184, 0.4);
  background: rgba(30, 41, 59, 0.48);
}
.project-nav-link[aria-current='page'] {
  color: var(--text-primary);
  border-color: var(--state-selected-border);
  background: var(--state-selected-bg);
}
.project-nav-link:focus-visible,
.profile-trigger:focus-visible,
.profile-menu-item:focus-visible,
.top-actions-cluster > button:focus-visible,
#global-search:focus-visible,
.timeline-mode-btn:focus-visible {
  outline: none;
  border-color: rgba(56, 189, 248, 0.86);
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.24);
}
.search-shell {
  position: relative;
  padding: 2px 0;
}
.search-shell.is-search-active #global-search {
  border-color: var(--state-selected-border);
  background: var(--state-selected-bg);
  box-shadow: var(--accent-glow);
}
#global-search {
  width: 100%;
  border-radius: var(--radius-pill);
  border: 1px solid var(--state-muted-border);
  background: var(--bg-surface-2);
  color: var(--color-text-primary);
  padding: var(--space-md) 44px var(--space-md) 16px;
  height: 42px;
  font: var(--font-body);
  transition: border-color var(--motion-normal) var(--ease-standard), background var(--motion-normal) var(--ease-standard), box-shadow var(--motion-normal) var(--ease-standard);
}
#global-search:focus-visible {
  outline: none;
  border-color: var(--accent-primary-hover);
  box-shadow: var(--accent-glow);
}
#global-search::placeholder { color: var(--text-muted); }
.search-no-results-state {
  margin: 6px 0 0;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--state-info-border);
  background: var(--state-info-bg);
  color: var(--state-info-text);
  font: var(--font-meta);
  display: grid;
  gap: 8px;
}
#search-no-results-reset {
  justify-self: start;
  min-height: 30px;
  padding: 0 12px;
}
.search-clear-btn {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  padding: 0;
}
.top-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 0;
  gap: 8px;
  position: relative;
  z-index: 1;
}
.top-utility-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: max-content;
}
.profile-shell {
  position: relative;
}
.profile-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  min-width: 38px;
  height: 38px;
  padding: 0;
}
.profile-trigger-icon {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--badge-bg);
  color: var(--text-secondary);
  font-size: 13px;
}
.profile-trigger-label {
  display: none;
}
.profile-menu {
  right: 0;
  width: min(260px, calc(100vw - 24px));
  display: grid;
  gap: 4px;
  padding: 8px;
}
.profile-menu-item {
  min-height: 34px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-text-primary);
  text-align: left;
  padding: 0 10px;
  font: var(--font-meta);
}
.profile-menu-item:hover,
.profile-menu-item:focus-visible {
  outline: none;
  border-color: var(--state-muted-border);
  background: var(--state-muted-bg-soft);
}
.profile-menu-item-danger {
  color: #fca5a5;
}
#explore-toolbar-shell {
  top: auto;
  left: auto;
  right: auto;
  padding: 0;
  background: transparent;
  border: 0;
}
#explore-workspace-trigger {
  border-color: rgba(148, 163, 184, 0.42);
  background: rgba(30, 41, 59, 0.46);
  color: var(--color-text-primary);
}
#explore-workspace-trigger[aria-expanded='true'] {
  border-color: rgba(125, 211, 252, 0.48);
  background: rgba(14, 116, 144, 0.26);
}
#research-context-bar {
  position: relative;
  z-index: auto;
  min-height: 72px;
  padding: 6px 10px;
  display: grid;
  grid-template-rows: auto auto;
  gap: 6px;
  background: transparent;
  border: 0;
  border-radius: 0;
  backdrop-filter: none;
  box-shadow: none;
}
.workspace-strip-context {
  display: grid;
  grid-template-columns: minmax(160px, auto) minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  min-width: 0;
}
.workspace-strip-tools {
  position: relative;
  min-width: 0;
}
.research-context-main,
.research-context-meta,
.research-context-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
#research-slice-state,
.research-context-meta > span {
  font: var(--font-caption);
  color: var(--color-text-secondary);
  white-space: nowrap;
}
#research-slice-state {
  color: rgba(203, 213, 225, 0.88);
  border: 1px solid rgba(52, 211, 153, 0.42);
  background: rgba(6, 78, 59, 0.22);
  border-radius: var(--radius-pill);
  padding: 0 10px;
  min-height: 26px;
  display: inline-flex;
  align-items: center;
}
#research-slice-state.is-saved {
  border-color: rgba(52, 211, 153, 0.42);
  background: rgba(6, 78, 59, 0.22);
}
#research-slice-state.is-dirty {
  color: #fbbf24;
  border-color: rgba(251, 191, 36, 0.54);
  background: rgba(120, 53, 15, 0.32);
}
.research-context-chip {
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: rgba(15, 23, 42, 0.54);
  border-radius: var(--radius-pill);
  padding: 0 8px;
  min-height: 24px;
  display: inline-flex;
  align-items: center;
}
.research-context-meta {
  overflow-x: auto;
  scrollbar-width: none;
}
.research-context-meta::-webkit-scrollbar { display: none; }
#research-context-bar button {
  min-height: 32px;
  border-radius: var(--radius-pill);
  padding: 0 10px;
  font: var(--font-caption);
  letter-spacing: 0.01em;
}
#research-slice-trigger {
  border-color: rgba(125, 211, 252, 0.58);
  background: rgba(14, 116, 144, 0.24);
  color: var(--color-text-primary);
  box-shadow: inset 0 1px 0 rgba(186, 230, 253, 0.12);
}
.map-tools-shell {
  display: flex;
  align-items: stretch;
  justify-content: flex-start;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  min-width: var(--map-rail-width);
}
.workspace-strip-tools > .top-panel {
  left: calc(100% + 8px);
  right: auto;
  top: 8px;
}
.top-actions-cluster {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 8px;
  min-width: 0;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: none;
  border-radius: 0;
  border: 0;
  background: transparent;
}
.top-actions-cluster::-webkit-scrollbar { display: none; }
.workspace-secondary-entry {
  flex: 0 0 auto;
  min-height: 30px;
  padding: 0 9px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: rgba(15, 23, 42, 0.18);
  color: var(--color-text-secondary);
  font: var(--font-caption);
  opacity: 0.86;
}
.workspace-secondary-entry:hover {
  opacity: 1;
  color: var(--color-text-primary);
}
#explore-workspace-panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  width: auto;
  max-width: none;
  padding: 10px;
  display: grid;
  gap: 8px;
  z-index: calc(var(--z-top-dropdown) + 2);
}
.workspace-tab-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}
.workspace-tab {
  min-height: 34px;
  border-radius: var(--radius-pill);
}
.workspace-tab[aria-selected='true'] {
  border-color: rgba(125, 211, 252, 0.72);
  background: rgba(14, 116, 144, 0.24);
  color: var(--color-text-primary);
}
.workspace-section-groups {
  display: flex;
  justify-content: space-between;
  padding: 0 4px;
}
.workspace-section-label {
  margin: 0;
  font: var(--font-caption);
  color: rgba(148, 163, 184, 0.9);
}
.workspace-panel-body {
  display: grid;
  gap: 8px;
}
#explore-workspace-panel .quick-layer-filter {
  padding-left: 0;
}
#explore-workspace-panel .layers-entry-helper {
  padding: 0;
}
#explore-workspace-panel .workspace-section-panel {
  position: relative;
  top: auto;
  right: auto;
  width: 100%;
  max-width: none;
  transform: none;
  box-shadow: none;
}
#explore-workspace-panel .workspace-section-panel.is-open {
  transform: none;
}
#explore-workspace-panel .workspace-section-panel[hidden] {
  display: none;
}
.quick-layer-filter {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding-left: 2px;
}
.quick-layer-filter-btn {
  min-height: 28px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148, 163, 184, 0.34);
  background: rgba(15, 23, 42, 0.26);
  color: var(--color-text-secondary);
  font: var(--font-caption);
  padding: 0 8px;
  white-space: nowrap;
  cursor: pointer;
}
.quick-layer-filter-btn.is-active {
  border-color: rgba(125, 211, 252, 0.72);
  background: rgba(14, 116, 144, 0.28);
  color: var(--color-text-primary);
}
.layers-entry-helper {
  margin: 0;
  padding: 0 2px 0 6px;
  color: rgba(203, 213, 225, 0.72);
  font: var(--font-caption);
  opacity: 0.78;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity var(--motion-fast) var(--ease-standard), color var(--motion-fast) var(--ease-standard);
}
.layers-entry-helper.is-visited {
  opacity: 0.55;
}
#layers-btn.is-layer-engaged {
  border-color: rgba(125, 211, 252, 0.72);
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.14);
}
#map-theme-toggle {
  min-width: 76px;
  padding: 0 10px;
}

@media (min-width: 1081px) {
  .map-tools-shell {
    position: relative;
    top: auto;
    left: auto;
    z-index: var(--z-map-controls);
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 10px;
  }
  .top-actions-cluster {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    padding: 2px 0;
    border-radius: 0;
    border-color: transparent;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
  }
  .top-actions-cluster > button {
    width: 100%;
    min-height: 32px;
    padding: 0 6px;
    font: var(--font-caption);
    letter-spacing: 0.01em;
    color: rgba(226, 232, 240, 0.92);
    border-color: rgba(74, 91, 112, 0.5);
    background: rgba(21, 28, 36, 0.9);
  }
  .top-actions-cluster > button:hover {
    border-color: rgba(125, 211, 252, 0.48);
    background: rgba(14, 116, 144, 0.2);
    color: rgba(240, 249, 255, 0.98);
  }
  #map-theme-toggle {
    min-width: 0;
  }
  .workspace-secondary-entry {
    width: 100%;
    min-height: 30px;
    padding: 0 6px;
    text-align: center;
    border-radius: 8px;
    border-color: rgba(74, 91, 112, 0.5);
    background: rgba(21, 28, 36, 0.9);
  }
}
.top-actions-cluster > button.has-active-filters {
  border-color: rgba(125, 211, 252, 0.72);
  background: rgba(14, 116, 144, 0.24);
}
.top-actions > button,
.icon-btn,
.ui-button,
.app-system-banner-btn,
.app-state-action-btn,
.detail-actions button,
.ugc-form-actions button,
.ugc-draft-actions button,
.moderation-head-actions button,
.moderation-review-actions button,
.moderation-reject-actions button,
.floating-card-close {
  min-height: 36px;
  border-radius: var(--radius-md);
  padding: 8px 12px;
  transition: transform var(--motion-fast) var(--ease-standard), background var(--motion-normal) var(--ease-standard), border-color var(--motion-normal) var(--ease-standard), box-shadow var(--motion-normal) var(--ease-standard);
}
.top-actions > button,
.top-actions-cluster > button,
.profile-trigger,
.icon-btn,
.ui-button {
  min-height: 36px;
  border-radius: var(--radius-pill);
  padding: 0 11px;
}
.icon-btn { min-width: 40px; }
.top-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(360px, calc(100vw - 24px));
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(var(--blur-lg));
  box-shadow: var(--shadow-subtle);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px) scale(0.985);
  transition: opacity var(--motion-normal) var(--ease-standard), transform var(--motion-soft) var(--ease-standard), visibility 0ms linear var(--motion-soft);
  z-index: calc(var(--z-top-dropdown) + 4);
}
.top-panel.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition-delay: 0ms, 0ms, 0ms;
}
.top-panel.is-closing { pointer-events: none; }
#courses-panel {
  max-height: min(62vh, 520px);
  overflow: auto;
}
#explore-toolbar-shell > #courses-panel,
#explore-toolbar-shell > #live-panel {
  top: 8px;
  left: calc(100% + 8px);
  right: auto;
}
.courses-list {
  display: grid;
  gap: 6px;
  margin: 8px 0 12px;
}
.course-item {
  text-align: left;
  border: 1px solid var(--state-muted-border);
  background: var(--bg-surface-2);
  color: var(--text-primary);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  cursor: pointer;
  display: grid;
  gap: 2px;
}
.course-item-title {
  font: var(--font-body);
  color: var(--text-primary);
}
.course-item-status {
  font: var(--font-meta);
  color: var(--text-secondary);
}
.course-item.is-selected {
  border-color: var(--state-selected-border);
  background: var(--state-selected-bg);
}
.course-card {
  border: 1px solid var(--state-muted-border);
  background: var(--bg-surface-2);
  border-radius: var(--radius-md);
  padding: 10px;
  display: grid;
  gap: 8px;
}
.course-description {
  margin: 0;
  color: var(--text-secondary);
  font: var(--font-body);
  font-family: var(--font-family-editorial);
}
.course-step p { font-family: var(--font-family-editorial); }
.course-step-badge {
  margin: 0;
  color: var(--color-accent);
  font: var(--font-caption);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.course-step h5,
.course-card h4 {
  margin: 0;
  font: var(--font-panel-title);
  color: var(--color-text-primary);
}
.course-nav {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.live-list {
  display: grid;
  gap: 6px;
  margin-top: 8px;
}
.live-item {
  text-align: left;
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: rgba(15, 23, 42, 0.58);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  color: var(--color-text-primary);
  display: grid;
  gap: 4px;
}
.live-item.is-active {
  border-color: rgba(56, 189, 248, 0.72);
  background: rgba(14, 116, 144, 0.26);
}
.live-item-meta {
  font: var(--font-meta);
  color: var(--color-text-secondary);
}
.search-dropdown {
  left: 0;
  right: auto;
  width: 100%;
  padding: 8px;
}
.search-result-item {
  width: 100%;
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  background: rgba(255,255,255,0.03);
  transition: border-color var(--motion-fast) var(--ease-standard), background var(--motion-fast) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}
.search-result-item:hover { border-color: rgba(148, 163, 184, 0.45); transform: translateY(-1px); }
.search-result-item:focus-visible { outline: none; border-color: rgba(56, 189, 248, 0.82); box-shadow: var(--accent-glow); }
.search-result-item.is-selected { border-color: var(--state-selected-border); background: var(--state-selected-bg); }
.search-result-meta { display: block; font: var(--font-meta); color: var(--text-secondary); margin-top: 3px; }
.search-no-results,
.bookmark-empty {
  color: var(--text-soft);
  font: var(--font-body);
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  background: var(--state-muted-bg);
}
.search-no-results + .ui-button {
  margin-top: 8px;
  width: 100%;
}
.search-truncation-note {
  margin-top: 8px;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  border: 1px dashed rgba(148, 163, 184, 0.35);
  background: rgba(148, 163, 184, 0.08);
  color: var(--color-text-secondary);
  font: var(--font-meta);
}
.panel-title { margin: 0 0 var(--space-sm); font: var(--font-panel-title); }
.status-summary { color: var(--text-secondary); font: var(--font-body); margin-bottom: var(--space-md); }
.layers-panel-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: var(--space-md);
}
.layers-panel-toolbar .status-summary {
  margin: 0;
}
#layers-panel {
  max-height: min(62vh, 520px);
  overflow: auto;
}
.panel-action-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: var(--space-md);
}
.slice-workzone {
  border: 1px solid rgba(148, 163, 184, 0.24);
  border-radius: var(--radius-md);
  background: rgba(15, 23, 42, 0.38);
  padding: 10px;
  margin-bottom: 10px;
}
.slice-zone-helper {
  margin-bottom: 8px;
}
.course-item-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.course-item-head .course-item-title {
  font-weight: 600;
}
.course-item.is-opened {
  border-color: var(--state-selected-outline);
  background: var(--state-selected-bg);
}
.course-item.is-current-slice {
  box-shadow: inset 0 0 0 1px rgba(148, 210, 245, 0.18);
}
.slice-item-meta {
  margin-bottom: 6px;
  color: var(--text-secondary);
}
.slice-item-usage {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: -2px 0 8px;
}
.slice-usage-badge {
  border-color: var(--badge-border);
  background: var(--badge-bg);
  color: var(--badge-text);
}
.slice-item-preview {
  margin-top: 0;
  margin-bottom: 10px;
  color: var(--text-secondary);
  font: var(--font-meta);
}
.slice-item-actions {
  margin-bottom: 0;
  justify-content: flex-start;
  gap: 10px;
}
.story-mode-surface {
  border: 1px solid var(--state-selected-border);
  border-radius: var(--radius-sm);
  background: var(--state-selected-bg);
  padding: 8px 10px;
  margin-bottom: 10px;
}
.story-mode-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.story-mode-badge {
  border-color: var(--state-selected-border);
  background: var(--state-selected-bg);
  color: var(--text-primary);
}
.story-mode-title {
  font: var(--font-panel-title);
  color: var(--text-primary);
}
.story-mode-state {
  margin: 0 0 4px;
  color: var(--text-secondary);
}
.story-mode-step {
  margin-bottom: 4px;
  color: var(--text-secondary);
}
.story-mode-step-title {
  margin: 0 0 6px;
  font: var(--font-meta);
  color: var(--text-primary);
}
.story-mode-context {
  margin-top: 0;
  margin-bottom: 10px;
  color: var(--text-secondary);
  font-family: var(--font-family-editorial);
}
.story-playback-controls {
  padding-top: 4px;
  border-top: 1px dashed var(--state-muted-border);
  margin-bottom: 0;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}
.story-playback-hint {
  margin-right: 2px;
  color: var(--text-muted);
}
.course-mode-surface {
  border: 1px solid rgba(147, 197, 253, 0.38);
  border-radius: var(--radius-sm);
  background: rgba(30, 64, 175, 0.14);
  padding: 8px 10px;
  margin-top: 8px;
}
.course-mode-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.course-mode-badge {
  border-color: rgba(147, 197, 253, 0.5);
  background: rgba(30, 64, 175, 0.2);
  color: #dbeafe;
}
.course-mode-title {
  font: var(--font-panel-title);
  color: var(--text-primary);
}
.course-mode-progress {
  margin: 0 0 4px;
  color: var(--text-secondary);
}
.course-mode-context {
  margin: 0 0 8px;
  color: var(--text-secondary);
  font-family: var(--font-family-editorial);
}
.course-playback-controls {
  margin-bottom: 0;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}
.course-playback-hint {
  margin-right: 2px;
  color: var(--text-muted);
}
.slice-compare-summary {
  border: 1px dashed rgba(148, 163, 184, 0.3);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  margin-bottom: 10px;
  background: rgba(15, 23, 42, 0.28);
}
.slice-compare-panel {
  border: 1px solid rgba(56, 189, 248, 0.34);
  border-radius: var(--radius-md);
  padding: 10px;
  margin-bottom: 10px;
  background: rgba(14, 116, 144, 0.16);
}
.slice-compare-panel-actions {
  margin-bottom: 0;
  justify-content: flex-end;
}
.slice-compare-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}
.slice-compare-card {
  border: 1px solid rgba(148, 163, 184, 0.24);
  border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.32);
  padding: 8px;
}
.slice-compare-card .panel-title {
  margin-bottom: 6px;
}
.slice-compare-card-meta {
  color: #9fb4cb;
}
.slice-compare-card-preview {
  color: rgba(191, 219, 254, 0.74);
}
.slice-compare-card-detail {
  color: #9fb4cb;
  margin-bottom: 6px;
}
.slice-compare-dimensions {
  border-top: 1px solid rgba(148, 163, 184, 0.22);
  padding-top: 8px;
  margin-bottom: 8px;
}
.slice-compare-summary-title {
  margin-bottom: 6px;
}
.slice-compare-selected-list {
  margin: 0 0 8px 16px;
  padding: 0;
  color: var(--color-text-secondary);
  font: var(--font-meta);
}
.slice-compare-summary-actions {
  margin-bottom: 0;
  justify-content: flex-end;
}
.slice-compare-hint {
  margin: 0;
  color: #9fb4cb;
}
.slice-secondary-workzone {
  border-top: 1px solid rgba(148, 163, 184, 0.2);
  padding-top: 8px;
}
.slice-secondary-disclosure > summary {
  cursor: pointer;
  list-style: none;
  color: var(--text-secondary);
}
.slice-secondary-disclosure > summary::-webkit-details-marker {
  display: none;
}
.slice-secondary-disclosure[open] > summary {
  color: var(--text-primary);
}
.slice-secondary-disclosure > .panel-stack {
  margin-top: 8px;
}
.slice-compare-toggle {
  min-width: 106px;
}
.slice-open-btn {
  min-width: 124px;
}
.slice-delete-btn {
  border-color: rgba(248, 113, 113, 0.35);
  background: rgba(127, 29, 29, 0.16);
  color: #fecaca;
}
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  border-radius: var(--radius-pill);
  padding: 5px var(--space-md);
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.08);
  font: var(--font-meta);
  transition: background var(--motion-fast) var(--ease-standard), border-color var(--motion-fast) var(--ease-standard), color var(--motion-fast) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}
.chip.is-active { border-color: rgba(125,211,252,.8); background: rgba(14,116,144,.35); }
.layer-item, .bookmark-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.03);
}
.layer-item {
  border: 1px solid rgba(148, 163, 184, 0.16);
}
.layer-group {
  margin-bottom: var(--space-md);
  padding: 10px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: var(--radius-lg);
  background: rgba(15, 23, 42, 0.38);
}
.layer-group-title {
  margin: 0;
  font: var(--font-caption);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #bfdbfe;
}
.layer-group-description {
  margin: 4px 0 10px;
  color: var(--color-text-muted);
  font: var(--font-meta);
}
.layer-group-list {
  display: grid;
  gap: 6px;
}
.layer-group-disclosure {
  display: grid;
  gap: 10px;
}
.layer-group-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  cursor: pointer;
}
.layer-group-summary::-webkit-details-marker {
  display: none;
}
.layer-group-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 8px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148, 163, 184, 0.42);
  background: rgba(15, 23, 42, 0.46);
  color: var(--color-text-secondary);
  font: var(--font-caption);
}
.layer-group-collapsible .layer-group-title::before {
  content: '▾';
  margin-right: 7px;
  color: var(--color-text-muted);
}
.layer-group-collapsible .layer-group-disclosure:not([open]) .layer-group-title::before {
  content: '▸';
}
.layer-dot { width: 10px; height: 10px; border-radius: 50%; display:inline-block; }
.bookmark-meta { font: var(--font-meta); color: var(--text-secondary); }
button {
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-md);
  padding: 9px var(--space-lg);
  background: rgba(255,255,255,0.08);
  color: var(--color-text-primary);
  cursor: pointer;
  transition: transform var(--motion-fast) var(--ease-standard), background var(--motion-normal) var(--ease-standard), border-color var(--motion-normal) var(--ease-standard), box-shadow var(--motion-normal) var(--ease-standard);
}
button:hover { background: rgba(255,255,255,0.14); transform: translateY(-1px); }
button:active { transform: translateY(0); }
button:focus-visible {
  outline: none;
  border-color: rgba(56, 189, 248, 0.85);
  box-shadow: var(--accent-glow);
}
.top-actions > button[data-active-count]:not([data-active-count=""])::after {
  content: attr(data-active-count);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  margin-left: 6px;
  padding: 0 5px;
  border-radius: var(--radius-pill);
  font: var(--font-caption);
  background: rgba(14, 116, 144, 0.45);
  border: 1px solid rgba(125, 211, 252, 0.72);
  color: #e0f2fe;
}

#bottom-panel {
  position: relative;
  left: auto;
  right: auto;
  bottom: auto;
  transform: none;
  width: min(var(--bottom-panel-max-width), 100%);
  max-width: 100%;
  margin: 0 auto;
  z-index: var(--z-bottom-panel);
  min-height: var(--bottom-panel-height);
  padding: 10px 12px;
  display: grid;
  grid-template-rows: auto;
  gap: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  backdrop-filter: none;
  box-shadow: none;
}
#bottom-panel.is-interaction-blocked {
  pointer-events: none;
  opacity: 0.66;
}
.timeline-row { display: grid; gap: 10px; }
.timeline-head {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.timeline-helper-label {
  font: var(--font-caption);
  color: rgba(148, 163, 184, 0.9);
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
#timeline-range-label {
  font-size: 11px;
  color: #cbd5e1;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1;
  opacity: 0.9;
}
.timeline-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: rgba(15, 23, 42, 0.64);
  min-height: 32px;
  box-shadow: inset 0 1px 0 rgba(148, 163, 184, 0.1);
}
.timeline-mode-btn {
  min-height: 24px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-text-secondary);
  font: var(--font-caption);
  letter-spacing: 0.02em;
}
.timeline-mode-btn:hover {
  transform: none;
  border-color: rgba(148, 163, 184, 0.34);
  background: rgba(30, 41, 59, 0.55);
  color: var(--color-text-primary);
}
.timeline-mode-btn:focus-visible {
  transform: none;
  background: rgba(30, 41, 59, 0.58);
  color: #e2e8f0;
}
.timeline-mode-btn.is-active {
  background: rgba(14, 116, 144, 0.28);
  border-color: rgba(125, 211, 252, 0.56);
  color: #e2e8f0;
}
.timeline-capsule {
  margin-left: auto;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  color: #dbeafe;
  border: 1px solid rgba(125, 211, 252, 0.4);
  background: rgba(14, 116, 144, 0.18);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.015em;
  line-height: 1;
}
.timeline-track-wrap {
  position: relative;
  height: 46px;
  --timeline-track-center: 18px;
  --timeline-track-thickness: 4px;
  --timeline-track-inactive-thickness: 6px;
  --timeline-knob-size: 18px;
  --timeline-left: 0%;
  --timeline-right: 100%;
  touch-action: none;
}
.timeline-track-wrap::before,
.timeline-track-wrap::after {
  content: "";
  position: absolute;
  top: calc(var(--timeline-track-center) - (var(--timeline-track-inactive-thickness) / 2));
  height: var(--timeline-track-inactive-thickness);
  border-radius: var(--radius-pill);
  background: rgba(15, 23, 42, 0.66);
  pointer-events: none;
}
.timeline-track-wrap::before {
  left: 0;
  width: var(--timeline-left);
}
.timeline-track-wrap::after {
  left: var(--timeline-right);
  right: 0;
}
.timeline-track-base, .timeline-active-range {
  position: absolute;
  top: calc(var(--timeline-track-center) - (var(--timeline-track-thickness) / 2));
  left: 0;
  right: 0;
  height: var(--timeline-track-thickness);
  border-radius: 999px;
  pointer-events: none;
}
.timeline-track-base { background: rgba(148, 163, 184, 0.38); }
.timeline-active-range { background: linear-gradient(90deg, rgba(56, 189, 248, 0.72), rgba(129, 140, 248, 0.68)); left: 0; right: 100%; }
.timeline-knob {
  position: absolute;
  top: calc(var(--timeline-track-center) - (var(--timeline-knob-size) / 2));
  width: var(--timeline-knob-size);
  height: var(--timeline-knob-size);
  border-radius: 50%;
  border: 2px solid rgba(191, 219, 254, 0.82);
  background: radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.2), rgba(15, 23, 42, 0.95) 64%);
  box-shadow: 0 2px 7px rgba(2, 6, 23, 0.34), 0 0 0 2px rgba(56, 189, 248, 0.1);
  transform: translateX(-50%);
  pointer-events: auto;
  cursor: ew-resize;
  transition: transform var(--motion-fast) var(--ease-standard), box-shadow var(--motion-fast) var(--ease-standard), border-color var(--motion-fast) var(--ease-standard), background var(--motion-fast) var(--ease-standard);
}
.timeline-knob::before {
  content: "";
  position: absolute;
  inset: -9px;
  border-radius: 50%;
}
.timeline-track-wrap:hover .timeline-knob { box-shadow: 0 3px 9px rgba(2, 6, 23, 0.4), 0 0 0 2px rgba(56, 189, 248, 0.14); }
.timeline-track-wrap:focus-within .timeline-knob { box-shadow: 0 3px 9px rgba(2, 6, 23, 0.4), 0 0 0 2px rgba(125, 211, 252, 0.3); }
.timeline-track-wrap.is-dragging .timeline-knob {
  box-shadow: 0 3px 10px rgba(2, 6, 23, 0.42), 0 0 0 3px rgba(56, 189, 248, 0.18);
}
.timeline-knob.is-active {
  transform: translateX(-50%) scale(1.04);
  border-color: rgba(186, 230, 253, 0.9);
}
.timeline-knob:focus-visible {
  outline: none;
  box-shadow: 0 3px 10px rgba(2, 6, 23, 0.42), 0 0 0 3px rgba(56, 189, 248, 0.24);
}
.timeline-track-wrap input[type='range']:focus-visible ~ .timeline-knob,
.timeline-track-wrap input[type='range']:active ~ .timeline-knob { border-color: rgba(125, 211, 252, 0.86); }
.timeline-axis {
  position: absolute;
  left: 0;
  right: 0;
  top: 29px;
  height: 28px;
  color: #94a3b8;
  font-size: 10px;
}
.timeline-anchor {
  position: absolute;
  transform: translateX(-50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  white-space: nowrap;
}
.timeline-anchor::before {
  content: '';
  width: 1px;
  height: 6px;
  background: rgba(148, 163, 184, 0.62);
}
.timeline-anchor-year {
  font: var(--font-caption);
  color: #cbd5e1;
}
.timeline-anchor-label {
  font-size: 9px;
  color: rgba(148, 163, 184, 0.95);
}
.timeline-track-wrap input[type='range'] {
  position: absolute;
  inset: 0 0 auto 0;
  top: calc(var(--timeline-track-center) - 12px);
  width: 100%;
  margin: 0;
  opacity: 0;
  height: 24px;
  pointer-events: none;
}
.timeline-row.is-point-mode #timeline-knob-end {
  opacity: 0;
  pointer-events: none;
}
.timeline-row.is-point-mode #timeline-end {
  display: none;
}
.timeline-row.is-point-mode .timeline-track-wrap::before,
.timeline-row.is-point-mode .timeline-track-wrap::after {
  background: rgba(15, 23, 42, 0.56);
}
.timeline-row.is-point-mode .timeline-capsule {
  border-color: rgba(125, 211, 252, 0.58);
  background: rgba(14, 116, 144, 0.24);
}
.timeline-row.is-range-mode .timeline-capsule {
  border-color: rgba(129, 140, 248, 0.58);
  background: rgba(79, 70, 229, 0.18);
}

#cards-state {
  font-size: 13px;
  color: var(--text-soft);
  min-height: 28px;
  display: flex;
  align-items: center;
  padding: 4px 0;
}
#cards-state.has-inline-error {
  border: 1px solid var(--state-error-border);
  background: var(--state-error-bg);
  border-radius: var(--radius-md);
  padding: 6px var(--space-md);
}
#cards-state.cards-inline-note {
  border-radius: var(--radius-md);
  padding: 7px var(--space-md);
  background: var(--state-muted-bg-soft);
}
#cards-ribbon {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 10px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  overscroll-behavior-x: contain;
}
.ribbon-card {
  min-width: 200px;
  max-width: 220px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.05);
  cursor: pointer;
  transition: transform var(--motion-normal) var(--ease-standard), border-color var(--motion-normal) var(--ease-standard), box-shadow var(--motion-normal) var(--ease-standard), background var(--motion-normal) var(--ease-standard);
}
.ribbon-card:hover {
  transform: translateY(-3px);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(147, 197, 253, 0.45);
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.26);
}
.ribbon-card.is-hovered:not(.is-selected) {
  transform: translateY(-3px);
  background: rgba(191, 219, 254, 0.1);
  border-color: rgba(147, 197, 253, 0.7);
  box-shadow: 0 10px 22px rgba(30, 64, 175, 0.24);
}
.ribbon-card.is-map-hovered:not(.is-selected) {
  transform: translateY(-2px);
  background: rgba(191, 219, 254, 0.08);
  border-color: rgba(125, 211, 252, 0.62);
  box-shadow: 0 8px 18px rgba(30, 64, 175, 0.18);
}
.ribbon-card.is-selected {
  transform: translateY(-3px);
  border-color: rgba(56, 189, 248, 0.95);
  box-shadow: 0 8px 26px rgba(14, 165, 233, 0.22), inset 0 0 0 1px rgba(186, 230, 253, 0.52);
  background: rgba(14, 116, 144, 0.18);
}
.ribbon-card:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(147, 197, 253, 0.3); }
.ribbon-card.is-selected:focus-visible { box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.25), 0 8px 26px rgba(14, 165, 233, 0.22), inset 0 0 0 1px rgba(186, 230, 253, 0.52); }
.ribbon-card img {
  width: 100%;
  height: 92px;
  object-fit: cover;
  display: block;
  background: rgba(148, 163, 184, 0.25);
}
.ribbon-card .meta { padding: 8px; display: grid; gap: 4px; }
.ribbon-card h4 { margin: 0; font: var(--font-card-title); color: #f8fafc; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ribbon-card h4,
.ribbon-card .tag,
.bookmark-item > span:first-child,
.search-result-item,
.related-title,
.related-meta {
  overflow-wrap: anywhere;
}
.ribbon-card p { margin: 0; font: var(--font-meta); color: var(--text-soft); }
.ribbon-card .tag {
  color: #93c5fd;
  font: var(--font-caption);
}
.ribbon-card .img-placeholder,
.detail-panel .img-placeholder {
  width: 100%;
  height: 92px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #cbd5e1;
  text-align: center;
  padding: 12px;
  border: 1px dashed rgba(148, 163, 184, 0.38);
  background: linear-gradient(150deg, rgba(15, 23, 42, 0.82), rgba(8, 47, 73, 0.3));
}
.detail-panel .img-placeholder.is-large {
  min-height: 190px;
  border-radius: 14px;
}
.img-placeholder-content {
  display: grid;
  justify-items: center;
  gap: 5px;
  max-width: 36ch;
}
.img-placeholder-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  border: 1px solid rgba(148, 163, 184, 0.4);
  background: rgba(30, 41, 59, 0.45);
  box-shadow: inset 0 1px 0 rgba(226, 232, 240, 0.08);
}
.img-placeholder-title {
  margin: 0;
  font: 600 12px/1.35 Inter, Arial, sans-serif;
  color: #dbeafe;
}
.img-placeholder-note {
  margin: 0;
  font: var(--font-meta);
  color: #9fb4cb;
}
.skeleton-card {
  min-width: 200px;
  max-width: 220px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  background: rgba(148, 163, 184, 0.14);
  position: relative;
  overflow: hidden;
  animation: pulse 1.5s ease infinite;
  height: 142px;
}
.skeleton-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(95deg, transparent, rgba(226, 232, 240, 0.18), transparent);
  transform: translateX(-100%);
  animation: shimmer 1.8s ease infinite;
}
@keyframes pulse { 0%, 100% { opacity: 0.45; } 50% { opacity: 0.9; } }
@keyframes shimmer { 100% { transform: translateX(100%); } }

.detail-panel {
  position: relative;
  grid-column: 2;
  align-self: stretch;
  z-index: var(--z-detail-panel);
  width: var(--detail-preview-width);
  min-height: 0;
  height: 100%;
  padding: 10px 10px 10px 12px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(6px);
  transition: opacity var(--motion-normal) var(--ease-standard), transform var(--motion-soft) var(--ease-standard), visibility 0ms linear var(--motion-soft);
  will-change: opacity, transform;
  background: rgba(17, 25, 38, 0.9);
  border: 0;
  border-left: 1px solid rgba(74, 91, 112, 0.5);
  border-radius: 0;
  box-shadow: none;
}
#detail-panel {
  background: rgba(17, 25, 38, 0.9);
  border-left-color: rgba(74, 91, 112, 0.5);
  box-shadow: none;
}
.detail-panel.is-full-mode {
  width: var(--detail-panel-width);
}
.detail-panel.is-preview-mode {
  width: var(--detail-preview-width);
}
.detail-panel[hidden] { pointer-events: none; }
.detail-panel.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(0);
}
.detail-panel.is-closing {
  pointer-events: none;
  transform: translateX(6px);
}
.detail-panel-head {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 2px 2px 8px;
  border-bottom: 1px solid rgba(74, 91, 112, 0.52);
  margin-bottom: 4px;
  background: rgba(17, 25, 38, 0.98);
  backdrop-filter: none;
}
.detail-panel-heading { margin: 0; font: var(--font-panel-title); text-transform: none; letter-spacing: .02em; color: #dbeafe; }
.detail-panel-body {
  overflow: auto;
  max-height: 100%;
  padding-right: 4px;
  padding-bottom: 10px;
  scrollbar-width: thin;
  overscroll-behavior: contain;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 4px 2px 12px;
}
.detail-panel[data-mode='full'] .detail-panel-body,
.detail-panel.is-full-mode .detail-panel-body {
  padding: 6px 3px 12px;
}
.detail-content { display: grid; gap: 14px; padding-right: 2px; }
.detail-panel .detail-panel-body .detail-panel-body-inner,
.detail-panel .detail-panel-body .detail-content {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 4px;
}
.detail-panel[data-mode='full'] .detail-content,
.detail-panel.is-full-mode .detail-content,
.detail-panel[data-mode='full'] .detail-content-full,
.detail-panel.is-full-mode .detail-content-full,
.detail-panel[data-mode='full'] .detail-panel-body-inner[data-mode='full'],
.detail-panel.is-full-mode .detail-panel-body-inner[data-mode='full'] {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 4px;
}
.detail-content-preview .detail-section {
  border: 0;
  border-radius: 0;
  padding: 2px 4px;
  gap: 7px;
  background: transparent;
  box-shadow: none;
}
.detail-content-preview .detail-section + .detail-section {
  margin-top: 2px;
  padding-top: 14px;
  border-top: 1px solid rgba(148, 163, 184, 0.18);
}
.detail-content-full {
  gap: 16px;
}
.detail-panel.is-full-mode .detail-content-full {
  gap: 16px;
}
.detail-panel.is-full-mode .detail-content-full .detail-section {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 4px 4px 12px;
}
.detail-panel.is-full-mode .detail-content-full .detail-section + .detail-section {
  border-top: 1px solid rgba(74, 91, 112, 0.42);
  padding-top: 12px;
}
.detail-panel.is-full-mode .detail-content-full .detail-title {
  color: var(--text-primary);
}
.detail-panel.is-full-mode .detail-content-full .detail-subtitle {
  color: var(--text-secondary);
}
.detail-panel.is-full-mode .detail-content-full .detail-section-title {
  color: var(--text-secondary);
}
.detail-panel.is-full-mode .detail-content-full .detail-description {
  color: var(--text-primary);
}
.detail-panel.is-full-mode .detail-content-full .detail-description.is-empty,
.detail-panel.is-full-mode .detail-content-full .detail-empty {
  color: var(--text-muted);
}
.detail-panel.is-full-mode .detail-content-full .detail-meta-label {
  color: var(--text-secondary);
}
.detail-panel.is-full-mode .detail-content-full .detail-meta-value {
  color: var(--text-primary);
}
.detail-panel.is-full-mode .detail-content-full .detail-min-row .detail-meta-value {
  color: var(--text-primary);
}
.detail-panel.is-full-mode .detail-content-full .detail-badge {
  border-color: var(--state-muted-border);
  background: var(--state-muted-bg);
  color: var(--text-secondary);
}
.detail-panel.is-full-mode .detail-content-full .detail-badge.is-accent {
  border-color: var(--accent-archive-soft);
  background: var(--state-muted-bg-soft);
  color: var(--accent-archive);
}
.detail-panel.is-full-mode .detail-content-full .detail-action-link {
  color: var(--accent-primary);
}
.detail-panel.is-full-mode .detail-content-full .detail-action-link:hover {
  color: var(--accent-primary-hover);
}
.detail-panel.is-full-mode .detail-content-full .detail-source-link-row .detail-action-link {
  border-color: var(--state-info-border);
  background: var(--state-info-bg);
}
.detail-panel.is-full-mode .detail-content-full .detail-media-caption {
  color: var(--text-muted);
}
.detail-panel.is-full-mode .detail-content-full .img-placeholder {
  color: var(--text-secondary);
  border-color: var(--border-soft);
  background: linear-gradient(150deg, var(--bg-surface-1), var(--bg-surface-2));
}
.detail-panel[data-mode='full'] .detail-content-full .detail-media-block,
.detail-panel.is-full-mode .detail-content-full .detail-media-block {
  background: var(--bg-surface-1);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 10px;
}
.detail-media-block {
  display: grid;
  gap: 10px;
  margin-bottom: 2px;
}
.detail-media-caption {
  margin: 0;
  font: var(--font-meta);
  color: var(--text-muted);
}
.detail-hero-media {
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 182px;
  max-height: 220px;
  border-radius: 14px;
  object-fit: cover;
  background: linear-gradient(145deg, rgba(30, 41, 59, 0.82), rgba(14, 116, 144, 0.22));
  border: 1px solid rgba(148, 163, 184, 0.24);
}
.detail-section {
  border: 1px solid rgba(74, 91, 112, 0.3);
  background: rgba(15, 23, 36, 0.3);
  border-radius: 8px;
  padding: 12px 13px;
  display: grid;
  gap: 9px;
}
.detail-title-block {
  gap: 6px;
}
.detail-preview-header {
  gap: 8px;
  padding-bottom: 8px;
}
.detail-header-media {
  width: 100%;
  border-radius: 10px;
  max-height: 146px;
  object-fit: cover;
}
.detail-preview-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.detail-preview-meta-chip {
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: rgba(30, 41, 59, 0.24);
  color: var(--text-secondary);
  font: var(--font-caption);
  padding: 2px 9px;
}
.detail-preview-meta-chip.is-period {
  border-color: rgba(196, 154, 108, 0.36);
  color: var(--accent-archive);
}
.detail-slice-context-block {
  background: rgba(15, 23, 36, 0.2);
  border-color: rgba(74, 91, 112, 0.34);
  gap: 7px;
}
.detail-slice-context-title {
  margin: 0;
  font: 600 14px/1.35 var(--font-family-ui);
  color: var(--text-primary);
}
.detail-slice-context-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.detail-slice-context-chip {
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(15, 23, 42, 0.32);
  color: var(--text-secondary);
  border-radius: var(--radius-pill);
  font: var(--font-caption);
  padding: 2px 8px;
}
.detail-slice-context-note {
  margin: 0;
  color: var(--text-secondary);
  font: 400 12px/1.5 var(--font-family-editorial);
}
.detail-epistemic-block {
  position: relative;
  border-left-width: 3px;
  gap: 7px;
}
.detail-epistemic-block .detail-section-title {
  letter-spacing: 0.08em;
}
.detail-epistemic-fact {
  border-left-color: rgba(63, 174, 122, 0.85);
  background: rgba(6, 78, 59, 0.18);
}
.detail-epistemic-relation {
  border-left-color: rgba(90, 167, 217, 0.68);
  background: rgba(30, 64, 175, 0.08);
}
.detail-epistemic-interpretation {
  border-left-color: rgba(214, 164, 73, 0.62);
  background: rgba(120, 53, 15, 0.08);
}
.detail-epistemic-interpretation.is-highlighted {
  box-shadow: 0 0 0 1px rgba(214, 164, 73, 0.52), inset 0 0 0 1px rgba(214, 164, 73, 0.35);
}
.detail-epistemic-ai {
  border-left-color: rgba(124, 140, 248, 0.44);
  border-style: dashed;
  background: rgba(67, 56, 202, 0.04);
  opacity: 0.86;
}
.detail-epistemic-ai .detail-empty {
  color: #9caef4;
}
.detail-action-zones {
  gap: 7px;
  background: rgba(15, 23, 36, 0.14);
}
.detail-action-zone-group {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}
.detail-action-zone-group + .detail-action-zone-group {
  padding-top: 7px;
  border-top: 1px solid rgba(148, 163, 184, 0.14);
}
.detail-action-zone-group-lower .ui-button {
  border-color: rgba(148, 163, 184, 0.22);
  color: #b5c5d8;
  background: rgba(15, 23, 42, 0.2);
}
.detail-action-zone-group-lower .ui-button:hover {
  border-color: rgba(148, 163, 184, 0.34);
  color: #d6e2f0;
}
.detail-action-zone-group-upper .ui-button-primary {
  box-shadow: 0 4px 10px rgba(2, 132, 199, 0.12);
}
.detail-source-link-row {
  border-top: 1px dashed rgba(148, 163, 184, 0.24);
  margin-top: 2px;
  padding-top: 5px;
}
.detail-meta-block,
.detail-source-block,
.detail-technical-block {
  gap: 8px;
}
.detail-panel .detail-meta-block {
  border: 1px solid rgba(74, 91, 112, 0.34);
  background: rgba(15, 23, 36, 0.16);
}
.detail-panel .detail-source-block {
  border: 1px solid rgba(96, 165, 250, 0.26);
  background: rgba(30, 64, 175, 0.08);
}
.detail-panel .detail-source-block .detail-section-title {
  color: var(--state-info-text);
}
.detail-panel .detail-source-link-row {
  padding-top: 4px;
  border-top: 1px dashed var(--state-info-border);
}
.detail-panel .detail-technical-block {
  border: 1px solid rgba(214, 164, 73, 0.34);
  background: rgba(120, 53, 15, 0.12);
}
.detail-panel .detail-technical-block .detail-section-title {
  color: var(--state-warning-text);
}
.detail-panel .detail-technical-block .detail-meta-row.is-confidence-row {
  padding: 4px 8px;
  border-radius: 8px;
  border: 1px solid var(--state-warning-border);
  background: var(--state-warning-bg);
}
.detail-panel .detail-technical-block .detail-meta-row.is-confidence-row .detail-meta-label {
  color: var(--state-warning-text);
}
.detail-panel .detail-technical-block .detail-meta-row.is-confidence-row .detail-meta-value {
  color: var(--state-warning-text);
}
.detail-panel .detail-related-block {
  border: 1px solid rgba(74, 91, 112, 0.34);
  background: rgba(27, 36, 48, 0.3);
}
.detail-panel .detail-related-block .detail-section-title {
  color: var(--accent-secondary);
}
.detail-title {
  margin: 0;
  font: 600 20px/1.3 var(--font-family-ui);
  color: var(--text-primary);
  letter-spacing: -0.01em;
}
.detail-subtitle {
  margin: 1px 0 0;
  font: 500 12px/1.45 Inter, Arial, sans-serif;
  color: #9fb1c7;
}
.detail-date { margin: 0; font: var(--font-meta); color: #bfdbfe; }
.detail-section-title { margin: 0; font: 600 12px/1.3333 var(--font-family-ui); text-transform: uppercase; color: var(--text-secondary); letter-spacing: 0.07em; }
.detail-description {
  margin: 0;
  max-width: 52ch;
  font: 400 15px/1.6 var(--font-family-editorial);
  color: var(--text-primary);
}
.detail-description-preview {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.detail-description.is-empty {
  color: #94a3b8;
  font-style: italic;
}
.detail-description-note {
  margin: 2px 0 0;
  color: var(--text-secondary);
  font: var(--font-meta);
  font-family: var(--font-family-editorial);
}
.detail-description,
.detail-meta-value { overflow-wrap: anywhere; }
.detail-badges { display: flex; flex-wrap: wrap; gap: 6px; }
.detail-badge, .ui-badge, .ugc-status-badge, .moderation-status-badge, .moderation-meta-pill {
  font: var(--font-caption);
  border-radius: var(--radius-pill);
  padding: 3px 9px;
  border: 1px solid var(--badge-border);
  color: var(--badge-text);
  background: var(--badge-bg);
}
.detail-badge {
  border-color: var(--state-muted-border);
  background: var(--state-muted-bg);
  color: var(--text-secondary);
}
.detail-panel .detail-badge:not(.is-accent) {
  border-color: var(--state-muted-border);
  background: var(--state-muted-bg);
}
.detail-badge.is-accent {
  border-color: var(--accent-archive-soft);
  background: rgba(196, 154, 108, 0.16);
  color: var(--accent-archive);
}
.detail-meta-row {
  display: grid;
  grid-template-columns: minmax(74px, 98px) minmax(0, 1fr);
  align-items: baseline;
  gap: 9px;
  font: var(--font-meta);
  padding: 0;
}
.detail-meta-label { color: var(--text-secondary); font: var(--font-meta); min-width: 0; }
.detail-meta-value { color: var(--text-primary); font: 400 13px/1.5385 var(--font-family-ui); text-align: left; min-width: 0; }
.detail-min-row { gap: 8px; }
.detail-min-row .detail-meta-value { text-align: left; font: 500 13px/1.5385 var(--font-family-ui); color: var(--text-primary); }
.detail-min-row .detail-action-link { overflow-wrap: anywhere; }
.detail-action-link, .detail-inline-action { font: var(--font-meta); color: var(--accent-primary); text-decoration: none; justify-self: start; }
.detail-panel .detail-action-link,
.detail-panel .detail-inline-action {
  color: var(--accent-primary);
}
.detail-panel .detail-action-link:hover,
.detail-panel .detail-inline-action:hover {
  color: var(--accent-primary-hover);
}
.detail-source-link-row .detail-action-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(125, 211, 252, 0.34);
  background: rgba(8, 47, 73, 0.2);
}
.detail-action-link:hover, .detail-inline-action:hover { text-decoration: underline; }
.detail-empty { margin: 0; font-size: 12px; color: var(--text-muted); }
.related-item { width: 100%; text-align: left; display: grid; gap: 2px; }
.related-title { font: var(--font-body); color: #f8fafc; }
.related-meta { font: var(--font-caption); color: var(--text-secondary); }
.detail-actions { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 6px; }
.detail-actions button:last-child { grid-column: span 2; }
.detail-preview-actions .detail-actions { gap: 8px; grid-template-columns: 1fr; }
.detail-preview-actions {
  background: transparent;
  border: 0;
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(148, 163, 184, 0.2);
}
.detail-preview-actions .detail-actions button {
  min-height: 36px;
  grid-column: span 1;
}
.detail-preview-actions .detail-actions .ui-button-primary {
  font-weight: 600;
  border-color: rgba(56, 189, 248, 0.66);
  box-shadow: 0 4px 10px rgba(2, 132, 199, 0.16);
}
.detail-preview-actions .detail-actions .ui-button:not(.ui-button-primary) {
  border-color: rgba(148, 163, 184, 0.28);
  color: #c8d6e8;
}
.detail-skeleton { display: grid; gap: 8px; }
.detail-skeleton-line {
  height: 18px;
  border-radius: 8px;
  background: rgba(148, 163, 184, 0.2);
  animation: pulse 1.4s ease infinite;
}
.detail-panel .img-placeholder,
.detail-panel .img-placeholder.is-large {
  background: linear-gradient(150deg, rgba(10, 18, 32, 0.96), rgba(8, 47, 73, 0.56));
  border-color: rgba(125, 211, 252, 0.3);
  color: #d8ebff;
}
@media (max-width: 740px) {
  .detail-slice-context-chips {
    gap: 5px;
  }
  .detail-action-zone-group {
    grid-template-columns: 1fr;
  }
}
.detail-panel .img-placeholder-title { color: #e2e8f0; }
.detail-panel .img-placeholder-note { color: var(--text-secondary); font-family: var(--font-family-editorial); }
.floating-card-close { position: static; min-width: 36px; padding: 0; }
#detail-panel-close {
  position: sticky;
  top: 4px;
  z-index: 3;
}
#detail-panel-close:focus-visible,
.detail-panel :is(button, [href]):focus-visible {
  outline: none;
  border-color: rgba(56, 189, 248, 0.86);
  box-shadow: var(--accent-glow);
}
.floating-card-close:hover { background: rgba(248, 113, 113, 0.2); border-color: rgba(248, 113, 113, 0.5); }
.floating-card-close:focus-visible { box-shadow: var(--accent-glow); }
.detail-panel.is-selected {
  border-color: rgba(125, 211, 252, 0.4);
  box-shadow: 0 1px 4px rgba(2, 6, 23, 0.22), inset 0 0 0 1px rgba(125, 211, 252, 0.24);
}


.legacy-sidebar { display: none !important; }

#error-banner {
  position: fixed;
  left: 12px;
  right: 12px;
  top: 78px;
  z-index: var(--z-system-banner);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  border: 1px solid var(--state-error-border);
  background: var(--state-error-bg);
  color: var(--state-error-text);
}
#loading-indicator {
  display: none !important;
}
.status-inline-loading { margin: 0 0 6px auto; }
.offline-status {
  position: fixed;
  left: calc(12px + var(--safe-left));
  top: calc(78px + var(--safe-top));
  z-index: var(--z-system-banner);
  border-radius: var(--radius-lg);
  padding: 7px var(--space-lg);
  border: 1px solid var(--state-warning-border);
  background: var(--state-warning-bg);
  color: var(--state-warning-text);
  font-size: 12px;
  max-width: min(360px, calc(100vw - 24px - var(--safe-left) - var(--safe-right)));
  display: grid;
  gap: 2px;
}
.offline-status-title { font-weight: 600; }
.offline-status-hint { color: #fde68a; opacity: 0.92; font-size: 11px; }
.app-status-host {
  position: fixed;
  left: 50%;
  top: calc(var(--workspace-top-offset) + 8px);
  transform: translateX(-50%);
  z-index: var(--z-system-toast);
  display: grid;
  gap: 8px;
  width: min(420px, calc(100vw - 24px - var(--safe-left) - var(--safe-right)));
  pointer-events: none;
}
.app-system-message {
  font: var(--font-meta);
  box-shadow: var(--shadow-medium);
  backdrop-filter: blur(var(--blur-md));
  pointer-events: auto;
}
.app-system-success { border-color: var(--state-success-border); background: var(--state-success-bg); color: var(--state-success-text); }
.app-system-warning { border-color: var(--state-warning-border); background: var(--state-warning-bg); color: var(--state-warning-text); }

.app-system-banner {
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  border: 1px solid var(--state-info-border);
  background: rgba(16, 24, 38, 0.85);
  backdrop-filter: blur(var(--blur-md));
  box-shadow: var(--shadow-medium);
  display: grid;
  gap: 8px;
}
.app-system-banner-text { margin: 0; color: var(--text-main); font: var(--font-body); }
.app-system-banner-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.app-system-banner-btn {
  font: var(--font-meta);
}

.app-state-block {
  display: grid;
  gap: 6px;
}
.app-state-title { font: var(--font-meta); }
.app-state-message { font: var(--font-body); }
.app-state-actions { display: flex; gap: 8px; }
.app-state-action-btn { font: var(--font-meta); }
.app-state-success { border-color: var(--state-success-border); background: var(--state-success-bg); color: var(--state-success-text); }
.app-state-warning { border-color: var(--state-warning-border); background: var(--state-warning-bg); color: var(--state-warning-text); }
.app-state-error { border-color: var(--state-error-border); background: var(--state-error-bg); color: var(--state-error-text); }

.status-panel {
  position: fixed;
  left: calc(12px + var(--safe-left));
  right: auto;
  bottom: var(--status-panel-bottom-offset);
  width: min(340px, calc(100vw - 24px - var(--safe-right) - var(--safe-left)));
  background: rgba(16, 24, 38, 0.44);
  border: 1px solid rgba(148, 163, 184, 0.16);
  color: rgba(229, 231, 235, 0.88);
  padding: 8px 11px;
  border-radius: 12px;
  font: var(--font-meta);
  z-index: calc(var(--z-bottom-panel) + 1);
  backdrop-filter: blur(8px);
  pointer-events: none;
}
#app-shell.has-right-detail #status {
  left: calc(12px + var(--safe-left));
}
.status-loading { font-size: 11px; color: rgba(191, 219, 254, 0.92); margin-bottom: 4px; }
.status-error { margin-top: 6px; color: #fecaca; }

/* modal and form legacy styles for auth/ugc */
.modal { position: fixed; inset: 0; background: rgba(0,0,0,0.5); display: flex; align-items: center; justify-content: center; padding: 16px; z-index: var(--z-modal); }
.modal-content { position: relative; width: min(460px, 92vw); max-height: 92vh; overflow: auto; background: #fff; color: #0f172a; border-radius: 14px; padding: 16px; }
.modal label { display: block; font-size: 13px; margin: 8px 0 4px; color: #111827; }
.modal input, .modal select, .modal textarea { width: 100%; padding: 10px 12px; border: 1px solid #cbd5e1; border-radius: 8px; font-size: 14px; }
.modal-close { position: absolute; top: 12px; right: 12px; color: #0f172a; }

.field-error, .field-error-message { color: #b91c1c; font-size: 12px; }
.field-error-message { margin-top: 4px; }
.is-invalid { border-color: #dc2626 !important; }
[hidden] { display: none !important; }

.ugc-panel {
  position: fixed;
  right: 12px;
  top: 84px;
  bottom: 206px;
  z-index: var(--z-workspace);
  width: min(460px, calc(100vw - 24px));
  padding: var(--space-lg);
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  gap: 10px;
  overflow: hidden;
}
.ugc-panel-head { align-items: flex-start; }
.ugc-panel-title { margin: 0; font: 600 15px/1.3 Inter, Arial, sans-serif; letter-spacing: .02em; }
.ugc-panel-subtitle { margin: 4px 0 0; color: var(--text-muted); font: var(--font-meta); text-transform: capitalize; }
.ugc-error-state { margin: 0 0 var(--space-md); }
.ugc-error-banner {
  border: 1px solid var(--state-error-border);
  background: var(--state-error-bg);
  color: var(--state-error-text);
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  font: var(--font-body);
  line-height: 1.4;
  white-space: pre-wrap;
}
.ugc-error-banner .app-state-block {
  gap: 8px;
}
.ugc-error-banner .app-state-title {
  font-weight: 600;
}
.ugc-inline-note, .ugc-inline-error {
  border-radius: 10px;
  padding: 0;
  font-size: 13px;
}
.ugc-my-drafts { border: 1px solid var(--glass-border); border-radius: 12px; padding: var(--space-md); background: rgba(15, 23, 42, 0.42); }
.ugc-my-drafts-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 8px; }
.ugc-my-drafts-head h3 { margin: 0; font: var(--font-body); }
.ugc-empty-state {
  border: 1px dashed var(--state-muted-border);
  border-radius: var(--radius-md);
  background: var(--state-muted-bg-soft);
  padding: 4px;
}
.ugc-drafts-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; max-height: 180px; overflow: auto; }
.ugc-draft-item { border: 1px solid rgba(148,163,184,.24); border-radius: var(--radius-md); padding: var(--space-sm); background: rgba(255,255,255,.03); display: grid; gap: 6px; }
.ugc-draft-meta { display: flex; gap: var(--space-sm); justify-content: space-between; align-items: center; font: var(--font-meta); color: var(--text-muted); }
.ugc-draft-actions { display: flex; flex-wrap: wrap; gap: 6px; }
.ugc-status-badge { text-transform: capitalize; padding: 2px 8px; }
.ugc-status-info { display: grid; justify-items: end; gap: 4px; }
.ugc-status-draft {
  border-color: var(--state-info-border);
  background: var(--state-info-bg);
  color: var(--state-info-text);
}
.ugc-status-pending { color: var(--state-warning-text); }
.ugc-status-approved { color: var(--state-success-text); }
.ugc-status-rejected { color: var(--state-error-text); }
.ugc-status-unknown {
  border-color: var(--state-muted-border);
  background: var(--state-muted-bg-soft);
  color: var(--text-soft);
}
.ugc-status-reason {
  display: block;
  max-width: 220px;
  color: var(--text-muted);
  font: var(--font-meta);
  text-align: right;
}

.ugc-draft-form { overflow: auto; border: 1px solid var(--glass-border); border-radius: 12px; padding: var(--space-md); display: grid; gap: var(--space-md); background: rgba(15, 23, 42, 0.5); overscroll-behavior: contain; }
.ugc-form-section { border: 1px solid rgba(148,163,184,.2); border-radius: var(--radius-md); padding: var(--space-md); }
.ugc-form-section h3 { margin: 0 0 var(--space-sm); font: var(--font-caption); color: #bfdbfe; text-transform: uppercase; letter-spacing: .06em; }
.ugc-draft-form label { display: block; font: var(--font-meta); color: #cbd5e1; margin-bottom: var(--space-sm); }
.ugc-draft-form input, .ugc-draft-form select, .ugc-draft-form textarea {
  width: 100%;
  margin-top: 4px;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(148,163,184,.4);
  color: var(--text-main);
  background: rgba(15, 23, 42, 0.55);
}
.ugc-draft-form textarea { min-height: 80px; resize: vertical; }
.ugc-draft-form input:focus-visible, .ugc-draft-form select:focus-visible, .ugc-draft-form textarea:focus-visible {
  outline: none;
  border-color: rgba(56, 189, 248, 0.85);
  box-shadow: var(--accent-glow);
}
.ugc-coords-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.ugc-field-errors { display: grid; gap: 4px; }
.ugc-form-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.ugc-form-actions button[disabled] { opacity: .55; cursor: not-allowed; }
.ugc-form-busy {
  opacity: 0.92;
}
.ugc-form-busy .ugc-form-actions button,
.ugc-form-busy #ugc-use-map-center-btn {
  cursor: progress;
}
.ugc-draft-item strong,
.ugc-draft-meta,
.ugc-field-errors,
.field-error-message { overflow-wrap: anywhere; }

.moderation-workspace {
  position: fixed;
  top: 84px;
  right: 12px;
  bottom: 206px;
  z-index: var(--z-workspace);
  width: min(980px, calc(100vw - 24px));
  padding: var(--space-lg);
  display: grid;
  grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
  grid-template-rows: auto 1fr;
  gap: 12px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px) scale(0.99);
  transition: opacity var(--motion-normal) var(--ease-standard), transform var(--motion-soft) var(--ease-standard), visibility 0ms linear var(--motion-soft);
}
.moderation-workspace.is-open { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0) scale(1); }
.moderation-head { grid-column: 1 / -1; }
.moderation-head h2 { margin: 0; font: 600 16px/1.25 Inter, Arial, sans-serif; }
.moderation-head-actions { display: flex; align-items: center; gap: 8px; }
.moderation-list-area, .moderation-review-area {
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: var(--radius-lg);
  background: rgba(15, 23, 42, 0.45);
  padding: var(--space-md);
  min-height: 0;
}
.moderation-list-area { display: flex; flex-direction: column; gap: 10px; overflow: hidden; }
.moderation-filters { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 8px; }
.moderation-filters input, .moderation-filters select, .moderation-reject-card textarea {
  width: 100%;
  border-radius: var(--radius-md);
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: rgba(15, 23, 42, 0.55);
  color: var(--text-main);
  padding: var(--space-sm) var(--space-md);
}
.moderation-filters input:focus-visible, .moderation-filters select:focus-visible, .moderation-reject-card textarea:focus-visible { outline: none; border-color: rgba(56, 189, 248, 0.85); box-shadow: var(--accent-glow); }
.moderation-filters #moderation-clear-search { white-space: nowrap; }
.moderation-list { display: flex; flex-direction: column; gap: 8px; overflow: auto; }
.moderation-item { width: 100%; text-align: left; border-radius: 12px; padding: var(--space-md); background: rgba(30, 41, 59, 0.52); border: 1px solid rgba(148, 163, 184, 0.24); }
.moderation-item.is-selected { border-color: rgba(56, 189, 248, 0.8); background: rgba(14, 116, 144, 0.22); }
.moderation-item-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 6px; }
.moderation-item-meta { margin: 0; color: var(--text-muted); font: var(--font-meta); }
.moderation-status-badge {
  display: inline-flex;
  align-items: center;
  text-transform: capitalize;
}
.moderation-review-area { overflow: auto; display: grid; gap: 10px; align-content: start; overscroll-behavior: contain; }
.moderation-list { overscroll-behavior: contain; }
.moderation-hero { min-height: 150px; border-radius: 12px; border: 1px solid rgba(148, 163, 184, 0.25); background: rgba(15, 23, 42, 0.48); overflow: hidden; display: flex; align-items: center; justify-content: center; }
.moderation-hero img { width: 100%; max-height: 220px; object-fit: cover; display: block; }
.moderation-hero-empty { color: var(--text-muted); }
.moderation-review-title-row { display: flex; justify-content: space-between; gap: 8px; align-items: center; }
.moderation-review-title-row h3 { margin: 0; font-size: 18px; }
.moderation-review-title-row h3,
.moderation-review-block p,
.moderation-meta-value,
.moderation-item-meta { overflow-wrap: anywhere; }
.moderation-review-sub { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 6px; }
.moderation-meta-pill {
  border-color: var(--state-muted-border);
  background: var(--state-muted-bg-soft);
  color: var(--text-muted);
  font: var(--font-meta);
}
.moderation-review-main { display: grid; gap: 8px; }
.moderation-review-block { border-radius: var(--radius-md); background: rgba(15, 23, 42, 0.5); border: 1px solid rgba(148, 163, 184, 0.2); padding: var(--space-sm) var(--space-md); }
.moderation-review-block h4 { margin: 0 0 6px; font: var(--font-caption); text-transform: uppercase; color: #bfdbfe; letter-spacing: .04em; }
.moderation-review-block p { margin: 0; color: var(--text-main); font: var(--font-body); white-space: pre-wrap; }
.moderation-review-meta { display: grid; gap: 6px; border-radius: var(--radius-md); border: 1px solid rgba(148, 163, 184, 0.2); background: rgba(15, 23, 42, 0.42); padding: var(--space-md); }
.moderation-meta-row { display: grid; grid-template-columns: 180px 1fr; gap: var(--space-sm); font: var(--font-body); align-items: baseline; }
.moderation-meta-label { color: var(--text-muted); }
.moderation-meta-value { color: var(--text-soft); }
.moderation-meta-row a { color: #93c5fd; word-break: break-all; }
.moderation-review-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.moderation-review-actions .app-state-block {
  width: 100%;
}
.moderation-approve-btn { border-color: rgba(52, 211, 153, 0.6); background: rgba(6, 78, 59, 0.38); }
.moderation-reject-btn { border-color: rgba(248, 113, 113, 0.56); background: rgba(127, 29, 29, 0.34); }
.moderation-reject-modal { position: fixed; inset: 0; z-index: var(--z-modal); background: rgba(2, 6, 23, 0.55); display: grid; place-items: center; padding: 12px; }
.moderation-reject-card { width: min(500px, calc(100vw - 24px)); padding: 14px; display: grid; gap: 10px; }
.moderation-reject-card h3 { margin: 0; }
.moderation-reject-card textarea { min-height: 110px; resize: vertical; }
.moderation-reject-actions { display: flex; justify-content: flex-end; gap: 8px; }

/* Shared state matrix helpers */
.is-loading {
  position: relative;
}
.is-loading::after {
  content: '';
  display: inline-block;
  width: 0.9em;
  height: 0.9em;
  margin-left: 0.45em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  vertical-align: -2px;
}
.is-success { border-color: var(--state-success-border) !important; }
.is-warning { border-color: var(--state-warning-border) !important; }
.is-error, .is-invalid { border-color: var(--state-error-border) !important; }

.ui-button-primary { border-color: rgba(56, 189, 248, 0.62); background: rgba(14, 116, 144, 0.32); }
.ui-button-primary:hover { border-color: rgba(56, 189, 248, 0.9); background: rgba(14, 116, 144, 0.45); }
.ui-button-secondary { background: rgba(255, 255, 255, 0.08); }
.ui-button-danger { border-color: rgba(248, 113, 113, 0.56); background: rgba(127, 29, 29, 0.34); }
.ui-button-success { border-color: rgba(52, 211, 153, 0.6); background: rgba(6, 78, 59, 0.38); }

:is(.app-system-banner-btn, .app-state-action-btn, .detail-actions button, .ugc-form-actions button, .ugc-draft-actions button, .moderation-head-actions button, .moderation-review-actions button, .moderation-reject-actions button, .floating-card-close):focus-visible {
  outline: none;
  border-color: rgba(56, 189, 248, 0.82);
  box-shadow: var(--accent-glow);
}

:is(.app-system-banner-btn, .app-state-action-btn, .detail-actions button, .ugc-form-actions button, .ugc-draft-actions button, .moderation-head-actions button, .moderation-review-actions button, .moderation-reject-actions button)[disabled] {
  background: var(--state-muted-bg-soft);
  border-color: rgba(148, 163, 184, 0.24);
}

@keyframes spin { to { transform: rotate(360deg); } }

@media (max-width: 920px) {
  #top-header { grid-template-columns: minmax(180px, 1fr) minmax(128px, 1fr) auto; padding: 8px 10px; }
  .top-actions > button { padding: 0 9px; font-size: 12px; }
  .project-nav-link { padding: 0 8px; }
  .project-nav-link:nth-last-child(-n+2) { display: none; }
  :root {
    --bottom-panel-side-gap: 10px;
    --bottom-panel-max-width: 760px;
  }
  #bottom-panel { padding: 10px; }
  .ribbon-card { min-width: 184px; max-width: 200px; }
  .detail-panel { width: clamp(332px, 34vw, 392px); }
  .detail-panel.is-full-mode { width: clamp(350px, 36vw, 420px); }
  .ugc-panel { right: 10px; top: 80px; bottom: 202px; width: min(430px, calc(100vw - 20px)); }
  .moderation-workspace { right: 10px; top: 80px; bottom: 202px; width: min(980px, calc(100vw - 20px)); }
}

@media (max-width: 720px) {
  :root {
    --bottom-panel-height: 84px;
    --bottom-panel-side-gap: 8px;
    --bottom-panel-max-width: none;
    --bottom-panel-right-reserve: 0px;
    --bottom-panel-center-shift: 0px;
    --workspace-strip-height: 76px;
  }
  #global-search { height: 38px; padding: 8px 38px 8px 12px; }
  .top-shell-left { gap: 8px; }
  .project-nav-link { padding: 0 7px; min-height: 32px; }
  .project-nav-link:nth-child(n+4) { display: none; }
  .profile-trigger-label { display: none; }
  .top-actions { gap: 6px; }
  .top-actions > button, .top-actions-cluster > button, .icon-btn { height: 34px; }
  .ribbon-card { min-width: 168px; max-width: 182px; }
  .ugc-panel { left: 8px; right: 8px; width: auto; top: 72px; bottom: 194px; }
  .moderation-workspace { left: 8px; right: 8px; width: auto; top: 72px; bottom: 194px; grid-template-columns: 1fr; }
  .moderation-meta-row { grid-template-columns: 1fr; }
}



.detail-panel-actions { display: inline-flex; gap: 6px; }
.search-dropdown { max-height: min(52vh, 420px); overflow: auto; }

.top-actions.is-collapsed > button:not(#ugc-create-btn):not(#overflow-btn):not(#moderation-toggle-btn),
.top-actions.is-collapsed > .top-utility-group > :not(#ugc-create-btn):not(#moderation-toggle-btn):not(.profile-shell) {
  display: none;
}
.top-actions.is-collapsed.is-expanded {
  position: absolute;
  right: 8px;
  top: calc(100% + 8px);
  border-radius: 12px;
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border);
  padding: 8px;
  flex-direction: column;
  align-items: stretch;
  min-width: 170px;
  z-index: var(--z-top-dropdown);
}
.top-actions.is-collapsed.is-expanded > button,
.top-actions.is-collapsed.is-expanded > .top-utility-group { display: block; width: 100%; }
.top-actions.is-collapsed.is-expanded > .top-utility-group {
  display: grid;
  gap: 8px;
}
.top-actions.is-collapsed.is-expanded > .top-utility-group > button,
.top-actions.is-collapsed.is-expanded > .top-utility-group > .profile-shell > .profile-trigger {
  width: 100%;
}
.maplibregl-ctrl-top-right,
.maplibregl-ctrl-top-left {
  top: var(--map-controls-safe-top);
  z-index: var(--z-map-controls);
}
.maplibregl-ctrl-top-right { right: calc(10px + var(--safe-right)); }
.maplibregl-ctrl-top-left { left: calc(10px + var(--safe-left)); }
#app-shell.has-right-detail .maplibregl-ctrl-top-right {
  right: calc(10px + var(--safe-right));
}
.maplibregl-ctrl-group {
  border-radius: 8px !important;
  overflow: hidden;
  border: 1px solid rgba(74, 91, 112, 0.46) !important;
  background: rgba(16, 24, 36, 0.9) !important;
  box-shadow: 0 1px 3px rgba(2, 6, 23, 0.16) !important;
}
.maplibregl-ctrl-group button {
  width: 34px !important;
  height: 34px !important;
  background: transparent !important;
}
.maplibregl-ctrl-group button + button {
  border-top-color: rgba(148, 163, 184, 0.22) !important;
}
.maplibregl-ctrl button.maplibregl-ctrl-zoom-in .maplibregl-ctrl-icon,
.maplibregl-ctrl button.maplibregl-ctrl-zoom-out .maplibregl-ctrl-icon,
.maplibregl-ctrl button.maplibregl-ctrl-compass .maplibregl-ctrl-icon {
  opacity: 0.88;
  filter: brightness(1.1) saturate(0.65);
}
.maplibregl-popup.artemis-popup {
  display: none !important;
}

#map .maplibregl-canvas {
  transition: filter 220ms ease;
}
#map.map-theme-dark .maplibregl-canvas {
  filter: brightness(0.98) contrast(1.04) saturate(0.88);
}
#map.map-theme-graphite .maplibregl-canvas {
  filter: brightness(1.02) contrast(1.02) saturate(0.78);
}
#map.map-theme-soft .maplibregl-canvas {
  filter: brightness(1.05) contrast(0.95) saturate(0.72);
}

@media (max-width: 1080px) {
  #workspace-main,
  #app-shell.has-right-detail #workspace-main {
    grid-template-columns: minmax(0, 1fr);
    column-gap: 0;
  }
  #explore-toolbar-shell {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: var(--z-map-controls);
    padding-top: 0;
  }
  .map-tools-shell {
    width: auto;
    min-width: 0;
    flex-direction: row;
    align-items: center;
  }
  .workspace-strip-tools > .top-panel,
  #explore-toolbar-shell > #courses-panel,
  #explore-toolbar-shell > #live-panel {
    top: calc(100% + 8px);
    left: 0;
    right: auto;
  }
  #map-container,
  #app-shell.has-right-detail #map-container {
    grid-column: 1;
  }
  .detail-panel {
    grid-column: 1;
  }
  #top-header { grid-template-columns: minmax(190px, 1fr) minmax(140px, 1fr) auto; min-height: 52px; }
  .brand { font-size: 13px; letter-spacing: 0.05em; }
  .project-nav-link:nth-last-child(-n+1) { display: none; }
  .top-actions > button, .icon-btn, .floating-card-close, .chip { min-height: 40px; }
  .timeline-head { row-gap: 8px; }
}

@media (max-width: 1280px) {
  #top-header { grid-template-columns: minmax(220px, 0.95fr) minmax(300px, 1.2fr) minmax(320px, 1fr); }
  .project-nav-link:nth-last-child(-n+1) { display: none; }
  .top-actions { gap: 8px; }
  .top-actions-cluster { gap: 6px; }
}


@media (max-width: 1080px) {
  #research-context-bar { gap: 6px; }
  .workspace-strip-context { grid-template-columns: minmax(0, 1fr); gap: 6px; }
  .research-context-actions { justify-content: flex-start; }
  .workspace-tab-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .top-actions-cluster { gap: 6px; padding: 3px 7px; }
  .quick-layer-filter {
    display: inline-flex;
    max-width: 180px;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .quick-layer-filter::-webkit-scrollbar { display: none; }
  .quick-layer-filter-btn {
    min-height: 26px;
    padding: 0 7px;
  }
  .layers-entry-helper { display: none; }
}
@media (max-width: 720px) {
  #workspace-frame {
    padding: calc(6px + var(--safe-top)) calc(6px + var(--safe-right)) calc(6px + var(--safe-bottom)) calc(6px + var(--safe-left));
  }
  .quick-layer-filter { max-width: 132px; }
  #top-header { min-height: 50px; padding: 6px 8px; }
  #top-header { grid-template-columns: minmax(0, 1fr) auto; column-gap: 6px; min-height: 46px; padding: 5px 8px; }
  .top-shell-left { grid-template-columns: 1fr; gap: 0; }
  .project-nav,
  .search-shell { display: none; }
  .top-actions { grid-template-columns: auto auto; gap: 4px; }
  .brand { font-size: 12px; }
  #research-context-bar {
    padding: 5px 8px;
    gap: 5px;
  }
  #research-context-bar .research-context-meta {
    display: none;
  }
  .workspace-strip-context {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 6px;
  }
  #research-context-bar .research-context-actions {
    overflow-x: auto;
    scrollbar-width: none;
  }
  #research-context-bar .research-context-actions::-webkit-scrollbar { display: none; }
  #explore-toolbar-shell {
    padding: 0;
  }
  #explore-workspace-panel {
    padding: 8px;
  }
  .top-actions-cluster {
    padding: 4px 6px;
    gap: 5px;
  }
  .workspace-secondary-entry {
    min-height: 28px;
    padding: 0 8px;
    font-size: 11px;
  }
  #bottom-panel {
    min-height: 84px;
    width: 100%;
    max-width: none;
    padding: 8px 10px;
    gap: 0;
  }
  .timeline-track-wrap { height: 34px; }
  .timeline-track-wrap {
    --timeline-track-center: 12px;
    --timeline-track-thickness: 3px;
    --timeline-track-inactive-thickness: 5px;
    --timeline-knob-size: 16px;
  }
  .timeline-axis { top: 20px; font-size: 9px; }
  .timeline-anchor-label { display: none; }
  .timeline-anchor-year { font-size: 9px; }
  .timeline-mode-toggle { margin-left: auto; }
  .ribbon-card { min-width: 148px; max-width: 160px; }
  .ribbon-card img { height: 76px; }
  .detail-panel {
    position: fixed;
    z-index: var(--z-detail-panel);
    top: auto;
    left: calc(8px + var(--safe-left));
    right: calc(8px + var(--safe-right));
    bottom: calc(8px + var(--safe-bottom));
    width: auto;
    max-height: min(72vh, 620px);
    transform: translateY(calc(100% - 68px));
    border-radius: 16px 16px 12px 12px;
  }
  .detail-panel.is-open { transform: translateY(calc(100% - 68px)); }
  .detail-panel.is-mobile-sheet.is-expanded { transform: translateY(0); }
  .detail-panel.is-mobile-sheet.is-expanded {
    box-shadow: 0 8px 18px rgba(2, 6, 23, 0.2);
    border-color: rgba(148, 163, 184, 0.24);
  }
  .detail-panel-body { max-height: calc(72vh - 72px); }
  .detail-action-zone-group { grid-template-columns: 1fr; }
  .ugc-panel {
    left: max(4px, var(--safe-left));
    right: max(4px, var(--safe-right));
    top: max(4px, var(--safe-top));
    bottom: max(4px, var(--safe-bottom));
    width: auto;
    border-radius: 14px;
    grid-template-rows: auto auto auto 1fr;
  }
  .ugc-draft-form { padding-bottom: 18px; }
  .moderation-workspace {
    left: max(4px, var(--safe-left));
    right: max(4px, var(--safe-right));
    top: max(4px, var(--safe-top));
    bottom: max(4px, var(--safe-bottom));
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
  }
  .moderation-mobile-back { display: inline-flex; }
  .moderation-workspace.is-mobile-review .moderation-list-area { display: none; }
  .moderation-workspace:not(.is-mobile-review) .moderation-review-area { display: none; }
  #error-banner, #loading-indicator { left: calc(8px + var(--safe-left)); right: calc(8px + var(--safe-right)); top: calc(64px + var(--safe-top)); width: auto; }
  .app-status-host {
    left: calc(8px + var(--safe-left));
    right: calc(8px + var(--safe-right));
    transform: none;
    top: calc(var(--top-header-height, 56px) + 10px + var(--safe-top));
    width: auto;
  }
  .status-panel {
    left: calc(8px + var(--safe-left));
    right: calc(8px + var(--safe-right));
    width: auto;
    bottom: calc(var(--bottom-panel-height) + 10px + var(--safe-bottom));
  }
  .offline-status { left: calc(8px + var(--safe-left)); right: calc(8px + var(--safe-right)); top: calc(64px + var(--safe-top)); max-width: none; }
}

@media (min-width: 721px) {
  .moderation-mobile-back { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
    scroll-behavior: auto !important;
  }
}
button[disabled], .chip[disabled], input[disabled], select[disabled], textarea[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
  filter: saturate(0.7);
}
#cards-ribbon .is-selected,
.moderation-item.is-selected,
.search-result-item.is-selected,
.chip.is-active {
  outline: 1px solid var(--state-selected-outline);
}
