/* TIGA OS — Cockpit primitives.

   All rules gated under [data-cockpit="on"] so the file is a no-op when
   the flag is off. Components use the .cock-* prefix to avoid clashes
   with the legacy classes in styles.css.

   Sections:
     1. Globals (selection, scrollbar, focus)
     2. Surfaces (glass, modal, popover, dropdown, divider)
     3. Typography (display scale, label-tiny, text utilities)
     4. KPI / metrics (kpi, tile, delta)
     5. Tabs / nav (pill-tabs, seg)
     6. Chips / status / badges
     7. Buttons
     8. Fields (input, select, textarea)
     9. Data display (data-row, table, empty, skeleton)
    10. Sparkline / atmospheric line
    11. Light-mode component overrides */

html[data-cockpit="on"] [data-num] {
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum' on, 'lnum' on;
}

/* ============================================================
   1 · GLOBALS
============================================================ */
html[data-cockpit="on"] body {
  font-feature-settings: 'kern', 'cv11';
  text-rendering: optimizeLegibility;
}

html[data-cockpit="on"] ::selection {
  background: var(--accent-soft);
  color: var(--text-display);
}

html[data-cockpit="on"] ::-webkit-scrollbar { width: 10px; height: 10px; }
html[data-cockpit="on"] ::-webkit-scrollbar-track { background: transparent; }
html[data-cockpit="on"] ::-webkit-scrollbar-thumb {
  background: var(--hairline-strong);
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: padding-box;
  transition: background-color var(--t-base) var(--ease-cockpit);
}
html[data-cockpit="on"] ::-webkit-scrollbar-thumb:hover {
  background: var(--hairline-bright);
  background-clip: padding-box;
  border: 3px solid transparent;
}

html[data-cockpit="on"] :where(.cock) :focus-visible,
html[data-cockpit="on"] :where([class*="cock-"]):focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-xs);
}

/* ============================================================
   2 · SURFACES
============================================================ */
html[data-cockpit="on"] .cock-surface {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
}
html[data-cockpit="on"] .cock-surface--hover {
  cursor: pointer;
  transition: border-color var(--t-base) var(--ease-cockpit), background var(--t-fast);
}
html[data-cockpit="on"] .cock-surface--hover:hover {
  border-color: var(--hairline-strong);
  background: var(--surface-2);
}
html[data-cockpit="on"] .cock-surface--hover.dragging,
html[data-cockpit="on"] .cock-surface--hover:active { opacity: .55; }

html[data-cockpit="on"] .cock-surface-2 {
  background: var(--surface-2);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-2);
}

html[data-cockpit="on"] .cock-glass,
html[data-cockpit="on"] .cock-glass-strong {
  position: relative;
  background: var(--surface-glass);
  -webkit-backdrop-filter: blur(var(--blur-glass)) saturate(1.4);
  backdrop-filter: blur(var(--blur-glass)) saturate(1.4);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-2);
}
html[data-cockpit="on"] .cock-glass-strong {
  background: var(--surface-glass-strong);
  -webkit-backdrop-filter: blur(var(--blur-overlay)) saturate(1.5);
  backdrop-filter: blur(var(--blur-overlay)) saturate(1.5);
  box-shadow: var(--shadow-3);
}
html[data-cockpit="on"] .cock-glass::before,
html[data-cockpit="on"] .cock-glass-strong::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: var(--inner-glow);
}

html[data-cockpit="on"] .cock-modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--surface-scrim);
  -webkit-backdrop-filter: blur(8px) saturate(1.1);
  backdrop-filter: blur(8px) saturate(1.1);
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  animation: cockFadeIn var(--t-base) var(--ease-cockpit);
}
@media (max-width: 639px) {
  html[data-cockpit="on"] .cock-modal-overlay { align-items: flex-end; padding: 0; }
  html[data-cockpit="on"] .cock-modal {
    max-width: 100%;
    width: 100%;
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    border-bottom: 0;
    max-height: 92vh;
  }
  html[data-cockpit="on"] .cock-modal--xl {
    border-radius: 0;
    max-height: 100vh;
    height: 100vh;
  }
}
html[data-cockpit="on"] .cock-modal__close {
  background: transparent;
  border: 0;
  width: 32px;
  height: 32px;
  border-radius: var(--r-pill);
  color: var(--text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-base) var(--ease-cockpit);
  font-family: inherit;
  flex-shrink: 0;
}
html[data-cockpit="on"] .cock-modal__close:hover {
  background: var(--interactive-hover);
  color: var(--text-display);
  transform: rotate(90deg);
}
html[data-cockpit="on"] .cock-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

html[data-cockpit="on"] .cock-modal {
  position: relative;
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-overlay);
  max-width: min(92vw, 720px);
  width: 100%;
  max-height: min(88vh, 760px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: cockModalIn var(--t-slow) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-modal--lg { max-width: min(94vw, 980px); }
html[data-cockpit="on"] .cock-modal--xl { max-width: min(96vw, 1280px); max-height: min(94vh, 920px); }

html[data-cockpit="on"] .cock-modal__head,
html[data-cockpit="on"] .cock-modal__foot {
  flex-shrink: 0;
  padding: 18px 24px;
  border-bottom: 1px solid var(--hairline);
}
html[data-cockpit="on"] .cock-modal__foot {
  border-top: 1px solid var(--hairline);
  border-bottom: 0;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
html[data-cockpit="on"] .cock-modal__body {
  flex: 1 1 auto;
  overflow: auto;
  padding: 24px;
}
html[data-cockpit="on"] .cock-modal__title {
  font-size: 20px;
  font-weight: var(--weight-display-strong);
  color: var(--text-display);
  letter-spacing: var(--tracking-display);
  margin: 0;
}

html[data-cockpit="on"] .cock-popover,
html[data-cockpit="on"] .cock-dropdown,
html[data-cockpit="on"] .cock-context {
  background: var(--surface-overlay);
  -webkit-backdrop-filter: blur(var(--blur-overlay)) saturate(1.4);
  backdrop-filter: blur(var(--blur-overlay)) saturate(1.4);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-overlay);
  padding: 6px;
  min-width: 200px;
  z-index: 60;
}
html[data-cockpit="on"] .cock-dropdown__item,
html[data-cockpit="on"] .cock-context__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: var(--r-sm);
  font-size: 13.5px;
  color: var(--text-secondary);
  cursor: pointer;
  user-select: none;
  transition: background var(--t-fast), color var(--t-fast);
}
html[data-cockpit="on"] .cock-dropdown__item:hover,
html[data-cockpit="on"] .cock-context__item:hover {
  background: var(--interactive-hover);
  color: var(--text-display);
}
html[data-cockpit="on"] .cock-dropdown__item--danger { color: var(--danger); }
html[data-cockpit="on"] .cock-dropdown__item--danger:hover { background: var(--danger-soft); color: var(--danger); }
html[data-cockpit="on"] .cock-dropdown__sep {
  height: 1px;
  background: var(--hairline);
  margin: 6px 4px;
}

html[data-cockpit="on"] .cock-divider {
  height: 1px;
  background: var(--hairline);
  border: 0;
  margin: 0;
}
html[data-cockpit="on"] .cock-divider--strong { background: var(--hairline-strong); }

/* ============================================================
   3 · TYPOGRAPHY
============================================================ */
html[data-cockpit="on"] .cock-display-xl,
html[data-cockpit="on"] .cock-display-lg,
html[data-cockpit="on"] .cock-display-md,
html[data-cockpit="on"] .cock-display-sm {
  font-family: var(--font-display);
  font-weight: var(--weight-display);
  letter-spacing: var(--tracking-display);
  color: var(--text-display);
  line-height: 1;
}
html[data-cockpit="on"] .cock-display-xl { font-size: clamp(48px, 7vw, 88px); }
html[data-cockpit="on"] .cock-display-lg { font-size: clamp(36px, 5vw, 64px); }
html[data-cockpit="on"] .cock-display-md { font-size: clamp(28px, 3.5vw, 44px); }
html[data-cockpit="on"] .cock-display-sm { font-size: clamp(22px, 2.5vw, 30px); }

html[data-cockpit="on"] .cock-section-title {
  font-size: 18px;
  font-weight: var(--weight-display-strong);
  color: var(--text-display);
  letter-spacing: var(--tracking-display);
  line-height: 1.25;
  margin: 0;
}
html[data-cockpit="on"] .cock-section-title--lg { font-size: 22px; }
/* Compact variant — column-internal headers, board headers (e.g. kanban member name).
   Sits between body-strong (13.5) and heading (18). On the type scale. */
html[data-cockpit="on"] .cock-section-title--sm {
  font-size: 14px;
  font-weight: var(--weight-body-strong);
  letter-spacing: 0;
  line-height: 1.2;
}

html[data-cockpit="on"] .cock-label-tiny {
  font-size: 10px;
  font-weight: var(--weight-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1;
}

html[data-cockpit="on"] .cock-text-primary   { color: var(--text-primary); }
html[data-cockpit="on"] .cock-text-secondary { color: var(--text-secondary); }
html[data-cockpit="on"] .cock-text-muted     { color: var(--text-muted); }
html[data-cockpit="on"] .cock-text-faint     { color: var(--text-faint); }
html[data-cockpit="on"] .cock-text-display   { color: var(--text-display); }
html[data-cockpit="on"] .cock-text-success   { color: var(--success); }
html[data-cockpit="on"] .cock-text-warning   { color: var(--warning); }
html[data-cockpit="on"] .cock-text-danger    { color: var(--danger); }
html[data-cockpit="on"] .cock-text-accent    { color: var(--accent); }

/* Solid background tokens — for filled dots, status pills, accent fills. */
html[data-cockpit="on"] .cock-bg-accent  { background: var(--accent); }
html[data-cockpit="on"] .cock-bg-success { background: var(--success); }
html[data-cockpit="on"] .cock-bg-warning { background: var(--warning); }
html[data-cockpit="on"] .cock-bg-danger  { background: var(--danger); }
html[data-cockpit="on"] .cock-bg-info    { background: var(--info); }
/* Soft tinted background helpers — match the matching cock-text-* token.
   Drop-in replacements for legacy bg-emerald-500/15, bg-red-500/15 etc. */
html[data-cockpit="on"] .cock-bg-success-soft { background: var(--success-soft); }
html[data-cockpit="on"] .cock-bg-warning-soft { background: var(--warning-soft); }
html[data-cockpit="on"] .cock-bg-danger-soft  { background: var(--danger-soft); }
html[data-cockpit="on"] .cock-bg-accent-soft  { background: var(--accent-soft); }
html[data-cockpit="on"] .cock-bg-info-soft    { background: var(--info-soft); }

/* ============================================================
   ICON HELPERS (Design System v1 §2.1)
   Pin sizes to the 5-step scale. Use these instead of ad-hoc
   `width="14"` etc. so icons stay consistent across the OS.
============================================================ */
html[data-cockpit="on"] .cock-icon-xs { width: var(--icon-xs); height: var(--icon-xs); flex-shrink: 0; }
html[data-cockpit="on"] .cock-icon-sm { width: var(--icon-sm); height: var(--icon-sm); flex-shrink: 0; }
html[data-cockpit="on"] .cock-icon-md { width: var(--icon-md); height: var(--icon-md); flex-shrink: 0; }
html[data-cockpit="on"] .cock-icon-lg { width: var(--icon-lg); height: var(--icon-lg); flex-shrink: 0; }
html[data-cockpit="on"] .cock-icon-xl { width: var(--icon-xl); height: var(--icon-xl); flex-shrink: 0; }
/* Round icon container — accent-soft + accent icon. The default for
   "feature highlight" SVG framings (Karriereportal teaser, etc). */
html[data-cockpit="on"] .cock-icon-frame {
  width: 36px;
  height: 36px;
  border-radius: var(--r-pill);
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
html[data-cockpit="on"] .cock-icon-frame--lg { width: 44px; height: 44px; }
html[data-cockpit="on"] .cock-icon-frame--square { border-radius: var(--r-md); }

/* ============================================================
   ILLUSTRATION SLOT
   Wrapper for empty-state SVGs / decorative illustrations.
   Constrains size + ensures consistent muted tint.
============================================================ */
html[data-cockpit="on"] .cock-illustration {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-faint);
  width: 96px;
  height: 96px;
  margin: 0 auto;
}
html[data-cockpit="on"] .cock-illustration--sm { width: 64px; height: 64px; }
html[data-cockpit="on"] .cock-illustration--lg { width: 128px; height: 128px; }
html[data-cockpit="on"] .cock-illustration svg { width: 100%; height: 100%; }

/* ============================================================
   METER (progress bar) — Auswertung funnel rows + similar
============================================================ */
html[data-cockpit="on"] .cock-meter {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
html[data-cockpit="on"] .cock-meter__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
}
html[data-cockpit="on"] .cock-meter__label {
  font-size: 13px;
  font-weight: var(--weight-body);
  color: var(--text-secondary);
}
html[data-cockpit="on"] .cock-meter__value {
  font-size: 16px;
  font-weight: var(--weight-display-strong);
  font-variant-numeric: tabular-nums;
  color: var(--text-display);
}
html[data-cockpit="on"] .cock-meter__bar {
  position: relative;
  height: 6px;
  border-radius: var(--r-pill);
  background: var(--interactive);
  overflow: hidden;
}
html[data-cockpit="on"] .cock-meter__fill {
  position: absolute;
  inset: 0 auto 0 0;
  border-radius: var(--r-pill);
  background: var(--accent);
  transform-origin: left center;
  transition: width var(--t-smooth) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-meter__fill--success { background: var(--success); }
html[data-cockpit="on"] .cock-meter__fill--warning { background: var(--warning); }
html[data-cockpit="on"] .cock-meter__fill--danger  { background: var(--danger); }

/* ============================================================
   STAT-ROW — Compact label/value pair, right-aligned value
============================================================ */
html[data-cockpit="on"] .cock-stat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-2) 0;
  font-size: 13px;
}
html[data-cockpit="on"] .cock-stat-row__label { color: var(--text-secondary); }
html[data-cockpit="on"] .cock-stat-row__value {
  color: var(--text-display);
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
}
html[data-cockpit="on"] .cock-stat-row + .cock-stat-row { border-top: 1px solid var(--hairline); }

/* ============================================================
   DIVIDER-SECTION — Horizontal divider with optional centered label
   Used to break a card into labeled sub-sections without a heavy header.
============================================================ */
html[data-cockpit="on"] .cock-divider-section {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin: var(--s-5) 0;
}
html[data-cockpit="on"] .cock-divider-section::before,
html[data-cockpit="on"] .cock-divider-section::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--hairline);
}
html[data-cockpit="on"] .cock-divider-section__label {
  font-size: 10px;
  font-weight: var(--weight-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}

/* ── Auswertung map (applicant heatmap) ──
   Custom Leaflet div-icon styles. Pop-in animation on each pin. */
.aw-hq-marker, .aw-applicant-marker {
  background: transparent !important;
  border: 0 !important;
}
.aw-hq-pin {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.05em;
  box-shadow: 0 2px 12px rgba(0,0,0,.4), 0 0 0 3px rgba(255,255,255,.95);
  position: absolute;
  top: 2px;
  left: 2px;
  font-family: 'Montserrat', sans-serif;
  z-index: 2;
}
.aw-hq-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.45;
  animation: aw-hq-pulse 2.4s ease-out infinite;
  z-index: 1;
}
@keyframes aw-hq-pulse {
  0% { transform: scale(0.8); opacity: 0.55; }
  100% { transform: scale(2.2); opacity: 0; }
}
.aw-applicant-pin {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--success);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.02em;
  box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92);
  font-family: 'Montserrat', sans-serif;
  animation: aw-pin-pop 0.45s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes aw-pin-pop {
  0%   { transform: scale(0) translateY(-12px); opacity: 0; }
  60%  { transform: scale(1.15) translateY(0); opacity: 1; }
  100% { transform: scale(1) translateY(0); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .aw-hq-pulse { animation: none; opacity: 0.3; }
  .aw-applicant-pin { animation: none; }
}

/* Border helpers */
html[data-cockpit="on"] .cock-border-accent  { border-color: var(--accent); }
html[data-cockpit="on"] .cock-border-success { border-color: var(--success); }
html[data-cockpit="on"] .cock-border-warning { border-color: var(--warning); }
html[data-cockpit="on"] .cock-border-danger  { border-color: var(--danger); }
html[data-cockpit="on"] .cock-border-hairline { border-color: var(--hairline); }
html[data-cockpit="on"] .cock-border-hairline-strong { border-color: var(--hairline-strong); }

/* ============================================================
   4 · KPI / METRICS
============================================================ */
html[data-cockpit="on"] .cock-kpi {
  display: flex;
  align-items: baseline;
  gap: 0.35em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum' on, 'lnum' on;
}
html[data-cockpit="on"] .cock-kpi__value {
  font-size: clamp(40px, 5.5vw, 72px);
  font-weight: var(--weight-display);
  letter-spacing: var(--tracking-display);
  color: var(--text-display);
  line-height: 1;
}
/* the dimmed continuation, e.g. "142,580" → "580" inside <em> */
html[data-cockpit="on"] .cock-kpi__value em {
  font-style: normal;
  color: var(--text-muted);
}
html[data-cockpit="on"] .cock-kpi__suffix {
  font-size: 0.42em;
  color: var(--text-muted);
  font-weight: var(--weight-body);
  letter-spacing: 0;
  align-self: baseline;
}
html[data-cockpit="on"] .cock-kpi__delta {
  font-size: 0.32em;
  font-weight: var(--weight-body-strong);
  letter-spacing: 0;
  padding: 4px 8px;
  border-radius: var(--r-pill);
  align-self: baseline;
}
html[data-cockpit="on"] .cock-kpi__delta--up   { color: var(--success); background: var(--success-soft); }
html[data-cockpit="on"] .cock-kpi__delta--down { color: var(--warning); background: var(--warning-soft); }
html[data-cockpit="on"] .cock-kpi__delta--flat { color: var(--text-muted); background: var(--interactive); }

html[data-cockpit="on"] .cock-tile {
  position: relative;
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 120px;
  transition: border-color var(--t-base) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-tile:hover {
  border-color: var(--hairline-strong);
}
html[data-cockpit="on"] .cock-tile__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
html[data-cockpit="on"] .cock-tile__label {
  font-size: 12px;
  color: var(--text-secondary);
  font-weight: var(--weight-label);
}
html[data-cockpit="on"] .cock-tile__value {
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: var(--weight-display);
  color: var(--text-display);
  letter-spacing: var(--tracking-display);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
html[data-cockpit="on"] .cock-tile__sub {
  font-size: 10px;
  font-weight: var(--weight-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
}

html[data-cockpit="on"] .cock-delta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
  padding: 3px 8px;
  border-radius: var(--r-pill);
}
html[data-cockpit="on"] .cock-delta--up   { color: var(--success); background: var(--success-soft); }
html[data-cockpit="on"] .cock-delta--down { color: var(--warning); background: var(--warning-soft); }
html[data-cockpit="on"] .cock-delta--neg  { color: var(--danger);  background: var(--danger-soft); }
html[data-cockpit="on"] .cock-delta--flat { color: var(--text-muted); background: var(--interactive); }

/* ============================================================
   5 · TABS / NAV
============================================================ */
html[data-cockpit="on"] .cock-tabs {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 4px;
  background: var(--interactive);
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}
html[data-cockpit="on"] .cock-tabs::-webkit-scrollbar { display: none; }
html[data-cockpit="on"] .cock-tab {
  flex-shrink: 0;
  padding: 8px 18px;
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: var(--weight-label);
  color: var(--text-secondary);
  background: transparent;
  border: 0;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition: color var(--t-fast), background var(--t-base) var(--ease-cockpit);
  font-family: inherit;
  white-space: nowrap;
}
html[data-cockpit="on"] .cock-tab:hover { color: var(--text-display); }
html[data-cockpit="on"] .cock-tab[aria-selected="true"],
html[data-cockpit="on"] .cock-tab.is-active {
  background: var(--pill-active-bg);
  color: var(--pill-active-fg);
}
html[data-cockpit="on"] .cock-tab__count {
  margin-left: 6px;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  opacity: 0.65;
}

html[data-cockpit="on"] .cock-seg {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: var(--surface-1);
  overflow: hidden;
}
html[data-cockpit="on"] .cock-seg__btn {
  padding: 8px 14px;
  font-size: 13px;
  font-weight: var(--weight-label);
  color: var(--text-secondary);
  background: transparent;
  border: 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: color var(--t-fast), background var(--t-fast);
  font-family: inherit;
}
html[data-cockpit="on"] .cock-seg__btn + .cock-seg__btn { border-left: 1px solid var(--hairline); }
html[data-cockpit="on"] .cock-seg__btn:hover { color: var(--text-display); background: var(--interactive-hover); }
html[data-cockpit="on"] .cock-seg__btn.is-active { color: var(--text-display); background: var(--interactive-active); }

/* ============================================================
   6 · CHIPS / STATUS / BADGES
============================================================ */
html[data-cockpit="on"] .cock-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: var(--interactive);
  border: 1px solid var(--hairline);
  font-size: 12px;
  font-weight: var(--weight-label);
  color: var(--text-secondary);
  white-space: nowrap;
  line-height: 1.4;
}
html[data-cockpit="on"] .cock-chip svg { width: 12px; height: 12px; flex-shrink: 0; }
html[data-cockpit="on"] .cock-chip--accent  { color: var(--accent);  background: var(--accent-soft);  border-color: transparent; }
html[data-cockpit="on"] .cock-chip--success { color: var(--success); background: var(--success-soft); border-color: transparent; }
html[data-cockpit="on"] .cock-chip--warning { color: var(--warning); background: var(--warning-soft); border-color: transparent; }
html[data-cockpit="on"] .cock-chip--danger  { color: var(--danger);  background: var(--danger-soft);  border-color: transparent; }
html[data-cockpit="on"] .cock-chip--ghost   { background: transparent; }
html[data-cockpit="on"] .cock-chip--lg { font-size: 13px; padding: 6px 14px; }

html[data-cockpit="on"] .cock-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--text-muted);
  flex-shrink: 0;
}
html[data-cockpit="on"] .cock-dot--success { background: var(--success); }
html[data-cockpit="on"] .cock-dot--warning { background: var(--warning); }
html[data-cockpit="on"] .cock-dot--danger  { background: var(--danger); }
html[data-cockpit="on"] .cock-dot--accent  { background: var(--accent); }
html[data-cockpit="on"] .cock-dot--idle    { background: var(--text-faint); }
html[data-cockpit="on"] .cock-dot--pulse {
  position: relative;
  box-shadow: 0 0 0 0 currentColor;
  animation: cockPulse 2s var(--ease-cockpit) infinite;
}
html[data-cockpit="on"] .cock-dot--pulse.cock-dot--success { color: var(--success); }
html[data-cockpit="on"] .cock-dot--pulse.cock-dot--warning { color: var(--warning); }
html[data-cockpit="on"] .cock-dot--pulse.cock-dot--danger  { color: var(--danger);  }

html[data-cockpit="on"] .cock-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: var(--r-pill);
  font-size: 10px;
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
  background: var(--danger);
  color: #fff;
  line-height: 1;
}
html[data-cockpit="on"] .cock-badge--accent  { background: var(--accent); }
html[data-cockpit="on"] .cock-badge--success { background: var(--success); }
html[data-cockpit="on"] .cock-badge--warning { background: var(--warning); }
html[data-cockpit="on"] .cock-badge--ghost   { background: var(--interactive); color: var(--text-secondary); }

/* ============================================================
   7 · BUTTONS
============================================================ */
html[data-cockpit="on"] .cock-btn,
html[data-cockpit="on"] .cock-btn-primary,
html[data-cockpit="on"] .cock-btn-ghost,
html[data-cockpit="on"] .cock-btn-danger,
html[data-cockpit="on"] .cock-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 18px;
  font-size: 13.5px;
  font-weight: var(--weight-body-strong);
  font-family: inherit;
  border-radius: var(--r-md);
  border: 1px solid transparent;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  white-space: nowrap;
  transition: background var(--t-fast),
              color var(--t-fast),
              border-color var(--t-fast),
              box-shadow var(--t-base) var(--ease-cockpit),
              transform var(--t-fast) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-btn:active,
html[data-cockpit="on"] .cock-btn-primary:active,
html[data-cockpit="on"] .cock-btn-ghost:active,
html[data-cockpit="on"] .cock-btn-danger:active,
html[data-cockpit="on"] .cock-btn-icon:active { transform: translateY(1px) scale(.985); }

html[data-cockpit="on"] .cock-btn-primary {
  background: var(--accent);
  color: var(--text-on-accent);
}
html[data-cockpit="on"] .cock-btn-primary:hover {
  filter: brightness(1.08);
  box-shadow: 0 6px 20px -6px var(--accent-glow);
}

html[data-cockpit="on"] .cock-btn,
html[data-cockpit="on"] .cock-btn-ghost {
  background: var(--interactive);
  border-color: var(--hairline);
  color: var(--text-primary);
}
html[data-cockpit="on"] .cock-btn:hover,
html[data-cockpit="on"] .cock-btn-ghost:hover {
  background: var(--interactive-hover);
  border-color: var(--hairline-strong);
  color: var(--text-display);
}

html[data-cockpit="on"] .cock-btn-danger {
  background: var(--danger);
  color: #fff;
}
html[data-cockpit="on"] .cock-btn-danger:hover { filter: brightness(1.05); }

html[data-cockpit="on"] .cock-btn-icon {
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: var(--r-pill);
  background: var(--interactive);
  border-color: var(--hairline);
  color: var(--text-secondary);
  flex-shrink: 0;
}
html[data-cockpit="on"] .cock-btn-icon:hover {
  background: var(--interactive-hover);
  color: var(--text-display);
  border-color: var(--hairline-strong);
}
html[data-cockpit="on"] .cock-btn-icon svg { width: 16px; height: 16px; }

html[data-cockpit="on"] .cock-btn-sm {
  padding: 6px 12px;
  font-size: 12.5px;
  border-radius: var(--r-sm);
}
html[data-cockpit="on"] .cock-btn-icon.cock-btn-sm { width: 28px; height: 28px; padding: 0; }
html[data-cockpit="on"] .cock-btn-icon.cock-btn-sm svg { width: 14px; height: 14px; }

html[data-cockpit="on"] .cock-btn-lg { padding: 13px 22px; font-size: 15px; }

html[data-cockpit="on"] :where(.cock-btn,.cock-btn-primary,.cock-btn-ghost,.cock-btn-danger,.cock-btn-icon)[disabled],
html[data-cockpit="on"] :where(.cock-btn,.cock-btn-primary,.cock-btn-ghost,.cock-btn-danger,.cock-btn-icon).is-disabled {
  opacity: .45;
  pointer-events: none;
  cursor: not-allowed;
}

/* ============================================================
   8 · FIELDS
============================================================ */
html[data-cockpit="on"] .cock-field { display: flex; flex-direction: column; gap: 6px; }

html[data-cockpit="on"] .cock-label {
  font-size: 12px;
  font-weight: var(--weight-label);
  color: var(--text-secondary);
  letter-spacing: 0.01em;
}
html[data-cockpit="on"] .cock-label--required::after {
  content: '*';
  color: var(--danger);
  margin-left: 4px;
}

html[data-cockpit="on"] .cock-input,
html[data-cockpit="on"] .cock-select,
html[data-cockpit="on"] .cock-textarea {
  width: 100%;
  padding: 10px 14px;
  background: var(--field-bg);
  border: 1px solid var(--field-border);
  border-radius: var(--r-md);
  color: var(--text-primary);
  font-size: 14px;
  font-weight: var(--weight-body);
  font-family: inherit;
  transition: border-color var(--t-fast),
              background var(--t-fast),
              box-shadow var(--t-fast);
  -webkit-appearance: none;
  appearance: none;
}
html[data-cockpit="on"] .cock-input::placeholder,
html[data-cockpit="on"] .cock-textarea::placeholder { color: var(--text-faint); }
html[data-cockpit="on"] .cock-input:hover,
html[data-cockpit="on"] .cock-select:hover,
html[data-cockpit="on"] .cock-textarea:hover {
  background: var(--field-bg-hover);
  border-color: var(--hairline-bright);
}
html[data-cockpit="on"] .cock-input:focus,
html[data-cockpit="on"] .cock-select:focus,
html[data-cockpit="on"] .cock-textarea:focus {
  outline: 0;
  border-color: var(--field-border-focus);
  box-shadow: var(--field-ring-focus);
  background: var(--field-bg-hover);
}

html[data-cockpit="on"] .cock-textarea {
  min-height: 96px;
  resize: vertical;
  line-height: 1.5;
}

html[data-cockpit="on"] .cock-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%239BA0A8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 6 8 10 12 6'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
  padding-right: 36px;
  cursor: pointer;
}

html[data-cockpit="on"] .cock-input--sm,
html[data-cockpit="on"] .cock-select--sm { padding: 6px 12px; font-size: 13px; border-radius: var(--r-sm); }

html[data-cockpit="on"] .cock-field--error .cock-input,
html[data-cockpit="on"] .cock-field--error .cock-select,
html[data-cockpit="on"] .cock-field--error .cock-textarea {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px var(--danger-soft);
}
html[data-cockpit="on"] .cock-field__error {
  font-size: 12px;
  color: var(--danger);
  font-weight: var(--weight-label);
}
html[data-cockpit="on"] .cock-field__hint {
  font-size: 12px;
  color: var(--text-muted);
}

html[data-cockpit="on"] .cock-input-group {
  position: relative;
  display: flex;
  align-items: center;
}
html[data-cockpit="on"] .cock-input-group__icon {
  position: absolute;
  left: 12px;
  color: var(--text-muted);
  pointer-events: none;
  display: flex;
}
html[data-cockpit="on"] .cock-input-group__icon svg { width: 16px; height: 16px; }
html[data-cockpit="on"] .cock-input-group .cock-input { padding-left: 38px; }

/* Search input — leading icon, pill rounded, glass-like */
html[data-cockpit="on"] .cock-search {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--interactive);
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  color: var(--text-secondary);
  font-size: 13.5px;
  font-family: inherit;
  width: 320px;
  max-width: 100%;
  transition: background var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
}
html[data-cockpit="on"] .cock-search:focus-within {
  background: var(--interactive-hover);
  border-color: var(--accent);
  box-shadow: var(--field-ring-focus);
  color: var(--text-display);
}
html[data-cockpit="on"] .cock-search input {
  background: transparent;
  border: 0;
  outline: 0;
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  flex: 1;
  min-width: 0;
}
html[data-cockpit="on"] .cock-search input::placeholder { color: var(--text-faint); }

html[data-cockpit="on"] .cock-checkbox,
html[data-cockpit="on"] .cock-radio {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}

/* Switch */
html[data-cockpit="on"] .cock-switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
  flex-shrink: 0;
}
html[data-cockpit="on"] .cock-switch input { opacity: 0; width: 0; height: 0; }
html[data-cockpit="on"] .cock-switch__track {
  position: absolute;
  inset: 0;
  background: var(--interactive-active);
  border-radius: var(--r-pill);
  transition: background var(--t-base) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-switch__track::before {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  transition: transform var(--t-base) var(--ease-cockpit);
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
html[data-cockpit="on"] .cock-switch input:checked + .cock-switch__track { background: var(--accent); }
html[data-cockpit="on"] .cock-switch input:checked + .cock-switch__track::before { transform: translateX(16px); }

/* ============================================================
   9 · DATA DISPLAY
============================================================ */
html[data-cockpit="on"] .cock-data-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 14px 16px;
  border-radius: var(--r-md);
  border: 1px solid transparent;
  transition: background var(--t-fast), border-color var(--t-fast);
}
html[data-cockpit="on"] .cock-data-row + .cock-data-row { margin-top: 4px; }
html[data-cockpit="on"] .cock-data-row:hover {
  background: var(--interactive-hover);
  border-color: var(--hairline);
}
html[data-cockpit="on"] .cock-data-row__title {
  font-size: 14px;
  font-weight: var(--weight-body-strong);
  color: var(--text-primary);
  line-height: 1.3;
  word-break: break-word;
}
html[data-cockpit="on"] .cock-data-row__sub {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

html[data-cockpit="on"] .cock-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-variant-numeric: tabular-nums;
}
html[data-cockpit="on"] .cock-table thead th {
  text-align: left;
  font-size: 11px;
  font-weight: var(--weight-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 12px 14px;
  border-bottom: 1px solid var(--hairline);
  white-space: nowrap;
  background: transparent;
}
html[data-cockpit="on"] .cock-table tbody td {
  padding: 14px;
  font-size: 13.5px;
  color: var(--text-primary);
  border-bottom: 1px solid var(--hairline);
  vertical-align: middle;
}
html[data-cockpit="on"] .cock-table tbody tr:last-child td { border-bottom: 0; }
html[data-cockpit="on"] .cock-table tbody tr:hover td { background: var(--interactive-hover); }
html[data-cockpit="on"] .cock-table.cock-table--clickable tbody tr { cursor: pointer; }

html[data-cockpit="on"] .cock-empty {
  text-align: center;
  padding: 56px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
html[data-cockpit="on"] .cock-empty__icon {
  width: 44px;
  height: 44px;
  color: var(--text-faint);
  margin-bottom: 4px;
  opacity: .85;
}
html[data-cockpit="on"] .cock-empty__title {
  font-size: 16px;
  font-weight: var(--weight-body-strong);
  color: var(--text-secondary);
}
html[data-cockpit="on"] .cock-empty__sub {
  font-size: 13px;
  color: var(--text-muted);
  max-width: 380px;
}

html[data-cockpit="on"] .cock-skel {
  position: relative;
  overflow: hidden;
  background: var(--interactive);
  border-radius: var(--r-sm);
}
html[data-cockpit="on"] .cock-skel::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--surface-glass-strong), transparent);
  animation: cockShimmer 1.4s linear infinite;
}

/* ============================================================
   10 · SPARKLINE / ATMOSPHERIC LINE
============================================================ */
html[data-cockpit="on"] .cock-line {
  position: relative;
  width: 100%;
  height: 64px;
}
html[data-cockpit="on"] .cock-line svg { width: 100%; height: 100%; display: block; overflow: visible; }
html[data-cockpit="on"] .cock-line path { fill: none; stroke-width: 1.25; stroke-linejoin: round; stroke-linecap: round; }
html[data-cockpit="on"] .cock-line .cock-line__main      { stroke: var(--text-display); opacity: .85; }
html[data-cockpit="on"] .cock-line .cock-line__bg        { stroke: var(--text-muted); opacity: .25; stroke-width: 1; }
html[data-cockpit="on"] .cock-line .cock-line__warn      { stroke: var(--warning); opacity: .9; stroke-width: 1.5; }
html[data-cockpit="on"] .cock-line .cock-line__fill      { fill: var(--text-display); opacity: .04; stroke: none; }
html[data-cockpit="on"] .cock-line .cock-line__grid      { stroke: var(--hairline); stroke-dasharray: 2 4; stroke-width: 1; }
html[data-cockpit="on"] .cock-line .cock-line__dot       { fill: var(--text-display); }
html[data-cockpit="on"] .cock-line .cock-line__dot--warn { fill: var(--warning); }
html[data-cockpit="on"] .cock-line .cock-line__axis      { fill: var(--text-faint); font-size: 10px; font-feature-settings: 'tnum' 1; }

/* HTML overlays — stay un-stretched even when the SVG uses
   preserveAspectRatio="none" to make the line span the full container. */
html[data-cockpit="on"] .cock-line__hdot {
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--text-display);
  transform: translate(-50%, -50%);
  pointer-events: none;
  box-shadow: 0 0 0 3px var(--surface-1);
}
html[data-cockpit="on"] .cock-line__hdot--warn { background: var(--warning); }
html[data-cockpit="on"] .cock-line__hlabels {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}
html[data-cockpit="on"] .cock-line__hlabel {
  font-size: 10px;
  color: var(--text-faint);
  font-feature-settings: 'tnum' 1;
  letter-spacing: 0.02em;
  white-space: nowrap;
  line-height: 1;
}
html[data-cockpit="on"] .cock-line__hy {
  position: absolute;
  right: 2px;
  font-size: 10px;
  color: var(--text-faint);
  font-feature-settings: 'tnum' 1;
  transform: translateY(-50%);
  pointer-events: none;
  padding: 0 2px;
  background: var(--surface-1);
  border-radius: 2px;
}

/* ---------- Task card (checkable item with title + pill + meta) ----------
   Default: subtle elevated surface so each task reads as a quiet card.
   The intent is "list of cards" not "decorated list rows". */
html[data-cockpit="on"] .cock-task {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 12px;
  background: var(--surface-2);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  transition: background var(--t-fast) var(--ease-cockpit), border-color var(--t-fast);
  position: relative;
}
html[data-cockpit="on"] .cock-task:hover {
  background: var(--surface-3);
  border-color: var(--hairline-strong);
}
html[data-cockpit="on"] .cock-task--done { opacity: .45; }
html[data-cockpit="on"] .cock-task--done:hover { background: transparent; border-color: transparent; }
html[data-cockpit="on"] .cock-task__check { margin-top: 2px; flex-shrink: 0; }
html[data-cockpit="on"] .cock-task__body { flex: 1 1 auto; min-width: 0; }
html[data-cockpit="on"] .cock-task__title {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 13.5px;
  font-weight: var(--weight-body-strong);
  color: var(--text-primary);
  line-height: 1.35;
  word-break: break-word;
}
html[data-cockpit="on"] .cock-task--done .cock-task__title { text-decoration: line-through; }
html[data-cockpit="on"] .cock-task__sub {
  font-size: 12px;
  color: var(--success);
  margin-top: 4px;
  font-feature-settings: 'tnum' 1;
}
html[data-cockpit="on"] .cock-task__chips {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  flex-wrap: wrap;
}
/* Glance-card layout (used by Team Board kanban):
   title row with right-aligned pill, and a single muted meta line below.
   Goal: every card is the same height so columns scan as a list. */
html[data-cockpit="on"] .cock-task__head {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  width: 100%;
}
html[data-cockpit="on"] .cock-task__title-text {
  flex: 1;
  min-width: 0;
  font-size: 13.5px;
  font-weight: var(--weight-body-strong);
  color: var(--text-primary);
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
html[data-cockpit="on"] .cock-task--done .cock-task__title-text { text-decoration: line-through; }
html[data-cockpit="on"] .cock-task__pill {
  flex-shrink: 0;
  font-size: 10.5px;
  font-weight: var(--weight-label);
  letter-spacing: 0.02em;
  padding: 3px 8px;
  border-radius: var(--r-pill);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
html[data-cockpit="on"] .cock-task__pill--danger  { background: var(--danger-soft);  color: var(--danger); }
html[data-cockpit="on"] .cock-task__pill--warning { background: var(--warning-soft); color: var(--warning); }
html[data-cockpit="on"] .cock-task__pill--subtle  { background: var(--interactive); color: var(--text-secondary); }
html[data-cockpit="on"] .cock-task__pill--accent  { background: var(--accent-soft);  color: var(--accent); }
html[data-cockpit="on"] .cock-task__meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: var(--s-1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Column foldout (paused tasks at column bottom) */
html[data-cockpit="on"] .cock-col-foldout {
  margin-top: var(--s-2);
  border-top: 1px solid var(--hairline);
  padding-top: var(--s-3);
}
html[data-cockpit="on"] .cock-col-foldout__toggle {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  width: 100%;
  background: transparent;
  border: 0;
  padding: var(--s-2) var(--s-3);
  font-family: inherit;
  font-size: 11.5px;
  letter-spacing: 0.02em;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--r-sm);
  transition: background var(--t-fast) var(--ease-cockpit), color var(--t-fast);
  text-align: left;
}
html[data-cockpit="on"] .cock-col-foldout__toggle:hover {
  background: var(--interactive-hover);
  color: var(--text-secondary);
}
html[data-cockpit="on"] .cock-col-foldout__caret {
  font-size: 10px;
  transition: transform var(--t-fast) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-col-foldout[data-open="true"] .cock-col-foldout__caret {
  transform: rotate(90deg);
}
html[data-cockpit="on"] .cock-col-foldout__body {
  display: none;
  margin-top: var(--s-2);
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
}
html[data-cockpit="on"] .cock-col-foldout:not([data-open="true"]) .cock-col-foldout__body {
  display: none;
}
html[data-cockpit="on"] .cock-task__action {
  flex-shrink: 0;
  color: var(--text-muted);
  opacity: 0;
  transition: opacity var(--t-fast);
  display: flex;
  align-self: center;
}
html[data-cockpit="on"] .cock-task:hover .cock-task__action { opacity: .65; }
@media (max-width: 1023px) {
  html[data-cockpit="on"] .cock-task__action { opacity: .35; }
}

/* ---------- Sidebar nav item ---------- */
html[data-cockpit="on"] .cock-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 9px 12px;
  border-radius: var(--r-md);
  font-size: 13.5px;
  font-weight: var(--weight-label);
  font-family: inherit;
  color: var(--text-secondary);
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  transition: background var(--t-fast), color var(--t-fast);
  -webkit-tap-highlight-color: transparent;
}
html[data-cockpit="on"] .cock-nav-item:hover {
  background: var(--interactive-hover);
  color: var(--text-display);
}
html[data-cockpit="on"] .cock-nav-item.is-active {
  background: var(--accent-soft);
  color: var(--accent);
}
html[data-cockpit="on"] .cock-nav-item.is-active::before {
  content: '';
  position: absolute;
  left: -1px;
  top: 25%;
  bottom: 25%;
  width: 3px;
  border-radius: 0 2px 2px 0;
  background: var(--accent);
}
html[data-cockpit="on"] .cock-nav-item { position: relative; }
html[data-cockpit="on"] .cock-nav-item--sm {
  padding: 7px 12px;
  font-size: 12px;
  color: var(--text-muted);
}
html[data-cockpit="on"] .cock-nav-item--sm:hover { color: var(--text-secondary); }
html[data-cockpit="on"] .cock-nav-item--sm.is-active {
  background: var(--interactive-active);
  color: var(--text-primary);
}
html[data-cockpit="on"] .cock-nav-item--sm.is-active::before { display: none; }
html[data-cockpit="on"] .cock-nav-item__icon { display: flex; flex-shrink: 0; }
html[data-cockpit="on"] .cock-nav-item__icon svg { width: 16px; height: 16px; }
html[data-cockpit="on"] .cock-nav-item__label { flex: 1; min-width: 0; }

/* ---------- Section head (title + meta) ---------- */
html[data-cockpit="on"] .cock-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}
html[data-cockpit="on"] .cock-section-head__meta {
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ============================================================
   ANIMATIONS
============================================================ */
@keyframes cockFadeIn  { from { opacity: 0; } to { opacity: 1; } }
@keyframes cockModalIn { from { opacity: 0; transform: translateY(8px) scale(.985); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes cockShimmer { from { transform: translateX(-100%); } to { transform: translateX(100%); } }
@keyframes cockPulse {
  0%   { box-shadow: 0 0 0 0 currentColor; opacity: 1; }
  70%  { box-shadow: 0 0 0 8px transparent; opacity: .9; }
  100% { box-shadow: 0 0 0 0 transparent; opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  html[data-cockpit="on"] .cock-modal,
  html[data-cockpit="on"] .cock-modal-overlay,
  html[data-cockpit="on"] .cock-skel::after,
  html[data-cockpit="on"] .cock-dot--pulse { animation: none; }
}

/* ============================================================
   11 · LIGHT-MODE COMPONENT OVERRIDES
   Most components inherit the light identity from tokens.css.
   These selectors patch the few cases where dark assumptions
   leak through (hard-to-read on white). */
============================================================ */
html[data-cockpit="on"][data-theme="light"] .cock-glass,
html[data-cockpit="on"] body.theme-light .cock-glass {
  -webkit-backdrop-filter: blur(var(--blur-glass)) saturate(1.1);
  backdrop-filter: blur(var(--blur-glass)) saturate(1.1);
}

html[data-cockpit="on"][data-theme="light"] .cock-select,
html[data-cockpit="on"] body.theme-light .cock-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%235A5E66' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 6 8 10 12 6'/></svg>");
}

html[data-cockpit="on"][data-theme="light"] .cock-switch__track::before,
html[data-cockpit="on"] body.theme-light .cock-switch__track::before {
  box-shadow: 0 1px 2px rgba(15,16,21,.18);
}

html[data-cockpit="on"][data-theme="light"] .cock-line .cock-line__main,
html[data-cockpit="on"] body.theme-light .cock-line .cock-line__main {
  opacity: 1;
  stroke-width: 1.5;
}
html[data-cockpit="on"][data-theme="light"] .cock-line .cock-line__bg,
html[data-cockpit="on"] body.theme-light .cock-line .cock-line__bg {
  opacity: .35;
}
html[data-cockpit="on"][data-theme="light"] .cock-line .cock-line__fill,
html[data-cockpit="on"] body.theme-light .cock-line .cock-line__fill {
  opacity: .06;
}
