/* ============================================================
   Earling Labs Crew — v0.1.0
   Canonical suite identity (locked 6/1/2026):
   Blueprint navy #0E1F35 + single amber accent #F5A623,
   green success / red error, blueprint grid, gold L-brackets,
   Space Grotesk + JetBrains Mono.
   ============================================================ */

:root {
  /* Base palette — blueprint navy */
  --bg:           #0E1F35;
  --bg-deep:      #081429;
  --surface:      #142B45;
  --surface-2:    #1A3552;
  --surface-3:    #213F60;

  /* Ink — blueprint paper cream */
  --ink:          #EFE5CC;
  --ink-soft:     #9FB4CC;
  --ink-dim:      #6B819A;
  --ink-deep:     #4A6080;

  /* Rules / borders (subtle amber) */
  --rule:         rgba(245, 166, 35, 0.18);
  --rule-strong:  rgba(245, 166, 35, 0.30);
  --rule-bright:  rgba(245, 166, 35, 0.45);

  /* Accent — the single family amber */
  --accent:       #F5A623;
  --accent-deep:  #C97A0F;
  --accent-soft:  rgba(245, 166, 35, 0.14);
  --accent-glow:  rgba(245, 166, 35, 0.35);

  /* Semantic */
  --success:      #00EC6E;
  --warning:      #F5C242;
  --error:        #FF4757;

  /* Type */
  --font-display: 'Space Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body:    'Space Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', 'Courier New', monospace;

  /* Geometry */
  --radius-sm: 2px;
  --radius:    4px;
  --radius-lg: 6px;
  --shadow:    0 6px 24px rgba(0, 0, 0, 0.35);
  --bracket-size: 14px;
  --bracket-thickness: 2px;
}

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

html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.55;
  min-height: 100vh;
  background-image:
    linear-gradient(rgba(245, 166, 35, 0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 166, 35, 0.022) 1px, transparent 1px),
    radial-gradient(ellipse at top, rgba(245, 166, 35, 0.045) 0%, transparent 60%);
  background-size: 24px 24px, 24px 24px, 100% 100%;
  background-attachment: fixed;
}

a { color: var(--accent); text-decoration: none; transition: color 0.15s; }
a:hover { color: var(--accent-deep); }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--ink);
}

.mono { font-family: var(--font-mono); }
.muted { color: var(--ink-soft); }
.dim { color: var(--ink-dim); }
.hidden { display: none !important; }
.hint { color: var(--ink-soft); font-size: 13px; }
.error { color: var(--error); font-size: 13px; min-height: 18px; margin-top: 6px; }

.wrap { max-width: 1080px; margin: 0 auto; padding: 0 24px 64px; }

/* ============================================================
   Top nav
   ============================================================ */
.topnav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px;
  border-bottom: 1px solid var(--rule);
  background: var(--bg-deep);
}
.topnav .brand-left { display: flex; align-items: center; gap: 12px; }
.topnav .brand-left img { height: 38px; width: auto; display: block; }
.topnav .wordmark {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 15px;
  color: var(--ink);
}
.topnav .navlinks { display: flex; align-items: center; gap: 22px; }
.topnav .navlinks a {
  position: relative;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  padding: 4px 0;
}
.topnav .navlinks a:hover { color: var(--ink); }
.topnav .navlinks a.active { color: var(--accent); }
.topnav .navlinks a.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--accent);
}
.topnav .nav-right { display: flex; align-items: center; gap: 16px; }
.topnav .user-chip { text-align: right; line-height: 1.2; }
.topnav .user-chip .u-name { font-size: 13px; color: var(--ink); }
.topnav .user-chip .u-co { font-size: 11px; color: var(--ink-dim); }
.btn-signout {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: transparent;
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius);
  padding: 7px 12px;
  cursor: pointer;
  transition: all 0.15s;
}
.btn-signout:hover { color: var(--ink); border-color: var(--accent); }

/* ============================================================
   Suite Apps switcher (cross-product launcher)
   ============================================================ */
.suite-switcher { position: relative; }
.suite-btn {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  background: transparent;
  border: 1px solid var(--rule-strong);
  border-radius: 999px;
  padding: 6px 12px;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.suite-btn:hover { border-color: var(--accent); background: var(--accent-soft); }
.suite-btn .caret { font-size: 9px; opacity: 0.8; }
.suite-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  min-width: 200px;
  background: var(--bg-deep);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
}
.suite-menu-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.suite-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.suite-pill {
  display: block;
  text-align: center;
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink);
  background: var(--surface-2);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 7px 10px;
  transition: all 0.15s;
}
a.suite-pill:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.suite-pill.current {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-soft);
  cursor: default;
  font-weight: 600;
}
.suite-pill.ghosted {
  color: var(--ink-dim);
  background: transparent;
  border-color: var(--rule);
  border-style: dashed;
  opacity: 0.5;
  cursor: not-allowed;
}
.suite-pill.ghosted:hover { opacity: 0.62; }

/* ============================================================
   Hero / Mission Brief
   ============================================================ */
.hero {
  position: relative;
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 36px;
  align-items: center;
  padding: 32px 0 28px;
  margin-bottom: 8px;
}
.hero .hero-logo { max-width: 300px; filter: drop-shadow(0 8px 24px rgba(0,0,0,0.4)); }
.hero .hero-logo img { width: 100%; height: auto; display: block; }
.hero .eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}
.hero h1 {
  font-size: clamp(28px, 4.2vw, 44px);
  text-transform: uppercase;
  line-height: 1.05;
  margin-bottom: 10px;
}
.hero .hero-desc { color: var(--ink-soft); max-width: 60ch; }
.hero .hero-actions { margin-top: 16px; display: flex; gap: 10px; flex-wrap: wrap; }
.version-pill {
  position: absolute;
  top: 0; right: 0;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--accent);
  background: var(--surface-3);
  border: 1px solid var(--rule-strong);
  border-radius: 999px;
  padding: 3px 10px;
}

@media (max-width: 720px) {
  .hero { grid-template-columns: 1fr; gap: 16px; }
  .hero .hero-logo { max-width: 200px; }
}

/* ============================================================
   Cards + gold L-corner brackets
   ============================================================ */
.card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 22px;
  margin-bottom: 18px;
}
.card.bracketed { overflow: visible; }
.bracket-corner { position: absolute; width: var(--bracket-size); height: var(--bracket-size); pointer-events: none; z-index: 2; }
.bracket-corner.bracket-tl { top: -1px; left: -1px; border-top: var(--bracket-thickness) solid var(--accent); border-left: var(--bracket-thickness) solid var(--accent); }
.bracket-corner.bracket-tr { top: -1px; right: -1px; border-top: var(--bracket-thickness) solid var(--accent); border-right: var(--bracket-thickness) solid var(--accent); }
.bracket-corner.bracket-bl { bottom: -1px; left: -1px; border-bottom: var(--bracket-thickness) solid var(--accent); border-left: var(--bracket-thickness) solid var(--accent); }
.bracket-corner.bracket-br { bottom: -1px; right: -1px; border-bottom: var(--bracket-thickness) solid var(--accent); border-right: var(--bracket-thickness) solid var(--accent); }

.card h3 {
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}
.card-muted { opacity: 0.78; }

/* ============================================================
   Buttons
   ============================================================ */
.btn-primary, .btn-secondary, .btn-danger {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 13px;
  border-radius: var(--radius);
  padding: 11px 18px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.15s;
  display: inline-block;
}
.btn-primary { background: var(--accent); color: var(--bg-deep); }
.btn-primary:hover { background: var(--accent-deep); color: var(--ink); }
.btn-secondary { background: transparent; color: var(--ink); border-color: var(--rule-strong); }
.btn-secondary:hover { border-color: var(--accent); color: var(--accent); }
.btn-danger { background: transparent; color: var(--error); border-color: rgba(255,71,87,0.4); }
.btn-danger:hover { background: rgba(255,71,87,0.12); }
button:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-sm { padding: 5px 10px; font-size: 11px; }

/* ============================================================
   Forms
   ============================================================ */
.field { margin-bottom: 14px; }
.field label {
  display: block;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 6px;
}
.field input, .field select, .field textarea {
  width: 100%;
  background: var(--surface-2);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 14px;
  padding: 10px 12px;
}
.field textarea { min-height: 76px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field-row-3 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 14px; }
@media (max-width: 640px) { .field-row, .field-row-3 { grid-template-columns: 1fr; } }

/* trade checkbox grid */
.trade-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
@media (max-width: 640px) { .trade-grid { grid-template-columns: 1fr 1fr; } }
.trade-grid label {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; text-transform: none; letter-spacing: 0;
  color: var(--ink); cursor: pointer;
  background: var(--surface-2); border: 1px solid var(--rule);
  border-radius: var(--radius); padding: 8px 10px;
}
.trade-grid input { width: auto; }

/* ============================================================
   Status pills
   ============================================================ */
.pill {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--rule-strong);
  color: var(--ink-soft);
  background: var(--surface-2);
}
.pill.lead         { color: var(--ink-soft); border-color: var(--rule-strong); }
.pill.estimating   { color: var(--accent); border-color: var(--rule-bright); background: var(--accent-soft); }
.pill.scheduled    { color: var(--accent); border-color: var(--rule-bright); background: var(--accent-soft); }
.pill.in_progress  { color: var(--warning); border-color: rgba(245,194,66,0.45); background: rgba(245,194,66,0.10); }
.pill.complete     { color: var(--success); border-color: rgba(0,236,110,0.45); background: rgba(0,236,110,0.10); }
.pill.closed       { color: var(--ink-dim); border-color: var(--rule); }

/* ============================================================
   Job list
   ============================================================ */
.filter-bar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin: 4px 0 18px; }
.filter-chip {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 5px 12px;
  cursor: pointer;
}
.filter-chip.active { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); }
.search-input {
  margin-left: auto;
  background: var(--surface-2);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 13px;
  padding: 7px 12px;
  min-width: 200px;
}
.search-input:focus { outline: none; border-color: var(--accent); }

.job-list { display: grid; gap: 12px; }
.job-card {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 14px;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
  padding: 16px 18px;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.05s;
}
.job-card:hover { border-color: var(--rule-bright); }
.job-card:active { transform: translateY(1px); }
.job-card .jc-title { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: var(--ink); }
.job-card .jc-meta { font-size: 13px; color: var(--ink-soft); margin-top: 3px; }
.job-card .jc-meta .sep { color: var(--ink-deep); margin: 0 7px; }
.job-card .jc-right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.job-card .jc-dates { font-family: var(--font-mono); font-size: 11px; color: var(--ink-dim); }

.empty-state { text-align: center; color: var(--ink-soft); padding: 40px 20px; }
.empty-state .es-big { font-family: var(--font-display); font-size: 18px; color: var(--ink); margin-bottom: 6px; }

/* ============================================================
   Detail page bits
   ============================================================ */
.kv { display: grid; grid-template-columns: 140px 1fr; gap: 8px 14px; font-size: 14px; }
.kv .k { color: var(--ink-dim); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; padding-top: 2px; }
.kv .v { color: var(--ink); }

.roadmap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 640px) { .roadmap-grid { grid-template-columns: 1fr; } }
.roadmap-item {
  background: var(--surface);
  border: 1px dashed var(--rule-strong);
  border-radius: var(--radius);
  padding: 14px 16px;
}
.roadmap-item .ri-name { font-family: var(--font-display); font-weight: 600; color: var(--ink); font-size: 14px; }
.roadmap-item .ri-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent); }
.roadmap-item .ri-desc { font-size: 12px; color: var(--ink-soft); margin-top: 4px; }

/* ============================================================
   System status table (settings)
   ============================================================ */
.status-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.status-table td { padding: 8px 0; border-bottom: 1px solid var(--rule); }
.status-table td:first-child { color: var(--ink-dim); text-transform: uppercase; font-size: 12px; letter-spacing: 0.05em; }
.status-table td:last-child { text-align: right; font-family: var(--font-mono); }
.dot-ok { color: var(--success); }
.dot-bad { color: var(--error); }

/* ============================================================
   Auth page
   ============================================================ */
.auth-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: 24px; }
.auth-container { max-width: 460px; width: 100%; }
.auth-container .brand { text-align: center; margin-bottom: 32px; }
.auth-container .brand .logo-wrap { margin: 0 auto 14px; max-width: 300px; filter: drop-shadow(0 6px 16px rgba(0,0,0,0.4)); }
.auth-container .brand .logo-wrap img { width: 100%; height: auto; display: block; }
.auth-container .brand .product-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.44em;
  color: var(--accent);
  text-transform: uppercase;
  margin: 8px 0 6px;
}
.auth-container .brand .tagline {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.tabs { display: flex; gap: 8px; margin-bottom: 18px; }
.tab {
  flex: 1;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 13px;
  color: var(--ink-soft);
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 9px;
  cursor: pointer;
}
.tab.active { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); }
.form { display: none; }
.form.active { display: block; }
.form .btn-primary { width: 100%; margin-top: 6px; }

.footer-note {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.08em;
  margin-top: 24px;
}

/* ============================================================
   Phase 2a — permits, inspections, AI suggest tray, footer
   ============================================================ */
.card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.card-head h3 { margin: 0; }

.inline-form {
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--bg-deep);
  padding: 14px 14px 4px;
  margin-bottom: 14px;
}

/* Permit / inspection rows */
.line-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 11px 12px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--surface-2);
  margin-bottom: 8px;
}
.line-item .li-main { min-width: 0; }
.line-item .li-title { font-family: var(--font-display); font-weight: 600; color: var(--ink); font-size: 14px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.line-item .li-meta { font-size: 12px; color: var(--ink-soft); margin-top: 3px; }
.line-item .li-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.empty-line { padding: 4px 2px; }

.mini-select {
  background: var(--surface-3);
  border: 1px solid var(--rule-strong);
  border-radius: var(--radius);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 6px;
}
.icon-btn {
  background: transparent; border: 1px solid var(--rule); border-radius: var(--radius);
  color: var(--ink-dim); width: 26px; height: 26px; cursor: pointer; line-height: 1;
  transition: color 0.15s, border-color 0.15s;
}
.icon-btn:hover { color: var(--error); border-color: rgba(255,71,87,0.5); }

/* Failed-state pill (extends the status pill palette) */
.pill.failed { color: var(--error); border-color: rgba(255,71,87,0.45); background: rgba(255,71,87,0.10); }

/* AI suggestion tray */
.suggest-tray {
  border: 1px solid var(--rule-bright);
  border-radius: var(--radius);
  background: var(--accent-soft);
  padding: 14px;
  margin-bottom: 14px;
}
.suggest-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.ai-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); }
.suggest-row {
  display: grid; grid-template-columns: 22px minmax(120px, max-content) 1fr; align-items: baseline;
  gap: 8px; padding: 7px 0; border-bottom: 1px solid var(--rule); cursor: pointer;
}
.suggest-row:last-of-type { border-bottom: none; }
.suggest-row input { width: 16px; height: 16px; accent-color: var(--accent); margin-top: 2px; }
.suggest-row .sug-type { font-family: var(--font-display); font-weight: 600; color: var(--ink); font-size: 13px; }
.suggest-row .sug-reason { font-size: 12px; color: var(--ink-soft); }
@media (max-width: 640px) { .suggest-row { grid-template-columns: 22px 1fr; } .suggest-row .sug-reason { grid-column: 2; } }

/* App footer (AI disclosure link) */
.app-footer { max-width: 920px; margin: 8px auto 40px; padding: 0 24px; text-align: center; }
.app-footer a { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.05em; color: var(--ink-dim); }
.app-footer a:hover { color: var(--accent); }

/* AI disclosure page list */
.disc-list { list-style: none; padding: 0; margin: 0; }
.disc-list li { position: relative; padding: 7px 0 7px 18px; font-size: 14px; color: var(--ink-soft); border-bottom: 1px solid var(--rule); }
.disc-list li:last-child { border-bottom: none; }
.disc-list li::before { content: '›'; position: absolute; left: 2px; color: var(--accent); font-weight: 700; }
.disc-list li strong { color: var(--ink); }

/* ============================================================
   Phase 2b — documents, file buttons, permit extract
   ============================================================ */
.extract-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 10px 12px; margin-bottom: 14px;
  border: 1px dashed var(--rule-bright); border-radius: var(--radius);
  background: var(--accent-soft);
}
.file-btn { cursor: pointer; display: inline-flex; align-items: center; }
.file-btn input[type=file] { display: none; }
.selected-file {
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft);
  padding: 8px 0; word-break: break-all;
}

/* ============================================================
   Phase 3 — job costing panel
   ============================================================ */
.costing-link { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.costing-link .link-row { display:flex; gap:8px; align-items:center; }
.costing-link input { width:220px; max-width:48vw; background:var(--surface-2); border:1px solid var(--rule-strong); border-radius:var(--radius); color:var(--ink); font-family:var(--font-mono); font-size:12px; padding:7px 9px; }

.cost-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px; }
@media (max-width:760px){ .cost-grid { grid-template-columns:1fr 1fr; } }
.cost-metric { background:var(--surface-2); border:1px solid var(--rule); border-radius:var(--radius); padding:11px 12px; }
.cm-label { font-family:var(--font-mono); font-size:10px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-dim); }
.cm-val { font-size:19px; color:var(--ink); margin-top:5px; }
.cm-val.pos { color:var(--success); }
.cm-val.neg { color:var(--error); }
.cm-pct { font-size:12px; color:var(--ink-soft); }
.cm-sub { font-size:11px; color:var(--ink-soft); margin-top:3px; }

.cost-bars { display:flex; flex-direction:column; gap:12px; margin-bottom:8px; }
.cbar-row { display:grid; grid-template-columns:1fr; gap:5px; }
.cbar-label { font-family:var(--font-mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); }
.cbar { height:9px; background:var(--surface-3); border-radius:999px; overflow:hidden; }
.cbar-fill { height:100%; border-radius:999px; transition:width .4s ease; }
.cbar-fill.fill-ok { background:var(--accent); }
.cbar-fill.fill-over { background:var(--error); }
.cbar-fig { font-size:11px; color:var(--ink-soft); text-align:right; }
.over-flag { font-family:var(--font-mono); font-size:9px; letter-spacing:.08em; color:var(--error); border:1px solid rgba(255,71,87,.45); background:rgba(255,71,87,.10); border-radius:999px; padding:1px 7px; margin-left:6px; }

.cost-section-label { font-family:var(--font-mono); font-size:10px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-dim); margin:14px 0 6px; }
.cat-list { display:flex; flex-direction:column; }
.cat-row { display:flex; justify-content:space-between; font-size:13px; color:var(--ink); padding:6px 0; border-bottom:1px solid var(--rule); }
.cat-row:last-child { border-bottom:none; }

.src-row { display:flex; gap:8px; flex-wrap:wrap; margin-top:14px; }
.src-chip { font-family:var(--font-mono); font-size:10px; letter-spacing:.05em; text-transform:uppercase; border-radius:999px; padding:3px 9px; border:1px solid var(--rule); }
.src-chip.src-ok { color:var(--success); border-color:rgba(0,236,110,.40); background:rgba(0,236,110,.08); }
.src-chip.src-down { color:var(--ink-dim); border-color:var(--rule); border-style:dashed; }

.claim-box { margin-top:16px; border-top:1px solid var(--rule); padding-top:12px; }
.claim-box summary { cursor:pointer; font-family:var(--font-mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--accent); }
.claim-row { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-top:10px; }
.claim-row input { background:var(--surface-2); border:1px solid var(--rule-strong); border-radius:var(--radius); color:var(--ink); font-family:var(--font-mono); font-size:12px; padding:7px 9px; min-width:200px; }

/* ============================================================
   Phase 4 — change orders
   ============================================================ */
.co-li-label { display:block; font-family:var(--font-mono); font-size:10px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:6px; }
.co-line { display:grid; grid-template-columns:1fr 80px 100px 30px; gap:8px; margin-bottom:7px; align-items:center; }
.co-line input { background:var(--surface-2); border:1px solid var(--rule-strong); border-radius:var(--radius); color:var(--ink); font-family:var(--font-body); font-size:13px; padding:7px 9px; }
.co-line .co-l-del { width:26px; height:30px; }
@media (max-width:560px){ .co-line { grid-template-columns:1fr 60px 80px 28px; } }
.co-total-row { font-family:var(--font-display); font-weight:600; color:var(--ink); font-size:15px; margin-bottom:12px; }
.co-total-row .mono { color:var(--accent); }
.co-decided { margin-top:12px; font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; }
.co-decided.approved { color:var(--success); }
.co-decided.rejected { color:var(--error); }
.dim { color:var(--ink-dim); }

/* ============================================================
   Phase 5 — team / assignees
   ============================================================ */
#assignee-list { display:flex; flex-wrap:wrap; gap:8px; }
.assignee-chip { display:inline-flex; align-items:center; gap:7px; background:var(--surface-2); border:1px solid var(--rule-strong); border-radius:999px; padding:5px 6px 5px 12px; font-size:13px; color:var(--ink); }
.assignee-chip .ac-role { font-family:var(--font-mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); }
.assignee-chip .icon-btn { width:22px; height:22px; }
.s-role-field { color:var(--accent); }

/* ============================================================
   Phase 6 — time & daily logs
   ============================================================ */
.time-summary { font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--accent); margin-bottom:10px; }
.mini-cost { width:90px; background:var(--surface-2); border:1px solid var(--rule-strong); border-radius:var(--radius); color:var(--ink); font-family:var(--font-mono); font-size:12px; padding:6px 8px; }

/* ============================================================
   Phase 6b — crew schedule
   ============================================================ */
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.page-head h1 { margin:4px 0 0; }
.week-nav { display:flex; gap:8px; }

.week-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:10px; }
@media (max-width:900px){ .week-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .week-grid { grid-template-columns:1fr; } }
.day-col { background:var(--surface-1); border:1px solid var(--rule); border-radius:var(--radius); min-height:120px; display:flex; flex-direction:column; }
.day-col.today { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset; }
.day-head { display:flex; align-items:baseline; justify-content:space-between; padding:8px 10px; border-bottom:1px solid var(--rule); }
.day-head .dn { font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-dim); }
.day-head .dd { font-family:var(--font-display); font-weight:600; color:var(--ink); }
.day-body { padding:8px; display:flex; flex-direction:column; gap:7px; }
.day-empty { color:var(--ink-deep); text-align:center; font-size:13px; padding:6px 0; }
.shift { display:flex; align-items:flex-start; justify-content:space-between; gap:6px; background:var(--surface-2); border:1px solid var(--rule-strong); border-radius:var(--radius); padding:7px 9px; }
.shift .sh-job { color:var(--accent); font-size:12px; font-weight:600; text-decoration:none; display:block; }
.shift .sh-worker { font-size:13px; color:var(--ink); }
.shift .sh-note { font-size:11px; color:var(--ink-soft); margin-top:2px; }

.job-schedule { margin-top:14px; }
.js-label { font-family:var(--font-mono); font-size:10px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:6px; display:flex; justify-content:space-between; }
.js-link { color:var(--accent); text-decoration:none; }
.js-row { display:flex; justify-content:space-between; font-size:13px; color:var(--ink); padding:4px 0; border-bottom:1px solid var(--rule); }
.js-row:last-child { border-bottom:none; }
.js-row .mono { color:var(--ink-soft); }

/* ============================================================
   v0.9.0 — dashboard command center
   ============================================================ */
.metric-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-bottom:22px; }
.metric-tile { background:var(--surface-1); border:1px solid var(--rule); border-radius:var(--radius); padding:16px 16px 14px; }
.metric-tile .mt-val { font-size:28px; color:var(--accent); line-height:1; }
.metric-tile .mt-label { font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink); margin-top:8px; }
.metric-tile .mt-sub { font-size:11px; color:var(--ink-soft); margin-top:3px; }

/* ============================================================
   v0.10.0 — compliance radar (cross-job permits & inspections)
   ============================================================ */
.compliance-row { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:12px 14px; border:1px solid var(--rule); border-radius:var(--radius); margin-bottom:9px; text-decoration:none; background:var(--surface-1); transition:border-color .15s; }
.compliance-row:hover { border-color:var(--accent); }
.compliance-row.attn-amber { border-left:3px solid var(--accent); }
.compliance-row.attn-red { border-left:3px solid var(--error); }
.cr-title { color:var(--ink); font-weight:600; font-size:14px; }
.cr-pill { font-family:var(--font-mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--rule); border-radius:999px; padding:1px 7px; margin-left:6px; }
.cr-meta { font-size:12px; color:var(--ink-soft); margin-top:3px; }
.cr-when { font-family:var(--font-mono); font-size:12px; color:var(--ink-soft); text-align:right; white-space:nowrap; }
.cr-when .urgent { color:var(--error); }
.cr-when .soon { color:var(--accent); }
.cr-when .dim { color:var(--ink-dim); }

/* ── Crew roster (Phase 1) ─────────────────────────── */
.pill.active   { color: var(--success); border-color: rgba(0,236,110,0.45); background: rgba(0,236,110,0.10); }
.pill.inactive { color: var(--ink-dim); border-color: var(--rule); }
.badge-type {
    display: inline-block; font-family: var(--font-mono); font-size: 10px;
    letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent);
    border: 1px solid var(--rule-bright); background: var(--accent-soft);
    border-radius: 4px; padding: 1px 6px; margin-right: 8px; vertical-align: middle;
}
.badge-type.sub { color: var(--ink-soft); border-color: var(--rule-strong); background: transparent; }
.toggle-inactive {
    display: inline-flex; align-items: center; gap: 6px; font-size: 13px;
    color: var(--ink-soft); margin-left: 4px; cursor: pointer; user-select: none;
}
.toggle-inactive input { accent-color: var(--accent); }
.jc-card.inactive-row { opacity: 0.62; }

/* Worker detail — later-phase shells */
.phase-list { list-style: none; padding: 0; margin: 6px 0 0; }
.phase-list li { padding: 9px 0; border-bottom: 1px solid var(--rule); color: var(--ink-soft); font-size: 14px; display: flex; justify-content: space-between; align-items: center; }
.phase-list li:last-child { border-bottom: none; }
.phase-list .ph-soon { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-dim); border: 1px dashed var(--rule-strong); border-radius: 4px; padding: 1px 6px; }
.detail-head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 4px 0 18px; }
.detail-head h1 { margin: 0; }
.back-link { display: inline-block; font-size: 13px; color: var(--ink-soft); text-decoration: none; margin-bottom: 10px; }
.back-link:hover { color: var(--accent); }
.save-note { font-size: 13px; color: var(--success); opacity: 0; transition: opacity 0.2s; }
.save-note.show { opacity: 1; }

/* Compliance radar */
.radar-counts { display: flex; gap: 12px; flex-wrap: wrap; margin: 4px 0 18px; }
.rc-stat { flex: 1; min-width: 120px; border: 1px solid var(--rule); border-radius: 8px; padding: 12px 14px; font-size: 12px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.05em; }
.rc-stat .rc-num { display: block; font-family: var(--font-mono); font-size: 24px; color: var(--ink); margin-bottom: 2px; letter-spacing: 0; }
.rc-stat.bad { border-color: rgba(255,71,87,0.5); } .rc-stat.bad .rc-num { color: var(--error); }
.rc-stat.warn { border-color: rgba(245,194,66,0.5); } .rc-stat.warn .rc-num { color: var(--warning); }
.rc-stat.ok .rc-num { color: var(--success); }
.doc-flag { display: inline-block; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; border-radius: 4px; padding: 1px 6px; margin-left: 8px; }
.doc-flag.exp { color: var(--error); border: 1px solid rgba(255,71,87,0.45); background: rgba(255,71,87,0.10); }
.doc-flag.soon { color: var(--warning); border: 1px solid rgba(245,194,66,0.45); background: rgba(245,194,66,0.10); }
