:root {
  --surface: rgba(243, 243, 240, 0.97);
  --surface-strong: #f6f6f3;
  --line: rgba(17, 24, 39, 0.88);
  --text: #111827;
  --muted: #5b6470;
  --teal: #0f172a;
  --blue: #1f2937;
  --amber: #d4a514;
  --red: #8f2d18;
  --shadow: 0 10px 24px rgba(17, 24, 39, 0.08);
  --radius-lg: 18px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Space Mono", monospace;
  color: var(--text);
  background:
    linear-gradient(rgba(17, 24, 39, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(17, 24, 39, 0.04) 1px, transparent 1px),
    linear-gradient(180deg, #d7d8d3 0%, #e6e7e2 42%, #d1d3ce 100%);
  background-size: 24px 24px, 24px 24px, auto;
}
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 290px minmax(0, 1fr); }
.sidebar { padding: 24px 20px; border-right: 2px solid var(--line); background: linear-gradient(180deg, #d7d9d3 0%, #cfd3cd 52%, #c7cbc5 100%); color: var(--text); position: sticky; top: 0; height: 100vh; overflow: auto; }
.brand-card, .sidebar-panel, .topbar, .hero-card, .card, .table-card, .panel-card { border: 2px solid var(--line); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow); backdrop-filter: none; }
.brand-card, .sidebar-panel { background: linear-gradient(180deg, rgba(248, 248, 244, 0.98), rgba(232, 234, 229, 0.96)); color: var(--text); }
.brand-card { padding: 12px 14px; display: flex; gap: 10px; align-items: center; margin-bottom: 12px; }
.brand-badge { width: 54px; height: 54px; border-radius: 18px; display: grid; place-items: center; font-family: "Space Mono", monospace; font-weight: 700; background: linear-gradient(135deg, #34d399, #38bdf8); color: #052033; }
.brand-badge-image {
  width: 66px;
  height: 66px;
  padding: 0;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
}
.brand-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.eyebrow, .panel-label, .section-label { margin: 0 0 6px; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }
.brand-card .eyebrow, .sidebar-panel .panel-label { color: var(--muted); }
.brand-card h1, .topbar h2, .hero-card h3, .section-header h3 { margin: 0; font-family: "Space Mono", monospace; letter-spacing: -0.03em; }
.sidebar .brand-card h1,
.sidebar .sidebar-panel,
.sidebar .panel-label {
  font-family: "Space Mono", monospace;
}
.brand-card h1 { font-size: 1.55rem; line-height: 1.05; }
.sidebar-nav, .mini-status, .bar-chart, .legend-list, .critical-list, .indicator-list, .simple-list, .grid-list, .timeline-list { display: grid; gap: 12px; }
.sidebar-profile { margin-top: 0; margin-bottom: 16px; padding: 12px 14px; }
.sidebar-profile .panel-label { margin-bottom: 4px; }
.sidebar-profile-role {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
  font-family: "Space Mono", monospace;
}
.nav-button {
  width: 100%;
  padding: 8px 14px;
  border: 1px solid rgba(17, 24, 39, 0.65);
  border-radius: 12px;
  color: var(--text);
  background: rgba(255, 252, 245, 0.94);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  text-align: left;
  cursor: pointer;
  overflow: hidden;
  font-family: "Space Mono", monospace;
  transition: background 180ms ease, border-color 180ms ease, box-shadow 180ms ease, padding 180ms ease;
}
.sidebar .nav-button,
.sidebar .nav-button span,
.sidebar .nav-button .nav-kicker {
  font-family: "Space Mono", monospace !important;
}
.nav-button > span:first-child {
  text-align: left;
  width: 100%;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.nav-button .nav-kicker {
  width: 100%;
  text-align: left;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateY(-4px);
  transition: max-height 180ms ease, opacity 180ms ease, transform 180ms ease, margin-top 180ms ease;
}
.nav-button:hover,
.nav-button:focus-visible,
.nav-button.active {
  background: linear-gradient(270deg, rgba(150, 164, 154, 0.82) 0%, rgba(212, 220, 214, 0.92) 52%, rgba(244, 246, 242, 0.98) 100%);
  border-color: rgba(17, 24, 39, 1);
  box-shadow: 0 8px 18px rgba(17, 24, 39, 0.08);
}
.nav-button.active {
  border-width: 2px;
  box-shadow:
    0 10px 22px rgba(17, 24, 39, 0.08),
    inset 0 0 0 1px rgba(17, 24, 39, 0.12);
}
.nav-button:hover .nav-kicker,
.nav-button:focus-visible .nav-kicker,
.nav-button.active .nav-kicker {
  max-height: 20px;
  opacity: 1;
  transform: translateY(0);
  margin-top: 4px;
}
.nav-kicker { font-size: 0.78rem; color: var(--muted); font-family: "Space Mono", monospace; }
.sidebar-panel { margin-top: 22px; padding: 18px; }
.mini-status-item, .card-header, .section-header, .critical-item header, .indicator-item header, .simple-item header, .timeline-item header { display: flex; justify-content: space-between; align-items: start; gap: 16px; }
.card-header-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.main-layout { padding: 28px; }
.topbar {
  padding: 8px 20px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;
  min-height: 44px;
  border-color: rgba(17, 24, 39, 1);
  background:
    linear-gradient(270deg, rgba(171, 175, 170, 0.46) 0%, rgba(216, 218, 213, 0.3) 42%, rgba(246, 246, 243, 0.98) 100%);
}
.topbar-title-wrap { text-align: center; }
.topbar h2 { font-size: clamp(1.45rem, 2vw, 1.95rem); line-height: 1.05; }
.topbar-actions, .hero-metrics, .donut-wrap { display: flex; gap: 12px; flex-wrap: wrap; }
.topbar-actions { justify-self: end; align-items: center; gap: 8px; flex-wrap: nowrap; }
.topbar-spacer { min-width: 0; }
.topbar-status {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.topbar-action-button {
  border: 2px solid rgba(17, 24, 39, 0.92);
  border-radius: 999px;
  padding: 7px 11px;
  background: linear-gradient(135deg, #f9df69, #f2c62b);
  color: #171c2b;
  font: inherit;
  font-family: "Space Mono", monospace;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.48) inset,
    0 10px 20px rgba(15, 23, 42, 0.08);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}
.topbar-action-button:hover {
  border-color: #111827;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.52) inset,
    0 12px 24px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}
.topbar-chip, .tag, .status-pill, .risk-badge { padding: 8px 12px; border-radius: 999px; font-size: 0.82rem; font-weight: 700; background: rgba(242, 243, 239, 0.94); color: var(--text); border: 1px solid rgba(17, 24, 39, 0.8); }
.topbar-chip-strong { color: #f8fafc; background: linear-gradient(135deg, var(--red), var(--blue)); }
.hero-card { margin-top: 20px; padding: 24px; display: flex; justify-content: space-between; gap: 18px; align-items: end; background: linear-gradient(180deg, rgba(244, 245, 241, 0.98), rgba(228, 230, 225, 0.94)); }
.hero-copy, .metric-title, .metric-foot, .card-header p, .section-header p, .critical-item p, .indicator-item p, .grid-card p, .simple-item p, .timeline-item p, .muted { color: var(--muted); }
.hero-metrics div { min-width: 156px; padding: 18px; border-radius: 22px; background: rgba(15, 23, 42, 0.04); }
.hero-metrics strong, .metric-value { display: block; margin-top: 6px; font-size: 1.65rem; font-family: "Space Mono", monospace; }
.content-view { display: none; margin-top: 20px; }
.content-view.active { display: block; }
.module-footer {
  margin-top: 18px;
  padding: 12px 18px 6px;
}
.module-footer p {
  margin: 0;
  text-align: center;
  font-size: 0.78rem;
  line-height: 1.5;
  color: #4b5563;
  font-family: "Space Mono", monospace;
}
.dashboard-grid { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 18px; }
.metric-card, .chart-card, .progress-card, .critical-card, .semaphore-card, .table-card, .panel-card, .grid-card, .timeline-item, .simple-item, .critical-item, .indicator-item { border-radius: 14px; border: 2px solid rgba(17, 24, 39, 0.9); }
.metric-card { grid-column: span 3; padding: 16px 18px; min-height: 118px; }
.metric-title { font-size: 0.82rem; }
.metric-foot { margin-top: 8px; font-size: 0.84rem; line-height: 1.4; }
.metric-card-secondary {
  background: rgba(248, 250, 252, 0.82);
}
.metric-card-secondary .metric-value {
  color: rgba(71, 85, 105, 0.72);
}
.dashboard-header-shell {
  grid-column: span 12;
  padding: 18px;
  display: grid;
  gap: 18px;
  border-color: rgba(17, 24, 39, 0.92);
  background:
    linear-gradient(270deg, rgba(176, 179, 173, 0.34) 0%, rgba(221, 223, 217, 0.2) 42%, rgba(246, 246, 243, 0.98) 100%);
}
.dashboard-header-top, .dashboard-header-bottom { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.dashboard-kpi-card {
  grid-column: auto;
  min-height: 78px;
  border-color: rgba(17, 24, 39, 0.9);
  background:
    linear-gradient(270deg, rgba(188, 191, 185, 0.38) 0%, rgba(216, 219, 214, 0.2) 38%, rgba(246,246,243,0.99) 100%);
}
.dashboard-kpi-card-compact { min-height: 94px; }
.dashboard-kpi-split {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
}
.dashboard-kpi-card-split {
  min-height: 0;
  padding: 9px 12px;
}
.dashboard-header-top .dashboard-kpi-card {
  min-height: 58px;
  padding: 9px 12px;
  display: flex;
  flex-direction: column;
}
.dashboard-header-shell .dashboard-kpi-card .metric-title {
  color: #111827;
  font-weight: 700;
  font-size: 0.84rem;
}
.dashboard-header-shell .dashboard-kpi-card .metric-value {
  color: #111827;
  margin-top: 2px;
  font-size: 1.22rem;
  font-weight: 800;
}
.dashboard-header-shell .dashboard-kpi-card .metric-foot {
  color: #111827;
  margin-top: 2px;
  font-size: 0.84rem;
}
.dashboard-header-top .dashboard-kpi-card .metric-foot {
  display: none;
}
.dashboard-header-top .dashboard-kpi-split {
  gap: 8px;
}
.dashboard-header-top .dashboard-kpi-card-split {
  min-height: 0;
  padding: 8px 10px;
}
.dashboard-header-bottom .dashboard-kpi-card {
  min-height: 58px;
  padding: 9px 12px;
  display: flex;
  flex-direction: column;
}
.dashboard-header-bottom .dashboard-kpi-split {
  gap: 8px;
}
.dashboard-header-bottom .dashboard-kpi-card-split {
  min-height: 0;
  padding: 8px 10px;
}
.dashboard-header-bottom .dashboard-kpi-card .metric-foot {
  display: none;
}
.dashboard-header-shell .dashboard-kpi-card .metric-title {
  display: block;
  min-height: 34px;
  line-height: 1.15;
}
.dashboard-header-shell .dashboard-kpi-card .metric-value {
  display: block;
  margin-top: 4px;
}
.dashboard-header-shell .metric-card-secondary .metric-title,
.dashboard-header-shell .metric-card-secondary .metric-value,
.dashboard-header-shell .metric-card-secondary .metric-foot {
  color: #111827;
}
.dashboard-hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(280px, 1fr);
  gap: 0;
  border: 2px solid rgba(17, 24, 39, 0.9);
  border-radius: 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at left bottom, rgba(249, 223, 105, 0.28), transparent 30%),
    radial-gradient(circle at top right, rgba(244, 162, 97, 0.26), transparent 24%),
    linear-gradient(270deg, rgba(244, 162, 97, 0.18) 0%, rgba(248, 211, 176, 0.14) 42%, rgba(255,255,255,0.98) 100%);
}
.dashboard-hero-chart-panel {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 12px;
}
.dashboard-hero-chart-header {
  width: 100%;
  display: flex;
  justify-content: center;
}
.dashboard-hero-chart-header .section-label {
  margin: 0;
  color: #111827;
  font-size: 0.96rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}
.dashboard-hero-chart-wrap { display: flex; justify-content: center; align-items: center; }
.budget-pie-3d {
  --pie-gradient: conic-gradient(from -18deg, #d7ddd8 0deg 360deg);
  position: relative;
  width: 300px;
  height: 300px;
  border-radius: 50%;
}
.budget-pie-3d-bottom,
.budget-pie-3d-top,
.budget-pie-3d-highlight {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}
.budget-pie-3d-bottom {
  border: 4px solid rgba(84, 26, 54, 0.82);
  box-shadow: 0 18px 30px rgba(17, 24, 39, 0.16);
}
.budget-pie-3d-top {
  background: transparent;
  border: 0;
}
.budget-pie-3d-highlight {
  inset: 18px 26px auto 26px;
  height: 78px;
  width: 190px;
  background: linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0.02));
  opacity: 0.55;
  transform: rotate(-12deg);
  pointer-events: none;
}
.budget-pie-labels {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
}
.budget-pie-label-text {
  fill: #111827;
  font-family: "Space Mono", monospace;
  font-size: 0.8rem;
  font-weight: 800;
  text-anchor: middle;
  dominant-baseline: middle;
}
.dashboard-hero-side-card,
.dashboard-hero-side-card p,
.dashboard-hero-side-card span,
.dashboard-hero-side-card strong {
  color: #111827;
}
.dashboard-hero-side {
  border-left: 2px solid rgba(17, 24, 39, 0.18);
  display: grid;
  grid-template-rows: repeat(4, minmax(0, 1fr));
  background: linear-gradient(180deg, rgba(255,255,255,0.5), rgba(249, 223, 105, 0.12));
}
.dashboard-hero-side-card {
  padding: 22px 24px;
  display: grid;
  align-content: center;
  gap: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--hero-dimension-color, #94a3b8) 14%, white), rgba(255,255,255,0.98));
}
.dashboard-hero-side-card + .dashboard-hero-side-card {
  border-top: 1.5px solid rgba(17, 24, 39, 0.16);
}
.dashboard-hero-side-card strong {
  font-family: "Space Mono", monospace;
  font-size: 1.55rem;
  font-weight: 800;
  letter-spacing: -0.03em;
}
.dashboard-hero-side-card .metric-title {
  color: color-mix(in srgb, var(--hero-dimension-color, #94a3b8) 60%, #111827);
  font-weight: 700;
}
.dimension-board-card {
  grid-column: span 12;
  padding: 22px;
  border-color: color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 56%, white);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 20%, white), rgba(255,255,255,0.98));
  box-shadow:
    0 18px 36px color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 14%, rgba(15, 23, 42, 0.12)),
    inset 0 0 0 1px color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 20%, white);
}
.action-tracking-header-card { grid-column: span 12; padding: 22px; }
.action-summary-card { grid-column: span 3; }
.action-summary-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; align-items: start; }
.action-summary-grid-card { grid-column: auto; width: 100%; align-self: start; }
.chart-card { grid-column: span 7; padding: 22px; }
.progress-card { grid-column: span 5; padding: 22px; }
.critical-card, .semaphore-card { grid-column: span 6; padding: 22px; }
.dimension-detail-card {
  grid-column: span 12;
  padding: 22px;
  border-color: color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 56%, white);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 22%, white), rgba(255,255,255,0.98));
  box-shadow:
    0 18px 36px color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 14%, rgba(15, 23, 42, 0.12)),
    inset 0 0 0 1px color-mix(in srgb, var(--selected-dimension-color, #94a3b8) 20%, white);
}
.dimension-board { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.dimension-summary-card { border: 2px solid rgba(17, 24, 39, 0.9); background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(245,248,252,0.96)); border-radius: 20px; padding: 18px; text-align: left; cursor: pointer; display: flex; flex-direction: column; height: 100%; }
.dimension-summary-card.static-card { cursor: default; }
.dimension-summary-card.selected { border-color: rgba(41, 71, 163, 0.32); box-shadow: 0 18px 40px rgba(41, 71, 163, 0.12); transform: translateY(-2px); }
.dimension-summary-top { display: flex; align-items: start; justify-content: space-between; gap: 12px; min-height: 56px; }
.dimension-summary-top > div { flex: 1 1 auto; }
.dimension-summary-card h5 { margin: 0; font-size: 1.05rem; font-family: "Space Mono", monospace; line-height: 1.3; }
.dimension-copy { min-height: 150px; line-height: 1.7; flex: 1 1 auto; }
.dimension-dot { width: 14px; height: 14px; border-radius: 999px; margin-top: 8px; box-shadow: 0 0 0 8px rgba(23, 28, 43, 0.05); }
.dimension-ring-wrap { display: flex; justify-content: center; align-items: center; padding-top: 14px; }
.dimension-ring { width: 122px; height: 122px; }
.dimension-ring-bg,
.dimension-ring-progress {
  fill: none;
  stroke-width: 10;
  transform: rotate(-90deg);
  transform-origin: 50% 50%;
}
.dimension-ring-bg { stroke: rgba(100, 116, 139, 0.36); }
.dimension-ring-progress { stroke-linecap: round; filter: saturate(1.05) brightness(0.88); }
.dimension-ring-text {
  text-anchor: middle;
  dominant-baseline: middle;
  fill: var(--text);
  font-family: "Space Mono", monospace;
  font-size: 1.2rem;
  font-weight: 700;
}
.dimension-action-count {
  margin: 10px 0 0;
  text-align: center;
  color: var(--muted);
  font-weight: 600;
}
.dimension-action-list { display: grid; gap: 14px; grid-auto-rows: 1fr; align-content: start; }
.dimension-action-item {
  border: 2px solid rgba(17, 24, 39, 0.88);
  border-radius: 18px;
  background: var(--surface-strong);
  padding: 16px;
  text-align: center;
}
.dimension-action-item h5 {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.45;
  font-family: "Space Mono", monospace;
  text-align: center;
}
.mini-ring-wrap { display: flex; justify-content: center; align-items: center; width: 100%; min-height: 96px; margin-top: 0; }
.action-matrix-section {
  grid-column: span 12;
  display: grid;
  gap: 16px;
}
.action-matrix-section-header {
  margin-bottom: 0;
}
.action-matrix-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.action-matrix-column {
  display: grid;
  gap: 14px;
  align-content: start;
}
.action-matrix-column-header,
.action-matrix-item,
.action-matrix-empty-cell {
  border: 2px solid rgba(17, 24, 39, 0.9);
  border-radius: 18px;
  background: rgba(255,255,255,0.98);
}
.action-matrix-column-header {
  min-height: 88px;
  padding: 18px 16px;
  display: flex;
  align-items: flex-start;
}
.action-matrix-column-header h4 {
  margin: 0;
}
.action-matrix-item {
  min-height: 230px;
  padding: 16px;
  display: grid;
  grid-template-rows: 132px 96px;
  justify-items: center;
  align-content: space-between;
}
.action-matrix-item h5 {
  margin: 0;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.98rem;
  line-height: 1.45;
}
.action-matrix-empty-cell {
  min-height: 230px;
  background: transparent;
  border-style: dashed;
  border-color: rgba(17, 24, 39, 0.24);
}
.mini-ring { width: 96px; height: 96px; }
.mini-ring-text {
  text-anchor: middle;
  dominant-baseline: middle;
  fill: var(--text);
  font-family: "Space Mono", monospace;
  font-size: 1rem;
  font-weight: 700;
}
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 18px; }
.dimension-preview-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 18px; margin-top: 18px; }
.detail-panel { border: 2px solid rgba(17, 24, 39, 0.88); border-radius: 14px; background: var(--surface-strong); padding: 18px; box-shadow: 0 6px 14px rgba(17, 24, 39, 0.04); }
.dimension-preview-copy {
  margin: 0;
  color: var(--text);
  line-height: 1.8;
}
.dimension-preview-list { display: grid; gap: 12px; }
.dimension-preview-item {
  border: 2px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 252, 245, 0.98);
  padding: 14px;
}
.dimension-preview-item p {
  margin: 0;
  color: var(--text);
  line-height: 1.7;
}
.detail-panel-soft { margin-top: 18px; background: rgba(232, 234, 229, 0.92); }
.detail-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-bottom: 12px; }
.detail-stats div { padding: 14px; border-radius: 12px; background: #fffdfa; border: 2px solid var(--line); }
.detail-stats span { display: block; color: var(--muted); font-size: 0.82rem; }
.detail-stats strong { display: block; margin-top: 6px; font-size: 1rem; }
.editor-textarea, .editor-input { width: 100%; border: 2px solid rgba(17, 24, 39, 0.82); border-radius: 12px; padding: 14px 16px; background: #fffdfa; color: var(--text); font: inherit; box-shadow: none; }
.editor-textarea:focus, .editor-input:focus { outline: none; border-color: #111827; box-shadow: 0 0 0 3px rgba(244, 208, 63, 0.2); }
.editor-textarea { min-height: 170px; resize: none; line-height: 1.8; overflow: hidden; padding-bottom: 34px; }
#objective-input { min-height: 280px; }
.strategy-textarea { min-height: 320px; }
.strategy-editor-list { display: grid; gap: 12px; }
.strategy-editor-item { padding: 0; border: 0; background: transparent; }
.strategy-editor-item .editor-textarea {
  min-height: 320px;
}
.detail-panel .eyebrow {
  font-weight: 700;
  font-size: 0.94rem;
  color: #111827;
}
.action-field .eyebrow {
  font-weight: 700;
  font-size: 0.94rem;
  color: #111827;
}
.action-dimension-picker { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; margin-top: 8px; }
.module-dimension-card {
  border: 2px solid rgba(17, 24, 39, 0.86);
  background: linear-gradient(180deg, color-mix(in srgb, var(--dimension-color) 8%, #f6f6f3), rgba(242,243,239,0.98));
  color: var(--text);
  border-radius: 12px;
  padding: 12px 16px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 10px;
  cursor: pointer;
  transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}
.module-dimension-card:hover {
  border-color: rgba(17, 24, 39, 1);
  box-shadow: 0 10px 20px color-mix(in srgb, var(--dimension-color) 14%, rgba(15, 23, 42, 0.08));
}
.module-dimension-card.selected {
  border-color: rgba(17, 24, 39, 1);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--dimension-color) 12%, #f6f6f3), rgba(242,243,239,0.99));
  box-shadow: 0 12px 22px color-mix(in srgb, var(--dimension-color) 16%, rgba(15, 23, 42, 0.1));
  transform: translateY(-2px);
}
.module-dimension-card-top { display: flex; justify-content: space-between; align-items: start; gap: 12px; min-height: 40px; }
.module-dimension-card h5 {
  margin: 0;
  font-size: 0.98rem;
  font-family: "Space Mono", monospace;
  line-height: 1.3;
}
.module-dimension-card.selected h5 {
  color: color-mix(in srgb, var(--dimension-color) 58%, #111827);
}
.module-dimension-card .eyebrow {
  transition: color 180ms ease;
}
.module-dimension-card.selected .eyebrow {
  color: color-mix(in srgb, var(--dimension-color) 55%, #475569);
}
.module-dimension-card .dimension-dot {
  box-shadow: 0 0 0 10px color-mix(in srgb, var(--dimension-color) 12%, white);
}
.module-dimension-card.selected .dimension-dot {
  box-shadow:
    0 0 0 10px color-mix(in srgb, var(--dimension-color) 24%, white),
    0 0 0 18px color-mix(in srgb, var(--dimension-color) 10%, transparent);
}
.action-selector-panel { margin-top: 0; }
.action-selector-panel-compact { padding: 14px 18px; }
.action-selector-header { min-height: auto; }
.action-selector-header h4 { margin: 0; line-height: 1.15; }
.action-name-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 12px; }
.action-name-card {
  border: 2px solid rgba(17, 24, 39, 0.82);
  background: rgba(244,245,241,0.98);
  color: var(--text);
  border-radius: 12px;
  padding: 14px 16px;
  text-align: left;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}
.action-name-card:hover {
  border-color: rgba(41, 71, 163, 0.3);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}
.action-name-card.selected {
  border-color: rgba(17, 24, 39, 1);
  background: linear-gradient(180deg, rgba(244,245,241,0.98), rgba(216,218,213,0.58));
  box-shadow: 0 10px 20px rgba(17, 24, 39, 0.08);
  transform: translateY(-1px);
}
.action-composer { margin-top: 0; padding: 18px; border-radius: 14px; border: 2px solid var(--line); background: rgba(243,243,240,0.9); }
.action-field { display: block; }
.action-form-grid { display: grid; gap: 16px; }
.action-form-grid-two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.action-name-input { min-height: 52px; }
.action-textarea { min-height: 210px; }
.action-notes-textarea { min-height: 120px; }
.activity-editor-panel { margin-top: 10px; }
.budget-editor-panel { margin-top: 10px; display: grid; gap: 18px; }
.budget-summary-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; }
.budget-summary-grid-compact { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 16px; }
.budget-summary-card {
  border: 2px solid var(--line);
  border-radius: 12px;
  background: rgba(243, 243, 240, 0.96);
  padding: 14px 16px;
  min-height: 96px;
  display: flex;
  flex-direction: column;
}
.budget-summary-card span {
  display: block;
  color: #111827;
  font-size: 0.82rem;
  min-height: 42px;
  line-height: 1.25;
  font-weight: 700;
}
.budget-summary-card strong {
  display: block;
  margin-top: auto;
  font-size: 1rem;
  font-family: "Space Mono", monospace;
  font-weight: 800;
  color: #111827;
}
.resource-editor-section { display: grid; gap: 14px; }
.resource-editor-list { display: grid; gap: 14px; }
.inline-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 2px solid var(--line);
  border-radius: 12px;
  background: rgba(239, 240, 236, 0.92);
  font-weight: 600;
}
.inline-toggle input {
  width: 16px;
  height: 16px;
}
.inline-toggle-compact {
  padding: 10px 12px;
  border-radius: 999px;
}
.lock-message {
  margin: 0 0 12px;
  padding: 10px 14px;
  border: 2px solid rgba(17, 24, 39, 0.82);
  border-radius: 12px;
  background: rgba(220, 222, 217, 0.72);
  color: var(--muted);
  font-size: 0.92rem;
}
.request-composer-row {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) 180px 180px auto;
  gap: 12px;
  align-items: center;
}
.material-request-table-head {
  display: grid;
  grid-template-columns: 72px 108px 170px 140px minmax(0, 1.2fr) 130px;
  gap: 12px;
  align-items: center;
  margin-top: 8px;
  padding: 0 10px;
}
.material-request-table-head span {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.material-request-table-head span:last-child {
  text-align: right;
}
.material-request-summary-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 130px;
  gap: 12px;
  align-items: center;
}
.material-request-summary-grid {
  display: grid;
  grid-template-columns: 72px 108px 170px 140px minmax(0, 1.2fr);
  gap: 12px;
  align-items: center;
}
.material-request-summary-grid span {
  color: #111827;
  font-size: 0.94rem;
}
.material-request-detail {
  margin-top: 14px;
}
.funding-composer-head,
.funding-composer-row { display: grid; grid-template-columns: 180px minmax(0, 1.4fr) 170px 170px 160px; gap: 12px; }
.funding-composer-head {
  align-items: center;
  margin-bottom: 10px;
  padding: 0;
}
.funding-composer-head span {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: left;
}
.funding-composer-head span:last-child { visibility: hidden; }
.funding-history-list { display: grid; gap: 12px; }
.funding-history-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
  gap: 16px;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
}
.funding-history-item h5 {
  margin: 0;
  font-size: 1rem;
  font-family: "Space Mono", monospace;
}
.funding-history-item p {
    margin: 6px 0 0;
    color: var(--muted);
}
.funding-history-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.funding-history-meta strong {
    font-family: "Space Mono", monospace;
    font-size: 1rem;
  }
.verification-editor-list {
  display: grid;
  gap: 10px;
}
.milestone-editor-list {
  display: grid;
  gap: 10px;
}
.verification-item-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}
.milestone-editor-head,
.milestone-editor-row {
  display: grid;
  grid-template-columns: 2.1fr 0.9fr 1fr 1.8fr 120px;
  gap: 12px;
  align-items: center;
  width: 100%;
  box-sizing: border-box;
}
.milestone-editor-head {
  padding: 0 12px 8px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}
.milestone-editor-head span {
  font-size: 0.84rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #111827;
  text-align: center;
  font-weight: 800;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.milestone-editor-row {
  padding: 10px 12px;
  border: 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 0;
  background: transparent;
}
.milestone-editor-row:last-child { border-bottom: 0; }
.milestone-editor-list {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
  overflow: hidden;
}
.milestone-editor-row .editor-input {
  min-height: 38px;
  padding-top: 8px;
  padding-bottom: 8px;
}
.milestone-percent-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.milestone-percent-wrap .editor-input {
  padding-right: 28px;
}
.milestone-percent-symbol {
  position: absolute;
  right: 12px;
  color: var(--muted);
  font-size: 0.9rem;
  pointer-events: none;
}
.milestone-remove-compact {
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 14px;
}
.milestone-tracking-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.milestone-table {
  display: grid;
  gap: 10px;
}
.milestone-table-head,
.milestone-table-row {
  display: grid;
  grid-template-columns: 2.1fr 0.9fr 1fr 1.8fr;
  gap: 12px;
  align-items: start;
  width: 100%;
  box-sizing: border-box;
}
.milestone-table-head {
  padding: 0 12px 8px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}
.milestone-table-head span {
  font-size: 0.84rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #111827;
  text-align: center;
  font-weight: 800;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.milestone-table-row {
  padding: 12px;
  border: 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 0;
  background: transparent;
}
.milestone-table-row > * {
  margin: 0;
}
.milestone-table {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
  overflow: hidden;
}
.milestone-table-row:last-child { border-bottom: 0; }
.evidence-requirements-grid {
  display: grid;
  gap: 10px;
}
.evidence-requirements-head,
.evidence-requirements-row {
  display: grid;
  grid-template-columns: minmax(220px, 1.2fr) 130px minmax(0, 1.2fr) 170px;
  gap: 12px;
  align-items: center;
}
.evidence-requirements-head {
  padding: 0 4px;
}
.evidence-requirements-head span {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.evidence-requirements-row {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
}
.evidence-requirement-name {
  font-weight: 600;
}
.evidence-requirement-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 600;
}
.evidence-requirement-status.is-pending {
  background: rgba(148, 163, 184, 0.16);
  color: #475569;
}
.evidence-requirement-status.is-complete {
  background: rgba(34, 197, 94, 0.16);
  color: #15803d;
}
.evidence-link-actions {
  display: grid;
  gap: 8px;
  align-items: center;
}
.resource-editor-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.92);
  padding: 16px;
}
.material-editor-card {
  padding: 12px 14px;
}
.action-field-span-2 { grid-column: span 2; }
.activity-editor-list { display: grid; gap: 14px; }
.activity-editor-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.92);
  padding: 16px;
}
.activity-editor-header { margin-bottom: 8px; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.activity-editor-head,
.activity-editor-row {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 150px 150px;
  gap: 10px;
  align-items: center;
}
.activity-editor-head {
  margin-top: 6px;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(23, 28, 43, 0.12);
}
.activity-editor-head span {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  font-weight: 600;
  font-weight: 700;
}
.subactivity-editor { display: grid; gap: 12px; }
.subactivity-editor-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.subactivity-editor-head-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 150px 150px 120px 54px;
  gap: 10px;
  align-items: center;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(23, 28, 43, 0.12);
}
.subactivity-editor-head-grid span {
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  font-weight: 700;
}
.subactivity-editor-list { display: grid; gap: 10px; }
.subactivity-editor-row {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 150px 150px 120px 54px;
  gap: 10px;
  align-items: center;
}
.form-validation-message {
  margin-bottom: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(181, 51, 61, 0.28);
  background: rgba(181, 51, 61, 0.08);
  color: var(--red);
  font-weight: 600;
}
.hidden { display: none; }
.app-shell-locked {
  filter: blur(8px);
  pointer-events: none;
  user-select: none;
}
.auth-overlay {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at top, rgba(41, 71, 163, 0.18), transparent 40%),
    rgba(9, 12, 22, 0.32);
  z-index: 30;
}
.auth-card {
  width: min(480px, 100%);
  padding: 28px;
  border-radius: 28px;
  border: 1px solid rgba(23, 28, 43, 0.18);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 28px 60px rgba(15, 23, 42, 0.24);
}
.auth-card h3 {
  margin: 8px 0 12px;
  font-size: 2rem;
}
.auth-description {
  margin: 0 0 18px;
  color: var(--muted);
  line-height: 1.6;
}
.auth-form {
  display: grid;
  gap: 14px;
}
.admin-user-list,
.admin-assignment-list {
  display: grid;
  gap: 10px;
}
.admin-user-meta {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.8rem;
  text-transform: capitalize;
}
.field-error-row {
  padding: 10px;
  border-radius: 14px;
  background: rgba(181, 51, 61, 0.08);
  border: 1px solid rgba(181, 51, 61, 0.22);
}
.password-field-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.password-field-wrap .editor-input {
  width: 100%;
}
.password-toggle-button {
  min-width: 88px;
  border: 2px solid rgba(17, 24, 39, 0.85);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(243,243,240,0.98), rgba(224,228,223,0.92));
  color: #111827;
  font-family: "Space Mono", monospace;
  font-weight: 700;
  padding: 11px 14px;
  cursor: pointer;
}
.admin-password-note {
  margin-top: 14px;
  background: rgba(17, 24, 39, 0.04);
  border-color: rgba(17, 24, 39, 0.14);
  color: #374151;
}
.field-hint { display: block; margin-top: 8px; color: var(--muted); font-size: 0.88rem; }
.action-list { display: grid; gap: 14px; }
.action-card {
  border: 2px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 253, 248, 0.98);
  padding: 18px;
}
.action-card.selected {
  border-color: rgba(17, 24, 39, 1);
  box-shadow: 0 10px 22px rgba(17, 24, 39, 0.08);
}
.action-card-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 16px;
}
.action-card-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}
.action-card h5 {
  margin: 0;
  font-size: 1.02rem;
  font-family: "Space Mono", monospace;
}
.action-card p { margin: 8px 0 0; color: var(--muted); line-height: 1.6; }
.action-card-meta { margin-top: 12px; color: var(--muted); font-size: 0.9rem; display: grid; gap: 6px; }
.action-card-footer { margin-top: 14px; display: grid; gap: 12px; }
.evidence-upload-field input[type="file"] {
  padding: 12px;
  min-height: auto;
}
.evidence-list { display: grid; gap: 12px; margin-top: 12px; }
.evidence-item {
  border: 2px solid var(--line);
  border-radius: 12px;
  background: #f6f6f3;
  padding: 14px 16px;
  display: grid;
  gap: 10px;
}
.evidence-item h5 {
  margin: 0;
  font-size: 0.98rem;
  font-family: "Space Mono", monospace;
}
.evidence-item p {
  margin: 6px 0 0;
  color: var(--muted);
}
.evidence-meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 0.86rem;
}
.evidence-actions {
  display: flex;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}
.action-empty-state {
  border: 1px dashed rgba(148, 163, 184, 0.45);
  border-radius: 20px;
  padding: 26px 18px;
  background: rgba(255,255,255,0.55);
}
.action-empty-state p { margin: 0; color: var(--muted); text-align: center; }
.action-detail-card { grid-column: span 12; }
.action-detail-card-empty { grid-column: span 12; }
.action-detail-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 18px; margin-top: 18px; }
.action-detail-stats { margin-top: 18px; }
.activity-list, .milestone-list, .subactivity-list { display: grid; gap: 12px; }
.activity-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.92);
  padding: 16px;
}
.activity-card-header, .milestone-item {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}
.activity-card h5, .milestone-item h5 { margin: 0; font-size: 1rem; font-family: "Space Mono", monospace; }
.activity-card p, .milestone-item p { margin: 6px 0 0; color: var(--muted); line-height: 1.5; }
.activity-progress { margin-top: 12px; }
.subactivity-item {
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.2);
}
.subactivity-bullet {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--blue);
  display: inline-block;
}
.subactivity-status { color: var(--muted); font-size: 0.85rem; text-transform: capitalize; }
.gantt-summary p:last-child { margin: 8px 0 0; color: var(--muted); line-height: 1.7; }
.gantt-panel { margin-top: 18px; }
.action-accordion-shell {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
  animation: accordionFade 0.22s ease;
}
.action-accordion-panel {
  display: grid;
  gap: 14px;
}
.gantt-panel-header p:last-child {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.6;
}
.gantt-board {
  margin-top: 12px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.92);
}
.gantt-activity-group + .gantt-activity-group {
  border-top: 1px solid rgba(148, 163, 184, 0.18);
}
.gantt-board-nested {
  margin-top: 14px;
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.98);
}
.gantt-board-header {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.03), rgba(15, 23, 42, 0.015));
}
.gantt-meta-head,
.gantt-meta-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  padding: 8px 12px;
}
.gantt-meta-head {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 700;
}
.gantt-meta-row {
  min-height: 28px;
  border-right: 1px solid rgba(148, 163, 184, 0.16);
}
.gantt-meta-row strong {
  font-size: 0.74rem;
  line-height: 1.2;
}
.gantt-head-track {
  position: relative;
  padding: 0;
}
.timeline-range {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 8px;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 600;
}
.timeline-range-compact {
  margin-top: 0;
  margin-bottom: 12px;
}
.gantt-scale {
  position: relative;
  min-height: 34px;
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.gantt-scale-month {
  position: absolute;
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0 4px;
  border-left: 1px solid rgba(15, 23, 42, 0.38);
  border-right: 1px solid rgba(15, 23, 42, 0.28);
  background: rgba(255, 255, 255, 0.28);
}
.gantt-scale-month.is-alt {
  background: rgba(248, 250, 252, 0.78);
}
.gantt-scale-month:first-child { border-left: 0; }
.gantt-chart { display: grid; gap: 4px; margin-top: 0; }
.gantt-row {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 0;
  align-items: center;
  border-top: 1px solid rgba(148, 163, 184, 0.12);
}
.gantt-row-sub .gantt-meta-row {
  padding-left: 18px;
  background: rgba(248, 250, 252, 0.6);
}
.gantt-meta-row-subitem strong {
  font-size: 0.7rem;
  font-weight: 600;
}
.gantt-track {
  position: relative;
  height: 26px;
  border-radius: 0;
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(241, 245, 249, 0.92));
  overflow: hidden;
}
.gantt-month-guides {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.gantt-month-guide {
  position: absolute;
  top: 0;
  bottom: 0;
  border-left: 1px solid rgba(15, 23, 42, 0.4);
  border-right: 1px solid rgba(15, 23, 42, 0.28);
  background: rgba(255, 255, 255, 0.2);
}
.gantt-month-guide.is-alt {
  background: rgba(248, 250, 252, 0.4);
}
.gantt-bar {
  position: absolute;
  top: 5px;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(135deg, #f59e0b, #ef4444);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  box-shadow: 0 6px 14px rgba(239, 68, 68, 0.16);
}
.gantt-bar span { overflow: hidden; text-overflow: ellipsis; font-weight: 700; font-size: 0.58rem; }
.gantt-bar-subactivity {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  box-shadow: 0 10px 22px rgba(29, 78, 216, 0.18);
}
.gantt-progress-marker {
  position: absolute;
  top: 14px;
  height: 3px;
  border-radius: 999px;
  background: rgba(239, 68, 68, 0.14);
  overflow: hidden;
}
.gantt-progress-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: rgba(239, 68, 68, 0.75);
}
.gantt-progress-marker-sub {
  background: rgba(37, 99, 235, 0.14);
}
.gantt-progress-fill-sub {
  background: rgba(37, 99, 235, 0.72);
}
.gantt-board-header-repeat {
  position: sticky;
  top: 0;
  z-index: 1;
}
.indicator-editor-list {
  display: grid;
  gap: 14px;
}
.indicator-preview-panel,
.indicator-edit-panel {
  margin-top: 14px;
}
.indicator-edit-trigger-wrap {
  justify-content: flex-start;
  padding: 0;
}
.indicator-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.indicator-preview-card {
  min-height: 108px;
  border: 1px solid rgba(15, 23, 42, 0.9);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.94);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}
.indicator-preview-card strong,
.indicator-preview-card p:last-child {
  color: #111827;
  font-size: 1rem;
  line-height: 1.35;
  margin: 0;
}
.indicator-preview-card .eyebrow {
  color: #374151;
}
.indicator-editor-card {
  padding: 16px;
}
.indicator-editor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
}
.activity-gantt-section { margin-top: 18px; }
.activity-gantt-stack { display: grid; gap: 16px; margin-top: 10px; }
.activity-gantt-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.94);
  padding: 18px;
}
.activity-gantt-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}
.activity-gantt-header h5 { margin: 6px 0 0; }
.activity-gantt-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin: 10px 0 14px;
  color: var(--muted);
  font-size: 0.92rem;
}
.gantt-chart-subactivities { margin-top: 0; }
.gantt-chart-subactivities .gantt-row { grid-template-columns: 320px minmax(0, 1fr); }
.action-accordion-trigger[aria-expanded="true"] {
  background: rgba(15, 23, 42, 0.08);
}
@keyframes accordionFade {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.editor-actions { display: flex; gap: 10px; flex-wrap: nowrap; align-items: center; margin-top: 14px; }
.editor-actions .editor-button { white-space: nowrap; }
.editor-actions-shared { justify-content: flex-start; margin-top: 18px; }
.editor-button {
  border: 2px solid rgba(17, 24, 39, 0.92);
  border-radius: 999px;
  padding: 12px 16px;
  background: linear-gradient(135deg, #f5d44a, #f0bf2b);
  color: #111827;
  cursor: pointer;
  font-family: "Space Mono", monospace;
  font-weight: 700;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.4) inset,
    0 10px 18px rgba(17, 24, 39, 0.08);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, filter 180ms ease;
}
.editor-button:hover {
  transform: translateY(-1px);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.4) inset,
    0 12px 20px rgba(17, 24, 39, 0.12);
}
.editor-button:disabled {
  cursor: not-allowed;
  filter: grayscale(0.12);
  opacity: 0.58;
  transform: none;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.24) inset,
    0 6px 10px rgba(17, 24, 39, 0.06);
}
.editor-button-secondary {
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(245, 239, 227, 0.96));
  color: var(--text);
  border-color: rgba(17, 24, 39, 0.82);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.7) inset,
    0 8px 16px rgba(17, 24, 39, 0.05);
}
.editor-button-secondary:hover {
  border-color: rgba(17, 24, 39, 1);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.7) inset,
    0 10px 18px rgba(17, 24, 39, 0.08);
}
.editor-button-danger {
  background: linear-gradient(180deg, rgba(255, 248, 248, 0.98), rgba(255, 234, 228, 0.96));
  color: #7f1d1d;
  border: 2px solid rgba(127, 29, 29, 0.72);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.7) inset,
    0 8px 16px rgba(127, 29, 29, 0.08);
}
.editor-button-danger:hover {
  border-color: rgba(127, 29, 29, 0.9);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.7) inset,
    0 10px 18px rgba(127, 29, 29, 0.1);
}
.dialog-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.38);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 50;
}
.dialog-card {
  width: min(980px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.65);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.24);
  padding: 24px;
}
.dialog-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 16px;
  margin-bottom: 18px;
}
.dialog-header h3 {
  margin: 0;
  font-family: "Space Mono", monospace;
  font-size: 1.5rem;
}
.dialog-header p {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.6;
}
.dialog-close-button {
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  color: var(--text);
  font-size: 1.25rem;
  cursor: pointer;
}
.copy-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.copy-field { display: block; }
.copy-textarea { min-height: 140px; }
.dialog-actions { margin-top: 20px; justify-content: flex-start; }
.risk-badge.alta, .status-atrasada { background: rgba(220, 38, 38, 0.12); color: var(--red); }
.risk-badge.media, .status-en_riesgo { background: rgba(217, 119, 6, 0.14); color: var(--amber); }
.status-en_ejecucion { background: rgba(37, 99, 235, 0.12); color: var(--blue); }
.status-completada { background: rgba(15, 118, 110, 0.12); color: var(--teal); }
.grid-list.two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.bar-row { display: grid; grid-template-columns: 180px minmax(0, 1fr) 50px; align-items: center; gap: 12px; }
.bar-track, .progress-line { height: 12px; border-radius: 999px; background: rgba(148, 163, 184, 0.18); overflow: hidden; }
.bar-fill, .progress-line > span { height: 100%; display: block; border-radius: inherit; background: linear-gradient(90deg, var(--red), var(--blue)); }
.donut-chart { width: 170px; height: 170px; }
.donut-chart circle { fill: none; stroke-width: 12; transform: rotate(-90deg); transform-origin: 50% 50%; }
.donut-bg { stroke: rgba(100, 116, 139, 0.32); }
.donut-progress { stroke: url(#donutGradient); stroke-linecap: round; filter: saturate(1.05) brightness(0.88); }
.donut-center { text-anchor: middle; dominant-baseline: middle; fill: var(--text); font-family: "Space Mono", monospace; font-size: 1.5rem; font-weight: 700; }
.legend-item, .critical-item, .indicator-item, .simple-item, .grid-card, .timeline-item { border: 1px solid var(--line); background: var(--surface-strong); padding: 16px; }
.semaphore { width: 12px; height: 12px; border-radius: 999px; display: inline-block; margin-right: 8px; }
.semaphore.verde { background: #22c55e; box-shadow: 0 0 0 6px rgba(34, 197, 94, 0.12); }
.semaphore.amarillo { background: #f59e0b; box-shadow: 0 0 0 6px rgba(245, 158, 11, 0.12); }
.semaphore.rojo { background: #ef4444; box-shadow: 0 0 0 6px rgba(239, 68, 68, 0.12); }
.table-card { padding: 22px; }
.table-card table { width: 100%; border-collapse: collapse; }
.table-card th, .table-card td { text-align: left; padding: 14px 8px; border-bottom: 1px solid var(--line); vertical-align: top; }
.table-card th { color: var(--muted); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; }
@media (max-width: 1200px) { .metric-card, .action-summary-card { grid-column: span 6; } .chart-card, .progress-card, .critical-card, .semaphore-card { grid-column: span 12; } .dimension-board, .action-summary-grid, .dashboard-header-top, .dashboard-header-bottom { grid-template-columns: repeat(2, minmax(0, 1fr)); } .dashboard-hero-panel { grid-template-columns: 1fr; } .dashboard-hero-side { grid-template-columns: repeat(3, minmax(0, 1fr)); grid-template-rows: none; border-left: 0; border-top: 1px solid rgba(23, 28, 43, 0.08); } .dashboard-hero-side-card + .dashboard-hero-side-card { border-top: 0; border-left: 1px solid rgba(23, 28, 43, 0.08); } .detail-grid, .detail-stats, .dimension-preview-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 980px) { .app-shell { grid-template-columns: 1fr; } .sidebar { position: static; height: auto; } .grid-list.two-up, .dimension-board, .action-summary-grid, .detail-grid, .detail-stats, .copy-form-grid, .dimension-preview-grid, .action-form-grid-two-up, .action-detail-grid, .gantt-board-header, .action-name-list, .dashboard-header-top, .dashboard-header-bottom, .dashboard-hero-chart-panel, .dashboard-hero-side, .action-dimension-picker { grid-template-columns: 1fr; } .gantt-row, .activity-editor-head, .activity-editor-row, .subactivity-editor-head-grid, .subactivity-editor-row { grid-template-columns: 1fr; } .gantt-meta-head, .gantt-meta-row, .gantt-meta-head-sub, .gantt-meta-row-sub { grid-template-columns: 1fr 1fr; } .dashboard-hero-side-card + .dashboard-hero-side-card { border-left: 0; border-top: 1px solid rgba(23, 28, 43, 0.08); } }
@media (max-width: 720px) { .main-layout, .sidebar { padding: 18px; } .topbar { grid-template-columns: 1fr; justify-items: center; } .topbar-actions { justify-self: center; } .hero-card, .donut-wrap, .critical-item header, .indicator-item header, .simple-item header, .timeline-item header, .action-card-header, .dialog-header, .activity-card-header, .milestone-item, .activity-gantt-header, .activity-gantt-meta, .funding-history-item { flex-direction: column; align-items: start; } .metric-card, .action-summary-card { grid-column: span 12; } .bar-row { grid-template-columns: 1fr; } .detail-stats, .budget-summary-grid, .budget-summary-grid-compact, .action-form-grid-two-up, .request-composer-row, .funding-composer-head, .funding-composer-row, .verification-item-row, .milestone-editor-head, .milestone-editor-row, .milestone-tracking-summary, .milestone-table-head, .milestone-table-row, .evidence-requirements-head, .evidence-requirements-row, .material-request-table-head, .material-request-summary-row, .material-request-summary-grid { grid-template-columns: 1fr; } .dialog-card { padding: 18px; } .subactivity-item { grid-template-columns: 12px minmax(0, 1fr); } .subactivity-status { grid-column: 2; } .gantt-scale { grid-template-columns: repeat(4, minmax(0, 1fr)); } .gantt-board-nested .gantt-scale { grid-template-columns: repeat(3, minmax(0, 1fr)); } .action-field-span-2 { grid-column: auto; } .subactivity-editor-row { grid-template-columns: 1fr; } }
