/* company360.css — Company 360 view (P2-09 · UX-03 redesign · prefix c360-)
 * Tokens from styles.css :root (UX-01). Dark-correct: no light-theme literal
 * fallbacks (the old #fff / #333 / pastel status chips rendered wrong on the
 * dark app). Status chips now derive from the semantic palette.
 */

/* -------------------------------------------------------------------------
 * Root + layout
 * ---------------------------------------------------------------------- */
.c360-root {
  padding: var(--space-4);
  max-width: 1400px;
  margin: 0 auto;
}

.c360-loading,
.c360-error {
  padding: var(--space-6);
  text-align: center;
  color: var(--text-secondary);
}

.c360-error {
  color: var(--danger);
}

/* -------------------------------------------------------------------------
 * Header (tightened)
 * ---------------------------------------------------------------------- */
.c360-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-color);
}

.c360-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.c360-company-name {
  font-size: var(--text-xl);
  font-weight: 700;
  margin: 0;
  color: var(--text-primary);
  line-height: var(--leading-tight);
}

.c360-customer-no {
  font-size: var(--text-sm);
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.c360-status-badge {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  border-radius: 1rem;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--bg-light);
  color: var(--text-secondary);
}

/* Status chips derive from the semantic palette (dark-correct). */
.c360-status-active   { background: color-mix(in srgb, var(--success) 22%, var(--bg-card)); color: var(--success); }
.c360-status-inactive { background: color-mix(in srgb, var(--danger) 22%, var(--bg-card));  color: var(--danger); }
.c360-status-archived { background: var(--bg-light); color: var(--text-secondary); }
.c360-status-prospect { background: color-mix(in srgb, var(--primary) 22%, var(--bg-card)); color: var(--primary); }
.c360-status-lead     { background: color-mix(in srgb, var(--warning) 22%, var(--bg-card)); color: var(--warning); }

/* Header counts slot (C-03) */
.c360-header-counts {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.c360-count-chip {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-2);
  border-radius: 1rem;
  background: var(--bg-light);
  color: var(--text-secondary);
  white-space: nowrap;
}

/* Open-invoices chip row (UX-w7 Finding 3) — money-tinted so it reads as a
   financial signal next to the lane-count chips. */
.c360-header-invoices {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.c360-invoice-chip {
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-1) var(--space-3);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--warning) 22%, var(--bg-card));
  color: var(--warning);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* Header action buttons (Write email + Edit) */
.c360-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.c360-compose-btn {
  background: var(--bg-light);
  color: var(--accent);
  border: 1px solid var(--border-color);
}
.c360-compose-btn:hover {
  border-color: var(--accent);
  background: var(--secondary);
}

/* Invoices-tab open summary banner */
.c360-invoice-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-3);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--warning) 14%, var(--bg-card));
  border: 1px solid color-mix(in srgb, var(--warning) 40%, transparent);
}
.c360-invoice-summary-label {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
}
.c360-invoice-summary-value {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--warning);
  font-variant-numeric: tabular-nums;
}

/* Invoice status pills (per workflow state: draft|validated|paid|abandoned) */
.c360-invoice-status {
  display: inline-block;
  padding: 0.1rem var(--space-2);
  border-radius: 1rem;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: capitalize;
  background: var(--bg-light);
  color: var(--text-secondary);
}
.c360-invoice-status-validated { background: color-mix(in srgb, var(--warning) 22%, var(--bg-card)); color: var(--warning); }
.c360-invoice-status-paid      { background: color-mix(in srgb, var(--success) 22%, var(--bg-card)); color: var(--success); }
.c360-invoice-status-abandoned { background: color-mix(in srgb, var(--danger) 22%, var(--bg-card));  color: var(--danger); }
.c360-invoice-status-draft     { background: var(--bg-light); color: var(--text-secondary); }

/* -------------------------------------------------------------------------
 * Grid of panels
 * ---------------------------------------------------------------------- */
.c360-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-4);
}

/* -------------------------------------------------------------------------
 * Panel base
 * ---------------------------------------------------------------------- */
.c360-panel {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.c360-panel-title {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  margin: 0 0 var(--space-3);
}

.c360-empty {
  color: var(--text-muted);
  font-style: italic;
  font-size: var(--text-sm);
  margin: 0;
}

/* -------------------------------------------------------------------------
 * Contacts
 * ---------------------------------------------------------------------- */
.c360-contact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.c360-contact-row {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.c360-contact-name {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.c360-contact-meta {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  flex: 1;
}

.c360-contact-seen {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-left: auto;
}

/* -------------------------------------------------------------------------
 * Timeline
 * ---------------------------------------------------------------------- */
.c360-timeline-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.c360-timeline-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.c360-timeline-icon {
  font-size: var(--text-sm);
  color: var(--primary);
  margin-top: 0.15rem;
  width: 16px;
  flex-shrink: 0;
}

.c360-timeline-body {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  flex: 1;
}

.c360-timeline-summary {
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.c360-timeline-date {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

/* -------------------------------------------------------------------------
 * Open cards
 * ---------------------------------------------------------------------- */
.c360-card-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.c360-lane-chip {
  display: inline-block;
  padding: var(--space-1) var(--space-2);
  border-radius: 1rem;
  font-size: var(--text-xs);
  background: var(--bg-light);
  color: var(--text-secondary);
}

.c360-card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.c360-card-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--text-sm);
  border: 1px solid transparent;
  transition: background 0.18s ease, border-color 0.18s ease;
}

.c360-card-row:hover {
  background: var(--bg-light);
  border-color: var(--border-color);
}

.c360-card-subject {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-primary);
}

.c360-ai-class-chip {
  display: inline-block;
  padding: 0.1rem var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  background: var(--bg-light);
  color: var(--text-secondary);
  flex-shrink: 0;
}

/* -------------------------------------------------------------------------
 * Documents
 * ---------------------------------------------------------------------- */
.c360-panel-docs {
  grid-column: span 2;
}

@media (max-width: 900px) {
  .c360-panel-docs { grid-column: span 1; }
}

.c360-doc-section {
  margin-bottom: var(--space-4);
}

.c360-doc-section:last-child {
  margin-bottom: 0;
}

.c360-doc-section-title {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin: 0 0 var(--space-2);
}

.c360-doc-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.c360-doc-table th {
  text-align: left;
  padding: var(--space-1) var(--space-2);
  color: var(--text-muted);
  font-weight: 600;
  border-bottom: 1px solid var(--border-color);
}

.c360-doc-table td {
  padding: var(--space-1) var(--space-2);
  border-bottom: 1px solid var(--border-color);
  vertical-align: middle;
  color: var(--text-primary);
}

.c360-doc-row {
  cursor: pointer;
  transition: background 0.15s ease;
}

.c360-doc-row:hover td {
  background: var(--bg-light);
}

.c360-doc-totals-row td {
  font-weight: 700;
  border-top: 2px solid var(--border-color);
  border-bottom: none;
}

.c360-doc-amount,
.c360-doc-totals-amount {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.c360-doc-status {
  font-size: var(--text-xs);
  padding: 0.1rem var(--space-2);
}

/* -------------------------------------------------------------------------
 * Hours
 * ---------------------------------------------------------------------- */
.c360-panel-hours {
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 120px;
}

.c360-hours-big {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1;
  color: var(--primary);
  margin-bottom: var(--space-1);
}

.c360-hours-label {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

/* -------------------------------------------------------------------------
 * AI Digest
 * ---------------------------------------------------------------------- */
.c360-panel-digest {
  grid-column: span 2;
}

@media (max-width: 900px) {
  .c360-panel-digest { grid-column: span 1; }
}

.c360-digest-body {
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  margin-bottom: var(--space-3);
  min-height: 2rem;
}

.c360-digest-body p {
  margin: 0 0 var(--space-2);
}

.c360-digest-body p:last-child {
  margin-bottom: 0;
}

.c360-digest-loading {
  color: var(--text-muted);
  font-style: italic;
}

.c360-digest-footer {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.c360-digest-date {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.c360-digest-btn {
  margin-left: auto;
}

/* -------------------------------------------------------------------------
 * Tabs (Overview / Files)
 * ---------------------------------------------------------------------- */
.c360-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border-color);
  margin-bottom: var(--space-4);
}

.c360-tab {
  background: none;
  border: none;
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color 0.18s ease, border-color 0.18s ease;
}

.c360-tab:hover {
  color: var(--text-primary);
}

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

/* -------------------------------------------------------------------------
 * Files tab
 * ---------------------------------------------------------------------- */
.c360-files-panel {
  padding: var(--space-2) 0;
}

.c360-files-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  font-size: var(--text-sm);
  margin-bottom: var(--space-3);
  color: var(--text-muted);
}

.c360-files-crumb-btn {
  background: none;
  border: none;
  padding: 0 var(--space-1);
  font-size: var(--text-sm);
  color: var(--primary);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.c360-files-crumb-btn:hover {
  color: var(--primary-dark);
}

.c360-files-crumb-sep {
  color: var(--text-muted);
}

.c360-files-crumb-current {
  color: var(--text-primary);
  font-weight: 600;
}

.c360-files-loading {
  font-size: var(--text-sm);
  color: var(--text-muted);
  font-style: italic;
  margin: var(--space-2) 0;
}

.c360-files-list-wrap {
  overflow-x: auto;
}

.c360-files-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.c360-files-table th {
  text-align: left;
  padding: var(--space-1) var(--space-2);
  color: var(--text-muted);
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 2px solid var(--border-color);
  white-space: nowrap;
}

.c360-files-table td {
  padding: var(--space-1) var(--space-2);
  border-bottom: 1px solid var(--border-color);
  vertical-align: middle;
  color: var(--text-primary);
}

.c360-files-row:hover td {
  background: var(--bg-light);
}

.c360-files-name {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.c360-files-icon {
  font-size: var(--text-sm);
  color: var(--text-muted);
  flex-shrink: 0;
}

.c360-files-icon-folder {
  color: var(--warning);
}

.c360-files-folder-btn {
  background: none;
  border: none;
  padding: 0;
  font-size: var(--text-sm);
  color: var(--primary);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-align: left;
}

.c360-files-folder-btn:hover {
  color: var(--primary-dark);
}

.c360-files-size,
.c360-files-date {
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  white-space: nowrap;
}

.c360-files-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.c360-files-dl-btn {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--bg-dark);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  transition: background 0.18s ease;
}

.c360-files-dl-btn:hover {
  background: var(--bg-light);
}

.c360-files-share-btn {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-2);
  color: var(--primary);
}

/* -------------------------------------------------------------------------
 * Share popup
 * ---------------------------------------------------------------------- */
.c360-share-popup {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-2);
  box-shadow: var(--shadow);
  margin-top: var(--space-1);
  flex-wrap: nowrap;
}

.c360-share-url-input {
  font-size: var(--text-xs);
  font-family: monospace;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: var(--space-1) var(--space-2);
  width: 220px;
  background: var(--bg-dark);
  color: var(--text-primary);
}

.c360-share-copy-btn,
.c360-share-close-btn {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-2);
  flex-shrink: 0;
}

.c360-share-close-btn {
  color: var(--text-muted);
}

/* -------------------------------------------------------------------------
 * Responsive
 * ---------------------------------------------------------------------- */
@media (max-width: 600px) {
  .c360-root {
    padding: var(--space-3);
  }
  .c360-grid {
    grid-template-columns: 1fr;
  }
  .c360-panel-docs,
  .c360-panel-digest {
    grid-column: span 1;
  }
}

/* ══ CRM redesign W4 — cockpit header + stat cards + dot-rail timeline ══════
   New atoms (avatar / stage chip / signal) come from crm-design.css. */

/* Cockpit header: avatar · identity · actions */
.c360-header {
  justify-content: flex-start;
  align-items: center;
}
.c360-avatar { flex: none; }            /* size from .crm-avatar-xl */
.c360-headmain { flex: 1; min-width: 0; }
.c360-titlerow {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.c360-titlerow .c360-company-name { margin-right: var(--space-1); }
.c360-meta {
  font-family: 'JetBrains Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Stat cards — each is a door to its tab */
.c360-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.c360-stat {
  background: var(--bg-card);
  border: 1px solid transparent;
  border-radius: var(--r-card);
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.c360-stat:hover {
  background: color-mix(in srgb, var(--bg-card) 82%, var(--bg-light));
  border-color: var(--border-soft);
}
.c360-stat:focus-visible {
  outline: 2px solid #93c5fd;
  outline-offset: 2px;
}
.c360-stat-label {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary);
}
.c360-stat-big {
  font-size: var(--text-lg);
  font-weight: 800;
  color: var(--text-primary);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
  line-height: 1.15;
}
.c360-stat.is-ok .c360-stat-big { color: var(--ok); }
.c360-stat-sub {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: 2px;
}

/* Dot-rail timeline */
.c360-timeline-row {
  position: relative;
  padding-bottom: var(--space-3);
}
.c360-timeline-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-pill);
  background: color-mix(in srgb, var(--primary) 18%, var(--bg-card));
  color: var(--primary);
  font-size: 11px;
  margin-top: 0;
  flex-shrink: 0;
  z-index: 1;
}
.c360-timeline-row::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 24px;
  bottom: -2px;
  width: 2px;
  background: var(--border-soft);
}
.c360-timeline-row:last-child::before { display: none; }

/* ── Tablet / phone: stats reflow, sticky compact header ──────────────────── */
@media (max-width: 1023px) {
  .c360-stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .c360-header {
    position: sticky;
    top: 0;
    z-index: 3;
    background: var(--bg-dark);
    padding-top: var(--space-3);
    flex-wrap: wrap;
  }
  .c360-header-actions { width: 100%; }
  .c360-compose-btn { flex: 1; min-height: var(--touch); }
  .c360-stat { padding: var(--space-2) var(--space-3); }
}
