:root {
  --bg-1: #02040a;
  --bg-2: #03060f;
  --panel: #0a0f1a;
  --panel-2: #070c14;
  --text: #e8f0ff;
  --muted: #9db2ce;
  --accent: #15c39a;
  --green: #1abc9c;
  --yellow: #f7c948;
  --red: #e45757;
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  background: var(--bg-2);
  color: var(--text);
  min-height: 100vh;
  padding: 0;
  display: flex;
  justify-content: center;
}

.app {
  width: 100%;
  background: var(--panel-2);
  border-radius: 0;
  box-shadow: none;
  padding: 16px;
  position: relative;
  overflow: hidden;
}

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

h1 {
  margin: 0 0 8px;
  font-size: 26px;
  letter-spacing: -0.5px;
}

.sub {
  margin: 0 0 22px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

.controls {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  margin-bottom: 20px;
}

.controls input {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 15px;
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.controls input:focus {
  border-color: rgba(26, 188, 156, 0.6);
  box-shadow: 0 0 0 4px rgba(26, 188, 156, 0.16);
}

.controls button {
  padding: 14px 18px;
  border: none;
  border-radius: 12px;
  background: linear-gradient(135deg, #15c39a, #109c73);
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(21, 195, 154, 0.3);
  transition: transform 120ms ease, box-shadow 120ms ease;
}

.controls button:active { transform: translateY(1px); }
.controls button:hover { box-shadow: 0 14px 34px rgba(21, 195, 154, 0.36); }

.view-toggle {
  display: inline-flex;
  background: #18263a;
  border-radius: 12px;
  padding: 4px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  gap: 4px;
}

.view-btn {
  border: none;
  background: transparent;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  color: var(--muted);
  cursor: pointer;
  transition: background 120ms ease, box-shadow 120ms ease, color 120ms ease;
}

.view-btn.active {
  background: #23344d;
  color: var(--text);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.18);
}

.board {
  display: grid;
  grid-template-rows: repeat(3, 1fr);
  gap: 14px;
  padding: 14px;
  background: transparent;
  border: none;
  box-shadow: none;
}

.row {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 16px;
  padding: 6px 0;
  border-radius: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.row-label {
  text-align: center;
  font-weight: 700;
  color: var(--muted);
  font-size: 13px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
}

.light {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.circle {
  width: 86px;
  height: 86px;
  border-radius: 50%;
  border: 6px solid rgba(0, 0, 0, 0.35);
  background: #1b2333;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 140ms ease;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.35);
}

.circle:active { transform: translateY(2px) scale(0.99); }
.circle.drop-target {
  box-shadow: 0 0 0 5px rgba(21, 195, 154, 0.45);
  transform: scale(1.04);
}

.circle.green { background: var(--green); }
.circle.yellow { background: var(--yellow); color: #4b3a00; }
.circle.red { background: var(--red); }

.names {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 0;
  align-items: center;
}

.names[data-side="left"] { display: none; }
.names[data-side="right"] { justify-content: flex-start; text-align: left; flex: 1; }

.chip {
  padding: 10px 14px;
  border-radius: 12px;
  background: #1a2538;
  border: 1px solid rgba(255, 255, 255, 0.06);
  font-weight: 700;
  font-size: 16px;
  color: var(--text);
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease;
  position: relative;
  user-select: none;
}

.chip.dragging {
  opacity: 0.6;
  transform: scale(0.98);
}

.chip:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.35);
  border-color: rgba(21, 195, 154, 0.5);
  background: #1f2d44;
}

.chip.selected {
  box-shadow: 0 12px 22px rgba(21, 195, 154, 0.35);
  border-color: rgba(21, 195, 154, 0.8);
  background: rgba(21, 195, 154, 0.1);
}

.chip.warned {
  background: #f7c948;
  border-color: #f0b000;
  color: #1b1400;
}

.app[data-view="tafel"] .chip.warned {
  background: #f7c948;
  color: #1b1400;
  border-color: #f0b000;
}

.chip.warned.selected {
  border-color: #d39a00;
  box-shadow: inset 0 0 0 2px rgba(211, 154, 0, 0.6);
}

.chip.placeholder {
  visibility: hidden;
  pointer-events: none;
}

.chip.ghost {
  opacity: 0;
  pointer-events: none;
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

.delete-btn {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(235, 87, 87, 0.85);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 14px rgba(0, 0, 0, 0.35);
}

.app[data-view="verwaltung"] .chip { padding-right: 20px; }
.app[data-view="verwaltung"] .chip .delete-btn { display: inline-flex; }

.hint {
  margin-top: 16px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
  background: rgba(255, 255, 255, 0.06);
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px dashed rgba(255, 255, 255, 0.16);
}

.hint p {
  margin: 0 0 6px;
}

.hint p:last-child {
  margin-bottom: 0;
}

.utility {
  display: flex;
  gap: 10px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.utility button {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: #1a2538;
  color: #e8f0ff;
  cursor: pointer;
  font-weight: 700;
  transition: transform 100ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.utility button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.25);
  border-color: rgba(21, 195, 154, 0.6);
}

/* Tracker Ansicht */
.tracker {
  display: none;
  padding: 8px 0;
  background: transparent;
  border: none;
  box-shadow: none;
  height: calc(100vh - 80px);
  grid-template-rows: auto 1fr;
  gap: 10px;
}

.app[data-view="tracker"] .tracker {
  display: grid;
}

/* Remove all glows/shadows globally */
*, *::before, *::after {
  box-shadow: none !important;
  text-shadow: none !important;
}

.app[data-view="tracker"] .tracker { display: block; }

.tracker-controls {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 14px;
}

.tracker-controls input {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: #0f1728;
  color: var(--text);
  width: 120px;
  font-size: 15px;
}

.tracker-controls button {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #1a2538;
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
  transition: transform 100ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.tracker-controls button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.25);
  border-color: rgba(21, 195, 154, 0.6);
}

.tracker-grid-wrapper {
  position: relative;
  overflow: hidden;
}

.tracker-line {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--tracker-line-left, 50%);
  transform: translateX(-50%);
  width: 6px;
  background: rgba(255, 255, 255, 0.45);
  pointer-events: none;
  border-radius: 2px;
}

.tracker-line.ok {
  background: rgba(21, 195, 154, 0.9);
}

.tracker-line.fail {
  background: rgba(228, 87, 87, 0.9);
}

.tracker-grid {
  display: grid;
  gap: 10px;
  grid-template-rows: repeat(6, 1fr);
  height: 100%;
}

.tracker-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: center;
  padding: 4px 0;
  border-radius: 0;
  background: transparent;
  border: none;
  min-height: auto;
}

.tracker-label {
  font-weight: 800;
  font-size: clamp(24px, 4vh, 40px);
  color: var(--text);
  line-height: 1.1;
  text-align: left;
  padding-right: 12px;
}

.tracker-boxes {
  display: grid;
  grid-template-columns: repeat(4, minmax(60px, 1fr));
  gap: 18px;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.tracker-box {
  width: 100%;
  aspect-ratio: 1 / 1;
  min-height: 52px;
  max-height: 110px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
  transition: transform 100ms ease, border-color 120ms ease, background 120ms ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  font-weight: 900;
  font-size: clamp(18px, 3vh, 28px);
}

.tracker-box.checked {
  background: #15c39a;
  border-color: rgba(21, 195, 154, 0.8);
  color: #0f1728;
  box-shadow: 0 8px 14px rgba(0, 0, 0, 0.3);
}

.tracker-stars {
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  padding-bottom: 6px;
}

.tracker-star {
  background: transparent;
  border: none;
  font-size: clamp(96px, 16vw, 160px);
  color: #7f8dab;
  cursor: pointer;
  padding: 6px;
  transition: transform 80ms ease, color 120ms ease;
}

.tracker-star:hover {
  transform: translateY(-2px);
}

.tracker-star.filled {
  color: #f7c948;
}

.tracker-stars.muted .tracker-star.filled {
  color: #7f8dab;
}

.tracker-status { display: none; }

/* Tafelansicht (nur Kreise + Namen) */
.app[data-view="tafel"] .top,
.app[data-view="tafel"] .controls,
.app[data-view="tafel"] .hint,
.app[data-view="tafel"] .utility {
  display: none;
}

.app[data-view="tracker"] .board,
.app[data-view="tracker"] .controls,
.app[data-view="tracker"] .hint,
.app[data-view="tracker"] .utility,
.app[data-view="tracker"] .tafel-back,
.app[data-view="tracker"] .top {
  display: none;
}

.app[data-view="tafel"] {
  padding: 90px 0 0 0;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  display: grid;
  grid-template-columns: 1fr 2fr;
  align-items: start;
  gap: 8px;
  min-height: 100vh;
}

.app[data-view="tafel"] .board {
  height: calc(100vh - 80px - 90px);
  min-height: 520px;
  margin: 0;
  width: 100%;
  padding: 10px;
}

.app[data-view="tafel"] .row {
  height: calc((100% - 28px) / 3); /* 28px = zwei Gaps à 14px */
}

.app[data-view="tafel"] .circle {
  width: calc((100vh - 80px - 28px) / 3 - 40px);
  height: calc((100vh - 80px - 28px) / 3 - 40px);
  max-width: 320px;
  max-height: 320px;
  min-width: 140px;
  min-height: 140px;
  aspect-ratio: 1 / 1;
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.45);
  font-size: 28px;
}

.app[data-view="tafel"] .chip {
  font-size: clamp(22px, 1.3vw, 36px);
  padding: clamp(12px, 0.9vw, 18px) clamp(16px, 1.4vw, 24px);
  box-shadow: none;
  background: rgba(255, 255, 255, 0.05);
}

.tafel-status {
  align-self: start;
  justify-self: center;
  margin: 12px 0 0;
  padding: 12px 14px;
  border-radius: 18px;
  background: #b12a2a;
  color: #fff;
  font-weight: 800;
  font-size: clamp(22px, 1.3vw, 36px);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  border: 1px solid rgba(255, 255, 255, 0.15);
  cursor: pointer;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.4);
  display: none;
  width: 66%;
  height: 33%;
  min-height: 140px;
  max-height: 360px;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.app[data-view="tafel"] .tafel-status { display: inline-flex; }

.tafel-status.open {
  background: #16a673;
  border-color: rgba(21, 195, 154, 0.7);
}

.tafel-back {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  font-size: 18px;
  cursor: pointer;
  display: none;
  box-shadow: 0 12px 20px rgba(0, 0, 0, 0.35);
}

/* Back button ersetzt durch vorhandenes Menü; ausblenden */
.tafel-back { display: none !important; }

.float-controls {
  position: fixed;
  bottom: 18px;
  right: 18px;
  display: flex;
  gap: 10px;
  z-index: 20;
}

.float-btn {
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(17, 28, 45, 0.9);
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4);
  transition: transform 100ms ease, box-shadow 120ms ease, border-color 120ms ease, opacity 120ms ease;
}

.float-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.45);
  border-color: rgba(21, 195, 154, 0.6);
}

.float-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.app[data-view="tracker"] ~ .float-controls {
  display: none;
}

.tafel-menu {
  position: absolute;
  top: 12px;
  right: 12px;
  display: none;
  z-index: 5;
}

.app[data-view="tafel"] .tafel-menu {
  display: inline-flex;
}

.app[data-view="tracker"] .tafel-menu {
  display: inline-flex;
}

/* Timer (Tafel) */
.timer-toggle {
  position: absolute;
  bottom: 18px;
  left: 18px;
  padding: 22px 24px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: #1a2538;
  color: #e8f0ff;
  font-weight: 800;
  font-size: 24px;
  cursor: pointer;
}

.app[data-view="verwaltung"] .timer-toggle {
  display: none;
}

.timer-panel {
  display: none;
  background: rgba(17, 28, 45, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 22px;
  padding: 28px;
  position: absolute;
  bottom: 140px;
  left: 16px;
  width: 500px;
  color: var(--text);
}

.app[data-view="tafel"] .timer-panel.visible {
  display: block;
}

.app[data-view="tracker"] .timer-panel.visible {
  display: block;
}

.timer-display {
  font-size: clamp(80px, 10vw, 120px);
  font-weight: 800;
  text-align: center;
  margin: 0 0 22px;
}

.timer-controls {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.timer-controls button {
  padding: 18px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: #0f1728;
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
  font-size: 20px;
}

.timer-inputs {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  margin-bottom: 18px;
}

.timer-inputs input {
  padding: 12px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: #0f1728;
  color: var(--text);
  font-size: 18px;
}

.timer-inputs button {
  padding: 12px 16px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: #0f1728;
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
  font-size: 18px;
}

.timer-presets {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.timer-presets button {
  padding: 12px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: #0f1728;
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
  font-size: 17px;
}

@media (max-width: 820px) {
  .row { grid-template-columns: 1fr; }
  .light { order: -1; }
  .row-label { display: none; }
  .circle { width: 76px; height: 76px; }
  .board { gap: 12px; }
  .tafel-back { top: 12px; right: 12px; }
  .timer-presets { grid-template-columns: repeat(2, 1fr); }
}
