/* 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 {
  /* border-box is critical — without it, padding+border on the logo variant
     would push total size past 40px, offsetting the pin from the pulse center. */
  box-sizing: border-box;
  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;
  overflow: hidden;
}
/* Logo variant — when the customer has an uploaded logo, render it inside the
   pin on a clean white disc instead of the accent-colored initial. The accent
   halo stays (pulse animation) but moves to a ring around the white disc.
   box-sizing inherited from .aw-hq-pin keeps it exactly 40×40 with padding+border
   accounted for, so its center aligns with the marker's iconAnchor at (20,20). */
.aw-hq-pin--logo {
  background: #fff;
  border: 2px solid var(--accent);
  padding: 4px;
  width: 40px;
  height: 40px;
  top: 0;
  left: 0;
  box-shadow: 0 2px 12px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.6);
}
.aw-hq-pin--logo svg,
.aw-hq-pin--logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  /* Logo keeps its original brand colors on the white disc — readable on
     light + dark map tiles since the disc itself is white. */
  filter: none !important;
}
.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;
}
/* Layered pulses — staggered start times create a continuous radar feel.
   Pulse-2 fires 0.8s after pulse-1, pulse-3 fires another 0.8s after that,
   so there's always a ring expanding outward. */
.aw-hq-pulse--2 {
  animation-delay: 0.8s;
  opacity: 0.32;
}
.aw-hq-pulse--3 {
  animation-delay: 1.6s;
  opacity: 0.22;
}
/* Burst — one-shot dramatic ring fired on entrance. Bigger scale + faster. */
.aw-hq-pulse--burst {
  animation: aw-hq-burst 1.4s cubic-bezier(.22,1,.36,1) forwards;
  z-index: 1;
}
@keyframes aw-hq-pulse {
  0% { transform: scale(0.8); opacity: 0.55; }
  100% { transform: scale(2.2); opacity: 0; }
}
@keyframes aw-hq-burst {
  0%   { transform: scale(0.6); opacity: 0.85; }
  100% { transform: scale(4.5); opacity: 0; }
}
/* Pool-variant — leads parked in the Bewerberpool render in accent (blue)
   instead of success (green) so customers can visually distinguish "qualified
   active" pins from "qualified parked" pins. Same shape, different fill. */
.aw-applicant-pin--pool {
  background: var(--accent) !important;
}
.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;
  position: relative;
  /* Slower drop with a fall-from-above feel — feels like the pin is being
     "placed" rather than "appearing". 0.8s vs 0.45s gives every pin its
     moment when staggered. */
  animation: aw-pin-pop 0.8s cubic-bezier(.22,1,.36,1) both;
}
/* Impact halo — accent-colored ring that radiates outward from each pin as it
   lands. Created via ::before so it doesn't interfere with the pin's own scale
   animation. Pure decorative; non-interactive. */
.aw-applicant-pin::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  background: var(--accent);
  z-index: -1;
  opacity: 0;
  animation: aw-pin-impact 1.0s cubic-bezier(.22,1,.36,1) 0.25s forwards;
}
@keyframes aw-pin-pop {
  0%   { transform: scale(0) translateY(-18px); opacity: 0; }
  35%  { opacity: 1; }
  55%  { transform: scale(1.18) translateY(0); }
  78%  { transform: scale(0.94); }
  100% { transform: scale(1); opacity: 1; }
}
@keyframes aw-pin-impact {
  0%   { transform: scale(0.6); opacity: 0.55; }
  100% { transform: scale(2.6); opacity: 0; }
}
/* Final-flourish flash — added to every applicant pin after the last drop,
   removed ~900ms later. Synchronized celebratory glow. */
.aw-applicant-pin--flash {
  animation: aw-pin-flash 0.9s cubic-bezier(.22,1,.36,1) both !important;
}
@keyframes aw-pin-flash {
  0%   { box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92); transform: scale(1); }
  40%  { box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92), 0 0 24px 8px rgba(167,243,208,.85); transform: scale(1.18); }
  100% { box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92); transform: scale(1); }
}
/* Pool variant glows in accent (blue) instead of success (green) */
.aw-applicant-pin--pool.aw-applicant-pin--flash {
  animation: aw-pin-flash-pool 0.9s cubic-bezier(.22,1,.36,1) both !important;
}
@keyframes aw-pin-flash-pool {
  0%   { box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92); transform: scale(1); }
  40%  { box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92), 0 0 24px 8px rgba(96,165,250,.85); transform: scale(1.18); }
  100% { box-shadow: 0 2px 8px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.92); transform: scale(1); }
}

/* HQ-radiating sweep wave — single ring expanding from HQ over the map.
   Used during the reveal phase to hint at "scanning area for applicants".
   Uses Leaflet's SVG layer so it follows zoom level. */
.aw-sweep-wave {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2;
  opacity: 0.6;
  animation: aw-sweep 2.6s cubic-bezier(.22,1,.36,1) forwards;
  transform-origin: center;
}
@keyframes aw-sweep {
  0%   { stroke-opacity: 0.65; stroke-width: 3; }
  100% { stroke-opacity: 0;    stroke-width: 0.5; }
}

/* Static catchment-radius rings (50/100/200km) — drawn as faint dashed
   guides after the reveal so the geographic spread reads as a pattern. */
.aw-catchment-ring {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1;
  stroke-dasharray: 4 6;
  opacity: 0.18;
}

/* Legend (bottom-left of map). Compact variant — just colored chips, no
   title or subtitle. Glass-style, slides in alongside the counter. */
.aw-legend {
  position: absolute;
  bottom: var(--s-3);
  left: var(--s-3);
  z-index: 600;
  background: var(--surface-overlay);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  max-width: 320px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity var(--t-smooth) var(--ease-cockpit), transform var(--t-smooth) var(--ease-cockpit);
}
.aw-legend.is-on { opacity: 1; transform: translateY(0); }
/* Compact: only the chip row, no title/sub block. Tighter padding. */
.aw-legend--compact { padding: var(--s-2) var(--s-3); gap: 0; }
.aw-legend--compact .aw-legend__row { margin-top: 0; }
.aw-legend__title {
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  color: var(--text-display);
  letter-spacing: -0.005em;
}
.aw-legend__sub {
  font-size: 11.5px;
  color: var(--text-muted);
  line-height: 1.45;
}
.aw-legend__row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-1);
}
.aw-legend__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  font-weight: var(--weight-label);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding: 3px 8px 3px 6px;
  background: var(--interactive);
  border-radius: var(--r-pill);
  white-space: nowrap;
}
.aw-legend__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.aw-legend__dot--hq        { background: var(--accent); box-shadow: 0 0 0 2px rgba(255,255,255,.6); }
.aw-legend__dot--qualified { background: var(--success); }
.aw-legend__dot--pool      { background: var(--accent); }
.aw-legend__dot--ring      { background: transparent; border: 1.5px dashed var(--accent); width: 10px; height: 10px; }

/* ============================================================
   RECRUITING WRAPPED — Spotify-Wrapped-style story player
   Full-screen overlay. Auto-advancing slides. One big idea per slide.
   See ui-portal-views.js for slide renderers.
============================================================ */
body.wr-open { overflow: hidden; }
.wr {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: #0A1018;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: wr-fade-in var(--t-smooth) var(--ease-cockpit);
}
@keyframes wr-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Background mesh — animated, subtle, drifts behind content */
.wr__mesh {
  position: absolute; inset: 0; z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.wr__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.55;
  animation: wr-blob-drift 18s ease-in-out infinite alternate;
  will-change: transform;
}
.wr__blob:nth-child(1) { top: -10%; left: -5%;  width: 50%; height: 60%; background: var(--accent);  animation-delay: 0s; }
.wr__blob:nth-child(2) { bottom: -15%; right: -10%; width: 60%; height: 65%; background: var(--success); animation-delay: -6s; }
.wr__blob:nth-child(3) { top: 30%; left: 35%; width: 35%; height: 40%; background: var(--info);    animation-delay: -12s; }
@keyframes wr-blob-drift {
  0%   { transform: translate(0, 0) scale(1); }
  50%  { transform: translate(8%, -4%) scale(1.1); }
  100% { transform: translate(-6%, 6%) scale(0.95); }
}

/* Top progress bars — manual-mode: static state, no auto-fill animation.
   Done slides = filled, current = highlighted, upcoming = empty. Clickable
   to jump directly. */
.wr__progress {
  position: relative;
  z-index: 10;
  display: flex;
  gap: 4px;
  padding: 16px 20px 0;
  flex-shrink: 0;
}
.wr__pbar {
  flex: 1;
  height: 3px;
  background: rgba(255,255,255,.18);
  border-radius: 2px;
  overflow: hidden;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease-cockpit);
}
.wr__pbar:hover { background: rgba(255,255,255,.28); }
.wr__pbar-fill {
  height: 100%;
  width: 0%;
  background: rgba(255,255,255,.95);
  border-radius: 2px;
  transition: width var(--t-base) var(--ease-cockpit);
}
.wr__pbar.is-done .wr__pbar-fill   { width: 100%; }
.wr__pbar.is-active .wr__pbar-fill { width: 100%; background: rgba(255,255,255,1); box-shadow: 0 0 8px rgba(255,255,255,.4); }

/* Top header — small brand watermark + close */
.wr__header {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px 0;
  flex-shrink: 0;
}
.wr__brand {
  display: flex;
  align-items: center;
  gap: 10px;
}
.wr__brand-mark {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: #fff;
  padding: 3px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}
.wr__brand-mark svg, .wr__brand-mark img { width: 100%; height: 100%; object-fit: contain; }
.wr__brand-text {
  font-size: 11px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  font-weight: var(--weight-label);
}
.wr__close {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  border: 0;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-family: inherit;
  font-size: 18px;
  line-height: 1;
  transition: background var(--t-fast) var(--ease-cockpit);
}
.wr__close:hover { background: rgba(255,255,255,.22); }

/* Slide stage — flex-grows to fill viewport */
.wr__stage {
  position: relative;
  z-index: 5;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--s-7) var(--s-6);
  min-height: 0;
}

/* Tap zones for nav (invisible). Manual mode: 50/50 split, no pause zone. */
.wr__tap {
  position: absolute;
  top: 0; bottom: 0;
  width: 50%;
  z-index: 8;
  cursor: pointer;
  background: transparent;
  border: 0;
  user-select: none;
}
.wr__tap--prev { left: 0; }
.wr__tap--next { right: 0; }

/* Bottom footer — its OWN flex row in the .wr column so it never overlaps
   the stage content (especially important for the full-bleed map slide).
   Holds the prev/next buttons + slide counter. */
.wr__footer {
  position: relative;
  z-index: 10;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-5) var(--s-5);
}
.wr__nav-arrow {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.14);
  border: 0;
  color: #fff;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: inherit;
  transition: background var(--t-fast) var(--ease-cockpit);
}
.wr__nav-arrow:hover:not(:disabled) { background: rgba(255,255,255,.28); }
.wr__nav-arrow:disabled { opacity: 0.4; cursor: not-allowed; }
.wr__nav-count {
  font-size: 12px;
  color: rgba(255,255,255,.85);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  font-weight: var(--weight-label);
  min-width: 56px;
  text-align: center;
}

/* Slide content container — animation root */
.wr__slide {
  position: relative;
  z-index: 6;
  width: 100%;
  max-width: 720px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--s-5);
  animation: wr-slide-in var(--t-smooth) var(--ease-cockpit);
}
/* Full-bleed variant — for slides that need the entire stage (map slide).
   Removes the 720px constraint and lets the content fill the canvas. */
.wr__slide--full {
  max-width: none;
  height: 100%;
  gap: var(--s-3);
  align-items: stretch;
}
.wr__slide--full .wr__eyebrow {
  margin-top: var(--s-3);
}
/* When using a full-bleed map slide, override the embedded section-head + map
   surface chrome so the map fills the slide cleanly. */
.wr__slide--full .wr-map-host { background: transparent !important; padding: 0 !important; border: 0 !important; height: 100% !important; }
.wr__slide--full .wr-map-host > .cock-section-head { display: none; }
.wr__slide--full .wr-map-host > div[id="aw-map"] { height: 100% !important; min-height: 380px; flex: 1; }
@keyframes wr-slide-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Slide typography — extra large, light weight */
.wr__eyebrow {
  font-size: 13px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  font-weight: var(--weight-label);
  animation: wr-fade-up 0.6s var(--ease-cockpit) both;
}
.wr__hero {
  font-size: clamp(80px, 18vw, 240px);
  font-weight: 200;
  letter-spacing: -0.04em;
  color: #fff;
  line-height: 0.95;
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum' 1;
  animation: wr-hero-in 0.9s var(--ease-cockpit) 0.15s both;
  transform-origin: center;
}
@keyframes wr-hero-in {
  0%   { opacity: 0; transform: translateY(24px) scale(0.94); letter-spacing: -0.02em; }
  60%  { opacity: 1; }
  100% { opacity: 1; transform: translateY(0) scale(1); letter-spacing: -0.04em; }
}
.wr__hero--md {
  font-size: clamp(56px, 12vw, 144px);
}
.wr__hero-suffix {
  font-size: 0.4em;
  color: rgba(255,255,255,.55);
  font-weight: 300;
  letter-spacing: 0;
  margin-left: 0.2em;
}
.wr__caption {
  font-size: clamp(15px, 2.5vw, 22px);
  color: rgba(255,255,255,.78);
  font-weight: 400;
  line-height: 1.4;
  max-width: 540px;
  animation: wr-fade-up 0.8s var(--ease-cockpit) 0.35s both;
}
.wr__title {
  font-size: clamp(28px, 5vw, 56px);
  font-weight: 250;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.05;
  animation: wr-fade-up 0.7s var(--ease-cockpit) 0.1s both;
}
.wr__big-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  animation: wr-fade-up 0.6s var(--ease-cockpit) 0.55s both;
}

/* Number + unit stacked vertically, hierarchy via size. Used by Savings slide. */
.wr__num-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  animation: wr-fade-up 0.8s var(--ease-cockpit) 0.15s both;
}
.wr__num-unit__num {
  font-size: clamp(80px, 18vw, 240px);
  font-weight: 200;
  letter-spacing: -0.04em;
  color: #fff;
  line-height: 0.95;
  font-variant-numeric: tabular-nums;
}
.wr__num-unit__unit {
  font-size: clamp(15px, 2.2vw, 22px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  font-weight: var(--weight-label);
}

/* Conv slide — small prefix line above the big ratio number */
.wr__conv-line {
  margin-bottom: -8px;
}
.wr__conv-prefix {
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 250;
  color: rgba(255,255,255,.7);
  letter-spacing: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) 0.1s both;
}

/* Verdict pill — used on Reaction slide. Bigger than .wr__big-pill, holds a
   bold tone label + a contextual hint underneath. Tone-colored. */
.wr__verdict {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 28px;
  border-radius: var(--r-lg);
  border: 1px solid;
  font-variant-numeric: tabular-nums;
  animation: wr-fade-up 0.7s var(--ease-cockpit) 0.5s both;
}
.wr__verdict-label {
  font-size: 18px;
  font-weight: var(--weight-body-strong);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.wr__verdict-hint {
  font-size: 12.5px;
  color: rgba(255,255,255,.7);
  font-weight: var(--weight-body);
  letter-spacing: 0.01em;
  text-transform: none;
}
.wr__verdict--success { background: rgba(52,211,153,.18); border-color: rgba(52,211,153,.45); color: #a7f3d0; }
.wr__verdict--warning { background: rgba(245,158,11,.18); border-color: rgba(245,158,11,.45); color: #fcd34d; }
.wr__verdict--danger  { background: rgba(239,68,68,.18);  border-color: rgba(239,68,68,.45);  color: #fca5a5; }
.wr__big-pill--success { background: rgba(52,211,153,.22); border-color: rgba(52,211,153,.4); color: #a7f3d0; }
.wr__big-pill--warning { background: rgba(245,158,11,.22); border-color: rgba(245,158,11,.4); color: #fcd34d; }
.wr__big-pill--danger  { background: rgba(239,68,68,.22);  border-color: rgba(239,68,68,.4);  color: #fca5a5; }

@keyframes wr-fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Funnel stages — bars draw out one by one */
.wr__funnel {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  max-width: 540px;
}
.wr__funnel-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  opacity: 0;
  animation: wr-fade-up 0.55s var(--ease-cockpit) both;
}
.wr__funnel-row:nth-child(1) { animation-delay: 0.4s; }
.wr__funnel-row:nth-child(2) { animation-delay: 0.7s; }
.wr__funnel-row:nth-child(3) { animation-delay: 1.0s; }
.wr__funnel-head {
  display: flex; justify-content: space-between; align-items: baseline;
  color: #fff;
}
.wr__funnel-label { font-size: 14px; color: rgba(255,255,255,.78); font-weight: 400; }
.wr__funnel-value { font-size: 32px; font-weight: 250; font-variant-numeric: tabular-nums; }
.wr__funnel-bar {
  height: 6px;
  background: rgba(255,255,255,.10);
  border-radius: 3px;
  overflow: hidden;
}
.wr__funnel-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 3px;
  width: 0%;
  animation: wr-bar-fill 1.2s var(--ease-cockpit) both;
}
.wr__funnel-row:nth-child(1) .wr__funnel-fill { animation-delay: 0.5s; }
.wr__funnel-row:nth-child(2) .wr__funnel-fill { animation-delay: 0.8s; }
.wr__funnel-row:nth-child(3) .wr__funnel-fill { animation-delay: 1.1s; background: var(--success); }
@keyframes wr-bar-fill {
  from { width: 0%; }
}

/* Big quality ring — SVG donut for the % slide */
.wr__ring {
  width: clamp(220px, 36vw, 360px);
  height: clamp(220px, 36vw, 360px);
  position: relative;
}
.wr__ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.wr__ring-track { fill: none; stroke: rgba(255,255,255,.10); stroke-width: 14; }
.wr__ring-fill  {
  fill: none; stroke: var(--success); stroke-width: 14;
  stroke-linecap: round;
  stroke-dasharray: var(--wr-ring-len, 1000);
  stroke-dashoffset: var(--wr-ring-len, 1000);
  animation: wr-ring-fill 1.6s var(--ease-cockpit) 0.3s forwards;
}
@keyframes wr-ring-fill {
  to { stroke-dashoffset: var(--wr-ring-target, 500); }
}
.wr__ring-center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px;
}
.wr__ring-num { font-size: clamp(56px, 10vw, 96px); font-weight: 200; color: #fff; line-height: 1; font-variant-numeric: tabular-nums; }
.wr__ring-suffix { font-size: 13px; letter-spacing: var(--tracking-label); text-transform: uppercase; color: rgba(255,255,255,.55); }

/* Quality slide stats below ring — qualifizierte (success) + optional pool (accent).
   Two big stat blocks side-by-side with a "+" separator so the +pool reads as
   a clear addition, not a footnote. */
.wr__qstat-grid {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: var(--s-4);
  margin-top: var(--s-4);
  flex-wrap: wrap;
  animation: wr-fade-up 0.7s var(--ease-cockpit) 0.5s both;
}
.wr__qstat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-lg);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  min-width: 180px;
}
.wr__qstat--qual {
  border-color: rgba(52,211,153,.35);
  background: rgba(52,211,153,.08);
}
.wr__qstat--pool {
  border-color: rgba(93,163,220,.4);
  background: rgba(93,163,220,.10);
}
.wr__qstat-num {
  font-size: clamp(38px, 6vw, 64px);
  font-weight: 200;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.wr__qstat--qual .wr__qstat-num { color: #a7f3d0; }
.wr__qstat--pool .wr__qstat-num { color: #b3d6ec; }
.wr__qstat-label {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  font-weight: var(--weight-label);
}
.wr__qstat-sub {
  font-size: 11px;
  color: rgba(255,255,255,.5);
}
.wr__qstat-plus {
  display: flex;
  align-items: center;
  font-size: 32px;
  font-weight: 200;
  color: rgba(255,255,255,.4);
  line-height: 1;
}

/* Top-job bar — multi-row "Bewerbungen nach Stelle" list. Each row stagger-fades in. */
.wr__job-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  width: 100%;
  margin-top: var(--s-3);
}
.wr__job-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: left;
  opacity: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) both;
}
.wr__job-row-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  color: #fff;
}
.wr__job-row-name { font-size: 18px; font-weight: 300; }
.wr__job-row-count {
  font-size: 26px;
  font-weight: 250;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.wr__job-bar { height: 12px; background: rgba(255,255,255,.08); border-radius: 6px; overflow: hidden; }
.wr__job-fill {
  height: 100%;
  border-radius: 6px;
  transition: width 1.2s cubic-bezier(.22,1,.36,1) 0.2s;
}
/* Äußerer Layer: muted für Gesamt-Bewerbungen */
.wr__job-fill--total { background: rgba(255,255,255,.28); }
/* Innerer Layer: kräftiges Grün für qualifizierte */
.wr__job-fill--qual  { background: var(--success); }
.wr__job-row-meta {
  display: flex;
  gap: var(--s-3);
  color: rgba(255,255,255,.65);
  font-size: 12.5px;
  font-variant-numeric: tabular-nums;
}
.wr__job-seg {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  font-weight: var(--weight-body-strong);
  color: rgba(255,255,255,.75);
}
.wr__job-seg::before {
  content: '';
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.wr__job-seg--direct::before { background: var(--success); }
.wr__job-seg--pool {
  font-size: 11px;
  font-weight: var(--weight-body);
  color: rgba(255,255,255,.55);
}
.wr__job-seg--pool::before   { background: var(--accent); width: 6px; height: 6px; }

/* Funnel slide v3 — horizontal flow: 3 stat cards joined by arrows. The loss
   chip sits ON TOP of the arrow line (centered overlay), 100% transitions
   render only the arrow. Caption below summarizes total conversion. */
.wr__flow {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: var(--s-3);
  width: 100%;
  margin-top: var(--s-5);
}
.wr__flow-card { flex: 0 0 280px; }
.wr__flow-conn { flex: 0 0 180px; }
.wr__flow-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: var(--s-6) var(--s-4);
  background: linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--r-lg);
  opacity: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) both;
  min-height: 180px;
}
.wr__flow-card--final {
  background: linear-gradient(180deg, rgba(52,211,153,.16) 0%, rgba(52,211,153,.06) 100%);
  border-color: rgba(52,211,153,.45);
  box-shadow: 0 0 40px -8px rgba(52,211,153,.35);
}
.wr__flow-num {
  font-size: clamp(56px, 8vw, 88px);
  font-weight: 200;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.wr__flow-card--final .wr__flow-num { color: #a7f3d0; }
.wr__flow-label {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  font-weight: var(--weight-label);
}
.wr__flow-sub {
  margin-top: 4px;
  font-size: 12px;
  color: rgba(255,255,255,.55);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.005em;
  text-align: center;
}
.wr__flow-card--final .wr__flow-sub { color: rgba(167,243,208,.75); }
.wr__flow-conn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.35);
  opacity: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) both;
}
.wr__flow-conn--loss { color: #fca5a5; }
.wr__flow-conn--keep { color: rgba(255,255,255,.35); }
.wr__flow-arrow {
  width: 100%;
  height: 10px;
  display: block;
}
/* Chip floats over the arrow center; pointer-events none keeps the line clickable */
.wr__flow-chip {
  position: absolute;
  top: 50%;
  left: 50%;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(20, 24, 30, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid currentColor;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  /* Custom keyframe — keeps the centering translate intact while fading up */
  animation: wr-chip-in 0.5s var(--ease-cockpit) both;
}
@keyframes wr-chip-in {
  from { opacity: 0; transform: translate(-50%, calc(-50% + 8px)); }
  to   { opacity: 1; transform: translate(-50%, -50%); }
}
.wr__flow-chip-num {
  font-size: 16px;
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  line-height: 1;
}
.wr__flow-chip--loss .wr__flow-chip-num { color: #fca5a5; }
.wr__flow-chip-label {
  font-size: 9.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  font-weight: var(--weight-label);
  line-height: 1;
}
.wr__flow-caption {
  margin-top: var(--s-5);
  text-align: center;
  font-size: 14px;
  color: rgba(255,255,255,.7);
  letter-spacing: 0.01em;
  opacity: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) 0.9s both;
}
.wr__flow-caption strong {
  color: #fff;
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
}
@media (max-width: 720px) {
  .wr__flow {
    flex-direction: column;
    gap: var(--s-2);
  }
  .wr__flow-card,
  .wr__flow-conn { flex: 0 0 auto; }
  .wr__flow-conn { height: 56px; }
  .wr__flow-arrow { transform: rotate(90deg); width: 30px; height: 10px; }
  .wr__flow-chip { font-size: 14px; }
}

/* Legacy funnel slide — SVG trapezoid stack (kept for any consumers) */
.wr__fn-shape {
  position: relative;
  width: 100%;
  margin-top: var(--s-4);
}
.wr__fn-label {
  position: absolute;
  left: 0; right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;  /* vertical center within the stage band */
  gap: 6px;
  pointer-events: none;
  opacity: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) both;
}
.wr__fn-label-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: rgba(255,255,255,.78);
  font-weight: 400;
}
.wr__fn-label-num {
  font-size: 28px;
  font-weight: 200;
  letter-spacing: -0.01em;
  color: #fff;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.wr__fn-delta {
  display: inline-block;
  padding: 2px 8px;
  font-size: 10.5px;
  font-weight: var(--weight-label);
  letter-spacing: 0.04em;
  background: rgba(255,255,255,.14);
  color: rgba(255,255,255,.9);
  border-radius: var(--r-pill);
  font-variant-numeric: tabular-nums;
  vertical-align: middle;
}
/* Drop-off annotation — floats at the transition Y where stages narrow.
   Connector line points from the funnel edge to the chip, so the user can
   visually trace "between THESE two stages we lost X". */
.wr__fn-drop {
  position: absolute;
  right: -2%;
  display: flex;
  align-items: center;
  gap: 8px;
  pointer-events: none;
  opacity: 0;
  animation: wr-fade-up 0.6s var(--ease-cockpit) both;
  transform: translateY(-50%);  /* center on the transition Y */
}
.wr__fn-drop-line {
  width: 24px;
  height: 1px;
  background: rgba(239,68,68,.5);
  flex-shrink: 0;
}
.wr__fn-drop-card {
  padding: 6px 12px;
  background: rgba(239,68,68,.16);
  border: 1px solid rgba(239,68,68,.4);
  border-radius: var(--r-md);
  color: #fca5a5;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  text-align: left;
}
.wr__fn-drop-flow {
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  color: #fee2e2;
  letter-spacing: 0.01em;
}
.wr__fn-drop-loss {
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(252,165,165,.85);
  margin-top: 2px;
  font-weight: var(--weight-label);
}
@media (max-width: 720px) {
  .wr__fn-drop { right: 4%; }
  .wr__fn-drop-line { width: 12px; }
  .wr__fn-drop-flow { font-size: 12px; }
  .wr__fn-drop-loss { font-size: 9.5px; }
}

/* Budget slide — bigger split-bar with rounded segments, channel rows below */
.wr__budget-bar {
  width: 100%;
  height: 28px;
  background: rgba(255,255,255,.08);
  border-radius: var(--r-pill);
  overflow: hidden;
  display: flex;
  margin-top: var(--s-4);
  padding: 4px;
  border: 1px solid rgba(255,255,255,.10);
}
.wr__budget-seg {
  height: 100%;
  width: 0%;
  border-radius: var(--r-pill);
  transition: width 1.2s cubic-bezier(.22,1,.36,1) 0.2s;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}
.wr__budget-seg + .wr__budget-seg { margin-left: 2px; }
.wr__budget-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  width: 100%;
  margin-top: var(--s-4);
}
.wr__budget-row {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  font-size: 15px;
  color: rgba(255,255,255,.9);
  padding: 10px 14px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
}
.wr__budget-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.wr__budget-label { flex: 1; text-align: left; font-weight: var(--weight-body-strong); }
.wr__budget-val   { font-variant-numeric: tabular-nums; font-weight: var(--weight-body-strong); color: #fff; font-size: 16px; }
.wr__budget-pct   { font-variant-numeric: tabular-nums; color: rgba(255,255,255,.55); min-width: 48px; text-align: right; font-size: 13px; }

/* ============================================================
   AUSWERTUNG · PERIOD-CARD LANDING
   The auswertung page is a grid of period-cards. Each card is a
   big tappable button that shows teaser metrics + opens the wrapped.
============================================================ */
.aw-landing-head {
  margin-bottom: var(--s-7);
}
.aw-period-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--s-5);
}
.aw-period-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  padding: var(--s-7) var(--s-6) var(--s-6);
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  color: inherit;
  transition: transform var(--t-fast) var(--ease-cockpit), background var(--t-fast) var(--ease-cockpit), border-color var(--t-fast) var(--ease-cockpit), box-shadow var(--t-base) var(--ease-cockpit);
  overflow: hidden;
}
.aw-period-card::before {
  /* Subtle accent gradient sheen — only visible on hover */
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--accent-soft) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--t-base) var(--ease-cockpit);
  pointer-events: none;
}
.aw-period-card:hover {
  transform: translateY(-2px);
  border-color: var(--hairline-strong);
  background: var(--surface-2);
  box-shadow: 0 12px 32px -12px rgba(0,0,0,.4);
}
.aw-period-card:hover::before { opacity: 1; }
.aw-period-card--gesamt {
  /* Gesamt = the big-picture card. Subtle accent border to differentiate. */
  border-color: rgba(93,163,220,.3);
  background: linear-gradient(135deg, var(--accent-soft) 0%, var(--surface-1) 70%);
}
.aw-period-card--gesamt:hover {
  border-color: var(--accent);
}
.aw-period-card__head {
  position: relative;
}
.aw-period-card__label {
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 250;
  letter-spacing: -0.02em;
  color: var(--text-display);
  line-height: 1.05;
}
.aw-period-card__sub {
  font-size: 11px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 6px;
  font-weight: var(--weight-label);
}
.aw-period-card__stats {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4) var(--s-5);
  padding: var(--s-5) 0 var(--s-3);
  border-top: 1px solid var(--hairline);
}
.aw-period-card__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.aw-period-card__num {
  font-size: 26px;
  font-weight: 250;
  letter-spacing: -0.01em;
  color: var(--text-display);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.aw-period-card__num-pct {
  font-size: 13px;
  color: var(--text-muted);
  font-weight: var(--weight-body);
  letter-spacing: 0;
}
.aw-period-card__lbl {
  font-size: 10.5px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: var(--weight-label);
}
.aw-period-card__cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: flex-start;
  padding: 10px 18px;
  background: var(--accent);
  color: #fff;
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  transition: background var(--t-fast) var(--ease-cockpit);
}
.aw-period-card:hover .aw-period-card__cta { background: var(--accent-glow); }
.aw-period-card__cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  background: rgba(255,255,255,.25);
  border-radius: 50%;
  flex-shrink: 0;
  color: #fff;
}
.aw-period-card__cta-icon svg {
  width: 8px;
  height: 10px;
  margin-left: 1px;  /* nudge right to optically center the triangle */
}

/* ============================================================
   BENTO DASHBOARD — Auswertung at-a-glance
   Replaces the period-card landing. All key metrics for the selected
   period visible in a single bento-grid layout. Wrapped slideshow
   remains optional behind the "Slideshow ansehen" button.
============================================================ */
.aw-dash-shell {
  padding: var(--s-4) var(--s-4) var(--s-7);
}
@media (min-width: 768px) {
  .aw-dash-shell { padding: var(--s-5) var(--s-6) var(--s-8); }
}

/* ── Hero header ─────────────────────────────────────────── */
.aw-dash-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--s-4);
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
}
.aw-dash-hero__main { display: flex; flex-direction: column; gap: 4px; }
.aw-dash-hero__eyebrow {
  font-size: 11px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: var(--weight-label);
}
.aw-dash-hero__title {
  font-size: clamp(32px, 4.5vw, 52px);
  font-weight: 200;
  letter-spacing: -0.025em;
  color: var(--text-display);
  line-height: 1.0;
}
.aw-dash-hero__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: linear-gradient(135deg, var(--accent), var(--success));
  color: #fff;
  border: 0;
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease-cockpit), box-shadow var(--t-fast) var(--ease-cockpit);
  box-shadow: 0 4px 16px -4px rgba(93,163,220,.45);
}
.aw-dash-hero__cta:hover { transform: translateY(-1px); box-shadow: 0 8px 24px -4px rgba(93,163,220,.6); }

/* ── Hero stat tiles ─────────────────────────────────────── */
.aw-dash-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  margin: var(--s-3) 0 var(--s-4);
}
.aw-dash-stats--5 { grid-template-columns: repeat(5, 1fr); }
.aw-dash-stats--6 { grid-template-columns: repeat(6, 1fr); }
@media (max-width: 1280px) {
  .aw-dash-stats--6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1100px) {
  .aw-dash-stats--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .aw-dash-stats { grid-template-columns: repeat(2, 1fr); }
  .aw-dash-stats--5,
  .aw-dash-stats--6 { grid-template-columns: repeat(2, 1fr); }
}
.aw-dash-stat {
  padding: var(--s-4) var(--s-5);
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: 2px;
  transition: border-color var(--t-fast) var(--ease-cockpit);
}
.aw-dash-stat--success {
  background: linear-gradient(135deg, rgba(52,211,153,.10) 0%, var(--surface-1) 65%);
  border-color: rgba(52,211,153,.25);
}
.aw-dash-stat--warning {
  background: linear-gradient(135deg, rgba(245,158,11,.10) 0%, var(--surface-1) 65%);
  border-color: rgba(245,158,11,.28);
}
.aw-dash-stat--danger {
  background: linear-gradient(135deg, rgba(239,68,68,.10) 0%, var(--surface-1) 65%);
  border-color: rgba(239,68,68,.28);
}
.aw-dash-stat--pool {
  background: linear-gradient(135deg, rgba(93,163,220,.10) 0%, var(--surface-1) 65%);
  border-color: rgba(93,163,220,.30);
}
.aw-dash-stat__num {
  font-size: clamp(28px, 2.6vw, 38px);
  font-weight: 200;
  letter-spacing: -0.025em;
  color: var(--text-display);
  font-variant-numeric: tabular-nums;
  line-height: 1.0;
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.aw-dash-stat__pct {
  font-size: 14px;
  font-weight: var(--weight-body);
  color: var(--text-muted);
  letter-spacing: 0;
  margin-left: 6px;
}
/* Numbers stay neutral display-color across all tones — only the card
   background gets the tonal tint (per Ediz: "grüne schrift raus"). */
.aw-dash-stat--warning .aw-dash-stat__num,
.aw-dash-stat--danger  .aw-dash-stat__num { color: var(--text-display); }
.aw-dash-stat__label {
  font-size: 10.5px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-secondary);
  font-weight: var(--weight-label);
}
.aw-dash-stat__sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}

/* ── Bento grid (12-col) ─────────────────────────────────── */
.aw-dash-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s-3);
}
@media (max-width: 900px) {
  .aw-dash-grid { grid-template-columns: 1fr; }
}
.aw-dash-card {
  padding: var(--s-5);
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  position: relative;
  overflow: hidden;
}
.aw-dash-card--span-full { grid-column: span 12; }
.aw-dash-card--span-8    { grid-column: span 8; }
.aw-dash-card--span-4    { grid-column: span 4; }
@media (max-width: 900px) {
  .aw-dash-card--span-full,
  .aw-dash-card--span-8,
  .aw-dash-card--span-4 { grid-column: span 1; }
}
.aw-dash-card--success {
  background: linear-gradient(135deg, rgba(52,211,153,.08) 0%, var(--surface-1) 70%);
  border-color: rgba(52,211,153,.25);
}
.aw-dash-card--warning {
  background: linear-gradient(135deg, rgba(245,158,11,.10) 0%, var(--surface-1) 70%);
  border-color: rgba(245,158,11,.30);
}
.aw-dash-card--danger {
  background: linear-gradient(135deg, rgba(239,68,68,.10) 0%, var(--surface-1) 70%);
  border-color: rgba(239,68,68,.30);
}
.aw-dash-card--empty { opacity: 0.65; }
.aw-dash-card--map { padding: 0; overflow: hidden; }
.aw-dash-card--map .cock-section-head { display: none; }
.aw-dash-card--map #aw-map { border-radius: var(--r-lg); height: 480px !important; }
@media (max-width: 900px) {
  .aw-dash-card--map #aw-map { height: 360px !important; }
}
.aw-dash-card__title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-2);
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  color: var(--text-display);
  letter-spacing: 0.01em;
}
.aw-dash-card__title-meta {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: var(--weight-body);
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}
.aw-dash-card__big {
  font-size: clamp(40px, 4.5vw, 56px);
  font-weight: 200;
  letter-spacing: -0.025em;
  color: var(--text-display);
  font-variant-numeric: tabular-nums;
  line-height: 1.0;
  margin-top: var(--s-1);
}
.aw-dash-card__big-sub {
  font-size: 0.5em;
  color: var(--text-muted);
  font-weight: var(--weight-body);
  letter-spacing: 0.01em;
  margin: 0 4px;
}
.aw-dash-card__cap {
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.4;
  margin-top: auto;
}
.aw-dash-card__cap strong {
  color: var(--text-display);
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
}

/* ── Funnel flow inside dashboard ────────────────────────── */
.aw-dash-flow {
  display: grid;
  grid-template-columns: 1fr 100px 1fr 100px 1fr;
  gap: var(--s-2);
  align-items: stretch;
  margin: var(--s-3) 0 var(--s-2);
}
@media (max-width: 900px) {
  .aw-dash-flow { grid-template-columns: 1fr; gap: var(--s-2); }
  .aw-dash-flow__arrow { height: 40px; }
  .aw-dash-flow__arrow svg { transform: rotate(90deg); width: 24px; height: 10px; }
}
.aw-dash-flow__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: var(--s-5) var(--s-3);
  background: linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.02) 100%);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  min-height: 140px;
}
.aw-dash-flow__card--final {
  background: linear-gradient(180deg, rgba(52,211,153,.14) 0%, rgba(52,211,153,.05) 100%);
  border-color: rgba(52,211,153,.4);
  box-shadow: 0 0 32px -8px rgba(52,211,153,.3);
}
.aw-dash-flow__num {
  font-size: clamp(40px, 4.5vw, 60px);
  font-weight: 200;
  letter-spacing: -0.02em;
  color: var(--text-display);
  font-variant-numeric: tabular-nums;
  line-height: 1.0;
}
.aw-dash-flow__card--final .aw-dash-flow__num { color: #a7f3d0; }
.aw-dash-flow__label {
  font-size: 10.5px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: var(--weight-label);
}
.aw-dash-flow__sub {
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  text-align: center;
  margin-top: 2px;
}
.aw-dash-flow__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.35);
}
.aw-dash-flow__arrow svg { width: 100%; height: 10px; display: block; }

/* ── Top Stellen rows ────────────────────────────────────── */
.aw-dash-jobs { display: flex; flex-direction: column; gap: var(--s-3); }
.aw-dash-job { display: flex; flex-direction: column; gap: 6px; }
.aw-dash-job__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
}
.aw-dash-job__name {
  font-size: 14px;
  color: var(--text-display);
  font-weight: var(--weight-body);
  letter-spacing: -0.005em;
}
.aw-dash-job__count {
  font-size: 24px;
  font-weight: 250;
  letter-spacing: -0.01em;
  color: var(--text-display);
  font-variant-numeric: tabular-nums;
  line-height: 1.0;
}
.aw-dash-job__bar {
  height: 10px;
  background: rgba(255,255,255,.06);
  border-radius: 999px;
  overflow: hidden;
}
.aw-dash-job__fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.8s cubic-bezier(.22,1,.36,1);
}
/* Äußerer Layer: muted grey für Gesamt-Bewerbungen (Volumen vs. max). */
.aw-dash-job__fill--total { background: rgba(255,255,255,.28); position: relative; }
/* Innerer Layer: kräftiges Grün für qualifizierte, innerhalb des äußeren */
.aw-dash-job__fill--qual  { background: var(--success); }
.aw-dash-job__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11.5px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  gap: var(--s-3);
}
/* Legend chips below the bar — text stays neutral, only the dot is colored
   (per Ediz: "grüne schrift raus") */
.aw-dash-job__seg {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-right: var(--s-3);
  white-space: nowrap;
  color: var(--text-secondary);
  font-weight: var(--weight-body-strong);
}
.aw-dash-job__seg::before {
  content: '';
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.aw-dash-job__seg--direct::before { background: var(--success); }
.aw-dash-job__seg--pool {
  font-size: 10.5px;
  font-weight: var(--weight-body);
  color: var(--text-muted);
}
.aw-dash-job__seg--pool::before   { background: var(--accent); width: 6px; height: 6px; }

/* ── Reaction verdict pill ────────────────────────────────── */
.aw-dash-verdict {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-md);
  margin-top: auto;
}
.aw-dash-verdict--success { background: rgba(52,211,153,.12); border: 1px solid rgba(52,211,153,.25); }
.aw-dash-verdict--warning { background: rgba(245,158,11,.12); border: 1px solid rgba(245,158,11,.25); }
.aw-dash-verdict--danger  { background: rgba(239,68,68,.12); border: 1px solid rgba(239,68,68,.25); }
.aw-dash-verdict__label {
  font-size: 14px;
  font-weight: var(--weight-body-strong);
  letter-spacing: -0.005em;
}
.aw-dash-verdict--success .aw-dash-verdict__label { color: #a7f3d0; }
.aw-dash-verdict--warning .aw-dash-verdict__label { color: #fbbf24; }
.aw-dash-verdict--danger  .aw-dash-verdict__label { color: #fca5a5; }
.aw-dash-verdict__hint {
  font-size: 11.5px;
  color: var(--text-muted);
  line-height: 1.4;
}

/* ── Budget: donut + rows ────────────────────────────────── */
.aw-dash-budget {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) 0 var(--s-2);
}
.aw-dash-budget__donut {
  display: flex;
  justify-content: center;
  align-items: center;
}
.aw-dash-brows {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  width: 100%;
  margin-top: var(--s-2);
  padding-top: var(--s-3);
  border-top: 1px solid var(--hairline);
}
.aw-dash-brow {
  display: grid;
  grid-template-columns: 14px 1fr auto auto;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-2) 0;
  border-top: 1px solid var(--hairline);
}
.aw-dash-brow:first-child { border-top: 0; }
.aw-dash-brow__dot { width: 10px; height: 10px; border-radius: 50%; }
.aw-dash-brow__dot--google { background: #34a853; }
.aw-dash-brow__dot--meta   { background: #1877f2; }
.aw-dash-brow__name { font-size: 13px; color: var(--text-secondary); font-weight: var(--weight-body); }
.aw-dash-brow__val  { font-size: 14px; color: var(--text-display); font-weight: var(--weight-body-strong); font-variant-numeric: tabular-nums; }
.aw-dash-brow__pct  {
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  min-width: 36px;
  text-align: right;
}

/* CTA / launcher button on auswertung header */
.wr-launch {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-4);
  border-radius: var(--r-pill);
  background: linear-gradient(135deg, var(--accent), var(--success));
  color: #fff;
  border: 0;
  font-family: inherit;
  font-size: 13px;
  font-weight: var(--weight-body-strong);
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease-cockpit), box-shadow var(--t-fast) var(--ease-cockpit);
  box-shadow: 0 4px 16px -4px rgba(93,163,220,.45);
}
.wr-launch:hover { transform: translateY(-1px); box-shadow: 0 8px 24px -4px rgba(93,163,220,.6); }
.wr-launch__icon {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 9px;
}

@media (prefers-reduced-motion: reduce) {
  .wr__blob { animation: none; }
  .wr__pbar-fill, .wr__funnel-fill, .wr__job-fill, .wr__ring-fill { animation: none !important; }
}

/* Live counter overlay (top-right of map) */
.aw-counter {
  position: absolute;
  top: var(--s-3);
  right: var(--s-3);
  z-index: 600;
  background: var(--surface-overlay);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: var(--s-2) var(--s-3);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 96px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity var(--t-smooth) var(--ease-cockpit), transform var(--t-smooth) var(--ease-cockpit);
}
.aw-counter.is-on { opacity: 1; transform: translateY(0); }
.aw-counter__value {
  font-size: 22px;
  font-weight: var(--weight-display);
  letter-spacing: -0.01em;
  color: var(--text-display);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.aw-counter__value-of {
  font-size: 13px;
  color: var(--text-muted);
  margin-left: 2px;
  font-weight: var(--weight-body);
}
.aw-counter__label {
  font-size: 9.5px;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: var(--weight-label);
}

@media (prefers-reduced-motion: reduce) {
  .aw-hq-pulse { animation: none; opacity: 0.3; }
  .aw-applicant-pin { animation: none; }
  .aw-sweep-wave { animation: none; opacity: 0; }
  .aw-connector { animation: none; opacity: 0; }
}

/* 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-color: 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-color: 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 {
  padding-right: 36px;
  cursor: pointer;
}
/* Chevron lives on the wrapper, not the select element itself — iOS Safari
   ignores background-repeat:no-repeat on <select> with appearance:none and
   tiles the image across the field. The wrapper bypasses the quirk. */
html[data-cockpit="on"] .cock-select-wrap {
  position: relative;
  width: 100%;
}
html[data-cockpit="on"] .cock-select-wrap::after {
  content: "";
  position: absolute;
  right: 12px;
  top: 50%;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  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-size: contain;
  pointer-events: none;
}

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); }

/* Concentric radius rule: when form controls sit directly inside a card
   (.cock-surface = 16px), drop to 8px so the nested radius is half the parent.
   Inside modals (.cock-modal = 24px) the default 12px already satisfies the
   rule, so no override needed. */
html[data-cockpit="on"] .cock-surface > .cock-input,
html[data-cockpit="on"] .cock-surface > .cock-select,
html[data-cockpit="on"] .cock-surface > .cock-textarea,
html[data-cockpit="on"] .cock-surface > .cock-select-wrap > .cock-select,
html[data-cockpit="on"] .cock-surface form .cock-input,
html[data-cockpit="on"] .cock-surface form .cock-select,
html[data-cockpit="on"] .cock-surface form .cock-textarea,
html[data-cockpit="on"] .cock-surface form .cock-btn-primary,
html[data-cockpit="on"] .cock-surface form .cock-btn-ghost,
html[data-cockpit="on"] .cock-surface form .cock-btn-danger,
html[data-cockpit="on"] .cock-surface > .cock-btn-primary,
html[data-cockpit="on"] .cock-surface > .cock-btn-ghost,
html[data-cockpit="on"] .cock-surface > .cock-btn-danger {
  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-sm); /* 8px = half of 16px card parent (concentric rule) */
  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-sm); /* 8px = half of 16px column parent (concentric rule) */
  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;
}

/* Collapsible — generic "set-once" section that defaults closed. Header
   carries title + optional meta + chevron. Body shows on data-open="true".
   Use for tab content that's rarely touched after initial config. */
html[data-cockpit="on"] .cock-collapsible {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  overflow: hidden;
}
html[data-cockpit="on"] .cock-collapsible__head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: 14px 18px;
  background: transparent;
  border: 0;
  width: 100%;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background var(--t-fast) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-collapsible__head:hover { background: var(--interactive-hover); }
html[data-cockpit="on"] .cock-collapsible__caret {
  width: 14px; height: 14px;
  color: var(--text-muted);
  flex-shrink: 0;
  transition: transform var(--t-fast) var(--ease-cockpit);
}
html[data-cockpit="on"] .cock-collapsible[data-open="true"] .cock-collapsible__caret { transform: rotate(90deg); }
html[data-cockpit="on"] .cock-collapsible__title {
  flex: 1; min-width: 0;
  font-size: 13.5px;
  font-weight: var(--weight-body-strong);
  color: var(--text-display);
  letter-spacing: 0;
}
html[data-cockpit="on"] .cock-collapsible__meta {
  font-size: 12px;
  color: var(--text-muted);
  flex-shrink: 0;
}
html[data-cockpit="on"] .cock-collapsible__body {
  display: none;
  padding: 4px 18px 18px;
  border-top: 1px solid var(--hairline);
}
html[data-cockpit="on"] .cock-collapsible[data-open="true"] .cock-collapsible__body { display: block; }

/* Task-group (board: ≥3 identical routines collapse into one expandable card) */
html[data-cockpit="on"] .cock-task-group {
  display: flex;
  flex-direction: column;
}
html[data-cockpit="on"] .cock-task-group .cock-task {
  cursor: pointer;
}
html[data-cockpit="on"] .cock-task-group__items {
  display: none;
  flex-direction: column;
  gap: var(--s-1);
  margin-top: var(--s-1);
  padding-left: var(--s-3);
  border-left: 1px solid var(--hairline);
  margin-left: var(--s-3);
}
html[data-cockpit="on"] .cock-task-group[data-open="true"] .cock-task-group__items {
  display: flex;
}
html[data-cockpit="on"] .cock-task-group__caret {
  display: inline-block;
  font-size: 10px;
  transition: transform var(--t-fast) var(--ease-cockpit);
  margin-right: var(--s-1);
}
html[data-cockpit="on"] .cock-task-group[data-open="true"] .cock-task-group__caret {
  transform: rotate(90deg);
}
html[data-cockpit="on"] .cock-task-group__count {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: var(--interactive);
  color: var(--text-secondary);
  border-radius: var(--r-pill);
  font-size: 11px;
  font-weight: var(--weight-body-strong);
  font-variant-numeric: tabular-nums;
}
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-wrap::after,
html[data-cockpit="on"] body.theme-light .cock-select-wrap::after {
  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;
}
