/* src/main-frontend.css */
:root {
  color-scheme: light;
  --ui-scale: 0.76;
  --font-sans:
    "DM Sans",
    "Segoe UI",
    "Tahoma",
    "PingFang SC",
    "Microsoft YaHei",
    "Noto Sans Arabic",
    sans-serif;
  --bg: #eef3f9;
  --surface: #ffffff;
  --surface-soft: #f7f9fc;
  --surface-muted: #eef2f7;
  --sidebar-surface: rgba(255, 255, 255, 0.94);
  --signin-surface: rgba(255, 255, 255, 0.92);
  --text: #171c24;
  --muted: #697487;
  --muted-strong: #4d5666;
  --border: #d9e1ec;
  --border-strong: #cad5e3;
  --shadow:
    rgba(14, 63, 126, 0.04) 0 0 0 1px,
    rgba(42, 51, 69, 0.04) 0 1px 2px,
    rgba(42, 51, 70, 0.06) 0 18px 36px -24px;
  --blue: #1d74d8;
  --green: #18a058;
  --green-soft: #e3f7eb;
  --amber: #f0b44c;
  --amber-soft: #fff1d5;
  --pink: #df5ea6;
  --pink-soft: #fde6f2;
  --red: #e64b4b;
  --red-soft: #fde7e7;
  --neutral-soft: #e9eef5;
  --radius-sm: 14px;
  --radius-md: 18px;
  --radius-lg: 22px;
  --radius-xl: 28px;
  --primary-button-bg: #1e252f;
  --primary-button-text: #ffffff;
  --nav-active-bg: #20252d;
  --nav-active-text: #ffffff;
  --panel-glow: rgba(20, 43, 73, 0.12);
}
:root[data-theme=dark] {
  color-scheme: dark;
  --bg: #0f141a;
  --surface: #171e26;
  --surface-soft: #1d2530;
  --surface-muted: #141a22;
  --sidebar-surface: rgba(18, 24, 31, 0.96);
  --signin-surface: rgba(20, 26, 34, 0.92);
  --text: #eef2f8;
  --muted: #8f9aab;
  --muted-strong: #c2cad6;
  --border: #2a3441;
  --border-strong: #394657;
  --shadow: rgba(0, 0, 0, 0.35) 0 0 0 1px, rgba(0, 0, 0, 0.3) 0 18px 36px -24px;
  --blue: #67a8ff;
  --green: #4fd28f;
  --green-soft: rgba(79, 210, 143, 0.14);
  --amber: #ffc468;
  --amber-soft: rgba(255, 196, 104, 0.14);
  --pink: #ff8bc2;
  --pink-soft: rgba(255, 139, 194, 0.14);
  --red: #ff7e7e;
  --red-soft: rgba(255, 126, 126, 0.14);
  --neutral-soft: rgba(227, 236, 247, 0.12);
  --primary-button-bg: #eef2f8;
  --primary-button-text: #11161d;
  --nav-active-bg: #eef2f8;
  --nav-active-text: #11161d;
  --panel-glow: rgba(0, 0, 0, 0.28);
}
:root[data-theme=mono] {
  color-scheme: light;
  --bg: #f2f2f2;
  --surface: #ffffff;
  --surface-soft: #f5f5f5;
  --surface-muted: #ececec;
  --sidebar-surface: rgba(255, 255, 255, 0.95);
  --signin-surface: rgba(255, 255, 255, 0.94);
  --text: #151515;
  --muted: #686868;
  --muted-strong: #4b4b4b;
  --border: #d7d7d7;
  --border-strong: #c6c6c6;
  --blue: #2b2b2b;
  --green: #3d3d3d;
  --green-soft: #ebebeb;
  --amber: #565656;
  --amber-soft: #efefef;
  --pink: #4a4a4a;
  --pink-soft: #efefef;
  --red: #1f1f1f;
  --red-soft: #ededed;
  --neutral-soft: #ececec;
  --primary-button-bg: #101010;
  --primary-button-text: #ffffff;
  --nav-active-bg: #111111;
  --nav-active-text: #ffffff;
  --panel-glow: rgba(0, 0, 0, 0.1);
}
:root[data-theme=color] {
  color-scheme: light;
  --bg: #edf4ff;
  --surface: #ffffff;
  --surface-soft: #f7fbff;
  --surface-muted: #e8f1ff;
  --sidebar-surface: rgba(255, 255, 255, 0.95);
  --signin-surface: rgba(255, 255, 255, 0.9);
  --text: #162032;
  --muted: #5d6f91;
  --muted-strong: #3d4e70;
  --border: #cfe0ff;
  --border-strong: #bdd3ff;
  --blue: #1668e3;
  --green: #0ea37a;
  --green-soft: #dcf8ee;
  --amber: #ffaf2f;
  --amber-soft: #fff0d1;
  --pink: #d851ba;
  --pink-soft: #fde5f8;
  --red: #ef4a64;
  --red-soft: #ffe4ea;
  --neutral-soft: #e8eef9;
  --primary-button-bg:
    linear-gradient(
      135deg,
      #1f6ff0 0%,
      #8247ff 100%);
  --primary-button-text: #ffffff;
  --nav-active-bg:
    linear-gradient(
      135deg,
      #1b2433 0%,
      #2b3651 100%);
  --nav-active-text: #ffffff;
  --panel-glow: rgba(34, 84, 170, 0.16);
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html,
body,
#main-frontend-root {
  min-height: 100%;
}
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--bg);
}
button,
input,
select,
textarea {
  font: inherit;
}
button {
  cursor: pointer;
}
a {
  color: inherit;
  text-decoration: none;
}
.app-shell {
  min-height: 100vh;
}
.workspace-scale {
  zoom: var(--ui-scale);
}
@supports not (zoom: 1) {
  .workspace-scale {
    transform: scale(var(--ui-scale));
    transform-origin: top left;
    width: calc(100% / var(--ui-scale));
  }
}
.app-shell--loading,
.app-shell--denied {
  display: grid;
  place-items: center;
  background:
    linear-gradient(
      180deg,
      #f4f8fc 0%,
      #edf2f8 100%);
}
.app-shell--signin {
  display: grid;
  place-items: center;
  background-color: #eef3f9;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.signin-card {
  width: min(520px, calc(100vw - 64px));
  padding: 22px;
  display: grid;
  gap: 14px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(215, 224, 236, 0.9);
  box-shadow: 0 24px 60px rgba(20, 43, 73, 0.12);
  backdrop-filter: blur(18px);
}
.signin-card.is-invalid {
  border-color: rgba(230, 75, 75, 0.5);
  box-shadow: 0 24px 60px rgba(230, 75, 75, 0.16);
}
.signin-input {
  min-height: 62px;
  padding: 0 20px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(248, 250, 253, 0.95);
  color: var(--text);
  outline: none;
  transition:
    border-color 120ms ease,
    box-shadow 120ms ease,
    background 120ms ease;
}
.signin-input:focus {
  border-color: rgba(29, 116, 216, 0.4);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(29, 116, 216, 0.1);
}
.signin-button {
  min-height: 64px;
  border: 0;
  border-radius: 18px;
  background: #1e252f;
  color: #ffffff;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.denied-card {
  padding: 22px 28px;
  border-radius: 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  color: var(--red);
  font-weight: 700;
}
.loading-orb {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 4px solid rgba(29, 116, 216, 0.12);
  border-top-color: var(--blue);
  animation: spin 0.9s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.workspace-layout {
  min-height: calc(100vh / var(--ui-scale));
  display: grid;
  grid-template-columns: 264px minmax(0, 1fr);
  grid-template-areas: "sidebar main";
}
.workspace-sidebar {
  grid-area: sidebar;
}
.workspace-main {
  grid-area: main;
}
html[dir=rtl] .workspace-layout {
  direction: ltr;
  grid-template-columns: minmax(0, 1fr) 264px;
  grid-template-areas: "main sidebar";
}
html[dir=rtl] .workspace-sidebar,
html[dir=rtl] .workspace-main {
  direction: rtl;
}
.workspace-sidebar {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh / var(--ui-scale));
  background: rgba(255, 255, 255, 0.94);
  border-right: 1px solid var(--border);
  backdrop-filter: blur(20px);
}
html[dir=rtl] .workspace-sidebar {
  border-right: 0;
  border-left: 1px solid var(--border);
}
.workspace-brand {
  padding: 20px 18px 16px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px 14px;
  border-bottom: 1px solid var(--border);
}
.workspace-brand__mark {
  grid-row: 1 / span 2;
  width: 44px;
  height: 44px;
  border-radius: 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--blue);
  color: #ffffff;
  font-weight: 800;
}
.workspace-brand__copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-self: center;
}
.workspace-brand__copy strong {
  font-size: 1.04rem;
  line-height: 1.15;
}
.workspace-brand__copy span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.3;
}
.project-picker {
  position: relative;
  width: 100%;
}
.project-picker__trigger {
  width: 100%;
  min-height: 34px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-align: left;
}
.project-picker__trigger strong {
  font-size: 1.04rem;
  line-height: 1.15;
  font-weight: 700;
}
.project-picker__panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 40;
  padding: 8px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow);
  display: grid;
  gap: 6px;
}
html[dir=rtl] .project-picker__panel {
  left: auto;
}
.project-picker__item {
  width: 100%;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--text);
  display: grid;
  gap: 3px;
  text-align: left;
}
html[dir=rtl] .project-picker__item {
  text-align: right;
}
.project-picker__item:hover,
.project-picker__item.is-selected {
  background: var(--surface-soft);
}
.project-picker__item-title {
  font-weight: 600;
}
.project-picker__item-meta {
  color: var(--muted);
  font-size: 0.82rem;
}
.workspace-brand__controls {
  grid-column: 2;
  display: grid;
  gap: 8px;
  justify-items: start;
}
html[dir=rtl] .workspace-brand__controls {
  justify-items: end;
}
.workspace-live-pill {
  grid-column: 3;
  grid-row: 1 / span 2;
  align-self: start;
  justify-self: end;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--green-soft);
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1;
}
html[dir=rtl] .workspace-live-pill {
  justify-self: start;
}
.preference-menu {
  position: relative;
  display: inline-flex;
}
.preference-trigger {
  min-width: 42px;
  min-height: 38px;
  padding: 0 10px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition:
    background 140ms ease,
    border-color 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease;
}
.preference-trigger:hover,
.preference-menu.is-open .preference-trigger {
  background: var(--surface-soft);
  border-color: var(--border-strong);
}
.preference-trigger:focus-visible {
  outline: none;
  border-color: rgba(29, 116, 216, 0.45);
  box-shadow: 0 0 0 4px rgba(29, 116, 216, 0.12);
}
.preference-trigger__flag {
  font-size: 1.08rem;
  line-height: 1;
}
.icon-button {
  width: 42px;
  height: 38px;
  padding: 0;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.icon-button svg {
  width: 18px;
  height: 18px;
  display: block;
}
.preference-menu__panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 30;
  min-width: 184px;
  padding: 8px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow);
}
html[dir=rtl] .preference-menu__panel {
  left: auto;
  right: 0;
}
.preference-menu__panel--theme {
  min-width: 212px;
}
.preference-menu__item {
  width: 100%;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 0;
  background: transparent;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 10px;
  text-align: left;
  transition:
    background 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease;
}
html[dir=rtl] .preference-menu__item {
  text-align: right;
}
.preference-menu__item:hover,
.preference-menu__item.is-selected {
  background: var(--surface-soft);
}
.preference-menu__item.is-selected {
  box-shadow: inset 0 0 0 1px rgba(29, 116, 216, 0.18);
}
.preference-menu__item:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(29, 116, 216, 0.3);
}
.preference-menu__flag {
  width: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  line-height: 1;
}
.preference-menu__label {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 0.9rem;
  font-weight: 500;
  white-space: nowrap;
}
.theme-preview {
  width: 34px;
  height: 22px;
  flex: 0 0 34px;
  padding: 4px;
  border-radius: 9px;
  border: 1px solid var(--border);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3px;
  align-items: stretch;
}
.theme-preview span {
  display: block;
  border-radius: 999px;
}
.theme-preview.is-light {
  background:
    linear-gradient(
      135deg,
      #ffffff 0%,
      #edf3fb 100%);
}
.theme-preview.is-light span:nth-child(1) {
  background: #1d74d8;
}
.theme-preview.is-light span:nth-child(2) {
  background: #18a058;
}
.theme-preview.is-light span:nth-child(3) {
  background: #df5ea6;
}
.theme-preview.is-dark {
  background:
    linear-gradient(
      135deg,
      #171e26 0%,
      #283243 100%);
  border-color: rgba(255, 255, 255, 0.08);
}
.theme-preview.is-dark span:nth-child(1) {
  background: #67a8ff;
}
.theme-preview.is-dark span:nth-child(2) {
  background: #4fd28f;
}
.theme-preview.is-dark span:nth-child(3) {
  background: #ff8bc2;
}
.theme-preview.is-mono {
  background:
    linear-gradient(
      135deg,
      #ffffff 0%,
      #dedede 100%);
}
.theme-preview.is-mono span:nth-child(1) {
  background: #111111;
}
.theme-preview.is-mono span:nth-child(2) {
  background: #585858;
}
.theme-preview.is-mono span:nth-child(3) {
  background: #c2c2c2;
}
.theme-preview.is-color {
  background:
    linear-gradient(
      135deg,
      #eff6ff 0%,
      #f7ebff 100%);
}
.theme-preview.is-color span:nth-child(1) {
  background: #1668e3;
}
.theme-preview.is-color span:nth-child(2) {
  background: #0ea37a;
}
.theme-preview.is-color span:nth-child(3) {
  background: #d851ba;
}
.workspace-search {
  padding: 16px 14px 0;
}
.workspace-search input {
  width: 100%;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid transparent;
  background: var(--surface-muted);
  outline: none;
  font-size: 0.84rem;
}
.workspace-search input:focus {
  border-color: rgba(29, 116, 216, 0.35);
  background: #ffffff;
}
.search-results-panel {
  margin: 12px 18px 0;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.96);
  display: grid;
  gap: 12px;
  max-height: 360px;
  overflow: auto;
}
.search-results-panel__header,
.search-results-group__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.search-results-panel__header span,
.search-results-group__header span,
.search-results-panel__state {
  color: var(--muted);
  font-size: 0.82rem;
}
.search-results-panel__state--error {
  color: var(--red);
}
.search-results-group,
.search-results-group__list {
  display: grid;
  gap: 8px;
}
.search-hit {
  width: 100%;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  text-align: left;
}
.search-hit--static {
  cursor: default;
}
.search-hit strong,
.search-hit span {
  display: block;
}
.search-hit span {
  margin-top: 6px;
  color: var(--muted);
  font-size: 0.82rem;
}
.workspace-nav {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  padding: 12px 10px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.workspace-nav__group {
  display: grid;
  gap: 6px;
}
.workspace-nav__section-title {
  padding: 0 4px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.workspace-nav__items {
  display: grid;
  gap: 4px;
}
.workspace-nav__node {
  display: grid;
  gap: 4px;
}
.workspace-nav__row {
  display: flex;
  align-items: center;
  min-height: 42px;
  border-radius: 14px;
  color: var(--text);
  transition:
    background 140ms ease,
    color 140ms ease,
    box-shadow 140ms ease,
    border-color 140ms ease;
}
.workspace-nav__row:hover {
  background: rgba(239, 243, 248, 0.92);
}
.workspace-nav__row.is-branch-active {
  background: rgba(244, 247, 251, 0.95);
}
.workspace-nav__row.is-active {
  background: #20252d;
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(33, 40, 48, 0.14);
}
.workspace-nav__entry-main,
.workspace-nav__entry-toggle {
  border: 0;
  background: transparent;
  color: inherit;
}
.workspace-nav__entry-main {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 42px;
  padding: 8px 11px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-align: left;
}
.workspace-nav__entry-leading {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 9px;
}
.workspace-nav__entry-icon {
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
  opacity: 0.9;
}
.workspace-nav__entry-icon svg {
  width: 17px;
  height: 17px;
  display: block;
}
.workspace-nav__dot {
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.58;
}
.workspace-nav__entry-label {
  min-width: 0;
  font-size: 1.02rem;
  font-weight: 500;
  line-height: 1.22;
  letter-spacing: -0.01em;
}
.workspace-nav__entry-badge {
  min-width: 22px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  border: 1px solid rgba(218, 226, 237, 0.95);
  background: #f4f7fb;
  color: var(--muted-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.74rem;
  font-weight: 600;
  line-height: 1;
}
.workspace-nav__row.is-active .workspace-nav__entry-badge {
  border-color: rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
}
.workspace-nav__entry-toggle {
  width: 28px;
  height: 28px;
  margin-right: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  opacity: 0.52;
  border-radius: 999px;
  transition: background 140ms ease, opacity 140ms ease;
}
.workspace-nav__entry-toggle:hover {
  background: rgba(227, 233, 242, 0.7);
  opacity: 1;
}
.workspace-nav__row.is-active .workspace-nav__entry-toggle:hover {
  background: rgba(255, 255, 255, 0.1);
}
.workspace-nav__entry-toggle.is-open {
  opacity: 1;
}
.workspace-nav__chevron-icon {
  width: 14px;
  height: 14px;
  display: block;
  transition: transform 140ms ease;
}
.workspace-nav__chevron-icon.is-open {
  transform: rotate(180deg);
}
.workspace-nav__children {
  display: grid;
  gap: 4px;
  padding-left: 14px;
  border-left: 1px solid rgba(210, 219, 231, 0.65);
  margin-left: 15px;
}
html[dir=rtl] .workspace-nav__entry-main {
  text-align: right;
}
html[dir=rtl] .workspace-nav__entry-toggle {
  margin-right: 0;
  margin-left: 6px;
}
html[dir=rtl] .workspace-nav__children {
  padding-left: 0;
  padding-right: 14px;
  border-left: 0;
  border-right: 1px solid rgba(210, 219, 231, 0.65);
  margin-left: 0;
  margin-right: 15px;
}
.workspace-nav__node.is-depth-1 .workspace-nav__entry-label {
  font-size: 0.96rem;
  font-weight: 500;
}
.workspace-nav__node.is-depth-2 .workspace-nav__entry-label,
.workspace-nav__node.is-depth-3 .workspace-nav__entry-label {
  font-size: 0.92rem;
  font-weight: 500;
}
.workspace-nav__node.is-depth-1 .workspace-nav__row,
.workspace-nav__node.is-depth-2 .workspace-nav__row,
.workspace-nav__node.is-depth-3 .workspace-nav__row {
  min-height: 34px;
  border-radius: 12px;
}
.workspace-nav__node.is-depth-1 .workspace-nav__entry-main,
.workspace-nav__node.is-depth-2 .workspace-nav__entry-main,
.workspace-nav__node.is-depth-3 .workspace-nav__entry-main {
  min-height: 34px;
  padding: 6px 9px;
}
.workspace-user {
  margin-top: auto;
  padding: 18px 18px 22px;
  border-top: 1px solid var(--border);
  display: grid;
  gap: 14px;
}
.workspace-user__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}
.workspace-user__identity {
  display: flex;
  align-items: center;
  gap: 12px;
}
.workspace-user__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #d8ebff;
  color: var(--blue);
  font-weight: 800;
}
.workspace-user__copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.workspace-user__copy strong {
  font-size: 0.96rem;
}
.workspace-user__copy span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.84rem;
}
.workspace-user__logout {
  justify-self: end;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--muted-strong);
}
.workspace-user__account {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--muted-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.workspace-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding: 36px 38px 40px;
  gap: 18px;
}
.workspace-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.workspace-header h1 {
  margin: 0;
  font-size: 2rem;
  line-height: 1.04;
}
.workspace-header p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 0.98rem;
}
.primary-button,
.secondary-button {
  min-height: 48px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
}
.primary-button {
  border: 0;
  background: #1f2630;
  color: #ffffff;
  font-weight: 700;
}
.secondary-button {
  background: var(--surface-soft);
  color: var(--muted-strong);
}
.danger-button {
  min-height: 48px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid rgba(230, 75, 75, 0.18);
  background: #fff4f4;
  color: #b63b3b;
}
.secondary-button--link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.workspace-banner,
.workspace-error {
  min-height: 52px;
  padding: 0 18px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.92);
}
.workspace-banner {
  color: var(--muted-strong);
}
.workspace-error {
  color: var(--red);
  border-color: rgba(230, 75, 75, 0.24);
  background: var(--red-soft);
}
.workspace-loading-panel {
  min-height: 280px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.workspace-content {
  display: grid;
  gap: 22px;
}
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 18px;
}
.metric-card {
  min-height: 150px;
  padding: 22px;
  display: grid;
  align-content: start;
  justify-items: start;
  gap: 12px;
  border-radius: var(--radius-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.metric-card strong {
  display: block;
  font-size: 2.1rem;
  line-height: 0.96;
}
.metric-card span:last-child {
  color: var(--muted);
  display: block;
  margin-top: -2px;
}
.metric-card__tone {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: block;
}
.tone-blue {
  background: #e3f0ff;
}
.tone-green {
  background: var(--green-soft);
}
.tone-amber {
  background: var(--amber-soft);
}
.tone-pink {
  background: var(--pink-soft);
}
.tone-neutral {
  background: var(--neutral-soft);
}
.dashboard-grid,
.workspace-grid {
  display: grid;
  gap: 22px;
}
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.catalog-card {
  min-width: 0;
  padding: 18px 18px 16px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background:
    linear-gradient(
      180deg,
      #ffffff,
      #f8fbff);
  display: grid;
  gap: 10px;
}
.catalog-card__eyebrow {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.catalog-card strong {
  font-size: 1.04rem;
}
.catalog-card p {
  margin: 0;
  color: var(--muted-strong);
  line-height: 1.5;
}
.bullet-list {
  display: grid;
  gap: 12px;
}
.bullet-list__item {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  align-items: flex-start;
  gap: 12px;
}
.bullet-list__dot {
  width: 10px;
  height: 10px;
  margin-top: 6px;
  border-radius: 50%;
  background: #1f2630;
}
.bullet-list__item p {
  margin: 0;
  color: var(--muted-strong);
  line-height: 1.5;
}
.dashboard-grid {
  grid-template-columns: minmax(0, 1.3fr) minmax(320px, 0.7fr);
}
.workspace-grid--three {
  grid-template-columns: minmax(300px, 0.78fr) minmax(0, 1.14fr) minmax(320px, 0.88fr);
}
.workspace-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.panel-card {
  min-width: 0;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
}
.panel--wide {
  min-height: 460px;
}
.panel--full {
  grid-column: 1 / -1;
}
.panel-card__header {
  padding: 22px 22px 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.panel-card__header h2 {
  margin: 0;
  font-size: 1.32rem;
}
.panel-card__header p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 0.92rem;
}
.panel-card__body {
  padding: 20px 22px 22px;
  flex: 1 1 auto;
  min-height: 0;
}
.panel-link {
  min-height: 40px;
  padding: 0 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--muted-strong);
}
.filter-toolbar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.filter-toolbar__field {
  display: grid;
  gap: 6px;
}
.filter-toolbar__field span {
  color: var(--muted);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.filter-toolbar__field select {
  min-height: 40px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--text);
  padding: 0 12px;
}
.chip-list {
  display: grid;
  gap: 10px;
}
.chip-list__item {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  text-align: left;
}
.chip-list__item.is-active {
  border-color: rgba(29, 116, 216, 0.3);
  background: #f0f6ff;
}
.chip-list__item strong,
.chip-list__item span {
  display: block;
}
.chip-list__item span {
  color: var(--muted);
  font-size: 0.82rem;
  margin-top: 4px;
}
.stack {
  display: grid;
  gap: 22px;
}
.detail-stack,
.split-column {
  display: grid;
  gap: 18px;
}
.form-stack {
  display: grid;
  gap: 12px;
}
.form-stack--compact {
  margin-top: 14px;
}
.form-stack input,
.form-stack select,
.form-stack textarea {
  width: 100%;
  min-height: 46px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--text);
  outline: none;
}
.form-stack textarea {
  resize: vertical;
  min-height: 92px;
}
.form-stack input:focus,
.form-stack select:focus,
.form-stack textarea:focus {
  border-color: rgba(29, 116, 216, 0.36);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(29, 116, 216, 0.1);
}
.form-row {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--muted-strong);
}
.checkbox-row input {
  width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
}
.selectable-list,
.compact-list,
.activity-feed {
  display: grid;
  gap: 12px;
}
.selectable-list__item,
.compact-list__item {
  width: 100%;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  text-align: left;
}
.selectable-list__item {
  border: 1px solid transparent;
}
.selectable-list__item:hover {
  background: #f4f7fb;
}
.selectable-list__item.is-active {
  border-color: rgba(29, 116, 216, 0.34);
  background: #f0f6ff;
  box-shadow: 0 10px 24px rgba(29, 116, 216, 0.08);
}
.selectable-list__item strong,
.compact-list__item strong,
.activity-feed__item strong {
  display: block;
}
.selectable-list__item span,
.compact-list__topline span,
.activity-feed__eyebrow {
  color: var(--muted);
  font-size: 0.84rem;
}
.selectable-list__item p,
.compact-list__item p,
.activity-feed__item p {
  margin: 10px 0 0;
  color: var(--muted-strong);
  line-height: 1.5;
}
.compact-list__topline,
.activity-feed__eyebrow {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.compact-list__item--link:hover {
  border-color: rgba(29, 116, 216, 0.24);
}
.inline-actions {
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 0.82rem;
}
.activity-feed__item {
  padding: 16px;
  border-radius: 16px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
}
.key-value-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.key-value-grid__item {
  min-height: 96px;
  padding: 14px 16px;
  border-radius: 16px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.key-value-grid__item span {
  color: var(--muted);
  font-size: 0.84rem;
}
.key-value-grid__item strong {
  line-height: 1.4;
}
.tag-cluster {
  display: grid;
  gap: 8px;
}
.tag-cluster__title {
  color: var(--muted);
  font-size: 0.84rem;
}
.tag-cluster__items {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tag-chip,
.tag-cluster__empty {
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  background: var(--surface-muted);
  color: var(--muted-strong);
}
.task-board {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.task-column {
  min-width: 0;
  border-radius: 18px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.task-column__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.task-column__header span {
  min-width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--surface);
  color: var(--muted-strong);
}
.task-column__body {
  display: grid;
  gap: 10px;
}
.task-card {
  padding: 14px;
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid var(--border);
  cursor: grab;
}
.task-card.is-selected {
  border-color: rgba(29, 116, 216, 0.34);
  box-shadow: 0 10px 24px rgba(29, 116, 216, 0.08);
}
.task-card__topline,
.task-card__footer {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.task-card p {
  margin: 10px 0;
  color: var(--muted-strong);
  line-height: 1.45;
}
.task-card__meta {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: 0.8rem;
}
.task-card__footer {
  color: var(--muted);
  font-size: 0.82rem;
}
.gantt-timeline {
  display: grid;
  gap: 14px;
}
.gantt-timeline__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.gantt-timeline__header span {
  color: var(--muted);
  font-size: 0.84rem;
}
.gantt-timeline__rows {
  display: grid;
  gap: 12px;
}
.gantt-row {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}
.gantt-row__meta {
  display: grid;
  gap: 4px;
}
.gantt-row__meta span {
  color: var(--muted);
  font-size: 0.82rem;
}
.gantt-row__track {
  min-height: 40px;
  border-radius: 14px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  position: relative;
}
.gantt-row__bar {
  position: absolute;
  top: 6px;
  bottom: 6px;
  min-width: 80px;
  padding: 0 12px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  background: #d9eaff;
  color: var(--blue);
  overflow: hidden;
}
.gantt-row__bar.is-blocked {
  background: #ffe7d9;
  color: #b96828;
}
.version-chain {
  display: grid;
  gap: 10px;
}
.version-chain__item {
  width: 100%;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  text-align: left;
}
.version-chain__item.is-active {
  border-color: rgba(29, 116, 216, 0.34);
  background: #f0f6ff;
}
.version-chain__topline,
.version-chain__meta,
.analytics-context__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.version-chain__item p {
  margin: 10px 0 0;
  color: var(--muted-strong);
}
.version-chain__meta {
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.82rem;
}
.analytics-context {
  display: grid;
  gap: 14px;
}
.analytics-context__group,
.analytics-context__items {
  display: grid;
  gap: 8px;
}
.analytics-context__header span {
  color: var(--muted);
  font-size: 0.82rem;
}
.analytics-context__item {
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface-soft);
}
.analytics-context__item strong,
.analytics-context__item span {
  display: block;
}
.analytics-context__item span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.8rem;
}
.analytics-context__item p {
  margin: 8px 0 0;
  color: var(--muted-strong);
  line-height: 1.45;
}
.results-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.results-strip--stacked {
  display: grid;
}
.result-tile {
  min-width: 220px;
  min-height: 92px;
  padding: 16px;
  border-radius: 18px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.result-tile strong {
  font-size: 1rem;
}
.result-tile span {
  color: var(--muted);
}
.empty-state {
  min-height: 120px;
  border-radius: 18px;
  border: 1px dashed var(--border-strong);
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--muted);
  background:
    linear-gradient(
      180deg,
      rgba(247, 249, 252, 0.85),
      rgba(242, 246, 251, 0.95));
  padding: 18px;
}
.empty-state--compact {
  min-height: 80px;
}
@media (max-width: 1500px) {
  .metrics-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .workspace-grid--three {
    grid-template-columns: minmax(300px, 0.84fr) minmax(0, 1fr);
  }
  .workspace-grid--three > :last-child {
    grid-column: 1 / -1;
  }
  .catalog-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 1180px) {
  .workspace-scale {
    zoom: 1;
  }
  .workspace-layout {
    grid-template-columns: 1fr;
  }
  .workspace-sidebar {
    min-height: auto;
  }
  .dashboard-grid,
  .workspace-grid--three,
  .workspace-grid--two,
  .metrics-grid {
    grid-template-columns: 1fr;
  }
  .workspace-main {
    padding: 24px 20px 28px;
  }
  .workspace-header {
    flex-direction: column;
  }
  .gantt-row {
    grid-template-columns: 1fr;
  }
}
