/* kymo Network — strict kymo CI · brand.json source of truth */

@font-face {
  font-family: 'TodayBEF';
  src: url('../fonts/todaybef-extralight-webfont.woff') format('woff');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'TodayBEF';
  src: url('../fonts/todaybef-regular-webfont.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'TodayBEF';
  src: url('../fonts/todaybef-medium-webfont.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

:root {
  --kymo-blue: #1A2B3C;
  --kymo-blue-90: #293a4b;
  --signal: #309FEA;
  --signal-light: #41ABF1;
  --gold: #9D6525;
  --olive: #90A74E;
  --bg: #FFFFFF;
  --bg-soft: #F6F6F6;
  --bg-warm: #E7E2DB;
  --border: #DDDEE0;
  --grey-light: #E2E2E2;
  --grey-mid: #D8D8D8;
  --text: #343843;
  --text-muted: #5A5F69;
  --text-subtle: #82878C;
  /* aliases — referenced by inline-styled welle-2 sections */
  --muted: #5A5F69;
  /* spacing rhythm (welle 3c — Lou's revised) */
  --space-section: 80px;    /* zwischen Rubriken (war 120) */
  --space-block: 32px;      /* zwischen verwandten Blöcken innerhalb einer Rubrik */
  --space-tight: 24px;      /* CTA bindet enger an vorherigen Inhalt */

  --font-sans: 'TodayBEF', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --font-serif: Constantia, 'Lucida Bright', 'Lucida Serif', Georgia, serif;

  --container-max: 1600px;
  --header-h: 80px;
  --gutter: 56px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: 0.02em;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; display: block; }
a { color: var(--signal); text-decoration: none; }
a:hover { color: var(--signal-light); }
button { font-family: inherit; cursor: pointer; }

.uppercase { text-transform: uppercase; letter-spacing: 0.18em; }
.serif { font-family: var(--font-serif); }
.muted { color: var(--text-muted); }
.subtle { color: var(--text-subtle); font-size: 12px; letter-spacing: 0.08em; }

/* ============ HEADER ============ */
/* ============ MASTHEAD (Cover-vs-Rubrik Header — Welle 3a) ============ */
.app-header.app-header--masthead {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  border-bottom: 2px solid var(--kymo-blue);
  height: auto;
  display: block;
}
.masthead {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 28px var(--gutter) 22px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 32px;
}
.masthead__date {
  font-size: 11px;
  letter-spacing: 0.32em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.masthead__brand {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.masthead__logo {
  height: 96px;
  width: auto;
  display: block;
  max-width: 380px;
}
.masthead__suffix {
  font-size: 10px;
  letter-spacing: 0.4em;
  color: var(--text-subtle);
  text-transform: uppercase;
  margin-top: 4px;
}
.masthead__utils {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: flex-end;
}
.rubric-nav {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  gap: 36px;
  border-top: 1px solid var(--border);
  overflow-x: auto;
}
.rubric-nav__item {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 14px 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.rubric-nav__item:hover { color: var(--kymo-blue); }
.rubric-nav__item.active {
  color: var(--kymo-blue);
  border-bottom-color: var(--kymo-blue);
}
.rubric-nav__item .nav__count {
  margin-left: 6px;
  background: var(--signal);
  color: #fff;
  border-radius: 8px;
  padding: 2px 6px;
  font-size: 9px;
  letter-spacing: 0.04em;
}
/* Volume-Items hervorheben — leicht stärker, Akzent durch Underline-Color */
.rubric-nav__item--volume {
  font-weight: 500;
  color: var(--kymo-blue);
}
.rubric-nav__item--volume.active {
  border-bottom-color: var(--signal);
}
.rubric-nav__item--volume[data-volume="b"].active {
  border-bottom-color: var(--olive);
}

/* ============ SUB-NAV (Volume-spezifische Sub-Sektionen · Welle 4) ============ */
.rubric-subnav {
  position: sticky;
  top: var(--header-h);
  z-index: 49;
  background: var(--bg-soft);
  border-bottom: 1px solid var(--border);
}
.rubric-subnav[hidden] { display: none; }
.rubric-subnav__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 12px var(--gutter);
  display: flex;
  align-items: center;
  gap: 24px;
}
.rubric-subnav__folio {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.rubric-subnav__folio::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--signal);
  display: inline-block;
}
.rubric-subnav--b .rubric-subnav__folio::before { background: var(--olive); }
.rubric-subnav__rule {
  flex: 0 0 32px;
  height: 1px;
  background: var(--border);
}
.rubric-subnav__items {
  display: flex;
  gap: 24px;
  flex: 1;
  overflow-x: auto;
}
.rubric-subnav__item {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 6px 0;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.rubric-subnav__item:hover { color: var(--kymo-blue); }
.rubric-subnav__item.active {
  color: var(--kymo-blue);
  border-bottom-color: var(--kymo-blue);
}

/* ============ VOLUME FRAME (im Surface über rubric-teaser · Welle 4) ============ */
.volume-frame {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  margin: 0 0 28px;
  background: var(--bg-soft);
  border-left: 3px solid var(--signal);
}
.volume-frame--b { border-left-color: var(--olive); }
.volume-frame__kicker {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
  white-space: nowrap;
}
.volume-frame__sep {
  flex: 0 0 24px;
  height: 1px;
  background: var(--border);
}
.volume-frame__hint {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  white-space: nowrap;
}

/* ============ COVER VOLUME INDICES (im Newsroom · Welle 4) ============ */
.cover-volume-indices {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: var(--space-section);
}
@media (max-width: 900px) {
  .cover-volume-indices { grid-template-columns: 1fr; }
}
.cover-volume-card {
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  padding: 36px 32px;
  background: var(--bg-soft);
  border-left: 4px solid var(--signal);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background 0.15s;
}
.cover-volume-card:hover { background: var(--bg); box-shadow: 0 1px 0 var(--border) inset, 0 -1px 0 var(--border) inset; }
.cover-volume-card--b { border-left-color: var(--olive); }
.cover-volume-card__kicker {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
}
.cover-volume-card__title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  font-size: 28px;
  line-height: 1.2;
  color: var(--kymo-blue);
}
.cover-volume-card__counts {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
}
.cover-volume-card__counts strong {
  color: var(--kymo-blue);
  font-weight: 500;
}
.cover-volume-card__cta {
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--signal);
  margin-top: 6px;
}
.cover-volume-card--b .cover-volume-card__cta { color: var(--olive); }

/* Brief-Banner-Slim: nur Title-Zeile, kein Logo (steht im Masthead) */
.brief-banner.brief-banner--slim {
  display: block;
  border-bottom: 1px solid var(--border);
  padding: 0 0 18px 0;
  margin-bottom: 32px;
  background: transparent;
}
.brief-banner.brief-banner--slim .brief-banner__title {
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  display: flex;
  gap: 56px;
  align-items: baseline;
}

/* ============ LEGACY (alte App-Header — bleiben weil noch verwendet?) ============ */
.app-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  height: var(--header-h);
  display: flex;
  align-items: center;
}
.app-header__inner {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 32px;
}
.brand {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 28px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1;
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
}
.brand__suffix {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 400;
}
.nav {
  display: flex;
  gap: 32px;
  justify-self: center;
}
.nav__item {
  background: none;
  border: 0;
  padding: 8px 0;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  position: relative;
  transition: color 0.2s;
}
.nav__item:hover { color: var(--kymo-blue); }
.nav__item.active { color: var(--kymo-blue); }
.nav__item.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: var(--signal);
}
.app-header__right {
  display: flex;
  gap: 24px;
  align-items: center;
}
.market-switch {
  background: none;
  border: 1px solid var(--border);
  padding: 8px 16px 8px 18px;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 400;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.market-switch::after {
  content: '↓';
  font-size: 10px;
  color: var(--text-subtle);
}
.market-switch:hover { border-color: var(--kymo-blue); }

/* Cover-Bands · Welle 11 · Role-gated cover sections */
.cover-band--action,
.cover-band--lead-pass,
.cover-band--heatmap {
  padding: 32px 36px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-warm);
  box-shadow: inset 0 1px 0 rgba(26,43,60,0.04);
}
.cover-band--action[hidden],
.cover-band--lead-pass[hidden],
.cover-band--heatmap[hidden] {
  display: none;
}
.cover-band__band-kicker {
  font-family: var(--font-sans, -apple-system, sans-serif);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 16px;
  color: var(--text-muted);
}
.cover-band__band-kicker--gold { color: #9D6525; }
.cover-band__band-kicker--signal { color: #309FEA; }
.cover-band__band-kicker--olive { color: #6B7F3A; }
.cover-band__band-title {
  font-family: var(--font-sans, sans-serif);
  font-size: 22px;
  font-weight: 200;
  letter-spacing: 0.01em;
  margin: 0 0 12px;
}
.cover-band__band-title em {
  font-family: 'Constantia', Georgia, serif;
  font-style: italic;
  font-weight: 400;
}
/* Today's Action — Trigger / Cold-Call cards */
.action-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  margin-top: 8px;
}
.action-card {
  border: 1px solid var(--border); padding: 14px 16px;
  background: var(--bg);
  display: flex; flex-direction: column; gap: 6px;
  text-align: left;
  font-family: 'TodayBEF', sans-serif;
}
.action-card__name { font-size: 14px; font-weight: 500; color: var(--kymo-blue); }
.action-card__why { font-size: 12px; color: var(--text-muted); line-height: 1.5; }
/* P2 · Strength-Pill — 20×20 Quadrat, weiß auf Vollfarbe, identisch zu .rl-strength-pill */
.action-card__strength {
  align-self: flex-start;
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; border-radius: 2px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 500; font-size: 11px; letter-spacing: 0.02em;
  color: #fff;
  margin-top: 6px;
}
.action-card__strength--A { background: var(--gold); }
.action-card__strength--B { background: var(--signal); }
.action-card__strength--C { background: var(--olive); }
/* Coverage Heatmap — Reps × Markets grid · P1 Welle 22 */
.heatmap-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 11px;
}
.heatmap-table th, .heatmap-table td {
  padding: 12px 14px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
/* Border only between columns (not outer left) */
.heatmap-table th + th,
.heatmap-table td + td {
  border-left: 1px solid var(--border);
}
.heatmap-table thead th {
  background: transparent;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 500; font-size: 10px;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-muted);
  border-bottom: 2px solid var(--border);
}
/* Rep name column — Constantia italic in kymo-blue */
.heatmap-table tbody td:first-child {
  text-align: left;
  font-family: 'Constantia', Georgia, serif;
  font-style: italic;
  font-size: 14px;
  color: var(--kymo-blue);
  font-weight: 400;
}
/* Heatmap cell: number + bar layout */
.heatmap-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}
.heatmap-cell__num {
  font-family: 'Constantia', Georgia, serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 1;
}
.heatmap-cell__bar-wrap {
  width: 100%;
  height: 3px;
  background: rgba(26,43,60,0.07);
  border-radius: 1px;
  overflow: hidden;
}
.heatmap-cell__bar {
  height: 100%;
  border-radius: 1px;
  transition: width 0.4s ease;
}
.heatmap-cell--high .heatmap-cell__num { color: #9D6525; }
.heatmap-cell--high .heatmap-cell__bar { background: var(--gold); }
.heatmap-cell--mid .heatmap-cell__num  { color: #1F7DBA; }
.heatmap-cell--mid .heatmap-cell__bar  { background: var(--signal); }
.heatmap-cell--low .heatmap-cell__num  { color: #5A6B26; }
.heatmap-cell--low .heatmap-cell__bar  { background: var(--olive); }
.heatmap-cell--none .heatmap-cell__num { color: var(--text-subtle); }

/* Lead-Pass · Olga */
.lead-pass-inbox { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.lead-pass-card {
  border: 1px solid var(--border); padding: 16px 18px;
  background: var(--bg);
  display: grid; grid-template-columns: 1fr auto; gap: 14px;
}
.lead-pass-card__from {
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-muted);
}
.lead-pass-card__title { font-size: 15px; margin: 4px 0 6px; color: var(--kymo-blue); }
.lead-pass-card__body { font-size: 12px; color: var(--text-muted); }
.lead-pass-card__actions { display: flex; flex-direction: column; gap: 6px; align-self: center; }
.lead-pass-card__actions button {
  padding: 6px 14px; font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; cursor: pointer;
  background: #fff; border: 1px solid var(--border); color: var(--kymo-blue);
}
.lead-pass-card__actions button.commit { background: #5A8C3D; color: #fff; border-color: #5A8C3D; }
.lead-pass-card__actions button.decline { color: var(--text-muted); }

/* View-Badge (welle 6 sprint 16b) — Provenance-Pille auf Story-Cards */
[data-lead-id] { position: relative; }
.view-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  font-family: var(--font-sans, -apple-system, sans-serif);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 4px 8px 3px;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border: 1px solid rgba(26, 43, 60, 0.12);
  z-index: 5;
  pointer-events: none;
  white-space: nowrap;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.view-badge--gold {
  color: #9D6525;
  border-left: 2px solid #9D6525;
}
.view-badge--olive {
  color: #6B7F3A;
  border-left: 2px solid #90A74E;
}
.view-badge--signal {
  color: #1F7DBA;
  border-left: 2px solid #309FEA;
}
.view-badge--player::before {
  content: '✦  ';
  opacity: 0.7;
}

/* View-Switcher (welle 6 sprint 16) — Top-Nav Dropdown */
.view-switch { position: relative; display: inline-block; }
.view-switch__btn {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  padding: 7px 12px 7px 14px;
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 400;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: all 0.15s;
}
.view-switch__btn:hover {
  border-color: var(--kymo-blue);
  background: var(--bg);
}
.view-switch__label-prefix {
  color: var(--text-subtle);
  font-size: 9px;
  letter-spacing: 0.18em;
}
.view-switch__label {
  color: var(--kymo-blue);
  font-weight: 500;
}
.view-switch__caret {
  font-size: 9px;
  color: var(--text-subtle);
  margin-left: 2px;
}
.view-switch__menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 320px;
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: 0 6px 24px rgba(26, 43, 60, 0.10);
  z-index: 100;
  padding: 8px 0;
}
.view-switch__menu[hidden] { display: none; }
.view-switch__group {
  padding: 8px 16px 4px;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-subtle);
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.view-switch__option {
  display: flex;
  flex-direction: column;
  width: 100%;
  background: none;
  border: 0;
  text-align: left;
  padding: 8px 16px;
  cursor: pointer;
  transition: background 0.15s;
}
.view-switch__option:hover { background: var(--bg-soft); }
.view-switch__option--active {
  background: var(--bg-soft);
  border-left: 2px solid var(--gold);
  padding-left: 14px;
}
.view-switch__option-name {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--kymo-blue);
  letter-spacing: 0.04em;
}
.view-switch__option-meta {
  font-family: var(--font-sans);
  font-size: 10px;
  color: var(--text-muted);
  margin-top: 2px;
  letter-spacing: 0.02em;
}
.fab {
  width: 40px; height: 40px;
  background: var(--kymo-blue);
  color: #fff;
  border: 0;
  border-radius: 50%;
  font-size: 24px;
  font-weight: 200;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
.fab:hover { background: var(--signal); }

.header-search {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  padding: 8px 12px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.15s;
}
.header-search:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
  background: var(--bg);
}
.header-search__icon {
  font-size: 14px;
  color: var(--kymo-blue);
}
.header-search__label {
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 10px;
}
.header-search__shortcut {
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 2px 6px;
  font-size: 9px;
  color: var(--text-subtle);
  letter-spacing: 0.04em;
  font-family: monospace;
}

/* ============ SURFACE WRAPPERS ============ */
.surface { display: none; min-height: calc(100vh - var(--header-h)); }
.surface.active { display: block; }
.surface__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 48px var(--gutter) 80px;
}

/* ============ BRIEF SURFACE ============ */
/* Editorial masthead — three-column "newspaper plate": mast / dateline / vol-issue. */
.brief-banner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  padding: 28px 0 24px;
  border-top: 2px solid var(--kymo-blue);
  border-bottom: 1px solid var(--border);
  position: relative;
  margin-bottom: 56px;
}
.brief-banner::after {
  /* dezenter Doppelstrich-Editorial-Akzent unter dem Banner */
  content: '';
  position: absolute;
  left: 0; right: 0;
  bottom: -5px;
  height: 1px;
  background: var(--border);
}
.brief-banner__masthead {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  justify-self: start;
}
.brief-banner__mast-mark {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 22px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1;
}
.brief-banner__mast-divider {
  width: 1px;
  height: 14px;
  background: var(--border);
}
.brief-banner__mast-name {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 400;
}
.brief-banner__title {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  text-align: center;
  justify-self: center;
}
.brief-banner__date {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.brief-banner__vol {
  color: var(--kymo-blue);
  font-weight: 500;
}
.brief-banner__vol-sep {
  color: var(--text-subtle);
  opacity: 0.5;
}
.brief-banner__issue {
  color: var(--text-muted);
}
@media (max-width: 880px) {
  .brief-banner {
    grid-template-columns: 1fr;
    gap: 10px;
    text-align: center;
    padding: 22px 0 18px;
  }
  .brief-banner__masthead, .brief-banner__date { justify-self: center; }
  .brief-banner__title { text-align: center; }
}

.brief-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 56px;
}
@media (max-width: 1100px) {
  .brief-grid { grid-template-columns: 1fr; }
}

/* HERO STORY (kymo Hero-Style: Bild + weiße Border-Box-Headline) */
.hero-story {
  position: relative;
  background: var(--kymo-blue);
  aspect-ratio: 16 / 10;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.4s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.hero-story:hover { transform: translateY(-2px); }
.hero-story__img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.85) saturate(0.95);
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.hero-story:hover .hero-story__img { transform: scale(1.02); }
.hero-story__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(26,43,60,0.55) 0%, rgba(26,43,60,0) 50%);
}
.hero-story__caption {
  position: absolute;
  left: 32px; right: 32px; bottom: 32px;
  color: #fff;
}
.hero-story__kicker {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 400;
  opacity: 0.85;
  margin-bottom: 12px;
}
.hero-story__headline-box {
  display: inline-block;
  border: 4px solid #fff;
  padding: 18px 28px 16px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 36px;
  line-height: 1;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.story-pull {
  margin-top: 32px;
  padding-bottom: 8px;
}
.story-pull__quote {
  font-family: var(--font-serif);
  font-size: 26px;
  line-height: 1.4;
  color: var(--kymo-blue);
  font-weight: 400;
  letter-spacing: 0;
  max-width: 760px;
}
.story-pull__meta {
  margin-top: 24px;
  display: flex;
  gap: 24px;
  align-items: center;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.story-pull__cta {
  background: none;
  border: 0;
  padding: 0;
  color: var(--signal);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.story-pull__cta::after { content: ' →'; }
.story-pull__body {
  margin-top: 18px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text);
  letter-spacing: 0.01em;
  max-width: 760px;
}

/* Project related — at the bottom of project detail */
.project-related {
  margin-top: 24px;
  padding-top: 8px;
}
.project-related .section-kicker {
  margin-top: -16px;
  margin-bottom: 24px;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 400;
}
.related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 1000px) { .related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .related-grid { grid-template-columns: 1fr; } }
.related-card {
  background: none;
  border: 1px solid var(--border);
  cursor: pointer;
  text-align: left;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s, border-color 0.15s, box-shadow 0.2s;
  overflow: hidden;
  padding: 0;
}
.related-card:hover {
  transform: translateY(-2px);
  border-color: var(--kymo-blue);
  box-shadow: 0 8px 24px rgba(26,43,60,0.06);
}
.related-card__visual {
  aspect-ratio: 16 / 10;
  width: 100%;
  overflow: hidden;
}
.related-card__visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.related-card:hover .related-card__visual img { transform: scale(1.04); }
.related-card__body {
  padding: 16px 18px 18px;
}
.related-card__kicker {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 6px;
}
.related-card__title {
  font-size: 15px;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  margin-bottom: 6px;
  line-height: 1.3;
}
.related-card__why {
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.02em;
  line-height: 1.45;
}

/* Hero · Editorial continuation block */
.story-pull__body {
  font-size: 15px;
  line-height: 1.75;
  max-width: 100%;
}
/* Drop-Cap auf story-pull__body deaktiviert 2026-05-04 (Denis-Feedback: float bricht Layout) */
/*
.story-pull__body::first-letter {
  font-family: var(--font-serif);
  font-size: 52px;
  line-height: 0.9;
  float: left;
  padding: 6px 12px 0 0;
  color: var(--kymo-blue);
  font-weight: 400;
}
*/

/* ============ TOP STORY · ARTICLE-MODE (welle 3e Sprint 1+) ============
 * Erweiterte Top Story: längerer Body + Inline-Galerie + Right-Rail bleibt sticky.
 */
.story-pull__body--secondary,
.story-pull__body--tertiary {
  margin-top: 18px;
  font-size: 15px;
  line-height: 1.75;
  color: var(--text);
}
.hero-story__inline-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  margin: 28px 0 12px;
}
.hero-story__inline-gallery__item {
  position: relative;
  aspect-ratio: 1/1;
  background: var(--bg-soft);
  overflow: hidden;
  cursor: pointer;
}
.hero-story__inline-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.hero-story__inline-gallery__item:hover img { transform: scale(1.04); }
.hero-story__inline-gallery__caption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 10px 12px;
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  background: linear-gradient(180deg, transparent, rgba(26,43,60,0.85));
  color: #fff;
}

.editorial-accent {
  margin: 36px 0 32px;
  padding: 28px 32px 26px;
  border-left: 3px solid var(--gold);
  background: linear-gradient(to right, rgba(157,101,37,0.04) 0%, rgba(157,101,37,0) 100%);
}
.editorial-accent__kicker {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  font-weight: 500;
}
.editorial-accent__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.45;
  color: var(--kymo-blue);
  letter-spacing: 0.005em;
  font-weight: 400;
}
.editorial-accent__attribution {
  margin-top: 14px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
}

.author-strip {
  margin-top: 36px;
  padding-top: 22px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 16px;
}
.author-strip__avatar {
  width: 36px; height: 36px;
  background: var(--bg-warm);
  color: var(--kymo-blue);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.author-strip__meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.author-strip__byline {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 400;
}
.author-strip__line {
  font-size: 13px;
  color: var(--kymo-blue);
  letter-spacing: 0.01em;
}
.author-strip__line strong { font-weight: 500; }
.author-strip__cta {
  background: none;
  border: 0;
  padding: 0;
  color: var(--signal);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  font-weight: 400;
  font-family: var(--font-sans);
}
.author-strip__cta::after { content: ' →'; }
.author-strip__cta:hover { color: var(--kymo-blue); }

/* Editorial section labels */
.section-kicker {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  display: block;
  font-weight: 400;
}

/* Pipeline section · beige magazine band — same width as rest, no full-bleed overflow */
.pipeline-section {
  margin-top: 80px;
  padding: 56px 36px;
  background: var(--bg-warm);
  border: 1px solid var(--border);
  overflow: hidden;
}
.pipeline-section__inner {
  max-width: 100%;
  margin: 0;
  padding: 0;
}
.pipeline-section .section-kicker {
  border-bottom-color: rgba(26,43,60,0.18);
  color: var(--kymo-blue);
}
.pipeline-section__header {
  margin-bottom: 28px;
}
.pipeline-section__sub {
  font-size: 13px;
  color: var(--text-muted);
  letter-spacing: 0.02em;
  margin-top: -6px;
  padding-bottom: 4px;
}
.pipeline-rail-wrap {
  position: relative;
  padding: 0 56px;
}
.pipeline-rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 1fr);
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 4px 0 18px;
  margin: -4px 0 0;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
  align-items: stretch;
}
.pipeline-rail::-webkit-scrollbar { height: 6px; }
.pipeline-rail::-webkit-scrollbar-track { background: transparent; }
.pipeline-rail::-webkit-scrollbar-thumb { background: var(--border); border-radius: 999px; }
.pipeline-rail .pipeline-card { scroll-snap-align: start; }
@media (min-width: 900px) {
  .pipeline-rail { grid-auto-columns: minmax(280px, 320px); }
}
.pipeline-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg);
  border: 1px solid var(--border);
  width: 40px; height: 40px;
  border-radius: 50%;
  font-size: 20px;
  color: var(--kymo-blue);
  cursor: pointer;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 200;
  line-height: 1;
  box-shadow: 0 2px 8px rgba(26,43,60,0.08);
  transition: all 0.15s;
}
.pipeline-arrow:hover { background: var(--kymo-blue); color: #fff; border-color: var(--kymo-blue); }
.pipeline-arrow:disabled { opacity: 0.3; cursor: not-allowed; }
.pipeline-arrow--prev { left: 0; }
.pipeline-arrow--next { right: 0; }
@media (max-width: 700px) {
  .pipeline-arrow { display: none; }
}
#pipeline-meta {
  color: var(--text-subtle);
  font-size: 11px;
  letter-spacing: 0.06em;
}
.pipeline-card {
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 0;
  cursor: pointer;
  text-align: left;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s, border-color 0.15s, box-shadow 0.2s;
  overflow: hidden;
}
.pipeline-card:hover {
  transform: translateY(-2px);
  border-color: var(--kymo-blue);
  box-shadow: 0 8px 24px rgba(26,43,60,0.06);
}
.pipeline-card__visual {
  aspect-ratio: 4 / 3;
  width: 100%;
  overflow: hidden;
  background: var(--bg-warm);
}
.pipeline-card__visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.pipeline-card:hover .pipeline-card__visual img { transform: scale(1.04); }
.pipeline-card__visual--lockup {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  text-align: center;
  position: relative;
}
.pipeline-card__visual--lockup::before,
.pipeline-card__visual--lockup::after {
  content: '';
  position: absolute;
  left: 14px; right: 14px;
  height: 1px;
  background: var(--kymo-blue);
  opacity: 0.4;
}
.pipeline-card__visual--lockup::before { top: 14px; }
.pipeline-card__visual--lockup::after { bottom: 14px; }
.pipeline-card__visual-name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 16px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1.2;
}
.pipeline-card__body {
  padding: 16px 18px 18px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.pipeline-card__kicker {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 6px;
}
.pipeline-card__title {
  font-size: 14px;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  line-height: 1.3;
  margin-bottom: 8px;
}
.pipeline-card__meta {
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.02em;
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: auto;
}
.pipeline-card__meta-row { display: flex; gap: 10px; }
.pipeline-card__meta-label {
  font-size: 8px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  min-width: 50px;
}

/* Rubric sections — Designers / Operators / etc. (issue-style magazine header) */
.rubric {
  margin-top: 96px;
  padding-top: 8px;
}
/* Hero header strip: number · headline · sub on left, thematic image on right */
.rubric__header {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 40px;
  align-items: stretch;
  margin-bottom: 36px;
  padding: 36px 0 28px 0;
  border-top: 1px solid var(--kymo-blue);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 5px 0 -4px var(--border);
  position: relative;
}
.rubric__header .rubric__hero { min-height: 240px; }
.rubric__header::before {
  /* dezente zweite hauchdünne Linie 4px über dem kymo-blue-Border (editorial double rule) */
  content: '';
  position: absolute;
  left: 0; right: 0;
  top: -5px;
  height: 1px;
  background: var(--border);
}
.rubric__header-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}
.rubric__number {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 13px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.rubric__number::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
  max-width: 80px;
}
.rubric__title {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: clamp(32px, 4.4vw, 52px);
  line-height: 1.02;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  margin: 0 0 14px 0;
}
.rubric__title em {
  font-style: italic;
  font-family: var(--font-serif, Constantia, Georgia, serif);
  font-weight: 300;
  letter-spacing: 0.01em;
  text-transform: none;
  /* Color set per-rubric below */
}
.rubric__sub {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-muted);
  letter-spacing: 0.01em;
  margin: 0;
  max-width: 52ch;
}
.rubric__hero {
  position: relative;
  min-height: 180px;
  background: var(--bg-warm);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.rubric__hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(26,43,60,0.18) 0%, rgba(26,43,60,0) 55%);
  pointer-events: none;
}

/* Per-rubric accent — 4 distinct accent colors. Akzent wandert vom 4px-Container-Border zur Header-Underline + 6×6 Kicker-Quadrat (welle 3a) */
.rubric {
  padding: 64px 36px 56px;
  margin-top: var(--space-section);
  border: none;
  position: relative;
}
/* Editorial-Quadrat vor dem rubric__number (Akzent statt Container-Border) */
.rubric__number::before {
  content: '';
  width: 6px;
  height: 6px;
  background: currentColor;
  display: inline-block;
  margin-right: 4px;
  flex: 0 0 auto;
}
/* 2px Header-Underline statt 1px (markiert die Rubrik-Sektion) */
.rubric .rubric__header { border-top-width: 2px; }

/* Designers · Gold (warm, creative) — heller BG ohne Band */
.rubric--designers { background: #FFFFFF; }
.rubric--designers .rubric__header { border-top-color: var(--gold); }
.rubric--designers .rubric__number { color: var(--gold); }
.rubric--designers .rubric__title em { color: var(--gold); }
/* welle 5 — statisches Hero raus, Lead-Card unten zeigt das Bild */
.rubric--designers .rubric__header { grid-template-columns: 1fr; }
.rubric--designers .rubric__hero { display: none; }

/* Operators · Signal Blue + warm full-bleed band */
.rubric--operators .rubric__header { border-top-color: var(--signal); }
.rubric--operators .rubric__number { color: var(--signal); }
.rubric--operators .rubric__title em { color: var(--signal); }
.rubric--operators::before {
  content: '';
  position: absolute;
  left: calc(var(--gutter) * -1);
  right: calc(var(--gutter) * -1);
  top: 0; bottom: 0;
  background: var(--bg-warm);
  z-index: -1;
}
.rubric--operators .rubric__header { grid-template-columns: 1fr; }
.rubric--operators .rubric__hero { display: none; }

/* Branded RE · Olive + soft full-bleed band */
.rubric--branded-re .rubric__header { border-top-color: var(--olive); }
.rubric--branded-re .rubric__number { color: var(--olive); }
.rubric--branded-re .rubric__title em { color: var(--olive); }
.rubric--branded-re .rubric__header { grid-template-columns: 1fr; }
.rubric--branded-re .rubric__hero { display: none; }
.rubric--branded-re::before {
  content: '';
  position: absolute;
  left: calc(var(--gutter) * -1);
  right: calc(var(--gutter) * -1);
  top: 0; bottom: 0;
  background: var(--bg-soft);
  z-index: -1;
}
.rubric--branded-re .rubric__hero {
  background-image: url('../../assets/hotels/p-shore-club-resort-residences.jpg');
}

/* Field Signals · kymo Blue */
.rubric--field-signals { background: #FFFFFF; }
.rubric--field-signals .rubric__header { border-top-color: var(--kymo-blue); }
.rubric--field-signals .rubric__number { color: var(--kymo-blue); }
.rubric--field-signals .rubric__title em { color: var(--kymo-blue); }
.rubric--field-signals .rubric__header { grid-template-columns: 1fr; }
.rubric--field-signals .rubric__hero { display: none; }

/* surface__inner braucht overflow visible damit ::before-Bands ausbrechen können */
.surface__inner { overflow: visible; }

/* ============ IN THIS ISSUE · Cover-Index (welle 3c) ============ */
.in-this-issue {
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}
.in-this-issue__heading {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
}
.in-this-issue__kicker {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
  flex: 0 0 auto;
}
.in-this-issue__rule {
  flex: 1;
  height: 1px;
  background: var(--border);
}
.in-this-issue__date {
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.in-this-issue__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--border);
}
@media (max-width: 1100px) { .in-this-issue__grid { grid-template-columns: repeat(2, 1fr); } }
.in-this-issue__teaser {
  background: var(--bg);
  border: none;
  text-align: left;
  padding: 18px 20px 22px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-family: inherit;
  transition: background 0.15s;
}
.in-this-issue__teaser:hover { background: var(--bg-soft); }
.in-this-issue__teaser-rubric {
  font-size: 9px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--text-subtle);
  display: flex;
  align-items: center;
  gap: 6px;
}
.in-this-issue__teaser-rubric::before {
  content: '';
  width: 5px;
  height: 5px;
  background: currentColor;
  display: inline-block;
}
.in-this-issue__teaser--designers .in-this-issue__teaser-rubric { color: var(--gold); }
.in-this-issue__teaser--operators .in-this-issue__teaser-rubric { color: var(--signal); }
.in-this-issue__teaser--branded-re .in-this-issue__teaser-rubric { color: var(--olive); }
.in-this-issue__teaser--field .in-this-issue__teaser-rubric { color: var(--kymo-blue); }
.in-this-issue__teaser--connections .in-this-issue__teaser-rubric { color: var(--signal); }
.in-this-issue__teaser-headline {
  font-size: 14px;
  line-height: 1.35;
  color: var(--kymo-blue);
  letter-spacing: 0.01em;
  font-weight: 400;
  margin-top: 2px;
}
.in-this-issue__teaser-arrow {
  margin-top: auto;
  font-size: 10px;
  letter-spacing: 0.3em;
  color: var(--signal);
  text-transform: uppercase;
}

/* ============ RUBRIC FOOTER · ACTION (CTA + View all) (welle 3c) ============ */
.rubric__footer.rubric__footer--action {
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
}
@media (max-width: 700px) { .rubric__footer.rubric__footer--action { grid-template-columns: 1fr; } }
.rubric__contribute {
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0;
  font-family: inherit;
}
.rubric__contribute-kicker {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
}
.rubric__contribute-body {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
}
.rubric__contribute:hover .rubric__contribute-kicker { color: var(--signal); }

.rubric__footer.rubric__footer--action .rubric__view-all {
  background: var(--kymo-blue);
  color: #fff;
  border: none;
  padding: 12px 22px;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}
.rubric__footer.rubric__footer--action .rubric__view-all:hover {
  background: var(--signal);
}

/* ============================================================
 * EDITORIAL MODULE LIBRARY (welle 3d)
 * Kanonische Bausteine — von Monocle inspiriert.
 * Reihenfolge: ATOMS → CARDS → MODULES → BANDS
 * ============================================================ */

/* ---------- ATOM · folio (Magazin-Kicker mit Akzent-Quadrat) ---------- */
.folio {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--text-subtle);
  display: flex;
  align-items: center;
  gap: 8px;
}
.folio::before {
  content: '';
  width: 6px;
  height: 6px;
  background: currentColor;
  display: inline-block;
}
.folio--gold { color: var(--gold); }
.folio--signal { color: var(--signal); }
.folio--olive { color: var(--olive); }
.folio--blue { color: var(--kymo-blue); }

/* ---------- ATOM · byline ---------- */
.byline {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  display: flex;
  gap: 12px;
  align-items: baseline;
}
.byline__sep { color: var(--border); }
.byline__time::before { content: '·'; margin-right: 8px; color: var(--border); }

/* ---------- CARD · story-card--feature (Monocle Featured) ---------- */
.story-card--feature {
  background: none;
  border: none;
  padding: 0;
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 18px;
  font-family: inherit;
  width: 100%;
}
.story-card--feature .story-card__visual {
  width: 100%;
  aspect-ratio: 4/3;
  background: var(--bg-soft);
  overflow: hidden;
  position: relative;
}
.story-card--feature .story-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.story-card--feature:hover .story-card__visual img { transform: scale(1.02); }
.story-card--feature .story-card__visual--lockup {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 24px;
}
.story-card--feature .story-card__visual--lockup-name {
  font-size: 22px;
  font-weight: 200;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--kymo-blue);
}
.story-card--feature .story-card__kicker {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.story-card--feature .story-card__headline {
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.2;
  letter-spacing: 0.005em;
  color: var(--kymo-blue);
  font-weight: 300;
  font-family: var(--font-serif);
  font-style: italic;
}
.story-card--feature .story-card__sub {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-muted);
  letter-spacing: 0.01em;
}
.story-card--feature .story-card__meta {
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--text-subtle);
  text-transform: uppercase;
  margin-top: 4px;
  display: flex;
  gap: 14px;
}
.story-card--feature .story-card__body {
  font-size: 13px;
  line-height: 1.65;
  color: var(--text-muted);
  margin-top: 6px;
}
.cover-band--dark .story-card--feature .story-card__body { color: rgba(255,255,255,0.78); }

/* ---------- CARD · story-card--brief (Minimal · Side-Rail) ---------- */
.story-card--brief {
  background: none;
  border: none;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: inherit;
  width: 100%;
}
.story-card--brief:last-child { border-bottom: none; }
.story-card--brief .story-card__kicker {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.story-card--brief .story-card__headline {
  font-size: 15px;
  line-height: 1.35;
  color: var(--kymo-blue);
  letter-spacing: 0.005em;
  font-weight: 400;
}
.story-card--brief .story-card__meta {
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.story-card--brief:hover .story-card__headline { color: var(--signal); }

/* ---------- MODULE · module-rail (Carousel · Monocle-Style) ---------- */
.module-rail {
  position: relative;
  margin-top: 24px;
}
.module-rail__track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(560px, 75%);
  gap: 28px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0 0 24px 0;
  scroll-padding-left: 0;
}
.module-rail__track::-webkit-scrollbar { display: none; }
.module-rail__track > * { scroll-snap-align: start; }
@media (max-width: 800px) {
  .module-rail__track { grid-auto-columns: minmax(85%, 90%); gap: 16px; }
}
/* Dezente Pfeil-Controls unten — kein Tool-Look */
.module-rail__controls {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 8px;
}
.module-rail__arrow {
  background: none;
  border: 1px solid var(--border);
  width: 36px;
  height: 36px;
  cursor: pointer;
  font-size: 14px;
  color: var(--text-muted);
  font-family: inherit;
  transition: color 0.15s, border-color 0.15s;
}
.module-rail__arrow:hover { color: var(--kymo-blue); border-color: var(--kymo-blue); }
.module-rail__arrow:disabled { opacity: 0.3; cursor: default; }
.module-rail__progress {
  flex: 1;
  height: 1px;
  background: var(--border);
  position: relative;
  margin: 0 12px;
}
.module-rail__progress-fill {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background: var(--kymo-blue);
  transition: width 0.3s, left 0.3s;
}
.module-rail__counter {
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--text-subtle);
  text-transform: uppercase;
}

/* ---------- CARD · story-card--lead (Rubrik-Anchor · Hero + Pull-Quote + Body + Byline) ---------- */
.story-card--lead {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.story-card--lead .story-card__visual {
  width: 100%;
  aspect-ratio: 16/10;
  background: var(--bg-soft);
  overflow: hidden;
  cursor: pointer;
}
.story-card--lead .story-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.story-card--lead .story-card__visual:hover img { transform: scale(1.02); }
.story-card--lead .story-card__visual--lockup {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 32px;
}
.story-card--lead .story-card__visual--lockup-mark {
  font-size: 28px;
  font-weight: 200;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--kymo-blue);
}
.story-card--lead .story-card__visual--lockup-kicker {
  margin-top: 6px;
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.story-card--lead .story-card__kicker {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.story-card--lead .story-card__pull {
  font-family: var(--font-serif);
  font-size: clamp(20px, 1.8vw, 28px);
  line-height: 1.35;
  font-style: italic;
  color: var(--kymo-blue);
  font-weight: 300;
  margin: 0;
}
/* Drop-Cap deaktiviert 2026-05-04 — siehe Welle-3-Bug */
.story-card--lead .story-card__pull::first-letter--off {
  font-size: 3em;
  line-height: 0.85;
  float: left;
  margin: 4px 12px 0 0;
  font-weight: 300;
}
.story-card--lead .story-card__body {
  font-size: 15px;
  line-height: 1.75;
  color: var(--text);
  letter-spacing: 0.01em;
  margin-top: 4px;
}
.story-card--lead .story-card__connection {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  border-top: 1px solid var(--border);
  padding-top: 14px;
}
.story-card--lead .story-card__connection a {
  color: var(--signal);
  text-decoration: none;
  cursor: pointer;
}
.story-card--lead .story-card__connection a:hover { text-decoration: underline; }

/* ---------- MODULE · module-rubric (Lead 2/3 + Side-Rail 1/3) ---------- */
.module-rubric {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 56px;
  margin-top: 32px;
}
@media (max-width: 900px) {
  .module-rubric { grid-template-columns: 1fr; gap: 32px; }
}
.module-rubric__main {
  min-width: 0;
}
.module-rubric__rail {
  min-width: 0;
  align-self: start;
  position: sticky;
  top: 200px;
  display: flex;
  flex-direction: column;
}
.module-rubric__rail-heading {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--kymo-blue);
}

/* ============ COVER-BAND SYSTEM (welle 3e Sprint 1) ============
 * Bänder im Cover-Newsroom — full-bleed Background, Inhalt im Container.
 * Modifier: --soft (grau), --warm (warm), --dark (kymo-blue), --cta.
 * Ersetzt die ::before-Pseudo-Tricks der alten Operators/BRE-Rubriken.
 */
/* Cover-Band — visuell kohärent mit allen anderen Sektionen (Welle 5g).
 * KEIN full-bleed — Bands gleiche Breite wie in-this-issue-band + andere Sektionen.
 * Padding 32px konsistent mit in-this-issue-band. */
.cover-band {
  position: relative;
  margin-top: var(--space-section);
  margin-bottom: 0;
  padding: 32px;
}
.cover-band__inner {
  max-width: 100%;
  margin: 0;
}
/* In-This-Issue ist Cover-Index, kein full-bleed Band — bleibt im Container, hat aber Bg-soft als Card-Stil */
.in-this-issue-band {
  margin-top: var(--space-section);
  padding: 32px;
  background: var(--bg-soft);
}
.in-this-issue-band > .cover-band__heading { margin-bottom: 22px; }
.cover-band__heading {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 28px;
}
.cover-band__kicker {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
  flex: 0 0 auto;
}
.cover-band__rule { flex: 1; height: 1px; background: var(--border); }
.cover-band__date {
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--text-subtle);
  text-transform: uppercase;
}

/* Modifier · Hintergrund-Rhythmus */
.cover-band--soft { background: var(--bg-soft); }
.cover-band--warm { background: var(--bg-warm); }
.cover-band--dark {
  background: var(--kymo-blue);
  color: #fff;
}
.cover-band--dark .cover-band__kicker { color: #fff; }
.cover-band--dark .cover-band__rule { background: rgba(255,255,255,0.18); }
.cover-band--dark .cover-band__date { color: rgba(255,255,255,0.65); }
.cover-band--dark .cover-band__heading--inverse .cover-band__kicker { color: #fff; }

.cover-band--dark .story-card__headline { color: #fff; }
.cover-band--dark .story-card__kicker { color: rgba(255,255,255,0.65); }
.cover-band--dark .story-card__meta { color: rgba(255,255,255,0.65); }
.cover-band--dark .story-card__visual { background: rgba(255,255,255,0.06); }
.cover-band--dark .story-card--feature .story-card__visual::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(26,43,60,0) 60%, rgba(26,43,60,0.35));
  pointer-events: none;
}
.cover-band--dark .story-card--brief {
  border-bottom-color: rgba(255,255,255,0.12);
}
.cover-band--dark .story-card--brief .story-card__headline { color: #fff; }
.cover-band--dark .story-card--brief:hover .story-card__headline { color: var(--signal-light); }

/* 2-Spalten Doppelseite */
.cover-band__doublepage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: stretch;
}
@media (max-width: 900px) {
  .cover-band__doublepage { grid-template-columns: 1fr; gap: 32px; }
}

/* 4-Spalten Module-Grid (In-This-Issue) */
.module-grid {
  display: grid;
  gap: 1px;
  background: var(--border);
}
.module-grid--3 { grid-template-columns: repeat(3, 1fr); }
.module-grid--4 { grid-template-columns: repeat(4, 1fr); }
.module-grid--5 { grid-template-columns: repeat(5, 1fr); }
.module-grid--6 { grid-template-columns: repeat(6, 1fr); }
.cover-band--soft .module-grid { background: var(--bg-soft); }
.cover-band--warm .module-grid { background: var(--bg-warm); }
@media (max-width: 1500px) {
  .module-grid--6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1300px) {
  .module-grid--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1100px) {
  .module-grid--3 { grid-template-columns: repeat(2, 1fr); }
  .module-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .module-grid--5 { grid-template-columns: repeat(2, 1fr); }
  .module-grid--6 { grid-template-columns: repeat(2, 1fr); }
}
.module-grid > .story-card--brief {
  background: var(--bg);
  padding: 28px 26px 30px;
  border-bottom: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 240px;
}
.cover-band--soft .module-grid > .story-card--brief { background: var(--bg-soft); }
.cover-band--warm .module-grid > .story-card--brief { background: var(--bg-warm); }
.in-this-issue-band .module-grid > .story-card--brief { background: var(--bg); }
.module-grid > .story-card--brief .story-card__headline {
  font-size: 16px;
  line-height: 1.35;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  color: var(--kymo-blue);
}
.module-grid > .story-card--brief .story-card__body {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-muted);
  letter-spacing: 0.01em;
  margin: 0;
}
.module-grid > .story-card--brief .story-card__meta {
  margin-top: auto;
  font-size: 10px;
  color: var(--text-subtle);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* Card-Modifier: Inverse (für Dark-Band) */
.story-card--inverse .story-card__headline { color: #fff; }
.story-card--inverse .story-card__kicker { color: rgba(255,255,255,0.7); }

/* Rubrik-Teaser-Header (kürzer als full rubric__header) */
.rubric-teaser__header {
  margin-bottom: 32px;
}
.rubric-teaser__folio {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.rubric-teaser__page { color: var(--text-subtle); }
.rubric-teaser__title {
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 200;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  line-height: 1.04;
  margin: 0 0 12px 0;
}
.cover-band--dark .rubric-teaser__title { color: #fff; }
.rubric-teaser__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  text-transform: none;
  letter-spacing: 0.01em;
  color: var(--gold);
}
.cover-band--dark .rubric-teaser__title em { color: var(--signal-light); }
.rubric-teaser__strapline {
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.55;
  max-width: 52ch;
}
.cover-band--dark .rubric-teaser__strapline { color: rgba(255,255,255,0.7); }

/* "View" CTA-Card als letzte Brief-Card */
.story-card--more {
  background: var(--bg-soft);
  border-bottom: none;
  padding: 18px;
}
.story-card--more .story-card__kicker { color: var(--signal); }
.cover-band--dark .story-card--more {
  background: rgba(255,255,255,0.06);
}
.cover-band--dark .story-card--more .story-card__kicker { color: var(--signal-light); }

/* Cover-Band CTA-Link (Field-Signals Bottom) */
.cover-band__cta-link {
  background: none;
  border: none;
  margin-top: 28px;
  padding: 0;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  cursor: pointer;
  border-bottom: 1px solid var(--kymo-blue);
  padding-bottom: 4px;
}
.cover-band__cta-link:hover { color: var(--signal); border-bottom-color: var(--signal); }

/* CTA-Block (My Connections Pitch) */
.cta-block {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding: 32px 0;
}
.cta-block__kicker {
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--signal);
  font-weight: 500;
}
.cta-block__headline {
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 200;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  line-height: 1.1;
  margin: 16px 0 18px;
}
.cta-block__headline em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  text-transform: none;
  letter-spacing: 0.01em;
}
.cta-block__body {
  font-size: 14px;
  line-height: 1.65;
  color: var(--text-muted);
  margin-bottom: 28px;
  max-width: 580px;
  margin-left: auto;
  margin-right: auto;
}
.cta-block__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.cta-block__primary {
  background: var(--kymo-blue);
  color: #fff;
  border: none;
  padding: 14px 28px;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s;
}
.cta-block__primary:hover { background: var(--signal); }
.cta-block__secondary {
  background: none;
  border: 1px solid var(--border);
  padding: 14px 24px;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.cta-block__secondary:hover { border-color: var(--kymo-blue); color: var(--signal); }

/* Field Signals Pulse (für Cover-Teaser-Header) */
.wire__pulse-label {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  text-transform: none;
  margin-left: 8px;
}

/* Composer + Tabs auf Cover ausblenden (Welle 3e Sprint 1 — gehört auf eigene Field-Signals-Surface) */
#wire-composer-host,
#wire-tabs { display: none !important; }

/* ============ WELLE 3F · RUBRIK-SURFACES · Layout-Hilfsklassen ============ */
/* Sticky bottom CTA-Bar (Field Signals Surface) */
.cta-block-actions-sticky {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  padding: 32px 0;
  margin-top: 48px;
  border-top: 1px solid var(--border);
}
.cta-block-actions-sticky .cta-block__primary,
.cta-block-actions-sticky .cta-block__secondary { font-size: 11px; padding: 13px 22px; }

/* Surface-eigener Composer + Tabs müssen sichtbar bleiben (eigene IDs · überschreibt nichts) */
#field-signals-composer,
#field-signals-tabs { display: flex; }
#field-signals-tabs { gap: 32px; border-bottom: 1px solid var(--border); margin-bottom: 28px; }

/* Surface-Header (Folio + Title + Strapline) hat oben Luft */
#surface-designers .rubric-teaser__header,
#surface-operators .rubric-teaser__header,
#surface-branded-re .rubric-teaser__header,
#surface-field-signals .rubric-teaser__header { padding-top: 16px; margin-bottom: 28px; }

/* Module-rail · Designer/Operator/BRE-Stream — gleicher Stil wie Pipeline */
#designers-stream-rail .module-rail__track,
#operators-stream-rail .module-rail__track,
#bre-stream-rail .module-rail__track {
  grid-auto-columns: minmax(320px, 1fr);
}
#designers-directory-grid .story-card--brief,
#bre-developers-grid .story-card--brief,
#operators-brands-grid .story-card--brief { min-height: 130px; }

/* ============ EXPLORER · Top-Hot-Leads als 3er-Hero-Reihe (welle 5) ============ */
.results-grid__hot-row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}
@media (max-width: 900px) { .results-grid__hot-row { grid-template-columns: 1fr; } }
.result-card.result-card--hero .result-card__img,
.result-card.result-card--hero .result-card__lockup {
  aspect-ratio: 16/10;
  height: auto;
}
.result-card.result-card--hero .result-card__title {
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.25;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  color: var(--kymo-blue);
}
.result-card.result-card--hero .result-card__story {
  font-size: 14px;
  line-height: 1.55;
}
.results-grid__hot-row > .result-card--hero:first-child .result-card__img,
.results-grid__hot-row > .result-card--hero:first-child .result-card__lockup {
  aspect-ratio: 4/3;
}

/* ============ PERSONAL BRIEFING (welle 5e) ============ */
/* welle 6 sprint 9 — Personal Briefing reduced to a single-line magazine masthead pin.
   Stats moved to .cover-stats-strip below the Editor's Letter. */
.personal-briefing {
  margin-top: 8px;
  padding: 12px 0 0;
  margin-bottom: 0;
  border-bottom: 0;
}
.personal-briefing__inner {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0;
}
.personal-briefing__hello {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  font-size: 15px;
  color: var(--kymo-blue);
}
.personal-briefing__hello strong {
  font-weight: 500;
  font-style: normal;
  font-family: var(--font-sans);
}
.personal-briefing__sep {
  margin: 0 10px;
  color: var(--border);
  font-size: 13px;
}
.personal-briefing__market,
.personal-briefing__date {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

/* Cover stats strip · 3 click-jumps under the Editor's Letter */
.cover-stats-strip {
  margin-top: 12px;
  margin-bottom: 28px;
}
.cover-stats-strip__inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-left: 1px solid var(--border);
}
@media (max-width: 720px) {
  .cover-stats-strip__inner { grid-template-columns: 1fr; }
}
.cover-stats-strip__btn {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 14px 18px;
  background: #fff;
  border: 0;
  border-right: 1px solid var(--border);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background .15s ease;
}
.cover-stats-strip__btn:hover {
  background: var(--bg-soft);
}
.cover-stats-strip__num {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 30px;
  line-height: 1;
  flex: 0 0 auto;
}
.cover-stats-strip__label {
  flex: 1 1 auto;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  line-height: 1.3;
}
.cover-stats-strip__arrow {
  font-size: 12px;
  color: var(--text-subtle);
}

/* Standalone folio header (Top Story above Hero on Cover) */
.cover-band__heading--standalone {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 0 0 14px;
  margin: 8px 0 18px;
  border-bottom: 1px solid var(--border);
}

/* ============ FIELD SIGNALS Cards visuell aufwerten (welle 5i) ============ */
.cover-band--warm .module-grid--3 > .story-card--brief {
  background: var(--bg);
  padding: 22px 22px 24px;
  border-left: 3px solid var(--kymo-blue);
  min-height: 160px;
}
.cover-band--warm .module-grid--3 > .story-card--brief .story-card__kicker {
  color: var(--signal);
  font-weight: 500;
}
.cover-band--warm .module-grid--3 > .story-card--brief .story-card__headline {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.35;
}

/* ============ PEOPLE-SUGGESTIONS in My Network (welle 5h) ============ */
.people-suggestions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
}
@media (max-width: 1100px) { .people-suggestions { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .people-suggestions { grid-template-columns: 1fr; } }
.person-card {
  background: var(--bg);
  padding: 18px 20px 16px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.person-card__source-badge {
  position: absolute;
  top: 12px;
  right: 14px;
  font-size: 8px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  background: var(--bg-soft);
  padding: 2px 6px;
}
.person-card--public .person-card__source-badge { color: var(--text-subtle); }
.person-card--crm-sap .person-card__source-badge { color: #fff; background: var(--gold); }
.person-card--crm-hubspot .person-card__source-badge { color: #fff; background: var(--signal); }
.person-card__head { display: flex; flex-direction: column; gap: 2px; padding-right: 100px; }
.person-card__name { font-size: 15px; color: var(--kymo-blue); font-weight: 500; }
.person-card__role { font-size: 11px; color: var(--text-muted); letter-spacing: 0.04em; }
.person-card__affiliation {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-top: 4px;
  font-weight: 500;
}
.person-card__actions {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.person-card__dismiss {
  background: var(--bg);
  border: 1px solid var(--border);
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: inherit;
  font-size: 14px;
  color: var(--text-subtle);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.person-card__dismiss:hover { color: var(--text); border-color: var(--text); }
.person-card__linkedin {
  margin-left: auto;
  font-size: 11px;
  color: var(--signal);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.person-card__linkedin:hover { border-bottom-color: var(--signal); }

/* ============ CALENDAR · Hospitality vs BRE Farb-Trennung (welle 5h) ============ */
.calendar-pill--hospitality { border-left: 3px solid var(--gold); }
.calendar-pill--bre { border-left: 3px solid var(--olive); }
.calendar-pill-filter--hospitality.active { background: var(--gold); color: #fff; border-color: var(--gold); }
.calendar-pill-filter--bre.active { background: var(--olive); color: #fff; border-color: var(--olive); }

/* ============ PROJECT-PEOPLE LinkedIn-Link (welle 5 — Bruno-Mailand-Lesson) ============ */
.player__linkedin {
  display: inline-block;
  margin-top: 6px;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--signal);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s, color 0.15s;
}
.player__linkedin:hover {
  border-bottom-color: var(--signal);
  color: var(--kymo-blue);
}

/* ============ MY NETWORK SURFACE STATS (welle 5) ============ */
.my-network-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 32px;
}
@media (max-width: 1100px) { .my-network-stats { grid-template-columns: repeat(2, 1fr); } }

/* Tab-Counter (small badge) */
.rubric-nav__item .nav__count {
  background: var(--signal);
  color: #fff;
  font-size: 9px;
  letter-spacing: 0.04em;
  padding: 2px 6px;
  border-radius: 10px;
  margin-left: 6px;
}

/* ============ STORY-CARD VISUAL --studio (welle 5) — Designer-Lockup ============ */
.story-card__visual--studio {
  background: linear-gradient(135deg, var(--bg-warm) 0%, #d8d2c8 100%);
}
.story-card__visual--studio .story-card__visual--lockup-mark {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 38px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gold);
}
.story-card__visual--studio .story-card__visual--lockup-kicker {
  margin-top: 8px;
  font-size: 9px;
  letter-spacing: 0.4em;
  color: var(--text-subtle);
  text-transform: uppercase;
}

/* ============ STORY-CARD VISUAL --source (welle 5) — schönerer Press-Lockup ============ */
.story-card__visual--source {
  background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg-warm) 100%);
}
.story-card__visual--source .story-card__visual--lockup-mark {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 32px;
  font-weight: 300;
  letter-spacing: 0.01em;
  color: var(--kymo-blue);
  text-transform: none;
}
.story-card__visual--source .story-card__visual--lockup-kicker {
  margin-top: 6px;
  font-size: 9px;
  letter-spacing: 0.4em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.cover-band--dark .story-card__visual--source {
  background: linear-gradient(180deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.12) 100%);
}
.cover-band--dark .story-card__visual--source .story-card__visual--lockup-mark { color: #fff; }
.cover-band--dark .story-card__visual--source .story-card__visual--lockup-kicker { color: rgba(255,255,255,0.6); }

/* ============ MY CONNECTIONS · Quick-Search Know-Button (welle 4) ============ */
.search-result__know-btn {
  background: var(--bg);
  border: 1px solid var(--border);
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: inherit;
  font-size: 14px;
  color: var(--kymo-blue);
  cursor: pointer;
  margin-right: 12px;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  flex: 0 0 auto;
}
.search-result__know-btn:hover {
  background: var(--kymo-blue);
  color: #fff;
  border-color: var(--kymo-blue);
}
.search-result__know-btn.is-known {
  background: var(--olive);
  color: #fff;
  border-color: var(--olive);
}
.search-result__know-btn.is-known:hover {
  background: var(--gold);
  border-color: var(--gold);
}
.search-result__pill {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 8px;
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--olive);
  color: #fff;
}

/* ============ DROP-CAP (welle 3c — DEAKTIVIERT 2026-05-04 nach Denis-Feedback) ============
 * Drop-Cap funktioniert im aktuellen Pull-Quote-Layout nicht zuverlässig (Float + line-height-Kollision).
 * Wird nach UX-Audit in passenderer Form wiederbelebt. */
/*
.story-pull__quote::first-letter,
.hero-story__pull-quote::first-letter {
  font-family: var(--font-serif);
  font-size: 3.6em;
  line-height: 0.85;
  float: left;
  margin: 4px 10px 0 0;
  color: var(--kymo-blue);
  font-weight: 300;
}
*/

/* (Operators-bg overridden above by .rubric--operators rule) */
.rubric--operators .rubric__header {
  border-top-color: var(--kymo-blue);
  border-bottom-color: rgba(26,43,60,0.18);
}

.rubric__stream {
  display: flex;
  flex-direction: column;
}
.rubric-cta-band-wrap {
  margin-top: 40px;
}
.rubric-cta-band-wrap .cta-band {
  margin: 0;
}

/* Mobile: stack hero image below text */
@media (max-width: 720px) {
  .rubric__header {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .rubric__hero {
    min-height: 140px;
    order: -1;
  }
  .rubric__title {
    font-size: clamp(28px, 8vw, 38px);
  }
}

/* Lead-style rubric header — Top Story · Pipeline · Field Signals */
.rubric__header--lead {
  display: block !important;
  margin-bottom: 32px;
}
.rubric__header--lead .rubric__hero { display: none; }
.rubric__header--lead .wire__counter {
  margin-top: 16px;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
}
/* Field-Signals counter inside the regular 2-col rubric header — editorial mast-line */
.rubric--field-signals .rubric__header .wire__counter {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  text-align: left;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 400;
}
.rubric--field-signals .rubric__header .wire__counter::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--signal);
  display: inline-block;
  animation: pulse 2.4s ease-in-out infinite;
}
.pipeline-section__header { display: none; }

/* Rubric footer · view-all link */
.rubric__footer {
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  text-align: right;
}
.rubric--operators .rubric__footer { border-top-color: rgba(26,43,60,0.18); }
.rubric__view-all {
  background: none;
  border: 0;
  padding: 0;
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--signal);
  cursor: pointer;
  transition: color 0.15s;
}
.rubric__view-all:hover { color: var(--kymo-blue); }

/* More from this market */
.market-more {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
  text-align: center;
}
.market-more__btn {
  background: none;
  border: 1px solid var(--border);
  padding: 14px 36px;
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  transition: all 0.2s;
}
.market-more__btn:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
  background: var(--bg-soft);
}

/* Mini-card action chip */
.mini-card__action {
  margin-top: 10px;
  display: inline-block;
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--signal);
  border-bottom: 1px solid var(--signal);
  padding-bottom: 2px;
}

/* Key-Facts strip under hero pull-quote */
.key-facts {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px 32px;
}
@media (max-width: 800px) {
  .key-facts { grid-template-columns: repeat(2, 1fr); }
}
.key-fact { display: flex; flex-direction: column; gap: 4px; }
.key-fact__label {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 400;
}
.key-fact__value {
  font-size: 14px;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  line-height: 1.35;
}
.key-fact__value.linkable {
  cursor: pointer;
  border-bottom: 1px dotted transparent;
  transition: border-color 0.15s, color 0.15s;
}
.key-fact__value.linkable:hover {
  color: var(--signal);
  border-bottom-color: var(--signal);
}
.key-fact__sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
  letter-spacing: 0.02em;
}
.key-fact__rank {
  display: inline-block;
  background: var(--bg-warm);
  color: var(--kymo-blue);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 2px 7px;
  margin-left: 6px;
}

/* Mini-card key facts (compact) */
.mini-card__facts {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.mini-card__fact {
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.02em;
  line-height: 1.45;
}
.mini-card__fact strong {
  color: var(--kymo-blue);
  font-weight: 400;
}
.mini-card__fact-label {
  font-size: 8px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-right: 6px;
}

/* ALSO TODAY CARDS */
.also-today {
  border-left: 1px solid var(--border);
  padding-left: 40px;
  /* Sticky-Sidebar — bleibt beim Scrollen der langen Top-Story sichtbar */
  position: sticky;
  top: calc(var(--header-h) + 24px);
  align-self: start;
  max-height: calc(100vh - var(--header-h) - 48px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.also-today::-webkit-scrollbar { width: 4px; }
.also-today::-webkit-scrollbar-thumb { background: var(--border); border-radius: 999px; }
@media (max-width: 1100px) {
  .also-today { position: static; max-height: none; overflow: visible; padding-left: 0; border-left: 0; padding-top: 32px; border-top: 1px solid var(--border); }
}
.also-today__heading {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  font-weight: 400;
  display: flex;
  align-items: center;
  gap: 12px;
}
.also-today__heading::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
  max-width: 60px;
}
.mini-card {
  display: block;
  background: none;
  border: 0;
  padding: 0;
  margin-bottom: 32px;
  text-align: left;
  cursor: pointer;
  width: 100%;
}
.mini-card { overflow: hidden; }
.mini-card__img {
  aspect-ratio: 16 / 10;
  width: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1), opacity 0.3s;
}
.mini-card:hover .mini-card__img { transform: scale(1.04); opacity: 0.96; }
.mini-card__kicker {
  margin-top: 14px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.mini-card__title {
  margin-top: 6px;
  font-size: 18px;
  font-weight: 400;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  line-height: 1.3;
}
.mini-card__story {
  margin-top: 10px;
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.55;
}

/* THE WIRE */
.wire {
  margin-top: 96px;
  border-top: 1px solid var(--border);
  padding-top: 40px;
}
.wire__intro {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: end;
  margin-bottom: 32px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--border);
}
.wire__intro-left { max-width: 760px; }
.wire__heading-big {
  font-size: 32px;
  font-weight: 200;
  letter-spacing: 0.02em;
  color: var(--kymo-blue);
  line-height: 1.1;
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.wire__sub {
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.6;
  letter-spacing: 0.01em;
}
.wire__sub strong {
  color: var(--kymo-blue);
  font-weight: 500;
}
.wire__counter {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  text-align: right;
}
.wire__counter strong {
  color: var(--kymo-blue);
  font-weight: 500;
}
.wire__heading {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  display: flex;
  align-items: center;
  gap: 16px;
}

/* Source tabs */
.wire-tabs {
  display: flex;
  gap: 32px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 28px;
}
.wire-tab {
  background: none;
  border: 0;
  padding: 12px 0;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  position: relative;
  transition: color 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.wire-tab:hover { color: var(--kymo-blue); }
.wire-tab.active { color: var(--kymo-blue); }
.wire-tab.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 2px;
  background: var(--signal);
}
.wire-tab__count {
  font-size: 9px;
  letter-spacing: 0.06em;
  background: var(--bg-warm);
  color: var(--kymo-blue);
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 500;
}

/* Wire as card grid */
.wire-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 1100px) { .wire-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .wire-grid { grid-template-columns: 1fr; } }
.signal-card {
  background: var(--bg);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  cursor: default;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.15s;
  animation: fadeInWire 0.6s ease;
  position: relative;
  padding: 28px 26px 22px;
  min-height: 280px;
}
.signal-card.clickable { cursor: pointer; }
.signal-card.clickable:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(26,43,60,0.08);
  border-color: var(--kymo-blue);
}
.signal-card__source-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--kymo-blue);
  color: #fff;
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  padding: 5px 10px;
  font-weight: 500;
  align-self: flex-start;
  margin-bottom: 18px;
}
.signal-card__source-tag--field { background: var(--kymo-blue); }
.signal-card__source-tag--research { background: var(--signal); }
.signal-card__source-tag--press { background: var(--gold); }
.signal-card__quote-mark {
  font-family: var(--font-serif);
  font-size: 56px;
  line-height: 0.6;
  color: var(--bg-warm);
  margin-bottom: 8px;
  user-select: none;
}
.signal-card__story {
  font-family: var(--font-serif);
  font-size: 21px;
  line-height: 1.4;
  color: var(--kymo-blue);
  letter-spacing: 0.005em;
  margin-bottom: 18px;
  flex: 1;
  font-weight: 400;
}
/* Connection-Pattern Strip (Player → Hotel) */
.signal-card__connection {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.signal-card__entity {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.signal-card__entity--clickable { cursor: pointer; transition: all 0.15s; }
.signal-card__entity--clickable:hover { border-color: var(--signal); color: var(--signal); }
.signal-card__entity-kind {
  font-size: 8px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.signal-card__connection-arrow {
  color: var(--text-subtle);
  font-size: 14px;
  font-weight: 200;
}
.signal-card__body { display: contents; }
.signal-card__footer { padding-top: 0; border-top: 0; }
.signal-card__footer {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.signal-card__author-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}
.signal-card__author-avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--bg-warm);
  color: var(--kymo-blue);
  font-size: 10px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.signal-card__author-avatar.is-ai {
  background: var(--kymo-blue);
  color: #fff;
}
.signal-card__author { font-weight: 500; color: var(--kymo-blue); }
.signal-card__source {
  font-size: 11px;
  color: var(--text-subtle);
  letter-spacing: 0.04em;
}
.signal-card__meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.signal-card__time {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.signal-card__action {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.signal-card__action:hover { color: var(--kymo-blue); }
.signal-card__action::after { content: ' →'; }

.signal-card__thank {
  background: none;
  border: 1px solid var(--border);
  padding: 5px 12px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.signal-card__thank:hover {
  border-color: var(--gold);
  color: var(--gold);
}
.signal-card__thank--given {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.signal-card__thank-count {
  font-size: 9px;
  background: rgba(255,255,255,0.25);
  padding: 1px 6px;
  border-radius: 999px;
}
.signal-card__thank--given:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
  opacity: 0.9;
}

/* CTA Cards interleaved between signal cards */
.cta-card {
  border: 1px dashed var(--border);
  background: var(--bg-soft);
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 280px;
  transition: all 0.2s;
  cursor: pointer;
  text-align: left;
  animation: fadeInWire 0.6s ease;
  position: relative;
  font-family: var(--font-sans);
}
.cta-card:hover {
  border-color: var(--kymo-blue);
  background: var(--bg);
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(26,43,60,0.06);
}
.cta-card--add {
  background: var(--kymo-blue);
  border: 1px solid var(--kymo-blue);
  color: #fff;
}
.cta-card--add:hover {
  background: var(--kymo-blue-90);
  border-color: var(--kymo-blue-90);
}
.cta-card--verify {
  background: var(--bg);
  border: 1px solid var(--signal);
}
.cta-card--thanks {
  background: var(--bg-warm);
  border: 1px solid var(--border);
}
.cta-card--pattern {
  background: #2c3a52;
  border: 1px solid #2c3a52;
  color: #fff;
}
.cta-card__kicker {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 14px;
}
.cta-card--add .cta-card__kicker { color: rgba(255,255,255,0.7); }
.cta-card--pattern .cta-card__kicker { color: rgba(255,255,255,0.7); }
.cta-card--verify .cta-card__kicker { color: var(--signal); }
.cta-card--thanks .cta-card__kicker { color: var(--gold); }
.cta-card__icon {
  font-size: 28px;
  margin-bottom: 14px;
  opacity: 0.85;
  font-weight: 200;
  line-height: 1;
}
.cta-card__body {
  font-size: 17px;
  line-height: 1.45;
  letter-spacing: 0.01em;
  flex: 1;
  font-weight: 200;
  color: var(--kymo-blue);
}
.cta-card--add .cta-card__body { color: #fff; font-weight: 200; }
.cta-card--pattern .cta-card__body { color: #fff; font-weight: 200; }
.cta-card__action {
  margin-top: 18px;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 400;
  color: var(--signal);
}
.cta-card--add .cta-card__action { color: #fff; }
.cta-card--pattern .cta-card__action { color: var(--signal-light); }
.cta-card--thanks .cta-card__action { color: var(--gold); }
.cta-card__action::after { content: ' →'; }

/* ============ FIELD SIGNALS · EDITORIAL WIRE ============ */
.wire-stream { display: flex; flex-direction: column; }
.wire-empty { padding: 32px 0; color: var(--text-subtle); font-style: italic; }

.wire-tabs--editorial {
  border-bottom: 1px solid var(--kymo-blue);
  border-top: 1px solid var(--border);
  padding: 14px 0;
  margin-bottom: 0;
  gap: 40px;
}
.wire-tabs--editorial .wire-tab {
  font-size: 10px;
  letter-spacing: 0.32em;
  padding: 4px 0;
}
.wire-tabs--editorial .wire-tab.active::after { display: none; }
.wire-tabs--editorial .wire-tab.active {
  color: var(--kymo-blue);
  font-weight: 500;
}
.wire-tabs--editorial .wire-tab__count {
  background: none;
  color: var(--text-subtle);
  padding: 0 0 0 4px;
  font-size: 9px;
}

/* Lead signal — three-column: visual LEFT, meta, story */
.signal-lead {
  display: grid;
  grid-template-columns: 240px 160px 1fr;
  gap: 36px;
  padding: 32px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--kymo-blue);
  background: linear-gradient(to right, rgba(26,43,60,0.03) 0%, rgba(26,43,60,0) 80px);
  align-items: stretch;
  cursor: pointer;
  animation: fadeInWire 0.6s ease;
  transition: background 0.2s;
  margin-bottom: 24px;
}
.signal-lead:hover {
  background: linear-gradient(to right, rgba(26,43,60,0.05) 0%, rgba(26,43,60,0) 120px);
}
/* Pro-rubric Lead-Signal accents — match rubric__number */
.rubric--designers .signal-lead { border-left-color: var(--gold); }
.rubric--designers .signal-lead .signal-lead__kicker { color: var(--gold); }
.rubric--operators .signal-lead { border-left-color: var(--signal); }
.rubric--operators .signal-lead .signal-lead__kicker { color: var(--signal); }
.rubric--branded-re .signal-lead { border-left-color: var(--olive, #90A74E); }
.rubric--branded-re .signal-lead .signal-lead__kicker { color: var(--olive, #90A74E); }
.rubric--field-signals .signal-lead { border-left-color: var(--kymo-blue); }
.rubric--field-signals .signal-lead .signal-lead__kicker { color: var(--kymo-blue); }
/* Legacy --no-visual support (kept for safety; JS now always emits visual) */
.signal-lead--no-visual { grid-template-columns: 200px 1fr; }
/* Brand-lockup fallback — editorial signature plate when no project / no player matched.
   Note: actual rules placed AFTER .signal-lead__visual / --lockup to win the cascade. */
.signal-lead__visual {
  width: 100%;
  height: 100%;
  align-self: stretch;
  overflow: hidden;
  background: var(--bg-warm);
  position: relative;
  min-height: 240px;
}
.signal-lead__visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.signal-lead:hover .signal-lead__visual img { transform: scale(1.04); }
.signal-lead__visual--lockup {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  text-align: center;
  position: relative;
}
.signal-lead__visual--lockup::before,
.signal-lead__visual--lockup::after {
  content: '';
  position: absolute;
  left: 18px; right: 18px;
  height: 1px;
  background: var(--kymo-blue);
  opacity: 0.4;
}
.signal-lead__visual--lockup::before { top: 18px; }
.signal-lead__visual--lockup::after { bottom: 18px; }
.signal-lead__visual-name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 18px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1.2;
}
/* Brand-lockup fallback — must come AFTER --lockup to override background */
.signal-lead__visual--brand {
  background: var(--kymo-blue);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.signal-lead__visual--brand::before,
.signal-lead__visual--brand::after {
  background: #fff;
  opacity: 0.45;
}
.signal-lead__visual-mark {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 32px;
  letter-spacing: 0.06em;
  color: #fff;
  line-height: 1;
}
.signal-lead__visual-kicker {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  font-weight: 400;
}
@media (max-width: 900px) {
  .signal-lead, .signal-lead--no-visual { grid-template-columns: 1fr !important; }
  .signal-lead__visual { width: 100%; aspect-ratio: 16 / 9; }
}
.signal-lead__meta { display: flex; flex-direction: column; gap: 14px; padding-top: 8px; }
.signal-lead__kicker {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
}
.signal-lead__source-line {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  line-height: 1.5;
}
.signal-lead__source-line strong {
  display: block;
  color: var(--kymo-blue);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.02em;
  margin-bottom: 4px;
}
.signal-lead__time {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.signal-lead__quote {
  font-family: var(--font-serif);
  font-size: 30px;
  line-height: 1.35;
  color: var(--kymo-blue);
  letter-spacing: 0.005em;
  font-weight: 400;
  margin-bottom: 24px;
}
.signal-lead__connection {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}
.signal-lead__connection a {
  color: var(--kymo-blue);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  padding-bottom: 1px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.signal-lead__connection a:hover { color: var(--signal); border-bottom-color: var(--signal); }
.signal-lead__action {
  margin-left: 18px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--signal);
  background: none;
  border: 0;
  cursor: pointer;
}
.signal-lead__action::after { content: ' →'; }

/* Secondary row */
.signal-secondary-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  padding: 32px 0;
  border-bottom: 1px solid var(--border);
}
.signal-secondary { cursor: pointer; animation: fadeInWire 0.6s ease; }
.signal-secondary__head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 14px;
}
.signal-secondary__source-pill {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 500;
}
.signal-secondary__source-pill--field { color: var(--kymo-blue); }
.signal-secondary__source-pill--research { color: var(--signal); }
.signal-secondary__source-pill--press { color: var(--gold); }
.signal-secondary__time {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.signal-secondary__quote {
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.45;
  color: var(--kymo-blue);
  letter-spacing: 0.005em;
  margin-bottom: 14px;
}
.signal-secondary__byline {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}
.signal-secondary__byline strong { color: var(--kymo-blue); font-weight: 500; }

/* Brief items */
.signal-brief {
  display: grid;
  grid-template-columns: 100px 1fr 140px auto;
  gap: 24px;
  padding: 18px 12px;
  margin: 0 -12px;
  border-bottom: 1px solid var(--border);
  align-items: baseline;
  cursor: pointer;
  transition: background 0.15s;
  animation: fadeInWire 0.6s ease;
}
.signal-brief:hover { background: var(--bg-soft); }
.signal-brief__source-tag {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 500;
}
.signal-brief__source-tag--field { color: var(--kymo-blue); }
.signal-brief__source-tag--research { color: var(--signal); }
.signal-brief__source-tag--press { color: var(--gold); }
.signal-brief__body {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.5;
  color: var(--kymo-blue);
  letter-spacing: 0.005em;
}
.signal-brief__byline {
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  text-align: right;
}
.signal-brief__byline strong { color: var(--kymo-blue); font-weight: 500; }
.signal-brief__time {
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  white-space: nowrap;
}
.signal-brief__source-link,
.signal-secondary__source-link,
.signal-lead__source-link {
  color: var(--signal);
  text-decoration: none;
  margin-left: 6px;
  font-size: 12px;
  transition: color 0.15s;
}
.signal-brief__source-link:hover,
.signal-secondary__source-link:hover,
.signal-lead__source-link:hover {
  color: var(--kymo-blue);
}

/* Editorial CTA bands */
.cta-band {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: center;
  padding: 32px 36px;
  margin: 24px 0;
  cursor: pointer;
  text-align: left;
  transition: opacity 0.15s;
  border: 0;
  font-family: var(--font-sans);
  width: 100%;
}
.cta-band:hover { opacity: 0.92; }
.cta-band--add { background: var(--kymo-blue); color: #fff; }
.cta-band--verify {
  background: var(--bg);
  border-top: 1px solid var(--signal);
  border-bottom: 1px solid var(--signal);
}
.cta-band--thanks {
  background: var(--bg-warm);
  border-top: 1px solid rgba(157,101,37,0.18);
  border-bottom: 1px solid rgba(157,101,37,0.18);
}
.cta-band--pattern {
  background: var(--bg);
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
}
.cta-band--pattern .cta-band__kicker { color: var(--gold); }
.cta-band--pattern .cta-band__body { color: var(--kymo-blue); }
.cta-band--pattern .cta-band__action { color: var(--gold); }
.cta-band__kicker {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 500;
  white-space: nowrap;
}
.cta-band--add .cta-band__kicker, .cta-band--pattern .cta-band__kicker { color: rgba(255,255,255,0.65); }
.cta-band--verify .cta-band__kicker { color: var(--signal); }
.cta-band--thanks .cta-band__kicker { color: var(--gold); }
.cta-band__body {
  font-size: 17px;
  line-height: 1.4;
  font-weight: 200;
  letter-spacing: 0.01em;
  color: var(--kymo-blue);
}
.cta-band--add .cta-band__body, .cta-band--pattern .cta-band__body { color: #fff; }
.cta-band__action {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 400;
  color: var(--signal);
  white-space: nowrap;
}
.cta-band--add .cta-band__action { color: #fff; }
.cta-band__action::after { content: ' →'; }

@media (max-width: 900px) {
  .signal-lead { grid-template-columns: 1fr; gap: 20px; padding: 32px 0; }
  .signal-lead__quote { font-size: 22px; }
  .signal-secondary-row { grid-template-columns: 1fr; gap: 24px; }
  .signal-brief { grid-template-columns: 80px 1fr; gap: 12px; }
  .signal-brief__byline, .signal-brief__time { display: none; }
  .cta-band { grid-template-columns: 1fr; gap: 12px; padding: 24px; }
}

/* Wire-Composer — inline "What did you see today?" */
.wire-composer {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 18px;
  align-items: center;
  background: var(--bg-soft);
  padding: 16px 20px;
  margin-bottom: 24px;
  transition: background 0.15s;
}
.wire-composer:focus-within {
  background: #fff;
  outline: 1px solid var(--signal);
}
.wire-composer__avatar {
  width: 56px; height: 56px;
  background: var(--bg-warm);
  color: var(--kymo-blue);
  font-size: 18px;
  font-weight: 200;
  letter-spacing: 0.06em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.wire-composer__input {
  background: none;
  border: 0;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--text);
  letter-spacing: 0.02em;
  width: 100%;
  padding: 8px 0;
}
.wire-composer__input:focus { outline: none; }
.wire-composer__input::placeholder {
  color: var(--text-subtle);
  font-style: normal;
}
.wire-composer__btn {
  background: var(--kymo-blue);
  color: #fff;
  border: 0;
  padding: 10px 20px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 400;
  transition: background 0.15s;
}
.wire-composer__btn:hover {
  background: var(--signal);
}
.wire__pulse {
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--signal);
  border-radius: 50%;
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.4); }
}
.wire__list {
  display: flex;
  flex-direction: column;
}
.wire-item {
  display: grid;
  grid-template-columns: 96px 1fr auto;
  gap: 24px;
  padding: 18px 16px;
  margin: 0 -16px;
  border-bottom: 1px solid var(--border);
  align-items: center;
  animation: fadeInWire 0.6s ease;
  transition: background 0.15s;
  cursor: default;
}
.wire-item:hover {
  background: var(--bg-soft);
}
.wire-item.clickable { cursor: pointer; }
@keyframes fadeInWire {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.wire-item__visual {
  width: 96px;
  height: 64px;
  position: relative;
  overflow: hidden;
}
.wire-item__visual img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.wire-item__visual--lockup {
  background: var(--bg-warm);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
}
.wire-item__visual-name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1.2;
  text-align: center;
}
.wire-item__visual--avatar {
  background: var(--bg-warm);
  display: flex;
  align-items: center;
  justify-content: center;
}
.wire-item__visual--avatar.is-ai {
  background: var(--kymo-blue);
  color: #fff;
}
.wire-item__visual-letters {
  font-size: 22px;
  font-weight: 200;
  letter-spacing: 0.06em;
  color: var(--kymo-blue);
}
.wire-item__visual--avatar.is-ai .wire-item__visual-letters {
  color: #fff;
  font-size: 28px;
}
.wire-item__body {
  font-size: 16px;
  color: var(--kymo-blue);
  line-height: 1.45;
  letter-spacing: 0.01em;
}
.wire-item__source {
  margin-top: 8px;
  font-size: 11px;
  color: var(--text-subtle);
  letter-spacing: 0.04em;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.wire-item__author { font-weight: 500; color: var(--text-muted); }
.wire-item__source-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.badge {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid var(--border);
  border-radius: 2px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.badge--public {
  color: var(--signal);
  border-color: var(--signal);
}
.badge--public::before { content: '◐'; font-size: 10px; }
.badge--internal {
  color: var(--kymo-blue);
  background: var(--bg-soft);
}
.badge--internal::before { content: '●'; color: var(--kymo-blue); font-size: 8px; }
.wire-item__action {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  background: none;
  border: 0;
}
.wire-item__action::after { content: ' →'; }

/* ============ EXPLORER SURFACE ============ */
.explorer-toolbar {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: var(--header-h);
  z-index: 20;
}
.explorer-toolbar__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 14px var(--gutter) 0;
}
.explorer-toolbar__primary {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
  align-items: center;
  padding-bottom: 14px;
}
.explorer-toolbar__advanced {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 32px;
  align-items: center;
  padding: 12px 0 14px;
  border-top: 1px solid var(--border);
  margin-top: 0;
}
.explorer-toolbar__advanced[hidden] { display: none; }
.explorer-divider {
  width: 1px;
  height: 22px;
  background: var(--border);
}
.explorer-modes {
  display: inline-flex;
  border: 1px solid var(--border);
}
.explorer-modes button {
  background: none;
  border: 0;
  padding: 9px 18px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  transition: all 0.15s;
  cursor: pointer;
}
.explorer-modes button:hover { color: var(--kymo-blue); }
.explorer-modes button.active {
  background: var(--kymo-blue);
  color: #fff;
}
.filter-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--text-muted);
}
.filter-group__label {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-right: 4px;
}
.filter-group__hint {
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  opacity: 0.7;
  margin-left: 6px;
}
.filter-group--geo {
  flex-wrap: wrap;
  row-gap: 6px;
}
.filter-group--geo .country-pills-inline {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-left: 10px;
  margin-left: 4px;
  border-left: 1px solid var(--border);
  min-height: 22px;
}
.filter-group--geo .country-pills-inline:empty {
  display: none;
}
.filter-group--connections.is-disabled {
  opacity: 0.42;
  pointer-events: none;
}
.atlas-filter-pill {
  background: none;
  border: 1px solid var(--border);
  padding: 5px 11px;
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  transition: all 0.15s;
  cursor: pointer;
}
.atlas-filter-pill:hover { border-color: var(--kymo-blue); color: var(--kymo-blue); }
.atlas-filter-pill.active {
  border-color: var(--kymo-blue);
  background: var(--kymo-blue);
  color: #fff;
}
.toolbar-toggle {
  margin-left: auto;
  background: none;
  border: 1px solid var(--border);
  padding: 6px 12px 6px 14px;
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.15s;
}
.toolbar-toggle:hover { border-color: var(--kymo-blue); color: var(--kymo-blue); }
.toolbar-toggle[aria-expanded="true"] {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
}
.toolbar-toggle[aria-expanded="true"] .toolbar-toggle__chev::before { content: '−'; }
.toolbar-toggle[aria-expanded="false"] .toolbar-toggle__chev::before { content: '+'; }
.toolbar-toggle__chev {
  display: inline-block;
  font-size: 12px;
  line-height: 1;
  width: 10px;
  text-align: center;
}
.toolbar-toggle__chev::before { content: '+'; }
.toolbar-reset {
  background: none;
  border: 0;
  padding: 6px 8px;
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  cursor: pointer;
  transition: color 0.15s;
}
.toolbar-reset:hover { color: var(--kymo-blue); }

/* Discovery strip */
.discovery-strip {
  background: var(--kymo-blue);
  color: #fff;
  padding: 14px var(--gutter);
  display: flex;
  align-items: center;
  gap: 16px;
}
.discovery-strip__kicker {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  opacity: 0.8;
  flex: 0 0 auto;
}
.discovery-strip__body {
  font-size: 14px;
  letter-spacing: 0.04em;
  flex: 1 1 auto;
  line-height: 1.45;
}
.discovery-strip__body strong {
  font-weight: 500;
  color: var(--signal-light);
}
.discovery-strip__next {
  background: none;
  border: 1px solid rgba(255,255,255,0.4);
  color: #fff;
  padding: 6px 12px;
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  cursor: pointer;
  flex: 0 0 auto;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.discovery-strip__next:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.7);
}
.discovery-strip__next:disabled {
  opacity: 0.3;
  cursor: default;
}
.discovery-strip__next span { font-size: 13px; line-height: 1; }
@media (max-width: 720px) {
  .discovery-strip { flex-wrap: wrap; }
  .discovery-strip__body { flex-basis: 100%; }
  .discovery-strip__next { margin-left: auto; }
}

/* Map area — bounded height now, not viewport */
.explorer-map-wrap {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  background: transparent;
}
.explorer-map-wrap__inner {
  position: relative;
  height: 480px;
  background: var(--bg-soft);
  overflow: hidden;
}
.map {
  width: 100%;
  height: 100%;
  background: var(--bg-soft);
  position: absolute;
  inset: 0;
}

/* Results grid */
.explorer-results {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 48px var(--gutter) 80px;
}
.explorer-results__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 32px;
}
.results-meta {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.results-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
@media (max-width: 1300px) {
  .results-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 980px) {
  .results-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .results-grid { grid-template-columns: 1fr; }
}
.results-grid__section-label {
  grid-column: 1 / -1;
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 24px;
  margin-bottom: -12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.results-grid__section-label:first-child { margin-top: 0; }
.results-grid__section-label--hot {
  color: var(--kymo-blue);
  border-bottom-color: var(--kymo-blue);
}
.results-grid__section-label--hot::before {
  content: '◆ ';
  color: var(--signal);
  margin-right: 4px;
  letter-spacing: 0;
}

/* Show-all CTA — clearly a button, not a card */
.show-all-cta {
  grid-column: 1 / -1;
  background: var(--bg);
  border: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 20px 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  transition: background 0.15s, color 0.15s;
  margin-top: 16px;
}
.show-all-cta:hover {
  background: var(--bg-warm);
  color: var(--signal);
}
.show-all-cta strong {
  font-weight: 500;
  color: var(--signal);
}
.show-all-cta__arrow { font-size: 14px; line-height: 1; }

.result-card {
  background: none;
  border: 0;
  padding: 0;
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  transition: opacity 0.15s, transform 0.2s;
  overflow: hidden;
}
.result-card:hover { transform: translateY(-2px); }
.result-card.dimmed { opacity: 0.35; }
.result-card__img {
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.result-card:hover .result-card__img { transform: scale(1.04); }
.result-card.glow .result-card__img,
.result-card.glow .result-card__lockup {
  outline: 2px solid var(--signal);
  outline-offset: 0;
}
.result-card__img {
  aspect-ratio: 16 / 10;
  width: 100%;
  object-fit: cover;
  background: var(--bg-soft);
}
.result-card__lockup {
  aspect-ratio: 16 / 10;
  width: 100%;
  background: var(--bg-warm);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 16px 14px;
  text-align: center;
  position: relative;
}
.result-card__lockup::before,
.result-card__lockup::after {
  content: '';
  position: absolute;
  left: 12px; right: 12px;
  height: 1px;
  background: var(--kymo-blue);
  opacity: 0.4;
}
.result-card__lockup::before { top: 12px; }
.result-card__lockup::after { bottom: 12px; }
.result-card__lockup-name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 18px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1.2;
}
.result-card__lockup-disc {
  margin-top: 10px;
  font-size: 8px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
/* Brand-logo lockup as visual fallback (better than typo lockup for branded hotels) */
.result-card__brand-lockup {
  aspect-ratio: 16 / 10;
  width: 100%;
  background: var(--bg-warm);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  gap: 12px;
}
.result-card__brand-lockup img {
  max-width: 70%;
  max-height: 60%;
  object-fit: contain;
  filter: contrast(1.05);
}
.result-card__brand-lockup-loc {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.result-card__kicker {
  margin-top: 14px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.result-card__title {
  margin-top: 6px;
  font-size: 16px;
  font-weight: 400;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  line-height: 1.3;
}
.result-card__story {
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.result-card__pills {
  margin-top: 10px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.result-card__pill {
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  border: 1px solid var(--border);
  color: var(--text-muted);
}
.result-card__pill--hot { background: var(--signal); color: #fff; border-color: var(--signal); }
.result-card__pill--warm { background: var(--bg-warm); color: var(--gold); border-color: var(--bg-warm); }
.result-card__pill--cold { color: var(--text-muted); }
.result-card__pill--anchor { color: var(--signal); border-color: var(--signal); }
.result-card__pill--rank { color: var(--kymo-blue); border-color: var(--kymo-blue); }
/* Leaflet override — kymo-Style Pins */
.kymo-pin {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--kymo-blue);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(26,43,60,0.25);
  cursor: pointer;
  transition: transform 0.2s;
}
.kymo-pin:hover { transform: scale(1.15); }
.kymo-pin--hot {
  background: var(--signal);
  width: 22px; height: 22px;
  box-shadow: 0 0 0 6px rgba(48,159,234,0.18), 0 4px 12px rgba(26,43,60,0.3);
  animation: hotPulse 2.4s ease-in-out infinite;
}
@keyframes hotPulse {
  0%, 100% { box-shadow: 0 0 0 6px rgba(48,159,234,0.18), 0 4px 12px rgba(26,43,60,0.3); }
  50% { box-shadow: 0 0 0 11px rgba(48,159,234,0.08), 0 4px 12px rgba(26,43,60,0.3); }
}
.kymo-pin--reference {
  background: var(--kymo-blue);
}
.leaflet-container {
  font-family: var(--font-sans) !important;
  background: #f3eee5 !important;
}
.leaflet-popup-content-wrapper {
  border-radius: 0 !important;
  box-shadow: 0 10px 40px rgba(26,43,60,0.18) !important;
  padding: 0 !important;
}
.leaflet-popup-content {
  margin: 0 !important;
  width: 280px !important;
}
.leaflet-popup-tip { background: #fff !important; }
.popup-card { padding: 0; }
.popup-card__img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
.popup-card__body { padding: 16px 18px 18px; }
.popup-card__kicker {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.popup-card__title {
  margin-top: 6px;
  font-size: 16px;
  color: var(--kymo-blue);
  font-weight: 400;
  letter-spacing: 0.02em;
}
.popup-card__story {
  margin-top: 10px;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
}
.popup-card__cta {
  margin-top: 14px;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
}
.popup-card__cta::after { content: ' →'; }

/* ============ PROJECT SURFACE ============ */
.project-back {
  background: none;
  border: 0;
  padding: 0;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 32px;
}
.project-back::before { content: '← '; }
.project-back:hover { color: var(--kymo-blue); }

.project-hero {
  position: relative;
  width: 100%;
  aspect-ratio: 21 / 9;
  background: var(--kymo-blue);
  margin-bottom: 32px;
  overflow: hidden;
  cursor: zoom-in;
}
.project-hero__img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.78);
  transition: transform 0.8s cubic-bezier(0.2, 0.7, 0.2, 1), filter 0.3s;
}
.project-hero:hover .project-hero__img { transform: scale(1.03); filter: brightness(0.85); }
.project-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(26,43,60,0.5), rgba(26,43,60,0) 60%);
}
.project-hero__caption {
  position: absolute;
  left: 48px; right: 48px; bottom: 48px;
  color: #fff;
}
.project-hero__location {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  opacity: 0.85;
  margin-bottom: 14px;
}
.project-hero__headline-box {
  display: inline-block;
  border: 4px solid #fff;
  padding: 18px 36px 16px;
  font-size: 44px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
}
.project-hero__meta {
  margin-top: 16px;
  font-size: 13px;
  letter-spacing: 0.06em;
  opacity: 0.92;
}

.project-status-bar {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-bottom: 48px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
.status-pill {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 2px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
}
.status-pill--hot { background: var(--signal); color: #fff; }
.status-pill--hot::before { content: '●'; }
.status-pill--warm { background: var(--bg-warm); color: var(--gold); }
.status-pill--warm::before { content: '●'; }
.status-pill--cold { background: var(--bg-soft); color: var(--text-muted); }
.status-pill--cold::before { content: '○'; }
.claim-indicator {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 10px;
}
.claim-indicator__avatar {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--bg-warm);
  color: var(--kymo-blue);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.section-heading {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  margin-bottom: 24px;
}
/* Major: anchors a primary section (Story, People & network, Related) */
.section-heading--major {
  font-size: 12px;
  letter-spacing: 0.36em;
  color: var(--kymo-blue);
  font-weight: 500;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--kymo-blue);
  display: inline-block;
  margin-bottom: 28px;
}
/* Sub: nested heading inside a major section (People / Activity / Connect) */
.section-heading--sub {
  font-size: 10px;
  letter-spacing: 0.28em;
  margin-bottom: 16px;
}

.story-block {
  margin-bottom: 64px;
}
/* The Story is the primary lead — give it slightly more breath */
.story-block--lead {
  margin-bottom: 56px;
}
/* Key facts as compact strip — tighter rhythm */
.story-block--facts {
  margin-bottom: 56px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--border);
}
.story-block__copy {
  font-family: var(--font-serif);
  font-size: 22px;
  line-height: 1.55;
  color: var(--text);
  max-width: 880px;
}
/* Story-block copy in the context-grid is supporting content — slightly smaller */
.project-context-grid .story-block__copy {
  font-size: 18px;
  line-height: 1.6;
}

/* Two-column context — About + From our network side by side */
.project-context-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 80px;
}
.project-context-grid .story-block { margin-bottom: 0; }
@media (max-width: 1000px) {
  .project-context-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* Two-column research — Location + Sources side by side */
.project-research-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 48px;
  margin-bottom: 64px;
}
.project-research-grid .story-block { margin-bottom: 0; }
@media (max-width: 1000px) {
  .project-research-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* Subtle left-accent for project's About + Network blocks (consistent with hero pattern) */
#project-about-block,
#project-network-block {
  padding-left: 24px;
  border-left: 3px solid var(--kymo-blue);
  background: linear-gradient(to right, rgba(26,43,60,0.03) 0%, rgba(26,43,60,0) 80px);
  padding-top: 4px;
  padding-bottom: 4px;
}
#project-network-block {
  border-left-color: var(--signal);
  background: linear-gradient(to right, rgba(48,159,234,0.04) 0%, rgba(48,159,234,0) 80px);
}

.three-col {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 64px;
}
.three-col--people {
  margin-top: 40px;
  margin-bottom: 0;
  padding-top: 28px;
  border-top: 1px solid var(--border);
}
@media (max-width: 1000px) {
  .three-col { grid-template-columns: 1fr; gap: 56px; }
}

.player {
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.player:last-child { border-bottom: 0; }
.player__role {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 4px;
}
.player__name {
  font-size: 16px;
  color: var(--kymo-blue);
  font-weight: 400;
  letter-spacing: 0.02em;
}
.anchor-pill {
  display: inline-block;
  margin-top: 8px;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  border: 1px solid var(--signal);
  padding: 4px 10px;
  border-radius: 2px;
}

.timeline-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 20px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.timeline-item:last-child { border-bottom: 0; }
.timeline-item__when {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.timeline-item__what {
  font-size: 14px;
  color: var(--text);
}

.connect-action {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: 1px solid var(--border);
  padding: 16px 20px;
  margin-bottom: 12px;
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  transition: all 0.2s;
}
.connect-action:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
}
.connect-action::before { content: '+ '; color: var(--signal); }

.reactions {
  display: flex;
  gap: 24px;
  padding: 24px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 56px;
  align-items: center;
}
.reaction-chip {
  background: none;
  border: 1px solid var(--border);
  padding: 8px 14px;
  font-size: 13px;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  letter-spacing: 0.04em;
  border-radius: 999px;
  transition: all 0.2s;
}
.reaction-chip:hover { border-color: var(--kymo-blue); color: var(--kymo-blue); }
.reaction-chip__count { font-size: 11px; color: var(--text-subtle); letter-spacing: 0.06em; }
.reaction-chip--active {
  background: var(--signal);
  border-color: var(--signal);
  color: #fff;
}
.reaction-chip--active .reaction-chip__count { color: rgba(255,255,255,0.85); }
.reaction-chip--pulse { animation: rPulse 0.4s ease; }
@keyframes rPulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.08); }
  100% { transform: scale(1); }
}

.action-bar {
  display: flex;
  gap: 12px;
  padding: 32px 0;
  border-top: 1px solid var(--border);
  align-items: center;
}
/* Grouped action bar — visual separation between watch / triage / primary */
.action-bar__group {
  display: flex;
  gap: 12px;
  align-items: center;
}
.action-bar__group--triage {
  padding-left: 20px;
  margin-left: 8px;
  border-left: 1px solid var(--border);
}
.action-bar__group--primary {
  margin-left: auto;
}

/* Group reactions + action bar so the decision zone reads as one moment */
.project-action-zone {
  margin-top: 64px;
  margin-bottom: 80px;
  padding: 8px 28px 8px;
  background: var(--bg-soft);
  border-left: 3px solid var(--kymo-blue);
}
.project-action-zone .reactions {
  border-top: 0;
  padding-top: 24px;
  padding-bottom: 16px;
  margin-bottom: 0;
}
.project-action-zone .action-bar {
  border-top: 1px solid var(--border);
  padding-bottom: 24px;
}
.action-btn {
  background: none;
  border: 1px solid var(--border);
  padding: 12px 24px;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  transition: all 0.2s;
}
.action-btn:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
}
.action-btn--primary {
  background: var(--kymo-blue);
  border-color: var(--kymo-blue);
  color: #fff;
}
.action-btn--primary:hover {
  background: var(--signal);
  border-color: var(--signal);
}

/* ============ PLAYER ============ */
.player-hero {
  display: grid;
  grid-template-columns: 144px 1fr auto;
  gap: 40px;
  align-items: center;
  padding: 40px 0 48px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 48px;
}
.player-hero__avatar {
  width: 144px; height: 144px;
  background: var(--kymo-blue);
  color: #fff;
  font-size: 48px;
  font-weight: 200;
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
/* Typografische Lockup-Card als "Logo" — kymo-konsistent, copyright-sicher */
.player-hero__lockup {
  width: 220px;
  height: 144px;
  background: var(--bg-warm);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 16px 20px;
  text-align: center;
  position: relative;
}
.player-hero__lockup::before {
  content: '';
  position: absolute;
  top: 8px; left: 8px; right: 8px;
  height: 1px;
  background: var(--kymo-blue);
  opacity: 0.4;
}
.player-hero__lockup::after {
  content: '';
  position: absolute;
  bottom: 8px; left: 8px; right: 8px;
  height: 1px;
  background: var(--kymo-blue);
  opacity: 0.4;
}
.player-hero__lockup-name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 22px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  line-height: 1.15;
}
.player-hero__lockup-discipline {
  margin-top: 14px;
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 400;
}
.player-hero {
  grid-template-columns: 220px 1fr auto;
}

.other-project-row {
  display: grid;
  grid-template-columns: 80px 1fr 120px 100px;
  gap: 24px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  align-items: baseline;
}
.other-project-row:last-child { border-bottom: 0; }
.other-project-row__year {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.other-project-row__name {
  font-size: 15px;
  color: var(--kymo-blue);
}
.other-project-row__role {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}
.other-project-row__loc {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  text-align: right;
}
.player-hero__role {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 8px;
}
.player-hero__name {
  font-size: 38px;
  font-weight: 200;
  letter-spacing: 0.02em;
  line-height: 1.1;
  color: var(--kymo-blue);
  margin-bottom: 10px;
}
.player-hero__sub {
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}
.player-hero__badges {
  margin-top: 16px;
  display: flex;
  gap: 10px;
}
.player-hero__action a {
  text-decoration: none;
  color: #fff;
}
.player-hero__action a.action-btn--primary {
  background: var(--kymo-blue);
  border: 1px solid var(--kymo-blue);
}
.player-hero__action a.action-btn--primary:hover {
  background: var(--signal);
  border-color: var(--signal);
  color: #fff;
}

.player__name.clickable {
  cursor: pointer;
  transition: color 0.15s;
}
.player__name.clickable:hover {
  color: var(--signal);
}
.player__name.clickable::after {
  content: ' →';
  color: var(--signal);
  opacity: 0;
  transition: opacity 0.15s;
}
.player__name.clickable:hover::after {
  opacity: 1;
}

.kymo-project-row {
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.kymo-project-row:last-child { border-bottom: 0; }
.kymo-project-row__year {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.kymo-project-row__name {
  font-size: 15px;
  color: var(--kymo-blue);
  margin-top: 4px;
}
.kymo-project-row__region {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-top: 2px;
}

.empty-state {
  font-size: 13px;
  color: var(--text-subtle);
  font-style: italic;
  padding: 8px 0;
}

/* ============ EXPLORER NETWORK MODE ============ */
.network-canvas {
  width: 100%;
  height: 100%;
  background: var(--bg-soft);
  position: absolute;
  inset: 0;
  display: none;
}
.network-canvas.active { display: block; }
.map.hidden { display: none; }
#network-svg {
  width: 100%;
  height: 100%;
  cursor: grab;
}
.network-node circle {
  cursor: pointer;
  transition: r 0.2s;
}
.network-node:hover circle {
  r: 14;
}
.network-node text {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.04em;
  fill: var(--kymo-blue);
  pointer-events: none;
}
.network-edge {
  stroke: var(--border);
  stroke-width: 1;
  fill: none;
  opacity: 0.5;
}
.network-edge--anchor {
  stroke: var(--signal);
  stroke-width: 2;
  opacity: 0.85;
}

/* Sources list on project */
.sources-disclaimer {
  font-size: 12px;
  color: var(--text-subtle);
  margin-bottom: 16px;
  letter-spacing: 0.04em;
}
.sources-list {
  display: flex;
  flex-direction: column;
}
.source-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
  color: var(--text);
  transition: background 0.15s, padding 0.15s;
}
.source-item:hover {
  color: var(--signal);
  background: var(--bg-soft);
  padding-left: 12px;
  padding-right: 12px;
}
.source-item__label {
  font-size: 14px;
  letter-spacing: 0.02em;
  color: var(--kymo-blue);
}
.source-item:hover .source-item__label { color: var(--signal); }
.source-item__url {
  font-size: 11px;
  color: var(--text-subtle);
  letter-spacing: 0.02em;
}
.source-item__icon {
  font-size: 11px;
  color: var(--signal);
  margin-left: 16px;
}

/* Project mini map */
.project-mini-map {
  width: 100%;
  height: 320px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
}
.project-network-graph {
  width: 100%;
  height: 380px;
  background:
    radial-gradient(circle at center, rgba(48,159,234,0.06) 0%, rgba(48,159,234,0) 55%),
    var(--bg-warm);
  border: 1px solid var(--border);
  overflow: hidden;
}
.project-network-graph svg { width: 100%; height: 100%; display: block; }
.pn-node circle { transition: r 0.2s; }
.pn-node:hover circle { r: 22; }
.pn-node text { font-family: var(--font-sans); font-size: 11px; fill: var(--kymo-blue); pointer-events: none; }
.pn-node--center circle { fill: var(--signal); }
.pn-node--center text { font-weight: 500; fill: var(--kymo-blue); }
.pn-node--anchor circle { fill: var(--kymo-blue); }
.pn-node--player circle { fill: #fff; stroke: var(--kymo-blue); stroke-width: 2.5; }
.pn-node--brand circle { fill: var(--bg-warm); stroke: var(--gold, #9D6525); stroke-width: 2; }
.pn-node--rep circle { fill: var(--bg-warm); stroke: var(--text-muted); stroke-width: 1.5; }
.pn-edge { stroke: var(--border); stroke-width: 1; fill: none; }
.pn-edge--anchor { stroke: var(--signal); stroke-width: 2; opacity: 0.7; }
.pn-edge--brand { stroke: var(--gold, #9D6525); stroke-width: 1.2; opacity: 0.5; stroke-dasharray: 4 4; }
.project-mini-map-meta {
  margin-bottom: 12px;
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}
.project-mini-map-meta strong { color: var(--kymo-blue); font-weight: 500; }

/* ============ NAV COUNT BADGE ============ */
.nav__count {
  display: inline-block;
  background: var(--signal);
  color: #fff;
  font-size: 9px;
  letter-spacing: 0;
  padding: 1px 6px;
  border-radius: 999px;
  margin-left: 6px;
  font-weight: 500;
  vertical-align: middle;
}

/* ============ BRAND ============ */
.brand-hero {
  display: grid;
  grid-template-columns: 220px 1fr auto;
  gap: 40px;
  align-items: center;
  padding: 40px 0 48px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 48px;
}
.brand-hero__lockup {
  width: 220px; height: 144px;
  background: var(--kymo-blue);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
  text-align: center;
}
.brand-hero__lockup-name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 28px;
  letter-spacing: 0.04em;
  line-height: 1.1;
}
.brand-hero__lockup-discipline {
  margin-top: 14px;
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  opacity: 0.7;
}
.brand-hero__meta { flex: 1; }
.brand-pill {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--kymo-blue);
  background: var(--bg-warm);
  padding: 6px 12px;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 8px;
  margin-right: 6px;
}
.brand-pill:hover { background: var(--signal); color: #fff; }

/* ============ EXPLORER HEADER + STATS ============ */
.explorer-header {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 48px var(--gutter) 24px;
}
.explorer-stats-wrap {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 32px var(--gutter) 0;
}
.explorer-discovery-wrap {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 24px var(--gutter) 0;
}
.explorer-discovery-wrap > .discovery-strip {
  padding: 14px 22px;
}
.explorer-map-wrap { padding-top: 0; }
.explorer-stats-section { margin: 0 0 22px 0; }
.explorer-stats-section__header {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 10px;
}
.section-heading__sub {
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted, #999);
  text-transform: none;
  font-weight: 300;
}
.explorer-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 800px) { .explorer-stats { grid-template-columns: repeat(2, 1fr); } }
button.explorer-stat {
  border: none;
  font-family: inherit;
  text-align: left;
  width: 100%;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
}
button.explorer-stat:hover { background: var(--bg-warm); }
button.explorer-stat:active { transform: translateY(1px); }
button.explorer-stat.is-active {
  background: var(--kymo-blue);
  color: #fff;
}
button.explorer-stat.is-active .explorer-stat__value,
button.explorer-stat.is-active .explorer-stat__label,
button.explorer-stat.is-active .explorer-stat__sub { color: #fff; }
.explorer-stat {
  padding: 20px 24px;
  background: var(--bg-soft);
  border-left: 3px solid var(--signal);
}
.explorer-stat--gold { border-left-color: var(--gold); }
.explorer-stat--olive { border-left-color: var(--olive); }
.explorer-stat--blue { border-left-color: var(--kymo-blue); }
.explorer-stat__label {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 8px;
}
.explorer-stat__value {
  font-size: 38px;
  font-weight: 200;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  line-height: 1;
}
.explorer-stat__sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 6px;
  letter-spacing: 0.04em;
}

/* ============ TEAM PROFILE ============ */
.team-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 800px) { .team-stats { grid-template-columns: repeat(2, 1fr); } }
.team-stat {
  padding: 20px 24px;
  background: var(--bg-soft);
  border-left: 3px solid var(--signal);
}
.team-stat__label {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 8px;
}
.team-stat__value {
  font-size: 38px;
  font-weight: 200;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  line-height: 1;
}
.team-stat__sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 6px;
  letter-spacing: 0.04em;
}

.team-tile {
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: padding 0.15s, background 0.15s;
}
.team-tile:hover { background: var(--bg-soft); padding-left: 12px; padding-right: 12px; }
.team-tile:last-child { border-bottom: 0; }
.team-tile__title {
  font-size: 14px;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
}
.team-tile__meta {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
  letter-spacing: 0.02em;
}

/* ============ CALENDAR ============ */
.calendar-canvas {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 24px 0;
}
.calendar-month {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 32px;
  padding: 24px 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
}
.calendar-month__head { display: flex; flex-direction: column; gap: 10px; padding-top: 4px; }
.calendar-month__label {
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
  line-height: 1.4;
}
.calendar-month__stats { display: flex; flex-direction: column; gap: 4px; }
.calendar-month__count {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.calendar-month__count--hot { color: var(--signal); font-weight: 500; }
.calendar-month__count--warm { color: var(--gold); font-weight: 500; }
.calendar-month__items {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.calendar-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--bg-soft);
  border-left: 3px solid var(--text-subtle);
  cursor: pointer;
  font-size: 12px;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
  transition: background 0.15s, transform 0.15s;
}
.calendar-pill:hover { background: var(--bg-warm); transform: translateY(-1px); }
.calendar-pill--hot { border-left-color: var(--signal); background: rgba(48,159,234,0.08); }
.calendar-pill--warm { border-left-color: var(--gold); }
.calendar-pill__name { font-weight: 500; }
.calendar-pill__month {
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: var(--bg);
  padding: 2px 6px;
  border-radius: 2px;
}
.calendar-pill__opening {
  font-size: 9px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  font-style: italic;
}

/* ============ AI INBOX ============ */
.aiinbox-item {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: 18px;
  padding: 20px 0;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.aiinbox-item__body {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.5;
  color: var(--kymo-blue);
}
.aiinbox-item__meta {
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--text-subtle);
  margin-top: 6px;
}
.aiinbox-action {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: none;
  border: 1px solid var(--border);
  padding: 8px 14px;
  cursor: pointer;
  color: var(--text-muted);
  transition: all 0.15s;
}
.aiinbox-action:hover { border-color: var(--kymo-blue); color: var(--kymo-blue); }
.aiinbox-action--publish:hover { background: var(--signal); border-color: var(--signal); color: #fff; }
.aiinbox-action--archive:hover { background: var(--text-subtle); border-color: var(--text-subtle); color: #fff; }
.aiinbox-action--promote:hover { background: var(--gold); border-color: var(--gold); color: #fff; }

/* ============ QUICK SEARCH ============ */
.modal--search {
  width: 720px;
  padding: 0;
  max-height: 70vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.modal--search .modal__textarea {
  border: 0;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
}
.modal--search .modal__textarea:focus { outline: none; }
.search-results {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
}
.search-section {
  padding: 4px 0;
}
.search-section__label {
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-subtle);
  padding: 12px 24px 8px;
}
.search-result {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 24px;
  cursor: pointer;
  transition: background 0.1s;
}
.search-result:hover, .search-result.selected {
  background: var(--bg-soft);
}
.search-result.selected {
  border-left: 3px solid var(--signal);
  padding-left: 21px;
}
.search-result__icon {
  width: 32px; height: 32px;
  background: var(--bg-warm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 500;
  color: var(--kymo-blue);
  letter-spacing: 0.04em;
}
.search-result__body { flex: 1; }
.search-result__title {
  font-size: 14px;
  color: var(--kymo-blue);
  letter-spacing: 0.02em;
}
.search-result__sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
  letter-spacing: 0.02em;
}
.search-result__kind {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.search-hint {
  padding: 12px 24px;
  border-top: 1px solid var(--border);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--text-subtle);
  background: var(--bg-soft);
}
.search-hint kbd {
  display: inline-block;
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 1px 6px;
  font-family: monospace;
  font-size: 10px;
  margin: 0 2px;
}

/* ============ MODAL ============ */
.modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(26, 43, 60, 0.66);
  backdrop-filter: blur(4px);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.25s ease;
}
.modal-backdrop.active { display: flex; }
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.modal {
  background: var(--bg);
  width: 640px;
  max-width: calc(100vw - 64px);
  max-height: calc(100vh - 64px);
  overflow-y: auto;
  padding: 48px;
  position: relative;
  animation: rise 0.35s cubic-bezier(0.2, 0.7, 0.2, 1);
}
@keyframes rise {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.modal__close {
  position: absolute;
  top: 16px; right: 16px;
  background: none;
  border: 0;
  font-size: 22px;
  color: var(--text-subtle);
  width: 36px; height: 36px;
}
.modal__close:hover { color: var(--kymo-blue); }
.modal__title {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  margin-bottom: 24px;
}
.modal__type-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-bottom: 32px;
}
.modal__type-btn {
  background: none;
  border: 1px solid var(--border);
  padding: 24px 12px 20px;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 400;
  transition: all 0.2s;
  text-align: center;
}
.modal__type-btn:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
}
.modal__type-btn.active {
  background: var(--kymo-blue);
  border-color: var(--kymo-blue);
  color: #fff;
}
.modal__field-label {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 10px;
  display: block;
}
.modal__textarea {
  width: 100%;
  border: 1px solid var(--border);
  padding: 16px;
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.6;
  color: var(--text);
  resize: vertical;
  min-height: 100px;
  letter-spacing: 0.02em;
}
.modal__textarea:focus {
  outline: none;
  border-color: var(--signal);
}
.parse-preview {
  margin-top: 20px;
  padding: 18px;
  background: var(--bg-soft);
  border-left: 2px solid var(--signal);
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.6;
}
.parse-preview strong { color: var(--kymo-blue); font-weight: 500; }
.parse-preview__heading {
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 8px;
  display: block;
}
.toggle-row {
  display: flex;
  gap: 24px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.toggle-group {
  display: flex;
  align-items: center;
  gap: 8px;
}
.toggle-group__label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.toggle-pill {
  background: none;
  border: 1px solid var(--border);
  padding: 5px 12px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  border-radius: 2px;
}
.toggle-pill.active {
  border-color: var(--kymo-blue);
  background: var(--kymo-blue);
  color: #fff;
}
.modal__submit {
  margin-top: 32px;
  width: 100%;
  background: var(--kymo-blue);
  color: #fff;
  border: 0;
  padding: 18px;
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 400;
  transition: background 0.2s;
}
.modal__submit:hover { background: var(--signal); }

/* ============ FOOTER ============ */
.app-footer {
  border-top: 1px solid var(--border);
  padding: 32px var(--gutter);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-subtle);
  display: flex;
  justify-content: space-between;
  max-width: var(--container-max);
  margin: 0 auto;
}

/* ============================================================
 * PLAYER · MAGAZIN-FOLIO (welle 3g)
 * 7 Bänder · konsistent mit Cover-Refactor (welle 3e)
 * Hell/Dunkel-Rhythmus: weiß → weiß → soft → DARK → WARM → weiß → weiß
 * ============================================================ */

/* Band 0 — Folio header (back + rubric badge + byline) */
.player-folio {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 32px 0 24px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.player-folio .project-back {
  background: none;
  border: 0;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0;
  cursor: pointer;
  transition: color 0.15s;
}
.player-folio .project-back:hover { color: var(--kymo-blue); }
.player-folio__meta {
  display: flex;
  align-items: baseline;
  gap: 18px;
  flex-wrap: wrap;
}

/* Band 1 — Lead story + sticky side-rail */
.player-band {
  margin-top: 48px;
}
.player-band--lead {
  margin-top: 56px;
  margin-bottom: 0;
}
.player-lead-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 64px;
  align-items: start;
}
@media (max-width: 980px) {
  .player-lead-grid { grid-template-columns: 1fr; gap: 40px; }
}

.player-lead {
  display: flex;
  flex-direction: column;
  gap: 24px;
  min-width: 0;
}
.player-lead__visual {
  width: 100%;
  aspect-ratio: 16/9;
  background: var(--bg-soft);
  overflow: hidden;
  position: relative;
}
.player-lead__visual--image img,
.player-lead__visual--logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.player-lead__visual--logo {
  background: var(--bg-warm);
  display: flex;
  align-items: center;
  justify-content: center;
}
.player-lead__visual--logo img {
  object-fit: contain;
  padding: 40px;
}
.player-lead__visual-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(180deg, rgba(26,43,60,0) 0%, rgba(26,43,60,0.75) 100%);
  color: #fff;
  padding: 32px 24px 16px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

/* welle 6 sprint 7 D · Double-Hero (Werk + Headshot side-by-side) */
.player-lead__visual--double {
  aspect-ratio: auto;
  background: transparent;
}
.player-lead__double {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 12px;
}
@media (max-width: 720px) {
  .player-lead__double { grid-template-columns: 1fr; }
}
.player-lead__double figure {
  margin: 0;
  position: relative;
  overflow: hidden;
  background: var(--bg-soft);
}
.player-lead__work {
  aspect-ratio: 4/3;
}
.player-lead__portrait {
  aspect-ratio: 3/4;
}
.player-lead__double figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.player-lead__double .player-lead__visual-caption {
  font-size: 9px;
  letter-spacing: 0.18em;
  padding: 24px 18px 12px;
}

/* Single-portrait fallback (no work-image, headshot only) */
.player-lead__visual--portrait {
  aspect-ratio: 4/5;
  background: var(--bg-soft);
}
.player-lead__visual--portrait img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

.player-lead__visual--lockup {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-warm);
  border: 1px solid var(--border);
  position: relative;
}
.player-lead__visual--lockup::before,
.player-lead__visual--lockup::after {
  content: '';
  position: absolute;
  left: 24px; right: 24px;
  height: 1px;
  background: var(--kymo-blue);
  opacity: 0.35;
}
.player-lead__visual--lockup::before { top: 24px; }
.player-lead__visual--lockup::after { bottom: 24px; }

/* PATTERN · studio-lockup — typografisches Studio-Lockup */
.studio-lockup {
  text-align: center;
  padding: 48px 32px;
  width: 100%;
}
.studio-lockup__name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: 0.04em;
  line-height: 1.1;
  color: var(--kymo-blue);
  text-transform: uppercase;
}
.studio-lockup__sub {
  margin-top: 18px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  color: var(--text-muted);
  letter-spacing: 0.01em;
}
.studio-lockup__discipline {
  margin-top: 24px;
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

.player-lead__headline {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: clamp(28px, 3.6vw, 48px);
  line-height: 1.1;
  letter-spacing: 0.01em;
  color: var(--kymo-blue);
  margin: 0;
}
.player-lead__headline em {
  font-style: normal;
  color: var(--signal);
}
.player-lead__pull {
  font-family: var(--font-serif);
  font-size: clamp(18px, 1.6vw, 24px);
  line-height: 1.4;
  font-style: italic;
  color: var(--kymo-blue);
  font-weight: 300;
  margin: 0;
  padding: 0 0 0 20px;
  border-left: 2px solid var(--gold);
}
.player-lead__body {
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
  letter-spacing: 0.01em;
  margin: 0;
}
.player-lead .byline {
  border-top: 1px solid var(--border);
  padding-top: 16px;
  margin-top: 8px;
}

/* Player Side-Rail · Sticky Quick-Facts */
.player-rail {
  min-width: 0;
  position: sticky;
  top: 200px;
  align-self: start;
  display: flex;
  flex-direction: column;
}
@media (max-width: 980px) {
  .player-rail { position: static; }
}
.player-rail__heading {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--kymo-blue);
  font-weight: 500;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--kymo-blue);
  margin-bottom: 16px;
}
.player-rail__heading--mid {
  margin-top: 32px;
}
.player-rail__facts {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 8px 16px;
  margin: 0;
}
.player-rail__facts dt {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
  padding-top: 3px;
}
.player-rail__facts dd {
  font-size: 13px;
  line-height: 1.5;
  color: var(--text);
  margin: 0;
}
.player-rail__kymo {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.player-rail__kymo-item {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 12px;
  align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.player-rail__kymo-item:last-child { border-bottom: 0; }
.player-rail__kymo-year {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-subtle);
}
.player-rail__kymo-name {
  font-size: 13px;
  color: var(--kymo-blue);
}
.player-rail__kymo-empty {
  font-size: 12px;
  color: var(--text-subtle);
  font-style: italic;
  line-height: 1.5;
}
.player-rail__connect {
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.player-rail__connect-btn {
  display: block;
  text-align: center;
  padding: 12px 16px;
  border: 1px solid var(--border);
  background: none;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-decoration: none;
  transition: all 0.2s;
}
.player-rail__connect-btn:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
}
.player-rail__connect-btn--primary {
  background: var(--kymo-blue);
  border-color: var(--kymo-blue);
  color: #fff;
}
.player-rail__connect-btn--primary:hover {
  background: var(--signal);
  border-color: var(--signal);
  color: #fff;
}
.player-rail__triage {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.player-rail__triage .connect-action {
  margin-bottom: 8px;
  padding: 12px 16px;
  font-size: 12px;
}

/* Confidence-Dots — semantisches Badge statt ASCII */
.conf-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}
.conf-dot--high { background: var(--olive); }
.conf-dot--medium { background: var(--gold); }
.conf-dot--low { background: var(--text-subtle); }
.cover-band--dark .conf-dot--high { background: var(--signal-light); }

/* Band 2 — Recently completed within Pipeline-Band */
.player-recently {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid rgba(0,0,0,0.06);
}
.player-recently > .folio { margin-bottom: 16px; }

/* Band 3 — relationship-card (Brand-Beziehungs-Karte) */
/* Override module-grid background inside dark band so we control card surfaces directly */
.cover-band--dark #player-brand-rel-grid {
  background: rgba(255,255,255,0.08);
}
.relationship-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 32px 28px;
  background: var(--kymo-blue);
  border: 0;
  text-align: left;
  cursor: default;
  font-family: inherit;
  color: #fff;
  transition: all 0.2s;
  min-height: 240px;
}
button.relationship-card { cursor: pointer; }
.cover-band--dark button.relationship-card:hover {
  background: var(--kymo-blue-90);
  transform: translateY(-2px);
}
.relationship-card__brand-mark {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 22px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.2;
  min-height: 56px;
  display: flex;
  align-items: center;
}
.relationship-card__logo {
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background: rgba(255,255,255,0.95);
  padding: 8px 12px;
  align-self: flex-start;
  max-width: 80%;
}
.relationship-card__logo img {
  max-height: 40px;
  max-width: 100%;
  object-fit: contain;
}
.relationship-card__count {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--signal-light);
  font-weight: 500;
}
.relationship-card__notes {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.85);
  flex: 1;
}
.relationship-card__exclusivity {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.relationship-card__cta {
  margin-top: auto;
  padding-top: 14px;
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--signal-light);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.relationship-card__cta--inert {
  color: rgba(255,255,255,0.45);
}

/* Band 4 — Studio doublepage · 2-Spalten Leadership + Office */
.player-studio-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}
@media (max-width: 900px) {
  .player-studio-grid { grid-template-columns: 1fr; gap: 32px; }
}
.player-studio-col > .folio { margin-bottom: 18px; }
.player-principals {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* PATTERN · principal-card */
.principal-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(0,0,0,0.1);
}
.principal-card:last-child { border-bottom: 0; }
.principal-card__name {
  font-family: var(--font-sans);
  font-weight: 200;
  font-size: 22px;
  letter-spacing: 0.02em;
  color: var(--kymo-blue);
  line-height: 1.15;
}
.principal-card__role {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 2px;
}
.principal-card__linkedin {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--signal);
  text-decoration: none;
  margin-top: 6px;
  display: inline-block;
}
.principal-card__linkedin:hover { text-decoration: underline; }
.principal-card__linkedin--inert {
  color: var(--text-subtle);
  font-style: italic;
}

/* Office address-block */
.player-office-block {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.office-line {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text);
  letter-spacing: 0.01em;
}
.office-line--hq {
  font-size: 16px;
  font-weight: 400;
  color: var(--kymo-blue);
  margin-bottom: 6px;
}
.office-line--additional {
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}
.office-line--mail,
.office-line--web {
  color: var(--signal);
  text-decoration: none;
  font-size: 13px;
}
.office-line--mail:hover,
.office-line--web:hover { text-decoration: underline; color: var(--kymo-blue); }
.office-line--awards {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,0.1);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-style: italic;
}

/* Band 5 — Other notable projects (story-card--brief in module-grid--4) */
#player-band-other .module-grid > .story-card--brief {
  border-bottom: 0;
  border-top: 2px solid var(--kymo-blue);
  padding-top: 18px;
  background: var(--bg-soft);
  padding: 18px 18px 24px;
}
#player-band-other .story-card--brief .story-card__headline {
  font-size: 15px;
  margin-top: 8px;
  color: var(--kymo-blue);
}
#player-band-other .story-card--brief .story-card__kicker {
  font-size: 10px;
  letter-spacing: 0.18em;
}
#player-band-other .story-card--brief .story-card__meta {
  margin-top: 8px;
  font-size: 11px;
  color: var(--text-subtle);
  letter-spacing: 0.04em;
}

/* Band 6 — CTA-Block uses existing .cta-block — keine Anpassung nötig */
#player-band-cta { padding-bottom: 80px; }

/* Pipeline-Band: ensure Story-Cards in --soft band carry visible background */
#player-band-pipeline .story-card--feature {
  background: #fff;
  padding: 14px;
}
#player-band-pipeline .story-card--feature .story-card__visual {
  margin: -14px -14px 16px;
  width: calc(100% + 28px);
}
#player-band-pipeline .module-rail__track {
  grid-auto-columns: minmax(360px, 380px);
  gap: 24px;
}
@media (max-width: 700px) {
  #player-band-pipeline .module-rail__track { grid-auto-columns: minmax(85%, 90%); }
}
#player-band-pipeline .story-card--brief {
  padding: 14px 16px;
  background: #fff;
  border: 0;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
}
#player-band-pipeline .story-card--brief .story-card__headline {
  color: var(--kymo-blue);
}

/* ============ Welle 6 Sprint 2 · Explorer Contact-Cards ============ */
.result-card--contact {
  position: relative;
  background: #fff;
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 14px 14px;
  text-align: left;
  border: 1px solid var(--border);
  border-top: 3px solid var(--kymo-blue);
}
.result-card--contact .result-card__source-badge {
  position: absolute; top: 10px; right: 10px;
  font-size: 9px; letter-spacing: 0.12em; font-weight: 500;
  color: var(--text-subtle);
  border: 1px solid var(--border-soft, var(--border));
  padding: 3px 6px;
  background: var(--bg-soft);
  text-transform: uppercase;
}
.result-card--contact .result-card__avatar {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--kymo-blue); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'TodayBEF', sans-serif; font-weight: 300; font-size: 22px; letter-spacing: 0.03em;
  margin-bottom: 4px;
}
.result-card--contact .result-card__kicker {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-muted);
}
.result-card--contact .result-card__title {
  font-family: 'TodayBEF', sans-serif; font-weight: 300;
  font-size: 18px; color: var(--kymo-blue);
  letter-spacing: 0.01em;
}
.result-card--contact .result-card__affiliation {
  font-size: 12px; cursor: pointer;
  border-bottom: 1px dotted transparent;
  padding-bottom: 1px; align-self: flex-start;
}
.result-card--contact .result-card__affiliation:hover {
  border-bottom-color: var(--text-muted);
}
.result-card--contact .result-card__pills {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px;
}
.result-card__pill--linkedin {
  font-size: 10px; letter-spacing: 0.06em;
  color: var(--signal);
  border: 1px solid var(--signal);
  padding: 2px 6px;
  background: #fff;
  text-decoration: none;
}
.result-card__pill--linkedin:hover {
  background: var(--signal); color: #fff;
}

/* ============ Project-Detail · Companies/Contacts split + Sales-Hint ============ */
.project-people-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 16px;
  margin-bottom: 24px;
}
@media (max-width: 720px) {
  .project-people-split { grid-template-columns: 1fr; }
}
.involved-company {
  padding: 10px 0 12px;
  border-bottom: 1px solid var(--border-soft, var(--border));
  cursor: pointer;
  transition: padding-left .15s ease, color .15s ease;
}
.involved-company:hover {
  padding-left: 4px;
}
.involved-company__role {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.involved-company__name {
  font-family: 'TodayBEF', sans-serif; font-weight: 300; font-size: 17px;
  color: var(--kymo-blue);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.involved-company__pill {
  font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--signal);
  border: 1px solid var(--signal);
  padding: 1px 5px;
  background: rgba(48,159,234,0.06);
}
.involved-company--in-net {
  background: linear-gradient(to right, rgba(48,159,234,0.04) 0%, transparent 100%);
  border-bottom-color: var(--signal);
}
.involved-company--empty {
  color: var(--text-muted); font-size: 12px; font-style: italic;
  cursor: default;
}
.player--in-net {
  background: linear-gradient(to right, rgba(48,159,234,0.05) 0%, transparent 100%);
  padding-left: 8px;
  border-left: 2px solid var(--signal);
}
.anchor-pill--in-net {
  background: var(--signal); color: #fff;
  border: 0;
}

/* ----- Sales-Hint (hot/cold sales hebel) ----- */
.sales-hint {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  margin-bottom: 20px;
  border-left: 3px solid var(--text-muted);
  background: var(--bg-soft);
  font-size: 14px;
  color: var(--text);
}
.sales-hint--warm {
  border-left-color: var(--signal);
  background: rgba(48,159,234,0.06);
  color: var(--kymo-blue);
}
.sales-hint--cold {
  border-left-color: var(--text-muted);
  background: var(--bg-soft);
  color: var(--text-muted);
}
.sales-hint__icon {
  font-size: 16px;
  color: var(--signal);
  font-weight: 600;
}
.sales-hint--cold .sales-hint__icon { color: var(--text-muted); }
.sales-hint em {
  font-style: italic; color: var(--text-muted); font-size: 12px;
}

/* ============ Contact-Detail-Page (NEW Surface · welle 6 sprint 2) ============ */
#surface-contact { background: var(--bg-soft); }
.contact-lead-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  padding: 40px 0;
  align-items: start;
}
@media (max-width: 960px) {
  .contact-lead-grid { grid-template-columns: 1fr; gap: 32px; }
}
.contact-lead {
  position: relative;
  background: #fff;
  padding: 40px;
  border: 1px solid var(--border);
}
.contact-lead__avatar {
  width: 96px; height: 96px;
  border-radius: 50%;
  background: var(--kymo-blue); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'TodayBEF', sans-serif; font-weight: 300; font-size: 36px; letter-spacing: 0.04em;
  margin-bottom: 24px;
}
.contact-lead__source-badge {
  position: absolute; top: 24px; right: 24px;
  font-size: 10px; letter-spacing: 0.14em; font-weight: 500;
  padding: 4px 10px; text-transform: uppercase;
  color: var(--text-subtle);
  border: 1px solid var(--border);
}
.contact-lead__source-badge--public { color: var(--text-subtle); background: var(--bg-soft); }
.contact-lead__source-badge--crm-sap { color: #fff; background: var(--gold); border-color: var(--gold); }
.contact-lead__source-badge--crm-hubspot { color: #fff; background: var(--signal); border-color: var(--signal); }
.contact-lead__source-badge--personal { color: #fff; background: var(--olive); border-color: var(--olive); }

.contact-lead__headline {
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-weight: 400; font-style: italic;
  font-size: 42px; line-height: 1.1;
  color: var(--kymo-blue);
  margin-bottom: 8px;
}
.contact-lead__role {
  font-size: 14px; letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 16px;
}
.contact-lead__affiliations {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 12px;
}
.contact-affiliation-pill {
  display: inline-flex; flex-direction: column; gap: 1px;
  padding: 6px 12px;
  border: 1px solid var(--border);
  background: #fff;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s ease;
}
.contact-affiliation-pill:hover {
  background: var(--bg-soft);
}
.contact-affiliation-pill__type {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 500;
}
.contact-affiliation-pill__name {
  font-size: 13px; color: var(--kymo-blue); font-family: 'TodayBEF', sans-serif; font-weight: 300;
}
.contact-lead__country {
  font-size: 12px; color: var(--text-muted);
  margin-top: 8px; margin-bottom: 24px;
}
.contact-lead__actions {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 16px;
}

.contact-note {
  padding: 10px 12px;
  background: var(--bg-soft);
  margin-bottom: 8px;
  border-left: 2px solid var(--signal);
}
.contact-note--empty {
  border-left-color: var(--border);
  color: var(--text-muted); font-style: italic;
  background: transparent;
}
.contact-note__when {
  font-size: 10px; letter-spacing: 0.08em;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.contact-note__text {
  font-size: 13px; color: var(--text);
}

.contact-pipeline__item {
  display: block; padding: 8px 0;
  border-bottom: 1px solid var(--border-soft, var(--border));
  text-decoration: none;
}
.contact-pipeline__item:hover {
  padding-left: 4px;
}
.contact-pipeline__title {
  font-family: 'TodayBEF', sans-serif; font-weight: 300;
  font-size: 14px; color: var(--kymo-blue);
}
.contact-pipeline__meta {
  font-size: 10px; letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ============ Hospitality · Magazin-Charakter (welle 6 sprint 3a/b) ============ */
/* Editor's letter — short editorial intro above the hero */
.editor-letter {
  margin-top: 48px;
  border-top: 3px solid var(--gold);
  background: #fff;
  border: 1px solid var(--border);
  border-top: 3px solid var(--gold);
}
.editor-letter--bre {
  border-top-color: var(--olive);
}
.editor-letter--cover {
  border-top-color: var(--kymo-blue);
  margin-top: 24px;
  margin-bottom: 32px;
}
.editor-letter--cover .editor-letter__kicker {
  color: var(--kymo-blue);
}
.editor-letter--cover .editor-letter__body::first-letter {
  color: var(--kymo-blue);
}
.editor-letter--network { border-top-color: var(--signal); margin-top: 24px; }
.editor-letter--network .editor-letter__kicker { color: var(--signal); }
.editor-letter--network .editor-letter__body::first-letter { color: var(--signal); }
.editor-letter--calendar { border-top-color: var(--signal-light); margin-top: 24px; }
.editor-letter--calendar .editor-letter__kicker { color: var(--signal-light); }
.editor-letter--calendar .editor-letter__body::first-letter { color: var(--signal-light); }
.editor-letter--pipeline { border-top-color: var(--gold); margin-top: 24px; }
.editor-letter--pipeline .editor-letter__kicker { color: var(--gold); }
.editor-letter--pipeline .editor-letter__body::first-letter { color: var(--gold); }
.editor-letter--signals { border-top-color: var(--kymo-blue); margin-top: 24px; }
.editor-letter--signals .editor-letter__kicker { color: var(--kymo-blue); }
.editor-letter--signals .editor-letter__body::first-letter { color: var(--kymo-blue); }

/* ============ Sales Action Bar (welle 6 sprint 4 · B) ============ */
.sales-action-bar {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-top: 1px solid var(--border-soft, var(--border));
  background: var(--bg-soft);
}
.sales-action-bar--compact {
  padding: 8px 12px;
  gap: 6px;
  font-size: 11px;
}
.sales-action-bar__pill {
  font-size: 9px; letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 7px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text-muted);
  margin-right: auto;
}
.sales-action-bar__pill--queued { color: var(--gold); border-color: var(--gold); background: rgba(157,101,37,0.06); }
.sales-action-bar__pill--touched-fresh { color: var(--signal); border-color: var(--signal); background: rgba(48,159,234,0.08); }
.sales-action-bar__pill--touched-stale { color: var(--olive); border-color: var(--olive); background: rgba(144,167,78,0.08); }
.sales-action-bar__pill--cold { color: var(--text-subtle); }
.sales-action-bar__btn {
  font-size: 10px; letter-spacing: 0.06em;
  padding: 5px 10px;
  border: 1px solid var(--kymo-blue);
  background: #fff; color: var(--kymo-blue);
  cursor: pointer;
  font-family: inherit;
  transition: background .15s ease, color .15s ease;
}
.sales-action-bar__btn:hover { background: var(--kymo-blue); color: #fff; }
.sales-action-bar__btn.is-active { background: var(--kymo-blue); color: #fff; }
.sales-action-bar__btn--primary {
  background: var(--kymo-blue); color: #fff;
  border-color: var(--kymo-blue);
}
.sales-action-bar__btn--primary:hover { background: var(--signal); border-color: var(--signal); }
.sales-action-bar__btn--ghost {
  border-color: var(--border);
  color: var(--text-muted);
}
.sales-action-bar__btn--ghost:hover { background: var(--text-muted); color: #fff; border-color: var(--text-muted); }
.sales-action-bar__voice-label {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-muted);
  margin-left: 4px;
}
.sales-action-bar__btn--voice {
  font-size: 10px; letter-spacing: 0.04em;
  padding: 4px 8px;
  border-color: var(--border);
  color: var(--text-muted);
  background: transparent;
}
.sales-action-bar__btn--voice:hover {
  background: var(--kymo-blue);
  color: #fff;
  border-color: var(--kymo-blue);
}

/* When a story-card has actions, wrap body in a button so click only opens project */
.story-card--with-actions {
  display: flex; flex-direction: column;
  background: #fff;
  border: 1px solid var(--border);
  text-align: left;
  padding: 0;
  cursor: default;
  font-family: inherit;
  transition: box-shadow .2s ease;
}
.story-card--with-actions:hover { box-shadow: 0 12px 32px rgba(26,43,60,0.1); }
.story-card__body-btn {
  display: flex; flex-direction: column;
  text-align: left;
  background: transparent;
  border: 0; padding: 0;
  cursor: pointer;
  font-family: inherit;
  width: 100%;
}
.story-card__sales-hint-row {
  padding: 8px 18px 14px;
}
.sales-hint-mini {
  display: inline-block;
  font-size: 11px; letter-spacing: 0.04em;
  padding: 3px 8px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: help;
}
.sales-hint-mini--warm { color: var(--signal); border-color: var(--signal); background: rgba(48,159,234,0.06); }
.sales-hint-mini--cold { color: var(--text-muted); }

/* Project-Detail action bar */
.project-sales-actions {
  margin-top: 12px;
}
.project-sales-actions .sales-action-bar {
  background: #fff;
  border: 1px solid var(--border);
  border-top: 3px solid var(--kymo-blue);
}

/* Outreach queue list (My Pipeline) */
.outreach-queue {
  display: flex; flex-direction: column;
  gap: 8px;
}
.outreach-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 16px;
  align-items: center;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid var(--border);
}
@media (max-width: 720px) {
  .outreach-row { grid-template-columns: 1fr; gap: 8px; }
}
.outreach-row__main {
  background: transparent;
  border: 0; padding: 0;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
}
.outreach-row__title {
  font-family: 'TodayBEF', sans-serif; font-weight: 300;
  font-size: 16px; color: var(--kymo-blue);
}
.outreach-row__meta {
  font-size: 11px; letter-spacing: 0.04em;
  color: var(--text-muted);
  margin-top: 2px;
}
.outreach-row__pill {
  font-size: 9px; letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 8px;
  border: 1px solid var(--border);
  color: var(--text-muted);
  background: var(--bg-soft);
}
.outreach-row__pill--queued { color: var(--gold); border-color: var(--gold); background: rgba(157,101,37,0.06); }
.outreach-row__pill--touched-fresh { color: var(--signal); border-color: var(--signal); background: rgba(48,159,234,0.08); }
.outreach-row__pill--touched-stale { color: var(--olive); border-color: var(--olive); background: rgba(144,167,78,0.08); }
.outreach-row .sales-action-bar {
  background: transparent; border-top: 0; padding: 0;
}
.editor-letter__inner {
  padding: 28px 32px;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 32px;
  align-items: start;
}
@media (max-width: 720px) {
  .editor-letter__inner { grid-template-columns: 1fr; gap: 12px; }
}
.editor-letter__masthead {
  display: flex; flex-direction: column; gap: 4px;
}
.editor-letter__kicker {
  font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold); font-weight: 500;
}
.editor-letter--bre .editor-letter__kicker { color: var(--olive); }
.editor-letter__byline {
  font-size: 11px; letter-spacing: 0.06em;
  color: var(--text-muted);
}
.editor-letter__body {
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-size: 17px; line-height: 1.55;
  color: var(--kymo-blue);
  margin: 0;
}
.editor-letter__body::first-letter {
  /* gentle drop-cap */
  font-size: 1.5em; line-height: 1; padding-right: 2px;
  color: var(--gold);
}
.editor-letter--bre .editor-letter__body::first-letter { color: var(--olive); }

.hospitality-hero {
  margin-top: 32px;
}
.hospitality-hero__rotator-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0 12px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.hospitality-hero__rotator-label {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-muted);
}
.hospitality-hero__rotator-btn {
  font-size: 11px; letter-spacing: 0.06em;
  color: var(--kymo-blue);
  background: transparent;
  border: 1px solid var(--kymo-blue);
  padding: 6px 12px;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.hospitality-hero__rotator-btn:hover {
  background: var(--kymo-blue); color: #fff;
}
.hospitality-hero__narrative {
  display: flex; flex-direction: column; gap: 10px;
  margin: 8px 0 4px;
}
.hospitality-hero__narrative p {
  font-size: 14px; line-height: 1.6;
  color: var(--text);
  margin: 0;
}
.hospitality-hero__narrative p:first-child {
  font-size: 15px;
  color: var(--kymo-blue);
}
.hospitality-hero__card {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 0;
  background: #fff;
  border: 1px solid var(--border);
  cursor: pointer;
  text-align: left;
  width: 100%;
  font-family: inherit;
  transition: box-shadow .2s ease;
}
.hospitality-hero__card:hover {
  box-shadow: 0 16px 40px rgba(26,43,60,0.08);
}
@media (max-width: 900px) {
  .hospitality-hero__card { grid-template-columns: 1fr; }
}
.hospitality-hero__visual {
  position: relative; overflow: hidden;
  background: var(--bg-soft);
  min-height: 380px;
}
.hospitality-hero__visual img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.hospitality-hero__body {
  padding: 40px 48px;
  display: flex; flex-direction: column;
  gap: 16px;
}
.hospitality-hero__kicker {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
}
.hospitality-hero__location {
  font-size: 11px; letter-spacing: 0.12em;
  color: var(--text-muted);
  text-transform: uppercase;
}
.hospitality-hero__headline {
  font-family: 'TodayBEF', sans-serif; font-weight: 200;
  font-size: 38px; line-height: 1.05; letter-spacing: -0.005em;
  color: var(--kymo-blue);
  margin: 0;
}
.hospitality-hero__pull {
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: 22px; line-height: 1.35;
  color: var(--text);
  margin: 0;
}
.hospitality-hero__body-text {
  font-size: 14px; line-height: 1.6;
  color: var(--text-muted);
  margin: 0;
}
.hospitality-hero__byline {
  display: flex; flex-wrap: wrap;
  align-items: center; gap: 4px;
  font-size: 11px; letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-top: 8px;
}
.hospitality-hero__byline .byline__sep {
  margin: 0 4px;
  color: var(--border);
}
.hospitality-hero__cta {
  margin-top: auto;
  border-top: 1px solid var(--border-soft, var(--border));
  padding-top: 16px;
}
.hospitality-hero__cta-label {
  font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
}

/* Dark numbers band — magazine "By the numbers" spread */
.hospitality-numbers-band {
  margin-top: 32px;
}
.hospitality-numbers__head {
  align-items: baseline;
}
.hospitality-numbers__date {
  font-size: 11px; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
}
.hospitality-numbers__pill {
  display: inline-block;
  margin-left: 12px;
  padding: 2px 8px;
  font-size: 9px; letter-spacing: 0.1em;
  background: var(--gold);
  color: #fff;
  text-transform: uppercase;
  cursor: help;
}
.hospitality-numbers__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.08);
  margin-top: 24px;
}
@media (max-width: 900px) {
  .hospitality-numbers__grid { grid-template-columns: repeat(2, 1fr); }
}
.hospitality-stat {
  padding: 28px 24px;
  background: var(--kymo-blue);
  border-top: 3px solid var(--accent, var(--signal));
  color: #fff;
  display: flex; flex-direction: column; gap: 6px;
}
.hospitality-stat--wide {
  grid-column: span 2;
}
.hospitality-stat__label {
  font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.hospitality-stat__value {
  font-family: 'TodayBEF', sans-serif; font-weight: 200;
  font-size: 56px; line-height: 1;
  letter-spacing: -0.01em;
  color: #fff;
}
.hospitality-stat--wide .hospitality-stat__value {
  font-size: 32px;
  line-height: 1.15;
  font-weight: 300;
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-style: italic;
}
.hospitality-stat__sub {
  font-size: 11px; letter-spacing: 0.04em;
  color: rgba(255,255,255,0.55);
}

#hospitality-pipeline-band {
  margin-top: 48px;
}
#hospitality-pipeline-band .story-card--feature {
  border: 1px solid var(--border);
  background: #fff;
  text-align: left;
  cursor: pointer;
  display: flex; flex-direction: column;
  font-family: inherit;
  transition: box-shadow .2s ease;
}
#hospitality-pipeline-band .story-card--feature:hover {
  box-shadow: 0 12px 32px rgba(26,43,60,0.1);
}
#hospitality-pipeline-band .story-card__visual {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--bg-soft);
}
#hospitality-pipeline-band .story-card__visual img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
#hospitality-pipeline-band .story-card__kicker {
  padding: 14px 18px 0;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  font-weight: 500;
}
#hospitality-pipeline-band .story-card__headline {
  padding: 6px 18px 0;
  font-family: 'TodayBEF', sans-serif; font-weight: 300;
  font-size: 18px; line-height: 1.2;
  color: var(--kymo-blue);
}
#hospitality-pipeline-band .story-card__copy {
  padding: 8px 18px 0;
  font-size: 13px; line-height: 1.55;
  color: var(--text);
}
#hospitality-pipeline-band .story-card__meta {
  padding: 12px 18px 18px;
  font-size: 11px; letter-spacing: 0.06em;
  color: var(--text-muted);
  border-top: 1px solid var(--border-soft, var(--border));
  margin-top: auto;
}

#hospitality-research-band {
  margin-top: 32px;
}
.hospitality-research-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) {
  .hospitality-research-grid { grid-template-columns: 1fr; }
}
.hospitality-research-panel {
  padding: 24px;
  background: #fff;
  border: 1px solid var(--border);
  border-top: 3px solid var(--accent, var(--kymo-blue));
}
.hospitality-research-panel__kicker {
  font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent, var(--kymo-blue));
  font-weight: 500;
  margin-bottom: 6px;
}
.hospitality-research-panel__title {
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: 22px; line-height: 1.2;
  color: var(--kymo-blue);
  margin: 0 0 16px;
}
.hospitality-research-list {
  list-style: none;
  margin: 0; padding: 0;
}
.hospitality-research-list li {
  display: flex; align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border-soft, var(--border));
  font-size: 13px;
}
.hospitality-research-list li:last-child {
  border-bottom: 0;
}
.hospitality-research-list__name {
  color: var(--kymo-blue);
  font-weight: 400;
}
.hospitality-research-list__name.clickable {
  cursor: pointer;
  border-bottom: 1px dotted transparent;
}
.hospitality-research-list__name.clickable:hover {
  border-bottom-color: var(--accent, var(--kymo-blue));
}
.hospitality-research-list__value {
  font-size: 11px; letter-spacing: 0.04em;
  color: var(--text-muted);
  text-align: right;
  white-space: nowrap;
}
.hospitality-research-panel__synth {
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-size: 14px; line-height: 1.55;
  color: var(--text);
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-soft, var(--border));
}
.hospitality-hero--bre .hospitality-hero__card {
  border-color: var(--olive);
}

/* ============ Werk-First-Visual Varianten (welle 6 sprint 3c) ============ */
/* Werk-Bild mit Caption-Overlay — der Designer durch sein Werk identifiziert */
.story-card__visual--work {
  position: relative;
  overflow: hidden;
  background: var(--bg-soft);
}
.story-card__visual--work img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.story-card__visual-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 8px 12px;
  background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0) 100%);
  color: rgba(255,255,255,0.92);
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 11px; letter-spacing: 0.04em;
}

/* Brand-Logo on top of work-image */
.story-card__visual--brand-over-work {
  position: relative;
  overflow: hidden;
  background: var(--bg-soft);
}
.story-card__visual-bg {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: brightness(0.78);
  transition: filter .25s ease;
}
.story-card:hover .story-card__visual-bg {
  filter: brightness(0.95);
}
.story-card__visual-overlay-logo {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 70%; max-width: 220px;
  background: rgba(255,255,255,0.95);
  padding: 14px 16px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}
.story-card__visual-overlay-logo img {
  max-width: 100%; max-height: 60px; object-fit: contain;
}

/* Logo-only fallback (no work image) */
.story-card__visual--logo-only {
  background: var(--bg-soft);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.story-card__visual--logo-only img {
  max-height: 60%; max-width: 70%; object-fit: contain;
}

/* Real headshot (rare — only when state.playerImages has it) */
.story-card__visual--portrait {
  background: var(--bg-soft);
  overflow: hidden;
}
.story-card__visual--portrait img {
  width: 100%; height: 100%; object-fit: cover; object-position: top;
  display: block;
}

/* Brief-card with thumbnail + body side-by-side (rail thumbnails) */
.story-card--brief-with-thumb {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 12px;
  align-items: stretch;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-soft, var(--border));
  background: transparent;
  border-left: 0; border-right: 0; border-top: 0;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  width: 100%;
}
.story-card--brief-with-thumb:hover {
  background: var(--bg-soft);
}
.story-card--brief-with-thumb .story-card__visual {
  width: 96px;
  min-height: 72px;
}
.story-card--brief-with-thumb .story-card__brief-body {
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 2px;
}
.story-card--brief-with-thumb .story-card__kicker {
  font-size: 9px; letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.story-card--brief-with-thumb .story-card__headline {
  font-family: 'TodayBEF', sans-serif; font-weight: 300;
  font-size: 14px; line-height: 1.2;
  color: var(--kymo-blue);
}
.story-card--brief-with-thumb .story-card__meta {
  font-size: 10px; letter-spacing: 0.04em;
  color: var(--text-muted);
}

/* Magazin-Section sub-bands need decent rhythm */
.hospitality-magazin-section {
  margin-top: 32px;
}
.hospitality-magazin-section .module-rubric {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}
@media (max-width: 900px) {
  .hospitality-magazin-section .module-rubric { grid-template-columns: 1fr; }
}
.hospitality-magazin-section .module-rubric__main {
  background: transparent;
  border: 0; padding: 0;
}
.hospitality-magazin-section .module-rubric__main .story-card__visual {
  margin-bottom: 16px;
}
.hospitality-magazin-section .module-rubric__main .story-card__headline {
  font-family: 'Constantia', 'Lucida Bright', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: 28px; line-height: 1.2;
  color: var(--kymo-blue);
  margin: 8px 0;
}
.cover-band--dark .hospitality-magazin-section .module-rubric__main .story-card__headline,
.cover-band--dark .hospitality-magazin-section .story-card__headline,
.cover-band--dark .hospitality-magazin-section .story-card__body,
.cover-band--dark .hospitality-magazin-section .story-card__meta,
.cover-band--dark .hospitality-magazin-section .module-rubric__rail-heading,
.cover-band--dark .hospitality-magazin-section .byline,
#hospitality-developers-stream .story-card__headline,
#bre-combined-developers .story-card__headline {
  color: #fff;
}
.cover-band--dark .hospitality-magazin-section .story-card__body,
.cover-band--dark .hospitality-magazin-section .story-card__meta,
.cover-band--dark .hospitality-magazin-section .byline {
  color: rgba(255,255,255,0.78);
}
.cover-band--dark .hospitality-magazin-section .story-card--brief-with-thumb {
  border-bottom-color: rgba(255,255,255,0.12);
}
.cover-band--dark .hospitality-magazin-section .story-card--brief-with-thumb:hover {
  background: rgba(255,255,255,0.05);
}
.hospitality-magazin-section .module-rubric__rail {
  display: flex; flex-direction: column;
  gap: 0;
  padding-top: 4px;
}
.hospitality-magazin-section .module-rubric__rail-heading {
  font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
  margin-bottom: 8px;
}
.hospitality-magazin-section .module-rubric__main .story-card {
  cursor: pointer;
}
/* Architects + designers grid card layout */
.hospitality-magazin-section .module-grid--4 .story-card--brief {
  background: #fff;
  border: 1px solid var(--border);
  display: flex; flex-direction: column;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  padding: 0;
  transition: box-shadow .2s ease;
}
.hospitality-magazin-section .module-grid--4 .story-card--brief:hover {
  box-shadow: 0 8px 24px rgba(26,43,60,0.08);
}
.hospitality-magazin-section .module-grid--4 .story-card__visual {
  margin-bottom: 0;
}
.hospitality-magazin-section .module-grid--4 .story-card__brief-body {
  padding: 12px 14px 14px;
  display: flex; flex-direction: column; gap: 4px;
}
.hospitality-magazin-section .module-grid--4 .story-card__kicker {
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-muted);
}
.hospitality-magazin-section .module-grid--4 .story-card__headline {
  font-family: 'TodayBEF', sans-serif; font-weight: 300;
  font-size: 15px; line-height: 1.2;
  color: var(--kymo-blue);
}
.hospitality-magazin-section .module-grid--4 .story-card__meta {
  font-size: 10px; letter-spacing: 0.04em;
  color: var(--text-muted);
}
/* Reciprocity-Loop · welle 17 */

/* ---- Action Inbox ---- */
.rl-action-inbox {
  /* dark cover-band from parent class */
}
.rl-action-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 4px;
}
.rl-action-card {
  display: grid;
  grid-template-columns: 4px 1fr auto;
  gap: 0;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 3px;
  overflow: hidden;
  animation: rl-fade-in 0.45s ease both;
  transition: background 0.2s ease;
}
.rl-action-card:hover {
  background: rgba(255,255,255,0.09);
}
.rl-action-card--done,
.rl-action-card--skip {
  opacity: 0.38;
  pointer-events: none;
}
@keyframes rl-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.rl-action-card__strength-bar {
  width: 4px;
}
.rl-strength--gold .rl-action-card__strength-bar,
.rl-action-card__strength-bar.rl-strength--gold { background: var(--gold); }
.rl-strength--signal .rl-action-card__strength-bar,
.rl-action-card__strength-bar.rl-strength--signal { background: var(--signal); }
.rl-strength--olive .rl-action-card__strength-bar,
.rl-action-card__strength-bar.rl-strength--olive { background: var(--olive); }

.rl-action-card__body {
  padding: 16px 20px 14px;
}
.rl-action-card__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.rl-strength-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 2px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.02em;
  color: #fff;
}
.rl-strength-pill.rl-strength--gold  { background: var(--gold); }
.rl-strength-pill.rl-strength--signal { background: var(--signal); }
.rl-strength-pill.rl-strength--olive  { background: var(--olive); }

.rl-action-card__studio {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.rl-action-card__brand {
  font-size: 10px;
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.06em;
}
.rl-action-card__headline {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 19px;
  font-weight: 400;
  line-height: 1.25;
  color: #fff;
  margin: 0 0 10px;
}
.rl-action-card__why {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,0.75);
  margin: 0 0 10px;
}
.rl-action-card__opening {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-bottom: 6px;
}
.rl-action-card__source {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  color: var(--signal);
  text-decoration: none;
  letter-spacing: 0.04em;
}
.rl-action-card__source:hover { text-decoration: underline; }

.rl-action-card__actions {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
  border-left: 1px solid rgba(255,255,255,0.08);
}
.rl-action-btn {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.45);
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.06em;
  cursor: pointer;
  padding: 0 16px;
  white-space: nowrap;
  transition: background 0.15s ease, color 0.15s ease;
  text-align: center;
}
.rl-action-btn:last-child { border-bottom: none; }
.rl-action-btn:hover { background: rgba(255,255,255,0.07); color: #fff; }
.rl-action-btn--done:hover  { color: var(--olive); }
.rl-action-btn--skip:hover  { color: rgba(255,100,100,0.9); }

/* ---- Tag Section ---- */
.rl-tag-section { /* inherits cover-band */ }
.rl-tag-intro {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 13px;
  color: var(--text-muted);
  margin: 4px 0 20px;
  line-height: 1.5;
}
.rl-designer-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 640px) {
  .rl-designer-grid { grid-template-columns: 1fr; }
}
@media (min-width: 960px) {
  .rl-designer-grid { grid-template-columns: repeat(3, 1fr); }
}

.rl-designer-card {
  display: flex;
  gap: 14px;
  padding: 16px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 3px;
  animation: rl-fade-in 0.5s ease both;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.rl-designer-card:hover {
  border-color: rgba(26,43,60,0.25);
  box-shadow: 0 4px 16px rgba(26,43,60,0.06);
}
.rl-designer-card--tagged {
  border-color: var(--signal);
  background: rgba(48,159,234,0.04);
}

.rl-designer-card__visual {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 2px;
  overflow: hidden;
  background: var(--bg-warm);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rl-designer-card__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  padding: 4px;
}

.rl-designer-card__content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.rl-designer-card__studio {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: var(--kymo-blue);
  line-height: 1.25;
  letter-spacing: 0.01em;
}
.rl-designer-card__founder {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.3;
}
.rl-designer-card__city {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 6px;
}

.rl-designer-card__tags {
  display: flex;
  gap: 5px;
  margin-bottom: 8px;
}
.rl-tag-btn {
  width: 28px;
  height: 26px;
  border-radius: 2px;
  border: 1.5px solid currentColor;
  background: transparent;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 500;
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease, color 0.15s ease;
  color: var(--text-subtle);
  border-color: var(--border);
}
.rl-tag-btn.rl-strength--gold  { color: var(--gold); border-color: var(--gold); }
.rl-tag-btn.rl-strength--signal { color: var(--signal); border-color: var(--signal); }
.rl-tag-btn.rl-strength--olive  { color: var(--olive); border-color: var(--olive); }
.rl-tag-btn:hover {
  opacity: 0.85;
}
.rl-tag-btn.rl-strength--gold.rl-tag-btn--active  { background: var(--gold); color: #fff; border-color: var(--gold); }
.rl-tag-btn.rl-strength--signal.rl-tag-btn--active { background: var(--signal); color: #fff; border-color: var(--signal); }
.rl-tag-btn.rl-strength--olive.rl-tag-btn--active  { background: var(--olive); color: #fff; border-color: var(--olive); }

/* Note area */
.rl-designer-card__note-area { margin-top: 2px; }
.rl-note-toggle {
  background: transparent;
  border: none;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  color: var(--signal);
  cursor: pointer;
  padding: 0;
  letter-spacing: 0.04em;
}
.rl-note-toggle:hover { text-decoration: underline; }
.rl-designer-card__note-area .rl-note-field {
  display: none;
  width: 100%;
  margin-top: 6px;
  padding: 6px 8px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 12px;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 2px;
  background: var(--bg);
  resize: vertical;
  box-sizing: border-box;
  line-height: 1.5;
}
.rl-designer-card__note-area.rl-designer-card__note-area--open .rl-note-field {
  display: block;
}

/* Empty states */
.rl-empty-state {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 14px;
  color: var(--text-muted);
  padding: 24px 0;
  line-height: 1.6;
}
.rl-empty-state--dark {
  color: rgba(255,255,255,0.5);
}

/* --- end welle 17 --- */

/* Lead-Pass-Inbox · welle 18 */

/* ---- Olga Inbox · pending section ---- */
.lp-inbox {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 4px;
}
.lp-pass-card {
  display: grid;
  grid-template-columns: 4px 1fr;
  gap: 0;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 3px;
  overflow: hidden;
  animation: rl-fade-in 0.45s ease both;
  transition: background 0.2s ease;
}
.lp-pass-card:hover { background: rgba(255,255,255,0.09); }
.lp-pass-card__bar {
  width: 4px;
  background: var(--gold);
}
.lp-pass-card__bar--committed { background: var(--signal); }
.lp-pass-card__bar--declined  { background: rgba(255,80,80,0.7); }
/* P-Wording · Welle 22 · Demo hint pill — olive/gold accent, dezent */
.lp-pass-card__hint {
  font-family: 'TodayBEF', sans-serif;
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(157,101,37,0.85);
  background: rgba(157,101,37,0.12);
  border: 1px solid rgba(157,101,37,0.2);
  border-radius: 2px;
  padding: 2px 8px;
  margin-bottom: 8px;
  display: inline-block;
}
.lp-pass-card__body {
  padding: 16px 20px 14px;
}
.lp-pass-card__from-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: var(--gold);
  border-radius: 2px;
  padding: 2px 8px;
  margin-bottom: 10px;
}
.lp-pass-card__from-pill--committed { background: var(--signal); }
.lp-pass-card__from-pill--declined  { background: rgba(180,60,60,0.8); }
.lp-pass-card__headline {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 19px;
  font-weight: 400;
  line-height: 1.25;
  color: #fff;
  margin: 0 0 10px;
}
.lp-pass-card__note {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,0.7);
  border-left: 2px solid var(--gold);
  padding-left: 12px;
  margin: 0 0 12px;
}
.lp-pass-card__note--response {
  border-left-color: var(--signal);
}
.lp-pass-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.45);
  margin-bottom: 14px;
}
.lp-pass-card__meta-item {
  display: flex;
  align-items: center;
  gap: 4px;
}
.lp-pass-card__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.lp-pass-card__textarea {
  width: 100%;
  margin-top: 10px;
  padding: 8px 10px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 12px;
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 2px;
  resize: vertical;
  min-height: 56px;
  line-height: 1.5;
  box-sizing: border-box;
}
.lp-pass-card__textarea::placeholder { color: rgba(255,255,255,0.3); }
.lp-action-btn {
  flex-shrink: 0;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 2px;
  color: rgba(255,255,255,0.55);
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.06em;
  cursor: pointer;
  padding: 6px 14px;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.lp-action-btn:hover { background: rgba(255,255,255,0.07); color: #fff; border-color: rgba(255,255,255,0.3); }
.lp-action-btn--commit:hover  { border-color: var(--signal); color: var(--signal); }
.lp-action-btn--decline:hover { border-color: rgba(255,100,100,0.7); color: rgba(255,120,120,0.9); }

/* ---- DDC Track Record cards ---- */
.lp-track-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 4px;
}
@media (max-width: 640px) { .lp-track-grid { grid-template-columns: 1fr; } }
.lp-track-card {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 16px 18px;
  animation: rl-fade-in 0.5s ease both;
}
.lp-track-card__status {
  display: inline-flex;
  align-items: center;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: var(--olive);
  border-radius: 2px;
  padding: 2px 7px;
  margin-bottom: 10px;
}
.lp-track-card__status--active { background: var(--signal); }
.lp-track-card__name {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 16px;
  color: var(--kymo-blue);
  margin: 0 0 6px;
  line-height: 1.3;
}
.lp-track-card__meta {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}

/* ---- NYC Players section ---- */
.lp-nyc-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 4px;
}
@media (max-width: 640px) { .lp-nyc-grid { grid-template-columns: 1fr; } }
@media (min-width: 960px) { .lp-nyc-grid { grid-template-columns: repeat(3, 1fr); } }
.lp-nyc-card {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 14px 16px;
  animation: rl-fade-in 0.5s ease both;
  transition: border-color 0.2s ease;
  cursor: default;
}
.lp-nyc-card:hover { border-color: rgba(26,43,60,0.25); }
.lp-nyc-card__logo {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: var(--bg-warm);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.lp-nyc-card__logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 3px;
}
.lp-nyc-card__logo-init {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}
.lp-nyc-card__content { flex: 1; min-width: 0; }
.lp-nyc-card__name {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: var(--kymo-blue);
  line-height: 1.3;
  margin-bottom: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lp-nyc-card__meta {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  text-transform: uppercase;
}
.lp-nyc-card__pipeline {
  display: inline-flex;
  align-items: center;
  margin-top: 6px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 10px;
  color: var(--signal);
  letter-spacing: 0.04em;
}

/* ---- Pass-to-Olga button · Project Detail ---- */
.lp-pass-olga-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--kymo-blue);
  color: #fff;
  border: none;
  border-radius: 2px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 12px;
  letter-spacing: 0.08em;
  cursor: pointer;
  padding: 8px 16px;
  margin-top: 12px;
  transition: background 0.15s ease, box-shadow 0.15s ease;
  position: relative;
}
.lp-pass-olga-btn:hover {
  background: #253d52;
  box-shadow: 0 2px 8px rgba(26,43,60,0.25);
}
.lp-pass-olga-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  background: var(--kymo-blue);
  box-shadow: none;
}
.lp-pass-olga-btn__dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
.lp-pass-olga-btn__hint {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-left: 2px;
}

/* ---- Pass-Status block · for Heads when they open a passed lead ---- */
.lp-pass-status-block {
  margin: 0 0 18px;
  padding: 14px 18px;
  background: rgba(26,43,60,0.04);
  border: 1px solid var(--border);
  border-left: 4px solid var(--gold);
  border-radius: 3px;
}
.lp-pass-status-block--committed { border-left-color: var(--signal); }
.lp-pass-status-block--declined  { border-left-color: rgba(200,60,60,0.6); }
.lp-pass-status-block__label {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}
.lp-pass-status-block--committed .lp-pass-status-block__label { color: var(--signal); }
.lp-pass-status-block--declined  .lp-pass-status-block__label { color: rgba(190,60,60,0.9); }
.lp-pass-status-block__text {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 14px;
  color: var(--text);
  line-height: 1.5;
}
.lp-pass-status-block__response {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 13px;
  color: var(--text-muted);
  margin-top: 8px;
  border-left: 2px solid var(--signal);
  padding-left: 10px;
  line-height: 1.5;
}

/* ---- Empty states Olga ---- */
.lp-empty {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  padding: 22px 0;
  line-height: 1.6;
}
.lp-empty--light {
  color: var(--text-muted);
}

/* --- end welle 18 --- */

.cover-band--warm .hospitality-magazin-section .module-grid--4 .story-card--brief {
  background: rgba(255,255,255,0.85);
}

/* Cold-Caller · welle 19 */

/* ---- Section containers ---- */
.cct-section {
  padding: 56px 0;
  border-top: 1px solid var(--border);
}
.cct-section--skipped {
  padding: 28px 0;
  border-top: 1px solid var(--border);
  opacity: 0.72;
}
.cct-section__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* ---- Section header ---- */
.cct-section__header {
  margin-bottom: 28px;
}
.cct-headline {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 28px;
  font-weight: 400;
  line-height: 1.2;
  color: var(--kymo-blue);
  margin: 0 0 6px;
}
.cct-sub {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-subtle);
}

/* ---- Cards grid (3-col) ---- */
.cct-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 960px) {
  .cct-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .cct-cards { grid-template-columns: 1fr; }
}

/* ---- Individual card ---- */
.cct-card {
  border: 1px solid var(--border);
  border-radius: 3px;
  background: var(--bg-soft);
  animation: rl-fade-in 0.45s ease both;  /* reuse Welle-17 keyframe */
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.cct-card:hover {
  border-color: rgba(26,43,60,0.22);
  box-shadow: 0 4px 18px rgba(26,43,60,0.07);
}
.cct-card--dimmed {
  opacity: 0.42;
}
.cct-card__inner {
  padding: 20px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  height: 100%;
}

/* ---- Card header ---- */
.cct-card__header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cct-card__name {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 500;
  font-size: 15px;
  color: var(--kymo-blue);
  line-height: 1.25;
}
.cct-card__meta {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  line-height: 1.4;
}

/* ---- Status pills ---- */
.cct-pill {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 2px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  width: fit-content;
  margin-top: 4px;
}
.cct-pill--gold    { background: rgba(157,101,37,0.12); color: var(--gold); }
.cct-pill--olive   { background: rgba(144,167,78,0.14); color: var(--olive); }
.cct-pill--grey    { background: var(--bg-warm); color: var(--text-subtle); }
.cct-pill--signal  { background: rgba(48,159,234,0.12); color: var(--signal); }

/* ---- Why block (kymo-blue border-left) ---- */
.cct-card__why {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-muted);
  border-left: 3px solid var(--signal);
  padding-left: 12px;
}
.cct-card__why-label {
  display: block;
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 4px;
}

/* ---- What-to-say block (gold border-left, Constantia italic) ---- */
.cct-card__script {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  border-left: 3px solid var(--gold);
  padding-left: 12px;
}

/* ---- Source link ---- */
.cct-card__source {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  color: var(--signal);
  text-decoration: none;
  letter-spacing: 0.04em;
  margin-top: auto;
}
.cct-card__source:hover { text-decoration: underline; }
.cct-card__source--plain {
  color: var(--text-subtle);
  cursor: default;
}

/* ---- Action buttons ---- */
.cct-card__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.cct-btn {
  flex: 1 1 auto;
  min-width: 72px;
  padding: 5px 10px;
  border-radius: 2px;
  border: 1.5px solid var(--border);
  background: var(--bg);
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
  white-space: nowrap;
  text-align: center;
}
.cct-btn:hover {
  border-color: var(--kymo-blue);
  color: var(--kymo-blue);
}
.cct-btn--called.cct-btn--active  { background: var(--olive);  border-color: var(--olive);  color: #fff; }
.cct-btn--skip.cct-btn--active    { background: var(--bg-warm); border-color: var(--grey-mid); color: var(--text-muted); }
.cct-btn--followup.cct-btn--active { background: var(--signal); border-color: var(--signal); color: #fff; }

/* ---- Stats strip ---- */
.cct-stats-strip {
  padding: 28px 0;
  background: var(--bg-soft);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.cct-stats-cells {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
}
@media (max-width: 640px) {
  .cct-stats-cells { grid-template-columns: repeat(2, 1fr); }
}
.cct-stat-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 12px;
  background: var(--bg-soft);
  gap: 4px;
}
.cct-stat-cell__value {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-size: 32px;
  font-weight: 400;
  color: var(--kymo-blue);
  line-height: 1;
}
.cct-stat-cell__label {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-subtle);
  text-align: center;
  line-height: 1.3;
}

/* ---- Skipped list ---- */
.cct-skipped-header {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 10px;
}
.cct-skipped-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cct-skipped-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 2px;
}
.cct-skipped-row__name {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: var(--text-muted);
  flex: 0 0 auto;
}
.cct-skipped-row__company {
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 12px;
  color: var(--text-subtle);
  flex: 1 1 auto;
  letter-spacing: 0.04em;
}
.cct-btn-readd {
  flex: 0 0 auto;
  padding: 4px 10px;
  border-radius: 2px;
  border: 1.5px solid var(--signal);
  background: transparent;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 11px;
  color: var(--signal);
  cursor: pointer;
  transition: background 0.15s ease;
}
.cct-btn-readd:hover {
  background: rgba(48,159,234,0.08);
}

/* ---- Empty state ---- */
.cct-empty {
  font-family: Constantia, 'Lucida Bright', Georgia, serif;
  font-style: italic;
  font-size: 16px;
  color: var(--text-muted);
  padding: 32px 0;
  line-height: 1.6;
}

/* --- end welle 19 --- */

/* ============================================================
   KV Sync Status Indicator · welle 23
   Kleine Pille top-rechts im Masthead-Utils
   ============================================================ */
.kv-sync-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'TodayBEF', sans-serif;
  font-weight: 200;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--olive);
  padding: 4px 8px;
  border-radius: 2px;
  white-space: nowrap;
  transition: color 0.2s ease;
}
.kv-sync-status__icon {
  font-size: 11px;
  line-height: 1;
  display: inline-block;
}
.kv-sync-status--syncing {
  color: var(--signal);
}
.kv-sync-status--syncing .kv-sync-status__icon {
  animation: kv-spin 1s linear infinite;
}
.kv-sync-status--offline {
  color: var(--gold);
}
@keyframes kv-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
/* --- end welle 23 kv-sync --- */
