:root {
  --bg-1: #f4f7fb;
  --bg-2: #edf2f8;
  --panel: rgba(255,255,255,0.94);
  --panel-2: #f8fbff;
  --line: #dce5f1;
  --text: #102033;
  --muted: #5d6e82;
  --brand: #2563eb;
  --brand-2: #0ea5e9;
  --success: #15803d;
  --warning: #b45309;
  --danger: #b91c1c;
  --radius: 24px;
  --shadow: 0 24px 56px rgba(15, 23, 42, 0.08);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--text); background: linear-gradient(180deg, var(--bg-1) 0%, var(--bg-2) 100%); }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }
h1,h2,h3,p { margin: 0; }
img { max-width: 100%; display: block; }
label { display: block; font-size: .88rem; font-weight: 700; margin-bottom: 8px; color: var(--text); }
input, select, textarea {
  width: 100%; padding: 13px 15px; border-radius: 16px; border: 1px solid var(--line); background: #fff; color: var(--text);
  font: inherit; transition: border-color .18s ease, box-shadow .18s ease;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: #94b7ff; box-shadow: 0 0 0 4px rgba(37,99,235,.12); }
textarea { resize: vertical; min-height: 96px; }
input[type="color"] { padding: 8px; min-height: 48px; }
.button {
  appearance: none; border: 0; border-radius: 16px; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #fff;
  font-weight: 800; padding: 12px 18px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 48px;
  box-shadow: 0 12px 30px rgba(37,99,235,.18);
}
.button:hover { text-decoration: none; transform: translateY(-1px); }
.button.secondary { background: #fff; color: var(--brand); border: 1px solid #cfe0ff; box-shadow: none; }
.button.ghost { background: transparent; color: var(--text); border: 1px solid var(--line); box-shadow: none; }
.button.full { width: 100%; }
.auth-shell {
  min-height: 100vh; display: grid; place-items: center; padding: 24px;
  background: radial-gradient(circle at top, #dff1ff 0%, #eef5fb 36%, #f3f7fb 100%);
}
.auth-card, .card, .metric-card, .hero-card {
  background: var(--panel); border: 1px solid rgba(255,255,255,.85); border-radius: var(--radius); box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}
.auth-card { width: 100%; max-width: 500px; padding: 32px; }
.auth-brand { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.brand-logo { width: 56px; height: 56px; }
.brand-logo.large { width: 72px; height: 72px; }
.brand-kicker { color: var(--muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; }
.brand-name { font-size: 1.2rem; font-weight: 800; }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 290px 1fr; }
.sidebar {
  position: sticky; top: 0; height: 100vh; padding: 24px 18px; background: linear-gradient(180deg, rgba(10,20,40,.96), rgba(15,28,52,.94)); color: #e6eef8;
  border-right: 1px solid rgba(255,255,255,.08);
}
.brand-card {
  display: flex; align-items: center; gap: 14px; padding: 18px; border-radius: 24px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08);
}
.nav-stack { display: flex; flex-direction: column; gap: 8px; margin-top: 22px; }
.nav-link {
  display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-radius: 16px; color: #dbe8fb; transition: background .18s ease, transform .18s ease;
}
.nav-link:hover, .nav-link.active { background: rgba(255,255,255,.11); text-decoration: none; transform: translateX(2px); }
.nav-dot { width: 10px; height: 10px; border-radius: 999px; display: inline-block; flex: 0 0 10px; }
.sidebar-nav-shell {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.nav-stack-accordion { gap: 10px; }
.nav-accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 0;
}
.nav-accordion > summary {
  list-style: none;
  cursor: pointer;
}
.nav-accordion > summary::-webkit-details-marker { display: none; }
.nav-accordion-summary {
  justify-content: space-between;
}
.nav-accordion-context {
  margin-left: auto;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: .72rem;
  color: #aebfd4;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}
.nav-chevron {
  font-size: .82rem;
  color: #9eb1ca;
  transition: transform .18s ease;
}
.nav-accordion[open] .nav-chevron { transform: rotate(180deg); }
.nav-accordion-panel {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 2px 0 0 10px;
  max-height: min(42vh, 360px);
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.nav-accordion-panel::-webkit-scrollbar { display: none; }
.nav-link-sub {
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: .92rem;
  background: rgba(255,255,255,.03);
}
.nav-link-sub:hover,
.nav-link-sub.active { background: rgba(255,255,255,.11); }
.nav-empty-state {
  padding: 8px 14px 2px;
  color: #9eb1ca;
  font-size: .84rem;
}
.sidebar-foot {
  margin-top: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: transparent;
}
.user-box { padding: 16px; border-radius: 18px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); }
.user-name { font-weight: 800; }
.user-meta { color: #b9c9dc; font-size: .82rem; margin-top: 6px; }
.main-content { padding: 26px; display: flex; flex-direction: column; gap: 18px; }
.page-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.page-top h1 { font-size: 2rem; letter-spacing: -.03em; }
.page-subtitle { color: var(--muted); margin-top: 6px; }
.flash { padding: 14px 16px; border-radius: 16px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow); }
.flash.success { border-color: #c8ead4; background: #eefaf2; color: #115b2f; }
.flash.warning { border-color: #f6e1ad; background: #fff9ea; color: #8a5a00; }
.flash.danger { border-color: #f2c6c6; background: #fff2f2; color: #8a1c1c; }
.auth-flash { max-width: 500px; width: 100%; margin-bottom: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.workstream-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.card, .metric-card { padding: 22px; }
.metric-card { position: relative; overflow: hidden; }
.metric-card::after {
  content: ""; position: absolute; inset: auto -30px -30px auto; width: 100px; height: 100px; border-radius: 999px;
  background: radial-gradient(circle, rgba(37,99,235,.08), transparent 70%);
}
.metric-card-brand { background: linear-gradient(135deg, rgba(16,62,160,.92), rgba(14,165,233,.9)); color: #fff; }
.metric-card-brand .metric-label, .metric-card-brand .metric-foot { color: rgba(255,255,255,.82); }
.metric-card-alert { border-color: #f4c6c6; background: linear-gradient(180deg, #fff7f7 0%, #fff 100%); }
.metric-label, .mini-label, .eyebrow { color: var(--muted); font-size: .8rem; text-transform: uppercase; letter-spacing: .09em; }
.metric-value { font-size: 2rem; font-weight: 900; margin-top: 8px; letter-spacing: -.03em; }
.metric-value.sm { font-size: 1.18rem; }
.metric-foot { color: var(--muted); margin-top: 8px; }
.card-head { display: flex; justify-content: space-between; gap: 14px; align-items: center; margin-bottom: 18px; }
.card-head h2 { font-size: 1.15rem; }
.stack-md, .stack-lg { display: flex; flex-direction: column; }
.stack-md { gap: 14px; }
.stack-lg { gap: 18px; }
.stacked-chart { display: flex; flex-direction: column; gap: 16px; }
.stacked-row { display: grid; grid-template-columns: minmax(170px, 220px) 1fr; gap: 16px; align-items: center; }
.stacked-title { font-weight: 800; }
.stacked-meta { color: var(--muted); font-size: .9rem; margin-top: 4px; }
.stacked-bar-wrap { width: 100%; }
.stacked-bar {
  display: flex; min-height: 24px; border-radius: 999px; overflow: hidden; border: 1px solid #d8e2f0; background: #eef3f8;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.stack-segment { min-width: 10px; }
.stack-empty { flex: 1; background: linear-gradient(90deg, #edf3f8, #f8fbff); }
.legend-grid { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 18px; }
.legend-item { display: inline-flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 999px; background: #f6f9fd; border: 1px solid var(--line); font-size: .9rem; }
.gate-totals-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.gate-total-card { padding: 16px; border-radius: 20px; background: linear-gradient(180deg, #fcfdff 0%, #f6f9fd 100%); border: 1px solid var(--line); }
.workstream-card {
  display: block; background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%); border: 1px solid var(--line);
  border-radius: 22px; padding: 18px; color: var(--text);
}
.workstream-card:hover { text-decoration: none; transform: translateY(-1px); }
.workstream-card.is-stale { border-color: #f1c3c3; box-shadow: 0 16px 30px rgba(185,28,28,.08); }
.workstream-card-top { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.workstream-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 18px 0; }
.mini-value { font-size: 1rem; font-weight: 800; margin-top: 4px; }
.mini-status-line { display: flex; align-items: center; gap: 8px; font-size: .88rem; color: var(--muted); }
.pill {
  display: inline-flex; align-items: center; padding: 6px 10px; border-radius: 999px;
  background: #eef3ff; color: #1a3ca8; font-weight: 700; font-size: .8rem;
}
.pill.small { padding: 4px 8px; font-size: .72rem; }
.pill.success { background: #e7f7ec; color: var(--success); }
.pill.warning { background: #fff5df; color: var(--warning); }
.pill.danger { background: #feecec; color: var(--danger); }
.pill.neutral { background: #eef1f5; color: #516074; }
.bar-track {
  width: 100%; height: 12px; border-radius: 999px; background: #ebeff6; overflow: hidden; border: 1px solid #e2e8f0;
}
.bar-track.thin { height: 8px; }
.bar-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--brand) 0%, #75a1ff 100%); }
.gate-row { display: flex; flex-direction: column; gap: 8px; }
.gate-topline { display: flex; justify-content: space-between; gap: 10px; font-size: .92rem; }
.timeline { display: flex; flex-direction: column; gap: 14px; }
.timeline.large { gap: 18px; }
.timeline-item { display: grid; grid-template-columns: 18px minmax(0,1fr); gap: 12px; }
.timeline-dot {
  width: 10px; height: 10px; border-radius: 999px; background: var(--brand); margin-top: 7px;
  box-shadow: 0 0 0 5px rgba(37,99,235,.12);
}
.timeline-title, .timeline-title-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; font-weight: 800; }
.timeline-meta { color: var(--muted); font-size: .84rem; margin-top: 2px; }
.timeline-body { margin-top: 6px; color: var(--text); }
.reference-box {
  margin-top: 10px; padding: 12px 14px; background: #f7f9fd; border: 1px solid var(--line); border-radius: 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.table-wrap { overflow: auto; }
.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td { padding: 14px 12px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.data-table thead th { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); }
.table-sub { color: var(--muted); font-size: .85rem; margin-top: 4px; }
.compact td, .compact th { padding-top: 10px; padding-bottom: 10px; }
.row-stale td { background: linear-gradient(90deg, rgba(255,241,241,.7), rgba(255,255,255,0)); }
.filter-grid, .form-grid, .gate-name-grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px;
}
.filter-actions, .button-row { display: flex; gap: 10px; align-items: end; flex-wrap: wrap; }
.filter-actions { padding-top: 24px; }
.workstream-filter-form { align-items: end; row-gap: 12px; margin-bottom: 16px; }
.workstream-filter-form .filter-actions { padding-top: 0; }
.muted { color: var(--muted); }
.empty-state, .empty-cell { color: var(--muted); padding: 14px 0; }
.gate-strip {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 12px; margin-bottom: 18px;
}
.gate-node {
  padding: 12px; border-radius: 18px; background: #f7f9fd; border: 1px solid var(--line); text-align: center;
}
.gate-node.done { background: #eef5ff; border-color: #cddcff; }
.gate-node.current { background: linear-gradient(180deg, #eaf1ff 0%, #f4f7ff 100%); border-color: #b9cbff; }
.gate-bubble {
  width: 38px; height: 38px; border-radius: 999px; display: grid; place-items: center;
  margin: 0 auto 8px; background: #fff; font-weight: 800; border: 1px solid var(--line);
}
.gate-caption { font-size: .85rem; font-weight: 700; }
.chip-row { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.inline-progress { min-width: 120px; margin-top: 8px; }
.info-row {
  display: flex; justify-content: space-between; gap: 12px; padding: 12px 0; border-bottom: 1px dashed var(--line);
}
.info-row:last-child { border-bottom: 0; }
.field-note { color: var(--muted); font-size: .8rem; margin-top: 6px; }
.checkbox-wrap { display: flex; align-items: center; }
.checkbox-inline { display: flex; align-items: center; gap: 10px; margin-top: 28px; }
.checkbox-inline input { width: auto; }
.actions-cell { white-space: nowrap; }
.actions-cell > a,
.actions-cell > .inline-form,
.actions-cell > .tiny-link { display: inline-flex; align-items: center; vertical-align: middle; }
.actions-cell > .inline-form + .inline-form,
.actions-cell > .inline-form + a,
.actions-cell > a + .inline-form,
.actions-cell > a + a,
.actions-cell > .tiny-link + .inline-form,
.actions-cell > .tiny-link + a { margin-left: 12px; }
.actions-cell a, .actions-cell .tiny-link { display: inline-flex; align-items: center; line-height: 1.15; }
.inline-form { display: inline-flex; align-items: center; margin: 0; }
.tiny-link { background: none; border: 0; padding: 0; color: var(--brand); cursor: pointer; font: inherit; line-height: 1.15; }
.tiny-link.danger { color: var(--danger); }
.button-sm { padding: 8px 12px; min-height: auto; font-size: .84rem; }
.full { width: 100%; }
.color-chip { display: inline-flex; gap: 8px; align-items: center; }
.narrow { max-width: 980px; }
@media (max-width: 1240px) {
  .grid-4, .workstream-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 980px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .grid-2, .filter-grid, .form-grid, .gate-name-grid { grid-template-columns: 1fr; }
  .stacked-row { grid-template-columns: 1fr; gap: 10px; }
}
@media (max-width: 720px) {
  .main-content { padding: 18px; }
  .grid-4, .workstream-grid { grid-template-columns: 1fr; }
  .page-top { flex-direction: column; }
  .actions-cell { white-space: normal; }
  .actions-cell > a,
  .actions-cell > .inline-form,
  .actions-cell > .tiny-link { display: flex; margin-left: 0 !important; margin-top: 6px; }
  .actions-cell > *:first-child { margin-top: 0; }
}

.sidebar .sidebar-ghost { color: #e6eef8; border-color: rgba(255,255,255,.18); }
.sidebar .sidebar-ghost:hover { color: #ffffff; background: rgba(255,255,255,.08); }
.auth-card h1 { margin-top: 8px; }
.hero-card { display: grid; grid-template-columns: 1.35fr .95fr; gap: 22px; padding: 24px; }
.hero-left { display: flex; flex-direction: column; gap: 12px; }
.hero-right { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.hero-description { color: var(--text); line-height: 1.55; }
.metric-tile { padding: 18px; border-radius: 18px; background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%); border: 1px solid var(--line); }
.filter-card { padding-bottom: 10px; }
.dashboard-filters { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.checkbox-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
select[multiple] { min-height: 130px; }
.num, .num-input { text-align: right; font-variant-numeric: tabular-nums; }
.data-table th.num, .data-table td.num { text-align: right; }
.metric-value.num, .mini-value.num, .gate-chart-total.num { text-align: right; }
.gate-panel-card { overflow: hidden; }
.gate-panel-grid, .gate-summary-grid {
  display: grid; grid-template-columns: repeat(var(--gate-columns, 5), minmax(0, 1fr)); gap: 18px;
}
.gate-panel-grid { align-items: end; min-height: 360px; }
.gate-panel-summary { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--line); }
.gate-summary-head { margin-bottom: 14px; }
.gate-summary-head h3 { font-size: 1rem; margin: 0; }
.gate-chart {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 18px; align-items: end; min-height: 360px;
}
.gate-chart-col { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.gate-chart-total { font-size: .92rem; font-weight: 800; width: 100%; }
.gate-chart-meta { color: var(--muted); font-size: .8rem; }
.gate-chart-track {
  height: 220px; width: 100%; display: flex; align-items: flex-end; justify-content: center;
  border-bottom: 1px solid var(--line); padding: 8px 12px 0;
}
.gate-chart-stack {
  width: 72px; min-height: 8px; border-radius: 18px 18px 0 0; overflow: hidden;
  display: flex; flex-direction: column-reverse; background: linear-gradient(180deg, #eef4fb 0%, #f7fbff 100%);
  border: 1px solid #d5e0ee; border-bottom: 0;
}
.gate-chart-segment { width: 100%; min-height: 8px; }
.gate-chart-empty { width: 100%; height: 100%; background: linear-gradient(180deg, #f2f6fb 0%, #f8fbff 100%); }
.gate-chart-label { font-size: .82rem; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.gate-chart-name { text-align: center; font-size: .88rem; font-weight: 700; line-height: 1.35; }
@media (max-width: 1180px) {
  .dashboard-filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-card { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .dashboard-filters, .checkbox-grid, .hero-right { grid-template-columns: 1fr; }
  .gate-chart { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 980px) {
  .gate-panel-grid, .gate-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}


.dashboard-project-drawer {
  margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line);
}
.dashboard-project-drawer-head { margin-bottom: 14px; align-items: flex-start; }
.dashboard-project-drawer-head h3 { margin: 0; font-size: 1rem; }
.dashboard-project-table-wrap {
  border: 1px solid var(--line); border-radius: 18px; background: #fff;
}
.dashboard-project-table thead th { white-space: nowrap; }
.dashboard-project-table td:nth-child(1),
.dashboard-project-table td:nth-child(2),
.dashboard-project-table td:nth-child(4),
.dashboard-project-table td:nth-child(5),
.dashboard-project-table td:nth-child(8),
.dashboard-project-table td:nth-child(11) {
  white-space: nowrap;
}
.dashboard-project-table td:nth-child(3) { min-width: 260px; }
.dashboard-project-table .table-sub {
  max-width: 520px; line-height: 1.45;
}
.dashboard-compact-card .card-head h2 { font-size: 1.06rem; }
.dashboard-compact-card .card-head .muted { font-size: .82rem; }
.dashboard-compact-card .workstream-card { padding: 14px; }
.dashboard-compact-card .workstream-card h3 { font-size: 1rem; margin: 4px 0 0; }
.dashboard-compact-card .eyebrow { font-size: .68rem; }
.dashboard-compact-card .workstream-metrics { gap: 10px; margin: 14px 0; }
.dashboard-compact-card .mini-label,
.dashboard-compact-card .table-sub,
.dashboard-compact-card .mini-status-line,
.dashboard-compact-card .data-table thead th,
.dashboard-compact-card .data-table td,
.dashboard-compact-card .data-table th {
  font-size: .82rem;
}
.dashboard-compact-card .mini-value { font-size: .94rem; font-weight: 700; }
.dashboard-compact-card .pill { font-size: .72rem; padding: 5px 9px; }
.dashboard-compact-card .data-table td,
.dashboard-compact-card .data-table th { padding-top: 9px; padding-bottom: 9px; }
@media (max-width: 980px) {
  .dashboard-project-drawer-head { gap: 10px; }
}
@media (max-width: 720px) {
  .dashboard-project-drawer-head { flex-direction: column; }
  .dashboard-project-drawer-head .button-sm { width: 100%; justify-content: center; }
  .dashboard-project-table td:nth-child(3) { min-width: 220px; }
}

.dashboard-screen {
  font-family: "Inter Tight", "Aptos Narrow", "Arial Narrow", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.dashboard-screen .card,
.dashboard-screen .metric-card { padding: 18px; }
.dashboard-screen .grid-4,
.dashboard-screen .grid-2,
.dashboard-screen .workstream-grid,
.dashboard-screen .gate-panel-grid,
.dashboard-screen .gate-summary-grid,
.dashboard-screen .dashboard-filters { gap: 14px; }
.dashboard-screen .card-head { margin-bottom: 14px; }
.dashboard-screen .card-head h2 { font-size: 1.02rem; }
.dashboard-screen .muted,
.dashboard-screen .metric-foot,
.dashboard-screen .table-sub,
.dashboard-screen .mini-status-line,
.dashboard-screen .timeline-meta,
.dashboard-screen .legend-item { font-size: .78rem; }
.dashboard-screen label { font-size: .8rem; margin-bottom: 6px; }
.dashboard-screen input,
.dashboard-screen select,
.dashboard-screen textarea {
  padding: 10px 12px;
  border-radius: 14px;
  font-size: .9rem;
}
.dashboard-screen .button { padding: 10px 15px; min-height: 42px; }
.dashboard-screen .button-sm { padding: 7px 10px; min-height: 36px; font-size: .78rem; }
.dashboard-screen .metric-label,
.dashboard-screen .mini-label,
.dashboard-screen .eyebrow {
  font-size: .72rem;
  letter-spacing: .08em;
}
.dashboard-screen .metric-value { font-size: 1.7rem; }
.dashboard-screen .metric-value.sm,
.dashboard-screen .mini-value { font-size: 1.02rem; }
.dashboard-screen .filter-actions { padding-top: 18px; }
.dashboard-screen .gate-panel-grid { min-height: 300px; }
.dashboard-screen .gate-chart-total { font-size: .84rem; }
.dashboard-screen .gate-chart-meta,
.dashboard-screen .gate-chart-label { font-size: .72rem; }
.dashboard-screen .gate-chart-name {
  font-size: .8rem;
  line-height: 1.25;
  word-break: break-word;
}
.dashboard-screen .gate-chart-track {
  height: 188px;
  padding: 6px 8px 0;
}
.dashboard-screen .gate-chart-stack { width: 58px; border-radius: 16px 16px 0 0; }
.dashboard-screen .gate-total-card { padding: 14px; }
.dashboard-screen .dashboard-project-drawer { margin-top: 18px; padding-top: 16px; }
.dashboard-screen .dashboard-project-drawer-head h3,
.dashboard-screen .gate-summary-head h3 { font-size: .94rem; }
.dashboard-screen .dashboard-project-table,
.dashboard-screen .dashboard-project-table thead th,
.dashboard-screen .dashboard-compact-card .data-table,
.dashboard-screen .dashboard-compact-card .data-table thead th,
.dashboard-screen .dashboard-compact-card .data-table td,
.dashboard-screen .dashboard-compact-card .data-table th {
  font-size: .76rem;
}
.dashboard-screen .dashboard-project-table td,
.dashboard-screen .dashboard-project-table th,
.dashboard-screen .dashboard-compact-card .data-table td,
.dashboard-screen .dashboard-compact-card .data-table th {
  padding: 8px 9px;
}
.dashboard-screen .dashboard-project-table td:nth-child(1),
.dashboard-screen .dashboard-project-table td:nth-child(2),
.dashboard-screen .dashboard-project-table td:nth-child(4),
.dashboard-screen .dashboard-project-table td:nth-child(5),
.dashboard-screen .dashboard-project-table td:nth-child(8),
.dashboard-screen .dashboard-project-table td:nth-child(11) {
  white-space: normal;
}
.dashboard-screen .dashboard-project-table td:nth-child(3) { min-width: 180px; }
.dashboard-screen .dashboard-project-table .table-sub {
  max-width: 360px;
  line-height: 1.3;
}
.dashboard-screen .dashboard-compact-card .workstream-card { padding: 12px; border-radius: 18px; }
.dashboard-screen .dashboard-compact-card .workstream-card h3 { font-size: .92rem; }
.dashboard-screen .dashboard-compact-card .workstream-metrics { gap: 8px; margin: 12px 0; }
.dashboard-screen .dashboard-compact-card .pill,
.dashboard-screen .dashboard-project-table .pill { font-size: .68rem; padding: 4px 8px; }
.dashboard-screen .timeline { gap: 12px; }
.dashboard-screen .timeline-item { gap: 10px; }
.dashboard-screen .timeline-dot { margin-top: 5px; }

@media (max-width: 1600px) {
  .dashboard-screen .grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
  .dashboard-screen .grid-2 { gap: 14px; }
  .dashboard-screen .workstream-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-screen .dashboard-project-table,
  .dashboard-screen .dashboard-project-table thead th,
  .dashboard-screen .dashboard-project-table td { font-size: .73rem; }
  .dashboard-screen .dashboard-project-table td:nth-child(3) { min-width: 160px; }
  .dashboard-screen .dashboard-project-table .table-sub { max-width: 300px; }
}

@media (max-width: 1280px) {
  .dashboard-screen .grid-4,
  .dashboard-screen .grid-2,
  .dashboard-screen .workstream-grid,
  .dashboard-screen .gate-panel-grid,
  .dashboard-screen .gate-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 860px) {
  .dashboard-screen .workstream-grid,
  .dashboard-screen .grid-4,
  .dashboard-screen .grid-2,
  .dashboard-screen .gate-panel-grid,
  .dashboard-screen .gate-summary-grid,
  .dashboard-screen .dashboard-filters { grid-template-columns: 1fr; }
}

.page-top-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.main-content { min-width: 0; }

.sidebar {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 18px;
  overflow: hidden;
  transition: padding .22s ease, opacity .22s ease, transform .22s ease, border-color .22s ease;
}
.sidebar-nav-shell {
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
  scrollbar-gutter: stable;
}
.sidebar-nav-shell::-webkit-scrollbar { width: 8px; }
.sidebar-nav-shell::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.14);
  border-radius: 999px;
}
.sidebar-nav-shell::-webkit-scrollbar-track { background: transparent; }
.nav-stack {
  min-height: max-content;
  margin-top: 0;
}
.nav-section { display: flex; flex-direction: column; gap: 8px; }
.nav-section + .nav-section { margin-top: 6px; }
.nav-link-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.nav-section-utility { margin-top: 8px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); }

body.sidebar-collapsed .app-shell { grid-template-columns: 0 minmax(0, 1fr); }
body.sidebar-collapsed .sidebar {
  padding-left: 0;
  padding-right: 0;
  opacity: 0;
  transform: translateX(-20px);
  pointer-events: none;
  border-right-color: transparent;
}

.dashboard-screen,
.dashboard-preview {
  --dash-font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --dash-scale: 1;
  font-family: var(--dash-font-family);
}
.dashboard-screen {
  display: flex;
  flex-direction: column;
  gap: calc(18px * var(--dash-scale));
}
.dashboard-preview {
  display: flex;
  flex-direction: column;
  gap: calc(14px * var(--dash-scale));
}
.dashboard-screen .card,
.dashboard-screen .metric-card,
.dashboard-preview .card,
.dashboard-preview .metric-card { padding: calc(18px * var(--dash-scale)); }
.dashboard-screen .grid-4,
.dashboard-screen .grid-2,
.dashboard-screen .workstream-grid,
.dashboard-screen .gate-panel-grid,
.dashboard-screen .gate-summary-grid,
.dashboard-screen .dashboard-filters { gap: calc(14px * var(--dash-scale)); }
.dashboard-screen .card-head,
.dashboard-preview .card-head { margin-bottom: calc(14px * var(--dash-scale)); }
.dashboard-screen .card-head h2,
.dashboard-preview .card-head h2 { font-size: calc(1.02rem * var(--dash-scale)); }
.dashboard-screen .muted,
.dashboard-screen .metric-foot,
.dashboard-screen .table-sub,
.dashboard-screen .mini-status-line,
.dashboard-screen .timeline-meta,
.dashboard-screen .legend-item,
.dashboard-preview .muted,
.dashboard-preview .metric-foot,
.dashboard-preview .table-sub { font-size: calc(.78rem * var(--dash-scale)); }
.dashboard-screen label,
.dashboard-preview label { font-size: calc(.8rem * var(--dash-scale)); margin-bottom: 6px; }
.dashboard-screen input,
.dashboard-screen select,
.dashboard-screen textarea,
.dashboard-preview input,
.dashboard-preview select,
.dashboard-preview textarea {
  padding: calc(10px * var(--dash-scale)) calc(12px * var(--dash-scale));
  border-radius: 14px;
  font-size: calc(.9rem * var(--dash-scale));
}
.dashboard-screen .button,
.dashboard-preview .button { padding: calc(10px * var(--dash-scale)) calc(15px * var(--dash-scale)); min-height: calc(42px * var(--dash-scale)); }
.dashboard-screen .button-sm,
.dashboard-preview .button-sm { padding: calc(7px * var(--dash-scale)) calc(10px * var(--dash-scale)); min-height: calc(36px * var(--dash-scale)); font-size: calc(.78rem * var(--dash-scale)); }
.dashboard-screen .metric-label,
.dashboard-screen .mini-label,
.dashboard-screen .eyebrow,
.dashboard-preview .metric-label,
.dashboard-preview .mini-label,
.dashboard-preview .eyebrow {
  font-size: calc(.72rem * var(--dash-scale));
  letter-spacing: .08em;
}
.dashboard-screen .metric-value,
.dashboard-preview .metric-value { font-size: calc(1.7rem * var(--dash-scale)); }
.dashboard-screen .metric-value.sm,
.dashboard-screen .mini-value,
.dashboard-preview .metric-value.sm,
.dashboard-preview .mini-value { font-size: calc(1.02rem * var(--dash-scale)); }
.dashboard-screen .filter-actions { padding-top: calc(18px * var(--dash-scale)); }
.dashboard-screen .gate-panel-grid { min-height: calc(300px * var(--dash-scale)); }
.dashboard-screen .gate-chart-total,
.dashboard-preview .gate-chart-total { font-size: calc(.84rem * var(--dash-scale)); }
.dashboard-screen .gate-chart-meta,
.dashboard-screen .gate-chart-label,
.dashboard-preview .gate-chart-meta,
.dashboard-preview .gate-chart-label { font-size: calc(.72rem * var(--dash-scale)); }
.dashboard-screen .gate-chart-name,
.dashboard-preview .gate-chart-name {
  font-size: calc(.8rem * var(--dash-scale));
  line-height: 1.25;
  word-break: break-word;
}
.dashboard-screen .gate-chart-track,
.dashboard-preview .gate-chart-track {
  height: calc(188px * var(--dash-scale));
  padding: 6px 8px 0;
}
.dashboard-screen .gate-chart-stack,
.dashboard-preview .gate-chart-stack { width: calc(58px * var(--dash-scale)); border-radius: 16px 16px 0 0; }
.dashboard-screen .gate-total-card,
.dashboard-preview .gate-total-card { padding: calc(14px * var(--dash-scale)); }
.dashboard-screen .dashboard-project-drawer { margin-top: calc(18px * var(--dash-scale)); padding-top: calc(16px * var(--dash-scale)); }
.dashboard-screen .dashboard-project-drawer-head h3,
.dashboard-screen .gate-summary-head h3,
.dashboard-preview .dashboard-project-drawer-head h3,
.dashboard-preview .gate-summary-head h3 { font-size: calc(.94rem * var(--dash-scale)); }
.dashboard-screen .dashboard-project-table,
.dashboard-screen .dashboard-project-table thead th,
.dashboard-screen .dashboard-compact-card .data-table,
.dashboard-screen .dashboard-compact-card .data-table thead th,
.dashboard-screen .dashboard-compact-card .data-table td,
.dashboard-screen .dashboard-compact-card .data-table th,
.dashboard-preview .data-table,
.dashboard-preview .data-table thead th,
.dashboard-preview .data-table td,
.dashboard-preview .data-table th { font-size: calc(.76rem * var(--dash-scale)); }
.dashboard-screen .dashboard-project-table td,
.dashboard-screen .dashboard-project-table th,
.dashboard-screen .dashboard-compact-card .data-table td,
.dashboard-screen .dashboard-compact-card .data-table th,
.dashboard-preview .data-table td,
.dashboard-preview .data-table th { padding: calc(8px * var(--dash-scale)) calc(9px * var(--dash-scale)); }
.dashboard-screen .dashboard-project-table td:nth-child(1),
.dashboard-screen .dashboard-project-table td:nth-child(2),
.dashboard-screen .dashboard-project-table td:nth-child(4),
.dashboard-screen .dashboard-project-table td:nth-child(5),
.dashboard-screen .dashboard-project-table td:nth-child(8),
.dashboard-screen .dashboard-project-table td:nth-child(11) { white-space: normal; }
.dashboard-screen .dashboard-project-table td:nth-child(3) { min-width: calc(180px * var(--dash-scale)); }
.dashboard-screen .dashboard-project-table .table-sub { max-width: calc(360px * var(--dash-scale)); line-height: 1.3; }
.dashboard-screen .dashboard-compact-card .workstream-card,
.dashboard-preview .workstream-card { padding: calc(12px * var(--dash-scale)); border-radius: 18px; }
.dashboard-screen .dashboard-compact-card .workstream-card h3,
.dashboard-preview .workstream-card h3 { font-size: calc(.92rem * var(--dash-scale)); }
.dashboard-screen .dashboard-compact-card .workstream-metrics,
.dashboard-preview .workstream-metrics { gap: calc(8px * var(--dash-scale)); margin: calc(12px * var(--dash-scale)) 0; }
.dashboard-screen .dashboard-compact-card .pill,
.dashboard-screen .dashboard-project-table .pill,
.dashboard-preview .pill { font-size: calc(.68rem * var(--dash-scale)); padding: calc(4px * var(--dash-scale)) calc(8px * var(--dash-scale)); }
.dashboard-screen .timeline { gap: calc(12px * var(--dash-scale)); }
.dashboard-screen .timeline-item { gap: calc(10px * var(--dash-scale)); }
.dashboard-screen .timeline-dot { margin-top: 5px; }
.dashboard-screen .legend-grid { margin-top: calc(18px * var(--dash-scale)); }

.dashboard-screen.size-compact,
.dashboard-preview.size-compact { --dash-scale: .9; }
.dashboard-screen.size-small,
.dashboard-preview.size-small { --dash-scale: .96; }
.dashboard-screen.size-standard,
.dashboard-preview.size-standard { --dash-scale: 1; }
.dashboard-screen.size-large,
.dashboard-preview.size-large { --dash-scale: 1.08; }
.dashboard-screen.size-xlarge,
.dashboard-preview.size-xlarge { --dash-scale: 1.16; }

.dashboard-screen.font-inter,
.dashboard-preview.font-inter { --dash-font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.dashboard-screen.font-segoe,
.dashboard-preview.font-segoe { --dash-font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; }
.dashboard-screen.font-aptos,
.dashboard-preview.font-aptos { --dash-font-family: Aptos, Calibri, "Segoe UI", sans-serif; }
.dashboard-screen.font-arial,
.dashboard-preview.font-arial { --dash-font-family: Arial, Helvetica, sans-serif; }
.dashboard-screen.font-trebuchet,
.dashboard-preview.font-trebuchet { --dash-font-family: "Trebuchet MS", "Segoe UI", sans-serif; }

.settings-grid { align-items: start; }
.settings-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.settings-preview-card { min-height: 100%; }
.settings-preview-metric { background: linear-gradient(135deg, rgba(16,62,160,.92), rgba(14,165,233,.9)); color: #fff; }
.settings-preview-metric .metric-label,
.settings-preview-metric .metric-foot { color: rgba(255,255,255,.82); }
.settings-preview-panel { padding: 0; overflow: hidden; }
.settings-preview-panel .card-head { padding: 18px 18px 0; }
.settings-preview-panel .data-table { margin-top: 0; }
.settings-preview-panel .data-table th,
.settings-preview-panel .data-table td { padding-left: 18px; padding-right: 18px; }

@media (max-width: 1280px) {
  body.sidebar-collapsed .app-shell { grid-template-columns: 0 minmax(0, 1fr); }
}
@media (max-width: 860px) {
  .page-top-actions { width: 100%; }
  .page-top-actions .button { flex: 1 1 180px; }
}

.nav-link-foot { justify-content: center; border: 1px solid rgba(255,255,255,.08); }

.app-shell { transition: grid-template-columns .22s ease; }
.password-strength {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.password-strength-bar {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: #ebeff6;
  border: 1px solid #dbe4ef;
  overflow: hidden;
}
.password-strength-bar span {
  display: block;
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #dc2626 0%, #f59e0b 50%, #16a34a 100%);
  transition: width .18s ease;
}
.password-strength-copy {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: .86rem;
}
.password-strength-copy strong {
  font-size: .88rem;
}
.recovery-code-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}
.recovery-code-item {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px dashed rgba(17, 24, 39, .25);
  background: rgba(255,255,255,.65);
  font-weight: 800;
  letter-spacing: .08em;
  text-align: center;
}
.button.danger { background: linear-gradient(135deg, #b91c1c 0%, #dc2626 100%); }

.password-input-wrap {
  position: relative;
}
.password-input-wrap input {
  padding-right: 52px;
}
.password-toggle-button {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-radius: 999px;
  font-size: 1rem;
}
.password-toggle-button:hover {
  background: rgba(37,99,235,.08);
}
.sidebar-version {
  text-align: center;
  color: #9eb1ca;
  font-size: .78rem;
}
.template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.template-card {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}
.request-card-pending {
  border-color: #f6e1ad;
  background: #fffaf0;
}
