:root {
  --bg: #060608;
  --panel: rgba(8, 8, 12, 0.92);
  --panel-soft: rgba(17, 17, 24, 0.92);
  --text: #f4ebff;
  --muted: #b8a6d8;
  --line: rgba(153, 111, 255, 0.16);
  --violet: #b98cff;
  --violet-deep: #51209e;
  --cyan: #59e7f3;
  --white-glow: #f6f2ff;
  --shadow: 0 30px 80px rgba(0, 0, 0, 0.45);
  --radius: 22px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: Georgia, "Times New Roman", serif;
  color: var(--text);
  background: #000;
}

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

.top-nav {
  display: flex;
  justify-content: center;
  align-items: start;
  gap: 16px;
  margin-bottom: 18px;
  position: relative;
}

.nav-links,
.todo-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.nav-links {
  justify-content: center;
  flex: 1 1 auto;
}

.nav-actions {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-left: auto;
}

.nav-pill,
.lock-button,
.todo-pill {
  border: 1px solid rgba(50, 240, 215, 0.16);
  border-radius: 999px;
  background: rgba(5, 20, 19, 0.84);
  color: #49e6df;
  box-shadow:
    inset 0 0 0 1px rgba(73, 230, 223, 0.04),
    0 0 0 1px rgba(0, 0, 0, 0.2),
    0 0 18px rgba(40, 214, 207, 0.08);
  padding: 13px 22px;
  cursor: pointer;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  max-width: 100%;
}

.nav-pill.is-active {
  color: #d8b6ff;
  border-color: rgba(185, 140, 255, 0.35);
  background: linear-gradient(180deg, rgba(61, 22, 122, 0.92), rgba(37, 12, 82, 0.94));
  box-shadow: 0 0 26px rgba(123, 58, 237, 0.28);
}

.lock-button {
  min-width: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 1.3rem;
  line-height: 1;
}

.view-section.hidden,
.hidden {
  display: none;
}

.field.hidden,
.checkbox-field.hidden,
.editor-grid.hidden,
.detail-section.hidden,
.move-actions .hidden {
  display: none;
}

.panel,
.kpi-card {
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(10, 10, 14, 0.96), rgba(6, 6, 10, 0.96));
  box-shadow: var(--shadow);
}

.hero-copy,
.panel-kicker,
.kpi-label,
.item-meta,
.detail-empty,
.search {
  font-family: "Trebuchet MS", sans-serif;
}

.games-hero {
  text-align: center;
  padding: 28px 0 12px;
}

.games-hero h2 {
  margin: 0;
  font-size: clamp(2.4rem, 4vw, 4.6rem);
  color: #d794ff;
}

.games-filter-panel {
  padding: 26px;
}

.games-form-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(220px, 0.9fr) minmax(220px, 0.9fr) minmax(180px, 0.7fr) 180px;
  gap: 22px;
  align-items: end;
}

.games-form-grid > * {
  min-width: 0;
}

.console-form-grid {
  grid-template-columns: minmax(0, 1fr) 200px;
}

.console-search-field {
  grid-column: span 1;
}

.field-search {
  grid-column: auto;
}

.field-platform {
  grid-column: auto;
}

.field-genre {
  grid-column: auto;
}

.field-sort {
  grid-column: auto;
  margin-left: 0;
}

.inventory-form-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.inventory-type-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 18px;
}

.inventory-type-tabs.hidden {
  display: none;
}

.inventory-search {
  grid-column: span 5;
}

.inventory-sort {
  grid-column: span 3;
}

.field {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.field span,
.checkbox-field span,
.stat-card span {
  color: var(--white-glow);
  font-size: 0.95rem;
  display: block;
  white-space: nowrap;
}

.field input,
.field select {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(8, 8, 12, 0.98);
  color: var(--text);
  padding: 16px 18px;
  font-size: 1rem;
  width: 100%;
  min-width: 0;
}

.field-help {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.checkbox-field {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 56px;
  align-self: end;
  padding-bottom: 4px;
}

.checkbox-field input {
  width: 22px;
  height: 22px;
}

.apply-button {
  border: 0;
  border-radius: 18px;
  padding: 16px 20px;
  background: linear-gradient(180deg, #6120f3, #4300c6);
  color: white;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(98, 32, 243, 0.34);
}

.games-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 22px;
}

.stat-card {
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(9, 9, 14, 0.96), rgba(7, 7, 12, 0.94));
  border-radius: 24px;
  padding: 20px 22px;
  box-shadow: var(--shadow);
}

.stat-card strong {
  display: block;
  margin-top: 12px;
  color: #d794ff;
  font-size: clamp(1.8rem, 2vw, 2.6rem);
  line-height: 1.05;
  overflow-wrap: anywhere;
}

.table-head.games-head {
  grid-template-columns: minmax(0, 2.2fr) 140px minmax(0, 1.1fr) 140px 140px 140px;
}

.table-head.top-values-head {
  grid-template-columns: minmax(0, 2.2fr) 140px 140px;
}

.table-head.console-head {
  grid-template-columns: minmax(0, 2fr) minmax(140px, 1.2fr) minmax(0, 1.3fr) 140px 140px 150px;
}

.table-head.inventory-head {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr) 140px 120px 140px;
}

.table-head.checklist-head {
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr) minmax(0, 1.4fr) 220px;
}

.sort-head {
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  cursor: pointer;
}

.game-row {
  display: grid;
  gap: 18px;
  align-items: center;
  padding: 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  cursor: pointer;
}

.games-row {
  grid-template-columns: minmax(0, 2.2fr) 140px minmax(0, 1.1fr) 140px 140px 140px;
}

.top-values-row {
  grid-template-columns: minmax(0, 2.2fr) 140px 140px;
}

.console-row {
  grid-template-columns: minmax(0, 2fr) minmax(140px, 1.2fr) minmax(0, 1.3fr) 140px 140px 150px;
}

.inventory-row {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr) 140px 120px 140px;
}

.table-head.inventory-no-type-head,
.inventory-no-type-row {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr) 120px 140px;
}

.table-head.inventory-no-type-head [data-inventory-sort="type"],
.inventory-no-type-row .game-rating {
  display: none;
}

.table-head.broken-inventory-head,
.broken-inventory-row {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.4fr) 140px;
}

.table-head.broken-inventory-head [data-inventory-sort="type"],
.table-head.broken-inventory-head [data-inventory-sort="value"],
.broken-inventory-row .game-rating,
.broken-inventory-row .game-value {
  display: none;
}

.checklist-row {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr) minmax(0, 1.4fr) 220px;
  gap: 18px;
  align-items: center;
  padding: 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.game-row:hover,
.inventory-row:hover {
  background: rgba(255, 255, 255, 0.02);
}

.game-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.mini-action {
  border: 1px solid rgba(185, 140, 255, 0.18);
  border-radius: 12px;
  background: rgba(14, 12, 22, 0.98);
  color: var(--text);
  padding: 10px 12px;
  cursor: pointer;
  font-family: "Trebuchet MS", sans-serif;
}

.game-name {
  margin: 0 0 5px;
  color: var(--text);
}

.game-platform,
.game-status,
.game-rating,
.game-owned {
  margin: 0;
  color: var(--muted);
  font-family: "Trebuchet MS", sans-serif;
}

.game-value {
  color: #d794ff;
}

.game-cost {
  color: var(--muted);
  font-family: "Trebuchet MS", sans-serif;
}

.pager {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 0 18px;
}

.pager-button {
  border: 1px solid rgba(185, 140, 255, 0.2);
  border-radius: 14px;
  background: rgba(12, 11, 18, 0.98);
  color: var(--text);
  width: 52px;
  height: 52px;
  font-size: 1.1rem;
  cursor: pointer;
}

.pager-center {
  display: flex;
  align-items: center;
  gap: 18px;
  color: var(--muted);
  font-family: "Trebuchet MS", sans-serif;
}

.page-jump {
  display: flex;
  align-items: center;
  gap: 10px;
}

.page-jump input {
  width: 78px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(8, 8, 12, 0.98);
  color: var(--text);
  padding: 10px 12px;
}

.actions-head {
  text-align: right;
  padding-right: 4px;
  justify-self: end;
}

.login-dialog {
  border: 1px solid rgba(185, 140, 255, 0.22);
  border-radius: 26px;
  background: rgba(10, 10, 16, 0.98);
  color: var(--text);
  min-width: min(460px, calc(100vw - 24px));
}

.login-dialog::backdrop {
  background: rgba(0, 0, 0, 0.68);
  backdrop-filter: blur(6px);
}

.detail-page {
  width: min(1180px, calc(100vw - 40px));
  margin: 0 auto 64px;
  border: 1px solid rgba(185, 140, 255, 0.22);
  border-radius: 30px;
  background: rgba(10, 10, 16, 0.98);
  color: var(--text);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.4);
}

.login-form {
  display: grid;
  gap: 18px;
  padding: 26px;
}

.detail-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: -4px;
}

.item-detail-tab-panel {
  display: grid;
  gap: 18px;
}

.item-detail-tab-panel.hidden {
  display: none;
}

.move-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.compact {
  padding: 14px 16px;
  margin: 0;
}

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

.photo-upload-field {
  gap: 10px;
}

.photo-upload-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.photo-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}

.photo-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 22px;
  border: 1px solid rgba(185, 140, 255, 0.2);
  background: linear-gradient(180deg, rgba(15, 15, 20, 0.98), rgba(10, 10, 16, 0.94));
  text-decoration: none;
  color: var(--text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
  transition: transform 140ms ease, border-color 140ms ease, box-shadow 140ms ease;
}

.photo-card:hover,
.photo-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(0, 255, 229, 0.34);
  box-shadow: 0 0 0 2px rgba(0, 255, 229, 0.08);
}

.photo-card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.photo-card-caption {
  font-size: 0.95rem;
  color: var(--soft);
  font-variant-numeric: tabular-nums;
}

.upload-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.upload-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  appearance: none;
  border-radius: 999px;
  border: 1px solid rgba(0, 255, 229, 0.22);
  background: linear-gradient(180deg, rgba(0, 48, 44, 0.72), rgba(0, 26, 22, 0.92));
  color: var(--cyan);
  font-family: "Georgia", "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease;
}

.upload-action:hover,
.upload-action:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(0, 255, 229, 0.42);
  box-shadow: 0 0 0 2px rgba(0, 255, 229, 0.12);
}

.upload-action:disabled {
  opacity: 0.48;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.camera-dialog {
  width: min(760px, calc(100vw - 24px));
}

.camera-form {
  display: grid;
  gap: 18px;
  padding: 24px;
}

.camera-header h2 {
  margin: 0;
}

.camera-header .detail-empty {
  margin: 8px 0 0;
}

.camera-preview-shell {
  overflow: hidden;
  border: 1px solid rgba(185, 140, 255, 0.18);
  border-radius: 24px;
  background: rgba(3, 6, 12, 0.92);
}

.camera-preview {
  display: block;
  width: 100%;
  max-height: 62vh;
  object-fit: cover;
  background: #020204;
}

.camera-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
}

.camera-thumb {
  overflow: hidden;
  border: 1px solid rgba(185, 140, 255, 0.16);
  border-radius: 18px;
  aspect-ratio: 1 / 1;
  background: rgba(12, 12, 20, 0.9);
}

.camera-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.camera-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.field textarea {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(8, 8, 12, 0.98);
  color: var(--text);
  padding: 16px 18px;
  font-size: 1rem;
  resize: vertical;
}

.notes-display {
  min-height: 110px;
  white-space: pre-wrap;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(8, 8, 12, 0.98);
  color: var(--muted);
  padding: 16px 18px;
  font-size: 1rem;
}

.import-grid {
  grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.6fr) 180px;
}

.import-field {
  grid-column: span 1;
}

.scores-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.high-scores-list {
  display: grid;
  gap: 12px;
}

.photo-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.photo-list:empty::before {
  content: "No pictures yet.";
  color: var(--muted);
  font-family: "Trebuchet MS", sans-serif;
}

.photo-list .mini-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 140px;
  min-height: 44px;
  text-decoration: none;
}

.score-row {
  display: grid;
  grid-template-columns: 1fr 0.8fr 1.2fr 56px;
  gap: 10px;
  align-items: center;
}

.price-row {
  grid-template-columns: 0.8fr 0.7fr 1fr 1fr 56px;
}

.score-row input {
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(8, 8, 12, 0.98);
  color: var(--text);
  padding: 12px 14px;
}

.remove-score {
  width: 56px;
}

.login-form h2 {
  margin: 0;
}

.login-actions {
  display: flex;
  justify-content: end;
  gap: 12px;
}

.danger-button {
  color: #ff9eb8;
  border-color: rgba(255, 112, 153, 0.35);
}

.clickable-row {
  cursor: pointer;
}

.login-error {
  color: #ff98bf;
  margin: 0;
}

.todo-pill.is-active {
  color: #d8b6ff;
  border-color: rgba(185, 140, 255, 0.35);
  background: linear-gradient(180deg, rgba(61, 22, 122, 0.92), rgba(37, 12, 82, 0.94));
}

.todo-primary-tabs {
  padding: 12px 0 26px;
  border-bottom: 1px solid rgba(185, 140, 255, 0.14);
  margin-bottom: 26px;
}

.compact-tabs {
  margin: 0;
}

.todo-filter-toolbar {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(260px, 0.8fr);
  gap: 18px;
  align-items: stretch;
  margin-bottom: 22px;
}

.single-filter-toolbar {
  grid-template-columns: minmax(280px, 0.72fr);
}

.todo-control-group {
  border: 1px solid rgba(185, 140, 255, 0.16);
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(80, 230, 222, 0.08), transparent 42%),
    rgba(4, 4, 8, 0.72);
  padding: 18px;
}

.control-label {
  display: block;
  margin: 0 0 12px;
  font-family: "Trebuchet MS", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cyan);
}

.segmented-tabs {
  gap: 10px;
}

.segmented-tabs .todo-pill {
  padding: 10px 16px;
  font-size: 0.95rem;
}

.price-automation-summary {
  align-items: center;
  margin: 0 0 18px;
}

.summary-card {
  border: 1px solid rgba(185, 140, 255, 0.12);
  border-radius: 20px;
  background: rgba(16, 14, 28, 0.72);
  padding: 14px 18px;
  min-width: min(720px, 100%);
}

.summary-card .detail-empty {
  margin: 0;
}

.add-workflow {
  display: grid;
  gap: 18px;
}

.add-workflow-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.9fr);
  gap: 20px;
  align-items: start;
}

.workflow-card {
  border: 1px solid rgba(185, 140, 255, 0.16);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(8, 8, 14, 0.98), rgba(5, 5, 10, 0.96)),
    rgba(8, 8, 14, 0.96);
  box-shadow: var(--shadow);
  padding: 22px;
  display: grid;
  gap: 18px;
}

.workflow-card-accent {
  background:
    radial-gradient(circle at top right, rgba(98, 32, 243, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(8, 8, 14, 0.98), rgba(5, 5, 10, 0.96));
}

.workflow-card-header {
  display: grid;
  gap: 8px;
}

.workflow-card-header h3 {
  margin: 0;
  font-size: 1.5rem;
  color: var(--white-glow);
}

.workflow-kicker {
  margin: 0;
  font-family: "Trebuchet MS", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cyan);
}

.workflow-copy {
  margin: 0;
  color: var(--muted);
  font-family: "Trebuchet MS", sans-serif;
  line-height: 1.55;
}

.add-search-grid,
.add-new-grid {
  grid-template-columns: minmax(220px, 0.85fr) minmax(0, 1.35fr) 180px;
}

.add-custom-field {
  grid-column: 1 / -1;
}

.add-broken-toggle {
  min-height: 0;
  padding-bottom: 0;
}

.add-status-box {
  margin: 0;
  min-height: 72px;
  display: flex;
  align-items: center;
}

.add-results {
  display: grid;
  gap: 12px;
}

.add-result-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid rgba(185, 140, 255, 0.18);
  background: rgba(4, 4, 8, 0.92);
}

.price-automation-row {
  grid-template-columns: minmax(260px, 1.4fr) minmax(110px, auto) minmax(110px, auto) minmax(150px, auto) minmax(240px, 1fr) minmax(150px, 0.5fr) auto;
}

.price-automation-url,
.price-automation-manual-value {
  min-width: 240px;
}

.price-automation-manual-value {
  min-width: 140px;
}

.price-automation-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.price-link-line a {
  color: var(--teal);
}

.price-automation-pager {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: center;
  gap: 14px;
  margin: 12px auto;
  padding: 8px 10px;
  border: 1px solid rgba(185, 140, 255, 0.16);
  border-radius: 999px;
  background: rgba(8, 7, 14, 0.86);
}

.price-automation-pager span {
  min-width: 132px;
  text-align: center;
  color: var(--white-glow);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
}

.price-automation-pager .pager-button {
  width: auto;
  min-width: 78px;
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
}

.add-new-grid {
  margin-top: 4px;
}

.eyebrow,
.panel-kicker {
  margin: 0;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cyan);
  font-size: 0.74rem;
}

.kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
  gap: 16px;
  margin-bottom: 22px;
}

.kpi-card {
  border-radius: var(--radius);
  padding: 20px 22px;
  min-width: 0;
  overflow: hidden;
}

.kpi-card strong {
  display: block;
  margin-top: 10px;
  font-size: clamp(1.28rem, 0.54vw + 0.94rem, 1.9rem);
  line-height: 1.1;
  white-space: nowrap;
  letter-spacing: -0.045em;
  font-variant-numeric: tabular-nums;
}

.console-stat-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.panel {
  border-radius: 28px;
  padding: 22px;
  margin-bottom: 22px;
  position: relative;
}

.panel-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.panel-header h2 {
  margin: 6px 0 0;
  font-size: 1.8rem;
}

.search {
  border: 1px solid rgba(185, 140, 255, 0.25);
  background: rgba(11, 10, 18, 0.95);
  color: var(--text);
  border-radius: 999px;
  padding: 12px 16px;
  min-width: min(280px, 100%);
}

.table-head,
.platform-row {
  display: grid;
  grid-template-columns: minmax(0, 2fr) 120px 140px minmax(180px, 1.6fr) 150px;
  gap: 18px;
  align-items: center;
}

.table-head {
  padding: 16px 18px;
  border-radius: 18px;
  background: #000;
  color: var(--white-glow);
  font-size: 0.95rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  position: sticky;
  top: 18px;
  z-index: 3;
}

.table-head > * {
  min-width: 0;
  white-space: nowrap;
}

.console-tabs {
  margin-bottom: 16px;
}

.console-panel {
  display: grid;
  gap: 16px;
}

.console-panel.hidden {
  display: none;
}

.table-body {
  margin-top: 14px;
}

.platform-row {
  width: 100%;
  border: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  background: transparent;
  color: inherit;
  text-align: left;
  padding: 20px 18px;
  cursor: pointer;
}

.platform-row:hover,
.platform-row.is-active {
  background: linear-gradient(90deg, rgba(89, 231, 243, 0.08), rgba(185, 140, 255, 0.08));
}

.platform-name,
.value,
.titles,
.owned {
  color: var(--violet);
  font-size: 1.05rem;
}

.bar-track {
  display: inline-flex;
  width: 100%;
  max-width: 360px;
  height: 22px;
  border-radius: 999px;
  background: rgba(61, 22, 122, 0.74);
  border: 1px solid rgba(153, 111, 255, 0.2);
  overflow: hidden;
}

.bar-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--cyan), var(--violet), var(--white-glow));
}

.complete {
  display: grid;
  gap: 8px;
}

.complete-text {
  color: var(--white-glow);
  font-weight: 700;
}

.detail-panel {
  background: linear-gradient(180deg, rgba(10, 10, 16, 0.98), rgba(9, 8, 14, 0.94));
}

.detail-section,
.history-list {
  display: grid;
  gap: 12px;
}

.detail-empty {
  padding: 22px;
  border-radius: 18px;
  background: rgba(14, 13, 22, 0.95);
  color: var(--muted);
}

.detail-content.hidden {
  display: none;
}

.detail-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}

.detail-stats div,
.detail-item {
  border-radius: 18px;
  border: 1px solid rgba(153, 111, 255, 0.14);
  background: var(--panel-soft);
}

.detail-stats div {
  padding: 18px;
}

.detail-stats span {
  display: block;
  color: var(--muted);
  margin-bottom: 8px;
}

.detail-stats strong {
  font-size: 1.6rem;
}

.detail-items {
  display: grid;
  gap: 12px;
}

.item-detail-dialog {
  width: min(980px, calc(100vw - 32px));
}

.item-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.game-title-block {
  cursor: pointer;
  min-width: 0;
}

.games-form-grid .apply-button {
  align-self: end;
  min-height: 56px;
  grid-column: auto;
  min-width: 180px;
}

.inventory-form-grid .apply-button {
  align-self: end;
  min-height: 56px;
  grid-column: span 2;
}

.admin-only.hidden {
  display: none;
}

.detail-item {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
}

.detail-item h3 {
  margin: 0 0 6px;
  font-size: 1.1rem;
}

.item-meta {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.item-value {
  color: var(--violet);
  font-size: 1.05rem;
  white-space: nowrap;
}

.wheel-panel {
  min-height: 280px;
}

.wheel-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.wheel-result {
  min-height: 160px;
}

@media (max-width: 980px) {
  .kpis,
  .detail-stats,
  .games-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .table-head,
  .platform-row {
    grid-template-columns: minmax(0, 1.8fr) 90px 110px minmax(150px, 1.2fr) 120px;
    gap: 12px;
  }

  .games-form-grid,
  .inventory-form-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .inventory-type-tabs {
    gap: 10px;
  }

  .todo-filter-toolbar,
  .single-filter-toolbar {
    grid-template-columns: 1fr;
  }

  .add-workflow-grid {
    grid-template-columns: 1fr;
  }

  .field-search,
  .field-platform,
  .field-genre,
  .inventory-search,
  .inventory-sort {
    grid-column: span 3;
  }

  .field-sort {
    grid-column: span 2;
  }

  .games-form-grid .apply-button {
    grid-column: span 1;
    min-width: 0;
  }

  .table-head.games-head,
  .games-row,
  .table-head.top-values-head,
  .top-values-row,
  .table-head.inventory-head,
  .inventory-row,
  .table-head.console-head,
  .console-row,
  .table-head.checklist-head,
  .checklist-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .score-row {
    grid-template-columns: 1fr 1fr;
  }

  .pager {
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  .page-shell {
    width: min(100% - 20px, 100%);
  }

  .panel {
    padding: 18px;
    border-radius: 22px;
  }

  .kpis,
  .detail-stats,
  .games-stat-grid,
  .games-form-grid,
  .inventory-form-grid {
    grid-template-columns: 1fr;
  }

  .add-search-grid,
  .add-new-grid {
    grid-template-columns: 1fr;
  }

  .photo-upload-actions {
    flex-direction: column;
  }

  .upload-action {
    width: 100%;
  }

  .camera-actions {
    flex-direction: column;
  }

  .camera-actions .nav-pill,
  .camera-actions .apply-button {
    width: 100%;
  }

  .inventory-type-tabs {
    justify-content: stretch;
  }

  .inventory-tab {
    flex: 1 1 100%;
  }

  .field-search,
  .field-platform,
  .field-genre,
  .field-sort,
  .inventory-search,
  .inventory-sort,
  .console-search-field,
  .games-form-grid .apply-button,
  .inventory-form-grid .apply-button {
    grid-column: span 1;
  }

  .panel-header {
    align-items: start;
    flex-direction: column;
  }

  .top-nav {
    justify-content: flex-start;
    align-items: stretch;
    flex-direction: column;
  }

  .todo-control-group {
    padding: 14px;
  }

  .segmented-tabs .todo-pill,
  .todo-primary-tabs .todo-pill {
    flex: 1 1 auto;
  }

  .price-automation-pager {
    width: 100%;
  }

  .nav-actions {
    margin-left: 0;
    justify-content: flex-end;
  }

  .table-head {
    display: none;
  }

  .platform-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "name name"
      "titles owned"
      "complete complete"
      "value value";
    gap: 14px 16px;
    border-radius: 18px;
    margin-bottom: 14px;
    border: 1px solid rgba(153, 111, 255, 0.14);
    padding: 20px 18px;
    background: linear-gradient(180deg, rgba(10, 10, 16, 0.98), rgba(7, 7, 12, 0.96));
  }

  .platform-row span {
    display: grid;
    gap: 6px;
    min-width: 0;
  }

  .platform-name {
    grid-area: name;
    font-size: 2rem;
    line-height: 1.08;
    color: var(--white-glow);
  }

  .titles,
  .owned,
  .value,
  .complete {
    color: var(--text);
  }

  .titles {
    grid-area: titles;
  }

  .owned {
    grid-area: owned;
  }

  .complete {
    grid-area: complete;
    gap: 10px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(14, 13, 22, 0.92);
    border: 1px solid rgba(153, 111, 255, 0.12);
  }

  .value {
    grid-area: value;
  }

  .titles::before,
  .owned::before,
  .complete::before,
  .value::before {
    font-family: "Trebuchet MS", sans-serif;
    font-size: 0.76rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--cyan);
  }

  .titles::before {
    content: "Titles";
  }

  .owned::before {
    content: "Owned Games";
  }

  .complete::before {
    content: "Completion";
  }

  .value::before {
    content: "Total Value";
  }

  .titles,
  .owned {
    font-size: 2rem;
    font-weight: 700;
    color: var(--violet);
  }

  .value {
    font-size: 1.9rem;
    font-weight: 700;
    color: #d794ff;
  }

  .bar-track {
    max-width: none;
    width: 100%;
    height: 18px;
  }

  .complete-text {
    font-size: 1.35rem;
    line-height: 1;
  }

  .detail-item {
    flex-direction: column;
  }

  .top-nav {
    flex-direction: column;
  }

  .game-row {
    gap: 12px;
    border-radius: 18px;
    margin-bottom: 14px;
    border: 1px solid rgba(153, 111, 255, 0.14);
    padding: 18px;
    background: linear-gradient(180deg, rgba(10, 10, 16, 0.98), rgba(7, 7, 12, 0.96));
  }

  .games-row,
  .console-row,
  .inventory-row,
  .checklist-row,
  .top-values-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .games-row {
    grid-template-areas:
      "title title"
      "owned genre"
      "beaten beaten"
      "value cost";
  }

  .console-row {
    grid-template-areas:
      "title title"
      "version status"
      "current current"
      "value cost";
  }

  .inventory-row {
    grid-template-areas:
      "title title"
      "platform platform"
      "status type"
      "value cost";
  }

  .checklist-row {
    grid-template-areas:
      "title title"
      "status rating"
      "actions actions";
  }

  .top-values-row {
    grid-template-areas:
      "title title"
      "value cost";
  }

  .game-title-block,
  .games-row .game-owned,
  .games-row .game-status,
  .games-row .game-rating,
  .games-row .game-value,
  .games-row .game-cost,
  .console-row .game-platform,
  .console-row .game-status,
  .console-row .game-rating,
  .console-row .game-value,
  .console-row .game-cost,
  .inventory-row .game-platform,
  .inventory-row .game-status,
  .inventory-row .game-rating,
  .inventory-row .game-value,
  .inventory-row .game-cost,
  .checklist-row .game-status,
  .checklist-row .game-rating,
  .checklist-row .game-actions,
  .top-values-row .game-value,
  .top-values-row .game-cost {
    min-width: 0;
  }

  .game-title-block {
    grid-area: title;
  }

  .games-row .game-owned {
    grid-area: owned;
  }

  .games-row .game-status {
    grid-area: genre;
  }

  .games-row .game-rating {
    grid-area: beaten;
  }

  .games-row .game-value,
  .top-values-row .game-value {
    grid-area: value;
  }

  .games-row .game-cost,
  .top-values-row .game-cost {
    grid-area: cost;
  }

  .console-row .game-platform {
    grid-area: version;
  }

  .console-row .game-status {
    grid-area: status;
  }

  .console-row .game-rating {
    grid-area: current;
  }

  .console-row .game-value {
    grid-area: value;
  }

  .console-row .game-cost {
    grid-area: cost;
  }

  .inventory-row .game-platform {
    grid-area: platform;
  }

  .inventory-row .game-status {
    grid-area: status;
  }

  .inventory-row .game-rating {
    grid-area: type;
  }

  .inventory-row .game-value {
    grid-area: value;
  }

  .inventory-row .game-cost {
    grid-area: cost;
  }

  .checklist-row > div:first-child {
    grid-area: title;
  }

  .checklist-row .game-status {
    grid-area: status;
  }

  .checklist-row .game-rating {
    grid-area: rating;
  }

  .checklist-row .game-actions {
    grid-area: actions;
  }

  .game-row [data-label],
  .checklist-row [data-label] {
    display: grid;
    gap: 6px;
    color: var(--text);
  }

  .game-row [data-label]::before,
  .checklist-row [data-label]::before {
    content: attr(data-label);
    font-family: "Trebuchet MS", sans-serif;
    font-size: 0.76rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--cyan);
  }

  .checklist-row .game-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }

  .editor-grid,
  .move-actions,
  .score-row {
    grid-template-columns: 1fr;
  }

  .pager-center {
    flex-direction: column;
  }
}
