:root {
  --bg: #0b0d10;
  --panel: rgba(20, 23, 28, 0.94);
  --line: rgba(128, 144, 168, 0.14);
  --text: #e4ebf5;
  --muted: #99a8bc;
  --accent-light: #7ab2e8;
  --accent-bright: #a8cdf4;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.55);
  --glow-subtle: rgba(85, 108, 140, 0.12);
  --transition-smooth: 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  font-family: Calibri, Candara, "Segoe UI", Arial, sans-serif;
  background:
    radial-gradient(circle at 0% 0%, rgba(72, 88, 110, 0.16), transparent 22%),
    radial-gradient(circle at 100% 12%, rgba(34, 42, 54, 0.28), transparent 28%),
    linear-gradient(180deg, #090b0f 0%, #111419 42%, #090b0f 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(255, 255, 255, 0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.012) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(circle at center, black 20%, transparent 80%);
}

body.session-pending .page-shell {
  opacity: 0;
  pointer-events: none;
}

.app-login {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 20px;
  background: linear-gradient(180deg, rgba(2, 4, 8, 0.85), rgba(2, 4, 8, 0.96));
  backdrop-filter: blur(14px);
  animation: fadeIn 400ms ease-out;
}

.app-login[hidden] {
  display: none;
}

.app-login__panel {
  width: min(420px, 100%);
  padding: 28px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(6, 9, 16, 0.97);
  box-shadow: var(--shadow), 0 0 120px rgba(60, 90, 140, 0.06);
  animation: slideUp 500ms cubic-bezier(0.16, 1, 0.3, 1);
}

.app-login__icon {
  width: 72px;
  height: 72px;
  border-radius: 12px;
  display: block;
  margin-bottom: 18px;
}

.app-login__form {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.app-login__form label,
.revenue-form label {
  display: grid;
  gap: 8px;
}

.app-login__form span,
.revenue-form span {
  color: var(--accent-bright);
}

.app-login__form input,
.app-login__form button,
.revenue-form input,
.revenue-form button,
.import-card input,
.import-card button,
.month-dialog__nav,
.month-dialog__close {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 14px 16px;
  font: inherit;
}

.app-login__form button,
.revenue-form button,
.import-card button {
  cursor: pointer;
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease, border-color 160ms ease;
}

.app-login__form button:hover,
.app-login__form button:focus-visible,
.revenue-form button:hover,
.revenue-form button:focus-visible,
.import-card button:hover,
.import-card button:focus-visible,
.month-dialog__nav:hover,
.month-dialog__nav:focus-visible,
.month-dialog__close:hover,
.month-dialog__close:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(39, 68, 108, 0.28);
  filter: brightness(1.08);
  border-color: rgba(185, 205, 233, 0.34);
}

.app-login__error {
  min-height: 1.2em;
  margin: 12px 0 0;
  color: #ffb8c0;
}

.page-shell {
  width: min(1240px, calc(100% - 28px));
  margin: 0 auto;
  padding: 20px 0 52px;
}

.hero {
  position: relative;
  overflow: hidden;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(10, 16, 26, 0.96), rgba(5, 8, 14, 0.98));
  box-shadow: var(--shadow);
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(5, 7, 13, 0.3), rgba(5, 7, 13, 0.78)),
    radial-gradient(circle at left center, rgba(125, 152, 199, 0.14), transparent 22%);
}

.hero__topline,
.hero__content,
.main-nav {
  position: relative;
  z-index: 1;
}

.hero__topline,
.panel__header,
.panel__actions,
.game-card__top,
.game-card__footer,
.revenue-entry {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

.hero__logo {
  width: min(420px, 52vw);
  max-width: 100%;
  height: auto;
  filter: drop-shadow(0 18px 34px rgba(0, 0, 0, 0.48));
}

.hero__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: end;
}

.hero__link--icon {
  width: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
}

.hero__link--icon svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.hero__link,
.game-card__footer a {
  color: var(--accent-bright);
  text-decoration: none;
}

.hero__link,
.main-nav__item,
.logout-button {
  border: 1px solid rgba(140, 170, 210, 0.16);
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(8, 14, 24, 0.72);
  transition: transform var(--transition-smooth), background var(--transition-smooth), border-color var(--transition-smooth), box-shadow var(--transition-smooth), color var(--transition-smooth);
}

.hero__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 18px;
}

.main-nav {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.main-nav__item,
.logout-button {
  color: var(--accent-bright);
  font: inherit;
  cursor: pointer;
}

.hero__link:hover,
.hero__link:focus-visible,
.main-nav__item:hover,
.main-nav__item:focus-visible,
.logout-button:hover,
.logout-button:focus-visible {
  transform: translateY(-2px);
  background: rgba(18, 30, 48, 0.95);
  border-color: rgba(140, 170, 210, 0.32);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.4), 0 0 40px var(--glow-subtle);
  color: #e8edf6;
}

.main-nav__item.is-active {
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
  color: var(--text);
}

.main-nav__item--install {
  margin-left: auto;
}

.eyebrow {
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  color: var(--accent-light);
}

h1,
h2,
h3 {
  margin: 0;
  font-weight: 700;
  letter-spacing: 0.02em;
  font-family: Calibri, Candara, "Segoe UI", Arial, sans-serif;
}

h1 {
  font-size: clamp(2.2rem, 5vw, 4rem);
}

h2 {
  font-size: 1.7rem;
}

.panel__meta,
.form-note,
.game-meta,
.game-stat span,
.empty-state,
.chart-embed-note,
.insight-meta,
.hero__version {
  color: var(--muted);
}

.panel__meta--loading,
.remote-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.throbber {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 2px solid rgba(185, 205, 233, 0.22);
  border-top-color: var(--accent-bright);
  animation: spin 0.9s linear infinite;
  flex: 0 0 auto;
}

.hero__version {
  margin: 0;
  color: var(--accent-bright);
  font-size: 0.92rem;
}

.panel,
.game-card,
.revenue-form-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  box-shadow: var(--shadow);
}

.dashboard {
  display: grid;
  gap: 24px;
  margin-top: 24px;
}

.tab-panel {
  display: none;
}

.tab-panel.is-active {
  display: block;
  animation: fadeIn 300ms ease-out;
}

#gamesTab {
  position: relative;
  isolation: isolate;
  overflow: clip;
}

#gamesTab::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.22;
  background:
    radial-gradient(circle at 18% 24%, rgba(206, 181, 124, 0.22), transparent 42%),
    radial-gradient(circle at 84% 18%, rgba(108, 126, 164, 0.18), transparent 44%),
    linear-gradient(180deg, rgba(8, 11, 16, 0.75), rgba(6, 8, 13, 0.86));
  transition: opacity var(--transition-smooth), background var(--transition-smooth);
}

#gamesTab[data-game-theme="tavern-legends"]::before {
  background:
    linear-gradient(180deg, rgba(6, 9, 14, 0.72), rgba(4, 6, 10, 0.88)),
    radial-gradient(circle at 70% 20%, rgba(226, 190, 121, 0.18), transparent 42%),
    url("/assets/tavern-legends-banner.png") center / cover no-repeat;
}

#gamesTab[data-game-theme="werewolf-hunter"]::before {
  background:
    linear-gradient(180deg, rgba(3, 7, 12, 0.78), rgba(2, 4, 8, 0.9)),
    radial-gradient(circle at 56% 8%, rgba(132, 152, 190, 0.2), transparent 40%),
    url("/assets/werewolf-hunter-banner.png") center / cover no-repeat;
}

#gamesTab > * {
  position: relative;
  z-index: 1;
}

.panel {
  padding: 24px;
}

.panel__header {
  margin-bottom: 20px;
  align-items: end;
}

.panel__actions {
  align-items: center;
}

.revenue-form-card {
  padding: 22px;
  margin-bottom: 20px;
}

.revenue-form {
  display: grid;
  gap: 14px;
}

.month-picker-trigger {
  text-align: left;
}

.revenue-chart {
  min-height: 320px;
}

.line-chart-card {
  position: relative;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.04);
  background:
    radial-gradient(circle at top, rgba(70, 130, 200, 0.05), transparent 36%),
    rgba(255, 255, 255, 0.01);
  padding: 14px;
}

.line-chart {
  width: 100%;
  height: 320px;
  display: block;
}

.line-chart__grid {
  stroke: rgba(255, 255, 255, 0.08);
  stroke-width: 1;
}

.line-chart__area {
  fill: rgba(122, 161, 216, 0.14);
}

.line-chart__line {
  fill: none;
  stroke: #95b3df;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 4px rgba(149, 179, 223, 0.3));
}

.line-chart__dot {
  fill: #dfe9fb;
  stroke: #36557d;
  stroke-width: 3;
}

.line-chart-card--sales {
  border-color: rgba(224, 183, 84, 0.18);
  background:
    radial-gradient(circle at top, rgba(224, 183, 84, 0.12), transparent 38%),
    linear-gradient(180deg, rgba(110, 78, 18, 0.16), rgba(255, 255, 255, 0.01));
}

.line-chart--sales .line-chart__area {
  fill: rgba(224, 183, 84, 0.16);
}

.line-chart--sales .line-chart__line {
  stroke: #e0b754;
  filter: drop-shadow(0 0 5px rgba(224, 183, 84, 0.35));
}

.line-chart--sales .line-chart__dot {
  fill: #ffefc5;
  stroke: #8a6520;
}

.line-chart--sales .line-chart__dot--hover.is-active {
  fill: #ffefc5;
  stroke: #e0b754;
  stroke-width: 3;
  filter: drop-shadow(0 0 6px rgba(224, 183, 84, 0.5));
}

.line-chart-card--twitch {
  border-color: rgba(145, 112, 255, 0.22);
  background:
    radial-gradient(ellipse at 50% -20%, rgba(145, 112, 255, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(50, 28, 86, 0.14), rgba(255, 255, 255, 0.01));
}

.line-chart--twitch .line-chart__area {
  fill: url(#twitch-gradient);
  fill: rgba(145, 112, 255, 0.14);
}

.line-chart--twitch .line-chart__line {
  stroke: #a970ff;
  filter: drop-shadow(0 0 6px rgba(169, 112, 255, 0.4));
}

.line-chart--twitch .line-chart__dot {
  fill: #f4ebff;
  stroke: #6f42c1;
}

.line-chart--twitch .line-chart__dot--hover.is-active {
  fill: #e0cfff;
  stroke: #a970ff;
  stroke-width: 3;
  filter: drop-shadow(0 0 8px rgba(169, 112, 255, 0.6));
}

.line-chart__hit-area {
  fill: transparent;
  cursor: crosshair;
}

.line-chart__hit-dot {
  fill: transparent;
}

.line-chart__dot--hover {
  opacity: 0;
  transition: opacity 150ms ease, r 150ms ease;
}

.line-chart__dot--hover.is-active {
  opacity: 1;
  r: 7;
}

.line-chart__hover-line {
  stroke: rgba(255, 255, 255, 0.18);
  stroke-width: 1;
  stroke-dasharray: 4 3;
  opacity: 0;
  transition: opacity 150ms ease;
  pointer-events: none;
}

.line-chart--twitch .line-chart__hover-line {
  stroke: rgba(169, 112, 255, 0.35);
}

.line-chart--sales .line-chart__hover-line {
  stroke: rgba(224, 183, 84, 0.3);
}

.line-chart-tooltip {
  position: absolute;
  z-index: 50;
  pointer-events: none;
  background: rgba(10, 12, 22, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  padding: 10px 14px;
  min-width: 120px;
  max-width: 260px;
  backdrop-filter: blur(12px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 150ms ease, transform 150ms ease;
}

.line-chart-tooltip.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.line-chart-tooltip__label {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 2px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.line-chart-tooltip__value {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}

.line-chart-tooltip__streamers {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.line-chart-tooltip__streamer {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: #c9a0ff;
  background: rgba(145, 112, 255, 0.12);
  border-radius: 4px;
  padding: 2px 7px;
}

.line-chart-tooltip__streamer::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #a970ff;
  flex-shrink: 0;
}

.line-chart__axis {
  fill: var(--muted);
  font-size: 12px;
}

.line-chart__value {
  fill: var(--accent-bright);
  font-size: 12px;
}

.revenue-list,
.month-grid {
  display: grid;
  gap: 10px;
}

.revenue-list {
  margin-top: 20px;
}

.revenue-entry,
.import-card,
.insight-card,
.game-stat {
  padding: 14px 16px;
  border-radius: 9px;
  border: 1px solid rgba(255, 255, 255, 0.04);
  background: rgba(255, 255, 255, 0.02);
}

.revenue-summary-card {
  margin-bottom: 18px;
  padding: 16px 0 20px;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(224, 183, 84, 0.14);
  background: transparent;
  box-shadow: none;
}

.revenue-summary-card strong {
  display: block;
  margin: 0 0 8px;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  color: #f3d48b;
  letter-spacing: 0.02em;
}

.insight-card {
  display: grid;
  gap: 14px;
}

.insight-card--sales {
  border-color: rgba(224, 183, 84, 0.14);
  background:
    linear-gradient(180deg, rgba(70, 48, 8, 0.15), rgba(255, 255, 255, 0.015));
  box-shadow: none;
}

.insight-card--wishlist {
  border-color: rgba(149, 179, 223, 0.18);
  background:
    linear-gradient(180deg, rgba(40, 63, 97, 0.18), rgba(255, 255, 255, 0.03)),
    rgba(255, 255, 255, 0.03);
}

.insight-card--twitch {
  border-color: rgba(145, 112, 255, 0.22);
  background:
    linear-gradient(180deg, rgba(55, 33, 95, 0.2), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.01);
}

.insight-card + .insight-card {
  margin-top: 18px;
}

.insight-card__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.insight-card__mini {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.02);
}

.insight-card--sales .insight-card__mini {
  border-color: rgba(224, 183, 84, 0.18);
  background: rgba(130, 95, 26, 0.12);
}

.insight-card--wishlist .insight-card__mini {
  border-color: rgba(149, 179, 223, 0.14);
  background: rgba(74, 104, 148, 0.08);
}

.insight-card--twitch .insight-card__mini {
  border-color: rgba(145, 112, 255, 0.24);
  background: rgba(91, 57, 158, 0.16);
}

.sparkline {
  width: 100%;
  height: 78px;
  display: block;
}

.sparkline__line {
  fill: none;
  stroke: #95b3df;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sparkline__area {
  fill: rgba(122, 161, 216, 0.12);
}

.insight-card__subtle {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.analysis-timeline {
  display: grid;
  gap: 10px;
}

.analysis-timeline-entry {
  display: grid;
  gap: 10px;
  padding: 14px 0;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  background: transparent;
}

.analysis-timeline-entry:last-child {
  border-bottom: none;
}

.analysis-timeline-entry__header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

.analysis-timeline-entry__source {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.analysis-timeline-entry__source h3 {
  margin: 0;
  font-size: 0.96rem;
}

.analysis-timeline-entry__aside {
  display: grid;
  justify-items: end;
  gap: 6px;
  flex-shrink: 0;
}

.analysis-timeline-entry__metric {
  color: var(--accent-bright);
  font-size: 0.94rem;
  white-space: nowrap;
}

.analysis-timeline-entry a {
  color: var(--accent-bright);
  text-decoration: none;
}

.analysis-timeline-entry--youtube {
  border-color: rgba(182, 36, 36, 0.2);
}

.analysis-timeline-entry--tiktok {
  border-color: rgba(47, 198, 196, 0.16);
}

.analysis-timeline-entry--twitch {
  border-color: rgba(145, 70, 255, 0.22);
}

.revenue-entry button {
  border: 0;
  color: #ffd4da;
  background: rgba(142, 56, 67, 0.18);
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
}

.chart-embed-card {
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}

.chart-embed-frame {
  width: 100%;
  min-height: 420px;
  border: 0;
  background: #0a1018;
}

.chart-embed-note {
  margin: 14px 0 0;
}

.games-grid,
.import-grid,
.insight-grid,
.marketing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.twitch-card,
.settings-card {
  padding: 18px 0;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  background: transparent;
}

.twitch-card:last-child,
.settings-card:last-child {
  border-bottom: none;
}

.settings-overlay {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: grid;
  justify-items: end;
  align-items: stretch;
  padding: 24px;
  background: rgba(0, 2, 6, 0.5);
  backdrop-filter: blur(8px);
  animation: fadeIn 200ms ease-out;
}

.settings-overlay[hidden] {
  display: none !important;
}

.settings-panel {
  width: min(520px, calc(100vw - 32px));
  height: calc(100vh - 48px);
  overflow: auto;
  padding: 24px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: linear-gradient(180deg, rgba(6, 10, 18, 0.99), rgba(4, 7, 13, 0.98));
  box-shadow: var(--shadow);
  animation: slideUp 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

.settings-panel__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}

.twitch-card {
  margin-bottom: 18px;
}

.twitch-card__header,
.twitch-summary,
.twitch-links,
.settings-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.twitch-card__header {
  align-items: flex-start;
}

.twitch-card__title-group {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.twitch-card__heading {
  display: grid;
  gap: 4px;
}

.twitch-card__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.twitch-card__brand-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9px;
  background: rgba(145, 70, 255, 0.16);
  border: 1px solid rgba(145, 70, 255, 0.36);
  color: #caa8ff;
}

.twitch-card__brand-icon svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.twitch-card__eyebrow {
  margin: 0;
  color: #b782ff;
  font-size: 0.94rem;
  letter-spacing: 0.18em;
}

.twitch-card__title-group h3 {
  margin: 0;
  font-size: 1.42rem;
}

.twitch-card__actions {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.twitch-summary strong {
  color: #b792ff;
  font-size: 1.8rem;
}

.twitch-links {
  justify-content: start;
  margin: 14px 0 18px;
}

.twitch-links a {
  color: var(--accent-bright);
  text-decoration: none;
}

.twitch-streams,
.settings-grid {
  display: grid;
  gap: 14px;
}

.settings-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.twitch-stream {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 14px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.02);
}

.twitch-stream img {
  width: 100%;
  border-radius: 10px;
  object-fit: cover;
}

.settings-form {
  display: grid;
  gap: 12px;
}

.settings-form__actions {
  display: grid;
  gap: 10px;
}

.settings-form label {
  display: grid;
  gap: 8px;
}

.settings-form input,
.settings-form textarea,
.settings-form button {
  border-radius: 10px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 13px 14px;
  font: inherit;
}

.settings-form textarea {
  resize: vertical;
  min-height: 104px;
}

.settings-form button {
  cursor: pointer;
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease, border-color 160ms ease;
}

.settings-form button.is-busy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.settings-form button:disabled {
  cursor: wait;
  opacity: 0.8;
}

.settings-form button:hover,
.settings-form button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(39, 68, 108, 0.28);
  filter: brightness(1.08);
  border-color: rgba(185, 205, 233, 0.34);
}

.settings-toggle {
  justify-content: flex-start;
}

.settings-toggle input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--accent-bright);
}

.marketing-dropdown {
  margin-top: 10px;
}

.marketing-dropdown summary {
  cursor: pointer;
  color: var(--accent-bright);
  margin-bottom: 12px;
}

.import-grid--single {
  grid-template-columns: 1fr;
}

.import-status {
  margin: 16px 0 0;
  color: var(--accent-bright);
}

.month-dialog {
  width: min(520px, calc(100% - 24px));
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(5, 8, 14, 0.99);
  color: var(--text);
  padding: 20px;
  box-shadow: var(--shadow);
  animation: slideUp 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

.month-dialog::backdrop {
  background: rgba(0, 0, 0, 0.7);
  animation: fadeIn 200ms ease-out;
}

.month-dialog__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.month-dialog__close {
  margin-top: 18px;
}

.outreach-preview-dialog .month-dialog__header {
  align-items: start;
}

.outreach-preview-dialog__close {
  width: 42px;
  min-width: 42px;
  height: 42px;
  margin-left: auto;
  padding: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 42px;
  font-size: 1.1rem;
  line-height: 1;
}

.outreach-preview-dialog {
  width: min(920px, calc(100% - 24px));
  height: min(86vh, 820px);
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr) auto;
  gap: 14px;
  overflow: hidden;
}

.outreach-preview-dialog__meta {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.outreach-preview-dialog__meta-card {
  display: grid;
  gap: 6px;
  padding: 12px 14px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
}

.outreach-preview-dialog__meta-card--hint {
  align-content: center;
  background: linear-gradient(180deg, rgba(17, 24, 38, 0.92), rgba(10, 15, 24, 0.9));
}

.outreach-preview-dialog__meta span {
  color: var(--muted);
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.outreach-preview-dialog__field {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.outreach-preview-dialog__field > span {
  color: var(--muted);
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.outreach-preview-dialog__field--body {
  min-height: 0;
  height: 100%;
}

.outreach-preview-dialog__field input,
.outreach-preview-dialog__field textarea {
  color-scheme: dark;
}

.outreach-preview-dialog__field input {
  width: 100%;
  min-width: 0;
  min-height: 48px;
  border-radius: 11px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: linear-gradient(180deg, rgba(16, 22, 34, 0.98), rgba(9, 13, 21, 0.96));
  color: #f3f7fd;
  -webkit-text-fill-color: #f3f7fd;
  caret-color: #f3f7fd;
  padding: 12px 14px;
  font: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.outreach-preview-dialog__field input::placeholder {
  color: rgba(194, 205, 221, 0.52);
}

.outreach-preview-dialog__field input:focus {
  outline: none;
  border-color: rgba(123, 169, 240, 0.46);
  box-shadow: 0 0 0 3px rgba(57, 95, 156, 0.18);
}

.outreach-preview-dialog__notice {
  padding: 11px 13px;
  border-radius: 11px;
  border: 1px solid rgba(222, 132, 86, 0.24);
  background: rgba(94, 52, 24, 0.22);
  color: #ffd2af;
  line-height: 1.45;
}

.outreach-preview-dialog__body {
  min-height: 0;
  height: 100%;
  padding: 16px;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.18);
  background: linear-gradient(180deg, rgba(13, 19, 30, 0.98), rgba(8, 12, 18, 0.96));
  color: #f4f8fd;
  -webkit-text-fill-color: #f4f8fd;
  caret-color: #f4f8fd;
  white-space: pre-wrap;
  line-height: 1.65;
  resize: none;
  overflow: auto;
  font: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.outreach-preview-dialog__body::placeholder {
  color: rgba(194, 205, 221, 0.52);
}

.outreach-preview-dialog__body:focus {
  outline: none;
  border-color: rgba(123, 169, 240, 0.46);
  box-shadow: 0 0 0 3px rgba(57, 95, 156, 0.18);
}

.outreach-preview-dialog__actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  padding-top: 2px;
}

.outreach-preview-dialog__actions .outreach-card__mail-button,
.outreach-preview-dialog__actions .ticket-card__restore {
  min-height: 46px;
}

.outreach-preview-dialog__actions .outreach-card__mail-button {
  min-width: 170px;
}

.month-grid {
  grid-template-columns: repeat(3, 1fr);
}

.month-grid__item {
  border: 1px solid rgba(149, 179, 223, 0.18);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  border-radius: 10px;
  padding: 14px 12px;
  font: inherit;
  cursor: pointer;
}

.month-grid__item.is-selected {
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
}

.game-card {
  overflow: hidden;
}

.game-card__image {
  width: 100%;
  height: auto;
  max-height: 220px;
  object-fit: cover;
  display: block;
  margin: 0 auto;
  border-radius: 12px;
}

.game-card__body {
  padding: 34px 20px 20px;
}

.game-card__media {
  position: relative;
  padding: 24px 24px 10px;
  background:
    radial-gradient(circle at top, rgba(70, 110, 170, 0.08), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.015), rgba(255, 255, 255, 0));
}

.game-card__logo-link {
  position: absolute;
  left: 40px;
  bottom: -18px;
  width: 86px;
  height: 86px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform 160ms ease;
}

.game-card__logo-link:hover {
  transform: scale(1.08);
}

.game-card__logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.35));
}

.game-card__logo-fallback {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--accent-bright);
  text-shadow: 0 10px 18px rgba(0, 0, 0, 0.35);
}

.games-switch-panel {
  padding-bottom: 18px;
}

.games-switcher {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.games-switcher__item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(141, 163, 193, 0.14);
  background: linear-gradient(180deg, rgba(33, 38, 45, 0.96), rgba(21, 25, 31, 0.96));
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform var(--transition-smooth), border-color var(--transition-smooth), background var(--transition-smooth), box-shadow var(--transition-smooth);
}

.games-switcher__item:hover,
.games-switcher__item:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(150, 182, 223, 0.24);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.22);
}

.games-switcher__item.is-active {
  border-color: rgba(128, 172, 230, 0.4);
  background: linear-gradient(180deg, rgba(35, 52, 76, 0.98), rgba(24, 36, 55, 0.98));
  box-shadow: 0 18px 40px rgba(19, 32, 50, 0.34);
}

.games-switcher__logo {
  width: 54px;
  height: 54px;
  object-fit: contain;
  flex: 0 0 auto;
}

.games-switcher__content {
  display: grid;
  gap: 4px;
}

.games-switcher__content strong {
  font-size: 1rem;
}

.games-switcher__content small {
  color: var(--muted);
}

.games-summary-banner {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(127, 164, 219, 0.18);
  background: linear-gradient(180deg, rgba(24, 28, 35, 0.96), rgba(17, 21, 26, 0.96));
  margin-bottom: 16px;
}

.games-summary-banner__label {
  color: var(--muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.games-summary-banner strong {
  font-size: 1.35rem;
  color: var(--accent-bright);
}

.recent-players-list {
  display: grid;
  gap: 12px;
}

.recent-player-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(127, 146, 173, 0.12);
  background: linear-gradient(180deg, rgba(29, 33, 39, 0.94), rgba(20, 23, 29, 0.96));
}

.recent-player-card__identity {
  display: grid;
  gap: 4px;
}

.recent-player-card__identity strong {
  font-size: 1rem;
}

.recent-player-card__identity span {
  color: var(--muted);
  font-size: 0.9rem;
}

.recent-player-card__score {
  flex: 0 0 auto;
}

.status-pill {
  white-space: nowrap;
  border-radius: 999px;
  padding: 9px 12px;
  background: rgba(66, 101, 143, 0.2);
  border: 1px solid rgba(149, 179, 223, 0.2);
  color: var(--accent-bright);
  font-size: 0.85rem;
}

.status-pill--sales {
  background: rgba(164, 122, 28, 0.2);
  border-color: rgba(224, 183, 84, 0.3);
  color: #f6d98f;
}

.status-pill--wishlist {
  background: rgba(66, 101, 143, 0.2);
  border-color: rgba(149, 179, 223, 0.2);
  color: var(--accent-bright);
}

.status-pill--twitch {
  background: rgba(102, 63, 180, 0.24);
  border-color: rgba(169, 125, 255, 0.32);
  color: #e7d7ff;
}

.status-pill--open {
  background: rgba(52, 142, 93, 0.18);
  border-color: rgba(95, 196, 138, 0.3);
  color: #bff2d2;
}

.status-pill--closed {
  background: rgba(123, 136, 157, 0.18);
  border-color: rgba(175, 188, 208, 0.26);
  color: #dbe6f8;
}

.game-meta {
  margin-top: 10px;
  line-height: 1.6;
}

.game-meta--live {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.game-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 18px;
}

.game-stat strong {
  display: block;
  margin-top: 8px;
  font-size: 1.05rem;
}

.game-stat__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.icon-button {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(100, 140, 190, 0.15);
  background: rgba(255, 255, 255, 0.03);
  color: var(--accent-bright);
  cursor: pointer;
  transition: all var(--transition-smooth);
}

.icon-button:hover {
  transform: rotate(25deg) scale(1.1);
  background: rgba(40, 65, 100, 0.25);
  border-color: rgba(100, 140, 190, 0.3);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

.icon-button:disabled {
  opacity: 0.4;
  cursor: default;
}

.icon-button svg,
.marketing-icon svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.empty-state {
  padding: 20px;
  border-radius: 12px;
  border: 1px dashed rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.01);
}

.page-footer {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-top: 18px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(4, 7, 13, 0.8);
  color: var(--muted);
  box-shadow: var(--shadow);
}

.page-footer p {
  margin: 0;
}

.marketing-card {
  display: grid;
  gap: 14px;
  padding: 16px 0;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  background: transparent;
}

.marketing-card:last-child {
  border-bottom: none;
}

.marketing-card__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.marketing-card__identity {
  display: flex;
  align-items: center;
  gap: 12px;
}

.marketing-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.marketing-grid--stack {
  display: grid;
  gap: 14px;
}

.marketing-card--compact {
  padding: 16px 18px;
}

.marketing-followers {
  display: grid;
  gap: 4px;
  justify-items: end;
  text-align: right;
}

.marketing-followers span {
  color: var(--muted);
  font-size: 0.88rem;
}

.marketing-icon-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.marketing-icon-link:hover .marketing-icon,
.marketing-icon-link:focus-visible .marketing-icon {
  transform: scale(1.08);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
}

.marketing-list {
  display: grid;
  gap: 10px;
}

.marketing-item {
  padding: 10px 0;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  background: transparent;
}

.marketing-item:last-child {
  border-bottom: none;
}

.marketing-item h4 {
  margin: 0;
  font-size: 0.98rem;
}

.marketing-item__meta {
  margin-top: 8px;
  color: var(--muted);
  font-size: 0.9rem;
}

.marketing-item__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.marketing-item__stats span {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: var(--accent-bright);
  font-size: 0.86rem;
}

.marketing-icon--youtube {
  background: rgba(182, 36, 36, 0.22);
  color: #ffd5d5;
}

.marketing-icon--tiktok {
  background: rgba(47, 198, 196, 0.14);
  color: #bff8f7;
}

.marketing-icon--twitch {
  background: rgba(145, 70, 255, 0.16);
  color: #d8c1ff;
  border-color: rgba(145, 70, 255, 0.34);
}

.marketing-icon--steam-news,
.marketing-icon--steam-tavern,
.marketing-icon--steam-werewolf {
  background: linear-gradient(180deg, rgba(23, 34, 47, 0.95), rgba(14, 20, 30, 0.95));
  color: #d9edf9;
  border-color: rgba(112, 162, 196, 0.34);
}

.marketing-icon--facebook {
  background: rgba(44, 97, 181, 0.22);
  color: #d7e7ff;
}

.marketing-card a {
  color: var(--accent-bright);
  text-decoration: none;
}

.development-grid {
  display: grid;
  gap: 18px;
}

.tickets-grid {
  display: grid;
  gap: 18px;
}

.tickets-shell {
  display: grid;
  gap: 18px;
}

.tickets-switcher {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.tickets-switcher__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.14);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.tickets-switcher__item strong {
  color: var(--accent-bright);
}

.tickets-switcher__item.is-active {
  border-color: rgba(149, 174, 214, 0.36);
  background: linear-gradient(180deg, rgba(52, 78, 112, 0.34), rgba(255, 255, 255, 0.03));
}

.tickets-switcher__item:hover,
.tickets-switcher__item:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(149, 174, 214, 0.26);
}

.tickets-board {
  padding: 20px 0 0;
  border-radius: 0;
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  background: transparent;
}

.tickets-board__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.tickets-list {
  display: grid;
  gap: 16px;
}

.ticket-card {
  padding: 0;
  border-radius: 14px;
  border: 1px solid rgba(151, 171, 205, 0.12);
  background:
    linear-gradient(180deg, rgba(19, 26, 39, 0.96), rgba(13, 18, 28, 0.96)),
    radial-gradient(circle at top left, rgba(112, 143, 198, 0.08), transparent 48%);
  overflow: hidden;
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.18);
  transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.ticket-card:hover {
  transform: translateY(-1px);
  border-color: rgba(155, 180, 220, 0.22);
  box-shadow: 0 22px 54px rgba(0, 0, 0, 0.24);
}

.ticket-card--closed {
  border-color: rgba(232, 84, 84, 0.4);
  box-shadow: inset 0 0 0 1px rgba(190, 44, 44, 0.18);
  background: linear-gradient(180deg, rgba(30, 15, 18, 0.92), rgba(18, 10, 13, 0.9));
}

.ticket-card__actions,
.ticket-card__stats {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.ticket-card__summary {
  list-style: none;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 18px 15px;
  cursor: pointer;
}

.ticket-card__summary::-webkit-details-marker {
  display: none;
}

.ticket-card__summary-main {
  min-width: 0;
  display: grid;
  gap: 8px;
  flex: 1;
}

.ticket-card__summary-main h3 {
  margin: 0;
  font-size: 1.03rem;
  line-height: 1.35;
}

.ticket-card__summary-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.ticket-card__summary-dot {
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: rgba(146, 164, 195, 0.75);
}

.ticket-card__summary-date,
.ticket-card__summary-reporter {
  margin: 0;
  color: var(--muted);
  font-size: 0.85rem;
}

.ticket-card__summary-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ticket-card__summary-side {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}

.ticket-card__summary-action {
  min-width: 122px;
}

.ticket-card__summary-chevron {
  color: var(--muted);
  font-size: 1.1rem;
  line-height: 1;
  transition: transform 160ms ease;
}

.ticket-card[open] .ticket-card__summary-chevron {
  transform: rotate(180deg);
}

.ticket-card__body {
  display: grid;
  gap: 14px;
  padding: 0 18px 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
}

.ticket-card__actions {
  flex-wrap: wrap;
  justify-content: flex-end;
  padding-top: 14px;
}

.ticket-card__meta {
  margin: 0 0 12px;
  color: var(--muted);
  line-height: 1.6;
}

.ticket-card__description {
  margin: 0;
  line-height: 1.65;
  white-space: pre-wrap;
  color: rgba(235, 241, 250, 0.92);
}

.ticket-card__stats {
  flex-wrap: wrap;
  justify-content: flex-start;
}

.ticket-card__close {
  border-radius: 999px;
  border: 1px solid rgba(232, 84, 84, 0.34);
  background: rgba(121, 27, 27, 0.22);
  color: #ffd7dc;
  padding: 9px 14px;
  font: inherit;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.ticket-card__close:hover,
.ticket-card__close:focus-visible {
  transform: translateY(-1px);
  background: rgba(150, 38, 38, 0.32);
  border-color: rgba(255, 162, 174, 0.42);
}

.ticket-card__close:disabled,
.ticket-card__restore:disabled {
  cursor: wait;
  opacity: 0.65;
}

.ticket-card__restore {
  border-radius: 999px;
  border: 1px solid rgba(95, 146, 214, 0.3);
  background: rgba(36, 61, 93, 0.28);
  color: var(--accent-bright);
  padding: 9px 14px;
  font: inherit;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.ticket-card__restore:hover,
.ticket-card__restore:focus-visible {
  transform: translateY(-1px);
  background: rgba(52, 78, 112, 0.42);
  border-color: rgba(149, 174, 214, 0.42);
}

.ticket-card__facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.ticket-card__facts div {
  display: grid;
  gap: 4px;
  padding: 12px 13px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.028);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.ticket-card__facts span {
  color: var(--muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.ticket-card__taverns-block {
  display: grid;
  gap: 10px;
}

.ticket-card__taverns {
  display: grid;
  gap: 12px;
}

.ticket-card__tavern {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-radius: 11px;
  border: 1px solid rgba(151, 171, 205, 0.09);
  background: rgba(255, 255, 255, 0.024);
}

.ticket-card__tavern-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.ticket-card__tavern-grid span {
  color: var(--muted);
}

.outreach-shell {
  display: grid;
  gap: 18px;
}

.outreach-status-loading {
  display: inline-flex;
  align-items: center;
  margin-left: 10px;
  vertical-align: middle;
}

.outreach-toolbar {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
  padding: 0 0 20px;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  background: transparent;
}

.outreach-toolbar__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: end;
  gap: 12px;
}

.outreach-toolbar__field {
  display: grid;
  gap: 6px;
  min-width: 180px;
}

.outreach-toolbar__field span {
  color: var(--muted);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.outreach-toolbar__field select,
.outreach-toolbar__field input {
  min-height: 42px;
}

.outreach-toolbar__field input,
.outreach-toolbar__field select,
.outreach-template-card__field input,
.outreach-template-card__field textarea {
  border-radius: 11px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background:
    linear-gradient(180deg, rgba(14, 22, 34, 0.96), rgba(8, 12, 18, 0.92));
  color: var(--text);
  padding: 12px 14px;
  font: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.outreach-toolbar__field select,
.outreach-toolbar__field select option,
.outreach-toolbar__field select optgroup {
  color: var(--text);
  background: #0d1420;
}

.outreach-toolbar__field select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(180deg, rgba(14, 22, 34, 0.96), rgba(8, 12, 18, 0.92)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5.25L7 9.25L11 5.25' fill='none' stroke='%23d8e2f0' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: center, right 14px center;
  background-size: auto, 14px 14px;
  padding-right: 40px;
}

.outreach-toolbar__field select option:hover,
.outreach-toolbar__field select option:checked,
.outreach-toolbar__field select option:focus {
  background: #1a2740;
  color: #f5f8fc;
}

.outreach-toolbar__field input::placeholder,
.outreach-template-card__field input::placeholder,
.outreach-template-card__field textarea::placeholder {
  color: rgba(194, 205, 221, 0.52);
}

.outreach-toolbar__field input:focus,
.outreach-toolbar__field select:focus,
.outreach-template-card__field input:focus,
.outreach-template-card__field textarea:focus {
  outline: none;
  border-color: rgba(185, 205, 233, 0.4);
  box-shadow: 0 0 0 4px rgba(82, 120, 175, 0.16);
}

#outreachLanguageSelect,
#outreachSettingsDefaultLanguage {
  color: var(--text);
}

.outreach-list {
  display: grid;
  gap: 14px;
}

.outreach-list__toolbar {
  display: grid;
  gap: 18px;
  padding: 18px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background:
    linear-gradient(180deg, rgba(14, 20, 31, 0.92), rgba(8, 12, 20, 0.88));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.outreach-filter-bar {
  display: grid;
  gap: 12px;
}

.outreach-filter-bar__search,
.outreach-filter-bar__filters {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: end;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.025);
}

.outreach-filter-bar__search {
  justify-content: flex-start;
}

.outreach-game-search-group {
  display: grid;
  gap: 8px;
  flex: 0 1 260px;
  min-width: 220px;
  max-width: 260px;
}

.outreach-game-search-group .outreach-toolbar__field {
  min-width: 0;
}

.outreach-game-suggestions {
  display: grid;
  gap: 6px;
  padding: 8px;
  border-radius: 11px;
  border: 1px solid rgba(149, 174, 214, 0.18);
  background: rgba(10, 16, 26, 0.96);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
  max-height: 220px;
  overflow: auto;
}

.outreach-game-suggestions__item {
  appearance: none;
  border: 1px solid rgba(149, 174, 214, 0.14);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  text-align: left;
  padding: 10px 12px;
  font: inherit;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.outreach-game-suggestions__item:hover,
.outreach-game-suggestions__item:focus-visible {
  border-color: rgba(110, 154, 224, 0.34);
  background: rgba(44, 69, 104, 0.28);
  transform: translateY(-1px);
  outline: none;
}

.outreach-game-suggestions__error {
  color: #ff8b96;
  font-size: 0.84rem;
  line-height: 1.4;
}

.outreach-inline-loader {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
}

.outreach-filter-bar__spacer {
  flex: 1 1 auto;
}

.outreach-filter-bar__filters {
  justify-content: space-between;
}

.outreach-list__toolbar-left,
.outreach-list__toolbar-right {
  display: flex;
  align-items: end;
  gap: 12px;
  flex-wrap: wrap;
}

.outreach-list__toolbar-left {
  flex: 1 1 540px;
}

.outreach-list__toolbar-right {
  flex: 0 0 auto;
  justify-content: flex-end;
}

.outreach-list__toolbar-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.outreach-list__toolbar-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.outreach-toolbar__field--search {
  flex: 1 1 320px;
  min-width: min(280px, 100%);
}

.outreach-toolbar__field--creator-search {
  flex: 0 1 260px;
  min-width: 220px;
  max-width: 260px;
}

.outreach-toolbar__field--loaded-filter {
  flex: 1 1 360px;
  min-width: min(320px, 100%);
  max-width: 520px;
}

.outreach-toolbar__field--compact {
  min-width: 128px;
}

.outreach-toolbar__icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding-inline: 16px;
  white-space: nowrap;
}

.outreach-toolbar__icon-button--fixed {
  min-width: 198px;
}

.outreach-toolbar__icon-button--danger {
  color: #ffd8dc;
  border-color: rgba(255, 109, 109, 0.34);
  background: rgba(115, 28, 38, 0.28);
}

.outreach-toolbar__icon-button--danger:hover {
  border-color: rgba(255, 132, 132, 0.46);
  background: rgba(146, 36, 48, 0.38);
}

.outreach-toolbar__icon-button--round {
  width: 44px;
  min-width: 44px;
  padding: 0;
  border-radius: 999px;
  font-size: 1.05rem;
}

.outreach-toolbar__icon-button[data-search-outreach-name] {
  min-width: 156px;
}

.outreach-strictness {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.outreach-strictness--right {
  justify-content: flex-end;
}

.outreach-strictness__label {
  color: var(--muted);
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.outreach-strictness__button {
  min-width: 96px;
  padding: 8px 12px;
  border-radius: 9px;
  border: 1px solid rgba(149, 174, 214, 0.16);
  background: rgba(255, 255, 255, 0.035);
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.outreach-strictness__icon {
  width: 1.4rem;
  height: 1.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.12rem;
  line-height: 1;
  font-family: "Segoe UI Symbol", "Noto Sans Symbols 2", "Noto Sans Symbols", sans-serif;
}

.outreach-strictness__button:hover {
  transform: translateY(-1px);
}

.outreach-strictness__button.is-active {
  color: var(--text);
}

.outreach-strictness__button--green {
  background: rgba(16, 185, 129, 0.08);
}

.outreach-strictness__button--blue {
  background: rgba(59, 130, 246, 0.08);
}

.outreach-strictness__button--amber {
  background: rgba(245, 158, 11, 0.08);
}

.outreach-strictness__button--orange {
  background: rgba(249, 115, 22, 0.08);
}

.outreach-strictness__button--red {
  background: rgba(239, 68, 68, 0.08);
}

.outreach-strictness__button--green.is-active {
  border-color: rgba(52, 211, 153, 0.45);
  background: rgba(16, 185, 129, 0.16);
}

.outreach-strictness__button--blue.is-active {
  border-color: rgba(96, 165, 250, 0.45);
  background: rgba(59, 130, 246, 0.16);
}

.outreach-strictness__button--amber.is-active {
  border-color: rgba(251, 191, 36, 0.45);
  background: rgba(245, 158, 11, 0.16);
}

.outreach-strictness__button--orange.is-active {
  border-color: rgba(251, 146, 60, 0.45);
  background: rgba(249, 115, 22, 0.16);
}

.outreach-strictness__button--red.is-active {
  border-color: rgba(248, 113, 113, 0.45);
  background: rgba(239, 68, 68, 0.14);
}

.outreach-list__count-text {
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 44px;
  color: var(--muted);
  font-size: 0.92rem;
  text-align: right;
}

.outreach-search-progress {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0 14px;
  color: var(--muted);
  font-size: 0.92rem;
}

.outreach-list__more-button {
  justify-self: center;
  min-width: 240px;
}

.outreach-filter-bar__toggle {
  min-height: 44px;
  padding: 0 14px;
  border-radius: 11px;
  border: 1px solid rgba(149, 174, 214, 0.18);
  background: rgba(255, 255, 255, 0.03);
}

.outreach-template-card {
  display: grid;
  gap: 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.025);
  overflow: hidden;
}

.outreach-template-card__summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 20px;
}

.outreach-template-card--toolbar {
  align-self: flex-end;
}

.outreach-template-card--toolbar[open] {
  flex-basis: 100%;
  width: 100%;
}

.outreach-template-card__summary--button {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  min-height: 42px;
  padding: 10px 14px;
}

.outreach-template-card__button-label {
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 600;
}

.outreach-template-dialog {
  width: min(760px, calc(100% - 24px));
}

.outreach-template-dialog__header {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 16px;
}

.outreach-template-dialog__fields {
  display: grid;
  gap: 12px;
}

.outreach-template-card__summary-copy {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.outreach-template-card__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  font-size: 1.1rem;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.outreach-template-card__summary::-webkit-details-marker {
  display: none;
}

.outreach-template-card__content {
  display: grid;
  gap: 14px;
  padding: 0 20px 20px;
}

.outreach-template-card[open] .outreach-template-card__summary {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.outreach-template-card[open] .outreach-template-card__chevron {
  transform: rotate(180deg);
  border-color: rgba(185, 205, 233, 0.32);
  background: rgba(149, 174, 214, 0.12);
}

.outreach-template-card__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.outreach-template-card__fields {
  display: grid;
  gap: 12px;
}

.outreach-template-card__field {
  min-width: 100%;
}

.outreach-template-card textarea {
  min-height: 220px;
  resize: vertical;
}

.outreach-card {
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.026), rgba(255, 255, 255, 0.018));
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.025);
}

.outreach-card--played {
  border-color: rgba(149, 174, 214, 0.22);
}

.outreach-card__summary {
  list-style: none;
  cursor: pointer;
  padding: 13px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.outreach-card__summary::-webkit-details-marker {
  display: none;
}

.outreach-card[open] .outreach-card__summary {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.outreach-card__identity {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  min-width: 0;
  flex: 1;
}

.outreach-card__avatar {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  flex: 0 0 42px;
}

.outreach-card__avatar--fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-bright);
  font-weight: 700;
}

.outreach-card__summary h3 {
  margin: 0;
  display: inline;
  font-size: 1rem;
  line-height: 1.25;
}

.outreach-card__identity > div {
  min-width: 0;
  flex: 1;
}

.outreach-card__platform-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  font-size: 0.8rem;
  background: rgba(255, 255, 255, 0.08);
  flex: 0 0 22px;
  text-decoration: none;
  align-self: center;
}

.outreach-card__platform-badge--twitch {
  color: #d2c2ff;
  background: rgba(145, 70, 255, 0.18);
}

.outreach-card__platform-badge--youtube {
  color: #ffd0d0;
  background: rgba(255, 0, 0, 0.18);
}

.outreach-card__summary-meta,
.outreach-card__note,
.outreach-card__description {
  margin: 0;
  color: var(--muted);
  line-height: 1.35;
  font-size: 0.92rem;
}

.outreach-card__summary-meta {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
}

.outreach-status-list {
  display: grid;
  gap: 6px;
  margin: 10px 0 0;
}

.outreach-status-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.outreach-status-item__label {
  color: var(--muted);
  font-size: 0.88rem;
  min-width: 120px;
}

.outreach-status-text {
  font-size: 0.92rem;
  font-weight: 700;
}

.outreach-status-number {
  font-size: 1.18rem;
  font-weight: 900;
  letter-spacing: 0.03em;
}

/* Compact horizontal status chips */
.outreach-status-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 8px 0 0;
}

.outreach-status-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 8px 3px 6px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.07);
  cursor: default;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.outreach-status-chip__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex: 0 0 6px;
  background: currentColor;
  opacity: 0.9;
}

.outreach-status-chip--green {
  color: #62e6a8;
}

.outreach-status-chip--amber {
  color: #f0b34d;
}

.outreach-status-chip--red {
  color: #ff8d8d;
}

.outreach-status-chip--neutral {
  color: var(--muted);
}

.outreach-status-chip--keys {
  font-weight: 700;
}

.outreach-status-text.is-green,
.outreach-status-number.is-green {
  color: #62e6a8;
}

.outreach-status-text.is-amber,
.outreach-status-number.is-amber {
  color: #f0b34d;
}

.outreach-status-text.is-red,
.outreach-status-number.is-red {
  color: #ff8d8d;
}

.outreach-status-text.is-neutral,
.outreach-status-number.is-neutral {
  color: var(--muted);
}

.outreach-status-keys {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 18px 0 8px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.035);
  box-shadow: inset 0 0 0 1px rgba(149, 174, 214, 0.08);
}

.outreach-status-keys .outreach-status-item__label {
  min-width: 0;
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.outreach-status-keys .outreach-status-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(12, 18, 28, 0.9);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}

.outreach-card__summary-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}

.outreach-card__summary-subline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 7px;
  margin-top: 8px;
}

.outreach-card__summary-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.outreach-card__metric-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(149, 174, 214, 0.16);
  background: rgba(255, 255, 255, 0.035);
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
}

.outreach-card__metric-pill.is-good {
  color: #84edb4;
  border-color: rgba(76, 196, 118, 0.26);
  background: rgba(27, 76, 45, 0.22);
}

.outreach-card__metric-pill.is-warning {
  color: #ffabab;
  border-color: rgba(217, 92, 92, 0.24);
  background: rgba(91, 29, 29, 0.22);
}

.outreach-card__metric-pill--key {
  color: #ffe7a7;
  border-color: rgba(227, 181, 63, 0.24);
  background: rgba(97, 72, 17, 0.24);
}

.outreach-card__email-chip {
  flex: 1 1 320px;
  min-width: 0;
  max-width: 100%;
  text-align: left;
  justify-content: flex-start;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.outreach-card__profile-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.outreach-card__game-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 20px;
  padding: 0 7px;
  border-radius: 999px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(149, 174, 214, 0.1);
  color: var(--text);
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.outreach-card__game-pill.is-unplayed {
  opacity: 0.38;
  filter: grayscale(1);
}

.outreach-card__game-pill--tl {
  padding: 2px 4px;
  background: transparent;
  border-color: transparent;
}

.outreach-card__tl-logo {
  display: block;
  width: 18px;
  height: 18px;
  object-fit: contain;
  border-radius: 3px;
}

.outreach-card__missing-email {
  color: #ff9f9f;
}

.outreach-card__summary-status {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: center;
}

.outreach-card__summary-status .status-pill {
  white-space: normal;
  text-align: right;
  word-break: break-word;
}

.outreach-card__quick-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 8px;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.14);
  background: rgba(255, 255, 255, 0.025);
}

.outreach-card__quick-actions .ticket-card__restore,
.outreach-card__quick-actions .ticket-card__close {
  min-width: 112px;
  min-height: 38px;
  padding: 0 12px;
  font-size: 0.88rem;
}

.outreach-card__mail-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 122px;
  letter-spacing: 0.04em;
  font-size: 0.96rem;
  cursor: pointer;
}

.outreach-card__mail-button.is-ready {
  border-color: rgba(92, 201, 120, 0.42);
  background: rgba(34, 92, 48, 0.28);
  color: #c7f4d0;
}

.outreach-card__mail-button.is-ready:disabled {
  opacity: 0.7;
}

.outreach-card__mail-button.is-missing {
  border-color: rgba(224, 82, 82, 0.4);
  background: rgba(122, 30, 30, 0.22);
  color: #ff9f9f;
}

.outreach-card__mail-button.is-missing:disabled {
  opacity: 0.7;
}

.outreach-card__body {
  display: grid;
  gap: 12px;
  padding: 0 14px 14px;
}

/* Game link row shown when game search is active */
.outreach-card__game-link-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 8px;
  background: rgba(98, 230, 168, 0.06);
  border: 1px solid rgba(98, 230, 168, 0.15);
}

.outreach-card__game-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.88rem;
  font-weight: 600;
  color: #62e6a8;
  text-decoration: none;
  transition: opacity 0.15s;
}

.outreach-card__game-link:hover {
  opacity: 0.8;
  text-decoration: underline;
}

/* Compact meta chip used inline in summary row */
.outreach-card__meta-chip {
  display: inline-flex;
  align-items: center;
  padding: 1px 6px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 500;
  background: rgba(255, 255, 255, 0.06);
  color: var(--muted);
  white-space: nowrap;
}

.outreach-card__meta-chip--key {
  color: #f0b34d;
  background: rgba(240, 179, 77, 0.1);
}

.outreach-card__facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 14px;
  border-radius: 13px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.022);
}

.outreach-card__facts div {
  display: grid;
  gap: 2px;
  padding: 6px 8px;
  border-radius: 7px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.02);
}

.outreach-card__facts span {
  color: var(--muted);
  font-size: 0.82rem;
}

.outreach-card__facts--4col {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.outreach-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.outreach-card__actions .ticket-card__restore,
.outreach-card__actions .ticket-card__close {
  text-align: center;
  text-decoration: none;
}

.outreach-card__details {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 13px;
  border: 1px solid rgba(149, 174, 214, 0.14);
  background: rgba(255, 255, 255, 0.02);
}

.outreach-card__analysis-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.outreach-card__analysis-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.outreach-card__analysis-actions .ticket-card__restore {
  min-height: 40px;
}

.outreach-card__key-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 4px 0 2px;
  min-height: 38px;
  border-radius: 11px;
  border: 1px solid rgba(149, 174, 214, 0.12);
  background: rgba(255, 255, 255, 0.028);
}

.development-project-card__rename {
  border: 1px solid rgba(109, 151, 221, 0.3);
  background: rgba(34, 50, 76, 0.28);
  color: #d8e7ff;
  border-radius: 9px;
  padding: 8px 12px;
  font: inherit;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.development-project-card__rename:hover,
.development-project-card__rename:focus-visible {
  transform: translateY(-1px);
  background: rgba(46, 68, 102, 0.42);
  border-color: rgba(151, 186, 245, 0.46);
}

.outreach-card__key-value {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 9px;
  border: 1px solid rgba(149, 174, 214, 0.18);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  font-size: 0.9rem;
  letter-spacing: 0.04em;
}

.outreach-card__copy-key {
  min-width: 36px;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.outreach-card__hook-chips {
  gap: 6px;
}

.outreach-card__draft {
  display: grid;
  gap: 10px;
  padding-top: 4px;
}

.outreach-card__draft textarea {
  min-height: 180px;
  resize: vertical;
}

.outreach-card__criteria {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.35;
}

.outreach-card__reasons {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.outreach-settings-dialog {
  width: min(920px, calc(100vw - 32px));
}

.outreach-settings-dialog__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.outreach-settings-dialog textarea {
  min-height: 132px;
  resize: vertical;
}

.outreach-settings-dialog__toggle {
  align-self: end;
}

.development-switcher {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.development-switcher__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.14);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.development-switcher__label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.development-switcher__logo {
  width: 26px;
  height: 26px;
  object-fit: contain;
  filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.28));
}

.development-switcher__item strong {
  color: var(--accent-bright);
}

.development-switcher__item.is-active {
  border-color: rgba(149, 174, 214, 0.36);
  background: linear-gradient(180deg, rgba(52, 78, 112, 0.34), rgba(255, 255, 255, 0.03));
}

.development-switcher__item:hover {
  transform: translateY(-1px);
  border-color: rgba(149, 174, 214, 0.26);
}

.development-switcher__item:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(149, 174, 214, 0.32);
  background: rgba(34, 50, 76, 0.38);
  box-shadow: 0 14px 28px rgba(7, 14, 24, 0.3);
}

.development-board {
  padding: 20px 0 0;
  border-radius: 0;
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  background: transparent;
}

.development-board__header {
  margin-bottom: 18px;
}

.development-sections {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.development-extras {
  display: grid;
  grid-template-columns: minmax(320px, 1fr);
  gap: 18px;
  margin-top: 18px;
}

.development-card {
  padding: 18px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.018);
}

.development-card--features {
  border-color: rgba(95, 146, 214, 0.18);
}

.development-card--bugs {
  border-color: rgba(232, 84, 84, 0.4);
  box-shadow: inset 0 0 0 1px rgba(190, 44, 44, 0.18);
}

.development-card--tracker {
  border-color: rgba(86, 150, 234, 0.18);
  background: linear-gradient(180deg, rgba(18, 28, 43, 0.96), rgba(11, 17, 27, 0.94));
}

.development-card--timeline {
  border-color: rgba(169, 183, 215, 0.18);
  background: linear-gradient(180deg, rgba(16, 24, 36, 0.98), rgba(10, 15, 23, 0.94));
}

.development-card__header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
  margin-bottom: 16px;
}

.development-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  margin-bottom: 16px;
}

.development-form input,
.development-form button {
  border-radius: 10px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 13px 14px;
  font: inherit;
}

.development-form button {
  cursor: pointer;
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease, border-color 160ms ease;
}

.development-form button:hover,
.development-form button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(39, 68, 108, 0.28);
  filter: brightness(1.08);
  border-color: rgba(185, 205, 233, 0.34);
}

.development-time-form,
.development-timeline-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.development-time-entry-form {
  margin-bottom: 18px;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.14);
  background: rgba(255, 255, 255, 0.025);
  overflow: hidden;
}

.development-time-entry-form summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  color: var(--accent-bright);
  font-weight: 600;
}

.development-time-entry-form summary::-webkit-details-marker {
  display: none;
}

.development-time-entry-form[open] summary {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.development-time-entry-form .development-time-form {
  margin: 0;
  padding: 16px;
}

.development-timer {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  padding: 16px;
  border-radius: 12px;
  border: 1px solid rgba(108, 156, 228, 0.18);
  background: rgba(255, 255, 255, 0.025);
}

.development-timer__summary {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.development-timer__summary strong {
  display: block;
  margin-top: 6px;
  font-size: 1.5rem;
  letter-spacing: 0.06em;
}

.development-timer__controls {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.development-timer__controls label {
  display: grid;
  gap: 8px;
}

.development-timer__note {
  grid-column: 1 / -1;
}

.development-timer__controls input,
.development-timer__controls select,
.development-timer__actions button {
  border-radius: 10px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 13px 14px;
  font: inherit;
}

.development-timer__actions {
  display: flex;
  gap: 10px;
}

.development-timer__actions button {
  cursor: pointer;
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease, border-color 160ms ease;
}

.development-timer__actions button:hover,
.development-timer__actions button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(39, 68, 108, 0.28);
  filter: brightness(1.08);
  border-color: rgba(185, 205, 233, 0.34);
}

.development-timer__actions .button-secondary {
  background: rgba(20, 29, 44, 0.92);
}

.development-timer__actions .button-danger {
  background: linear-gradient(180deg, rgba(140, 52, 67, 0.95), rgba(93, 28, 39, 0.95));
  border-color: rgba(196, 101, 116, 0.3);
}

.development-timer__actions button:disabled {
  cursor: default;
  opacity: 0.55;
  transform: none;
  box-shadow: none;
  filter: none;
}

.development-time-form label,
.development-timeline-form label {
  display: grid;
  gap: 8px;
}

.development-time-form__note,
.development-timeline-form__title,
.development-timeline-form__note {
  grid-column: 1 / -1;
}

.development-time-form input,
.development-time-form select,
.development-time-form button,
.development-timeline-form input,
.development-timeline-form select,
.development-timeline-form button {
  border-radius: 10px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 13px 14px;
  font: inherit;
}

.development-time-form button,
.development-timeline-form button {
  cursor: pointer;
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease, border-color 160ms ease;
}

.development-time-form button:hover,
.development-time-form button:focus-visible,
.development-timeline-form button:hover,
.development-timeline-form button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(39, 68, 108, 0.28);
  filter: brightness(1.08);
  border-color: rgba(185, 205, 233, 0.34);
}

.development-project-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  margin-bottom: 14px;
}

.development-project-form__name {
  display: grid;
  gap: 8px;
}

.development-project-form input,
.development-project-form button {
  border-radius: 10px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 13px 14px;
  font: inherit;
}

.development-project-form button {
  cursor: pointer;
  background: linear-gradient(180deg, #3860a0, #1e3a6e);
}

.development-project-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.development-month-overview {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}

.development-month-overview__header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}

.development-month-overview__header strong {
  display: block;
  font-size: 1rem;
}

.development-month-overview__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}

.development-month-card {
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
  padding: 14px;
  display: grid;
  gap: 6px;
}

.development-month-card.is-current {
  border-color: rgba(109, 151, 221, 0.34);
  background: rgba(34, 50, 76, 0.38);
}

.development-month-card span,
.development-month-card small {
  color: var(--muted);
}

.development-month-card strong {
  font-size: 1.05rem;
}

.development-project-card {
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
  padding: 14px;
  display: grid;
  gap: 12px;
}

.development-project-card.is-active {
  border-color: rgba(109, 151, 221, 0.34);
  background: rgba(34, 50, 76, 0.38);
}

.development-project-card__header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}

.development-project-card__actions {
  display: grid;
  gap: 8px;
  justify-items: end;
}

.development-project-card__header strong {
  display: block;
  font-size: 1rem;
}

.development-project-card__delete {
  border: 1px solid rgba(224, 82, 82, 0.28);
  background: rgba(122, 30, 30, 0.22);
  color: #ffb3b3;
  border-radius: 9px;
  padding: 8px 12px;
  font: inherit;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.development-project-card__delete:hover,
.development-project-card__delete:focus-visible {
  transform: translateY(-1px);
  background: rgba(154, 36, 36, 0.34);
  border-color: rgba(255, 108, 108, 0.46);
}

.development-project-card__stats {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.88rem;
}

.development-week {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.development-week__day,
.development-project-total,
.development-time-entry,
.development-timeline-entry {
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
}

.development-week__day {
  padding: 12px;
  display: grid;
  gap: 6px;
}

.development-week__day span,
.development-project-total span {
  color: var(--muted);
  font-size: 0.84rem;
}

.development-project-totals {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.development-project-total {
  padding: 12px;
  display: grid;
  gap: 6px;
}

.development-project-total.is-active {
  border-color: rgba(109, 151, 221, 0.34);
  background: rgba(34, 50, 76, 0.38);
}

.development-time-log,
.development-timeline {
  display: grid;
  gap: 12px;
}

.development-time-log__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--accent-bright);
}

.development-time-entry,
.development-timeline-entry {
  padding: 14px;
}

.development-time-entry {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.development-time-entry p,
.development-time-entry span {
  margin: 0;
}

.development-time-entry p {
  color: var(--muted);
  font-size: 0.9rem;
  margin-bottom: 4px;
}

.development-time-entry span {
  display: block;
  margin-top: 6px;
  color: var(--muted);
}

.development-timeline-entry__main {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
  margin-bottom: 12px;
}

.development-timeline-entry h4 {
  margin: 0;
  font-size: 1rem;
}

.development-list {
  display: grid;
  gap: 10px;
}

.development-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 9px;
  border: 1px solid rgba(255, 255, 255, 0.04);
  background: rgba(255, 255, 255, 0.015);
}

.development-item.is-done {
  border-color: rgba(92, 201, 120, 0.42);
  background: rgba(34, 92, 48, 0.28);
  box-shadow: inset 0 0 0 1px rgba(92, 201, 120, 0.12);
}

.development-item.is-done .development-item__toggle span {
  text-decoration: line-through;
  color: #c7f4d0;
}

.development-item__toggle {
  display: flex;
  align-items: start;
  gap: 12px;
  flex: 1;
  cursor: pointer;
}

.development-item__toggle input {
  margin-top: 2px;
  accent-color: #58c46c;
}

.development-item__delete {
  border: 1px solid rgba(224, 82, 82, 0.28);
  background: rgba(122, 30, 30, 0.22);
  color: #ffb3b3;
  border-radius: 9px;
  padding: 9px 12px;
  font: inherit;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.development-item__delete:hover {
  transform: translateY(-1px);
  background: rgba(154, 36, 36, 0.34);
  border-color: rgba(255, 108, 108, 0.46);
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

@media (max-width: 980px) {
  .games-grid,
  .import-grid,
  .insight-grid,
  .marketing-grid,
  .development-grid,
  .tickets-switcher,
  .development-switcher,
  .development-sections,
  .development-extras,
  .development-project-overview,
  .development-week,
  .development-timer__controls,
  .settings-grid,
  .game-stats {
    grid-template-columns: 1fr;
  }

  .hero__topline,
  .panel__header,
  .panel__actions,
  .game-card__top,
  .game-card__footer,
  .marketing-card__header,
  .development-month-overview__header,
  .revenue-entry,
  .page-footer {
    flex-direction: column;
    align-items: start;
  }

  .marketing-followers {
    justify-items: start;
    text-align: left;
  }

  .twitch-stream {
    grid-template-columns: 1fr;
  }

  .twitch-card__header,
  .twitch-card__actions {
    align-items: stretch;
    flex-direction: column;
  }

  .settings-panel {
    width: 100%;
    height: calc(100vh - 24px);
  }

  .development-project-form {
    grid-template-columns: 1fr;
  }

  .development-timer__actions {
    flex-direction: column;
  }

  .development-project-card__actions {
    justify-items: stretch;
  }

  .ticket-card__actions,
  .tickets-board__header,
  .outreach-toolbar,
  .outreach-card__summary {
    flex-direction: column;
    align-items: stretch;
  }

  .ticket-card__summary-side {
    width: 100%;
    justify-content: space-between;
    margin-left: 0;
  }

  .ticket-card__summary-action {
    min-width: 0;
    flex: 1;
  }

  .ticket-card__facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ticket-card__tavern-grid {
    grid-template-columns: 1fr;
  }

  .outreach-card__summary-status,
  .outreach-card__facts {
    grid-template-columns: 1fr;
    justify-items: start;
  }

  .outreach-card__summary-status {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .outreach-list__toolbar,
  .outreach-list__toolbar-left,
  .outreach-list__toolbar-right {
    align-items: stretch;
  }

  .outreach-list__toolbar-right {
    justify-content: flex-start;
  }

  .outreach-filter-bar__search,
  .outreach-filter-bar__filters {
    flex-direction: column;
    align-items: stretch;
  }

  .outreach-settings-dialog__grid {
    grid-template-columns: 1fr;
  }

  .outreach-toolbar__icon-button--fixed,
  .outreach-toolbar__icon-button[data-search-outreach-name],
  .outreach-filter-bar .outreach-toolbar__icon-button,
  .outreach-list__count-text {
    min-width: 100%;
  }

  .outreach-list__count-text {
    justify-content: flex-start;
    text-align: left;
  }
}

@media (max-width: 560px) {
  .ticket-card__summary {
    padding: 14px;
  }

  .ticket-card__body {
    padding: 0 14px 14px;
  }

  .ticket-card__summary-meta {
    gap: 6px;
  }

  .ticket-card__facts {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .page-shell {
    width: min(100% - 18px, 1240px);
    padding-top: 10px;
  }

  .hero,
  .panel,
  .game-card,
  .revenue-form-card {
    border-radius: 14px;
  }

  .hero,
  .panel {
    padding: 18px;
  }
}

body.session-pending .page-shell--app {
  opacity: 0;
  pointer-events: none;
}

.page-shell--app {
  width: 100%;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  min-height: 100vh;
}

.app-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 20px 14px 18px;
  border-right: 1px solid rgba(80, 110, 155, 0.1);
  background:
    linear-gradient(180deg, rgba(5, 8, 14, 0.99), rgba(3, 6, 12, 0.97)),
    radial-gradient(circle at top, rgba(60, 90, 135, 0.08), transparent 38%);
  box-shadow: 24px 0 60px rgba(0, 0, 0, 0.35);
  z-index: 3;
}

.app-sidebar__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 10px 18px;
  margin-bottom: 10px;
  border-bottom: 1px solid rgba(133, 157, 192, 0.16);
}

.app-sidebar__logo {
  width: 42px;
  height: 42px;
  border-radius: 9px;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.32);
}

.app-sidebar__brand-copy {
  display: grid;
  gap: 3px;
}

.app-sidebar__brand-copy strong {
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}

.app-sidebar__brand-copy span,
.app-sidebar__status,
.app-sidebar__version {
  color: var(--muted);
  font-size: 0.78rem;
}

.main-nav--sidebar {
  display: grid;
  gap: 8px;
  margin-top: 0;
}

.sidebar-section {
  display: grid;
  gap: 4px;
}

.sidebar-section + .sidebar-section {
  margin-top: 10px;
}

.sidebar-section__label {
  margin: 0;
  padding: 4px 10px 2px;
  color: rgba(146, 167, 204, 0.48);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.main-nav--sidebar .main-nav__item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  width: 100%;
  border-radius: 10px;
  padding: 11px 14px;
  background: rgba(8, 14, 24, 0.5);
  color: var(--muted);
  border-color: transparent;
  box-shadow: none;
  transition: all var(--transition-smooth);
}

.main-nav--sidebar .main-nav__item svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
  flex-shrink: 0;
}

.main-nav--sidebar .main-nav__item > span:not(.main-nav__badge) {
  flex: 1;
  text-align: left;
}

.main-nav__badge {
  margin-left: auto;
  width: 20px;
  min-width: 20px;
  height: 20px;
  padding: 0;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #ff5b67;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
 }

.main-nav__badge[hidden] {
  display: none !important;
}

.main-nav--sidebar .main-nav__item.is-active {
  background: linear-gradient(180deg, rgba(28, 52, 88, 0.88), rgba(16, 32, 56, 0.96));
  border-color: rgba(140, 190, 255, 0.2);
  color: #cce4ff;
  box-shadow: inset 3px 0 0 0 #72b8f0, 0 4px 16px rgba(0, 0, 0, 0.25);
  padding-left: 11px;
}

.main-nav--sidebar .main-nav__item--install {
  margin-top: 10px;
}

/* ── Sidebar Collapse ─────────────────────────────── */
.app-sidebar {
  transition: width 220ms ease;
}

.sidebar-collapse-btn {
  position: absolute;
  right: -14px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(80, 110, 155, 0.18);
  background: #060a14;
  color: var(--muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  flex-shrink: 0;
  transition: all var(--transition-smooth);
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.sidebar-collapse-btn:hover {
  background: rgba(30, 50, 78, 0.8);
  color: #e4ecf8;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
.sidebar-collapse-btn svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
  transition: transform 220ms ease;
}
.app-sidebar--collapsed .sidebar-collapse-btn svg {
  transform: rotate(180deg);
}

/* Im collapsed State: nur Icons zeigen */
.app-sidebar--collapsed .app-sidebar__brand-copy,
.app-sidebar--collapsed .sidebar-section__label,
.app-sidebar--collapsed .main-nav__item > span:not(.main-nav__badge),
.app-sidebar--collapsed .main-nav__badge,
.app-sidebar--collapsed .app-sidebar__status,
.app-sidebar--collapsed .app-sidebar__version,
.app-sidebar--collapsed .app-sidebar__footer p {
  display: none !important;
}
.app-sidebar--collapsed .main-nav--sidebar .main-nav__item {
  justify-content: center;
  padding: 11px;
}
.app-sidebar--collapsed .main-nav--sidebar .main-nav__item.is-active {
  padding-left: 11px;
}
.app-sidebar--collapsed .app-sidebar__brand {
  justify-content: center;
  padding-bottom: 14px;
}
.app-sidebar--collapsed .app-sidebar__logo {
  margin: 0 auto;
}
.app-sidebar--collapsed .app-sidebar__footer {
  padding: 14px 10px 10px;
}

/* ── System-Status Dot im Sidebar-Footer ─────────── */
.sidebar-status-indicator {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}
.sidebar-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: rgba(133, 157, 192, 0.4);
  transition: background 400ms ease;
}
.sidebar-status-dot--green { background: #2ecc71; box-shadow: 0 0 6px rgba(46,204,113,0.5); }
.sidebar-status-dot--amber { background: #f39c12; box-shadow: 0 0 6px rgba(243,156,18,0.5); }
.sidebar-status-dot--red   { background: #e74c3c; box-shadow: 0 0 6px rgba(231,76,60,0.5); }
.sidebar-status-label {
  color: var(--muted);
  font-size: 0.75rem;
}

/* ── Ticket Filterbar ─────────────────────────────── */
.tickets-filter {
  padding: 0 0 14px;
  display: flex;
  gap: 8px;
  align-items: center;
}
.tickets-filter__input {
  flex: 1;
  padding: 8px 12px;
  border: 1px solid rgba(133, 157, 192, 0.2);
  border-radius: 8px;
  background: rgba(15, 23, 37, 0.55);
  color: inherit;
  font: inherit;
  font-size: 0.875rem;
  transition: border-color 160ms ease;
}
.tickets-filter__input:focus {
  outline: none;
  border-color: rgba(122, 174, 255, 0.42);
}
.tickets-filter__input::placeholder {
  color: rgba(133, 157, 192, 0.45);
}
.tickets-filter__count {
  font-size: 0.8rem;
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Ticket Schließen-Button: etwas größer ──────── */
.ticket-card__close,
.ticket-card__restore {
  min-width: 110px;
  text-align: center;
}

/* ── Outreach: gesendete Karte ───────────────────── */
.outreach-card--sent {
  opacity: 0.55;
  border-color: rgba(46, 204, 113, 0.22) !important;
  transition: opacity 300ms ease;
}
.outreach-card--sent:hover {
  opacity: 0.75;
}
.outreach-sent-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(46, 204, 113, 0.12);
  border: 1px solid rgba(46, 204, 113, 0.28);
  color: #5ddc8c;
  border-radius: 999px;
  padding: 3px 10px;
  font-size: 0.75rem;
  font-weight: 600;
}

/* ── Outreach Key-Badge ──────────────────────────── */
.outreach-key-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.18);
  background: rgba(255, 255, 255, 0.04);
  margin-top: 10px;
  width: fit-content;
}

.outreach-key-badge__count {
  font-size: 1.7rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.02em;
}

.outreach-key-badge__label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.outreach-key-badge--green .outreach-key-badge__count { color: #62e6a8; }
.outreach-key-badge--green {
  border-color: rgba(98, 230, 168, 0.2);
  background: rgba(98, 230, 168, 0.06);
}

.outreach-key-badge--amber .outreach-key-badge__count { color: #f0b34d; }
.outreach-key-badge--amber {
  border-color: rgba(240, 179, 77, 0.25);
  background: rgba(240, 179, 77, 0.06);
}

.outreach-key-badge--red .outreach-key-badge__count { color: #ff8d8d; }
.outreach-key-badge--red {
  border-color: rgba(255, 141, 141, 0.22);
  background: rgba(255, 141, 141, 0.05);
}

/* ── Outreach Compact-Modus ──────────────────────── */
.outreach-compact-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid rgba(133, 157, 192, 0.2);
  background: rgba(15, 23, 37, 0.55);
  color: var(--muted);
  font: inherit;
  font-size: 0.8rem;
  cursor: pointer;
  margin-left: auto;
  transition: background 160ms ease, color 160ms ease;
}
.outreach-compact-toggle:hover,
.outreach-compact-toggle.is-active {
  background: rgba(54, 82, 121, 0.5);
  color: #f3f7ff;
}
.outreach-compact-toggle svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

/* Kompakte Outreach-Liste */
.outreach-list--compact .outreach-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
}
.outreach-list--compact .outreach-card__avatar-wrap,
.outreach-list--compact .outreach-card__body,
.outreach-list--compact .outreach-card__footer,
.outreach-list--compact .outreach-card__analysis-wrap,
.outreach-list--compact .outreach-card__description {
  display: none !important;
}
.outreach-list--compact .outreach-card__header {
  margin-bottom: 0;
}
.outreach-list--compact .outreach-card__meta-stats {
  display: none !important;
}
.outreach-list--compact .outreach-card__quick-actions {
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
}

/* ── Twitch "Zuletzt live" Chip ────────────────────── */
.twitch-last-live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(15, 23, 37, 0.55);
  border: 1px solid rgba(133, 157, 192, 0.16);
  color: var(--muted);
  font-size: 0.82rem;
  margin-top: 8px;
}
.twitch-last-live svg {
  width: 12px;
  height: 12px;
  fill: currentColor;
  opacity: 0.6;
}

.app-sidebar__footer {
  margin-top: auto;
  padding: 18px 10px 10px;
  border-top: 1px solid rgba(133, 157, 192, 0.16);
}

.app-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 26px;
  border-bottom: 1px solid rgba(80, 110, 155, 0.08);
  background:
    linear-gradient(180deg, rgba(4, 7, 14, 0.96), rgba(4, 7, 14, 0.88)),
    radial-gradient(circle at top, rgba(70, 100, 150, 0.06), transparent 40%);
  backdrop-filter: blur(20px);
}

.topbar__headline {
  display: grid;
  gap: 4px;
}

.topbar__headline h1 {
  margin: 0;
  font-size: 1.55rem;
  letter-spacing: -0.03em;
}

.topbar__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.topbar__button,
.topbar__link,
.topbar__logout {
  min-height: 46px;
}

.topbar__logout {
  white-space: nowrap;
}

.topbar__version {
  color: var(--accent-bright);
  font-size: 0.88rem;
  white-space: nowrap;
}

.dashboard {
  width: min(1480px, 100%);
  margin: 0 auto;
  padding: 26px;
}

.tab-panel {
  gap: 22px;
}

.overview-hero {
  position: relative;
  overflow: hidden;
  padding: 0;
  min-height: 280px;
}

.overview-hero__backdrop {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(6, 10, 18, 0.96) 0%, rgba(8, 14, 24, 0.94) 48%, rgba(4, 7, 14, 0.98) 100%),
    radial-gradient(circle at 15% 20%, rgba(80, 120, 180, 0.1), transparent 24%),
    radial-gradient(circle at 85% 30%, rgba(50, 75, 110, 0.12), transparent 28%);
}

.overview-hero__content {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  align-items: center;
  gap: 26px;
  padding: 34px;
}

.overview-hero__copy {
  display: grid;
  gap: 16px;
}

.overview-hero__copy h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.1rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.overview-hero__text {
  max-width: 62ch;
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.overview-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.overview-hero__chips span {
  border: 1px solid rgba(120, 155, 200, 0.14);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(8, 14, 24, 0.65);
  color: var(--accent-bright);
  font-size: 0.82rem;
  transition: all var(--transition-smooth);
}

.overview-hero__chips span:hover {
  border-color: rgba(120, 155, 200, 0.28);
  background: rgba(16, 26, 42, 0.75);
  transform: translateY(-1px);
}

.overview-hero__brand {
  display: flex;
  justify-content: center;
}

.overview-hero__brand .hero__logo {
  width: min(100%, 480px);
}

@media (max-width: 1180px) {
  .page-shell--app {
    grid-template-columns: 220px minmax(0, 1fr);
  }

  .dashboard {
    padding: 20px;
  }

  .overview-hero__content {
    grid-template-columns: 1fr;
  }

  .overview-hero__brand {
    justify-content: flex-start;
  }
}

@media (max-width: 900px) {
  .page-shell--app {
    grid-template-columns: minmax(0, 1fr); /* verhindert, dass Sidebar-Inhalt das Grid aufbläht */
  }

  .app-sidebar {
    position: sticky;
    top: 0;
    height: auto;
    width: 100%;
    max-width: 100%;
    overflow-x: hidden; /* nav-Inhalt scrollt intern, Sidebar bleibt viewport-breit */
    padding: 12px 12px 10px;
    border-right: 0;
    border-bottom: 1px solid rgba(133, 157, 192, 0.14);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(16px);
  }

  .app-sidebar__brand {
    padding: 0 2px 12px;
    margin-bottom: 8px;
  }

  .app-sidebar__footer {
    display: none;
  }

  .main-nav--sidebar {
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 4px;
    scroll-snap-type: x proximity;
    overscroll-behavior-x: contain;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

  .main-nav--sidebar::-webkit-scrollbar {
    display: none;
  }

  .sidebar-section {
    flex: 0 0 180px;
    min-width: 180px;
    scroll-snap-align: start;
  }

  .topbar {
    padding: 16px 18px;
  }

  .dashboard {
    padding: 18px;
  }
}

@media (max-width: 640px) {
  .app-login {
    padding: 14px;
  }

  .app-login__panel {
    padding: 20px 18px;
    border-radius: 12px;
  }

  .page-shell--app {
    min-height: 100dvh;
  }

  .app-sidebar {
    padding: 10px 10px 8px;
  }

  .app-sidebar__brand {
    gap: 10px;
    padding-bottom: 10px;
  }

  .app-sidebar__logo {
    width: 36px;
    height: 36px;
    border-radius: 10px;
  }

  .app-sidebar__brand-copy strong {
    font-size: 0.88rem;
  }

  .sidebar-section {
    flex: 0 0 156px;
    min-width: 156px;
    gap: 5px;
  }

  .sidebar-section__label {
    padding: 0 4px;
    font-size: 0.62rem;
  }

  .main-nav--sidebar .main-nav__item {
    min-height: 44px;
    padding: 9px 11px;
    gap: 10px;
  }

  .main-nav--sidebar .main-nav__item > span:not(.main-nav__badge) {
    font-size: 0.9rem;
  }

  .main-nav__badge {
    width: 18px;
    min-width: 18px;
    height: 18px;
    font-size: 0.62rem;
  }

  .topbar,
  .topbar__actions {
    align-items: stretch;
  }

  .topbar {
    flex-direction: column;
    gap: 12px;
    padding: 12px 12px 14px;
  }

  .topbar__actions {
    width: 100%;
    justify-content: stretch;
  }

  .topbar__headline h1 {
    font-size: 1.24rem;
  }

  .topbar__link,
  .topbar__button,
  .topbar__logout {
    flex: 1 1 100%;
    justify-content: center;
  }

  .dashboard {
    margin-top: 16px;
    padding: 12px;
    gap: 16px;
  }

  .panel {
    padding: 16px;
  }

  .panel__header {
    margin-bottom: 14px;
    gap: 10px;
  }

  .panel__meta {
    font-size: 0.92rem;
    line-height: 1.45;
  }

  .overview-hero__content {
    padding: 20px 16px;
  }

  .overview-hero__copy h2 {
    font-size: 1.55rem;
  }

  .overview-hero__chips {
    gap: 8px;
  }

  .chart-embed-frame {
    min-height: 280px;
  }

  .month-dialog {
    width: min(100% - 12px, 520px);
    padding: 14px;
    border-radius: 12px;
  }

  .month-dialog__header {
    align-items: flex-start;
    gap: 12px;
  }

  .outreach-preview-dialog,
  .outreach-settings-dialog,
  .outreach-template-dialog {
    width: min(100% - 12px, 760px);
  }

  .outreach-preview-dialog__meta {
    grid-template-columns: 1fr;
    margin-bottom: 12px;
  }

  .outreach-preview-dialog__body {
    min-height: 220px;
    padding: 14px;
  }

  .outreach-preview-dialog__actions {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .outreach-preview-dialog__actions .ticket-card__restore,
  .outreach-preview-dialog__actions .ticket-card__close {
    width: 100%;
  }

  .revenue-summary-card strong {
    font-size: 1.55rem;
  }
}

.panel,
.game-card,
.revenue-form-card,
.revenue-summary-card,
.settings-panel,
.settings-card,
.ticket-card,
.outreach-card,
.outreach-template-card,
.overview-link-card,
.overview-metric-card {
  border-radius: 11px;
}

.hero__link,
.main-nav__item,
.logout-button,
.settings-form button,
.ticket-card__restore,
.ticket-card__close,
.outreach-toolbar__icon-button,
.month-picker-trigger {
  border-radius: 9px;
}

.overview-board {
  display: grid;
  gap: 22px;
}

.overview-panel {
  overflow: hidden;
}

.overview-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.overview-metric-card {
  padding: 18px;
  border: 1px solid rgba(80, 110, 155, 0.1);
  background: linear-gradient(180deg, rgba(8, 13, 22, 0.9), rgba(5, 9, 16, 0.96));
  transition: transform var(--transition-smooth), border-color var(--transition-smooth), box-shadow var(--transition-smooth);
}

.overview-metric-card:hover {
  transform: translateY(-2px);
  border-color: rgba(80, 110, 155, 0.2);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.overview-metric-card span,
.system-status-card span {
  display: block;
  color: var(--muted);
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.overview-metric-card strong {
  display: block;
  margin-top: 10px;
  font-size: 1.8rem;
  letter-spacing: -0.04em;
}

.overview-metric-card small {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  line-height: 1.45;
}

.overview-sections {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 22px;
}

.overview-category__cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.overview-ticket-preview {
  display: grid;
  gap: 12px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(151, 171, 205, 0.12);
}

.overview-ticket-preview__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.overview-ticket-preview__header .eyebrow {
  margin: 0;
}

.overview-ticket-preview__list {
  display: grid;
  gap: 10px;
}

.overview-ticket-preview__item {
  display: grid;
  gap: 4px;
  width: 100%;
  text-align: left;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(151, 171, 205, 0.1);
  background: rgba(255, 255, 255, 0.025);
  color: var(--text);
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.overview-ticket-preview__item:hover,
.overview-ticket-preview__item:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(135, 171, 226, 0.28);
  background: rgba(255, 255, 255, 0.04);
}

.overview-ticket-preview__item strong {
  font-size: 0.95rem;
}

.overview-ticket-preview__item span,
.overview-ticket-preview__empty {
  color: var(--muted);
  font-size: 0.86rem;
}

.overview-category__cards--single {
  grid-template-columns: minmax(0, 1fr);
}

.overview-link-card {
  display: grid;
  gap: 6px;
  width: 100%;
  padding: 16px;
  text-align: left;
  cursor: pointer;
  border: 1px solid rgba(80, 110, 155, 0.1);
  background: linear-gradient(180deg, rgba(8, 13, 22, 0.9), rgba(5, 9, 16, 0.96));
  color: var(--text);
  transition: transform var(--transition-smooth), border-color var(--transition-smooth), background var(--transition-smooth), box-shadow var(--transition-smooth);
}

.overview-link-card strong {
  font-size: 1rem;
}

.overview-link-card span {
  color: var(--muted);
  line-height: 1.45;
}

.overview-link-card:hover,
.overview-link-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(120, 155, 200, 0.22);
  background: linear-gradient(180deg, rgba(14, 22, 36, 0.95), rgba(8, 13, 22, 0.98));
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35), 0 0 50px var(--glow-subtle);
}

.system-status-list {
  display: grid;
  gap: 10px;
}

.system-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(133, 157, 192, 0.09);
}

.system-status-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.system-status-row__label {
  color: #dce6f7;
  font-size: 0.94rem;
}

.system-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 132px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  white-space: nowrap;
  border: 1px solid transparent;
}

.system-status-badge--green {
  color: #61e38b;
  background: rgba(36, 174, 96, 0.14);
  border-color: rgba(36, 174, 96, 0.28);
}

.system-status-badge--amber {
  color: #f1b44b;
  background: rgba(241, 180, 75, 0.12);
  border-color: rgba(241, 180, 75, 0.24);
}

.system-status-badge--red {
  color: #ff6b75;
  background: rgba(224, 76, 92, 0.12);
  border-color: rgba(224, 76, 92, 0.24);
}

.system-status-badge--neutral {
  color: #9fb3d5;
  background: rgba(84, 104, 135, 0.16);
  border-color: rgba(84, 104, 135, 0.28);
}

.settings-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.settings-card__header h3 {
  margin: 4px 0 0;
}

.settings-card--outreach {
  grid-column: 1 / -1;
}

.settings-card--legacy-push {
  display: none;
}

#gamesLegacyTab {
  display: none !important;
}

.settings-panel--inline {
  width: 100%;
  height: auto;
  overflow: visible;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.settings-panel--inline .settings-panel__header {
  margin-bottom: 18px;
}

.settings-panel--inline #settingsCloseButton {
  display: none;
}

.settings-panel--inline .settings-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.settings-notification-list {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.settings-notification-row {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(133, 157, 192, 0.14);
  border-radius: 9px;
  background: rgba(11, 17, 27, 0.52);
}

.settings-notification-row input {
  margin: 0;
}

.settings-notification-row__label {
  color: var(--text);
  font-size: 0.95rem;
}

.settings-notification-row__meta {
  color: var(--muted);
  font-size: 0.84rem;
}

.settings-notification-row__action {
  min-width: 96px;
  justify-content: center;
}

.settings-notification-row--master {
  border-style: dashed;
}

.outreach-settings-dialog__grid--embedded {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.outreach-settings-dialog__grid--embedded .outreach-toolbar__field textarea,
.outreach-settings-dialog__grid--embedded .outreach-toolbar__field input,
.outreach-settings-dialog__grid--embedded .outreach-toolbar__field select {
  min-height: 48px;
}

@media (max-width: 1100px) {
  .overview-metrics,
  .system-status-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .overview-sections {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .overview-metrics,
  .overview-category__cards,
  .system-status-grid,
  .system-status-grid--settings,
  .outreach-settings-dialog__grid--embedded {
    grid-template-columns: 1fr;
  }

  .settings-panel--inline .settings-grid {
    grid-template-columns: 1fr;
  }

  .settings-card__header {
    flex-direction: column;
    align-items: stretch;
  }
}

/* ══════════════════════════════════════════════════
   PIPELINE / KANBAN
   ══════════════════════════════════════════════════ */

.pipeline-board {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 8px;
  align-items: flex-start;
}

.pipeline-column {
  flex: 0 0 200px;
  min-width: 0;
  background: var(--surface-2, #0a0e18);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: 12px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--transition-smooth), background var(--transition-smooth);
}

.pipeline-column__cards {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 32px;
}

.pipeline-column__empty {
  font-size: 0.75rem;
  color: var(--text-muted, rgba(255,255,255,.3));
  text-align: center;
  padding: 8px 0;
  margin: 0;
}

.pipeline-column__label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-muted, rgba(255,255,255,.45));
  margin: 0 0 2px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pipeline-column__count {
  background: var(--surface-3, rgba(255,255,255,.06));
  border-radius: 20px;
  padding: 1px 7px;
  font-size: 0.63rem;
}

.pipeline-column.drag-over {
  border-color: var(--accent, #7c6af5);
  background: rgba(124,106,245,.08);
}

.pipeline-chip {
  background: var(--surface-3, rgba(255,255,255,.06));
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 8px;
  padding: 8px 10px;
  cursor: grab;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  user-select: none;
  transition: opacity 0.15s;
}

.pipeline-chip:active {
  cursor: grabbing;
}

.pipeline-chip.dragging {
  opacity: 0.4;
}

.pipeline-chip__avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--surface-3, rgba(255,255,255,.1));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--text-muted, rgba(255,255,255,.5));
}

.pipeline-chip__name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 500;
}

.pipeline-chip__platform {
  font-size: 0.63rem;
  color: var(--text-muted, rgba(255,255,255,.4));
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Key Log Table ──────────────────────────── */

.pipeline-key-log {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.pipeline-key-log th {
  text-align: left;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--text-muted, rgba(255,255,255,.45));
  border-bottom: 1px solid var(--border, rgba(255,255,255,.08));
  padding: 6px 10px;
}

.pipeline-key-log td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border, rgba(255,255,255,.05));
  vertical-align: middle;
}

.pipeline-key-log tr:last-child td {
  border-bottom: none;
}

.pipeline-key-code {
  font-family: monospace;
  font-size: 0.76rem;
  letter-spacing: .02em;
  color: var(--text-muted, rgba(255,255,255,.55));
}

.pipeline-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 20px;
  padding: 2px 8px;
  font-size: 0.68rem;
  font-weight: 700;
  background: rgba(52,211,153,.15);
  color: #34d399;
}

.pipeline-streamed-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 20px;
  padding: 2px 8px;
  font-size: 0.68rem;
  font-weight: 600;
  background: rgba(255,255,255,.06);
  color: var(--text-muted, rgba(255,255,255,.4));
}

.pipeline-streamed-badge--yes {
  background: rgba(124,106,245,.15);
  color: #a78bfa;
}

.key-log-empty {
  padding: 24px;
  text-align: center;
  color: var(--text-muted, rgba(255,255,255,.35));
  font-size: 0.82rem;
}

/* ── Live Alert Banner ──────────────────────── */

.live-alert-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(52,211,153,.1);
  border: 1px solid rgba(52,211,153,.3);
  border-radius: 12px;
  padding: 12px 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.live-alert-banner__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #34d399;
  flex-shrink: 0;
  animation: pulse-dot 1.4s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

.live-alert-banner__text {
  flex: 1;
  min-width: 0;
  font-size: 0.82rem;
  color: var(--text-secondary, rgba(255,255,255,.8));
  line-height: 1.4;
}

.live-alert-banner__link {
  font-size: 0.8rem;
  font-weight: 600;
  color: #34d399;
  text-decoration: none;
  flex-shrink: 0;
}

.live-alert-banner__link:hover {
  text-decoration: underline;
}

.live-alert-banner__dismiss {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted, rgba(255,255,255,.4));
  padding: 0 2px;
  line-height: 1;
  font-size: 1rem;
}

.live-alert-banner__dismiss:hover {
  color: #fff;
}

/* ── Steam Reviews Grid ─────────────────────── */

.steam-reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}

.steam-review-card {
  background: var(--surface-2, #080c14);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: 12px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color var(--transition-smooth);
}

.steam-review-card:hover {
  border-color: rgba(255,255,255,.12);
}

.steam-review-card--positive {
  border-left: 3px solid #34d399;
}

.steam-review-card--negative {
  border-left: 3px solid #f87171;
}

.steam-review-card__header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.steam-review__thumb {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.steam-review__thumb--up {
  fill: #34d399;
}

.steam-review__thumb--down {
  fill: #f87171;
}

.steam-review-card__date {
  font-size: 0.7rem;
  color: var(--text-muted, rgba(255,255,255,.4));
  margin-left: auto;
}

.steam-review-card__playtime {
  font-size: 0.7rem;
  color: var(--text-muted, rgba(255,255,255,.4));
}

.steam-review-card__text {
  font-size: 0.8rem;
  color: var(--text-secondary, rgba(255,255,255,.7));
  line-height: 1.5;
  margin: 0;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 6;
}

/* ══════════════════════════════════════════════════
   MOBILE OPTIMIERUNGEN  (≤ 480 px)
   Berührt keine Desktop-Darstellung
   ══════════════════════════════════════════════════ */
@media (max-width: 480px) {

  /* ── Sidebar: schmaler, kompakter Top-Strip ─── */
  .sidebar-collapse-btn {
    display: none; /* Collapse-Knopf auf Mobile nicht sinnvoll */
  }

  .app-sidebar {
    padding: 7px 10px 5px;
  }

  .app-sidebar__brand {
    gap: 9px;
    padding-bottom: 7px;
    margin-bottom: 5px;
  }

  .app-sidebar__logo {
    width: 30px;
    height: 30px;
    border-radius: 7px;
  }

  .app-sidebar__brand-copy strong {
    font-size: 0.82rem;
  }

  .app-sidebar__brand-copy span {
    display: none; /* "Studio Dashboard" Untertitel weglassen */
  }

  /* Nav: alle Icons in bis zu 2 Reihen, kein horizontales Scrollen */
  .main-nav--sidebar {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
    padding-bottom: 4px;
    overflow-x: visible;
    align-items: flex-start;
  }

  /* Sektionen werden unsichtbare Wrapper –
     ihre Items nehmen direkt am Flex-Layout teil */
  .sidebar-section {
    display: contents;  /* phantom – kein eigenes Box-Model */
  }

  /* margin-top aus Basis-CSS neutralisieren */
  .sidebar-section + .sidebar-section {
    margin-top: 0;
  }

  /* Visueller Trenner: erstes Item jeder nicht-ersten Sektion */
  .sidebar-section:not(:first-child) > .main-nav__item:first-child {
    margin-left: 4px;
    border-left: 1px solid rgba(133, 157, 192, 0.18);
    padding-left: 10px;
  }

  /* App-Installieren-Button auf Mobile verstecken */
  .main-nav__item--install {
    display: none !important;
  }

  /* Abschnittslabels weglassen */
  .sidebar-section__label {
    display: none;
  }

  /* Nav-Items: kompakte Icon-Quadrate */
  .main-nav--sidebar .main-nav__item {
    width: auto;        /* überschreibt width:100% aus Basis-CSS */
    min-height: 54px;
    min-width: 54px;
    padding: 10px;
    gap: 0;
    border-radius: 12px;
    justify-content: center;
    flex: 0 0 auto;
  }

  /* Text ausblenden – nur Icon */
  .main-nav--sidebar .main-nav__item > span:not(.main-nav__badge) {
    display: none;
  }

  .main-nav--sidebar .main-nav__item svg {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    stroke-width: 1.9;
  }

  /* Badge weiterhin sichtbar */
  .main-nav--sidebar .main-nav__item .main-nav__badge {
    display: flex;
    min-width: 20px;
    height: 20px;
    font-size: 0.72rem;
  }

  /* ── Dashboard / Inhaltsbereich ─────────────── */
  .dashboard {
    padding: 10px;
    gap: 12px;
    margin-top: 10px;
  }

  /* ── Topbar: kompakte Einzelzeile ─────────────── */
  /* 640px setzt flex-direction:column – hier zurücksetzen */
  .topbar,
  .topbar__actions {
    align-items: center;  /* 640px setzt stretch */
  }

  .topbar {
    flex-direction: row;  /* 640px setzt column */
    justify-content: space-between;
    padding: 8px 12px;
    gap: 8px;
    min-height: 0;
  }

  /* Eyebrow "Studio Dashboard" weglassen – spart Höhe */
  .topbar__headline .eyebrow {
    display: none;
  }

  .topbar__headline {
    gap: 0;
    flex: 1 1 auto;
    min-width: 0;
  }

  .topbar__headline h1 {
    font-size: 1rem;
    letter-spacing: -0.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Actions: kompakte Zeile, kein Wrap */
  .topbar__actions {
    flex-direction: row;
    flex-wrap: nowrap;
    width: auto;          /* 640px setzt width:100% */
    gap: 6px;
    justify-content: flex-end;
    flex-shrink: 0;
  }

  /* Website-Link auf Mobile verstecken – spart Platz */
  .topbar__link {
    display: none;
  }

  /* Settings-Icon: kompakter quadratischer Button */
  .topbar__button {
    flex: 0 0 auto;       /* 640px setzt flex: 1 1 100% */
    min-height: 36px;
    min-width: 36px;
    padding: 6px;
    font-size: 0;         /* Text ausblenden, nur Icon */
  }

  .topbar__button svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
  }

  /* Abmelden: klein aber tippbar */
  .topbar__logout {
    flex: 0 0 auto;       /* 640px setzt flex: 1 1 100% */
    min-height: 36px;
    padding: 6px 10px;
    font-size: 0.82rem;
    white-space: nowrap;
  }

  /* Versions-Text weglassen */
  .topbar__version {
    display: none;
  }

  /* ── Panels ────────────────────────────────── */
  .panel {
    padding: 14px;
  }

  .panel__header {
    gap: 8px;
    margin-bottom: 12px;
  }

  /* ── Overview ──────────────────────────────── */

  /* Hero-Banner ausblenden: spart ~220px auf Mobile */
  .overview-hero {
    display: none;
  }

  .overview-board {
    gap: 10px;
  }

  /* "Studio Überblick" Panel: nur Metriken, kein dekorativer Header-Text */
  .overview-panel {
    padding: 12px;
  }

  .overview-panel .panel__header {
    margin-bottom: 8px;
    gap: 2px;
  }

  .overview-panel .panel__header h2 {
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0;
  }

  /* Lange Beschreibung ausblenden */
  .overview-panel .panel__meta {
    display: none;
  }

  /* Metriken: 2-spaltig statt 4-spaltig, kompakter */
  .overview-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .overview-metric-card {
    padding: 9px 11px;
  }

  .overview-metric-card span {
    font-size: 0.65rem;
    letter-spacing: 0.06em;
  }

  .overview-metric-card strong {
    font-size: 1.25rem;
    margin-top: 3px;
  }

  /* Beschreibungstext in Metriken ausblenden */
  .overview-metric-card small {
    display: none;
  }

  /* Sections: untereinander statt nebeneinander */
  .overview-sections {
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
  }

  /* Kategorie-Panels: sehr kompakt */
  .overview-category {
    padding: 10px 12px 12px;
  }

  .overview-category .panel__header {
    margin-bottom: 8px;
    gap: 0;
  }

  /* Eyebrow bleibt, h3 ausblenden – Kategoriename reicht */
  .overview-category .panel__header h3 {
    display: none;
  }

  .overview-category .panel__header .eyebrow {
    font-size: 0.6rem;
    letter-spacing: 0.1em;
  }

  /* Kategorie-Karten: 2-spaltig, sehr kompakt */
  .overview-category__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  .overview-link-card {
    padding: 9px 11px;
    gap: 0;
  }

  .overview-link-card strong {
    font-size: 0.88rem;
    font-weight: 700;
  }

  /* Beschreibungstext in Link-Karten ausblenden */
  .overview-link-card span {
    display: none;
  }

  /* ── Ticket-Karten ─────────────────────────── */
  .ticket-card {
    padding: 14px;
    border-radius: 11px;
  }

  .ticket-card__restore,
  .ticket-card__close {
    min-height: 44px;
    padding: 0 14px;
    font-size: 0.9rem;
  }


  /* ── Outreach: Toolbar & Statusbereich ─────── */
  .outreach-shell {
    gap: 12px;
  }

  .outreach-toolbar {
    padding: 12px;
    gap: 10px;
  }

  .outreach-toolbar h3 {
    font-size: 1rem;
  }

  .outreach-toolbar__actions {
    gap: 8px;
  }

  .outreach-toolbar__field {
    min-width: 0;
  }

  .outreach-toolbar__field select,
  .outreach-toolbar__field input {
    min-height: 40px;
    padding: 9px 12px;
    font-size: 0.9rem;
  }

  .outreach-status-chips {
    gap: 4px;
  }

  .outreach-status-chip {
    font-size: 0.72rem;
    padding: 2px 7px 2px 5px;
  }

  .outreach-key-badge {
    padding: 7px 14px;
    gap: 6px;
    margin-top: 8px;
    border-radius: 10px;
  }

  .outreach-key-badge__count {
    font-size: 1.4rem;
  }

  /* ── Outreach: Ergebnisliste & Toolbar ─────── */
  .outreach-list__toolbar {
    flex-direction: column;
    gap: 8px;
  }

  .outreach-list__toolbar-left,
  .outreach-list__toolbar-right {
    width: 100%;
  }

  .outreach-list__toolbar-right {
    justify-content: flex-start;
  }

  .outreach-list__toolbar-stack {
    width: 100%;
    align-items: stretch;
  }

  .outreach-list__toolbar-row {
    flex-wrap: wrap;
    gap: 8px;
  }

  .outreach-toolbar__icon-button--fixed,
  .outreach-toolbar__icon-button[data-search-outreach-name],
  .outreach-toolbar__icon-button[data-refresh-outreach],
  .outreach-toolbar__icon-button[data-search-outreach-game] {
    flex: 1 1 100%;
    justify-content: center;
    min-height: 44px;
  }

  .outreach-compact-toggle {
    margin-left: 0;
    flex: 1 1 auto;
    justify-content: center;
  }

  .outreach-strictness-wrap {
    width: 100%;
  }

  .outreach-strictness {
    width: 100%;
    justify-content: space-between;
  }

  .outreach-strictness__button {
    flex: 1;
    justify-content: center;
  }

  /* ── Outreach: Creator-Karten ──────────────── */
  .outreach-card__summary {
    padding: 7px 10px;
    gap: 8px;
  }

  .outreach-card__avatar {
    width: 26px;
    height: 26px;
    flex: 0 0 26px;
  }

  .outreach-card__facts {
    grid-template-columns: 1fr 1fr;
  }

  .outreach-card__facts--4col {
    grid-template-columns: 1fr 1fr;
  }

  .outreach-card__body {
    padding: 8px 10px 10px;
  }

  .outreach-card__game-link-row {
    flex-wrap: wrap;
  }

  .outreach-card__analysis-actions {
    flex-direction: column;
  }

  .outreach-card__analysis-actions .ticket-card__restore {
    width: 100%;
    justify-content: center;
  }

  /* ── Filter-Leiste ─────────────────────────── */
  .outreach-filter-bar {
    gap: 10px;
  }

  /* Search-Zeile (Eingabefeld + Buttons): vertikal stapeln
     WICHTIG: flex-wrap:nowrap – sonst entstehen bei column+wrap mehrere Tracks */
  .outreach-filter-bar__search {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 8px;
  }

  /* Letztes outreach-filter-bar__search = Filterdropdowns-Reihe
     → als Zeile mit 2 Spalten anzeigen */
  .outreach-filter-bar__search:last-child {
    flex-direction: row;
    flex-wrap: wrap;
  }

  /* Game-Suchgruppe: volle Breite auf Mobile */
  .outreach-game-search-group {
    flex: 1 1 auto;
    min-width: 0;
    max-width: 100%;
  }

  /* Filter-Sektion im ersten Filter-Bar */
  .outreach-filter-bar__filters {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Filter-Toggle kompakt */
  .outreach-filter-bar__toggle {
    flex: 1 1 calc(50% - 4px);
  }

  .outreach-toolbar__field--compact {
    flex: 1 1 calc(50% - 4px);
    min-width: 0;
  }

  /* Outreach-Liste: kein seitlicher Überlauf */
  .outreach-list {
    overflow-x: hidden;
  }

  /* ── Dialoge: volle Breite & Höhe ──────────── */
  .outreach-preview-dialog,
  .outreach-settings-dialog,
  .outreach-template-dialog {
    width: min(100% - 8px, 640px);
    max-height: 90dvh;
    border-radius: 14px;
  }

  .outreach-settings-dialog__grid {
    grid-template-columns: 1fr;
  }

  .month-dialog {
    width: min(100% - 8px, 520px);
    border-radius: 12px;
  }

  /* ── Marketing-Grid ────────────────────────── */
  .marketing-grid {
    gap: 12px;
  }

  /* ── Games-Grid ────────────────────────────── */
  .games-grid {
    gap: 12px;
  }

  .game-card {
    border-radius: 12px;
  }

  /* ── Allgemeine Touch-Targets ──────────────── */
  button,
  [role="button"] {
    -webkit-tap-highlight-color: transparent;
  }

  /* Alle primären Aktionsknöpfe mind. 44px hoch */
  .hero__link,
  .logout-button,
  .settings-form button,
  .month-picker-trigger,
  .outreach-strictness__button,
  .outreach-toolbar__icon-button {
    min-height: 44px;
  }

  /* ── Scrollbare Bereiche: besseres Overscroll ── */
  .main-nav--sidebar,
  .dashboard,
  .outreach-list {
    overscroll-behavior: contain;
  }

  /* ── Panel: kompaktere Titel auf Mobile ─────── */
  .panel h2 {
    font-size: 1.35rem;
    letter-spacing: -0.02em;
  }

  .panel__meta {
    font-size: 0.78rem;
    line-height: 1.4;
  }

  /* ── Pipeline Kanban: horizontales Scroll-Snap ── */
  .pipeline-board {
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
    gap: 10px;
    /* Verhindert, dass der Board den Panel aufbläst */
    max-width: calc(100vw - 48px);
    width: calc(100vw - 48px);
  }

  .pipeline-column {
    flex: 0 0 82vw;
    scroll-snap-align: start;
    max-width: 300px;
  }

  /* Key Log Table: horizontal scrollbar */
  #keyLogTable {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .pipeline-key-log {
    min-width: 540px;
  }

  /* ── Steam Reviews: Single-Column ───────────── */
  .steam-reviews-grid {
    grid-template-columns: 1fr;
  }

  /* ── Development Timer ───────────────────────── */
  .development-timer {
    gap: 12px;
  }

  .development-timer__controls {
    grid-template-columns: 1fr;
  }

  .development-timer__actions {
    gap: 8px;
    flex-wrap: wrap;
  }

  .development-timer__actions button {
    min-height: 44px;
    flex: 1 1 auto;
    font-size: 0.9rem;
  }

  .development-timer__summary strong {
    font-size: 1.6rem;
  }

  /* ── Twitch Card ─────────────────────────────── */
  .twitch-card__heading {
    font-size: 1rem;
  }

  .twitch-card__title-group h3 {
    font-size: 0.88rem;
  }

  .twitch-summary strong {
    font-size: 1.5rem;
  }

  /* ── Revenue ─────────────────────────────────── */
  .revenue-form {
    gap: 10px;
  }

  .revenue-form input,
  .revenue-form button,
  .revenue-form select {
    min-height: 44px;
    font-size: 0.95rem;
  }

  .revenue-summary-card {
    padding: 14px 16px;
  }

  .revenue-summary-card strong {
    font-size: 1.6rem;
  }

  /* ── Game Card ───────────────────────────────── */
  .game-card {
    padding: 0;
  }

  .game-card__body {
    padding: 14px;
  }

  /* ── Marketing Cards ─────────────────────────── */
  .marketing-card {
    gap: 12px;
  }

  .marketing-card__header {
    gap: 10px;
  }

  /* ── Settings ────────────────────────────────── */
  .settings-form {
    gap: 14px;
  }

  .settings-form input,
  .settings-form select,
  .settings-form textarea {
    min-height: 44px;
    font-size: 0.95rem;
  }

  /* ── Live Alert Banner: kompakter ───────────── */
  .live-alert-banner {
    padding: 10px 12px;
    gap: 8px;
  }

  .live-alert-banner__text {
    font-size: 0.78rem;
  }
}

/* ══════════════════════════════════════════════════
   SKELETON LOADING & ANIMATIONS
   ══════════════════════════════════════════════════ */

.skeleton {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.03) 25%,
    rgba(255, 255, 255, 0.06) 50%,
    rgba(255, 255, 255, 0.03) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.8s ease-in-out infinite;
  border-radius: 8px;
}

.skeleton--text {
  height: 14px;
  width: 60%;
  margin: 6px 0;
}

.skeleton--heading {
  height: 22px;
  width: 40%;
  margin: 4px 0;
}

.skeleton--card {
  height: 180px;
  border-radius: 11px;
}

.skeleton--metric {
  height: 90px;
  border-radius: 11px;
}

/* Card hover glow effect */
.panel,
.game-card,
.ticket-card,
.outreach-card,
.marketing-card,
.development-card,
.twitch-card,
.settings-card {
  transition: transform var(--transition-smooth), border-color var(--transition-smooth), box-shadow var(--transition-smooth);
}

.game-card:hover,
.ticket-card:hover,
.marketing-card:hover {
  border-color: rgba(80, 120, 175, 0.15);
  box-shadow: var(--shadow), 0 0 60px var(--glow-subtle);
}

/* Smooth page shell entrance */
.page-shell--app {
  animation: fadeIn 400ms ease-out;
}

/* Empty state animation */
.empty-state {
  animation: fadeIn 500ms ease-out;
}

/* Button press effect */
.icon-button:active,
.hero__link:active,
.main-nav__item:active,
.overview-link-card:active,
.ticket-card__close:active,
.ticket-card__restore:active {
  transform: scale(0.97);
  transition-duration: 80ms;
}

/* Status dot pulse animation */
.sidebar-status-dot--green,
.sidebar-status-dot--amber,
.sidebar-status-dot--red {
  animation: pulse-dot 2s ease-in-out infinite;
}

/* Retry button for error states */
.error-retry {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 9px;
  border: 1px solid rgba(255, 140, 140, 0.24);
  background: rgba(120, 30, 30, 0.18);
  color: #ffb3b3;
  font: inherit;
  font-size: 0.88rem;
  cursor: pointer;
  transition: all var(--transition-smooth);
}

.error-retry:hover {
  transform: translateY(-1px);
  background: rgba(150, 40, 40, 0.28);
  border-color: rgba(255, 140, 140, 0.36);
}

.error-retry svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

/* Improved throbber */
.throbber {
  border-color: rgba(120, 155, 200, 0.15);
  border-top-color: var(--accent-bright);
}

/* Smooth scrollbar for sidebar nav on mobile */
.main-nav--sidebar {
  scrollbar-color: rgba(80, 110, 155, 0.2) transparent;
}

.status-pill--success {
  border-color: rgba(46, 204, 113, 0.28);
  color: #87e0a9;
  background: rgba(20, 72, 44, 0.32);
}

.automations-shell {
  display: grid;
  gap: 18px;
}

.automations-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding: 18px 20px;
  border: 1px solid rgba(138, 164, 206, 0.14);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(14, 18, 24, 0.92), rgba(10, 13, 18, 0.96));
}

.automations-toolbar__copy {
  display: grid;
  gap: 10px;
}

.automations-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.automations-toolbar__message {
  margin: 0;
  color: var(--muted);
}

.automations-toolbar__button {
  white-space: nowrap;
}

.automations-table-card {
  border: 1px solid rgba(138, 164, 206, 0.14);
  border-radius: 18px;
  background: rgba(10, 13, 18, 0.88);
  overflow: hidden;
}

.automations-table-wrap {
  overflow-x: auto;
}

.automations-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1180px;
}

.automations-table th,
.automations-table td {
  padding: 16px 18px;
  text-align: left;
  border-bottom: 1px solid rgba(138, 164, 206, 0.1);
  vertical-align: top;
}

.automations-table th {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent-light);
  background: rgba(13, 17, 24, 0.96);
}

.automations-table tbody tr:hover {
  background: rgba(24, 31, 44, 0.36);
}

.automations-name-cell {
  display: grid;
  gap: 6px;
}

.automations-name-cell strong {
  font-size: 0.98rem;
}

.automations-name-cell span {
  color: var(--muted);
  font-size: 0.78rem;
}

.automations-method,
.automations-enabled,
.automations-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(138, 164, 206, 0.18);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

.automations-method--get {
  background: rgba(57, 125, 207, 0.2);
  color: #9cc5ff;
}

.automations-method--post {
  background: rgba(46, 204, 113, 0.18);
  color: #90e9ae;
}

.automations-method--put,
.automations-method--patch {
  background: rgba(243, 156, 18, 0.18);
  color: #ffd48b;
}

.automations-method--delete {
  background: rgba(231, 76, 60, 0.18);
  color: #ffaea4;
}

.automations-enabled.is-enabled {
  color: #87e0a9;
  border-color: rgba(46, 204, 113, 0.28);
  background: rgba(20, 72, 44, 0.32);
}

.automations-enabled.is-disabled {
  color: #f0b0b8;
  border-color: rgba(231, 76, 60, 0.22);
  background: rgba(76, 25, 25, 0.28);
}

.automations-status--success {
  color: #87e0a9;
  border-color: rgba(46, 204, 113, 0.28);
  background: rgba(20, 72, 44, 0.32);
}

.automations-status--failed {
  color: #ffb0b7;
  border-color: rgba(231, 76, 60, 0.22);
  background: rgba(76, 25, 25, 0.28);
}

.automations-status--idle {
  color: var(--muted);
  background: rgba(21, 28, 40, 0.46);
}

.automations-url {
  display: inline-block;
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}

.automations-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.automations-actions__button {
  border: 1px solid rgba(138, 164, 206, 0.18);
  background: rgba(12, 18, 28, 0.92);
  color: var(--text);
  padding: 9px 12px;
  border-radius: 12px;
  cursor: pointer;
  font: inherit;
}

.automations-actions__button:hover,
.automations-actions__button:focus-visible {
  background: rgba(22, 31, 46, 0.96);
  border-color: rgba(138, 164, 206, 0.32);
}

.automations-actions__button--danger {
  color: #ffb0b7;
  border-color: rgba(231, 76, 60, 0.2);
  background: rgba(54, 20, 24, 0.86);
}

.automations-dialog {
  width: min(920px, calc(100vw - 28px));
}

.automations-dialog__form {
  display: grid;
  gap: 18px;
}

.automations-dialog__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.automations-dialog__field {
  display: grid;
  gap: 8px;
}

.automations-dialog__field--full {
  grid-column: 1 / -1;
}

.automations-dialog__field--checkbox {
  align-content: end;
  display: flex;
  gap: 10px;
  align-items: center;
  min-height: 54px;
}

.automations-dialog__field span {
  color: var(--accent-bright);
  font-size: 0.88rem;
}

.automations-dialog__field input,
.automations-dialog__field select,
.automations-dialog__field textarea {
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(149, 174, 214, 0.22);
  background: rgba(8, 12, 18, 0.92);
  color: var(--text);
  padding: 13px 14px;
  font: inherit;
}

.automations-dialog__field textarea {
  resize: vertical;
  min-height: 132px;
}

.automations-dialog__field input:focus-visible,
.automations-dialog__field select:focus-visible,
.automations-dialog__field textarea:focus-visible {
  outline: none;
  border-color: rgba(171, 198, 236, 0.45);
  box-shadow: 0 0 0 3px rgba(87, 122, 178, 0.18);
}

.automations-dialog__security-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.55;
}

.automations-dialog__notice,
.automations-dialog__validation {
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(138, 164, 206, 0.18);
  background: rgba(16, 22, 32, 0.86);
}

.automations-dialog__notice {
  color: #ffe1a3;
  border-color: rgba(243, 156, 18, 0.24);
  background: rgba(64, 45, 18, 0.28);
}

.automations-dialog__validation {
  color: #ffb7be;
  border-color: rgba(231, 76, 60, 0.22);
  background: rgba(76, 25, 25, 0.28);
}

.automations-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.automations-test-result {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(138, 164, 206, 0.18);
  background: rgba(11, 16, 24, 0.92);
}

.automations-test-result__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.automations-test-result__status {
  color: var(--muted);
  font-size: 0.86rem;
}

.automations-test-result__status.is-success {
  color: #87e0a9;
}

.automations-test-result__status.is-error {
  color: #ffb7be;
}

.automations-test-result__status.is-loading {
  color: #ffe1a3;
}

.automations-test-result__body {
  margin: 0;
  max-height: 320px;
  overflow: auto;
  padding: 14px;
  border-radius: 12px;
  background: rgba(5, 8, 14, 0.96);
  border: 1px solid rgba(138, 164, 206, 0.1);
  color: #dce7f6;
  font: 0.83rem/1.55 "Cascadia Code", "Consolas", monospace;
  white-space: pre-wrap;
  word-break: break-word;
}

.automations-history-dialog {
  width: min(860px, calc(100vw - 28px));
}

.automations-history-dialog__meta {
  margin-bottom: 16px;
}

.automations-history-dialog__body {
  max-height: min(62vh, 640px);
  overflow: auto;
}

.automations-history-list {
  display: grid;
  gap: 12px;
}

.automations-history-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border-radius: 14px;
  border: 1px solid rgba(138, 164, 206, 0.14);
  background: rgba(9, 13, 19, 0.92);
}

.automations-history-card__top,
.automations-history-card__title,
.automations-history-card__metrics,
.automations-history-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.automations-history-card__title,
.automations-history-card__metrics,
.automations-history-card__meta {
  justify-content: flex-start;
}

.automations-history-card__trigger,
.automations-history-card__metrics span,
.automations-history-card__meta span {
  color: var(--muted);
  font-size: 0.84rem;
}

.automations-history-card__preview {
  margin: 0;
  max-height: 220px;
  overflow: auto;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(5, 8, 14, 0.96);
  border: 1px solid rgba(138, 164, 206, 0.1);
  color: #dce7f6;
  font: 0.8rem/1.55 "Cascadia Code", "Consolas", monospace;
  white-space: pre-wrap;
  word-break: break-word;
}

.automations-history-card__error {
  margin: 0;
  color: #ffb7be;
  font-size: 0.86rem;
}

@media (max-width: 920px) {
  .automations-toolbar {
    flex-direction: column;
  }

  .automations-dialog__grid {
    grid-template-columns: 1fr;
  }

  .automations-history-card__top {
    align-items: flex-start;
  }
}

.firebase-card {
  display: grid;
  gap: 14px;
}

.firebase-card__status-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.firebase-card__status-item {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(138, 164, 206, 0.14);
  background: rgba(10, 13, 18, 0.82);
}

.firebase-card__status-item span,
.firebase-card__token > span {
  color: var(--accent-light);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.firebase-status-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 110px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(138, 164, 206, 0.18);
  background: rgba(21, 28, 40, 0.46);
  color: var(--muted);
}

.firebase-status-chip--default {
  color: var(--muted);
}

.firebase-status-chip--granted {
  color: #87e0a9;
  border-color: rgba(46, 204, 113, 0.28);
  background: rgba(20, 72, 44, 0.32);
}

.firebase-status-chip--denied {
  color: #ffb7be;
  border-color: rgba(231, 76, 60, 0.22);
  background: rgba(76, 25, 25, 0.28);
}

.firebase-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.firebase-card__actions button {
  border: 1px solid rgba(138, 164, 206, 0.18);
  background: rgba(12, 18, 28, 0.92);
  color: var(--text);
  padding: 12px 16px;
  border-radius: 12px;
  cursor: pointer;
  font: inherit;
  transition: all var(--transition-smooth);
}

.firebase-card__actions button:hover,
.firebase-card__actions button:focus-visible {
  background: rgba(22, 31, 46, 0.96);
  border-color: rgba(138, 164, 206, 0.32);
}

.firebase-card__actions button:disabled {
  opacity: 0.7;
  cursor: wait;
}

.firebase-card__token {
  display: grid;
  gap: 8px;
}

.firebase-card__devices {
  display: grid;
  gap: 10px;
}

.firebase-card__devices-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--accent-light);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.firebase-devices-list {
  display: grid;
  gap: 10px;
}

.firebase-devices__empty {
  margin: 0;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(138, 164, 206, 0.12);
  background: rgba(6, 10, 16, 0.94);
  color: var(--muted);
}

.firebase-device-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(138, 164, 206, 0.12);
  background: rgba(6, 10, 16, 0.94);
}

.firebase-device-card__main {
  display: grid;
  gap: 8px;
}

.firebase-device-card__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.firebase-device-card__meta,
.firebase-device-card__dates,
.firebase-device-card__status {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
}

.firebase-device-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: start;
  justify-content: end;
}

.firebase-device-card__actions button {
  border: 1px solid rgba(138, 164, 206, 0.18);
  background: rgba(12, 18, 28, 0.92);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 12px;
  cursor: pointer;
  font: inherit;
  transition: all var(--transition-smooth);
}

.firebase-device-card__actions button:hover,
.firebase-device-card__actions button:focus-visible {
  background: rgba(22, 31, 46, 0.96);
  border-color: rgba(138, 164, 206, 0.32);
}

.firebase-device-card__actions button:disabled {
  opacity: 0.6;
  cursor: default;
}

.firebase-card__token pre {
  margin: 0;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(138, 164, 206, 0.12);
  background: rgba(6, 10, 16, 0.94);
  color: #dce7f6;
  font: 0.8rem/1.55 "Cascadia Code", "Consolas", monospace;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 180px;
  overflow: auto;
}

.firebase-card__message {
  margin: 0;
  color: var(--muted);
}

@media (max-width: 720px) {
  .firebase-card__status-grid {
    grid-template-columns: 1fr;
  }

  .firebase-device-card {
    grid-template-columns: 1fr;
  }

  .firebase-device-card__actions {
    justify-content: start;
  }
}
