/* ============================================================
   MOONQUAKE 3.0 DESIGN SYSTEM
   Dark NASA dispatch aesthetic
   ============================================================ */


/* ============================================================
   S0 — DESIGN TOKENS
   ============================================================ */

:root {
  /* ---- Surfaces ---- */
  --bg:           #0F1113;
  --panel:        #161A1E;
  --panel-2:      #1C2126;
  --panel-3:      #212830;
  --line:         #252B31;
  --line-hot:     #323941;

  /* ---- Text ---- */
  --ink:          #E8E4DC;
  --ink-dim:      #B8B3AA;
  --ink-mid:      #9F9A92;
  --ink-faint:    #8A857D;

  /* ---- Accent (themeable, was --goldstone) ---- */
  --accent:        #D9A441;
  --accent-bright: #F0BC5A;
  --accent-glow:   rgba(217, 164, 65, 0.18);

  /* ---- Semantic ---- */
  --transponder:  #4A8FB8;
  --positive:     #6BA870;
  --caution:      #C4883D;
  --critical:     #BC5E52;

  /* ---- Tool hues ---- */
  --brand-hue:    #B47CD9;
  --content-hue:  #4A8FB8;
  --revenue-hue:  #D9A441;
  --insights-hue: #6BA870;
  --settings-hue: #8F8B83;

  /* ---- Type families ---- */
  --font-display: 'Fraunces', serif;
  --font-body:    'Inter', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;

  /* ---- Spacing (4px base) ---- */
  --sp-1:   4px;
  --sp-2:   8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-20: 80px;
  --sp-24: 96px;

  /* ---- Type scale ---- */
  --text-xs:  10px;
  --text-sm:  12px;
  --text-base: 14px;
  --text-md:  16px;
  --text-lg:  18px;
  --text-xl:  22px;
  --text-2xl: 28px;
  --text-3xl: 36px;
  --text-4xl: 48px;

  /* ---- Z-index layers ---- */
  --z-rail:          50;
  --z-nav:           40;
  --z-content:        1;
  --z-dropdown:      60;
  --z-modal-overlay: 100;
  --z-modal:         110;
  --z-toast:         120;
  --z-cmd-palette:   130;

  /* ---- Motion ---- */
  --ease:          cubic-bezier(0.4, 0, 0.2, 1);
  --duration-fast: 0.15s;
  --duration-base: 0.25s;
  --duration-slow: 0.4s;

  /* ---- Shadow ---- */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.5);
  --shadow-xl: 0 16px 48px rgba(0,0,0,0.6);

  /* ---- Focus ---- */
  --focus-ring: 0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
}


/* ============================================================
   S1 — RESET & FOUNDATIONS
   ============================================================ */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Hard rule: No italics in UI */
.app *,
.login-wrap * {
  font-style: normal !important;
}

/* Exception: .prose re-enables italics */
.prose em,
.prose i,
.prose cite,
.prose dfn,
.prose var,
.prose address {
  font-style: italic !important;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-size-adjust: 100%;
  tab-size: 4;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--ink);
  background: var(--bg);
  min-height: 100vh;
  overflow-x: hidden;
}

img, svg, video, canvas, audio, iframe, embed, object {
  display: block;
  max-width: 100%;
}

a {
  color: var(--accent);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease);
}

a:hover {
  color: var(--accent-bright);
}

a:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

::selection {
  background: var(--accent);
  color: var(--bg);
}

/* ---- Scrollbar ---- */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--line-hot);
  border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--ink-faint);
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--line-hot) transparent;
}

/* Square corners globally */
input, textarea, select, button, .card, .panel, .modal, .toast, .alert,
.badge, .btn, .tab, table, td, th, details, fieldset {
  border-radius: 0;
}


/* ============================================================
   S2 — TYPOGRAPHY
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-body);
  font-weight: 600;
  line-height: 1.2;
  color: var(--ink);
}

h1 { font-size: var(--text-3xl); letter-spacing: -0.02em; }
h2 { font-size: var(--text-2xl); letter-spacing: -0.01em; }
h3 { font-size: var(--text-xl); }
h4 { font-size: var(--text-lg); }
h5 { font-size: var(--text-md); }
h6 { font-size: var(--text-base); }

p { margin-bottom: var(--sp-4); }

small, .text-sm { font-size: var(--text-sm); }
.text-xs { font-size: var(--text-xs); }
.text-md { font-size: var(--text-md); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }
.text-4xl { font-size: var(--text-4xl); }

.text-dim   { color: var(--ink-dim); }
.text-mid   { color: var(--ink-mid); }
.text-faint { color: var(--ink-faint); }
.text-accent { color: var(--accent); }

.font-display { font-family: var(--font-display); }
.font-mono    { font-family: var(--font-mono); }

strong, b { font-weight: 600; }

code, kbd, samp, pre {
  font-family: var(--font-mono);
  font-size: 0.9em;
}

/* .eyebrow — uppercase mono label */
.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  line-height: 1;
}


/* ============================================================
   S2b — PROSE (user content)
   ============================================================ */

.prose {
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--ink);
  max-width: 72ch;
}

.prose h1 { font-size: var(--text-3xl); margin-top: var(--sp-12); margin-bottom: var(--sp-4); }
.prose h2 { font-size: var(--text-2xl); margin-top: var(--sp-10); margin-bottom: var(--sp-4); }
.prose h3 { font-size: var(--text-xl);  margin-top: var(--sp-8);  margin-bottom: var(--sp-3); }
.prose h4 { font-size: var(--text-lg);  margin-top: var(--sp-6);  margin-bottom: var(--sp-2); }
.prose h5 { font-size: var(--text-md);  margin-top: var(--sp-6);  margin-bottom: var(--sp-2); }
.prose h6 { font-size: var(--text-base); margin-top: var(--sp-6); margin-bottom: var(--sp-2); color: var(--ink-dim); }

.prose p {
  margin-bottom: var(--sp-4);
}

.prose a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.prose a:hover {
  color: var(--accent-bright);
}

.prose strong {
  font-weight: 600;
  color: var(--ink);
}

.prose ul,
.prose ol {
  margin-bottom: var(--sp-4);
  padding-left: var(--sp-6);
}

.prose ul { list-style-type: disc; }
.prose ol { list-style-type: decimal; }

.prose ul ul { list-style-type: circle; }
.prose ol ol { list-style-type: lower-alpha; }

.prose li {
  margin-bottom: var(--sp-1);
}

.prose li > ul,
.prose li > ol {
  margin-top: var(--sp-1);
  margin-bottom: 0;
}

.prose dl {
  margin-bottom: var(--sp-4);
}

.prose dt {
  font-weight: 600;
  color: var(--ink);
  margin-bottom: var(--sp-1);
}

.prose dd {
  margin-left: var(--sp-6);
  margin-bottom: var(--sp-3);
  color: var(--ink-dim);
}

.prose blockquote {
  border-left: 3px solid var(--accent);
  padding: var(--sp-3) var(--sp-4);
  margin: 0 0 var(--sp-4) 0;
  background: var(--panel);
  color: var(--ink-dim);
}

.prose blockquote p:last-child {
  margin-bottom: 0;
}

.prose code {
  background: var(--panel-2);
  padding: 1px var(--sp-1);
  font-size: 0.875em;
  color: var(--accent-bright);
}

.prose pre {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-4);
  overflow-x: auto;
  margin-bottom: var(--sp-4);
  line-height: 1.6;
}

.prose pre code {
  background: none;
  padding: 0;
  color: var(--ink);
  font-size: var(--text-sm);
}

.prose kbd {
  display: inline-block;
  padding: 1px var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  background: var(--panel-3);
  border: 1px solid var(--line-hot);
  border-bottom-width: 2px;
  color: var(--ink-dim);
  line-height: 1.4;
  white-space: nowrap;
}

.prose mark {
  background: var(--accent-glow);
  color: var(--accent-bright);
  padding: 1px var(--sp-1);
}

.prose del {
  text-decoration: line-through;
  color: var(--ink-faint);
}

.prose sub,
.prose sup {
  font-size: 0.75em;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

.prose sub { bottom: -0.25em; }
.prose sup { top: -0.5em; }

.prose hr {
  border: none;
  border-top: 1px solid var(--line);
  margin: var(--sp-8) 0;
}

.prose figure {
  margin: 0 0 var(--sp-6) 0;
}

.prose figcaption {
  font-size: var(--text-sm);
  color: var(--ink-faint);
  margin-top: var(--sp-2);
}

.prose table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--sp-4);
  font-size: var(--text-sm);
}

.prose table th {
  text-align: left;
  font-weight: 600;
  color: var(--ink-dim);
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--line-hot);
}

.prose table td {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--line);
}

.prose img {
  margin: var(--sp-4) 0;
}

.prose > *:first-child { margin-top: 0; }
.prose > *:last-child { margin-bottom: 0; }


/* ============================================================
   S3 — LAYOUT: APP SHELL
   ============================================================ */

.app {
  display: grid;
  grid-template-columns: 64px 220px 1fr;
  min-height: 100vh;
  background: var(--bg);
}

.app-content {
  grid-column: 3;
  padding: var(--sp-6);
  overflow-y: auto;
  position: relative;
  z-index: var(--z-content);
}


/* ============================================================
   S3a — TOOL RAIL
   ============================================================ */

.tool-rail {
  grid-column: 1;
  width: 64px;
  background: var(--panel);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--sp-3) 0;
  gap: var(--sp-1);
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: var(--z-rail);
  overflow-y: auto;
}

.tool-rail-logo {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-4);
  color: var(--accent);
}

.tool-rail-item {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-faint);
  cursor: pointer;
  position: relative;
  transition: color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}

.tool-rail-item:hover {
  color: var(--ink);
  background: var(--panel-2);
}

.tool-rail-item.active {
  color: var(--accent);
  background: var(--accent-glow);
}

.tool-rail-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: var(--accent);
}

/* Tooltip */
.tool-rail-item::after {
  content: attr(data-tooltip);
  position: absolute;
  left: calc(100% + var(--sp-2));
  top: 50%;
  transform: translateY(-50%);
  white-space: nowrap;
  font-size: var(--text-xs);
  background: var(--panel-3);
  color: var(--ink);
  padding: var(--sp-1) var(--sp-2);
  border: 1px solid var(--line-hot);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease);
  z-index: var(--z-dropdown);
}

.tool-rail-item:hover::after {
  opacity: 1;
}

.tool-rail-spacer {
  flex: 1;
}

.tool-rail-divider {
  width: 24px;
  height: 1px;
  background: var(--line);
  margin: var(--sp-2) 0;
}


/* ============================================================
   S3b — TOOL NAV (sidebar)
   ============================================================ */

.tool-nav {
  grid-column: 2;
  width: 220px;
  background: var(--panel);
  border-right: 1px solid var(--line);
  position: fixed;
  top: 0;
  left: 64px;
  bottom: 0;
  z-index: var(--z-nav);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.tool-nav-logo {
  padding: var(--sp-4) var(--sp-4) 0;
  display: flex; align-items: center; justify-content: flex-start;
}
.tool-nav-logo img {
  max-width: 100%; max-height: 64px; width: auto; height: auto; display: block;
}

.tool-nav-head {
  padding: var(--sp-4);
  border-bottom: 1px solid var(--line);
}

.tool-nav-head h2 {
  font-size: var(--text-md);
  font-weight: 600;
}

.tool-nav-section {
  padding: var(--sp-3) var(--sp-3) 0;
}

.tool-nav-section-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  padding: var(--sp-2) var(--sp-2);
}

.tool-nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2);
  color: var(--ink-dim);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}

.tool-nav-item:hover {
  color: var(--ink);
  background: var(--panel-2);
}

.tool-nav-item.active {
  color: var(--accent);
  background: var(--accent-glow);
}

.tool-nav-item .count {
  margin-left: auto;
  font-size: var(--text-xs);
  color: var(--ink-faint);
  font-family: var(--font-mono);
}

.tool-nav-footer {
  margin-top: auto;
  padding: var(--sp-3);
  border-top: 1px solid var(--line);
}


/* ============================================================
   S3c — IDENTITY BLOCK
   ============================================================ */

.identity-block {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
}

.identity-block-logo {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.identity-block-text {
  min-width: 0;
}

.identity-block-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.identity-block-sub {
  font-size: var(--text-xs);
  color: var(--ink-faint);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}


/* ============================================================
   S3d — BREADCRUMB
   ============================================================ */

.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

.breadcrumb a {
  color: var(--ink-faint);
  transition: color var(--duration-fast) var(--ease);
}

.breadcrumb a:hover {
  color: var(--ink);
}

.breadcrumb-sep {
  color: var(--ink-faint);
  font-size: var(--text-xs);
}

.breadcrumb-current {
  color: var(--ink-dim);
}


/* ============================================================
   S3e — PAGE HEADER, SECTION HEADER
   ============================================================ */

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}

.page-header h1 {
  font-size: var(--text-2xl);
  font-weight: 600;
}

.page-header-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--line);
}

.section-head h2 {
  font-size: var(--text-lg);
  font-weight: 600;
}

.section-head h3 {
  font-size: var(--text-md);
  font-weight: 600;
}

.section-head-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}


/* ============================================================
   S3f — LAYOUT GRIDS
   ============================================================ */

.two-col {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-6);
}

.two-col-even {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
}

.three-col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}

.content-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-4);
}


/* ============================================================
   S4 — FORMS
   ============================================================ */

.form-group {
  margin-bottom: var(--sp-4);
}

.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink-dim);
  margin-bottom: var(--sp-1);
}

.form-label .required {
  color: var(--critical);
  margin-left: var(--sp-1);
}

/* Shared input styles */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="month"],
input[type="week"],
textarea,
select {
  display: block;
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--ink);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 0;
  outline: none;
  transition: border-color var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease);
  appearance: none;
  -webkit-appearance: none;
}

input[type="text"]:hover,
input[type="email"]:hover,
input[type="password"]:hover,
input[type="search"]:hover,
input[type="tel"]:hover,
input[type="url"]:hover,
input[type="number"]:hover,
input[type="date"]:hover,
input[type="time"]:hover,
input[type="datetime-local"]:hover,
input[type="month"]:hover,
input[type="week"]:hover,
textarea:hover,
select:hover {
  border-color: var(--line-hot);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
textarea:focus,
select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}

input::placeholder,
textarea::placeholder {
  color: var(--ink-faint);
}

/* Date/time color scheme */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator,
input[type="week"]::-webkit-calendar-picker-indicator {
  filter: invert(0.7);
  cursor: pointer;
}

/* Textarea */
textarea {
  min-height: 96px;
  resize: vertical;
}

/* Select arrow */
select {
  padding-right: var(--sp-8);
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%236B6760' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-3) center;
}

/* Disabled */
input:disabled,
textarea:disabled,
select:disabled,
.form-group.disabled input,
.form-group.disabled textarea,
.form-group.disabled select {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--panel-2);
}

.form-group.disabled .form-label {
  opacity: 0.5;
}

/* Help, Error, Success */
.form-help {
  font-size: var(--text-sm);
  color: var(--ink-faint);
  margin-top: var(--sp-1);
}

.form-error {
  font-size: var(--text-sm);
  color: var(--critical);
  margin-top: var(--sp-1);
}

.form-success {
  font-size: var(--text-sm);
  color: var(--positive);
  margin-top: var(--sp-1);
}

/* Error state on input */
.form-group.has-error input,
.form-group.has-error textarea,
.form-group.has-error select {
  border-color: var(--critical);
}

.form-group.has-error input:focus,
.form-group.has-error textarea:focus,
.form-group.has-error select:focus {
  box-shadow: 0 0 0 1px var(--critical);
}

/* Success state on input */
.form-group.has-success input,
.form-group.has-success textarea,
.form-group.has-success select {
  border-color: var(--positive);
}

/* Fieldset, Legend */
fieldset {
  border: 1px solid var(--line);
  padding: var(--sp-4);
  margin-bottom: var(--sp-6);
}

legend {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ink-dim);
  padding: 0 var(--sp-2);
}


/* ---- Custom Checkbox ---- */

.checkbox {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--ink-dim);
  user-select: none;
}

.checkbox input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.checkbox-mark {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  border: 1px solid var(--line-hot);
  background: var(--panel);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}

.checkbox input:checked + .checkbox-mark {
  background: var(--accent);
  border-color: var(--accent);
}

.checkbox input:checked + .checkbox-mark::after {
  content: '';
  width: 4px;
  height: 8px;
  border: solid var(--bg);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg) translate(-1px, -1px);
}

.checkbox input:focus-visible + .checkbox-mark {
  box-shadow: var(--focus-ring);
}

.checkbox input:disabled + .checkbox-mark {
  opacity: 0.5;
  cursor: not-allowed;
}


/* ---- Custom Radio ---- */

.radio {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--ink-dim);
  user-select: none;
}

.radio input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.radio-mark {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  border: 1px solid var(--line-hot);
  border-radius: 50%;
  background: var(--panel);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color var(--duration-fast) var(--ease);
}

.radio input:checked + .radio-mark {
  border-color: var(--accent);
}

.radio input:checked + .radio-mark::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
}

.radio input:focus-visible + .radio-mark {
  box-shadow: var(--focus-ring);
}

.radio input:disabled + .radio-mark {
  opacity: 0.5;
  cursor: not-allowed;
}


/* ---- Toggle Switch ---- */

.toggle-switch {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  user-select: none;
  font-size: var(--text-sm);
  color: var(--ink-dim);
}

.toggle-switch input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-track {
  width: 36px;
  height: 20px;
  background: var(--panel-3);
  border-radius: 999px;
  position: relative;
  transition: background var(--duration-fast) var(--ease);
  flex-shrink: 0;
}

.toggle-track::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: var(--ink-mid);
  border-radius: 50%;
  transition: transform var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}

.toggle-switch input:checked + .toggle-track {
  background: var(--accent);
}

.toggle-switch input:checked + .toggle-track::after {
  transform: translateX(16px);
  background: var(--bg);
}

.toggle-switch input:focus-visible + .toggle-track {
  box-shadow: var(--focus-ring);
}

.toggle-switch input:disabled + .toggle-track {
  opacity: 0.5;
  cursor: not-allowed;
}


/* ---- Range Slider ---- */

.range-slider {
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  height: 4px;
  background: var(--panel-3);
  outline: none;
  cursor: pointer;
}

.range-slider::-webkit-slider-thumb {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  background: var(--accent);
  border-radius: 50%;
  border: 2px solid var(--bg);
  cursor: pointer;
  transition: box-shadow var(--duration-fast) var(--ease);
}

.range-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  background: var(--accent);
  border-radius: 50%;
  border: 2px solid var(--bg);
  cursor: pointer;
}

.range-slider:focus-visible::-webkit-slider-thumb {
  box-shadow: var(--focus-ring);
}


/* ---- File Upload ---- */

.file-upload {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--panel);
  border: 1px solid var(--line);
  color: var(--ink-dim);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease);
}

.file-upload:hover {
  border-color: var(--line-hot);
}

.file-upload input[type="file"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.drop-zone {
  border: 2px dashed var(--line);
  padding: var(--sp-8);
  text-align: center;
  color: var(--ink-faint);
  transition: border-color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}

.drop-zone.dragover {
  border-color: var(--accent);
  background: var(--accent-glow);
  color: var(--accent);
}

.drop-zone-icon {
  margin-bottom: var(--sp-2);
}

.drop-zone-text {
  font-size: var(--text-sm);
}

.drop-zone-hint {
  font-size: var(--text-xs);
  color: var(--ink-faint);
  margin-top: var(--sp-1);
}


/* ---- Tag Input ---- */

.tag-input {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-2);
  background: var(--panel);
  border: 1px solid var(--line);
  min-height: 36px;
  align-items: center;
  transition: border-color var(--duration-fast) var(--ease);
}

.tag-input:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}

.tag-input .tag {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 1px var(--sp-2);
  background: var(--panel-3);
  font-size: var(--text-sm);
  color: var(--ink-dim);
}

.tag-input .tag-remove {
  cursor: pointer;
  color: var(--ink-faint);
  font-size: var(--text-xs);
  line-height: 1;
}

.tag-input .tag-remove:hover {
  color: var(--critical);
}

.tag-input input {
  flex: 1;
  min-width: 80px;
  border: none;
  background: transparent;
  outline: none;
  font-size: var(--text-sm);
  color: var(--ink);
  padding: var(--sp-1) 0;
}


/* ---- Number Stepper ---- */

.number-stepper {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
}

.number-stepper button {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-2);
  border: none;
  color: var(--ink-dim);
  cursor: pointer;
  font-size: var(--text-md);
  transition: background var(--duration-fast) var(--ease);
}

.number-stepper button:hover {
  background: var(--panel-3);
  color: var(--ink);
}

.number-stepper input {
  width: 48px;
  height: 32px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  background: var(--panel);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  outline: none;
}


/* ---- Input Group ---- */

.input-group {
  display: flex;
}

.input-group-prefix,
.input-group-suffix {
  display: flex;
  align-items: center;
  padding: 0 var(--sp-3);
  background: var(--panel-2);
  border: 1px solid var(--line);
  color: var(--ink-faint);
  font-size: var(--text-sm);
  white-space: nowrap;
}

.input-group-prefix {
  border-right: none;
}

.input-group-suffix {
  border-left: none;
}

.input-group input {
  flex: 1;
  min-width: 0;
}


/* ---- Multi-Step Form ---- */

.multi-step {
  position: relative;
}

.step-indicator {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
}

.step-indicator-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

.step-indicator-item.active {
  color: var(--accent);
}

.step-indicator-item.complete {
  color: var(--positive);
}

.step-indicator-dot {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid currentColor;
  border-radius: 50%;
  font-size: var(--text-xs);
  font-weight: 600;
}

.step-indicator-item.active .step-indicator-dot {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg);
}

.step-indicator-item.complete .step-indicator-dot {
  background: var(--positive);
  border-color: var(--positive);
  color: var(--bg);
}

.step-indicator-line {
  flex: 1;
  height: 1px;
  background: var(--line);
}

.step-indicator-item.complete + .step-indicator-line {
  background: var(--positive);
}


/* ============================================================
   S5 — BUTTONS
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1;
  color: var(--ink-dim);
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 0;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  transition: background var(--duration-fast) var(--ease),
              color var(--duration-fast) var(--ease),
              border-color var(--duration-fast) var(--ease);
}

.btn:hover {
  color: var(--ink);
  background: var(--panel-3);
  border-color: var(--line-hot);
}

.btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.btn:disabled,
.btn.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Primary */
.btn-primary {
  background: var(--accent);
  color: var(--bg);
  border-color: var(--accent);
}

.btn-primary:hover {
  background: var(--accent-bright);
  border-color: var(--accent-bright);
  color: var(--bg);
}

/* Secondary */
.btn-secondary {
  background: transparent;
  color: var(--ink-dim);
  border-color: var(--line-hot);
}

.btn-secondary:hover {
  background: var(--panel-2);
  color: var(--ink);
}

/* Ghost */
.btn-ghost {
  background: transparent;
  color: var(--ink-dim);
  border-color: transparent;
}

.btn-ghost:hover {
  background: var(--panel-2);
  color: var(--ink);
}

/* Danger */
.btn-danger {
  background: var(--critical);
  color: var(--ink);
  border-color: var(--critical);
}

.btn-danger:hover {
  background: #CF6B5F;
  border-color: #CF6B5F;
}

/* Positive */
.btn-positive {
  background: var(--positive);
  color: var(--bg);
  border-color: var(--positive);
}

.btn-positive:hover {
  background: #7DB982;
  border-color: #7DB982;
}

/* ---- Sizes ---- */

.btn-xs {
  padding: 2px var(--sp-2);
  font-size: var(--text-xs);
}

.btn-sm {
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--text-sm);
}

/* .btn-md is default */

.btn-lg {
  padding: var(--sp-3) var(--sp-6);
  font-size: var(--text-md);
}

/* Block */
.btn-block {
  display: flex;
  width: 100%;
}

/* Icon only */
.btn-icon {
  padding: var(--sp-2);
  width: 36px;
  height: 36px;
}

.btn-icon.btn-xs { width: 24px; height: 24px; padding: 2px; }
.btn-icon.btn-sm { width: 28px; height: 28px; padding: var(--sp-1); }
.btn-icon.btn-lg { width: 44px; height: 44px; padding: var(--sp-3); }

/* FAB */
.btn-fab {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  padding: 0;
  background: var(--accent);
  color: var(--bg);
  border: none;
  box-shadow: var(--shadow-lg);
  position: fixed;
  bottom: var(--sp-6);
  right: var(--sp-6);
  z-index: var(--z-dropdown);
}

.btn-fab:hover {
  background: var(--accent-bright);
  box-shadow: var(--shadow-xl);
}

/* Button Group */
.btn-group {
  display: inline-flex;
}

.btn-group .btn {
  border-right-width: 0;
}

.btn-group .btn:last-child {
  border-right-width: 1px;
}

.btn-group .btn.active {
  background: var(--accent-glow);
  color: var(--accent);
  border-color: var(--accent);
}

.btn-group .btn.active + .btn {
  border-left-color: var(--accent);
}

/* Split Button */
.btn-split {
  display: inline-flex;
}

.btn-split .btn-split-main {
  border-right: none;
}

.btn-split .btn-split-trigger {
  padding: var(--sp-2);
  border-left: 1px solid rgba(0,0,0,0.2);
}

.btn-split .btn-split-trigger.btn-primary {
  border-left-color: rgba(0,0,0,0.2);
}


/* ============================================================
   S6 — NAVIGATION
   ============================================================ */

/* ---- Tabs (underline) ---- */

.tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--line);
}

.tab {
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink-faint);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
}

.tab:hover {
  color: var(--ink);
}

.tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.tab .tab-count {
  margin-left: var(--sp-2);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  font-family: var(--font-mono);
}

/* Pill Tabs */
.tabs-pill {
  display: flex;
  gap: var(--sp-1);
  padding: var(--sp-1);
  background: var(--panel);
  border: 1px solid var(--line);
}

.tabs-pill .tab {
  border: none;
  margin: 0;
  border-radius: 0;
  padding: var(--sp-1) var(--sp-3);
}

.tabs-pill .tab.active {
  background: var(--accent);
  color: var(--bg);
}

/* Vertical Tabs */
.tabs-vertical {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-bottom: none;
  border-right: 1px solid var(--line);
  width: max-content;
}

.tabs-vertical .tab {
  border-bottom: none;
  border-right: 2px solid transparent;
  margin-bottom: 0;
  margin-right: -1px;
  text-align: left;
}

.tabs-vertical .tab.active {
  border-right-color: var(--accent);
}


/* ---- Pagination ---- */

.pagination {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}

.pagination-item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 var(--sp-2);
  font-size: var(--text-sm);
  color: var(--ink-dim);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease);
}

.pagination-item:hover {
  background: var(--panel-2);
  color: var(--ink);
}

.pagination-item.active {
  color: var(--accent);
  border-color: var(--accent);
}

.pagination-item:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.pagination-ellipsis {
  color: var(--ink-faint);
  padding: 0 var(--sp-1);
}


/* ---- Command Palette ---- */

.cmd-palette-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: var(--z-cmd-palette);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 20vh;
}

.cmd-palette {
  width: 100%;
  max-width: 560px;
  background: var(--panel);
  border: 1px solid var(--line-hot);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-cmd-palette);
}

.cmd-palette-input {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--line);
}

.cmd-palette-input input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: var(--text-md);
  color: var(--ink);
  font-family: var(--font-body);
}

.cmd-palette-input input::placeholder {
  color: var(--ink-faint);
}

.cmd-palette-input .cmd-palette-icon {
  color: var(--ink-faint);
}

.cmd-palette-group {
  padding: var(--sp-2) 0;
}

.cmd-palette-group-label {
  padding: var(--sp-1) var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.cmd-palette-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-4);
  cursor: pointer;
  color: var(--ink-dim);
  font-size: var(--text-sm);
  transition: background var(--duration-fast) var(--ease);
}

.cmd-palette-item:hover,
.cmd-palette-item.focused {
  background: var(--panel-2);
  color: var(--ink);
}

.cmd-palette-item-shortcut {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-faint);
}

.cmd-palette-empty {
  padding: var(--sp-8) var(--sp-4);
  text-align: center;
  color: var(--ink-faint);
  font-size: var(--text-sm);
}

.cmd-palette-footer {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-2) var(--sp-4);
  border-top: 1px solid var(--line);
  font-size: var(--text-xs);
  color: var(--ink-faint);
}


/* ============================================================
   S7 — DATA DISPLAY
   ============================================================ */

/* ---- Data Table ---- */

.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th {
  text-align: left;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--line-hot);
  white-space: nowrap;
  user-select: none;
  position: relative;
}

/* Sticky header */
.data-table-sticky thead th {
  position: sticky;
  top: 0;
  background: var(--panel);
  z-index: 2;
}

/* Sortable */
.data-table th.sortable {
  cursor: pointer;
  padding-right: var(--sp-6);
}

.data-table th.sortable:hover {
  color: var(--ink-dim);
}

.data-table th.sortable::after {
  content: '';
  position: absolute;
  right: var(--sp-2);
  top: 50%;
  transform: translateY(-50%);
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid var(--ink-faint);
  opacity: 0.4;
}

.data-table th.sort-asc::after {
  border-top: none;
  border-bottom: 4px solid var(--accent);
  opacity: 1;
}

.data-table th.sort-desc::after {
  border-top: 4px solid var(--accent);
  opacity: 1;
}

.data-table td {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--line);
  font-size: var(--text-sm);
  color: var(--ink-dim);
  vertical-align: middle;
}

.data-table tbody tr:hover {
  background: var(--panel);
}

.data-table tbody tr.selected {
  background: var(--accent-glow);
}

/* Row actions */
.data-table .row-actions {
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease);
  display: flex;
  gap: var(--sp-1);
}

.data-table tbody tr:hover .row-actions {
  opacity: 1;
}

/* Expandable row */
.data-table .expandable-trigger {
  cursor: pointer;
  color: var(--ink-faint);
  transition: transform var(--duration-fast) var(--ease);
}

.data-table .expandable-trigger.open {
  transform: rotate(90deg);
}

.data-table .expandable-content td {
  padding: var(--sp-4);
  background: var(--panel);
  border-bottom: 1px solid var(--line);
}

/* Numeric alignment */
.data-table td.numeric,
.data-table th.numeric {
  text-align: right;
  font-family: var(--font-mono);
}


/* ---- Data List (vertical key-value) ---- */

.data-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.data-list-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--line);
}

.data-list-label {
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

.data-list-value {
  font-size: var(--text-sm);
  color: var(--ink);
  text-align: right;
}


/* ---- KV Pair (inline) ---- */

.kv-pair {
  display: inline-flex;
  gap: var(--sp-2);
  font-size: var(--text-sm);
}

.kv-pair-key {
  color: var(--ink-faint);
}

.kv-pair-key::after {
  content: ':';
}

.kv-pair-value {
  color: var(--ink);
}


/* ---- DL List ---- */

.dl-list {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-2) var(--sp-4);
}

.dl-list dt {
  font-size: var(--text-sm);
  color: var(--ink-faint);
  font-weight: 500;
}

.dl-list dd {
  font-size: var(--text-sm);
  color: var(--ink);
}


/* ---- Stat / Stat Grid ---- */

.stat {
  padding: var(--sp-4);
}

.stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: var(--sp-1);
}

.stat-value {
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--ink);
  line-height: 1.1;
}

.stat-delta {
  font-size: var(--text-sm);
  margin-top: var(--sp-1);
  font-family: var(--font-mono);
}

.stat-delta.up { color: var(--positive); }
.stat-delta.down { color: var(--critical); }
.stat-delta.flat { color: var(--ink-faint); }

.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1px;
  background: var(--line);
}

.stat-grid .stat {
  background: var(--panel);
}

/* ---- Metric Card ---- */

.metric-card {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-4);
}

.metric-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-2);
}

.metric-card-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.metric-card-value {
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--ink);
  line-height: 1.1;
}

.metric-card-sparkline {
  height: 32px;
  margin-top: var(--sp-3);
}

.metric-card-footer {
  display: flex;
  justify-content: space-between;
  margin-top: var(--sp-3);
  font-size: var(--text-xs);
  color: var(--ink-faint);
}


/* ============================================================
   S8 — CHARTS (CSS + SVG hooks)
   ============================================================ */

.chart-container {
  position: relative;
  width: 100%;
}

.chart-container canvas {
  width: 100% !important;
}

/* Chart.js theming hooks */
.chart-container {
  --chart-grid: var(--line);
  --chart-tick: var(--ink-faint);
  --chart-tooltip-bg: var(--panel-3);
  --chart-tooltip-text: var(--ink);
  --chart-tooltip-border: var(--line-hot);
}

.chart-line { --chart-color-1: var(--accent); --chart-color-2: var(--transponder); --chart-color-3: var(--positive); --chart-color-4: var(--brand-hue); }
.chart-bar  { --chart-color-1: var(--accent); --chart-color-2: var(--transponder); --chart-color-3: var(--positive); --chart-color-4: var(--brand-hue); }
.chart-area { --chart-fill-opacity: 0.15; }
.chart-donut { --chart-stroke-width: 24; --chart-donut-bg: var(--panel-2); }

/* Sparkline */
.sparkline {
  display: inline-block;
  vertical-align: middle;
}

.sparkline svg {
  display: block;
}

.sparkline path {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.5;
}

.sparkline .sparkline-area {
  fill: var(--accent-glow);
  stroke: none;
}

/* Heatmap */
.heatmap-cell {
  display: inline-block;
  width: var(--sp-4);
  height: var(--sp-4);
  background: var(--panel-2);
}

.heatmap-cell[data-level="1"] { background: rgba(217, 164, 65, 0.15); }
.heatmap-cell[data-level="2"] { background: rgba(217, 164, 65, 0.30); }
.heatmap-cell[data-level="3"] { background: rgba(217, 164, 65, 0.50); }
.heatmap-cell[data-level="4"] { background: rgba(217, 164, 65, 0.75); }
.heatmap-cell[data-level="5"] { background: var(--accent); }


/* ---- Progress Bar ---- */

.progress-bar {
  width: 100%;
  height: 6px;
  background: var(--panel-3);
  overflow: hidden;
}

.progress-bar-fill {
  height: 100%;
  background: var(--accent);
  transition: width var(--duration-base) var(--ease);
}

.progress-bar-fill.positive { background: var(--positive); }
.progress-bar-fill.caution  { background: var(--caution); }
.progress-bar-fill.critical { background: var(--critical); }

/* Segmented */
.progress-segmented {
  display: flex;
  gap: 2px;
  width: 100%;
  height: 6px;
}

.progress-segmented-item {
  flex: 1;
  background: var(--panel-3);
}

.progress-segmented-item.filled {
  background: var(--accent);
}

/* Stacked */
.progress-stacked {
  display: flex;
  width: 100%;
  height: 6px;
  background: var(--panel-3);
  overflow: hidden;
}

.progress-stacked-segment {
  height: 100%;
  transition: width var(--duration-base) var(--ease);
}


/* ---- Gauge ---- */

.gauge {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.gauge svg {
  transform: rotate(-90deg);
}

.gauge-track {
  fill: none;
  stroke: var(--panel-3);
}

.gauge-fill {
  fill: none;
  stroke: var(--accent);
  stroke-linecap: butt;
  transition: stroke-dashoffset var(--duration-slow) var(--ease);
}

.gauge-value {
  position: absolute;
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--ink);
}

.gauge-label {
  position: absolute;
  bottom: 20%;
  font-size: var(--text-xs);
  color: var(--ink-faint);
}


/* ---- Bullet Chart ---- */

.bullet-chart {
  position: relative;
  height: 24px;
  background: var(--panel-2);
}

.bullet-chart-range {
  position: absolute;
  top: 0;
  bottom: 0;
}

.bullet-chart-range.poor    { background: var(--panel-3); }
.bullet-chart-range.ok      { background: var(--line); }
.bullet-chart-range.good    { background: var(--line-hot); }

.bullet-chart-measure {
  position: absolute;
  top: 4px;
  bottom: 4px;
  background: var(--accent);
}

.bullet-chart-marker {
  position: absolute;
  top: 2px;
  bottom: 2px;
  width: 2px;
  background: var(--ink);
}


/* ============================================================
   S9 — CARDS & CONTAINERS
   ============================================================ */

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-4);
}

.card-elevated {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-4);
  box-shadow: var(--shadow-md);
}

.card-flush {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: 0;
}

.card-tight {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-2);
}

.card-loose {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-6);
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
}

.card-title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--ink);
}

.card-footer {
  margin-top: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
}


/* ---- Panel ---- */

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--line);
}

.panel-head h3 {
  font-size: var(--text-md);
  font-weight: 600;
}

.panel-body {
  padding: var(--sp-4);
}

.panel-foot {
  padding: var(--sp-3) var(--sp-4);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-2);
}


/* ---- Accordion ---- */

.accordion {
  border: 1px solid var(--line);
}

.accordion-item {
  border-bottom: 1px solid var(--line);
}

.accordion-item:last-child {
  border-bottom: none;
}

.accordion-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  background: none;
  border: none;
  color: var(--ink);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  transition: background var(--duration-fast) var(--ease);
}

.accordion-trigger:hover {
  background: var(--panel);
}

.accordion-trigger::after {
  content: '';
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--ink-faint);
  transition: transform var(--duration-fast) var(--ease);
  flex-shrink: 0;
}

.accordion-item.open .accordion-trigger::after {
  transform: rotate(180deg);
}

.accordion-content {
  padding: 0 var(--sp-4) var(--sp-4);
  font-size: var(--text-sm);
  color: var(--ink-dim);
  display: none;
}

.accordion-item.open .accordion-content {
  display: block;
}


/* ---- Drawer ---- */

.drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: var(--z-modal-overlay);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease);
}

.drawer-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 400px;
  max-width: 100vw;
  background: var(--panel);
  border-left: 1px solid var(--line);
  z-index: var(--z-modal);
  transform: translateX(100%);
  transition: transform var(--duration-base) var(--ease);
  display: flex;
  flex-direction: column;
}

.drawer.open {
  transform: translateX(0);
}

.drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4);
  border-bottom: 1px solid var(--line);
}

.drawer-head h2 {
  font-size: var(--text-md);
  font-weight: 600;
}

.drawer-body {
  flex: 1;
  padding: var(--sp-4);
  overflow-y: auto;
}

.drawer-foot {
  padding: var(--sp-3) var(--sp-4);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-2);
}

/* Drawer from left */
.drawer.drawer-left {
  left: 0;
  right: auto;
  border-left: none;
  border-right: 1px solid var(--line);
  transform: translateX(-100%);
}

.drawer.drawer-left.open {
  transform: translateX(0);
}


/* ---- Card Tabbed ---- */

.card-tabbed {
  background: var(--panel);
  border: 1px solid var(--line);
}

.card-tabbed > .tabs {
  padding: 0 var(--sp-4);
}

.card-tabbed-body {
  padding: var(--sp-4);
}


/* ============================================================
   S10 — FEEDBACK
   ============================================================ */

/* ---- Toast ---- */

.toast-container {
  position: fixed;
  top: var(--sp-6);
  right: var(--sp-6);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  max-width: 400px;
}

.toast {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--panel-2);
  border: 1px solid var(--line-hot);
  box-shadow: var(--shadow-lg);
  animation: toast-in var(--duration-base) var(--ease);
}

.toast.toast-accent {
  border-left: 3px solid var(--accent);
}

.toast.toast-positive {
  border-left: 3px solid var(--positive);
}

.toast.toast-caution {
  border-left: 3px solid var(--caution);
}

.toast.toast-critical {
  border-left: 3px solid var(--critical);
}

.toast-body {
  flex: 1;
}

.toast-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 2px;
}

.toast-message {
  font-size: var(--text-sm);
  color: var(--ink-dim);
}

.toast-close {
  background: none;
  border: none;
  color: var(--ink-faint);
  cursor: pointer;
  padding: 0;
  line-height: 1;
}

.toast-close:hover {
  color: var(--ink);
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateX(24px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.toast.toast-out {
  animation: toast-out var(--duration-fast) var(--ease) forwards;
}

@keyframes toast-out {
  to {
    opacity: 0;
    transform: translateX(24px);
  }
}


/* ---- Banner ---- */

.banner {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm);
  border-bottom: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--ink-dim);
}

.banner.banner-accent  { border-bottom-color: var(--accent); background: var(--accent-glow); color: var(--accent-bright); }
.banner.banner-positive { border-bottom-color: var(--positive); background: rgba(107,168,112,0.1); color: var(--positive); }
.banner.banner-caution  { border-bottom-color: var(--caution);  background: rgba(196,136,61,0.1);  color: var(--caution); }
.banner.banner-critical { border-bottom-color: var(--critical); background: rgba(188,94,82,0.1);   color: var(--critical); }

.banner-dismiss {
  margin-left: auto;
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  opacity: 0.7;
}

.banner-dismiss:hover {
  opacity: 1;
}


/* ---- Alert ---- */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: var(--panel);
  border: 1px solid var(--line);
  font-size: var(--text-sm);
  color: var(--ink-dim);
}

.alert-positive {
  border-color: var(--positive);
  background: rgba(107,168,112,0.08);
}

.alert-positive .alert-icon { color: var(--positive); }

.alert-caution {
  border-color: var(--caution);
  background: rgba(196,136,61,0.08);
}

.alert-caution .alert-icon { color: var(--caution); }

.alert-critical {
  border-color: var(--critical);
  background: rgba(188,94,82,0.08);
}

.alert-critical .alert-icon { color: var(--critical); }

.alert-title {
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 2px;
}


/* ---- Modal ---- */

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: var(--z-modal-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease);
}

.modal-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.modal {
  width: 100%;
  max-width: 520px;
  max-height: 80vh;
  background: var(--panel);
  border: 1px solid var(--line-hot);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-modal);
  display: flex;
  flex-direction: column;
  transform: scale(0.96);
  transition: transform var(--duration-base) var(--ease);
}

.modal-overlay.open .modal {
  transform: scale(1);
}

.modal-sm { max-width: 400px; }
.modal-lg { max-width: 720px; }
.modal-xl { max-width: 960px; }

.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4);
  border-bottom: 1px solid var(--line);
}

.modal-head h2 {
  font-size: var(--text-md);
  font-weight: 600;
}

.modal-close {
  background: none;
  border: none;
  color: var(--ink-faint);
  cursor: pointer;
  padding: var(--sp-1);
}

.modal-close:hover {
  color: var(--ink);
}

.modal-body {
  padding: var(--sp-4);
  overflow-y: auto;
  flex: 1;
}

.modal-foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  border-top: 1px solid var(--line);
}


/* ---- Empty State ---- */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-16) var(--sp-8);
  text-align: center;
}

.empty-state-icon {
  color: var(--ink-faint);
  margin-bottom: var(--sp-4);
  opacity: 0.5;
}

.empty-state-title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--ink-dim);
  margin-bottom: var(--sp-2);
}

.empty-state-desc {
  font-size: var(--text-sm);
  color: var(--ink-faint);
  max-width: 320px;
  margin-bottom: var(--sp-6);
}


/* ---- Skeleton ---- */

@keyframes skeleton-pulse {
  0%   { opacity: 0.5; }
  50%  { opacity: 0.8; }
  100% { opacity: 0.5; }
}

.skeleton {
  background: var(--panel-2);
  animation: skeleton-pulse 1.5s var(--ease) infinite;
}

.skeleton-line {
  height: 14px;
  background: var(--panel-2);
  margin-bottom: var(--sp-2);
  animation: skeleton-pulse 1.5s var(--ease) infinite;
}

.skeleton-line:last-child {
  width: 60%;
}

.skeleton-circle {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--panel-2);
  animation: skeleton-pulse 1.5s var(--ease) infinite;
}

.skeleton-card {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-4);
}

.skeleton-card .skeleton-line {
  margin-bottom: var(--sp-3);
}


/* ---- Spinner ---- */

.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--line-hot);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

.spinner-sm { width: 14px; height: 14px; border-width: 1.5px; }
.spinner-lg { width: 32px; height: 32px; border-width: 3px; }
.spinner-xl { width: 48px; height: 48px; border-width: 3px; }

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


/* ---- Brand Observer ---- */

.brand-observer {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: var(--accent-glow);
  border: 1px solid var(--accent);
  border-left-width: 3px;
}

.brand-observer-icon {
  color: var(--accent);
  flex-shrink: 0;
}

.brand-observer-body {
  flex: 1;
}

.brand-observer-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--accent-bright);
  margin-bottom: 2px;
}

.brand-observer-text {
  font-size: var(--text-sm);
  color: var(--ink-dim);
}


/* ============================================================
   S11 — STATUS & METADATA
   ============================================================ */

/* ---- Badge ---- */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 1px var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 600;
  line-height: 1.4;
  background: var(--panel-3);
  color: var(--ink-dim);
  white-space: nowrap;
}

.badge-accent   { background: var(--accent-glow); color: var(--accent-bright); }
.badge-positive { background: rgba(107,168,112,0.15); color: var(--positive); }
.badge-caution  { background: rgba(196,136,61,0.15); color: var(--caution); }
.badge-critical { background: rgba(188,94,82,0.15); color: var(--critical); }
.badge-info     { background: rgba(74,143,184,0.15); color: var(--transponder); }


/* ---- Pill ---- */

.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 2px var(--sp-3);
  font-size: var(--text-xs);
  font-weight: 500;
  border-radius: 999px;
  background: var(--panel-3);
  color: var(--ink-dim);
  white-space: nowrap;
}

.pill-accent   { background: var(--accent-glow); color: var(--accent-bright); }
.pill-positive { background: rgba(107,168,112,0.15); color: var(--positive); }
.pill-caution  { background: rgba(196,136,61,0.15); color: var(--caution); }
.pill-critical { background: rgba(188,94,82,0.15); color: var(--critical); }
.pill-info     { background: rgba(74,143,184,0.15); color: var(--transponder); }


/* ---- Dots ---- */

.dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ink-faint);
}

.dot-accent   { background: var(--accent); }
.dot-positive { background: var(--positive); }
.dot-caution  { background: var(--caution); }
.dot-critical { background: var(--critical); }
.dot-info     { background: var(--transponder); }

.dot-pulse {
  animation: dot-pulse 1.5s ease-in-out infinite;
}

@keyframes dot-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* Channel dot */
.cdot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  margin-right: var(--sp-1);
}


/* ---- Stage Pill ---- */

.stage-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 2px var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 500;
  border-radius: 999px;
  border: 1px solid;
}

.stage-pill-lead    { border-color: var(--transponder); color: var(--transponder); background: rgba(74,143,184,0.1); }
.stage-pill-qual    { border-color: var(--accent);      color: var(--accent);      background: var(--accent-glow); }
.stage-pill-prop    { border-color: var(--caution);     color: var(--caution);     background: rgba(196,136,61,0.1); }
.stage-pill-won     { border-color: var(--positive);    color: var(--positive);    background: rgba(107,168,112,0.1); }
.stage-pill-lost    { border-color: var(--critical);    color: var(--critical);    background: rgba(188,94,82,0.1); }
.stage-pill-churned { border-color: var(--ink-faint);   color: var(--ink-faint);   background: rgba(107,103,96,0.1); }


/* ---- Timestamp ---- */

.timestamp {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  white-space: nowrap;
}


/* ---- Audit Entry ---- */

.audit-entry {
  display: flex;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--line);
  font-size: var(--text-sm);
}

.audit-entry-time {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  white-space: nowrap;
  min-width: 100px;
}

.audit-entry-actor {
  font-weight: 500;
  color: var(--ink);
}

.audit-entry-action {
  color: var(--ink-dim);
}

.audit-entry-target {
  color: var(--accent);
}


/* ============================================================
   S12 — ICONS (Lucide)
   ============================================================ */

.icon-xs { width: 12px; height: 12px; }
.icon-sm { width: 14px; height: 14px; }
.icon-md { width: 16px; height: 16px; }
.icon-lg { width: 20px; height: 20px; }
.icon-xl { width: 24px; height: 24px; }

svg.lucide,
.icon {
  color: currentColor;
  stroke-width: 1.5;
  flex-shrink: 0;
}


/* ============================================================
   S13 — PIPELINE / KANBAN
   ============================================================ */

.kanban-board {
  display: flex;
  gap: var(--sp-3);
  overflow-x: auto;
  padding-bottom: var(--sp-4);
}

.kanban-column {
  flex: 0 0 280px;
  min-width: 280px;
  background: var(--panel);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 200px);
}

.kanban-column-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3);
  border-bottom: 1px solid var(--line);
}

.kanban-column-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ink);
}

.kanban-column-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-faint);
}

.kanban-column-body {
  flex: 1;
  padding: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  overflow-y: auto;
}

.kanban-card {
  background: var(--panel-2);
  border: 1px solid var(--line);
  padding: var(--sp-3);
  cursor: grab;
  transition: box-shadow var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}

.kanban-card:hover {
  border-color: var(--line-hot);
  box-shadow: var(--shadow-sm);
}

.kanban-card.dragging {
  opacity: 0.6;
  box-shadow: var(--shadow-lg);
}

.kanban-card-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink);
  margin-bottom: var(--sp-1);
}

.kanban-card-meta {
  font-size: var(--text-xs);
  color: var(--ink-faint);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.drop-indicator {
  height: 2px;
  background: var(--accent);
  margin: var(--sp-1) 0;
  border-radius: 999px;
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease);
}

.drop-indicator.active {
  opacity: 1;
}


/* ============================================================
   S14 — AVATARS
   ============================================================ */

.avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-3);
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.avatar-sm { width: 24px; height: 24px; }
.avatar-lg { width: 40px; height: 40px; }
.avatar-xl { width: 56px; height: 56px; }

.avatar-initials {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ink-dim);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.avatar-sm .avatar-initials { font-size: var(--text-xs); }
.avatar-lg .avatar-initials { font-size: var(--text-md); }
.avatar-xl .avatar-initials { font-size: var(--text-lg); }

/* Avatar Group (stacked overlap) */
.avatar-group {
  display: flex;
}

.avatar-group .avatar {
  margin-left: -8px;
  border: 2px solid var(--bg);
}

.avatar-group .avatar:first-child {
  margin-left: 0;
}

.avatar-group .avatar-overflow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--panel-3);
  border: 2px solid var(--bg);
  margin-left: -8px;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--ink-faint);
}

/* Avatar with status dot */
.avatar-status {
  position: relative;
  display: inline-flex;
}

.avatar-status .dot {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 10px;
  height: 10px;
  border: 2px solid var(--bg);
}

/* Avatar + Name */
.avatar-name {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.avatar-name-text {
  display: flex;
  flex-direction: column;
}

.avatar-name-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink);
}

.avatar-name-role {
  font-size: var(--text-xs);
  color: var(--ink-faint);
}


/* ============================================================
   S15 — FILE & MEDIA
   ============================================================ */

.thumbnail {
  width: 48px;
  height: 48px;
  overflow: hidden;
  background: var(--panel-2);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.thumbnail-lg { width: 80px; height: 80px; }
.thumbnail-xl { width: 120px; height: 120px; }

.file-card {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  background: var(--panel);
  border: 1px solid var(--line);
  transition: border-color var(--duration-fast) var(--ease);
}

.file-card:hover {
  border-color: var(--line-hot);
}

.file-card-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-2);
  color: var(--ink-faint);
  flex-shrink: 0;
}

.file-card-info {
  flex: 1;
  min-width: 0;
}

.file-card-name {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.file-card-meta {
  font-size: var(--text-xs);
  color: var(--ink-faint);
}

.file-card-actions {
  display: flex;
  gap: var(--sp-1);
}

.upload-zone {
  border: 2px dashed var(--line);
  padding: var(--sp-10);
  text-align: center;
  transition: border-color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}

.upload-zone.dragover {
  border-color: var(--accent);
  background: var(--accent-glow);
}

.upload-zone-icon {
  margin: 0 auto var(--sp-3);
  color: var(--ink-faint);
}

.upload-zone-title {
  font-size: var(--text-md);
  font-weight: 500;
  color: var(--ink-dim);
  margin-bottom: var(--sp-1);
}

.upload-zone-hint {
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--sp-2);
}

.gallery-grid-item {
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--panel-2);
  border: 1px solid var(--line);
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease);
}

.gallery-grid-item:hover {
  border-color: var(--accent);
}

.gallery-grid-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.video-embed {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  overflow: hidden;
  background: var(--panel);
}

.video-embed iframe,
.video-embed video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


/* ============================================================
   S16 — SPECIALIZED
   ============================================================ */

/* ---- Code Block ---- */

.code-block {
  background: var(--panel);
  border: 1px solid var(--line);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.6;
}

.code-block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) var(--sp-4);
  border-bottom: 1px solid var(--line);
  background: var(--panel-2);
}

.code-block-lang {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  text-transform: uppercase;
}

.code-block-copy {
  font-size: var(--text-xs);
  color: var(--ink-faint);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--sp-1) var(--sp-2);
}

.code-block-copy:hover {
  color: var(--ink);
}

.code-block pre {
  padding: var(--sp-4);
  margin: 0;
}

.code-block code {
  color: var(--ink);
}

/* Syntax highlight tokens */
.code-block .token-keyword  { color: var(--brand-hue); }
.code-block .token-string   { color: var(--positive); }
.code-block .token-number   { color: var(--accent); }
.code-block .token-comment  { color: var(--ink-faint); }
.code-block .token-function { color: var(--transponder); }
.code-block .token-operator { color: var(--ink-mid); }
.code-block .token-property { color: var(--caution); }
.code-block .token-tag      { color: var(--critical); }
.code-block .token-attr     { color: var(--accent-bright); }
.code-block .token-value    { color: var(--positive); }
.code-block .token-class    { color: var(--accent); }
.code-block .token-type     { color: var(--brand-hue); }
.code-block .token-punctuation { color: var(--ink-mid); }

/* Line numbers */
.code-block .line-number {
  display: inline-block;
  min-width: 3ch;
  padding-right: var(--sp-3);
  text-align: right;
  color: var(--ink-faint);
  user-select: none;
  opacity: 0.5;
}

.code-block .line-highlight {
  background: var(--accent-glow);
  display: block;
  margin: 0 calc(var(--sp-4) * -1);
  padding: 0 var(--sp-4);
}


/* ---- Diff View ---- */

.diff-view {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.6;
  background: var(--panel);
  border: 1px solid var(--line);
  overflow-x: auto;
}

.diff-view-header {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-4);
  border-bottom: 1px solid var(--line);
  background: var(--panel-2);
  font-size: var(--text-xs);
  color: var(--ink-faint);
}

.diff-line {
  display: flex;
  padding: 0 var(--sp-4);
}

.diff-line-number {
  min-width: 3ch;
  padding-right: var(--sp-3);
  text-align: right;
  color: var(--ink-faint);
  user-select: none;
  opacity: 0.5;
}

.diff-added {
  background: rgba(107,168,112,0.1);
  color: var(--positive);
}

.diff-added .diff-line-number {
  color: var(--positive);
  opacity: 0.7;
}

.diff-removed {
  background: rgba(188,94,82,0.1);
  color: var(--critical);
}

.diff-removed .diff-line-number {
  color: var(--critical);
  opacity: 0.7;
}

.diff-context {
  color: var(--ink-dim);
}

.diff-hunk {
  padding: var(--sp-1) var(--sp-4);
  background: var(--panel-2);
  color: var(--transponder);
  font-size: var(--text-xs);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}


/* ---- JSON Viewer ---- */

.json-viewer {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.6;
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-4);
  overflow-x: auto;
}

.json-viewer .json-key      { color: var(--transponder); }
.json-viewer .json-string   { color: var(--positive); }
.json-viewer .json-number   { color: var(--accent); }
.json-viewer .json-boolean  { color: var(--brand-hue); }
.json-viewer .json-null     { color: var(--ink-faint); }
.json-viewer .json-bracket  { color: var(--ink-mid); }

.json-viewer .json-toggle {
  cursor: pointer;
  color: var(--ink-faint);
  user-select: none;
}

.json-viewer .json-toggle:hover {
  color: var(--ink);
}

.json-viewer .json-collapsed {
  color: var(--ink-faint);
}

.json-viewer .json-collapsed::after {
  content: '...';
}


/* ---- Terminal Output ---- */

.terminal-output {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.6;
  background: #0A0C0E;
  border: 1px solid var(--line);
  padding: var(--sp-4);
  overflow-x: auto;
  color: var(--ink-dim);
}

.terminal-output .terminal-prompt {
  color: var(--positive);
}

.terminal-output .terminal-prompt::before {
  content: '$ ';
  color: var(--accent);
}

.terminal-output .terminal-error {
  color: var(--critical);
}

.terminal-output .terminal-warn {
  color: var(--caution);
}

.terminal-output .terminal-success {
  color: var(--positive);
}

.terminal-output .terminal-info {
  color: var(--transponder);
}

.terminal-output .terminal-dim {
  color: var(--ink-faint);
}


/* ---- KBD ---- */

.kbd {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 1px var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  background: var(--panel-3);
  border: 1px solid var(--line-hot);
  border-bottom-width: 2px;
  color: var(--ink-dim);
  line-height: 1.4;
  white-space: nowrap;
}

.kbd + .kbd {
  margin-left: 2px;
}

.kbd-combo {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
}

.kbd-combo .kbd-sep {
  color: var(--ink-faint);
  font-size: var(--text-xs);
}


/* ============================================================
   S17 — UTILITY CLASSES
   ============================================================ */

/* Display */
.hidden { display: none !important; }
.block  { display: block; }
.flex   { display: flex; }
.inline-flex { display: inline-flex; }
.grid   { display: grid; }

/* Flex utilities */
.flex-col     { flex-direction: column; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.items-end    { align-items: flex-end; }
.justify-center  { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-end     { justify-content: flex-end; }
.flex-1       { flex: 1; }
.flex-shrink-0 { flex-shrink: 0; }
.flex-wrap    { flex-wrap: wrap; }

/* Gap */
.gap-1  { gap: var(--sp-1); }
.gap-2  { gap: var(--sp-2); }
.gap-3  { gap: var(--sp-3); }
.gap-4  { gap: var(--sp-4); }
.gap-6  { gap: var(--sp-6); }
.gap-8  { gap: var(--sp-8); }

/* Margin */
.mt-0  { margin-top: 0; }
.mt-2  { margin-top: var(--sp-2); }
.mt-4  { margin-top: var(--sp-4); }
.mt-6  { margin-top: var(--sp-6); }
.mt-8  { margin-top: var(--sp-8); }
.mb-0  { margin-bottom: 0; }
.mb-2  { margin-bottom: var(--sp-2); }
.mb-4  { margin-bottom: var(--sp-4); }
.mb-6  { margin-bottom: var(--sp-6); }
.mb-8  { margin-bottom: var(--sp-8); }
.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }

/* Padding */
.p-0  { padding: 0; }
.p-2  { padding: var(--sp-2); }
.p-3  { padding: var(--sp-3); }
.p-4  { padding: var(--sp-4); }
.p-6  { padding: var(--sp-6); }
.p-8  { padding: var(--sp-8); }

/* Width */
.w-full { width: 100%; }

/* Text alignment */
.text-left   { text-align: left; }
.text-center { text-align: center; }
.text-right  { text-align: right; }

/* Overflow */
.overflow-hidden { overflow: hidden; }
.overflow-auto   { overflow: auto; }
.truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }
.sticky   { position: sticky; }

/* Borders */
.border     { border: 1px solid var(--line); }
.border-t   { border-top: 1px solid var(--line); }
.border-b   { border-bottom: 1px solid var(--line); }
.border-l   { border-left: 1px solid var(--line); }
.border-r   { border-right: 1px solid var(--line); }

/* Backgrounds */
.bg-panel   { background: var(--panel); }
.bg-panel-2 { background: var(--panel-2); }
.bg-panel-3 { background: var(--panel-3); }

/* Opacity */
.opacity-50 { opacity: 0.5; }
.opacity-70 { opacity: 0.7; }

/* Cursor */
.pointer { cursor: pointer; }
.not-allowed { cursor: not-allowed; }

/* Selection */
.select-none { user-select: none; }

/* Transition */
.transition {
  transition: all var(--duration-fast) var(--ease);
}

/* Screen reader only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}


/* ============================================================
   S18 — PRINT
   ============================================================ */

@media print {
  *,
  *::before,
  *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
  }

  body {
    font-size: 12pt;
    line-height: 1.5;
  }

  a {
    text-decoration: underline;
  }

  a[href]::after {
    content: ' (' attr(href) ')';
    font-size: 0.8em;
    color: #555;
  }

  .app {
    display: block;
  }

  .tool-rail,
  .tool-nav,
  .btn-fab,
  .toast-container,
  .modal-overlay,
  .drawer-overlay,
  .cmd-palette-overlay {
    display: none !important;
  }

  .app-content {
    padding: 0;
    margin: 0;
  }

  .card,
  .panel {
    border: 1px solid #ccc !important;
    page-break-inside: avoid;
  }

  .data-table {
    border-collapse: collapse;
  }

  .data-table th,
  .data-table td {
    border: 1px solid #ccc !important;
    padding: 4px 8px;
  }

  h1, h2, h3, h4, h5, h6 {
    page-break-after: avoid;
  }

  img, figure {
    page-break-inside: avoid;
  }

  .badge, .pill, .stage-pill {
    border: 1px solid #999 !important;
  }

  @page {
    margin: 1.5cm;
  }
}

/* ============================================================
 * Session 11.5d — Client + Satellite dashboards (2026-04-23)
 * All classes below were added in Session 11.5d to replace inline
 * styles in the Client shell, the Satellite overview, the Goldstone
 * briefing card, the Beacon list, and the Outposts list. Logged in
 * spec/SESSION-11-5D-CLASSES-ADDED.md.
 * ============================================================ */

/* --- Client shell chrome (replaces inline styles in templates/client/layout/base.php) --- */
.dash-nav-item[data-active="true"] { color: var(--ink); border-left-color: var(--accent); }
.dash-nav-item[data-active="false"] { color: var(--ink-dim); }
.dash-sidebar-username { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); font-weight: 300; }
.dash-sidebar-signout { background: transparent; border: 0; padding: 0; font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300; color: var(--ink-faint); cursor: pointer; text-decoration: underline; margin-top: var(--sp-2); }
.dash-signout-form { margin-top: var(--sp-2); }
.dash-topbar-version { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); font-weight: 300; }
.dash-location-form { display: flex; align-items: center; gap: var(--sp-2); }
.dash-location-label { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); font-weight: 300; }
.dash-flash { padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-5); font-size: var(--text-sm); background: var(--panel); color: var(--ink); border: 1px solid var(--accent); }
.dash-flash--error { border-color: var(--critical, #c0392b); }

/* --- Client Home: Goldstone daily briefing ("killer feature" pitch card) --- */
.briefing-card { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-5) var(--sp-6); margin-bottom: var(--sp-6); border-left: 3px solid var(--accent); }
.briefing-head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--sp-4); margin-bottom: var(--sp-3); }
.briefing-id { display: flex; align-items: center; gap: var(--sp-2); }
.briefing-mark { width: 22px; height: 22px; border-radius: 50%; background: radial-gradient(circle at 40% 40%, var(--accent-bright, var(--accent)), var(--accent)); box-shadow: 0 0 8px var(--accent-glow, rgba(217,164,65,0.45)); }
.briefing-name { font-family: var(--font-display); font-size: var(--text-base); color: var(--ink); }
.briefing-since { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); }
.briefing-body { font-family: var(--font-display); font-size: var(--text-lg); color: var(--ink); line-height: 1.45; margin-bottom: var(--sp-4); }
.briefing-actions { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.briefing-action { display: inline-flex; align-items: center; padding: var(--sp-2) var(--sp-3); border: 1px solid var(--line); background: var(--panel-2, var(--panel)); color: var(--ink); font-size: var(--text-sm); text-decoration: none; transition: border-color 0.12s; }
.briefing-action:hover { border-color: var(--accent); }
.briefing-empty { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); letter-spacing: 0.05em; }

/* --- Client Home: KPI grid --- */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-6); }
.kpi-card { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4) var(--sp-5); }
.kpi-label { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); font-weight: 300; letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: var(--sp-2); }
.kpi-value { font-family: var(--font-display); font-size: var(--text-3xl, 2rem); color: var(--ink); line-height: 1; }
.kpi-sub { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-dim); margin-top: var(--sp-2); }

/* --- Tier dots (replace dollar-weight markers in all lead/deal rows) --- */
.tier-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: var(--sp-2); vertical-align: middle; }
.tier-dot--hot { background: var(--critical, #c0392b); }
.tier-dot--warm { background: var(--caution, #D9A441); }
.tier-dot--cool { background: var(--ink-dim); }
.tier-chip { display: inline-flex; align-items: center; gap: var(--sp-1); padding: 2px var(--sp-2); border: 1px solid var(--line); font-family: var(--font-mono); font-size: 11px; font-weight: 300; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-dim); }
.tier-chip--t1 { color: var(--ink-faint); }
.tier-chip--t2 { color: var(--ink-dim); }
.tier-chip--t3 { color: var(--ink); }
.tier-chip--t4 { color: var(--accent); border-color: var(--accent); }
.tier-chip--t5 { color: var(--accent-bright, var(--accent)); border-color: var(--accent-bright, var(--accent)); }

/* --- Client Home: recent leads + pipeline + content health + channels panels --- */
.panel-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); margin-bottom: var(--sp-6); }
@media (max-width: 900px) { .panel-grid-2 { grid-template-columns: 1fr; } }
.panel-card { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4) var(--sp-5); }
.panel-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--sp-3); }
.panel-title { font-family: var(--font-display); font-size: var(--text-base); color: var(--ink); }
.panel-note { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); }
.lead-row { display: grid; grid-template-columns: 20px 1fr auto; align-items: center; gap: var(--sp-2); padding: var(--sp-2) 0; border-bottom: 1px solid var(--line); font-size: var(--text-sm); color: var(--ink); }
.lead-row:last-child { border-bottom: 0; }
.lead-name { color: var(--ink); }
.lead-stage { font-family: var(--font-mono); font-size: 11px; color: var(--ink-faint); text-transform: uppercase; letter-spacing: 0.05em; }

/* Funnel visualization (Visitors → Identified → MQL → SQL → Won) */
.funnel { display: flex; align-items: stretch; gap: 4px; margin-top: var(--sp-3); }
.funnel-step { flex: 1; background: var(--panel-2, var(--panel)); border: 1px solid var(--line); padding: var(--sp-3); text-align: center; }
.funnel-step-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); }
.funnel-step-value { font-family: var(--font-display); font-size: var(--text-2xl, 1.5rem); color: var(--ink); margin-top: var(--sp-1); }
.funnel-step--won { border-color: var(--accent); }
.funnel-tier-mix { margin-top: var(--sp-2); display: flex; gap: 2px; justify-content: center; }
.funnel-tier-mix .tier-dot { width: 7px; height: 7px; margin: 0; }

/* Channel attribution bars (tier-weighted) */
.channel-row { display: grid; grid-template-columns: 120px 1fr 50px; align-items: center; gap: var(--sp-3); padding: var(--sp-1) 0; font-size: var(--text-sm); }
.channel-name { color: var(--ink); font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }
.channel-bar-track { height: 6px; background: var(--panel-2, var(--panel)); border: 1px solid var(--line); overflow: hidden; }
.channel-bar-fill { height: 100%; background: var(--accent); }
.channel-weight { font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim); text-align: right; }

/* --- Observation list (client_visible-scoped) --- */
.observation-row { display: block; padding: var(--sp-3); border: 1px solid var(--line); margin-bottom: var(--sp-2); background: var(--panel); text-decoration: none; color: var(--ink); transition: border-color 0.12s; }
.observation-row:hover { border-color: var(--accent); }
.observation-title { font-family: var(--font-display); font-size: var(--text-base); color: var(--ink); margin-bottom: var(--sp-1); }
.observation-body { font-size: var(--text-sm); color: var(--ink-dim); line-height: 1.45; }
.observation-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); margin-top: var(--sp-2); }

/* --- Beacon: LeadPost enrichments list --- */
.beacon-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.beacon-table th { text-align: left; padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--line); font-family: var(--font-mono); font-size: 11px; font-weight: 300; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-faint); }
.beacon-table td { padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--line); color: var(--ink); vertical-align: top; }
.beacon-confidence { display: inline-block; font-family: var(--font-mono); font-size: 11px; padding: 1px var(--sp-2); border: 1px solid var(--line); color: var(--ink-dim); }
.beacon-confidence--high { color: var(--accent); border-color: var(--accent); }
.beacon-empty { padding: var(--sp-6); text-align: center; color: var(--ink-faint); font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.05em; }

/* --- Outposts grid --- */
.outpost-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--sp-4); }
.outpost-card { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4) var(--sp-5); text-decoration: none; color: var(--ink); transition: border-color 0.12s; display: block; }
.outpost-card:hover { border-color: var(--accent); }
.outpost-type { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: var(--sp-2); }
.outpost-name { font-family: var(--font-display); font-size: var(--text-lg); color: var(--ink); margin-bottom: var(--sp-2); }
.outpost-meta { font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim); }

/* --- Satellite overview (multi-Client health table) --- */
.sat-clients-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.sat-clients-table th { text-align: left; padding: var(--sp-3); border-bottom: 1px solid var(--line); font-family: var(--font-mono); font-size: 11px; font-weight: 300; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-faint); }
.sat-clients-table td { padding: var(--sp-3); border-bottom: 1px solid var(--line); color: var(--ink); }
.sat-clients-table tr:hover { background: var(--panel-2, var(--panel)); }
.sat-client-name { font-family: var(--font-display); color: var(--ink); text-decoration: none; }
.sat-client-name:hover { color: var(--accent); }
.health-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: var(--sp-2); vertical-align: middle; }
.health-dot--green { background: var(--positive, #2a9d5f); }
.health-dot--amber { background: var(--caution, #D9A441); }
.health-dot--red { background: var(--critical, #c0392b); }
.health-label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-dim); }

/* Satellite drill-into-Client banner */
.sat-drilldown-banner { background: var(--panel); border: 1px solid var(--accent); padding: var(--sp-3) var(--sp-5); margin-bottom: var(--sp-5); display: flex; justify-content: space-between; align-items: center; font-size: var(--text-sm); }
.sat-drilldown-banner a { color: var(--accent); text-decoration: none; font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }
.sat-drilldown-banner a:hover { text-decoration: underline; }

/* --- Deals sub-nav tabs (Pipeline / Contacts / Schedule / Dispatch / Channels / AEO) --- */
.subnav { display: flex; gap: var(--sp-4); border-bottom: 1px solid var(--line); margin-bottom: var(--sp-5); }
.subnav-item { padding: var(--sp-2) 0; font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-dim); text-decoration: none; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.subnav-item:hover { color: var(--ink); }
.subnav-item[data-active="true"] { color: var(--ink); border-bottom-color: var(--accent); }

/* Empty states shared by client/satellite surfaces */
.empty-state { padding: var(--sp-8) var(--sp-6); text-align: center; color: var(--ink-faint); font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.05em; }

/* Channel bar percentage increments — discrete 10% tiers so attribution
 * geometry renders without inline style overrides. Template rounds to nearest
 * 10 and picks the corresponding class. Session 11.5d.
 */
.channel-bar-fill--pct-0   { width: 0%; }
.channel-bar-fill--pct-10  { width: 10%; }
.channel-bar-fill--pct-20  { width: 20%; }
.channel-bar-fill--pct-30  { width: 30%; }
.channel-bar-fill--pct-40  { width: 40%; }
.channel-bar-fill--pct-50  { width: 50%; }
.channel-bar-fill--pct-60  { width: 60%; }
.channel-bar-fill--pct-70  { width: 70%; }
.channel-bar-fill--pct-80  { width: 80%; }
.channel-bar-fill--pct-90  { width: 90%; }
.channel-bar-fill--pct-100 { width: 100%; }

/* ============================================================
 * Session 11.5d — Client shell core layout (regression fix).
 * These were in the inline <style> of the old base.php; when the
 * layout was rewritten to eliminate inline styles the rules were
 * not lifted. Without them the sidebar, main column, topbar, and
 * content padding all collapse into a single stacked flow.
 * ============================================================ */
.dash-shell { display: flex; min-height: 100vh; }
.dash-sidebar { width: 220px; flex-shrink: 0; background: var(--panel); border-right: 1px solid var(--line); display: flex; flex-direction: column; }
.dash-sidebar-header { padding: var(--sp-5) var(--sp-5) var(--sp-4); border-bottom: 1px solid var(--line); }
.dash-sidebar-client { font-family: var(--font-display); font-size: var(--text-lg); color: var(--ink); line-height: 1.2; }
.dash-sidebar-sub { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); font-weight: 300; letter-spacing: 0.05em; text-transform: uppercase; margin-top: var(--sp-1); }
.dash-nav { flex: 1; padding: var(--sp-4) 0; overflow-y: auto; }
.dash-nav-section { margin-bottom: var(--sp-4); }
.dash-nav-label { font-family: var(--font-mono); font-size: 10px; font-weight: 300; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); padding: 0 var(--sp-5) var(--sp-2); }
.dash-nav-item { display: block; padding: var(--sp-2) var(--sp-5); font-size: var(--text-sm); text-decoration: none; border-left: 2px solid transparent; transition: color 0.1s; color: var(--ink-dim); }
.dash-nav-item:hover { color: var(--ink); }
.dash-sidebar-footer { padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--line); }
.dash-main { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.dash-topbar { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-3) var(--sp-6); border-bottom: 1px solid var(--line); background: var(--surface); gap: var(--sp-4); }
.dash-topbar-title { font-family: var(--font-display); font-size: var(--text-xl); color: var(--ink); }
.dash-topbar-right { display: flex; align-items: center; gap: var(--sp-3); }
.dash-content { flex: 1; padding: var(--sp-6) var(--sp-8); }
.loc-select { font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300; background: var(--panel); border: 1px solid var(--line); color: var(--ink); padding: var(--sp-1) var(--sp-2); cursor: pointer; }

/* Stable scrollbar gutter (was inline in base.php). */
html.dash-scrollbar-stable { scrollbar-gutter: stable; }

/* ============================================================
   SESSION 11.5e-1 — Client views: prototype-faithful port
   Classes added to match prototypes/satellite-proto/dashboard.html
   and insights.html. No italics anywhere (CLAUDE.md). No inline
   styles in any template; every dynamic value maps to a class.
   ============================================================ */

/* --- Rail brand mark (dot-with-orbit) --------------------- */
.rail-brand {
  width: 36px; height: 36px;
  border: 1px solid var(--accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--sp-4);
  position: relative;
  flex-shrink: 0;
}
.rail-brand::before {
  content: '';
  width: 8px; height: 8px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--accent-glow);
}
.rail-brand::after {
  content: '';
  position: absolute;
  inset: -4px;
  border: 1px solid var(--line-hot);
  border-radius: 50%;
}

/* --- Tool-rail icons: Fraunces glyph + tiny mono label ---- */
.tool-icon {
  width: 48px; height: 48px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  cursor: pointer;
  border-left: 2px solid transparent;
  margin-left: -2px;
  position: relative;
  transition: all 0.15s;
  text-decoration: none;
  flex-shrink: 0;
  gap: 2px;
}
.tool-icon .tic {
  font-family: var(--font-display);
  font-size: 20px;
  line-height: 1;
  color: var(--ink-faint);
  transition: color 0.15s, transform 0.15s;
}
.tool-icon .tlbl {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 8px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.tool-icon:hover { background: rgba(255,255,255,0.02); }
.tool-icon:hover .tic { transform: scale(1.08); }
.tool-icon:hover .tic,
.tool-icon:hover .tlbl { color: var(--ink); }
.tool-icon[data-active="true"] {
  border-left-color: var(--accent);
  background: var(--accent-glow);
}
.tool-icon[data-active="true"] .tic,
.tool-icon[data-active="true"] .tlbl { color: var(--accent); }

/* Tooltip on hover */
.tool-icon::before {
  content: attr(data-label);
  position: absolute;
  left: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--panel-3);
  border: 1px solid var(--line-hot);
  color: var(--ink);
  padding: 6px 10px;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s;
  z-index: 100;
}
.tool-icon:hover::before { opacity: 1; }

.rail-bottom {
  margin-top: auto;
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--line);
  flex-shrink: 0;
}
.rail-user {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--panel-3);
  border: 1px solid var(--line-hot);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
}

/* --- Client shell layout: 64 rail + 220 nav + content ----- */
.client-shell { display: grid; grid-template-columns: 64px 220px 1fr; min-height: 100vh; }
.client-rail {
  background: #0B0D0F;
  border-right: 1px solid var(--line);
  padding: var(--sp-3) 0;
  display: flex; flex-direction: column; align-items: center;
  gap: 6px;
  position: sticky; top: 0;
  height: 100vh;
}
.client-nav {
  background: var(--panel);
  border-right: 1px solid var(--line);
  padding: var(--sp-5) 0;
  display: flex; flex-direction: column;
  position: sticky; top: 0;
  height: 100vh;
  overflow-y: auto;
}
.client-nav-header {
  padding: 0 var(--sp-5) var(--sp-4);
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid var(--line);
}
.client-nav-tool {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--accent);
  line-height: 1;
}
.client-nav-sub {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 6px;
}
.client-nav-section-label {
  padding: var(--sp-3) var(--sp-5) 6px;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.client-nav-link {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 9px var(--sp-5);
  color: var(--ink-dim);
  font-size: 14px;
  cursor: pointer;
  border-left: 2px solid transparent;
  transition: all 0.15s;
  text-decoration: none;
}
.client-nav-link:hover { color: var(--ink); background: var(--panel-2); }
.client-nav-link[data-active="true"] {
  color: var(--accent);
  background: linear-gradient(90deg, var(--accent-glow) 0%, transparent 80%);
  border-left-color: var(--accent);
}
.client-nav-footer {
  margin-top: auto;
  padding: var(--sp-4) var(--sp-5);
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  color: var(--ink-faint);
}
.client-nav-user-line { margin-bottom: 6px; }
.client-nav-signout {
  background: transparent; border: none;
  color: var(--ink-faint);
  font-family: var(--font-mono);
  font-weight: 300; font-size: 11px;
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: 0;
}
.client-nav-signout:hover { color: var(--ink); }

.client-content { padding: var(--sp-6) var(--sp-8); min-width: 0; }

.client-loc-form { display: flex; align-items: center; gap: var(--sp-2); }
.client-loc-label {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* --- Page header (prototype: label/title/sub + meta) ------ */
.mqx-page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--line);
  gap: var(--sp-6);
}
.mqx-page-label {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 8px;
}
.mqx-page-title {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
}
/* No italics — prototype used em{font-style:italic}. Use color + weight. */
.mqx-page-title .mqx-em { color: var(--accent); font-weight: 500; }
.mqx-page-sub {
  margin-top: 10px;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 13px;
  color: var(--ink-dim);
  letter-spacing: 0.02em;
}
.mqx-page-meta {
  text-align: right;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 13px;
  color: var(--ink-dim);
}
.mqx-page-meta b { color: var(--ink); font-weight: 400; display: block; margin-bottom: 4px; }

.mqx-pulse {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--positive);
  margin-right: 6px;
  animation: mqx-pulse 2.5s infinite;
  box-shadow: 0 0 8px rgba(107, 168, 112, 0.5);
}
@keyframes mqx-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* --- AI hero (Goldstone briefing block) ------------------- */
.ai-hero {
  background: linear-gradient(135deg, rgba(217,164,65,0.07) 0%, transparent 55%), var(--panel);
  border: 1px solid var(--line-hot);
  padding: 28px 32px;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
}
.ai-hero::after {
  content: ''; position: absolute; top: -80px; right: -80px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);
  pointer-events: none;
}
.ai-header { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.ai-mark {
  width: 22px; height: 22px;
  border: 1px solid var(--accent); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  flex-shrink: 0;
}
.ai-mark::before {
  content: ''; width: 5px; height: 5px;
  background: var(--accent); border-radius: 50%;
  box-shadow: 0 0 6px var(--accent-glow);
}
.ai-name { font-family: var(--font-display); font-size: 18px; font-weight: 500; letter-spacing: -0.01em; color: var(--ink); }
.ai-status {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.ai-message {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 400; line-height: 1.55;
  color: var(--ink); margin-bottom: 18px;
}
.ai-message b { color: var(--accent); font-weight: 500; }
.ai-input-row {
  display: flex; gap: 10px;
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 10px 14px;
  align-items: center;
}
.ai-input-row:focus-within { border-color: var(--accent); }
.ai-input {
  flex: 1; background: transparent; border: none; outline: none;
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 14px; padding: 4px 0;
  width: 100%;
}
.ai-input::placeholder { color: var(--ink-faint); }
.ai-send {
  background: var(--accent); color: var(--bg);
  padding: 7px 16px;
  font-family: var(--font-mono);
  font-weight: 400; font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase;
  border: 1px solid var(--accent);
  cursor: pointer;
  white-space: nowrap;
}
.ai-send:hover { background: var(--accent-hot, var(--accent)); }
.ai-suggestions { display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-top: var(--sp-4); }
.ai-suggest {
  padding: 6px 12px;
  background: rgba(217,164,65,0.06);
  border: 1px solid rgba(217,164,65,0.2);
  color: var(--ink-dim);
  font-size: 12px;
  cursor: pointer;
  text-decoration: none;
  font-family: var(--font-body);
}
.ai-suggest:hover { background: rgba(217,164,65,0.12); color: var(--ink); }

/* --- Action cards (URGENT / OPPORTUNITY / FOLLOW UP) ------ */
.action-list { display: flex; flex-direction: column; gap: var(--sp-3); }
.action-card {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-left: 2px solid var(--accent);
  padding: 16px 18px;
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
  color: var(--ink);
  display: block;
}
.action-card:hover { border-color: var(--line-hot); }
.action-card--urgent      { border-left-color: var(--critical); }
.action-card--opportunity { border-left-color: var(--positive); }
.action-card--followup    { border-left-color: var(--caution); }

.action-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
}
.action-tag {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}
.action-tag--urgent      { color: var(--critical); }
.action-tag--opportunity { color: var(--positive); }
.action-tag--followup    { color: var(--caution); }

.action-time {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 10px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}
.action-body {
  font-family: var(--font-display);
  font-size: 15px; line-height: 1.5;
  color: var(--ink);
}
.action-body .action-em { color: var(--accent); font-weight: 500; }
.action-cta {
  margin-top: 10px;
  font-family: var(--font-mono);
  font-weight: 300; font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-dim);
}
.action-cta b { color: var(--accent); font-weight: 400; }

/* --- Stat grid (4 KPIs, tier-based) ----------------------- */
.mqx-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--line);
  border: 1px solid var(--line);
  margin-bottom: var(--sp-6);
}
.mqx-stat { background: var(--panel); padding: 22px 20px; }
.mqx-stat-label {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 12px;
}
.mqx-stat-value {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink);
}
.mqx-stat-value--accent   { color: var(--accent); }
.mqx-stat-value--positive { color: var(--positive); }
.mqx-stat-value--caution  { color: var(--caution); }
.mqx-stat-value--critical { color: var(--critical); }
.mqx-stat-delta {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  color: var(--positive);
  letter-spacing: 0.02em;
}
.mqx-stat-delta--neg  { color: var(--critical); }
.mqx-stat-delta--flat { color: var(--ink-faint); }

/* --- Two-col / three-col grids (prototype sizing) --------- */
.mqx-two-col       { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--sp-6); }
.mqx-two-col-even  { display: grid; grid-template-columns: 1fr 1fr;   gap: var(--sp-6); }

/* --- Card shell (prototype refinement over existing .card) */
.mqx-card {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-6);
}
.mqx-card + .mqx-card { margin-top: var(--sp-5); }
.mqx-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-5);
  gap: var(--sp-3);
}
.mqx-card-title {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}
.mqx-card-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--line);
}
.mqx-card-link {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--accent);
  white-space: nowrap;
  text-decoration: none;
}
.mqx-card-link:hover { color: var(--accent-bright, var(--accent)); }

/* --- Recent leads ladder ---------------------------------- */
.mqx-lead-row {
  display: grid; grid-template-columns: 1fr auto auto;
  gap: var(--sp-4); padding: 12px 0;
  border-bottom: 1px solid var(--line);
  align-items: center;
  text-decoration: none;
  color: var(--ink);
}
.mqx-lead-row:last-child { border-bottom: none; }
.mqx-lead-row:hover { background: rgba(217,164,65,0.02); }
.mqx-lead-name { font-weight: 500; margin-bottom: 2px; color: var(--ink); }
.mqx-lead-meta { font-family: var(--font-mono); font-weight: 300; font-size: 11px; color: var(--ink-dim); }
.mqx-lead-time { font-family: var(--font-mono); font-weight: 300; font-size: 11px; color: var(--ink-faint); white-space: nowrap; }

/* Tier/temperature badges for leads */
.mqx-temp-pill {
  display: inline-block;
  padding: 2px 10px;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.mqx-temp-pill--hot  { background: rgba(217,164,65,0.15); color: var(--accent); }
.mqx-temp-pill--warm { background: rgba(196,136,61,0.15); color: var(--caution); }
.mqx-temp-pill--cool { background: rgba(74,143,184,0.15); color: var(--transponder, var(--ink-dim)); }

/* --- Funnel viz (height-varying bars + metrics row) ------- */
.funnel-viz { display: flex; gap: 1px; height: 60px; align-items: flex-end; margin: var(--sp-4) 0 12px; }
.fbar { flex: 1; background: var(--accent); }
.fbar--s1 { height: 100%; opacity: 0.18; }
.fbar--s2 { height: 64%;  opacity: 0.32; }
.fbar--s3 { height: 28%;  opacity: 0.5; }
.fbar--s4 { height: 12%;  opacity: 0.72; }
.fbar--s5 { height: 6%;   opacity: 1; box-shadow: 0 0 12px var(--accent-glow); }

.funnel-labels, .funnel-numbers {
  display: flex; gap: 1px;
  font-family: var(--font-mono); font-weight: 300;
  font-size: 10px; letter-spacing: 0.04em;
}
.funnel-labels { color: var(--ink-faint); }
.funnel-numbers { margin-top: 4px; color: var(--ink); font-weight: 400; font-size: 12px; }
.funnel-labels > div, .funnel-numbers > div { flex: 1; text-align: center; }

.funnel-stats {
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-weight: 300; font-size: 12px;
  color: var(--ink-dim);
  display: flex; gap: var(--sp-5); flex-wrap: wrap;
}
.funnel-stats b { color: var(--positive); font-weight: 400; }
.funnel-stats b.funnel-stat--caution  { color: var(--caution); }
.funnel-stats b.funnel-stat--critical { color: var(--critical); }

/* --- Channel attribution (tier-weighted) ------------------ */
.mqx-channel-row {
  display: flex; justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  font-size: 13px;
}
.mqx-channel-row:last-child { border-bottom: none; }
.mqx-channel-name { color: var(--ink-dim); display: flex; align-items: center; gap: 8px; }
.mqx-channel-weight { font-family: var(--font-mono); font-weight: 400; font-size: 13px; color: var(--ink); }
.mqx-channel-weight span { color: var(--ink-faint); margin-left: 6px; }

/* --- Content-health two-col KPI mini-grid ----------------- */
.mqx-health-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 2px;
  background: var(--line);
  border: 1px solid var(--line);
}
.mqx-health-cell { background: var(--panel-2); padding: 14px 16px; }
.mqx-health-label {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 6px;
}
.mqx-health-value {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 500;
  color: var(--ink);
}
.mqx-health-value--pos { color: var(--positive); }
.mqx-health-value--crit { color: var(--critical); }

/* --- Kanban visual refresh (already has base .kanban-*) --- */
.mqx-kanban-tier-chip {
  display: inline-block;
  padding: 2px 8px;
  font-family: var(--font-mono);
  font-weight: 300; font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.mqx-kanban-tier-chip--t1 { background: rgba(74,143,184,0.15);  color: var(--transponder, var(--ink-dim)); }
.mqx-kanban-tier-chip--t2 { background: rgba(78,74,68,0.2);     color: var(--ink-mid); }
.mqx-kanban-tier-chip--t3 { background: rgba(196,136,61,0.15);  color: var(--caution); }
.mqx-kanban-tier-chip--t4 { background: rgba(217,164,65,0.15);  color: var(--accent); }
.mqx-kanban-tier-chip--t5 { background: rgba(107,168,112,0.15); color: var(--positive); }
.mqx-kanban-card-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 8px; gap: 8px;
}
.mqx-kanban-days {
  font-family: var(--font-mono); font-weight: 300; font-size: 11px;
  color: var(--ink-faint); letter-spacing: 0.04em;
}

/* --- Outposts grid refresh (prototype card treatment) ----- */
.mqx-outpost-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-5);
}
.mqx-outpost-card {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-5);
  transition: border-color 0.15s;
  text-decoration: none;
  color: var(--ink);
  display: block;
}
.mqx-outpost-card:hover { border-color: var(--line-hot); }
.mqx-outpost-type {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: 8px;
}
.mqx-outpost-name {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 6px;
  color: var(--ink);
}
.mqx-outpost-meta {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 12px;
  color: var(--ink-dim);
  display: flex; justify-content: space-between;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.mqx-outpost-metric {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 500;
  color: var(--accent);
  margin-top: var(--sp-3);
}

/* --- Settings form section ------------------------------- */
.mqx-form-section {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: var(--sp-6);
  max-width: 560px;
}
.mqx-form-group { margin-bottom: var(--sp-5); }
.mqx-form-group:last-child { margin-bottom: 0; }
.mqx-form-label {
  display: block;
  font-family: var(--font-mono);
  font-weight: 300; font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 8px;
}
.mqx-form-help {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 11px;
  color: var(--ink-faint);
  margin-top: 6px;
}

/* --- Insights sub-nav placeholder (11.5e-2) --------------- */
.mqx-subnav {
  display: flex; gap: var(--sp-4);
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-3);
}
.mqx-subnav-item {
  font-family: var(--font-mono);
  font-weight: 300; font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-dim);
  padding: 6px 2px;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -3px;
}
.mqx-subnav-item:hover { color: var(--ink); }
.mqx-subnav-item[data-active="true"] {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.mqx-subnav-item[data-disabled="true"] {
  color: var(--ink-faint);
  cursor: not-allowed;
  pointer-events: none;
}
.mqx-subnav-item[data-disabled="true"]::after {
  content: ' · 11.5e-2';
  color: var(--ink-faint);
  font-size: 10px;
  letter-spacing: 0.04em;
}

/* --- Flash banners (reuse .dash-flash base, no italics) --- */

/* --- Responsive collapse (hide tool-nav under 1100px) ----- */
@media (max-width: 1100px) {
  .client-shell { grid-template-columns: 64px 1fr; }
  .client-nav { display: none; }
  .mqx-two-col, .mqx-two-col-even { grid-template-columns: 1fr; }
  .mqx-stat-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ===========================================================
   SESSION 11.5e-2 — Sub-page utilities
   Shared patterns for CRM / Scheduler / Dispatch / Chat
   sub-pages and the new Locations admin surface. No inline
   styles; every class is reusable across sub-pages.
   =========================================================== */

/* Toolbar / filter row above list views */
.mqx-toolbar {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: var(--sp-4); margin-bottom: var(--sp-6); flex-wrap: wrap;
}
.mqx-toolbar-filters { display: flex; gap: var(--sp-3); align-items: center; flex-wrap: wrap; }
.mqx-toolbar-actions { display: flex; gap: var(--sp-3); align-items: center; }

/* Inputs (scoped — not overriding existing form styles elsewhere) */
.mqx-input {
  background: var(--panel); border: 1px solid var(--line); color: var(--ink);
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-body); font-size: var(--text-sm);
}
.mqx-input--wide { width: 220px; }
.mqx-select {
  background: var(--panel); border: 1px solid var(--line); color: var(--ink);
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
}
.mqx-link-muted {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-dim); text-decoration: none;
}
.mqx-link-muted:hover { color: var(--ink); }

/* Data table */
.mqx-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.mqx-table thead tr { border-bottom: 1px solid var(--line); }
.mqx-table th {
  text-align: left; padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); letter-spacing: 0.05em; text-transform: uppercase;
}
.mqx-table tbody tr { border-bottom: 1px solid var(--line); }
.mqx-table td { padding: var(--sp-3); }
.mqx-cell-mono {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300; color: var(--ink-dim);
}
.mqx-cell-faint {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300; color: var(--ink-faint);
}
.mqx-cell-link { color: var(--ink); text-decoration: none; }
.mqx-cell-link:hover { color: var(--accent); }
.mqx-table-empty {
  padding: var(--sp-6); text-align: center; color: var(--ink-faint);
  font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 300;
}

/* Pagination row */
.mqx-pagination { margin-top: var(--sp-4); display: flex; gap: var(--sp-3); }

/* Detail page grid (main + sidebar) */
.mqx-detail-grid { display: grid; grid-template-columns: 1fr 340px; gap: var(--sp-8); }
.mqx-detail-grid--narrow { grid-template-columns: 1fr 300px; }
@media (max-width: 1100px) {
  .mqx-detail-grid, .mqx-detail-grid--narrow { grid-template-columns: 1fr; }
}

/* Detail header card (big title block) */
.mqx-detail-card {
  background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-6); margin-bottom: var(--sp-6);
}
.mqx-detail-title {
  font-family: var(--font-display); font-size: var(--text-2xl); color: var(--ink);
  margin-bottom: var(--sp-1);
}
.mqx-detail-sub {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300; color: var(--ink-dim);
}
.mqx-detail-meta { margin-top: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); }
.mqx-detail-meta-line { font-size: var(--text-sm); color: var(--ink-dim); }

/* Sidebar card */
.mqx-side-card {
  background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-5); margin-bottom: var(--sp-5);
}
.mqx-side-card--compact { padding: var(--sp-4); margin-bottom: var(--sp-4); }
.mqx-side-label {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); letter-spacing: 0.05em; text-transform: uppercase;
  margin-bottom: var(--sp-2);
}
.mqx-side-value { font-size: var(--text-sm); color: var(--ink); }
.mqx-side-value--big {
  font-family: var(--font-display); font-size: var(--text-xl); color: var(--ink);
  margin-top: var(--sp-3);
}

/* Section label + block */
.mqx-section { margin-bottom: var(--sp-6); }
.mqx-section-label {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); letter-spacing: 0.05em; text-transform: uppercase;
  margin-bottom: var(--sp-3);
}

/* Timeline (activity / events) */
.mqx-timeline-row {
  display: flex; gap: var(--sp-4); padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--line);
}
.mqx-timeline-date {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); white-space: nowrap; min-width: 48px;
}
.mqx-timeline-body { font-size: var(--text-sm); color: var(--ink-dim); }

/* Linked list-card row (e.g. deals under a contact) */
.mqx-list-cards { display: flex; flex-direction: column; gap: var(--sp-2); }
.mqx-list-card {
  display: flex; justify-content: space-between; gap: var(--sp-3); align-items: flex-start;
  background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-3) var(--sp-4); text-decoration: none; color: var(--ink);
  font-size: var(--text-sm);
}
.mqx-list-card:hover { border-color: var(--accent); }
.mqx-list-card-title { color: var(--ink); }
.mqx-list-card-sub {
  color: var(--ink-faint);
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
}

/* Empty state */
.mqx-empty {
  font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 300;
  color: var(--ink-faint);
}

/* Board (horizontal status columns — dispatch) */
.mqx-board { display: flex; gap: var(--sp-4); overflow-x: auto; padding-bottom: var(--sp-4); }
.mqx-board-col { min-width: 220px; flex-shrink: 0; }
.mqx-board-col-head {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-dim);
  padding: var(--sp-2) 0 var(--sp-3);
  border-bottom: 1px solid var(--line); margin-bottom: var(--sp-3);
}
.mqx-board-card {
  display: block; background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-3); margin-bottom: var(--sp-2);
  text-decoration: none; color: var(--ink);
}
.mqx-board-card:hover { border-color: var(--accent); }
.mqx-board-card-title { font-size: var(--text-sm); color: var(--ink); }
.mqx-board-card-sub {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); margin-top: var(--sp-1);
}

/* Chat (conversation + message bubbles) */
.mqx-chat-stream { display: flex; flex-direction: column; gap: var(--sp-3); max-width: 720px; }
.mqx-chat-row { display: flex; }
.mqx-chat-row--user { justify-content: flex-end; }
.mqx-chat-bubble {
  max-width: 75%; background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-3) var(--sp-4);
}
.mqx-chat-role {
  font-family: var(--font-mono); font-size: 10px; font-weight: 300;
  color: var(--ink-faint); text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: var(--sp-1);
}
.mqx-chat-msg { font-size: var(--text-sm); color: var(--ink); line-height: 1.6; white-space: pre-wrap; }
.mqx-chat-gap { font-family: var(--font-mono); font-size: 10px; color: var(--ink-faint); margin-top: var(--sp-1); }
.mqx-chat-head {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); margin-bottom: var(--sp-4);
}

/* Locations list / edit */
.mqx-loc-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-4);
}
.mqx-loc-card {
  background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-2);
  text-decoration: none; color: var(--ink);
}
.mqx-loc-card:hover { border-color: var(--accent); }
.mqx-loc-name { font-family: var(--font-display); font-size: var(--text-xl); color: var(--ink); }
.mqx-loc-addr {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300; color: var(--ink-dim);
}
.mqx-loc-contact { font-size: var(--text-sm); color: var(--ink-dim); }
.mqx-loc-metric {
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  color: var(--ink-faint); border-top: 1px solid var(--line);
  padding-top: var(--sp-2); margin-top: var(--sp-2);
}
.mqx-loc-status {
  font-family: var(--font-mono); font-size: 10px; font-weight: 400;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.mqx-loc-status--active { color: var(--accent); }
.mqx-loc-status--inactive { color: var(--ink-faint); }

/* Kanban drag-and-drop (extends existing .kanban-*) */
.kanban-card[draggable="true"] { cursor: grab; }
.kanban-card.is-dragging { opacity: 0.4; }
.kanban-column.is-drop-target {
  background: rgba(208, 171, 92, 0.05);
  outline: 1px dashed var(--accent); outline-offset: -4px;
}

/* Flash banner (reuse on sub-pages) */
.mqx-flash {
  padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-4);
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  border: 1px solid var(--line); background: var(--panel); color: var(--ink);
}
.mqx-flash--error { color: var(--accent); }

/* Session 11.5e-2-b — Imagine (part 2 continued). */
.mqx-report-summary {
  padding: var(--sp-4) var(--sp-5);
  color: var(--ink-dim);
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: var(--text-sm);
  line-height: 1.6;
  border-bottom: 1px solid var(--line);
}

/* Form section divider — labels a grouped sub-section inside a form card. */
.mqx-form-section-divider {
  margin: var(--sp-5) 0 var(--sp-3);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* --- Weekly slot-grid calendar (client/bookings/calendar) --------- */
.mqx-cal-picker { display: flex; gap: var(--sp-2); align-items: center; }
.mqx-form-label--inline { margin: 0; }

.mqx-cal-grid-wrap { overflow-x: auto; background: var(--panel); border: 1px solid var(--line); }
.mqx-cal-grid { width: 100%; border-collapse: collapse; table-layout: fixed; }
.mqx-cal-grid th, .mqx-cal-grid td { border: 1px solid var(--line); }
.mqx-cal-grid thead th {
  background: var(--panel-2);
  padding: var(--sp-3) var(--sp-2);
  text-align: center;
  font-family: var(--font-mono); font-size: var(--text-xs); font-weight: 300;
  letter-spacing: 0.04em;
  color: var(--ink);
}
.mqx-cal-day-name { color: var(--ink-faint); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; }
.mqx-cal-day-date { color: var(--ink); margin-top: 2px; }
.mqx-cal-time-col {
  width: 60px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 300;
  color: var(--ink-faint);
  text-align: right;
  padding: var(--sp-1) var(--sp-2);
  background: var(--panel-2);
}
.mqx-cal-slot { height: 28px; padding: 0; position: relative; }
.mqx-cal-slot-click {
  display: block;
  width: 100%; height: 100%;
  text-decoration: none;
  transition: background var(--duration-fast) var(--ease);
}
.mqx-cal-slot-click:hover { background: var(--accent-glow); }
.mqx-cal-slot--busy { background: var(--panel-2); }
.mqx-cal-slot--booking { background: var(--panel-2); padding: 0; }
.mqx-cal-slot--booking { position: relative; padding: 0; }
.mqx-cal-booking {
  display: block; padding: 4px 8px;
  background: rgba(107, 168, 112, 0.15);
  border-left: 2px solid var(--positive);
  text-decoration: none;
  height: 100%;
}
.mqx-cal-booking--laned { position: absolute; top: 0; bottom: 0; }
.mqx-cal-booking--pending { opacity: 0.55; border-left-style: dashed; }
.mqx-cal-booking-time {
  font-family: var(--font-mono); font-weight: 400; font-size: 11px;
  color: var(--positive); letter-spacing: 0.04em;
}
.mqx-cal-booking-label {
  font-family: var(--font-mono); font-weight: 300; font-size: 10px;
  color: var(--ink-dim); margin-top: 1px;
}

/* Service-address row: street + city / state / postal grid on one line at wide widths. */
.mqx-addr-row { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--sp-4); }
@media (max-width: 700px) { .mqx-addr-row { grid-template-columns: 1fr; } }
.mqx-form-help--inline {
  font-family: var(--font-mono); font-weight: 300; font-size: 11px;
  color: var(--ink-faint); letter-spacing: 0.02em;
  text-transform: none; margin-left: var(--sp-1);
}

/* Google Places Autocomplete dropdown — restyled for the dark Moonquake theme. */
.pac-container {
  background: var(--panel-2);
  border: 1px solid var(--line-hot);
  box-shadow: 0 8px 24px rgba(0,0,0,0.6);
  font-family: var(--font-mono);
  margin-top: 2px;
}
.pac-item {
  padding: 8px 12px;
  border-top: 1px solid var(--line);
  color: var(--ink);
  font-family: var(--font-mono); font-weight: 300; font-size: 12px;
  cursor: pointer;
}
.pac-item:hover, .pac-item-selected { background: var(--accent-glow); }
.pac-item-query { color: var(--accent); font-weight: 400; font-size: 13px; }
.pac-matched { color: var(--accent); font-weight: 500; }
.pac-icon { filter: invert(1) brightness(0.8); }
.pac-logo:after {
  background-color: var(--panel-2);
  filter: invert(0.9);
}

/* PlaceAutocompleteElement (modern Google Places widget) — make it line up
   visually with our other inputs. The inner shadow-DOM styling is limited;
   the CSS below controls the outer box only. */
.mqx-place-autocomplete {
  display: block;
  width: 100%;
  margin-bottom: var(--sp-1);
}
gmp-place-autocomplete {
  width: 100%;
  --gmp-input-background: var(--panel-2);
  --gmp-input-text-color: var(--ink);
  --gmp-input-border-color: var(--line);
}

/* Drive-time ETA value on booking detail side-card. */
.mqx-eta-value { font-family: var(--font-display); font-size: var(--text-lg); color: var(--accent); margin: 4px 0 2px; }

/* Booking status pill + inline-form helpers (booking detail actions). */
.mqx-status-pill {
  display: inline-block;
  font-family: var(--font-mono); font-weight: 400; font-size: 10px;
  letter-spacing: 0.08em;
  padding: 2px 8px;
  border: 1px solid var(--line);
  color: var(--ink-dim);
  margin-left: var(--sp-1);
}
.mqx-status-pill--pending   { color: var(--caution);  border-color: var(--caution); }
.mqx-status-pill--confirmed { color: var(--accent);   border-color: var(--accent); }
.mqx-status-pill--completed { color: var(--positive); border-color: var(--positive); }
.mqx-status-pill--cancelled { color: var(--critical); border-color: var(--critical); }
.mqx-status-pill--no_show   { color: var(--critical); border-color: var(--critical); }
.mqx-inline-form { display: inline-block; margin: 0; }

/* Staff rows on the crew detail page: inline edit form per row + remove button. */
.mqx-staff-row {
  display: flex; gap: var(--sp-2); align-items: center;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.mqx-staff-row:last-child { border-bottom: none; }
.mqx-staff-form {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.6fr 1.1fr auto;
  gap: var(--sp-2); align-items: center;
  flex: 1; min-width: 0;
}
.mqx-staff-form input { min-width: 0; }
@media (max-width: 900px) {
  .mqx-staff-form { grid-template-columns: 1fr 1fr; }
  .mqx-staff-form button { grid-column: 1 / -1; }
}

/* Job detail crew assignment form */
.mqx-assign-form { display: grid; gap: var(--sp-2); margin-top: var(--sp-3); }

/* --- Scheduler assistant widget ---------------------------------- */
.mqx-assist {
  background: var(--panel);
  border: 1px solid var(--accent);
  padding: var(--sp-4) var(--sp-5);
  margin: var(--sp-5) 0;
  display: grid; gap: var(--sp-3);
}
.mqx-assist-head {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-weight: 300; font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent);
}
.mqx-assist-head .mqx-assist-hint {
  color: var(--ink-faint); font-size: 10px;
}
.mqx-assist textarea {
  width: 100%; min-height: 68px;
  background: var(--panel-2); color: var(--ink);
  border: 1px solid var(--line); padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-mono); font-weight: 300; font-size: var(--text-sm);
  resize: vertical;
}
.mqx-assist-actions { display: flex; justify-content: space-between; align-items: center; gap: var(--sp-3); }
.mqx-assist-examples {
  font-family: var(--font-mono); font-weight: 300; font-size: 10px;
  color: var(--ink-faint); letter-spacing: 0.02em;
}
.mqx-assist-result {
  font-family: var(--font-mono); font-weight: 300; font-size: 12px;
  padding: var(--sp-2) var(--sp-3);
  min-height: 1.5em;
}
.mqx-assist-result:empty { display: none; }
.mqx-assist-result--ok      { color: var(--positive); border-left: 2px solid var(--positive); }
.mqx-assist-result--err     { color: var(--critical); border-left: 2px solid var(--critical); }
.mqx-assist-result--loading { color: var(--ink-dim); }

/* Blocked slots in the weekly calendar + block strip above the grid. */
.mqx-cal-slot--blocked {
  background: rgba(217, 164, 65, 0.22);
  position: relative;
}
.mqx-cal-block-label {
  position: absolute;
  inset: 2px 4px auto 4px;
  font-family: var(--font-mono); font-weight: 400; font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--accent);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.mqx-block-strip {
  display: flex; gap: var(--sp-2); align-items: center; flex-wrap: wrap;
  background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-2) var(--sp-3); margin-bottom: var(--sp-2);
}
.mqx-block-strip-label {
  font-family: var(--font-mono); font-weight: 300; font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint);
}
.mqx-block-chip-form { margin: 0; display: inline-block; }
.mqx-block-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(217, 164, 65, 0.15);
  border: 1px solid var(--accent);
  padding: 3px 4px 3px 8px;
  font-family: var(--font-mono); font-weight: 300; font-size: 11px;
  color: var(--accent);
}
.mqx-block-chip-x {
  background: transparent; border: 0; color: var(--accent);
  font-size: 14px; line-height: 1; padding: 0 4px;
  cursor: pointer;
}
.mqx-block-chip-x:hover { color: var(--critical); }

/* Upcoming-blocks strip: chip + external remove button in a paired wrap. */
.mqx-block-chip-wrap { display: inline-flex; align-items: stretch; gap: 0; }
.mqx-block-chip-wrap .mqx-block-chip {
  border-right: 0; text-decoration: none;
}
.mqx-block-chip-wrap .mqx-block-chip-form { margin: 0; }
.mqx-block-chip-wrap .mqx-block-chip-x {
  border: 1px solid var(--accent); border-left: 0;
  background: rgba(217, 164, 65, 0.15);
  color: var(--accent);
  padding: 3px 8px; cursor: pointer;
  font-size: 14px; line-height: 1;
}
.mqx-block-chip-wrap .mqx-block-chip-x:hover { color: var(--critical); }
.mqx-block-chip--current { background: rgba(217, 164, 65, 0.28); }

/* Small calendar-name tag shown on merged "All calendars" chips. */
.mqx-cal-tag {
  display: inline-block;
  font-family: var(--font-mono); font-weight: 400; font-size: 9px;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--ink-faint);
  background: rgba(255,255,255,0.04);
  padding: 1px 4px; margin-right: 2px;
}

/* Dispatch board — richer cards (time line + status pill + crew row). */
.mqx-board-card-head {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--sp-2); margin-bottom: 4px;
}
.mqx-board-card-time {
  font-family: var(--font-mono); font-weight: 400; font-size: 11px;
  color: var(--ink); letter-spacing: 0.04em;
}
.mqx-board-col { min-width: 280px; flex: 1; }
.mqx-board { align-items: stretch; }
.mqx-status-pill--scheduled   { color: var(--accent);   border-color: var(--accent); }
.mqx-status-pill--assigned    { color: var(--transponder, var(--accent));   border-color: var(--accent); }
.mqx-status-pill--in_progress { color: var(--positive); border-color: var(--positive); }

/* /client/ask response panel under the Home hero input. */
.ai-reply { margin-top: var(--sp-3); padding: var(--sp-3) var(--sp-4); border-left: 2px solid var(--accent); background: rgba(217, 164, 65, 0.06); }
.ai-reply-q { font-family: var(--font-mono); font-weight: 300; font-size: 11px; color: var(--ink-faint); letter-spacing: 0.04em; margin-bottom: 4px; }
.ai-reply-a { font-size: var(--text-sm); color: var(--ink); line-height: 1.5; }

/* Session 11.5g — Starr — utility classes for recurring inline-style patterns. */

/* Compact mono filter control — used on filter toolbars where a <select> or
   <input> needs to read like a metadata affordance, not a first-class field. */
.mqx-filter-control {
  background: var(--bg);
  color: var(--ink);
  border: 1px solid var(--line);
  padding: var(--sp-1) var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 300;
  letter-spacing: 0.04em;
  width: auto;
}

/* Deeper-panel textarea/input — used for edit surfaces that sit inside a
   content card (so their background is lighter than the form default). */
.mqx-input-deep {
  background: var(--panel-2);
  color: var(--ink);
  border: 1px solid var(--line);
  padding: var(--sp-2);
  font-family: var(--font-body);
  width: 100%;
}

/* Link-style button — transparent chrome, mono text, used for "Sign out" /
   "Switch →" affordances inside shell footers. Kept visually low so they
   don't compete with primary actions. */
.mqx-btn-linkish {
  background: transparent;
  border: 0;
  color: var(--ink-faint);
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: 0;
  text-transform: none;
}
.mqx-btn-linkish:hover { color: var(--accent); }
.mqx-btn-linkish--caps {
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* --- Session 11.5h — Harrison — Design System Editor surface ----- */
.mqx-design-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
@media (max-width: 800px) { .mqx-design-grid { grid-template-columns: 1fr; } }
.mqx-design-field { display: flex; flex-direction: column; gap: 4px; }
.mqx-design-field-label {
  font-family: var(--font-mono); font-weight: 300; font-size: 11px;
  color: var(--ink-faint); letter-spacing: 0.04em;
}
.mqx-design-color-row {
  display: grid; grid-template-columns: 40px 1fr; gap: var(--sp-2); align-items: center;
}
.mqx-design-color-row input[type="color"] {
  width: 40px; height: 32px; padding: 0; border: 1px solid var(--line); background: transparent;
}
.mqx-design-logo-preview {
  display: flex; align-items: center; justify-content: center;
  background: var(--panel-2); border: 1px solid var(--line);
  padding: var(--sp-4); margin-bottom: var(--sp-3);
}
.mqx-design-logo-preview img { max-width: 240px; max-height: 120px; display: block; }
.mqx-design-preview {
  width: 100%; height: 420px;
  border: 1px solid var(--line); background: var(--panel);
  margin-bottom: var(--sp-3);
}
.mqx-design-css-snippet {
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim);
  background: var(--bg); border: 1px solid var(--line);
  padding: var(--sp-3); margin: 0; overflow-x: auto;
  white-space: pre-wrap;
}

/* --- P8 — Theme library + AI design assistant ----------------------- */
.mqx-theme-list { display: flex; flex-direction: column; gap: var(--sp-2); }
.mqx-theme-row {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--line); border-radius: var(--radius-sm, 4px);
  background: var(--panel);
}
.mqx-theme-row[data-active="true"] { border-color: var(--accent); }
.mqx-theme-name { flex: 1; font-family: var(--font-display); color: var(--ink); }
.mqx-theme-active-tag {
  font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--accent);
}
.mqx-theme-actions { display: flex; gap: var(--sp-2); }
.mqx-theme-actions form { display: inline-block; }
.mqx-theme-save-row { display: flex; gap: var(--sp-2); margin-top: var(--sp-3); }
.mqx-theme-save-row input[type="text"] { flex: 1; }

.mqx-ai-panel {
  display: flex; flex-direction: column;
  border: 1px solid var(--line); background: var(--panel);
  height: 480px; overflow: hidden;
}
.mqx-ai-log {
  flex: 1; overflow-y: auto; padding: var(--sp-3);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.mqx-ai-msg {
  padding: var(--sp-2) var(--sp-3); border: 1px solid var(--line);
  font-family: var(--font-body); font-size: 13px; color: var(--ink);
}
.mqx-ai-msg[data-role="user"] { background: var(--panel-2); }
.mqx-ai-msg[data-role="assistant"] { background: var(--bg); }
.mqx-ai-diff {
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim);
  white-space: pre-wrap; margin-top: var(--sp-2);
}
.mqx-ai-form {
  display: flex; gap: var(--sp-2); padding: var(--sp-3);
  border-top: 1px solid var(--line); background: var(--panel-2);
}
.mqx-ai-form input[type="text"] { flex: 1; }
.mqx-ai-actions { display: flex; gap: var(--sp-2); margin-top: var(--sp-2); }

/* Logo rendered in the top-left of the rail (Mothership + Satellite shells) */
.rail-logo-img {
  display: block; max-width: 32px; max-height: 32px;
  margin: 6px auto 16px;
}

/* --- Session 11.5j — Brand Profile visual-identity editor ------------- */
.mqx-color-row {
  display: flex; gap: var(--sp-4); align-items: flex-start;
  padding: var(--sp-3) 0; border-bottom: 1px solid var(--line);
}
.mqx-color-row:last-of-type { border-bottom: 0; }
.mqx-color-swatch { flex: 0 0 80px; }
.mqx-color-swatch input[type="color"] {
  width: 64px; height: 64px; padding: 0; border: 1px solid var(--line); background: transparent;
}
.mqx-color-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-2) var(--sp-3); flex: 1;
}
.mqx-color-grid label { display: flex; flex-direction: column; gap: 2px; }
.mqx-color-primary {
  flex-direction: row !important; align-items: center; gap: var(--sp-2);
  grid-column: 1 / -1;
}
.mqx-color-field-label {
  font-family: var(--font-mono); font-weight: 300; font-size: 10px;
  letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-faint);
}

.mqx-font-row {
  display: grid;
  grid-template-columns: 1fr 1.5fr 1fr 0.7fr 1.2fr 1fr;
  gap: var(--sp-2) var(--sp-3);
  padding: var(--sp-3) 0; border-bottom: 1px solid var(--line);
}
.mqx-font-row:last-of-type { border-bottom: 0; }
.mqx-font-row label { display: flex; flex-direction: column; gap: 2px; }

.mqx-logo-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3);
  padding: var(--sp-3) 0; border-bottom: 1px solid var(--line);
}
.mqx-logo-row:last-of-type { border-bottom: 0; }
.mqx-logo-row label { display: flex; flex-direction: column; gap: 2px; }

@media (max-width: 900px) {
  .mqx-color-grid { grid-template-columns: 1fr 1fr; }
  .mqx-font-row { grid-template-columns: 1fr 1fr; }
  .mqx-logo-row { grid-template-columns: 1fr; }
}

/* --- P3b — Brand Book Visual editor ----------------------------------- */
.bbv-wrap { padding: var(--sp-6); max-width: 1280px; }
.bbv-breadcrumb {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.bbv-breadcrumb-link { color: var(--ink-faint); text-decoration: none; }
.bbv-title-row { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--sp-4); gap: var(--sp-3); }
.bbv-title { font-family: var(--font-display); font-size: 28px; font-weight: 500; color: var(--ink); margin: 0; }
.bbv-save-status {
  font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink-dim);
}
.bbv-save-status[data-state="pending"] { color: var(--accent); }
.bbv-save-status[data-state="error"]   { color: #dc2626; }

.bbv-flash { padding: var(--sp-3); margin-bottom: var(--sp-3); border: 1px solid var(--line); background: var(--panel); color: var(--ink-dim); }
.bbv-flash-success { border-left: 3px solid var(--accent); }
.bbv-flash-error   { border-left: 3px solid #dc2626; }

.bbv-main { display: grid; grid-template-columns: 220px 1fr; gap: var(--sp-4); min-height: 640px; }

.bbv-rail {
  background: var(--panel); border: 1px solid var(--line); padding: var(--sp-3);
  overflow-y: auto; max-height: 80vh;
}
.bbv-rail-title {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.bbv-rail-list { list-style: none; margin: 0; padding: 0; }
.bbv-rail-item {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2); border: 1px solid transparent; cursor: pointer;
  font-size: var(--text-sm); color: var(--ink-dim);
}
.bbv-rail-item:hover { border-color: var(--line); }
.bbv-rail-item-active { border-color: var(--accent); color: var(--ink); background: var(--panel-2); }
.bbv-rail-item-excluded { opacity: 0.5; }
.bbv-rail-num { font-family: var(--font-mono); font-size: 11px; color: var(--ink-faint); min-width: 18px; }
.bbv-rail-label { flex: 1; }
.bbv-add-page {
  margin-top: var(--sp-3); width: 100%; padding: var(--sp-2);
  background: transparent; border: 1px dashed var(--line); color: var(--ink-faint);
  font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.06em;
  text-transform: uppercase; cursor: pointer;
}
.bbv-add-page:hover { border-color: var(--accent); color: var(--accent); }

.bbv-editor { display: flex; flex-direction: column; gap: var(--sp-3); min-width: 0; }
.bbv-preview { background: #1f1f1f; border: 1px solid var(--line); padding: var(--sp-2); height: 480px; }
.bbv-preview-frame { width: 100%; height: 100%; border: 0; background: #fff; }

.bbv-nav { display: flex; gap: var(--sp-2); align-items: center; justify-content: center; }
.bbv-nav-btn {
  background: var(--panel); border: 1px solid var(--line); color: var(--ink);
  font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.06em;
  text-transform: uppercase; padding: var(--sp-2) var(--sp-3); cursor: pointer;
}
.bbv-nav-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.bbv-nav-btn-danger { color: #dc2626; border-color: #dc2626; }
.bbv-nav-info { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-dim); min-width: 100px; text-align: center; }

.bbv-form { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4); }
.bbv-form-title {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-3);
}
.bbv-include {
  display: flex; align-items: center; gap: var(--sp-2);
  margin-bottom: var(--sp-3); padding: var(--sp-2); background: var(--bg);
  border: 1px solid var(--line); font-size: var(--text-sm); color: var(--ink-dim);
}
.bbv-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.bbv-form-field { display: flex; flex-direction: column; gap: 4px; }
.bbv-form-field-full { grid-column: 1 / -1; }
.bbv-form-label {
  font-family: var(--font-mono); font-size: 10px; font-weight: 300;
  letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-faint);
}
.bbv-form-input {
  width: 100%; padding: 6px 8px; background: var(--bg); border: 1px solid var(--line);
  color: var(--ink); font-family: inherit; font-size: var(--text-sm);
}
textarea.bbv-form-input { min-height: 80px; resize: vertical; }
input.bbv-form-input[type="color"] { width: 64px; height: 32px; padding: 0; }
input.bbv-form-input[type="checkbox"] { width: auto; }

@media (max-width: 1080px) {
  .bbv-main { grid-template-columns: 1fr; }
  .bbv-form-grid { grid-template-columns: 1fr; }
}

/* P3c — Brand Book Media sub-tab + Visual sub-tab image picker. */
.bbm-wrap { padding: var(--sp-6); max-width: 1280px; }
.bbm-breadcrumb {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.bbm-breadcrumb-link { color: var(--ink-faint); text-decoration: none; }
.bbm-title-row { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--sp-4); gap: var(--sp-3); }
.bbm-title { font-family: var(--font-display); font-size: 28px; font-weight: 500; color: var(--ink); margin: 0; }
.bbm-flash { padding: var(--sp-3); margin-bottom: var(--sp-3); border: 1px solid var(--line); background: var(--panel); color: var(--ink-dim); }
.bbm-flash-success { border-left: 3px solid var(--accent); }
.bbm-flash-error   { border-left: 3px solid #dc2626; }

.bbm-upload {
  background: var(--panel); border: 1px solid var(--line);
  padding: var(--sp-4); margin-bottom: var(--sp-4);
}
.bbm-upload-title {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.bbm-upload-form { display: flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center; }
.bbm-upload-input { color: var(--ink); font-family: inherit; }
.bbm-upload-text {
  flex: 1; min-width: 160px; padding: 6px 8px; background: var(--bg);
  border: 1px solid var(--line); color: var(--ink); font-family: inherit; font-size: var(--text-sm);
}
.bbm-upload-btn {
  background: var(--accent); color: var(--panel); border: none; padding: 8px 18px;
  font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.06em;
  text-transform: uppercase; font-weight: 600; cursor: pointer;
}
.bbm-upload-disabled { color: var(--ink-faint); font-size: var(--text-sm); }

.bbm-library { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4); }
.bbm-library-title {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-3);
}
.bbm-empty { color: var(--ink-faint); padding: var(--sp-4); text-align: center; }
.bbm-grid {
  display: grid; gap: var(--sp-3);
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.bbm-card { background: var(--bg); border: 1px solid var(--line); display: flex; flex-direction: column; }
.bbm-thumb {
  aspect-ratio: 4 / 3; background: #1f1f1f; display: flex;
  align-items: center; justify-content: center; overflow: hidden;
}
.bbm-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bbm-thumb-fallback { color: var(--ink-faint); font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.08em; }
.bbm-card-body { padding: var(--sp-2); display: flex; flex-direction: column; gap: 4px; }
.bbm-card-name {
  color: var(--ink); font-size: var(--text-sm);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bbm-card-meta { color: var(--ink-faint); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; }
.bbm-card-actions { display: flex; gap: var(--sp-2); margin-top: 4px; align-items: center; }
.bbm-card-link {
  color: var(--accent); text-decoration: none; font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
}
.bbm-card-form { margin: 0; }
.bbm-card-trash {
  background: none; border: none; color: #dc2626; cursor: pointer; padding: 0;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
}

/* Visual sub-tab — image field picker button */
.bbv-image-row { display: flex; gap: var(--sp-2); align-items: stretch; }
.bbv-image-row .bbv-form-input { flex: 1; }
.bbv-pick-btn {
  background: var(--panel-2); color: var(--ink-dim); border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 0 12px; cursor: pointer;
}
.bbv-pick-btn:hover { color: var(--accent); border-color: var(--accent); }

/* Visual sub-tab — click-to-upload zone (replaces the per-field Pick button).
   Click anywhere on the zone or drop a file to upload. The hires source is
   preserved on disk; the editor preview shows the webres derivative
   (~1000px max). */
.bbv-image-zone {
  position: relative;
  display: flex; align-items: center; gap: var(--sp-3);
  border: 1px dashed var(--line); border-radius: 4px;
  padding: var(--sp-2); cursor: pointer; min-height: 96px;
  transition: border-color 120ms, background 120ms;
}
.bbv-image-zone:hover, .bbv-image-zone:focus { border-color: var(--accent); outline: none; }
.bbv-image-zone.drag { border-color: var(--accent); background: var(--panel-2); }
.bbv-image-zone.uploading { opacity: 0.6; pointer-events: none; }
.bbv-image-zone-thumb {
  width: 96px; height: 80px; flex: 0 0 96px;
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 2px;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.bbv-image-zone-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.bbv-image-zone:not(.has-image) .bbv-image-zone-thumb img { display: none; }
.bbv-image-zone:not(.has-image) .bbv-image-zone-thumb::after {
  content: '\2295'; color: var(--ink-faint); font-size: 24px;
}
.bbv-image-zone-cta { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.bbv-image-zone-title {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink);
}
.bbv-image-zone-sub {
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-faint);
}
.bbv-image-zone-browse { color: var(--accent); text-decoration: underline; }
.bbv-image-zone-file { display: none; }

/* Picker modal (used by Visual sub-tab) */
.bbm-picker-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.7);
  display: flex; align-items: center; justify-content: center; z-index: 1000;
}
.bbm-picker {
  background: var(--bg); border: 1px solid var(--line);
  width: min(960px, 90vw); max-height: 86vh; display: flex; flex-direction: column;
}
.bbm-picker-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--line);
}
.bbm-picker-title { font-family: var(--font-display); font-size: 18px; color: var(--ink); margin: 0; font-weight: 500; }
.bbm-picker-close {
  background: none; border: 1px solid var(--line); color: var(--ink-dim);
  font-family: var(--font-mono); font-size: var(--text-xs); padding: 4px 10px; cursor: pointer;
}
.bbm-picker-body { padding: var(--sp-4); overflow: auto; flex: 1; }
.bbm-picker-empty { color: var(--ink-faint); text-align: center; padding: var(--sp-6); }
.bbm-picker-tile {
  background: var(--panel); border: 1px solid var(--line); cursor: pointer;
  padding: 0; display: flex; flex-direction: column; text-align: left;
}
.bbm-picker-tile:hover { border-color: var(--accent); }
.bbm-picker-tile .bbm-thumb { aspect-ratio: 1 / 1; }
.bbm-picker-tile-name {
  padding: 6px 8px; color: var(--ink); font-size: var(--text-xs);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bbm-picker-foot {
  display: flex; gap: var(--sp-2); align-items: center;
  padding: var(--sp-3) var(--sp-4); border-top: 1px solid var(--line);
}
.bbm-picker-status { color: var(--ink-faint); font-family: var(--font-mono); font-size: var(--text-xs); flex: 1; }

/* P5 Brand IA refactor — Brand Profile Web tab. Mockup gen + full-site gen +
   preview deploy + WP conversion + Live Editor entry + webp viewport export. */
.bpw-wrap { padding: var(--sp-6); max-width: 1280px; }
.bpw-breadcrumb {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.bpw-breadcrumb-link { color: var(--ink-faint); text-decoration: none; }
.bpw-title {
  font-family: var(--font-display); font-size: 28px; font-weight: 500;
  color: var(--ink); margin: 0 0 var(--sp-4); letter-spacing: -0.02em;
}
.bpw-flash { padding: var(--sp-3); margin-bottom: var(--sp-3); border: 1px solid var(--line); background: var(--panel); color: var(--ink); font-family: var(--font-body); font-size: 14px; line-height: 1.5; }
.bpw-flash-success { border-left: 3px solid var(--positive, var(--accent)); }
.bpw-flash-error   { border-left: 3px solid #dc2626; }

.bpw-grid-two {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); margin-bottom: var(--sp-4);
}
@media (max-width: 1024px) { .bpw-grid-two { grid-template-columns: 1fr; } }

.bpw-panel { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4); margin-bottom: var(--sp-4); }
.bpw-panel-row { display: flex; gap: var(--sp-4); justify-content: space-between; align-items: flex-start; }
.bpw-panel-row-main { flex: 1; min-width: 0; }
.bpw-panel-row-action { flex-shrink: 0; }
.bpw-panel-row-action-stack { display: flex; flex-direction: column; gap: var(--sp-2); align-items: flex-end; }
.bpw-panel-head { display: flex; justify-content: space-between; align-items: baseline; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.bpw-panel-eyebrow {
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-dim);
  letter-spacing: 0.08em; text-transform: uppercase; font-weight: 500;
}
.bpw-panel-title { font-family: var(--font-display); font-size: 22px; margin: var(--sp-1) 0 0; color: var(--ink); font-weight: 500; line-height: 1.2; }
.bpw-inline-form { margin: 0; }

.bpw-btn-primary {
  background: var(--ink); color: var(--bg); border: none;
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono); font-size: var(--text-sm);
  letter-spacing: 0.04em; cursor: pointer;
}
.bpw-btn-accent {
  background: var(--accent); color: #000; border: 1px solid var(--line);
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono); font-size: var(--text-sm);
  letter-spacing: 0.04em; cursor: pointer;
}
.bpw-btn-disabled {
  background: var(--panel-2); color: var(--ink-faint); border: 1px solid var(--line);
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono); font-size: var(--text-sm);
  letter-spacing: 0.04em; cursor: not-allowed;
}
.bpw-btn-positive {
  background: var(--positive, var(--accent)); color: #000; border: 1px solid var(--line);
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono); font-size: var(--text-sm);
  letter-spacing: 0.04em; cursor: pointer;
}
.bpw-btn-secondary {
  background: var(--panel-2); color: var(--ink); border: 1px solid var(--line);
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono); font-size: var(--text-sm);
  letter-spacing: 0.04em; cursor: pointer; text-decoration: none;
  display: inline-flex; align-items: center;
}
.bpw-btn-secondary:hover { border-color: var(--accent); color: var(--accent); }
.bpw-btn-row { display: flex; gap: var(--sp-2); align-items: stretch; }
.bpw-btn-row .bpw-inline-form { margin: 0; }

/* Panel meta — text operators read constantly. Sans, full-contrast ink, 14px.
   Mono only carried via the .bpw-mono-token class on individual tokens (timestamps,
   prompt versions, paths). */
.bpw-run-meta { font-family: var(--font-body); font-size: 14px; line-height: 1.55; margin-bottom: var(--sp-3); color: var(--ink); }
.bpw-run-meta .bpw-mono-token { font-family: var(--font-mono); font-size: 12px; color: var(--ink-dim); }
.bpw-run-empty { font-family: var(--font-body); font-size: 14px; color: var(--ink-dim); }
.bpw-run-actions { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; margin-top: var(--sp-2); }
.bpw-run-error { color: #f87171; margin-top: var(--sp-2); font-family: var(--font-body); font-size: 14px; }
.bpw-run-path { color: var(--ink-dim); margin-top: var(--sp-2); word-break: break-all; font-family: var(--font-mono); font-size: 12px; }
.bpw-run-files { margin-top: var(--sp-2); }
.bpw-run-files summary { cursor: pointer; color: var(--ink-dim); font-family: var(--font-body); font-size: 13px; }
.bpw-files-list { font-family: var(--font-mono); font-size: 12px; color: var(--ink-dim); list-style: none; padding: 0; margin: var(--sp-2) 0 0; }
.bpw-files-list li { word-break: break-all; padding: 2px 0; }

.bpw-status-running  { color: var(--accent); }
.bpw-status-complete { color: var(--positive, var(--accent)); }
.bpw-status-failed   { color: #dc2626; }
.bpw-status-faint    { color: var(--ink-faint); }

.bpw-link { font-family: var(--font-body); font-size: 14px; color: var(--accent); text-decoration: none; font-weight: 500; }
.bpw-link:hover { text-decoration: underline; }
.bpw-export-label { font-family: var(--font-body); font-size: 13px; color: var(--ink-dim); margin-left: var(--sp-2); }

.bpw-mockup-thumbs { display: grid; grid-template-columns: 3fr 2fr 1fr; gap: var(--sp-2); margin-top: var(--sp-3); }
.bpw-thumb-figure { margin: 0; }
.bpw-thumb-img { width: 100%; height: auto; border: 1px solid var(--line); display: block; }
.bpw-thumb-caption {
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim);
  letter-spacing: 0.08em; text-transform: uppercase; text-align: center; margin-top: var(--sp-1);
}

.bpw-deploy-link { margin-top: var(--sp-2); }
.bpw-deploy-meta { font-family: var(--font-body); font-size: 13px; color: var(--ink-dim); margin-top: var(--sp-1); }
.bpw-helper { font-family: var(--font-body); font-size: 13px; color: var(--ink-dim); margin-top: var(--sp-2); font-style: normal; }

.bpw-approve-form { display: flex; flex-direction: column; gap: var(--sp-1); margin: 0; }
.bpw-approve-notes {
  background: var(--panel-2); border: 1px solid var(--line);
  padding: var(--sp-1) var(--sp-2); font-family: var(--font-mono); font-size: 11px; color: var(--ink); width: 240px;
}

.bpw-runs { margin-top: var(--sp-6); }
.bpw-runs-table-wrap { background: var(--panel); border: 1px solid var(--line); margin-top: var(--sp-2); }
.bpw-runs-table { width: 100%; border-collapse: collapse; }
.bpw-runs-table thead tr { background: var(--panel-2); border-bottom: 1px solid var(--line); }
.bpw-runs-table th {
  text-align: left; padding: var(--sp-3); font-family: var(--font-mono);
  font-weight: 500; font-size: 12px; color: var(--ink); letter-spacing: 0.06em; text-transform: uppercase;
}
/* Cells default to readable sans; mono is reserved for cells holding
   token values (timestamps, prompt IDs, paths). Add .bpw-cell-mono on
   those td elements directly. */
.bpw-runs-table td { padding: var(--sp-3); font-family: var(--font-body); font-size: 13px; color: var(--ink); border-bottom: 1px solid var(--line); line-height: 1.4; }
.bpw-runs-table td.bpw-cell-mono { font-family: var(--font-mono); font-size: 12px; color: var(--ink-dim); }
.bpw-col-right { text-align: right; }
.bpw-btn-row-delete {
  background: transparent; color: var(--ink-faint); border: 1px solid transparent;
  padding: 2px 8px; cursor: pointer; font-family: var(--font-body); font-size: 16px; line-height: 1;
}
.bpw-btn-row-delete:hover { color: #f87171; border-color: #f87171; }

/* Brand Profile · Link to Client (P6 IA refactor) */
.bpl-wrap { padding: var(--sp-6); max-width: 720px; }
.bpl-breadcrumb {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.bpl-breadcrumb-link { color: var(--ink-faint); text-decoration: none; }
.bpl-title {
  font-family: var(--font-display); font-size: 28px; font-weight: 500; color: var(--ink);
  margin: 0 0 var(--sp-5); letter-spacing: -0.01em;
}
.bpl-panel { background: var(--panel); border: 1px solid var(--line); padding: var(--sp-4); margin-bottom: var(--sp-4); color: var(--ink-dim); }
.bpl-panel-title { font-family: var(--font-display); font-size: 16px; font-weight: 500; margin: 0 0 var(--sp-3); color: var(--ink); }
.bpl-form { display: flex; gap: var(--sp-2); align-items: center; flex-wrap: wrap; }
.bpl-select {
  background: var(--panel-2); color: var(--ink); border: 1px solid var(--line);
  padding: var(--sp-2); font-family: var(--font-sans); flex: 1; min-width: 200px;
}
.bpl-btn {
  background: var(--panel); color: var(--ink); border: 1px solid var(--line);
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-mono);
  font-size: var(--text-sm); letter-spacing: 0.04em; text-transform: uppercase;
  cursor: pointer;
}
.bpl-btn-accent { background: var(--accent); color: #000; border-color: var(--accent); }
.bpl-empty { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--ink-faint); }
.bpl-flash { padding: var(--sp-3); margin-bottom: var(--sp-3); border: 1px solid var(--line); background: var(--panel); color: var(--ink-dim); font-family: var(--font-mono); font-size: var(--text-sm); }
.bpl-flash-success { border-left: 3px solid var(--positive, var(--accent)); }
.bpl-flash-error   { border-left: 3px solid #dc2626; }

/* Brand Profiles list — P6 link/unlink action button */
.bpl-list-action {
  background: transparent; color: var(--ink-faint); border: 1px solid var(--line);
  padding: 4px 10px; font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: 0.04em; cursor: pointer; text-decoration: none; display: inline-block;
  margin-right: 4px;
}

/* --- Design editor preview iframe skeleton ------------------------- */
.dpv { background: var(--bg); color: var(--ink); font-family: var(--font-body); margin: 0; padding: 0; }
.dpv-shell { display: grid; grid-template-columns: 56px 1fr; min-height: 100vh; }
.dpv-rail {
  background: var(--panel); border-right: 1px solid var(--line);
  display: flex; flex-direction: column; align-items: center; padding: var(--sp-3) 0; gap: var(--sp-3);
}
.dpv-rail-brand {
  width: 28px; height: 28px; background: var(--accent); border-radius: var(--radius-sm);
}
.dpv-rail-icon {
  width: 28px; height: 28px; border: 1px solid var(--line); background: var(--panel-2);
  border-radius: var(--radius-sm); display: block;
}
.dpv-rail-icon[data-active="true"] { border-color: var(--accent); background: var(--panel-3); }
.dpv-main { padding: var(--sp-5); }
.dpv-header {
  border-bottom: 1px solid var(--line); padding-bottom: var(--sp-4); margin-bottom: var(--sp-5);
}
.dpv-eyebrow {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.dpv-title { font-family: var(--font-display); font-weight: 500; font-size: 32px; color: var(--ink); margin: var(--sp-2) 0 0; }
.dpv-sub { color: var(--ink-dim); margin-top: var(--sp-2); }
.dpv-section { margin-bottom: var(--sp-5); }
.dpv-section-label {
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
  letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.dpv-card {
  border: 1px solid var(--line); background: var(--panel); padding: var(--sp-4);
  border-radius: var(--radius-md); margin-bottom: var(--sp-3);
}
.dpv-card-title { font-family: var(--font-display); color: var(--ink); margin: 0 0 var(--sp-2); font-weight: 500; }
.dpv-row { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; }
.dpv-btn {
  border: 1px solid var(--line); background: var(--panel-2); color: var(--ink);
  padding: var(--sp-2) var(--sp-3); border-radius: var(--radius-sm);
  font-family: var(--font-mono); font-size: var(--text-sm); cursor: pointer;
}
.dpv-btn-primary { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.dpv-btn-positive { background: var(--positive); color: var(--bg); border-color: var(--positive); }
.dpv-btn-danger { background: var(--critical); color: var(--bg); border-color: var(--critical); }
.dpv-swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: var(--sp-2); }
.dpv-swatch {
  border: 1px solid var(--line); background: var(--panel); padding: var(--sp-2);
  border-radius: var(--radius-sm);
}
.dpv-swatch-chip { height: 36px; border-radius: var(--radius-sm); margin-bottom: var(--sp-2); border: 1px solid var(--line); }
.dpv-swatch-name { font-family: var(--font-mono); font-size: 10px; color: var(--ink-faint); letter-spacing: 0.04em; }
.dpv-type-row { padding: var(--sp-2) 0; border-bottom: 1px dashed var(--line); }
.dpv-type-row:last-child { border-bottom: 0; }
.dpv-type-display { font-family: var(--font-display); font-weight: 500; font-size: 24px; color: var(--ink); }
.dpv-type-body    { font-family: var(--font-body); font-size: var(--text-sm); color: var(--ink-dim); }
.dpv-type-mono    { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); letter-spacing: 0.04em; }
.dpv-spacer-row { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-2); }
.dpv-spacer-bar { background: var(--accent); height: 12px; }
.dpv-spacer-1 { width: var(--sp-1); }
.dpv-spacer-2 { width: var(--sp-2); }
.dpv-spacer-3 { width: var(--sp-3); }
.dpv-spacer-4 { width: var(--sp-4); }
.dpv-spacer-5 { width: var(--sp-5); }
.dpv-spacer-6 { width: var(--sp-6); }
.dpv-radius-md { border-radius: var(--radius-md); }
.dpv-radius-sm { border-radius: var(--radius-sm); }
.dpv-radius-0  { border-radius: 0; }
.dpv-chip-accent        { background: var(--accent); }
.dpv-chip-accent-bright { background: var(--accent-bright); }
.dpv-chip-accent-glow   { background: var(--accent-glow); }
.dpv-chip-ink           { background: var(--ink); }
.dpv-chip-ink-dim       { background: var(--ink-dim); }
.dpv-chip-ink-faint     { background: var(--ink-faint); }
.dpv-chip-bg            { background: var(--bg); }
.dpv-chip-panel         { background: var(--panel); }
.dpv-chip-panel-2       { background: var(--panel-2); }
.dpv-chip-panel-3       { background: var(--panel-3); }
.dpv-chip-line          { background: var(--line); }
.dpv-chip-line-hot      { background: var(--line-hot); }
.dpv-chip-positive      { background: var(--positive); }
.dpv-chip-caution       { background: var(--caution); }
.dpv-chip-critical      { background: var(--critical); }
.dpv-spacer-name { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint); width: 60px; }
.dpv-radius-row { display: flex; gap: var(--sp-3); }
.dpv-radius-tile {
  width: 64px; height: 64px; background: var(--panel-3); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-faint);
}
.dpv-status { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.dpv-pill {
  font-family: var(--font-mono); font-size: var(--text-xs); padding: 4px 10px;
  border-radius: var(--radius-sm); border: 1px solid var(--line);
}
.dpv-pill-positive { color: var(--positive); border-color: var(--positive); }
.dpv-pill-caution  { color: var(--caution);  border-color: var(--caution); }
.dpv-pill-critical { color: var(--critical); border-color: var(--critical); }

/* Web tab — long-job overlay. Shown while a synchronous Anthropic / Playwright
   / rsync call is running and the browser is waiting on the response. Not a
   real progress bar (the call is opaque server-side); a spinner + ETA + elapsed
   counter so the operator knows the tab is alive. */
.bpw-longjob-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(15, 17, 21, 0.82);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(2px);
}
.bpw-longjob-overlay[hidden] { display: none; }
.bpw-longjob-card {
  background: var(--bg); border: 1px solid var(--line);
  padding: var(--sp-6) var(--sp-7);
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-3);
  min-width: 320px; max-width: 440px; text-align: center;
}
.bpw-longjob-spinner {
  width: 48px; height: 48px;
  border: 3px solid var(--line);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: bpw-longjob-spin 0.9s linear infinite;
}
@keyframes bpw-longjob-spin { to { transform: rotate(360deg); } }
.bpw-longjob-title {
  font-family: var(--font-display); font-size: var(--text-lg);
  color: var(--ink); font-weight: 500;
}
.bpw-longjob-eta {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--ink-dim); letter-spacing: 0.04em;
}
.bpw-longjob-warn {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--accent); letter-spacing: 0.06em; text-transform: uppercase;
}
.bpw-longjob-elapsed {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--ink-faint); letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}

/* Brand Profile · Live Edit (BLE)
   Replaces the inline-styled live-edit template. Body sans for everything
   operators read; mono only on token-style values via .ble-mono-token. */
.ble-wrap { padding: var(--sp-4); max-width: 100%; }

.ble-breadcrumb {
  font-family: var(--font-body); font-size: 13px; color: var(--ink-dim);
  margin-bottom: var(--sp-3); letter-spacing: 0.02em;
}
.ble-breadcrumb-link { color: var(--ink-dim); text-decoration: none; font-weight: 500; }
.ble-breadcrumb-link:hover { color: var(--ink); }
.ble-mono-token { font-family: var(--font-mono); font-size: 12px; color: var(--ink-dim); }

.ble-grid {
  display: grid; grid-template-columns: 2fr 1fr; gap: var(--sp-4);
  height: calc(100vh - 160px); min-height: 600px;
}
@media (max-width: 1024px) { .ble-grid { grid-template-columns: 1fr; height: auto; } }

.ble-panel {
  background: var(--panel); border: 1px solid var(--line);
  display: flex; flex-direction: column; overflow: hidden;
}
.ble-panel-head {
  padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: var(--sp-3);
}
.ble-panel-eyebrow {
  font-family: var(--font-mono); font-size: 12px; color: var(--ink);
  letter-spacing: 0.08em; text-transform: uppercase; font-weight: 500;
}
.ble-panel-status {
  margin-left: auto; font-family: var(--font-body); font-size: 13px; color: var(--ink-dim);
}

.ble-select {
  font-family: var(--font-body); font-size: 13px;
  background: var(--bg); color: var(--ink); border: 1px solid var(--line);
  padding: 4px 8px; cursor: pointer;
}
.ble-btn-subtle {
  font-family: var(--font-body); font-size: 13px;
  background: var(--bg); color: var(--ink); border: 1px solid var(--line);
  padding: 4px 10px; cursor: pointer; font-weight: 500;
}
.ble-btn-subtle:hover { border-color: var(--accent); color: var(--accent); }
.ble-btn-subtle:disabled { opacity: 0.4; cursor: not-allowed; }

.ble-preview-frame { flex: 1; width: 100%; border: 0; background: white; }

.ble-chat-log {
  flex: 1; overflow-y: auto; padding: var(--sp-3);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.ble-chat-empty {
  color: var(--ink-dim); font-family: var(--font-body); font-size: 14px;
  text-align: center; padding: var(--sp-4); line-height: 1.5;
}
.ble-suggest { color: var(--accent); font-weight: 600; }

.ble-msg {
  background: var(--bg); border: 1px solid var(--line);
  padding: var(--sp-3); font-family: var(--font-body); font-size: 14px; line-height: 1.5;
}
.ble-msg-operator { background: var(--bg); }
.ble-msg-designer { background: var(--panel-2, #1c1c1c); }
.ble-msg-label {
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 4px; font-weight: 500;
}
.ble-msg-body { white-space: pre-wrap; color: var(--ink); }
.ble-msg-mode {
  font-family: var(--font-mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.06em; margin-left: 4px;
}
.ble-mode-fast  { color: var(--positive, #6ba870); }
.ble-mode-mixed { color: var(--caution, #c4883d); }
.ble-mode-full  { color: var(--ink-dim); }

.ble-send-form {
  border-top: 1px solid var(--line); padding: var(--sp-2);
  display: flex; flex-direction: column; gap: var(--sp-2); margin: 0;
}
.ble-msg-input {
  font-family: var(--font-body); font-size: 14px; line-height: 1.5;
  background: var(--bg); color: var(--ink); border: 1px solid var(--line);
  padding: var(--sp-2); resize: vertical; min-height: 60px;
}
.ble-msg-input:focus { border-color: var(--accent); outline: none; }
.ble-send-row { display: flex; gap: var(--sp-2); align-items: center; }
.ble-btn-primary {
  background: var(--ink); color: var(--bg); border: none;
  padding: var(--sp-2) var(--sp-4); font-family: var(--font-body); font-size: 14px;
  font-weight: 500; cursor: pointer;
}
.ble-btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }
.ble-send-status {
  font-family: var(--font-body); font-size: 13px; color: var(--ink-dim);
}
