:root {
  color-scheme: dark;
  --bg: #09111f;
  --bg-soft: rgba(8, 19, 36, 0.82);
  --panel: rgba(10, 22, 42, 0.88);
  --surface: rgba(11, 22, 42, 0.92);
  --surface2: rgba(6, 13, 25, 0.88);
  --line: rgba(164, 199, 255, 0.11);
  --line-hover: rgba(124, 245, 215, 0.22);
  --text: #e8f2ff;
  --muted: #8ba4c0;
  --accent: #7cf5d7;
  --accent-alt: #ffad66;
  --danger: #ff7a7a;
  --shadow: 0 12px 40px rgba(0, 0, 0, 0.3), 0 2px 8px rgba(0,0,0,0.2);
  --shadow-sm: 0 2px 12px rgba(0, 0, 0, 0.22);
  --radius: 0.75rem;
  --radius-sm: 0.5rem;
  --radius-lg: 1rem;
  --radius-xl: 1.25rem;
  font-family: 'Inter', "Segoe UI", system-ui, sans-serif;
  font-size: 13px;
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
body {
  background:
    radial-gradient(circle at top left, rgba(124, 245, 215, 0.10), transparent 24%),
    radial-gradient(circle at 85% 12%, rgba(255, 173, 102, 0.13), transparent 18%),
    linear-gradient(135deg, #09111f 0%, #0d1730 45%, #081019 100%);
  color: var(--text);
  font-size: 0.8125rem;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
button, input, textarea, select, a { font: inherit; }
a { color: inherit; text-decoration: none; }
code { color: var(--accent); font-size: 0.75rem; }
p { margin: 0.5rem 0 0; }
h1,h2,h3,h4 { margin: 0; line-height: 1.2; }

.app-shell { min-height: 100vh; position: relative; overflow-x: hidden; padding-bottom: 5rem; }
.ambient { position: fixed; width: 30rem; height: 30rem; border-radius: 999px; filter: blur(72px); opacity: 0.24; pointer-events: none; }
.ambient-a { top: -8rem; left: -8rem; background: #40e0c0; }
.ambient-b { right: -8rem; bottom: -8rem; background: #ff8c42; }
.grid-overlay { position: fixed; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px); background-size: 36px 36px; mask-image: linear-gradient(to bottom, rgba(0,0,0,0.9), transparent); pointer-events: none; }
.flash-stack { position: fixed; top: 1rem; right: 1rem; display: grid; gap: 0.75rem; z-index: 20; }
.flash { min-width: 18rem; max-width: 26rem; padding: 0.9rem 1rem; border-radius: 1rem; border: 1px solid var(--line); background: rgba(4, 11, 24, 0.92); box-shadow: var(--shadow); }
.flash-success { border-color: rgba(124, 245, 215, 0.3); }
.flash-error { border-color: rgba(255, 122, 122, 0.32); }
.flash-warning { border-color: rgba(255, 173, 102, 0.3); }
.flash-info { border-color: rgba(82, 186, 247, 0.3); }

.auth-layout, .dashboard-layout { position: relative; z-index: 1; }
.auth-layout { display: grid; grid-template-columns: 1.1fr 0.9fr; min-height: 100vh; }
.hero-panel, .auth-panel, .center-wrap { padding: 3rem; display: flex; align-items: center; justify-content: center; }
.hero-copy { max-width: 42rem; }
.hero-copy h1, .center-card h1, .topbar h1, .spotlight-card h2, .panel-card h2, .panel-card h3, .ticket-card h4 { margin: 0; line-height: 1.08; }
.hero-copy h1 { font-size: clamp(2.8rem, 5vw, 5rem); }
.hero-text { margin: 1rem 0 0; line-height: 1.7; color: var(--muted); }
.eyebrow { margin: 0 0 0.7rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.18em; font-size: 0.72rem; }
.hero-metrics, .member-list, .ticket-list, .approval-grid, .admin-list, .comment-list { display: grid; gap: 1rem; }
.metric-card, .panel-card, .spotlight-card, .center-card, .setup-note, .comment-card, .member-row, .approval-card, .ticket-card, .analytics-row, .stage-summary-card, .metric-block, .mini-stat {
  border: 1px solid var(--line);
  background: var(--bg-soft);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-sm);
  border-radius: var(--radius-lg);
}
.metric-card, .metric-block, .mini-stat, .stage-summary-card, .panel-card, .spotlight-card, .center-card, .comment-card, .member-row, .approval-card, .analytics-row, .ticket-card { padding: 0.9rem 1rem; }
.metric-card span, .metric-block span, .mini-stat span, .stage-summary-card span, .ticket-meta span, .member-row span, .approval-card span, .meta-chip, .detail-grid span, .muted-note, .admin-identity span, small { color: var(--muted); }
.metric-card strong, .metric-block strong { display: block; margin-top: 0.2rem; }
.metric-block strong { font-size: 1.75rem; }
.metric-amber { background: linear-gradient(135deg, rgba(255,173,102,0.25), rgba(255,173,102,0.08)); }
.metric-coral { background: linear-gradient(135deg, rgba(255,122,122,0.24), rgba(255,122,122,0.08)); }
.metric-teal { background: linear-gradient(135deg, rgba(124,245,215,0.24), rgba(124,245,215,0.08)); }
.metric-sky { background: linear-gradient(135deg, rgba(82,186,247,0.22), rgba(82,186,247,0.08)); }

.auth-card { width: min(100%, 32rem); }
.auth-tabs, .segmented-control { display: inline-flex; gap: 0.4rem; padding: 0.35rem; border: 1px solid var(--line); border-radius: 999px; background: rgba(4, 11, 24, 0.72); margin-bottom: 1.25rem; flex-wrap: wrap; }
.segmented-button { border: 1px solid var(--line); border-radius: 999px; padding: 0.7rem 1rem; color: var(--muted); background: transparent; display: inline-flex; align-items: center; justify-content: center; }
.segmented-button-active { color: var(--text); background: linear-gradient(135deg, rgba(124,245,215,0.22), rgba(82,186,247,0.22)); }

.auth-form, .ticket-form, .inline-form { display: grid; gap: 1rem; }
.auth-inline-form { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.ticket-form { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.ticket-form .span-two, .span-two { grid-column: span 2; }
label { display: flex; flex-direction: column; gap: 0.3rem; color: var(--muted); font-size: 0.75rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; }
input, textarea, select {
  width: 100%; min-height: 2.5rem; padding: 0.55rem 0.85rem; color: var(--text);
  border-radius: var(--radius); border: 1px solid var(--line); background: var(--surface2); outline: none;
  font-size: 0.8125rem; transition: border-color 0.15s, box-shadow 0.15s;
}
textarea { min-height: 7rem; resize: vertical; }
input:focus, textarea:focus, select:focus { border-color: rgba(124, 245, 215, 0.55); box-shadow: 0 0 0 3px rgba(124, 245, 215, 0.09); }
input::placeholder, textarea::placeholder { color: var(--muted); opacity: 0.7; }
select option { background: #0d1730; color: var(--text); }

.primary-button, .ghost-button, .danger-button, .warning-button {
  border-radius: var(--radius-sm); cursor: pointer; padding: 0.55rem 1rem;
  font-size: 0.8125rem; font-weight: 500;
  transition: transform 0.15s ease, opacity 0.15s ease, box-shadow 0.15s ease;
  display: inline-flex; align-items: center; gap: 0.4rem; white-space: nowrap;
}
.primary-button { border: 0; background: linear-gradient(135deg, #7cf5d7, #52baf7); color: #04111f; font-weight: 600; }
.primary-button:hover { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(124,245,215,0.25); }
.ghost-button { border: 1px solid var(--line); background: transparent; color: var(--text); }
.ghost-button:hover { background: rgba(255,255,255,0.04); border-color: rgba(164,199,255,0.22); transform: translateY(-1px); }
.danger-button { border: 1px solid rgba(255, 122, 122, 0.28); background: rgba(255, 122, 122, 0.08); color: #ffc8c8; }
.danger-button:hover { background: rgba(255, 122, 122, 0.16); transform: translateY(-1px); }
.warning-button { border: 1px solid rgba(255,173,102,0.28); background: rgba(255,173,102,0.08); color: #ffd5a8; }
.warning-button:hover { background: rgba(255,173,102,0.16); transform: translateY(-1px); }
.btn-sm { padding: 0.38rem 0.7rem; font-size: 0.75rem; }
.checkbox-row { flex-direction: row; align-items: center; }
.checkbox-row input { width: auto; min-height: auto; }
.compact-checkbox { font-size: 0.9rem; }

.topbar { position: sticky; top: 0; z-index: 10; display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1rem 1.75rem 0.75rem; backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); background: rgba(9,17,31,0.72); }
.topbar-actions { display: flex; align-items: center; gap: 1rem; }
.identity-pill, .meta-chip { padding: 0.35rem 0.75rem; border-radius: 999px; border: 1px solid var(--line); background: rgba(4, 11, 24, 0.72); font-size: 0.75rem; }
.identity-pill span, .identity-pill small { display: block; }
.dashboard-layout { padding: 0 2rem 2rem; }
.spotlight-card { margin-top: 0.75rem; padding: 1.1rem 1.25rem; border: 1px solid var(--line); background: var(--panel); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.section-header { display: flex; justify-content: space-between; gap: 1rem; align-items: center; margin-bottom: 1rem; }
.section-header-stack { align-items: flex-start; }
.compact-copy { max-width: 46rem; }
.metric-grid, .workspace-grid, .detail-grid, .ticket-meta, .progress-flow, .stage-summary-grid { display: grid; gap: 1rem; }
.metric-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.metric-grid-wide { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.workspace-grid { margin-top: 1rem; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.span-three { grid-column: span 3; }
.ticket-card { background: radial-gradient(circle at top right, rgba(124,245,215,0.08), transparent 24%), rgba(6, 15, 30, 0.7); }
.ticket-card-expanded { display: grid; gap: 1.25rem; }
.ticket-head-expanded, .comment-meta { display: flex; justify-content: space-between; gap: 1rem; }
.ticket-badges { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 0.75rem; }
.pill { display: inline-flex; align-items: center; padding: 0.2rem 0.55rem; border-radius: 999px; font-size: 0.68rem; border: 1px solid transparent; font-weight: 500; letter-spacing: 0.01em; }
.pill-low, .pill-sla-healthy { background: rgba(124,245,215,0.12); border-color: rgba(124,245,215,0.26); }
.pill-medium, .pill-sla-resolved { background: rgba(82,186,247,0.14); border-color: rgba(82,186,247,0.28); }
.pill-high, .pill-sla-warning { background: rgba(255,173,102,0.14); border-color: rgba(255,173,102,0.32); }
.pill-critical, .pill-sla-breached { background: rgba(255,122,122,0.14); border-color: rgba(255,122,122,0.34); }
.pill-neutral { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.09); }
.progress-flow { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.progress-node { display: grid; justify-items: center; gap: 0.5rem; padding: 0.8rem 0.6rem; border-radius: 1rem; border: 1px solid var(--line); background: rgba(3, 10, 24, 0.48); color: var(--muted); }
.progress-node-complete { color: var(--text); border-color: rgba(82,186,247,0.28); }
.progress-node-current { background: linear-gradient(135deg, rgba(124,245,215,0.16), rgba(82,186,247,0.16)); }
.progress-dot { width: 0.9rem; height: 0.9rem; border-radius: 999px; background: currentColor; }
.detail-grid, .ticket-meta-wide { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.ticket-meta, .admin-row, .admin-row-ticket, .analytics-row { align-items: end; }
.ticket-meta { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.ticket-meta form, .admin-row form, .admin-row-ticket form { display: grid; gap: 0.6rem; }
.comments-panel { border-top: 1px solid var(--line); padding-top: 1rem; }
.comment-card { background: rgba(3, 10, 24, 0.5); }
.approval-grid { grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); }
.approval-card-column { align-items: stretch; }
.admin-row { display: grid; grid-template-columns: 1.3fr repeat(6, minmax(0, 1fr)); gap: 0.6rem; padding: 0.85rem; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(5, 14, 28, 0.5); }
.admin-row-ticket { grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr)); }
.analytics-row { grid-template-columns: 1.4fr repeat(4, minmax(0, 1fr)); }
.stage-summary-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.mini-stat strong, .stage-summary-card strong { display: block; margin-top: 0.3rem; font-size: 1.4rem; }
.empty-state { text-align: center; padding: 2rem 1rem; border: 1px dashed var(--line); border-radius: 1rem; }
.announcement-banner { position: relative; z-index: 2; display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin: 1rem 2rem 0; padding: 1rem 1.2rem; border: 1px solid rgba(255,173,102,0.28); border-radius: 1.25rem; background: linear-gradient(135deg, rgba(255,173,102,0.18), rgba(82,186,247,0.16)); box-shadow: var(--shadow); }
.announcement-banner h3, .announcement-banner p { margin: 0; }
.center-card { max-width: 44rem; text-align: center; }
.setup-note { display: grid; gap: 0.4rem; margin-top: 1rem; }
.app-footer { position: fixed; left: 50%; bottom: 0.65rem; transform: translateX(-50%); z-index: 4; padding: 0.5rem 0.9rem; min-width: min(92vw, 20rem); text-align: center; color: var(--muted); border: 1px solid var(--line); border-radius: 999px; background: rgba(4, 11, 24, 0.9); backdrop-filter: blur(12px); font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; }

@media (max-width: 1200px) {
  .metric-grid-wide, .detail-grid, .ticket-meta, .admin-row, .admin-row-ticket, .analytics-row, .stage-summary-grid, .progress-flow { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 960px) {
  .auth-layout, .workspace-grid, .metric-grid, .metric-grid-wide, .detail-grid, .ticket-meta, .admin-row, .admin-row-ticket, .analytics-row, .stage-summary-grid, .progress-flow, .ticket-form { grid-template-columns: 1fr; }
  .hero-panel, .auth-panel, .dashboard-layout, .topbar, .center-wrap { padding-left: 1rem; padding-right: 1rem; }
  .auth-layout, .topbar, .ticket-head-expanded, .comment-meta, .announcement-banner, .section-header { flex-direction: column; align-items: stretch; }
  .span-two, .span-three { grid-column: span 1; }
  .auth-tabs, .segmented-control { width: 100%; }
  .segmented-button { width: 100%; }
  .app-footer { width: calc(100vw - 2rem); min-width: auto; }
}

.admin-user-card, .triage-card {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 1.1rem;
  background: rgba(5, 14, 28, 0.56);
}

.inline-admin-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.inline-admin-actions form {
  margin: 0;
}

.triage-card-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
}

.triage-card-head p {
  margin: 0.35rem 0 0;
  color: var(--muted);
}

.triage-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
}

@media (max-width: 960px) {
  .inline-admin-actions,
  .triage-card-head {
    flex-direction: column;
    align-items: stretch;
  }

  .triage-grid {
    grid-template-columns: 1fr;
  }
}

.admin-account-grid {
  display: grid;
  grid-template-columns: 1.2fr repeat(5, minmax(0, 1fr));
  gap: 0.8rem;
  align-items: end;
}

.account-summary {
  display: grid;
  gap: 0.25rem;
}

@media (max-width: 1200px) {
  .admin-account-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 960px) {
  .admin-account-grid {
    grid-template-columns: 1fr;
  }
}

.filter-bar {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, minmax(0, 1fr)) auto auto;
  gap: 0.8rem;
  align-items: end;
}

.ticket-meta-rich {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ticket-two-column {
  display: grid;
  grid-template-columns: 1.25fr 0.95fr;
  gap: 1rem;
}

.resolution-note {
  display: grid;
  gap: 0.25rem;
  margin-top: 0.9rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(5, 14, 28, 0.48);
}

.resolution-note span {
  color: var(--muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.activity-list {
  display: grid;
  gap: 0.9rem;
}

.activity-row {
  display: grid;
  grid-template-columns: 1rem 1fr;
  gap: 0.9rem;
  align-items: start;
}

.activity-row p {
  margin: 0.25rem 0 0;
  color: var(--muted);
}

.activity-dot {
  width: 0.8rem;
  height: 0.8rem;
  margin-top: 0.35rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #7cf5d7, #52baf7);
  box-shadow: 0 0 0 6px rgba(124, 245, 215, 0.08);
}

.admin-row-ticket-rich {
  grid-template-columns: 1.3fr repeat(5, minmax(0, 1fr));
}

.triage-grid-wide {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

@media (max-width: 1200px) {
  .filter-bar,
  .ticket-meta-rich,
  .ticket-two-column,
  .admin-row-ticket-rich,
  .triage-grid-wide {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 960px) {
  .filter-bar,
  .ticket-meta-rich,
  .ticket-two-column,
  .admin-row-ticket-rich,
  .triage-grid-wide {
    grid-template-columns: 1fr;
  }
}
.auth-track-link {
  margin-top: 1rem;
  display: flex;
  justify-content: center;
}

.stack-actions-tight {
  display: grid;
  gap: 0.65rem;
  justify-items: end;
}

.detail-grid-rich {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ticket-section-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.panel-section {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(5, 14, 28, 0.42);
}

.inline-form-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: end;
}

.saved-view-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.8rem;
  margin-top: 0.8rem;
}

.notification-grid {
  margin-top: 1rem;
}

.notification-card {
  display: grid;
  gap: 0.75rem;
}

.track-card {
  width: min(100%, 70rem);
}

.track-result {
  display: grid;
  gap: 1rem;
  margin-top: 1.5rem;
}

@media (max-width: 1200px) {
  .detail-grid-rich,
  .ticket-section-grid,
  .inline-form-row,
  .saved-view-form {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 960px) {
  .stack-actions-tight {
    justify-items: stretch;
  }

  .detail-grid-rich,
  .ticket-section-grid,
  .inline-form-row,
  .saved-view-form {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   SIDEBAR SHELL
   ========================================================= */
:root { --sidebar-w: 13.5rem; }

.sb-body {
  display: flex;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(124,245,215,0.10), transparent 24%),
    radial-gradient(circle at 85% 12%, rgba(255,173,102,0.13), transparent 18%),
    linear-gradient(135deg, #09111f 0%, #0d1730 45%, #081019 100%);
  color: var(--text);
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  font-size: 0.8125rem;
}

.sidebar {
  position: fixed; top:0; left:0; bottom:0;
  width: var(--sidebar-w); z-index:100;
  display: flex; flex-direction:column;
  background: rgba(5,11,23,0.95);
  backdrop-filter: blur(24px);
  border-right: 1px solid var(--line);
}

.sidebar-brand {
  display:flex; align-items:center; gap:0.65rem;
  padding:1rem 1rem 0.9rem;
  border-bottom: 1px solid var(--line);
}

.sidebar-logo {
  width:2rem; height:2rem; border-radius:0.5rem;
  background: linear-gradient(135deg,#7cf5d7,#52baf7);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}

.sidebar-app-name { font-size:0.875rem; font-weight:700; letter-spacing:-0.01em; }
.sidebar-app-sub  { font-size:0.65rem; color:var(--muted); text-transform:uppercase; letter-spacing:0.06em; margin-top:0.1rem; }

.sidebar-nav {
  flex:1; overflow-y:auto;
  padding:0.6rem 0.5rem;
  display:flex; flex-direction:column; gap:0.1rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(124,245,215,0.15) transparent;
}

.sidebar-link {
  display:flex; align-items:center; gap:0.6rem;
  padding:0.5rem 0.7rem; border-radius:var(--radius-sm);
  color:var(--muted); font-size:0.8rem; font-weight:500;
  transition:background 0.15s,color 0.15s;
  text-decoration:none; border:1px solid transparent;
  line-height: 1;
}
.sidebar-link:hover { background:rgba(124,245,215,0.07); color:var(--text); }
.sidebar-link-active {
  background: linear-gradient(135deg,rgba(124,245,215,0.14),rgba(82,186,247,0.10));
  color:var(--text); border-color:rgba(124,245,215,0.18);
}

.sidebar-icon {
  width: 1.1rem; height: 1.1rem; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  opacity: 0.75;
}
.sidebar-link:hover .sidebar-icon,
.sidebar-link-active .sidebar-icon { opacity: 1; }
.sidebar-icon svg { width: 0.95rem; height: 0.95rem; }

.sidebar-divider { height:1px; background:var(--line); margin:0.4rem 0.35rem; }
.sidebar-section-label {
  font-size:0.63rem; color:var(--muted);
  text-transform:uppercase; letter-spacing:0.14em;
  padding:0.2rem 0.7rem 0.1rem;
}

.sidebar-footer {
  border-top:1px solid var(--line);
  padding:0.75rem 0.85rem;
  display:flex; align-items:center; gap:0.5rem;
}

.sidebar-avatar {
  width:1.75rem; height:1.75rem; border-radius:999px;
  background:linear-gradient(135deg,#7cf5d7,#52baf7);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:0.72rem; color:#04111f; flex-shrink:0;
}

.sidebar-user-info { flex:1; min-width:0; }
.sidebar-user-name {
  font-size:0.78rem; font-weight:500;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sidebar-user-role { font-size:0.65rem; color:var(--muted); text-transform:capitalize; margin-top:0.05rem; }

.sidebar-signout {
  background:transparent; border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:0.3rem 0.5rem; color:var(--muted); cursor:pointer; font-size:0.72rem;
  transition:color 0.15s, border-color 0.15s;
}
.sidebar-signout:hover { color:var(--danger); border-color:rgba(255,122,122,0.3); }

.sb-main { margin-left:var(--sidebar-w); flex:1; min-width:0; position:relative; z-index:1; }
.sb-page { padding:1.5rem 2rem 3rem; max-width:1400px; }

/* =========================================================
   PAGE HEADER & BREADCRUMB
   ========================================================= */
.page-header {
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:1.25rem; margin-bottom:1.25rem;
}
.page-title { font-size:1.2rem; font-weight:700; margin:0.15rem 0 0; line-height:1.2; letter-spacing:-0.02em; }
.page-subtitle { margin:0.25rem 0 0; color:var(--muted); font-size:0.78rem; line-height:1.55; }
.page-header-actions { display:flex; gap:0.5rem; align-items:center; flex-shrink:0; }

.breadcrumb {
  display:flex; align-items:center; gap:0.5rem;
  font-size:0.82rem; color:var(--muted); margin-bottom:1rem;
}
.breadcrumb a { color:var(--accent); text-decoration:none; }
.breadcrumb a:hover { text-decoration:underline; }
.breadcrumb-sep { color:var(--muted); }

/* =========================================================
   SECTION CARD
   ========================================================= */
.section-card {
  background:var(--panel); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:1.1rem; margin-bottom:1rem;
  backdrop-filter:blur(16px); box-shadow:var(--shadow-sm);
}
.section-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:1rem; }
.section-card-title  { margin:0.15rem 0 0; font-size:0.875rem; font-weight:600; }

/* =========================================================
   HOME METRIC CARDS
   ========================================================= */
.home-metrics {
  display:grid; grid-template-columns:repeat(5,minmax(0,1fr));
  gap:0.75rem; margin-bottom:1.25rem;
}
.hm-card {
  border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:1rem 1.1rem; backdrop-filter:blur(16px); box-shadow:var(--shadow-sm);
  transition:border-color 0.15s, transform 0.15s;
}
.hm-card:hover { border-color:rgba(164,199,255,0.2); transform:translateY(-1px); }
.hm-label { font-size:0.66rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--muted); margin-bottom:0.3rem; }
.hm-value { font-size:1.6rem; font-weight:700; line-height:1; margin-bottom:0.2rem; letter-spacing:-0.02em; }
.hm-sub   { font-size:0.73rem; color:var(--muted); }
.hm-amber { background:linear-gradient(135deg,rgba(255,173,102,0.22),rgba(255,173,102,0.07)); }
.hm-coral { background:linear-gradient(135deg,rgba(255,122,122,0.22),rgba(255,122,122,0.07)); }
.hm-teal  { background:linear-gradient(135deg,rgba(124,245,215,0.22),rgba(124,245,215,0.07)); }
.hm-sky   { background:linear-gradient(135deg,rgba(82,186,247,0.20),rgba(82,186,247,0.07)); }

/* =========================================================
   QUEUE CARDS
   ========================================================= */
.queue-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.queue-grid-full { grid-template-columns:repeat(auto-fill,minmax(17rem,1fr)); }

.queue-card {
  background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:0.95rem 1rem; display:block; text-decoration:none; color:var(--text);
  transition:border-color 0.18s,transform 0.18s,box-shadow 0.18s; cursor:pointer;
  position:relative; overflow:hidden;
}
.queue-card:hover { border-color:rgba(124,245,215,0.32); transform:translateY(-2px); box-shadow:0 6px 24px rgba(0,0,0,0.25); }
.queue-card-large { padding:1.15rem; }

.queue-card-header { display:flex; align-items:center; gap:0.6rem; margin-bottom:0.75rem; }
.queue-icon { font-size:1.25rem; }
.queue-icon-large { font-size:1.8rem; flex-shrink:0; }
.queue-name { font-size:0.875rem; font-weight:600; }
.queue-desc { font-size:0.75rem; color:var(--muted); margin-top:0.1rem; }
.queue-stats { display:flex; gap:0.85rem; }
.queue-stats-large { gap:1.25rem; margin-bottom:0.75rem; }
.qs-item { display:flex; flex-direction:column; }
.qs-val  { font-size:1.25rem; font-weight:700; line-height:1; letter-spacing:-0.02em; }
.qs-lbl  { font-size:0.65rem; color:var(--muted); margin-top:0.1rem; text-transform:uppercase; letter-spacing:0.05em; }
.qs-critical .qs-val { color:#ffad66; }
.qs-breached .qs-val { color:#ff7a7a; }
.queue-empty { font-size:0.75rem; color:var(--muted); margin:0.4rem 0 0; }
.queue-cta   { font-size:0.75rem; color:var(--accent); font-weight:500; }

/* =========================================================
   REQUEST TABLE
   ========================================================= */
.req-table-wrap { overflow-x:auto; border-radius:var(--radius); border:1px solid var(--line); }
.req-table { width:100%; border-collapse:collapse; font-size:0.78rem; }
.req-table th {
  padding:0.55rem 0.85rem; text-align:left;
  font-size:0.65rem; text-transform:uppercase; letter-spacing:0.1em;
  color:var(--muted); background:rgba(3,10,24,0.6);
  border-bottom:1px solid var(--line); white-space:nowrap; font-weight:600;
}
.req-table td {
  padding:0.65rem 0.85rem;
  border-bottom:1px solid rgba(164,199,255,0.06); vertical-align:middle;
}
.req-row { cursor:pointer; transition:background 0.12s; }
.req-row:hover { background:rgba(124,245,215,0.04); }
.req-row:last-child td { border-bottom:none; }

.req-id-link { color:var(--accent); font-weight:600; font-size:0.75rem; text-decoration:none; white-space:nowrap; font-variant-numeric:tabular-nums; }
.req-id-link:hover { text-decoration:underline; }
.req-title { max-width:26rem; }
.req-title-link { color:var(--text); text-decoration:none; font-weight:500; font-size:0.8rem; }
.req-title-link:hover { color:var(--accent); }
.req-tags { display:flex; gap:0.25rem; flex-wrap:wrap; margin-top:0.25rem; }
.req-date     { white-space:nowrap; color:var(--muted); font-size:0.73rem; }
.req-assignee { color:var(--muted); font-size:0.75rem; white-space:nowrap; }

.qd-filter-bar {
  display:grid;
  grid-template-columns:1.5fr repeat(3,minmax(0,1fr)) auto auto;
  gap:0.75rem; align-items:end;
}

/* =========================================================
   STATUS PILL VARIANTS
   ========================================================= */
.pill-status-triage      { background:rgba(255,173,102,0.16); border-color:rgba(255,173,102,0.35); color:#ffad66; }
.pill-status-in_progress { background:rgba(82,186,247,0.16);  border-color:rgba(82,186,247,0.35);  color:#52baf7; }
.pill-status-blocked     { background:rgba(255,122,122,0.16); border-color:rgba(255,122,122,0.35); color:#ff7a7a; }
.pill-status-resolved    { background:rgba(124,245,215,0.14); border-color:rgba(124,245,215,0.32); color:#7cf5d7; }

/* =========================================================
   REQUEST DETAIL PAGE
   ========================================================= */
.rd-header { display:flex; justify-content:space-between; align-items:flex-start; gap:1.5rem; margin-bottom:1.25rem; }
.rd-title-area { flex:1; }
.rd-title { font-size:1.2rem; font-weight:700; margin:0; line-height:1.2; }
.rd-header-actions { display:flex; gap:0.75rem; align-items:center; flex-shrink:0; }

.rd-progress { margin-bottom:1.25rem; }

.rd-layout { display:grid; grid-template-columns:1fr 21rem; gap:1.25rem; align-items:start; }
.rd-main    { display:flex; flex-direction:column; }
.rd-sidebar { display:flex; flex-direction:column; }
.rd-info-card { padding:1.2rem; }

.rd-detail-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:0.65rem 1rem; margin-top:0.75rem; font-size:0.85rem;
}
.rd-detail-grid > div { display:flex; flex-direction:column; gap:0.1rem; }
.rd-detail-grid span  { color:var(--muted); font-size:0.76rem; text-transform:uppercase; letter-spacing:0.07em; }
.rd-detail-grid strong { font-weight:500; word-break:break-word; }
.rd-tracking-link { grid-column:span 2; }
.rd-tracking-link code { font-size:0.72rem; color:var(--muted); word-break:break-all; }
.rd-description { color:var(--muted); line-height:1.7; margin:0.5rem 0 0; }

.rd-actions-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.75rem; }
.rd-actions-grid form { display:grid; gap:0.5rem; }
.rd-unified-form {
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.rd-form-section {
  border:1px solid rgba(164,199,255,0.09);
  background:linear-gradient(180deg, rgba(10,23,43,0.6), rgba(7,17,31,0.34));
  border-radius:1rem;
  padding:1rem;
}
.rd-form-section-head {
  margin-bottom:0.9rem;
}
.rd-form-section-head h3 {
  margin:0.2rem 0 0;
  font-size:1rem;
  font-weight:600;
}
.rd-ops-highlights {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0.85rem;
  margin-bottom:1rem;
}
.rd-ops-highlight {
  padding:0.9rem 1rem;
  border-radius:0.95rem;
  border:1px solid var(--line);
  background:rgba(8,19,36,0.72);
  display:flex;
  flex-direction:column;
  gap:0.2rem;
}
.rd-ops-highlight span {
  color:var(--muted);
  font-size:0.74rem;
  text-transform:uppercase;
  letter-spacing:0.09em;
}
.rd-ops-highlight strong {
  font-size:1rem;
  font-weight:600;
}
.rd-section-chip-group {
  display:flex;
  gap:0.45rem;
  align-items:center;
  flex-wrap:wrap;
}
.rd-field-span-two {
  grid-column:1 / -1;
}
.rd-form-footer {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:0.2rem 0 0.1rem;
}
.rd-form-note {
  display:flex;
  flex-direction:column;
  gap:0.2rem;
}
.rd-form-note strong {
  font-size:0.95rem;
}
.rd-form-note span {
  color:var(--muted);
  font-size:0.82rem;
}

.comment-internal { border-color:rgba(255,173,102,0.2); background:rgba(255,173,102,0.05); }
.new-req-card { max-width:56rem; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1100px) {
  .rd-layout     { grid-template-columns:1fr; }
  .home-metrics  { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .queue-grid    { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:900px) {
  :root { --sidebar-w:0px; }
  .sidebar  { display:none; }
  .sb-page  { padding:1rem 1rem 3rem; }
  .home-metrics { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .queue-grid   { grid-template-columns:1fr; }
  .qd-filter-bar { grid-template-columns:1fr 1fr; }
  .rd-actions-grid { grid-template-columns:1fr; }
  .rd-detail-grid  { grid-template-columns:1fr; }
  .rd-ops-highlights { grid-template-columns:1fr; }
  .rd-form-footer { flex-direction:column; align-items:stretch; }
}
@media (max-width:600px) {
  .home-metrics { grid-template-columns:1fr 1fr; }
  .page-header  { flex-direction:column; }
  .rd-header    { flex-direction:column; }
}

/* =========================================================
   VIEW TABS (My Requests, etc.)
   ========================================================= */
.view-tabs { display:flex; gap:0.4rem; border-bottom:1px solid var(--line); margin-bottom:0; padding-bottom:0.65rem; flex-wrap:wrap; }
.view-tab {
  padding:0.38rem 0.85rem; border-radius:0.5rem 0.5rem 0 0;
  font-size:0.78rem; font-weight:500; text-decoration:none; color:var(--muted);
  border-bottom:2px solid transparent; transition:color 0.15s, border-color 0.15s;
}
.view-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.view-tab:hover  { color:var(--text); }

/* =========================================================
   SLA BAR
   ========================================================= */
.sla-bar {
  display:flex; height:0.75rem; border-radius:999px;
  overflow:hidden; background:rgba(255,255,255,0.05);
}
.sla-bar-breached { background:#ff7a7a; }
.sla-bar-warning  { background:#ffad66; }
.sla-bar-healthy  { background:#7cf5d7; }

.sla-legend { display:flex; gap:1rem; margin-top:0.5rem; font-size:0.8rem; color:var(--muted); }
.sla-dot { display:inline-block; width:0.6rem; height:0.6rem; border-radius:50%; margin-right:0.3rem; }
.sla-dot-breached { background:#ff7a7a; }
.sla-dot-warning  { background:#ffad66; }
.sla-dot-healthy  { background:#7cf5d7; }

/* =========================================================
   MINI PROGRESS BAR (SLA table column)
   ========================================================= */
.mini-bar {
  height:0.5rem; border-radius:999px;
  background:rgba(255,255,255,0.06); overflow:hidden; min-width:6rem;
}
.mini-bar-fill { height:100%; border-radius:999px; transition:width 0.4s; }
.mini-bar-good { background:#7cf5d7; }
.mini-bar-warn { background:#ffad66; }
.mini-bar-bad  { background:#ff7a7a; }

/* =========================================================
   RESOLUTION NOTE
   ========================================================= */
.resolution-note {
  background:rgba(124,245,215,0.08); border:1px solid rgba(124,245,215,0.2);
  border-radius:0.75rem; padding:0.9rem 1rem; margin-top:0.75rem;
  display:flex; flex-direction:column; gap:0.3rem;
}
.resolution-note span { font-size:0.75rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--accent); }
.resolution-note strong { font-size:0.9rem; }

/* =========================================================
   MUTED NOTE
   ========================================================= */
.muted-note { color:var(--muted); font-size:0.85rem; }

/* =========================================================
   TEMPLATE CARDS GRID
   ========================================================= */
.templates-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));
  gap:1rem; margin-top:1.5rem;
}
.template-card {
  display:flex; align-items:flex-start; gap:1rem;
  background:var(--surface); border:1px solid var(--line);
  border-radius:1.25rem; padding:1.25rem 1.5rem;
  text-decoration:none; color:var(--text);
  position:relative;
  transition:border-color 0.2s, transform 0.15s, box-shadow 0.2s;
}
.template-card:hover {
  border-color:rgba(124,245,215,0.35);
  transform:translateY(-2px);
  box-shadow:0 4px 24px rgba(0,0,0,0.3);
}
.template-card-icon { font-size:2rem; line-height:1; flex-shrink:0; }
.template-card-title { font-size:1rem; font-weight:600; margin-bottom:0.25rem; }
.template-card-meta  { font-size:0.75rem; color:var(--accent); margin-bottom:0.4rem; }
.template-card-desc  { font-size:0.82rem; color:var(--muted); }
.template-card-arrow {
  position:absolute; right:1.25rem; top:50%; transform:translateY(-50%);
  font-size:1.25rem; color:var(--accent); opacity:0;
  transition:opacity 0.2s, transform 0.2s;
}
.template-card:hover .template-card-arrow { opacity:1; transform:translateY(-50%) translateX(3px); }

/* =========================================================
   CHART CONTAINER
   ========================================================= */
.chart-container { position:relative; height:280px; }

/* =========================================================
   BULK ACTION TOOLBAR
   ========================================================= */
.bulk-toolbar {
  display:none; align-items:center; gap:0.75rem; flex-wrap:wrap;
  background:rgba(124,245,215,0.07); border:1px solid rgba(124,245,215,0.2);
  border-radius:0.75rem; padding:0.75rem 1rem; margin-bottom:1rem;
}
.bulk-toolbar.active { display:flex; }
.bulk-toolbar select, .bulk-toolbar input[type="text"] {
  padding:0.3rem 0.6rem; border-radius:0.5rem; font-size:0.82rem;
  border:1px solid var(--line); background:var(--surface2); color:var(--text);
}
.bulk-toolbar .bulk-count { font-size:0.82rem; font-weight:600; color:var(--accent); }

/* =========================================================
   GOOGLE OAUTH BUTTON
   ========================================================= */
.google-btn {
  display:flex; align-items:center; justify-content:center; gap:0.6rem;
  background:#fff; color:#222; border-radius:0.65rem;
  padding:0.65rem 1.25rem; font-weight:500; font-size:0.9rem;
  text-decoration:none; transition:opacity 0.15s;
}
.google-btn:hover { opacity:0.9; }

/* =========================================================
   LIGHT MODE CSS VARIABLE OVERRIDES (data-theme="light")
   ========================================================= */
[data-theme="light"] {
  --bg:      #f2f4f8;
  --bg-soft: rgba(255,255,255,0.9);
  --panel:   rgba(255,255,255,0.95);
  --surface: #ffffff;
  --surface2:#eceff5;
  --line:    rgba(0,0,0,0.08);
  --line-hover: rgba(14,138,110,0.25);
  --text:    #1a1d2e;
  --muted:   #5a607a;
  --accent:  #0e8a6e;
  --shadow:  0 2px 12px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.05);
  --shadow-sm: 0 1px 6px rgba(0,0,0,0.06);
}
[data-theme="light"] .sb-body { background:#f2f4f8; }
[data-theme="light"] .sidebar { background:rgba(255,255,255,0.97); border-right:1px solid var(--line); }
[data-theme="light"] .sidebar-link { color:#5a607a; }
[data-theme="light"] .sidebar-link:hover { background:rgba(0,0,0,0.04); color:#1a1d2e; }
[data-theme="light"] .sidebar-link-active { background:rgba(14,138,110,0.1); color:var(--accent); border-color:rgba(14,138,110,0.2); }
[data-theme="light"] .ambient-a, [data-theme="light"] .ambient-b { opacity:0.04; }
[data-theme="light"] .grid-overlay { opacity:0.02; }
[data-theme="light"] .section-card { background:#fff; border-color:rgba(0,0,0,0.07); box-shadow: var(--shadow-sm); }
[data-theme="light"] input, [data-theme="light"] textarea, [data-theme="light"] select { background:#fff; border-color:rgba(0,0,0,0.12); color:#1a1d2e; }
[data-theme="light"] .req-table th { background:rgba(0,0,0,0.03); }
[data-theme="light"] .topbar { background:rgba(242,244,248,0.9); border-color:rgba(0,0,0,0.08); }
[data-theme="light"] .hm-card { background:#fff; }
[data-theme="light"] .sidebar-footer { background:#fafbfd; }
[data-theme="light"] .page-title { color:#1a1d2e; }

/* =========================================================
   MAINTENANCE BANNER
   ========================================================= */
.maintenance-banner {
  position:fixed;top:0;left:0;right:0;z-index:9999;
  background:linear-gradient(90deg,#ff7a00,#ff4e42);
  color:#fff;font-weight:600;font-size:0.88rem;
  padding:0.55rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;
}
.maintenance-close {
  background:none;border:none;color:#fff;cursor:pointer;font-size:1rem;padding:0 0.4rem;
}
body:has(.maintenance-banner[style*="flex"]) .sidebar,
body:has(.maintenance-banner[style*="flex"]) .sb-main { padding-top:2.4rem; }

/* =========================================================
   KEYBOARD SHORTCUT MODAL
   ========================================================= */
.kb-modal {
  position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,0.6);
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);
}
.kb-modal-inner {
  background:var(--surface,#1a1d2e);border:1px solid var(--line,rgba(255,255,255,0.08));
  border-radius:1rem;padding:1.75rem;max-width:480px;width:100%;
  box-shadow:0 25px 60px rgba(0,0,0,0.5);
}
.kb-grid { display:grid;grid-template-columns:1fr 1fr;gap:0.65rem; }
.kb-item { display:flex;align-items:center;gap:0.4rem;font-size:0.85rem;color:var(--muted,#8890a8); }
.kb-item span { color:var(--text,#e8eaf0); }
kbd {
  background:var(--surface2,#12141f);border:1px solid var(--line,rgba(255,255,255,0.12));
  border-radius:0.3rem;padding:0.1rem 0.4rem;font-size:0.8rem;font-family:monospace;
  color:var(--accent,#7cf5d7);
}

/* =========================================================
   DUPLICATE DETECTION TOAST
   ========================================================= */
.dup-toast {
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:9998;
  background:var(--surface,#1a1d2e);border:1px solid rgba(255,173,102,0.4);
  border-radius:0.9rem;padding:1rem;max-width:380px;width:calc(100vw - 3rem);
  box-shadow:0 10px 40px rgba(0,0,0,0.4);
  animation:slideInRight 0.25s ease;
}
@keyframes slideInRight { from{transform:translateX(100%);opacity:0} to{transform:translateX(0);opacity:1} }

/* =========================================================
   SIDEBAR TOOL BUTTONS (dark mode + shortcuts)
   ========================================================= */
.sidebar-tool-btn {
  background:none;border:none;width:100%;text-align:left;cursor:pointer;font-size:inherit;
}

/* =========================================================
   VIEW TABS (admin subtabs)
   ========================================================= */
.view-tabs { display:flex;flex-wrap:wrap;gap:0.4rem; }
.view-tab {
  padding:0.45rem 0.85rem;border-radius:0.55rem;font-size:0.84rem;font-weight:500;
  color:var(--muted,#8890a8);text-decoration:none;cursor:pointer;transition:all 0.15s;
  background:var(--surface2,#12141f);border:1px solid transparent;
}
.view-tab:hover { color:var(--text,#e8eaf0);background:var(--surface,#1a1d2e); }
.view-tab.active { color:var(--accent,#7cf5d7);background:rgba(124,245,215,0.1);border-color:rgba(124,245,215,0.25); }

/* =========================================================
   STAGE DISTRIBUTION GRID (analytics)
   ========================================================= */
.stage-dist-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:0.75rem;margin-top:1rem; }
.stage-dist-card {
  background:var(--surface2,#12141f);border:1px solid var(--line,rgba(255,255,255,0.06));
  border-radius:0.75rem;padding:1rem;text-align:center;
}

/* =========================================================
   MINI PROGRESS BAR (team throughput)
   ========================================================= */
.mini-bar { background:var(--surface2,#12141f);border-radius:99px;height:6px;overflow:hidden;width:100%;min-width:80px; }
.mini-bar-fill { height:100%;border-radius:99px;transition:width 0.4s ease; }
.mini-bar-good  { background:#7cf5d7; }
.mini-bar-warn  { background:#ffad66; }
.mini-bar-bad   { background:#ff7a7a; }

/* =========================================================
   ADMIN USER CARDS (modern)
   ========================================================= */
.admin-user-card-modern {
  background:var(--surface,#1a1d2e);border:1px solid var(--line,rgba(255,255,255,0.06));
  border-radius:0.9rem;padding:1.25rem;transition:border-color 0.15s;
}
.admin-user-card-modern:hover { border-color:rgba(124,245,215,0.2); }
.admin-user-header { display:flex;align-items:center;gap:0.9rem;flex-wrap:wrap;margin-bottom:1rem; }
.admin-account-edit-grid {
  display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:0.5rem;align-items:end;flex-wrap:wrap;
}
.admin-checkboxes { display:flex;flex-wrap:wrap;gap:0.5rem;align-items:center; }
.admin-checkboxes .checkbox-row { font-size:0.8rem; }
.triage-modern-card {
  background:var(--surface,#1a1d2e);border:1px solid var(--line,rgba(255,255,255,0.06));
  border-radius:0.9rem;padding:1.25rem;transition:border-color 0.15s;
}
.triage-grid-modern { display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:0.6rem; }

/* =========================================================
   CSAT STARS
   ========================================================= */
.csat-stars { display:flex;justify-content:center;gap:0.5rem;margin:1rem 0; }
.csat-star {
  font-size:2.5rem;cursor:pointer;color:rgba(255,255,255,0.2);
  transition:color 0.15s,transform 0.1s;user-select:none;
}
.csat-star:hover { transform:scale(1.15); }
.csat-star-label { display:contents; }

/* =========================================================
   PILL STATUS VARIANTS
   ========================================================= */
.pill-status-open       { background:rgba(82,186,247,0.15);color:#52baf7; }
.pill-status-in_progress{ background:rgba(255,173,102,0.15);color:#ffad66; }
.pill-status-resolved   { background:rgba(124,245,215,0.15);color:#7cf5d7; }
.pill-status-closed     { background:rgba(136,144,168,0.15);color:#8890a8; }
.pill-status-triage     { background:rgba(185,130,255,0.15);color:#b982ff; }

.google-btn img { width:1.1rem; height:1.1rem; }




.rd-shell {
  display: grid;
  gap: 1.25rem;
}

.rd-badges-top {
  margin-bottom: 0.9rem;
}

.rd-subtitle {
  max-width: 56rem;
  margin-top: 0.55rem;
}

.rd-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.overview-card {
  display: grid;
  gap: 0.35rem;
  padding: 1.1rem 1.15rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: rgba(5, 14, 28, 0.62);
  box-shadow: var(--shadow);
}

.overview-card span {
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.overview-card strong {
  font-size: 1rem;
  line-height: 1.35;
}

.overview-card small {
  color: var(--muted);
}

.rd-stack {
  display: grid;
  gap: 1rem;
}

.rd-inline-action {
  display: flex;
  gap: 0.75rem;
  align-items: end;
  margin-top: 1rem;
}

.rd-comment-list,
.rd-compact-list {
  margin-bottom: 1rem;
}

.inline-hint {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.5;
}

.myreq-metrics {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.myreq-filter-bar {
  margin-top: 1rem;
}

.req-table-foot {
  margin-top: 0.85rem;
  color: var(--muted);
  font-size: 0.82rem;
  text-align: right;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  min-width: 0;
  flex: 1;
}

.sidebar-logo-icon {
  font-size: 0.88rem;
  font-weight: 700;
  color: #04111f;
}

.sidebar-icon {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

@media (max-width: 1200px) {
  .rd-overview-grid,
  .myreq-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .rd-overview-grid,
  .myreq-metrics,
  .rd-inline-action {
    grid-template-columns: 1fr;
  }

  .rd-inline-action {
    display: grid;
  }
}

.myreq-hero {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: stretch;
  padding: 1rem 0 1.15rem;
  border-bottom: 1px solid var(--line);
  margin-bottom: 1rem;
}

.myreq-hero-copy {
  display: grid;
  gap: 0.35rem;
  max-width: 42rem;
}

.myreq-hero-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  min-width: 18rem;
}

.myreq-mini-card {
  display: grid;
  gap: 0.2rem;
  padding: 0.95rem 1rem;
  border: 1px solid var(--line);
  border-radius: 0.9rem;
  background: rgba(5, 14, 28, 0.48);
}

.myreq-mini-card span {
  color: var(--muted);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.myreq-mini-card strong {
  font-size: 1.35rem;
  line-height: 1.1;
}

.myreq-summary-bar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.9rem 1rem;
  margin-top: 1rem;
  border: 1px solid var(--line);
  border-radius: 0.85rem;
  background: rgba(82, 186, 247, 0.07);
  color: var(--muted);
  font-size: 0.84rem;
}

@media (max-width: 1200px) {
  .myreq-hero {
    flex-direction: column;
  }

  .myreq-hero-stats {
    min-width: 0;
  }
}

@media (max-width: 900px) {
  .myreq-hero-stats {
    grid-template-columns: 1fr;
  }
}

.saved-view-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1rem;
}

.saved-view-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.6rem 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(82, 186, 247, 0.08);
  color: var(--text);
  text-decoration: none;
  font-size: 0.82rem;
}

.saved-view-form {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}

.saved-view-form input[type="text"] {
  min-width: 18rem;
}

.rd-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

@media (max-width: 900px) {
  .rd-metric-grid {
    grid-template-columns: 1fr;
  }
}

.founder-card {
  display: grid;
  gap: 0.85rem;
}

.founder-update-form {
  margin-top: 0.5rem;
}

.founder-metrics-extended {
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
  margin-bottom: 1.5rem;
}

.founder-layout-grid {
  align-items: start;
}

.founder-form-grid,
.founder-update-form,
.founder-mini-form {
  gap: 0.85rem;
}

.founder-card-rich {
  gap: 1rem;
}

.founder-subgrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.founder-inner-card {
  background: rgba(8, 18, 34, 0.72);
}

.founder-roi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.founder-approval-card,
.founder-attachment-card,
.founder-board-card {
  text-decoration: none;
}

.founder-attachment-card:hover {
  border-color: rgba(124,245,215,0.32);
}

.founder-timeline {
  display: grid;
  gap: 0.9rem;
}

.founder-timeline-item {
  display: grid;
  grid-template-columns: 0.9rem 1fr;
  gap: 0.8rem;
  align-items: start;
}

.founder-timeline-dot {
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 999px;
  margin-top: 0.35rem;
  background: linear-gradient(135deg, var(--accent), #7cf5d7);
  box-shadow: 0 0 0 4px rgba(124,245,215,0.08);
}

.founder-kind-risk .founder-timeline-dot {
  background: linear-gradient(135deg, #ff7c7c, #ffb36b);
}

.founder-kind-okr .founder-timeline-dot {
  background: linear-gradient(135deg, #5db0ff, #7cf5d7);
}

.founder-kind-approval .founder-timeline-dot {
  background: linear-gradient(135deg, #ffc857, #ff9f1c);
}

@media (max-width: 1100px) {
  .founder-subgrid,
  .founder-roi-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 760px) {
  .founder-subgrid,
  .founder-roi-grid {
    grid-template-columns: 1fr;
  }
}

.compact-record {
  overflow: hidden;
}

.compact-record-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
}

.compact-record-summary::-webkit-details-marker {
  display: none;
}

.compact-record-summary::after {
  content: '+';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--text);
  flex-shrink: 0;
}

.compact-record[open] .compact-record-summary::after {
  content: '-';
}

.compact-record-meta {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.compact-record-body {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}

.founder-decision-summary {
  align-items: flex-start;
}

.founder-decision-summary p {
  margin: 0.3rem 0 0;
}

@media (max-width: 760px) {
  .compact-record-summary {
    flex-direction: column;
    align-items: flex-start;
  }

  .compact-record-meta {
    justify-content: flex-start;
  }
}

.hm-neutral {
  background: linear-gradient(135deg, rgba(58,74,106,0.72), rgba(29,39,58,0.86));
}

.home-metrics-secondary {
  margin-top: 1rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-grid-two {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 1.25rem;
  margin: 1.25rem 0;
}

.home-split-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.mini-ticket-row {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid var(--line);
  border-radius: 0.85rem;
  text-decoration: none;
  color: var(--text);
  margin-bottom: 0.65rem;
  background: rgba(7, 17, 31, 0.45);
}

.mini-ticket-row-static {
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
}

.mini-ticket-row span {
  color: var(--muted);
  font-size: 0.82rem;
}

.mini-row-actions {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-wrap: wrap;
}

.mini-row-actions form {
  margin: 0;
}

@media (max-width: 980px) {
  .home-metrics-secondary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-grid-two,
  .home-split-cards {
    grid-template-columns: 1fr;
  }
}

.app-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1rem;
}

.app-card {
  display:flex;
  flex-direction:column;
  gap:0.75rem;
  padding:1rem;
  border-radius:var(--radius-lg);
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(10,23,43,0.7), rgba(7,17,31,0.5));
  text-decoration:none;
  color:var(--text);
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.app-card:hover {
  transform:translateY(-2px);
  border-color:rgba(124,245,215,0.26);
  box-shadow:0 6px 22px rgba(0,0,0,0.26);
}

.app-card-top {
  display:flex;
  justify-content:space-between;
  gap:0.8rem;
  align-items:flex-start;
}

.app-card-top h3 {
  margin:0.15rem 0 0;
  font-size:0.9rem;
  font-weight:600;
}

.app-metric-row {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0.7rem;
}

.app-metric-row div {
  padding:0.75rem 0.85rem;
  border-radius:0.85rem;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.05);
}

.app-metric-row span {
  display:block;
  color:var(--muted);
  font-size:0.73rem;
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin-bottom:0.25rem;
}

.app-metric-row strong {
  font-size:1.15rem;
}

.app-card-meta {
  display:flex;
  justify-content:space-between;
  gap:0.7rem;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:0.8rem;
}

@media (max-width:900px) {
  .app-metric-row { grid-template-columns:1fr; }
}

.app-inline-note p { margin: 0.45rem 0 0; color: var(--muted); line-height: 1.6; }
.rd-inline-link-row { display:flex; flex-wrap:wrap; gap:0.75rem; margin-top:1rem; }
.rd-inline-link-row .ghost-button { min-width: 0; }


.app-filter-bar {
  display: grid;
  grid-template-columns: minmax(260px, 2fr) repeat(3, minmax(0, 1fr)) auto;
  gap: 0.9rem;
  margin-bottom: 1.25rem;
}
.search-result-card {
  display: block;
  padding: 1rem 1.05rem;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(10, 17, 31, 0.72);
  text-decoration: none;
  color: inherit;
}
.search-result-card:hover {
  border-color: rgba(106, 227, 219, 0.35);
  transform: translateY(-1px);
}
.search-result-card p {
  margin: 0.45rem 0;
  color: var(--muted);
  line-height: 1.55;
}
@media (max-width: 1100px) {
  .app-filter-bar {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 720px) {
  .app-filter-bar {
    grid-template-columns: 1fr;
  }
}


.health-trend-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.85rem;
}
.health-trend-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 0.95rem;
  background: rgba(10, 17, 31, 0.68);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.health-trend-card span,
.health-trend-card small {
  color: var(--muted);
}
.health-trend-healthy { border-color: rgba(74, 222, 128, 0.22); }
.health-trend-degraded { border-color: rgba(251, 191, 36, 0.22); }
.health-trend-critical { border-color: rgba(248, 113, 113, 0.24); }


.app-registry-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.app-form-group {
  border: 1px solid rgba(164,199,255,0.09);
  background: linear-gradient(180deg, rgba(10,23,43,0.48), rgba(7,17,31,0.24));
  border-radius: 1rem;
  padding: 1rem;
}
.app-registry-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem 1rem;
  margin-top: 0.8rem;
}
.app-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 0.25rem;
}
.app-form-subtitle {
  margin: 0.35rem 0 0;
  max-width: 44rem;
}
@media (max-width: 900px) {
  .app-registry-grid {
    grid-template-columns: 1fr;
  }
  .app-form-actions {
    flex-direction: column;
    align-items: stretch;
  }
}


.command-palette { position: fixed; inset: 0; z-index: 35; background: rgba(3, 8, 20, 0.76); backdrop-filter: blur(14px); align-items: flex-start; justify-content: center; padding: 8vh 1rem 1rem; }
.command-palette-inner { width: min(52rem, 100%); border: 1px solid var(--line); background: rgba(7, 15, 29, 0.96); border-radius: 1.5rem; box-shadow: var(--shadow); padding: 1.2rem; }
.command-palette-head { display:flex; justify-content:space-between; gap:1rem; align-items:flex-start; margin-bottom:1rem; }
.command-palette-form { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:0.8rem; margin-bottom:1rem; }
.command-palette-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.85rem; }
.command-link-card { display:block; border:1px solid var(--line); border-radius:1rem; padding:0.95rem 1rem; background: rgba(12, 24, 44, 0.72); color: var(--text); text-decoration:none; }
.command-link-card strong { display:block; margin-bottom:0.25rem; }
.command-link-card span { color: var(--muted); font-size:0.9rem; }
.rd-dual-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:1rem; }
.rd-workboard { border:1px solid var(--line); border-radius:1rem; padding:1rem; background: rgba(7, 15, 29, 0.6); display:grid; gap:0.85rem; }
.rd-workboard-head { display:flex; justify-content:space-between; align-items:center; }
.rd-workboard-head h3 { margin:0; font-size:1rem; }
.rd-work-item { display:grid; grid-template-columns:auto minmax(0,1fr) auto; gap:0.75rem; align-items:center; padding:0.75rem 0.85rem; border:1px solid rgba(124,245,215,0.12); border-radius:0.9rem; background: rgba(10, 20, 36, 0.8); }
.rd-work-item-done { opacity:0.72; }
.rd-work-item-copy strong { display:block; }
.rd-work-item-copy p { margin:0.2rem 0 0; color:var(--muted); font-size:0.86rem; }
.incident-command-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:1rem; margin-top:1rem; }
.incident-command-card { border:1px solid var(--line); border-radius:1.15rem; padding:1rem; background: linear-gradient(180deg, rgba(14,26,48,0.92), rgba(7,15,29,0.9)); display:grid; gap:0.9rem; }
.incident-command-head { display:flex; justify-content:space-between; gap:0.75rem; align-items:flex-start; }
.incident-command-head h3 { margin:0.35rem 0 0; font-size:1.05rem; }
.incident-command-fields { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:0.8rem; }
@media (max-width: 900px) {
  .command-palette-grid, .rd-dual-grid, .incident-command-fields { grid-template-columns:1fr; }
}

/* =========================================================
   COMMAND PALETTE — compact
   ========================================================= */
.command-palette-inner { padding: 1rem; }
.command-link-card { padding: 0.8rem 0.9rem; border-radius: var(--radius); }
.command-link-card strong { font-size: 0.8rem; }
.command-link-card span { font-size: 0.75rem; }

/* =========================================================
   CONNECTOR HUB PAGE
   ========================================================= */
.hub-header-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}
.hub-stat-card {
  padding: 0.85rem 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--bg-soft);
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.hub-stat-card span { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }
.hub-stat-card strong { font-size: 1.5rem; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.hub-stat-card small { font-size: 0.72rem; color: var(--muted); }
.hub-stat-healthy strong { color: var(--accent); }
.hub-stat-degraded strong { color: var(--accent-alt); }
.hub-stat-critical strong { color: var(--danger); }

.hub-app-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 0.85rem;
  margin-top: 1rem;
}

.hub-app-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(160deg, rgba(10,22,42,0.88), rgba(6,14,28,0.75));
  overflow: hidden;
  transition: border-color 0.16s, transform 0.16s, box-shadow 0.16s;
}
.hub-app-card:hover {
  border-color: rgba(124,245,215,0.22);
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(0,0,0,0.28);
}
.hub-app-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0.9rem 1rem 0.75rem;
  border-bottom: 1px solid var(--line);
}
.hub-app-meta { flex: 1; min-width: 0; }
.hub-app-name { font-size: 0.875rem; font-weight: 600; margin-bottom: 0.2rem; }
.hub-app-desc { font-size: 0.73rem; color: var(--muted); line-height: 1.45; }
.hub-health-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  flex-shrink: 0;
}
.hub-health-badge::before {
  content: '';
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}
.hub-health-healthy { background: rgba(124,245,215,0.12); color: #7cf5d7; border: 1px solid rgba(124,245,215,0.25); }
.hub-health-degraded { background: rgba(255,173,102,0.12); color: #ffad66; border: 1px solid rgba(255,173,102,0.28); }
.hub-health-critical { background: rgba(255,122,122,0.12); color: #ff7a7a; border: 1px solid rgba(255,122,122,0.3); }
.hub-health-unknown { background: rgba(154,176,202,0.10); color: #9ab0ca; border: 1px solid rgba(154,176,202,0.2); }
.hub-health-maintenance { background: rgba(82,186,247,0.12); color: #52baf7; border: 1px solid rgba(82,186,247,0.25); }

.hub-app-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: 1px solid var(--line);
}
.hub-stat-cell {
  padding: 0.6rem 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  border-right: 1px solid var(--line);
}
.hub-stat-cell:last-child { border-right: none; }
.hub-stat-cell span { font-size: 0.63rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
.hub-stat-cell strong { font-size: 1rem; font-weight: 700; letter-spacing: -0.01em; }
.hub-stat-cell.has-issues strong { color: var(--accent-alt); }
.hub-stat-cell.has-critical strong { color: var(--danger); }

.hub-app-links {
  display: flex;
  gap: 0.4rem;
  padding: 0.65rem 0.85rem;
  flex-wrap: wrap;
  align-items: center;
}
.hub-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.28rem 0.6rem;
  border-radius: var(--radius-sm);
  font-size: 0.7rem;
  font-weight: 500;
  border: 1px solid var(--line);
  color: var(--muted);
  text-decoration: none;
  background: rgba(255,255,255,0.03);
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.hub-link-btn:hover { background: rgba(124,245,215,0.08); color: var(--text); border-color: rgba(124,245,215,0.22); }
.hub-link-btn svg { width: 0.7rem; height: 0.7rem; }

.hub-deps-section {
  padding: 0.6rem 0.85rem;
  border-top: 1px solid var(--line);
}
.hub-deps-label {
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 0.4rem;
}
.hub-deps-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}
.hub-dep-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  font-size: 0.67rem;
  border: 1px solid var(--line);
  background: rgba(82,186,247,0.07);
  color: #52baf7;
  text-decoration: none;
}
.hub-dep-chip:hover { border-color: rgba(82,186,247,0.32); background: rgba(82,186,247,0.12); }

.hub-ext-apps-section {
  margin-top: 1.25rem;
}
.hub-ext-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.hub-ext-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 1rem;
  background: rgba(10,22,42,0.7);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  text-decoration: none;
  color: var(--text);
  transition: border-color 0.15s, transform 0.15s;
}
.hub-ext-card:hover { border-color: rgba(124,245,215,0.22); transform: translateY(-1px); }
.hub-ext-card-top {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.hub-ext-icon {
  width: 2.25rem; height: 2.25rem;
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
  border: 1px solid var(--line);
  background: var(--surface2);
}
.hub-ext-name { font-size: 0.85rem; font-weight: 600; }
.hub-ext-type { font-size: 0.68rem; color: var(--muted); margin-top: 0.1rem; }
.hub-ext-desc { font-size: 0.73rem; color: var(--muted); line-height: 1.45; }
.hub-ext-status {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.7rem;
  color: var(--muted);
  margin-top: 0.1rem;
}
.hub-ext-dot {
  width: 0.45rem; height: 0.45rem;
  border-radius: 50%;
  flex-shrink: 0;
}
.hub-ext-dot-connected { background: #7cf5d7; box-shadow: 0 0 0 3px rgba(124,245,215,0.15); }
.hub-ext-dot-pending { background: #ffad66; }
.hub-ext-dot-disconnected { background: #ff7a7a; }

.hub-legend {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 0.75rem;
  padding: 0.65rem 0.9rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(5,12,24,0.5);
  font-size: 0.72rem;
  color: var(--muted);
}
.hub-legend-item { display: flex; align-items: center; gap: 0.4rem; }

.hub-filter-bar {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 0.75rem;
}

@media (max-width: 1100px) {
  .hub-header-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .hub-header-grid { grid-template-columns: 1fr 1fr; }
  .hub-app-grid, .hub-ext-grid { grid-template-columns: 1fr; }
}

/* =========================================================
   FLASH / TOAST — refined
   ========================================================= */
.flash { min-width: 16rem; max-width: 22rem; padding: 0.75rem 0.9rem; border-radius: var(--radius); font-size: 0.78rem; }

/* =========================================================
   BREADCRUMB — compact
   ========================================================= */
.breadcrumb { font-size: 0.73rem; margin-bottom: 0.75rem; }

/* =========================================================
   EMPTY STATE — compact
   ========================================================= */
.empty-state { padding: 1.5rem 1rem; font-size: 0.8rem; border-radius: var(--radius); }

/* =========================================================
   SECTION HEADER — compact
   ========================================================= */
.section-header { margin-bottom: 0.75rem; }

/* =========================================================
   MINI TICKET ROW — compact
   ========================================================= */
.mini-ticket-row { padding: 0.65rem 0.8rem; border-radius: var(--radius); margin-bottom: 0.5rem; }
.mini-ticket-row span { font-size: 0.73rem; }

/* =========================================================
   AUTH CARD — refined
   ========================================================= */
.hero-copy h1 { font-size: clamp(2.2rem, 4vw, 3.8rem); }
.segmented-button { padding: 0.5rem 0.85rem; font-size: 0.8rem; }

/* =========================================================
   ANNOUNCEMENT BANNER — compact
   ========================================================= */
.announcement-banner { margin: 0.75rem 1.75rem 0; padding: 0.75rem 1rem; border-radius: var(--radius-lg); }
.announcement-banner h3 { font-size: 0.875rem; }
.announcement-banner p { font-size: 0.78rem; }

/* =========================================================
   PROGRESS FLOW — compact
   ========================================================= */
.progress-node { padding: 0.65rem 0.5rem; border-radius: var(--radius-sm); }
.progress-dot { width: 0.7rem; height: 0.7rem; }
