
/* family-boardgames/app/static/css/00-base.css */
@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url("/static/fonts/manrope-cyrillic-ext.woff2") format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url("/static/fonts/manrope-cyrillic.woff2") format("woff2");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url("/static/fonts/manrope-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Noto Serif";
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url("/static/fonts/noto-serif-cyrillic-ext.woff2") format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Noto Serif";
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url("/static/fonts/noto-serif-cyrillic.woff2") format("woff2");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
  font-family: "Noto Serif";
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url("/static/fonts/noto-serif-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  color-scheme: light;
  --bg: #f6f0e8;
  --paper: #fffaf3;
  --paper-strong: #fffdf8;
  --ink: #2d241d;
  --muted: #76695f;
  --line: #e5d7c7;
  --accent: #8f4d2d;
  --accent-dark: #6f321b;
  --danger: #9d2d2d;
  --shadow: 0 20px 55px rgba(70, 45, 26, 0.14);
  --radius: 22px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Manrope", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 500;
  background:
    radial-gradient(circle at 15% 0%, rgba(207, 143, 85, 0.22), transparent 34rem),
    radial-gradient(circle at 90% 10%, rgba(126, 73, 38, 0.14), transparent 28rem),
    var(--bg);
  color: var(--ink);
}

button, input, textarea, select { font: inherit; }

button { cursor: pointer; }

a { color: var(--accent-dark); }

.hero {
  max-width: 1180px;
  margin: 0 auto;
  padding: 42px 22px 24px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 22px;
  align-items: stretch;
}

h1, h2, h3, p { margin-top: 0; }

h1 {
  margin-bottom: 12px;
  font-family: "Noto Serif", Georgia, serif;
  font-size: clamp(2.5rem, 5.3vw, 5.2rem);
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: 0;
}

h2 { margin-bottom: 8px; font-size: clamp(1.25rem, 2.5vw, 1.7rem); }

h3 { margin-bottom: 8px; }

.hero-text {
  max-width: 620px;
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.55;
}

.eyebrow {
  margin-bottom: 10px;
  color: var(--accent-dark);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.muted { color: var(--muted); font-size: 0.95rem; }

.login-card, .panel, .toolbar, .empty, .modal-card {
  border: 1px solid rgba(229, 215, 199, 0.82);
  background: rgba(255, 250, 243, 0.86);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
}

.login-card {
  padding: 18px;
  align-self: center;
}

.login-card label {
  display: block;
  margin-bottom: 9px;
  font-weight: 800;
}

.login-row {
  display: flex;
  gap: 12px;
  align-items: stretch;
}

.login-row input { min-width: 0; }

.login-card > .button {
  margin-top: 10px;
}

.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px 64px;
}

.tabs {
  max-width: 1180px;
  margin: 0 auto 18px;
  padding: 0 22px;
  display: flex;
  gap: 10px;
}

.tab {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 11px 18px;
  background: rgba(255, 250, 243, 0.72);
  color: var(--muted);
  font-weight: 800;
  box-shadow: 0 0 0 rgba(70, 45, 26, 0);
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease, color .16s ease;
}

.tab:hover:not(.active),
.tab:focus-visible:not(.active) {
  transform: translateY(-2px);
  border-color: rgba(143, 77, 45, 0.38);
  background: rgba(255, 252, 247, 0.94);
  color: var(--accent-dark);
  box-shadow: 0 10px 20px rgba(70, 45, 26, 0.1);
}

.tab.active {
  background: var(--ink);
  border-color: var(--ink);
  color: #fffaf3;
}

.tab-panel { display: none; }
.tab-panel.active { display: block; }

.panel {
  padding: 22px;
  margin-bottom: 20px;
}

.add-panel {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(260px, 1.1fr);
  gap: 18px;
  align-items: start;
}

.add-form {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.add-form input {
  flex: 1 1 0;
  width: auto;
}

.add-form .button {
  flex: 0 0 auto;
}

input, textarea, select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 13px;
  background: var(--paper-strong);
  color: var(--ink);
  outline: none;
}

textarea { resize: vertical; }

input:focus, textarea:focus, select:focus {
  border-color: rgba(143, 77, 45, 0.62);
  box-shadow: 0 0 0 4px rgba(143, 77, 45, 0.12);
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  min-height: 46px;
  background: var(--accent);
  color: white;
  font-weight: 850;
  line-height: 1.15;
  transition: transform .14s ease, background .14s ease, opacity .14s ease;
}

.button:hover { transform: translateY(-1px); background: var(--accent-dark); }
.button:disabled { cursor: not-allowed; opacity: 0.55; transform: none; }

.button.secondary {
  border: 1px solid var(--line);
  background: var(--paper-strong);
  color: var(--ink);
}

.button.secondary:hover { background: #f5eadf; }

.admin-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 16px;
}

.edit-mode-button {
  background: linear-gradient(180deg, #6f9b65 0%, #5f8a66 100%);
  box-shadow: 0 10px 18px rgba(95, 138, 102, 0.2);
}

.edit-mode-button:hover {
  background: linear-gradient(180deg, #638f5b 0%, #527b5b 100%);
  box-shadow: 0 12px 22px rgba(95, 138, 102, 0.26);
}

body.is-editing #logoutButton {
  display: none;
}

.button.danger { background: var(--danger); }
.button.danger:hover { background: #7f2020; }

.manual-add {
  grid-column: 1 / -1;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.manual-add summary {
  cursor: pointer;
  font-weight: 850;
  color: var(--accent-dark);
}

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

#preorderForm {
  grid-column: 1 / -1;
}

.form-grid.compact { margin-top: 14px; }

.form-grid label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.92rem;
  font-weight: 800;
}

.form-grid label > input,
.form-grid label > textarea,
.form-grid label > select {
  color: var(--ink);
  font-weight: 500;
}

.image-upload-field input[type="file"] {
  padding: 10px;
  border: 1px dashed rgba(113, 72, 45, 0.34);
  background: rgba(255, 250, 243, 0.76);
}

.image-upload-title {
  display: block;
}

.image-current-file {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 42px;
  padding: 8px 10px 8px 12px;
  border: 1px solid rgba(113, 72, 45, 0.22);
  border-radius: 12px;
  background: rgba(255, 252, 247, 0.84);
  color: var(--ink);
  font-weight: 600;
}

.image-current-file.hidden {
  display: none;
}

.image-upload-field.is-marked-remove .image-current-file {
  color: var(--muted);
  border-style: dashed;
  opacity: 0.72;
}

.image-remove-button {
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 999px;
  background: #f1e4d6;
  color: var(--accent);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
}

.image-remove-button:hover {
  background: #ead6c4;
}

body:not(.is-editing) .game-detail-edit-form .image-remove-button {
  display: none;
}

.bgg-upload-field {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.92rem;
  font-weight: 800;
}

.bgg-upload-field input[type="file"] {
  padding: 10px;
  border: 1px dashed rgba(113, 72, 45, 0.34);
  background: rgba(255, 250, 243, 0.76);
}

.wide { grid-column: 1 / -1; }

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

.toolbar h2 { margin-bottom: 4px; }

.sort-controls {
  display: flex;
  gap: 12px;
  align-items: end;
}

.sort-controls:empty { display: none; }

.sort-controls label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-weight: 800;
  font-size: 0.78rem;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 18px;
}

.game-card, .preorder-card {
  position: relative;
  overflow: visible;
  min-height: 0;
  border: 1px solid rgba(229, 215, 199, 0.9);
  border-radius: 24px;
  background: var(--paper);
  box-shadow: 0 10px 24px rgba(70, 45, 26, 0.08);
  transition: transform .16s ease, box-shadow .16s ease;
}

.game-card:hover, .preorder-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(70, 45, 26, 0.12);
}

.card-button {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  border-radius: inherit;
  overflow: hidden;
  background: transparent;
  text-align: left;
  color: inherit;
}


.card-menu {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 8;
}

.card-menu-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(229, 215, 199, 0.92);
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.88);
  color: var(--muted);
  box-shadow: 0 8px 20px rgba(70, 45, 26, 0.12);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
}

.card-menu-trigger:hover {
  background: var(--paper-strong);
  color: var(--ink);
}

.card-menu-popover {
  position: absolute;
  top: 42px;
  right: 0;
  z-index: 10;
  min-width: 170px;
  display: grid;
  gap: 4px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: var(--paper-strong);
  box-shadow: 0 16px 36px rgba(70, 45, 26, 0.18);
}

.card-menu-popover button {
  width: 100%;
  border: 0;
  border-radius: 11px;
  padding: 10px 11px;
  background: transparent;
  color: var(--ink);
  text-align: left;
  font-weight: 800;
}

.card-menu-popover button:hover {
  background: #f5eadf;
}

.card-menu-popover .danger-text {
  color: var(--danger);
}

.cover {
  width: 100%;
  height: 170px;
  background: linear-gradient(135deg, #d6b08c, #876149);
  display: grid;
  place-items: center;
  color: rgba(255,255,255,.9);
  font-size: 0.95rem;
  font-weight: 900;
}

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

.cover img.placeholder-cover {
  object-fit: cover;
}

.card-content { padding: 14px; }

.card-content h3 {
  min-height: 48px;
  font-size: 1.05rem;
  line-height: 1.25;
}

.badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0;
}

.badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 9px;
  background: #fffdf8;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 850;
}

.badge.strong { color: var(--accent-dark); }

.card-meta {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  color: var(--muted);
  font-size: 0.76rem;
}

.empty {
  padding: 28px;
  text-align: center;
  color: var(--muted);
}

.modal {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(45, 36, 29, 0.42);
}

.modal.hidden { display: none; }

.modal-card {
  width: min(880px, 100%);
  max-height: min(90vh, 980px);
  overflow: auto;
  padding: 24px;
  position: relative;
  background: var(--paper);
}

.icon-button {
  border: 0;
  border-radius: 50%;
  background: #f4e7d8;
  color: var(--ink);
  width: 40px;
  height: 40px;
  font-size: 1.3rem;
  line-height: 1;
}

.close-modal {
  position: absolute;
  right: 18px;
  top: 18px;
}

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

.upload-row input { padding: 10px; }
.upload-row .button { margin-top: 4px; }

.toast {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 40;
  max-width: min(460px, calc(100vw - 36px));
  border-radius: 18px;
  padding: 14px 16px;
  background: var(--ink);
  color: #fffaf3;
  box-shadow: var(--shadow);
  font-weight: 750;
}

.hidden { display: none !important; }

.preorder-card { min-height: 250px; }
.preorder-card .cover { height: 130px; }

.payment-list {
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.86rem;
}

body:not(.is-editing) .admin-only {
  display: none !important;
}

@media (max-width: 820px) {
  .hero { grid-template-columns: 1fr; padding-top: 28px; }
  .add-panel { grid-template-columns: 1fr; }
  .add-form { flex-direction: column; }
  .toolbar { align-items: stretch; flex-direction: column; }
  .sort-controls { flex-direction: column; align-items: stretch; }
  .form-grid { grid-template-columns: 1fr; }
  .wide { grid-column: auto; }
  .login-row { flex-direction: column; }
}

.mode-control {
  min-width: 190px;
}

.toggle-line {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px 13px;
  background: var(--paper-strong);
  color: var(--ink);
  font-weight: 800;
}

.toggle-line input {
  width: auto;
  margin: 0;
}

.compact-muted {
  margin: 4px 0 0;
  font-size: 0.86rem;
  line-height: 1.35;
}

.small-button {
  padding: 9px 12px;
  white-space: nowrap;
  width: 100%;
  justify-content: flex-start;
  overflow: hidden;
}

.payment-schedule-box {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  background: rgba(255, 253, 248, 0.72);
}

.payment-box-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
  margin-bottom: 12px;
  color: var(--muted);
}

.payment-box-header strong {
  display: block;
  color: var(--muted);
  font-size: 0.92rem;
}

.payment-rows {
  display: grid;
  gap: 10px;
}

.payment-row {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) minmax(130px, 1fr) 42px;
  gap: 10px;
  align-items: end;
}

.payment-row label {
  margin: 0;
}

.payment-remove {
  width: 42px;
  height: 42px;
  align-self: end;
  background: #f5eadf;
}

.payments-empty {
  border: 1px dashed var(--line);
  border-radius: 14px;
  padding: 14px;
  color: var(--muted);
  text-align: center;
  background: rgba(255, 250, 243, 0.55);
}

.payment-plan {
  margin-bottom: 20px;
}

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

.payment-plan-header h2 {
  margin-bottom: 0;
}

.table-wrap {
  overflow-x: auto;
}

.payment-plan-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 620px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--paper-strong);
}

.payment-plan-table th,
.payment-plan-table td {
  padding: 12px 13px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

.payment-plan-table th {
  color: var(--muted);
  font-size: 0.86rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: rgba(245, 234, 223, 0.75);
}

.payment-plan-table tr:last-child td {
  border-bottom: 0;
}

.overdue-row td {
  background: rgba(157, 45, 45, 0.07);
}

.overdue-mark {
  display: inline-block;
  margin-left: 8px;
  border-radius: 999px;
  padding: 3px 7px;
  background: rgba(157, 45, 45, 0.12);
  color: var(--danger);
  font-size: 0.72rem;
  font-weight: 850;
}

@media (max-width: 820px) {
  .payment-box-header,
  .payment-plan-header {
    flex-direction: column;
    align-items: stretch;
  }

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

  .payment-remove {
    width: 100%;
    border-radius: 14px;
  }
}

.payment-status-select {
  min-width: 150px;
  padding: 9px 11px;
  border-radius: 12px;
}

.paid-history-row td {
  background: rgba(87, 126, 74, 0.07);
}

.paid-mark {
  display: inline-block;
  margin-left: 8px;
  border-radius: 999px;
  padding: 3px 7px;
  background: rgba(87, 126, 74, 0.13);
  color: #3f6b37;
  font-size: 0.72rem;
  font-weight: 850;
}

/* family-boardgames/app/static/css/10-mobile.css */
/* Mobile stability and overflow fixes */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

button,
input,
textarea,
select {
  min-width: 0;
  max-width: 100%;
}

img,
svg {
  max-width: 100%;
}

.hero,
.container,
.tabs,
.panel,
.toolbar,
.empty,
.login-card,
.add-panel,
.add-panel > *,
.add-form,
.form-grid,
.sort-controls,
.grid,
.payment-schedule-box,
.payment-plan,
.payment-plan-header,
.table-wrap,
.modal-card {
  min-width: 0;
}

.hero-text,
.muted,
.panel,
.manual-add,
.card-content,
.payment-schedule-box,
.payment-plan-table td,
.payment-plan-table th {
  overflow-wrap: anywhere;
  word-break: normal;
}

@media (hover: none) and (pointer: coarse) {
  .game-card,
  .preorder-card,
  .button {
    transition: none;
  }

  .game-card:hover,
  .preorder-card:hover,
  .button:hover {
    transform: none;
  }
}

@media (max-width: 820px) {
  body {
    background: var(--bg);
  }

  .hero {
    max-width: 100%;
    padding: 24px 14px 18px;
    gap: 18px;
  }

  .container {
    max-width: 100%;
    padding: 0 14px 44px;
  }

  .tabs {
    max-width: 100%;
    padding: 0 14px;
    flex-wrap: wrap;
  }

  .tab {
    padding: 10px 16px;
  }

  .login-card,
  .panel,
  .toolbar,
  .empty,
  .modal-card {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 9px 24px rgba(70, 45, 26, 0.10);
  }

  .panel,
  .toolbar {
    padding: 18px;
    border-radius: 20px;
  }

  .add-panel {
    overflow: hidden;
  }

  .add-form {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
  }

  .add-form input,
  .add-form .button {
    width: 100%;
  }

  .button {
    white-space: normal;
  }

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

  .game-card,
  .preorder-card {
    min-height: auto;
    box-shadow: 0 8px 22px rgba(70, 45, 26, 0.10);
    transition: none;
  }

  .cover {
    height: 178px;
  }

  .preorder-card .cover {
    height: 126px;
  }

  .card-content h3 {
    min-height: 0;
  }

  .modal {
    padding: 10px;
  }

  .modal-card {
    width: 100%;
    max-height: calc(100svh - 20px);
    padding: 18px;
  }

  .close-modal {
    right: 12px;
    top: 12px;
  }

  .payment-plan-table {
    min-width: 560px;
  }
}

@media (max-width: 430px) {
  .hero {
    padding-left: 12px;
    padding-right: 12px;
  }

  .container,
  .tabs {
    padding-left: 12px;
    padding-right: 12px;
  }

  .panel,
  .toolbar,
  .login-card,
  .empty {
    border-radius: 18px;
  }
}



/* family-boardgames/app/static/css/20-legacy-responsive-updates.css */
/* Update 5: stronger mobile overflow and scroll-performance fixes */
html {
  width: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  width: 100%;
  overflow-x: clip;
}

@supports not (overflow: clip) {
  body { overflow-x: hidden; }
}

/* На узких и средних экранах не держим две колонки в блоке добавления:
   именно это на телефонах часто создаёт огромную ширину страницы. */

@media (max-width: 1200px) {
  .grid {
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  }
}

@media (max-width: 1100px) {
  .hero {
    grid-template-columns: 1fr;
  }

  .add-panel {
    grid-template-columns: minmax(0, 1fr);
  }

  .add-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
  }

  .add-form input,
  .add-form .button {
    width: 100%;
    min-width: 0;
  }

  .login-card,
  .panel,
  .toolbar,
  .empty,
  .modal-card {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}

@media (max-width: 820px) {
  :root {
    --shadow: 0 6px 16px rgba(70, 45, 26, 0.08);
  }

  body {
    background: var(--bg) !important;
  }

  .hero,
  .tabs,
  .container {
    width: 100%;
    max-width: 100%;
  }

  .panel,
  .toolbar,
  .login-card,
  .empty {
    box-shadow: 0 5px 14px rgba(70, 45, 26, 0.07) !important;
  }

  .game-card,
  .preorder-card {
    box-shadow: 0 5px 14px rgba(70, 45, 26, 0.07) !important;
    contain: layout paint;
    content-visibility: auto;
    contain-intrinsic-size: 320px;
  }

  .cover img {
    transform: translateZ(0);
    backface-visibility: hidden;
  }

  input,
  textarea,
  select,
  .button {
    font-size: 16px;
  }
}


/* Update 7: small typography and spacing refinements */
h1 {
  letter-spacing: 0.006em;
  line-height: 1.04;
}

.login-card .muted {
  margin: 12px 0 0;
  line-height: 1.35;
}

@media (max-width: 820px) {
  h1 {
    letter-spacing: 0.004em;
    line-height: 1.06;
  }

  .login-card .muted {
    margin-top: 14px;
  }
}

/* Update 8: lighter cards, cleaner missing data, lighter buttons */
:root {
  --shadow: 0 10px 28px rgba(70, 45, 26, 0.08);
}

.login-card,
.panel,
.toolbar,
.empty,
.modal-card {
  box-shadow: 0 10px 26px rgba(70, 45, 26, 0.08);
}

.game-card,
.preorder-card {
  box-shadow: 0 6px 18px rgba(70, 45, 26, 0.07);
}

.game-card:hover,
.preorder-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(70, 45, 26, 0.09);
}

.card-menu-trigger {
  box-shadow: 0 4px 10px rgba(70, 45, 26, 0.09);
}

.card-menu-popover {
  box-shadow: 0 10px 24px rgba(70, 45, 26, 0.12);
}

.toast {
  box-shadow: 0 8px 18px rgba(70, 45, 26, 0.12);
}

.button,
.tab,
.card-menu-popover button,
.manual-add summary,
.toggle-line,
.badge {
  font-weight: 700;
}

.button {
  letter-spacing: 0.005em;
}

.card-content h3 {
  min-height: 0;
}

.card-meta:empty,
.badges:empty {
  display: none;
}

@media (max-width: 820px) {
  .login-card,
  .panel,
  .toolbar,
  .empty,
  .modal-card,
  .game-card,
  .preorder-card {
    box-shadow: 0 4px 12px rgba(70, 45, 26, 0.06) !important;
  }
}

/* Update 8: cleaner empty fields, lighter buttons, softer shadows */
:root {
  --shadow: 0 8px 22px rgba(70, 45, 26, 0.08);
}

.login-card,
.panel,
.toolbar,
.empty,
.modal-card {
  box-shadow: var(--shadow);
}

.game-card,
.preorder-card {
  box-shadow: 0 6px 18px rgba(70, 45, 26, 0.075);
}

.game-card:hover,
.preorder-card:hover {
  box-shadow: 0 9px 22px rgba(70, 45, 26, 0.105);
}

.card-menu-trigger {
  box-shadow: 0 5px 12px rgba(70, 45, 26, 0.08);
}

.card-menu-popover {
  box-shadow: 0 9px 20px rgba(70, 45, 26, 0.12);
}

.toast {
  box-shadow: 0 8px 22px rgba(70, 45, 26, 0.13);
}

.button {
  font-weight: 700;
  letter-spacing: 0;
}

.tab,
.manual-add summary,
.card-menu-popover button,
.badge,
.form-grid label,
.sort-controls label,
.login-card label {
  font-weight: 700;
}

.eyebrow {
  font-weight: 700;
}

@media (max-width: 820px) {
  :root {
    --shadow: 0 4px 12px rgba(70, 45, 26, 0.06);
  }

  .panel,
  .toolbar,
  .login-card,
  .empty {
    box-shadow: 0 4px 12px rgba(70, 45, 26, 0.055) !important;
  }

  .game-card,
  .preorder-card {
    box-shadow: 0 4px 12px rgba(70, 45, 26, 0.055) !important;
  }

  .card-menu-trigger {
    box-shadow: 0 4px 10px rgba(70, 45, 26, 0.06);
  }
}

/* Update 8: calmer cards, lighter buttons, custom placeholder and favicon support */
:root {
  --shadow: 0 10px 28px rgba(70, 45, 26, 0.08);
}

.login-card,
.panel,
.toolbar,
.empty,
.modal-card {
  box-shadow: var(--shadow);
}

.login-card .muted {
  margin-top: 18px;
}

.button,
.tab,
.card-menu-popover button {
  font-weight: 700;
}

.badge {
  font-weight: 700;
}

.game-card,
.preorder-card {
  box-shadow: 0 7px 18px rgba(70, 45, 26, 0.075);
}

.game-card:hover,
.preorder-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 9px 24px rgba(70, 45, 26, 0.10);
}

.card-menu-trigger {
  box-shadow: 0 3px 10px rgba(70, 45, 26, 0.08);
}

.card-menu-popover {
  box-shadow: 0 8px 22px rgba(70, 45, 26, 0.11);
}

.cover {
  background: #ead5bc;
}

.card-meta:empty,
.badges:empty {
  display: none;
}

@media (max-width: 820px) {
  :root {
    --shadow: 0 4px 12px rgba(70, 45, 26, 0.055);
  }

  .login-card .muted {
    margin-top: 18px;
  }

  .login-card,
  .panel,
  .toolbar,
  .empty,
  .modal-card {
    box-shadow: 0 4px 12px rgba(70, 45, 26, 0.055) !important;
  }

  .game-card,
  .preorder-card {
    box-shadow: 0 4px 12px rgba(70, 45, 26, 0.055) !important;
  }

  .card-menu-trigger,
  .card-menu-popover {
    box-shadow: 0 3px 9px rgba(70, 45, 26, 0.07) !important;
  }
}


/* Update 8: cleaner cards, lighter shadows, custom placeholder/favicon polish */
:root {
  --shadow: 0 10px 26px rgba(70, 45, 26, 0.08);
}

.login-card,
.panel,
.toolbar,
.empty,
.modal-card {
  box-shadow: var(--shadow);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.game-card,
.preorder-card {
  box-shadow: 0 7px 18px rgba(70, 45, 26, 0.075);
}

.game-card:hover,
.preorder-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(70, 45, 26, 0.10);
}

.card-menu-button {
  box-shadow: 0 4px 10px rgba(70, 45, 26, 0.08);
}

.card-menu-panel {
  box-shadow: 0 10px 22px rgba(70, 45, 26, 0.12);
}

h1 {
  letter-spacing: 0.014em;
}

.button,
.tab {
  font-weight: 700;
}

.badge {
  font-weight: 720;
}

.login-card #adminState {
  margin-top: 24px;
}

.login-card.admin-logged-in #adminState {
  margin-top: 22px;
}

.card-meta {
  justify-content: flex-start;
}

.card-meta span + span::before {
  content: "·";
  margin: 0 8px 0 0;
  color: var(--line);
}

@media (max-width: 820px) {
  h1 {
    letter-spacing: 0.01em;
  }

  .login-card #adminState {
    margin-top: 20px;
  }

  .game-card,
  .preorder-card,
  .panel,
  .toolbar,
  .login-card,
  .empty,
  .modal-card {
    box-shadow: 0 4px 12px rgba(70, 45, 26, 0.055) !important;
  }
}

/* Update 8.1: match current card menu class names */
body:not(.is-admin) .card-menu {
  display: none;
}

.card-menu-trigger {
  box-shadow: 0 4px 10px rgba(70, 45, 26, 0.08);
  font-weight: 700;
}

.card-menu-popover {
  box-shadow: 0 10px 22px rgba(70, 45, 26, 0.12);
}

.card-menu-popover button {
  font-weight: 700;
}

@media (max-width: 820px) {
  .grid,
  .game-card,
  .preorder-card,
  .card-button,
  .cover,
  .card-content {
    touch-action: pan-y;
  }
}

/* Update 9: remove placeholder image, fix mobile scroll jump, make shadows calmer */
:root {
  --shadow: 0 7px 18px rgba(70, 45, 26, 0.055);
}

.login-card,
.panel,
.toolbar,
.empty,
.modal-card {
  box-shadow: var(--shadow) !important;
}

.game-card,
.preorder-card {
  box-shadow: 0 4px 12px rgba(70, 45, 26, 0.052) !important;
  content-visibility: visible !important;
  contain: none !important;
  contain-intrinsic-size: auto !important;
}

.game-card:hover,
.preorder-card:hover {
  transform: none;
  box-shadow: 0 5px 14px rgba(70, 45, 26, 0.065) !important;
}

.cover.no-cover {
  background: linear-gradient(135deg, #c9a17e, #9b7054);
  color: rgba(255, 250, 243, 0.94);
}

.cover.no-cover span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  font-weight: 700;
  letter-spacing: 0;
}

.cover img {
  transform: none !important;
  backface-visibility: visible !important;
}

.card-button {
  touch-action: pan-y pinch-zoom;
}

button,
select,
input,
textarea,
.card-menu-trigger,
.card-menu-popover button {
  touch-action: manipulation;
}

@media (max-width: 820px) {
  :root {
    --shadow: 0 3px 9px rgba(70, 45, 26, 0.045);
  }

  body {
    overscroll-behavior-y: auto;
  }

  .game-card,
  .preorder-card,
  .panel,
  .toolbar,
  .login-card,
  .empty,
  .modal-card {
    box-shadow: 0 3px 9px rgba(70, 45, 26, 0.045) !important;
  }

  .card-menu-trigger,
  .card-menu-popover {
    box-shadow: 0 2px 7px rgba(70, 45, 26, 0.055) !important;
  }

  .cover.no-cover {
    background: linear-gradient(135deg, #c9a17e, #9b7054);
  }
}

/* Update 9.1: final mobile stability overrides and text placeholder class */
html,
body {
  overflow-x: hidden !important;
}

.cover.no-photo {
  background: linear-gradient(135deg, #c9a17e, #9b7054);
  color: rgba(255, 250, 243, 0.94);
  text-align: center;
}

.cover.no-photo span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 9px;
  min-height: 32px;
  font-weight: 700;
  letter-spacing: 0;
}

.game-card,
.preorder-card {
  contain: none !important;
  content-visibility: visible !important;
  contain-intrinsic-size: auto !important;
}

.cover img {
  transform: none !important;
  backface-visibility: visible !important;
}

@media (max-width: 820px) {
  .game-card,
  .preorder-card {
    contain: none !important;
    content-visibility: visible !important;
    contain-intrinsic-size: auto !important;
  }
}


/* Update 10: denser mobile cards, no upload UI, no year on game cards */
.upload-row {
  display: none !important;
}

.card-meta:empty {
  display: none !important;
}

@media (max-width: 820px) {
  .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .game-card,
  .preorder-card {
    border-radius: 18px;
  }

  .cover {
    height: 118px;
    font-size: 0.86rem;
  }

  .preorder-card .cover {
    height: 108px;
  }

  .card-content {
    padding: 10px;
  }

  .card-content h3 {
    font-size: 0.92rem;
    line-height: 1.2;
    margin-bottom: 7px;
  }

  .badges {
    gap: 5px;
    margin: 8px 0 0;
  }

  .badge {
    padding: 5px 7px;
    font-size: 0.72rem;
    line-height: 1.1;
    max-width: 100%;
  }

  .card-meta {
    margin-top: 8px;
    font-size: 0.74rem;
    line-height: 1.25;
  }

  .card-menu {
    top: 8px;
    right: 8px;
  }

  .card-menu-trigger {
    width: 31px;
    height: 31px;
    font-size: 0.92rem;
  }

  .card-menu-popover {
    top: 37px;
    min-width: 145px;
  }

  .card-menu-popover button {
    padding: 9px 10px;
    font-size: 0.76rem;
  }
}

@media (max-width: 360px) {
  .grid {
    gap: 8px;
  }

  .card-content {
    padding: 9px;
  }

  .cover {
    height: 104px;
  }

  .badge {
    font-size: 0.68rem;
    padding: 5px 6px;
  }
}

/* family-boardgames/app/static/css/30-game-type-and-card-layout.css */
/* Update 11: expansions toggle and flexible playing time field */
.addon-inline,
.addon-toggle,
.checkbox-field {
  user-select: none;
}

.addon-inline {
  flex: 0 0 auto;
  min-width: 142px;
  justify-content: center;
}

.addon-toggle {
  min-width: 150px;
  align-self: end;
}

.checkbox-field {
  display: inline-flex !important;
  grid-template-columns: none !important;
  align-items: center;
  justify-content: flex-start;
  gap: 9px !important;
  min-height: 46px;
  padding: 12px 13px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--paper-strong);
  color: var(--ink) !important;
  font-weight: 700 !important;
}

.checkbox-field input,
.addon-inline input,
.addon-toggle input {
  width: auto !important;
  min-width: auto !important;
  max-width: none !important;
  margin: 0;
  flex: 0 0 auto;
}

.addon-badge {
  color: var(--accent-dark);
  background: #f6eadc;
}

@media (max-width: 1100px) {
  .addon-inline {
    width: 100%;
    justify-content: flex-start;
  }
}

@media (max-width: 820px) {
  .addon-toggle {
    width: 100%;
    min-width: 0;
  }
}

/* Update 12: cleaner expansion selectors and safer 2-column mobile cards */
.add-form .inline-select,
.inline-select {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.add-form .add-type-select {
  flex: 0 0 170px;
  min-width: 150px;
}

.add-form .add-type-select select {
  width: 100%;
}

.addon-inline,
.addon-toggle,
.checkbox-field {
  display: none !important;
}

.cover {
  overflow: hidden !important;
}

.cover img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  background: #fffdf8 !important;
}

@media (max-width: 1100px) {
  .add-form .add-type-select {
    width: 100%;
    min-width: 0;
    flex: 1 1 auto;
  }
}

@media (max-width: 820px) {
  .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    align-items: start !important;
  }

  .game-card,
  .preorder-card {
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .card-button {
    height: auto !important;
    min-height: 100% !important;
    overflow: hidden !important;
  }

  .cover,
  .preorder-card .cover {
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
  }

  .cover img {
    object-fit: contain !important;
    padding: 4px !important;
  }

  .card-content {
    padding: 9px !important;
  }

  .card-content h3 {
    font-size: 0.9rem !important;
    line-height: 1.18 !important;
    margin: 0 0 7px !important;
    min-height: 0 !important;
    word-break: break-word;
  }

  .badge {
    font-size: 0.68rem !important;
    padding: 5px 6px !important;
  }
}

@media (max-width: 360px) {
  .cover,
  .preorder-card .cover {
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
  }
}

/* Update 12: expansion selects and safer mobile card layout */
.inline-select {
  flex: 0 0 170px;
  width: 170px;
}

.add-form select,
.sort-controls select,
.form-grid select {
  min-width: 0;
}

/* Старые чекбоксы больше не используются, но оставляем обычное поведение для случайных checkbox внутри форм. */
.checkbox-field,
.addon-toggle,
.addon-inline {
  display: grid !important;
}

.card-button {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.cover {
  overflow: hidden;
  flex: 0 0 auto;
  border-bottom: 1px solid rgba(229, 215, 199, 0.76);
}

.cover img {
  object-fit: contain;
  background: var(--paper-strong);
}

.card-content {
  position: relative;
  z-index: 1;
  flex: 1 1 auto;
  background: var(--paper);
}

.game-card,
.preorder-card {
  overflow: visible;
}

.game-card .card-button,
.preorder-card .card-button {
  overflow: hidden;
}

@media (max-width: 1100px) {
  .inline-select {
    width: 100%;
    flex: 1 1 auto;
  }
}

@media (max-width: 820px) {
  .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px;
    align-items: start;
  }

  .game-card,
  .preorder-card {
    min-width: 0;
    min-height: 0;
    border-radius: 18px;
  }

  .cover,
  .preorder-card .cover {
    width: 100%;
    height: auto !important;
    aspect-ratio: 1 / 0.72;
  }

  .cover.no-photo {
    aspect-ratio: 1 / 0.72;
  }

  .cover img {
    width: 100%;
    height: 100%;
    object-fit: contain !important;
  }

  .card-content {
    padding: 10px 9px 11px;
  }

  .card-content h3 {
    display: block;
    margin: 0 0 8px;
    font-size: 0.86rem;
    line-height: 1.18;
    overflow-wrap: anywhere;
  }

  .badges {
    gap: 5px;
    margin: 0;
  }

  .badge {
    padding: 5px 7px;
    font-size: 0.68rem;
    line-height: 1.05;
  }

  .card-meta {
    margin-top: 7px;
    font-size: 0.72rem;
  }

  .card-menu {
    top: 7px;
    right: 7px;
  }

  .card-menu-trigger {
    width: 30px;
    height: 30px;
  }
}

@media (max-width: 360px) {
  .grid {
    gap: 9px;
  }

  .card-content {
    padding: 9px 8px 10px;
  }

  .badge {
    font-size: 0.64rem;
    padding: 4px 6px;
  }
}


/* family-boardgames/app/static/css/40-showcase-cards-and-filters.css */
/* ===== Update 16: refined showcase game card ===== */
:root {
  --card-accent: #d98249;
  --card-accent-dark: #b96a38;
  --soft-shadow: 0 10px 22px rgba(70, 45, 26, 0.08);
}

.game-card.showcase-card {
  overflow: hidden;
  background: rgba(255, 252, 247, 0.95);
  box-shadow: var(--soft-shadow);
  border: 1px solid rgba(229, 215, 199, 0.92);
}

.game-card.showcase-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 26px rgba(70, 45, 26, 0.10);
}

.game-card.showcase-card .card-button {
  display: block;
  width: 100%;
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  text-align: left;
}

.game-card.showcase-card .cover {
  height: 170px;
  margin: 0;
  border-radius: 26px 26px 0 0;
  overflow: hidden;
  background: #c09370;
}

.game-card.showcase-card .cover.no-photo {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #b88e6d;
}

.game-card.showcase-card .cover.no-photo span {
  color: #fffaf3;
  font-size: 1.05rem;
  font-weight: 800;
}

.game-card.showcase-card .cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.game-card.showcase-card .showcase-content {
  padding: 12px 14px 14px;
}

.game-card.showcase-card .showcase-title {
  margin: 0 0 10px;
  font-family: "Noto Serif", Georgia, serif;
  font-size: clamp(0.92rem, 0.95vw, 1.18rem);
  line-height: 1.06;
  letter-spacing: 0;
  font-weight: 600;
  overflow-wrap: anywhere;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.12em;
}

.game-card.showcase-card .showcase-type {
  display: inline-flex;
  margin: -2px 0 10px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(143, 77, 45, 0.18);
  background: rgba(143, 77, 45, 0.08);
  color: var(--accent-dark);
  font-size: 0.76rem;
  font-weight: 800;
}

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

.metric-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  min-height: 32px;
  padding: 0 9px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 252, 247, 0.98);
  color: var(--muted);
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
  white-space: nowrap;
  width: 100%;
  justify-content: flex-start;
  overflow: hidden;
}

.metric-pill.accent {
  background: linear-gradient(180deg, #db874f 0%, #cf7a43 100%);
  border-color: transparent;
  color: #fffaf3;
  box-shadow: 0 8px 16px rgba(207, 122, 67, 0.18);
}

.metric-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
}

.metric-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.metric-label,
.metric-value {
  line-height: 1;
  font-size: 0.72rem;
}

.metric-pill .metric-label:empty {
  display: none;
}

.metric-pill .metric-value {
  color: currentColor;
  font-size: 0.78rem;
  font-weight: 800;
}

.metric-pill .metric-label:not(:empty) + .metric-value::before {
  content: ' ';
}

.game-card.showcase-card .card-menu {
  top: 14px;
  right: 14px;
}

.game-card.showcase-card .card-menu-trigger {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: rgba(255, 250, 243, 0.97);
  border: 1px solid rgba(229, 215, 199, 0.95);
  color: #6e5748;
  box-shadow: 0 8px 16px rgba(70, 45, 26, 0.12);
  font-size: 1.3rem;
  line-height: 1;
}

@media (max-width: 1100px) {
  .game-card.showcase-card .cover {
    height: 170px;
  }

  .game-card.showcase-card .showcase-content {
    padding: 13px 14px 15px;
  }

  .game-card.showcase-card .showcase-title {
    font-size: clamp(0.9rem, 1.2vw, 1.08rem);
  }
}

@media (max-width: 900px) {
  .game-card.showcase-card .cover {
    height: 170px;
  }

  .metrics-grid {
    gap: 8px;
  }

  .metric-pill {
    min-height: 32px;
    padding: 0 9px;
    gap: 6px;
  }

  .metric-icon {
    width: 16px;
    height: 16px;
    flex-basis: 16px;
  }

  .metric-pill .metric-label,
  .metric-pill .metric-value {
    font-size: 0.7rem;
  }

  .metric-pill .metric-value {
    font-size: 0.76rem;
  }

  .game-card.showcase-card .card-menu-trigger {
    width: 42px;
    height: 42px;
    font-size: 1.3rem;
  }
}

@media (max-width: 640px) {
  .game-card.showcase-card .cover {
    height: 148px;
  }

  .game-card.showcase-card .showcase-title {
    font-size: 0.86rem;
    margin-bottom: 9px;
  }

  .metrics-grid {
    gap: 6px;
  }

  .metric-pill {
    min-height: 32px;
    padding: 0 7px;
    gap: 5px;
  }

  .metric-icon {
    width: 14px;
    height: 14px;
    flex-basis: 14px;
  }

  .metric-pill .metric-label,
  .metric-pill .metric-value {
    font-size: 0.68rem;
  }

  .metric-pill .metric-value {
    font-size: 0.7rem;
  }

  .game-card.showcase-card .card-menu {
    top: 8px;
    right: 8px;
  }

  .game-card.showcase-card .card-menu-trigger {
    width: 38px;
    height: 38px;
    font-size: 1.05rem;
    box-shadow: 0 5px 10px rgba(70,45,26,.11);
  }
}



/* Update 20: contain cover images instead of cropping */
.cover {
  background: #fffdf8 !important;
}
.cover img {
  object-fit: contain !important;
  object-position: center !important;
  background: #fffdf8 !important;
}
.game-card.showcase-card .cover img {
  object-fit: contain !important;
  object-position: center !important;
  background: #fffdf8 !important;
}
.cover.no-photo {
  background: #b88e6d !important;
}


/* Update 21: player filter dropdown and real contain covers */
.game-card.showcase-card .cover,
.preorder-card .cover,
.cover {
  background: #fff !important;
}

.game-card.showcase-card .cover img,
.preorder-card .cover img,
.cover img {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #fff !important;
  display: block !important;
}

.cover.no-photo,
.game-card.showcase-card .cover.no-photo {
  background: #b88e6d !important;
}

.filter-dropdown {
  position: relative;
  display: grid;
  gap: 6px;
  min-width: 168px;
}

.filter-label {
  color: var(--muted);
  font-weight: 800;
  font-size: 0.9rem;
}

.filter-button {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--paper-strong);
  color: var(--ink);
  padding: 0 42px 0 14px;
  text-align: left;
  font: inherit;
  font-weight: 800;
  cursor: pointer;
  position: relative;
}

.filter-button::after {
  content: '⌄';
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-54%);
  color: var(--muted);
  font-size: 1.1rem;
}

.filter-menu {
  position: absolute;
  z-index: 60;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--paper-strong);
  box-shadow: 0 12px 28px rgba(70, 45, 26, 0.13);
}

.filter-menu label {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  color: var(--ink);
  font-weight: 700;
  cursor: pointer;
}

.filter-menu label:hover {
  background: rgba(139, 75, 43, 0.08);
}

.filter-menu input {
  width: auto;
  min-width: 16px;
  margin: 0;
  accent-color: var(--accent);
}

@media (max-width: 820px) {
  .filter-dropdown {
    min-width: 0;
    width: 100%;
  }

  .filter-menu {
    left: 0;
    right: auto;
    width: min(100%, 260px);
  }
}

/* Update 22: true safe-fit images inside the cover rectangle.
   Причина проблемы: предыдущие стили вписывали само изображение в блок,
   но фото товара часто уже очень плотно обрезано внутри файла. Добавляем
   внутренний белый «паспарту», чтобы коробка не казалась приближенной и
   никогда не залезала на текстовую часть карточки. */
.game-card.showcase-card .cover,
.game-card .cover,
.preorder-card .cover,
.cover {
  background: #fff !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  border-bottom: 1px solid rgba(229, 215, 199, 0.92) !important;
}

.game-card.showcase-card .cover:not(.no-photo),
.game-card .cover:not(.no-photo),
.preorder-card .cover:not(.no-photo) {
  padding: 14px !important;
}

.game-card.showcase-card .cover img,
.game-card .cover img,
.preorder-card .cover img,
.cover img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: transparent !important;
  box-sizing: border-box !important;
  transform: none !important;
  backface-visibility: visible !important;
}

/* Для «Нет фото» оставляем бежевую заглушку без белой рамки. */
.game-card.showcase-card .cover.no-photo,
.game-card .cover.no-photo,
.preorder-card .cover.no-photo,
.cover.no-photo {
  padding: 0 !important;
  background: #b88e6d !important;
}

/* На мобильных делаем отступ чуть меньше, чтобы карточки по 2 в ряд не стали слишком тесными. */
@media (max-width: 640px) {
  .game-card.showcase-card .cover:not(.no-photo),
  .game-card .cover:not(.no-photo),
  .preorder-card .cover:not(.no-photo) {
    padding: 8px !important;
  }
}

/* Update 23: back to full-cover images, but centered.
   Убираем белое паспарту из update 22. Картинка снова заполняет весь
   прямоугольник обложки, но обрезается от центра: если фото высокое,
   мы видим середину фото, а не только верх. */
.game-card.showcase-card .cover,
.game-card .cover,
.preorder-card .cover,
.cover {
  overflow: hidden !important;
  display: block !important;
  padding: 0 !important;
  background: #c09370 !important;
  border-bottom: 1px solid rgba(229, 215, 199, 0.92) !important;
}

.game-card.showcase-card .cover:not(.no-photo),
.game-card .cover:not(.no-photo),
.preorder-card .cover:not(.no-photo),
.cover:not(.no-photo) {
  padding: 0 !important;
  background: #c09370 !important;
}

.game-card.showcase-card .cover img,
.game-card .cover img,
.preorder-card .cover img,
.cover img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  background: transparent !important;
  box-sizing: border-box !important;
  transform: none !important;
  backface-visibility: visible !important;
}

/* Для «Нет фото» оставляем бежевую заглушку. */
.game-card.showcase-card .cover.no-photo,
.game-card .cover.no-photo,
.preorder-card .cover.no-photo,
.cover.no-photo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  background: #b88e6d !important;
}

/* Update 24: mobile cover cleanup and smaller filter label/button.
   На мобилке предыдущие правила могли оставлять видимый бежевый фон
   по бокам изображения. Слегка увеличиваем само изображение внутри cover,
   оставляя центрирование, чтобы оно точно закрывало всю область. */
.game-card.showcase-card .cover:not(.no-photo),
.game-card .cover:not(.no-photo),
.preorder-card .cover:not(.no-photo),
.cover:not(.no-photo) {
  background: #fff !important;
  overflow: hidden !important;
}

.game-card.showcase-card .cover:not(.no-photo) img,
.game-card .cover:not(.no-photo) img,
.preorder-card .cover:not(.no-photo) img,
.cover:not(.no-photo) img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  background: transparent !important;
}

@media (max-width: 820px) {
  .game-card.showcase-card .cover:not(.no-photo) img,
  .game-card .cover:not(.no-photo) img,
  .preorder-card .cover:not(.no-photo) img,
  .cover:not(.no-photo) img {
    width: 104% !important;
    height: 104% !important;
    margin-left: -2% !important;
    margin-top: -2% !important;
  }
}

/* Кнопка фильтра должна выглядеть как остальные select-поля. */
.filter-button {
  font-size: 1rem !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  min-height: 46px !important;
}

.filter-label {
  font-size: 0.9rem !important;
  line-height: 1.15 !important;
}

@media (max-width: 820px) {
  .filter-button {
    font-size: 1rem !important;
    min-height: 48px !important;
  }
}



/* Update 26: square game covers */
/* Картинка игры теперь занимает квадратную область: высота обложки = ширина карточки. */
.game-card.showcase-card .cover {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  background: #b88e6d;
}

.game-card.showcase-card .cover img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  margin: 0 !important;
  transform: none !important;
}

.game-card.showcase-card .cover.no-photo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
}

@media (max-width: 1200px) {
  .game-card.showcase-card .cover {
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
  }
}

@media (max-width: 900px) {
  .game-card.showcase-card .cover {
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
  }
}

@media (max-width: 640px) {
  .game-card.showcase-card .cover {
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
  }
}
/* End update 26 */


/* Update 27: square preorder covers */
/* Карточки предзаказов теперь получают такую же квадратную область фото, как карточки игр. */
.preorder-card .cover {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  background: #b88e6d;
}

.preorder-card .cover img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  margin: 0 !important;
  transform: none !important;
}

.preorder-card .cover.no-photo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
}

@media (max-width: 1200px) {
  .preorder-card .cover {
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
  }
}

@media (max-width: 900px) {
  .preorder-card .cover {
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
  }
}

@media (max-width: 640px) {
  .preorder-card .cover {
    aspect-ratio: 1 / 1 !important;
    height: auto !important;
  }
}
/* End update 27 */


/* Update 28: mobile preorder meta and compact metric pills */
/* На десктопе ничего не меняем. Только мобильные карточки. */
@media (max-width: 640px) {
  /* 1) Предзаказы: строка "Поступление · август 2027 г." должна оставаться одной строкой. */
  .preorder-card .card-meta {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 4px !important;
    margin-top: 7px !important;
    font-size: 0.58rem !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }

  .preorder-card .card-meta span {
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
    min-width: 0 !important;
  }

  .preorder-card .card-meta span + span::before {
    margin: 0 4px 0 0 !important;
  }

  /* 2) Игры: уменьшаем текст во всех четырёх плашках только на мобилке. */
  .game-card.showcase-card .metrics-grid {
    gap: 6px !important;
  }

  .game-card.showcase-card .metric-pill {
    min-height: 29px !important;
    padding: 0 6px !important;
    gap: 4px !important;
    max-width: 100% !important;
  }

  .game-card.showcase-card .metric-icon {
    width: 12px !important;
    height: 12px !important;
    flex-basis: 12px !important;
  }

  .game-card.showcase-card .metric-label,
  .game-card.showcase-card .metric-value {
    font-size: 0.58rem !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
  }

  .game-card.showcase-card .metric-pill .metric-value {
    font-size: 0.62rem !important;
    font-weight: 800 !important;
  }
}

@media (max-width: 380px) {
  .preorder-card .card-meta {
    font-size: 0.54rem !important;
    gap: 3px !important;
  }

  .game-card.showcase-card .metric-pill {
    min-height: 27px !important;
    padding: 0 5px !important;
    gap: 3px !important;
  }

  .game-card.showcase-card .metric-icon {
    width: 11px !important;
    height: 11px !important;
    flex-basis: 11px !important;
  }

  .game-card.showcase-card .metric-label,
  .game-card.showcase-card .metric-value,
  .game-card.showcase-card .metric-pill .metric-value {
    font-size: 0.54rem !important;
  }
}
/* End update 28 */


/* Update 29: image overlay facts */
.game-card.showcase-card .cover {
  position: relative;
}

.cover-facts {
  position: absolute;
  left: 10px;
  bottom: 10px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  pointer-events: none;
}

.cover-fact {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 30px;
  padding: 0 9px;
  border-radius: 9px;
  border: 1px solid rgba(229, 215, 199, 0.78);
  background: rgba(255, 250, 243, 0.92);
  color: #6f5747;
  font-size: 0.78rem;
  line-height: 1;
  font-weight: 800;
  box-shadow: 0 5px 12px rgba(70, 45, 26, 0.10);
}

.cover-fact svg {
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
}

@media (max-width: 640px) {
  .cover-facts {
    left: 7px;
    bottom: 7px;
    gap: 4px;
  }

  .cover-fact {
    min-height: 24px;
    padding: 0 6px;
    gap: 4px;
    border-radius: 7px;
    font-size: 0.62rem;
  }

  .cover-fact svg {
    width: 13px;
    height: 13px;
    flex-basis: 13px;
  }
}
/* End update 29 */

/* family-boardgames/app/static/css/50-forms-and-preorders.css */
/* Update 32: no-overflow BGG add form */
/* Главная причина вылезания была в том, что форма жила в правой колонке add-panel,
   а сумма ширин input + select + кнопка оказывалась больше доступного места.
   Теперь форма занимает отдельную строку внутри карточки и не может выйти за её рамки. */
.add-panel {
  overflow: hidden;
}

.add-panel #addBggForm {
  box-sizing: border-box;
  min-width: 0;
  max-width: 100%;
}

.add-panel #addBggForm *,
.add-panel #addBggForm *::before,
.add-panel #addBggForm *::after {
  box-sizing: border-box;
}

.add-panel .manual-add {
  grid-column: 1 / -1;
}

@media (min-width: 900px) {
  .add-panel {
    grid-template-columns: 1fr !important;
    align-items: start;
  }

  .add-panel #addBggForm {
    grid-column: 1 / -1;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 170px 220px;
    gap: 12px;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    justify-self: stretch !important;
    align-items: stretch;
  }

  .add-panel #addBggForm .bgg-upload-field {
    grid-column: 1 / -1;
  }

  .add-panel #addBggForm #bggUrl,
  .add-panel #addBggForm #bggItemType,
  .add-panel #addBggForm .inline-select,
  .add-panel #addBggForm .bgg-upload-field,
  .add-panel #addBggForm .bgg-upload-field input,
  .add-panel #addBggForm .button {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .add-panel #addBggForm .button {
    justify-self: stretch;
    white-space: nowrap;
    padding-left: 0.95rem;
    padding-right: 0.95rem;
    font-size: 0.98rem;
  }
}

@media (max-width: 1120px) and (min-width: 900px) {
  .add-panel #addBggForm {
    grid-template-columns: minmax(0, 1fr) 160px;
  }

  .add-panel #addBggForm .button {
    grid-column: 1 / -1;
  }
}

@media (max-width: 899px) {
  .add-panel #addBggForm {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 10px;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  .add-panel #addBggForm #bggUrl,
  .add-panel #addBggForm #bggItemType,
  .add-panel #addBggForm .inline-select,
  .add-panel #addBggForm .bgg-upload-field,
  .add-panel #addBggForm .bgg-upload-field input,
  .add-panel #addBggForm .button {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}
/* End update 32 */


/* Update 33: remove preorder add separator */
#preordersTab .manual-add {
  border-top: 0 !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}
/* End update 33 */


/* Update 34: preorder cards equal vertical rhythm */
#preordersGrid,
.preorder-grid {
  align-items: stretch;
}

#preordersGrid .preorder-card {
  height: 100%;
  display: flex;
}

#preordersGrid .preorder-card .card-button {
  width: 100%;
  height: 100%;
  display: flex !important;
  flex-direction: column;
}

#preordersGrid .preorder-card .cover {
  flex: 0 0 auto;
}

#preordersGrid .preorder-card .card-content {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}

#preordersGrid .preorder-card .card-content h3 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.34em;
  line-height: 1.17;
  margin-bottom: 12px;
}

#preordersGrid .preorder-card .badges {
  margin-top: auto;
}

#preordersGrid .preorder-card .card-meta {
  margin-top: 12px;
}

@media (max-width: 640px) {
  #preordersGrid .preorder-card .card-content h3 {
    min-height: 2.38em;
    line-height: 1.19;
    margin-bottom: 10px;
  }

  #preordersGrid .preorder-card .badges {
    gap: 6px;
  }

  #preordersGrid .preorder-card .card-meta {
    margin-top: 9px;
  }
}
/* End update 34 */

/* family-boardgames/app/static/css/60-installments.css */
/* Update 35: installments section styles start */
#paymentPlanPanel,
.payment-plan,
.payment-overview {
  display: none !important;
}

.installment-head,
.installment-table-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 18px;
}

.installment-head h2,
.installment-table-head h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.2rem);
  letter-spacing: 0;
}

.installment-calendar-card {
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 252, 247, 0.8);
  overflow: hidden;
}

.installment-calendar-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 18px;
}

.month-control {
  display: grid;
  grid-template-columns: 44px 1fr 44px;
  align-items: center;
  gap: 10px;
}

.month-control strong {
  text-align: center;
  font-size: 1.35rem;
}

.installment-weekdays,
.installment-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.installment-weekdays {
  padding: 0 18px 8px;
  color: var(--muted);
  font-weight: 800;
  text-align: center;
}

.installment-calendar-grid {
  padding: 0 18px 18px;
}

.installment-day {
  position: relative;
  min-height: 92px;
  border: 1px solid rgba(229, 215, 199, 0.85);
  background: rgba(255, 252, 247, 0.66);
  color: var(--ink);
  font: inherit;
  cursor: pointer;
}

.installment-day.empty,
.installment-day:disabled {
  cursor: default;
}

.installment-day.empty {
  background: rgba(255,255,255,0.25);
}

.installment-day:not(:disabled):hover {
  background: rgba(245, 234, 223, 0.7);
}

.installment-day.today {
  outline: 3px solid rgba(139, 75, 43, 0.25);
  outline-offset: -5px;
}

.day-number {
  position: absolute;
  top: 12px;
  left: 12px;
  font-size: 1.25rem;
  font-weight: 850;
}

.payment-mark {
  position: absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  width: 34px;
  height: 7px;
  border-radius: 999px;
  background: #d95d5d;
  box-shadow: 0 5px 12px rgba(217, 93, 93, 0.22);
}

.payment-check {
  position: absolute;
  right: 12px;
  bottom: 12px;
  color: #4f9a4a;
  font-size: 2rem;
  font-weight: 900;
  line-height: 1;
}

.day-amount {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 8px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 750;
}

.installment-day.has-unpaid .day-amount {
  bottom: 34px;
}

.installment-day.all-paid .day-amount {
  right: 42px;
}

.installment-month-summary {
  display: grid;
  gap: 8px;
  margin: 0 18px 18px;
  padding: 18px;
  border-left: 5px solid var(--accent);
  border-radius: 16px;
  background: rgba(139, 75, 43, 0.08);
  color: var(--muted);
}

.installment-month-summary div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
}

.installment-month-summary strong {
  color: var(--ink);
}

.installment-table-head input {
  max-width: 360px;
}

.installment-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 252, 247, 0.72);
}

.installment-table {
  width: max-content;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.installment-table th,
.installment-table td {
  min-width: 180px;
  padding: 14px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  background: rgba(255, 252, 247, 0.86);
}

.installment-table thead th {
  color: var(--muted);
  text-align: left;
  font-weight: 850;
}

.installment-table .sticky-col {
  position: sticky;
  left: 0;
  z-index: 2;
  min-width: 270px;
  max-width: 320px;
  background: #fffaf3;
  box-shadow: 1px 0 0 var(--line);
}

.installment-table thead .sticky-col {
  z-index: 3;
}

.installment-table .sticky-col span {
  display: inline-block;
  max-width: 210px;
  overflow-wrap: anywhere;
}

.installment-table .sticky-col a {
  margin-left: 8px;
  color: var(--accent);
  font-weight: 900;
}

.installment-check-cell {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.installment-check-cell input,
.installment-sheet-payment input {
  width: 28px;
  height: 28px;
  accent-color: var(--accent);
}

.installment-sheet.hidden {
  display: none;
}

.installment-sheet {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  align-items: end;
}

.installment-sheet-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(33, 25, 21, 0.45);
  backdrop-filter: blur(2px);
}

.installment-sheet-card {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100% - 24px));
  margin: 0 auto 18px;
  padding: 26px;
  border-radius: 28px;
  border: 1px solid var(--line);
  background: #fffaf3;
  box-shadow: 0 25px 70px rgba(33, 25, 21, 0.24);
}

.installment-sheet-handle {
  width: 76px;
  height: 7px;
  margin: 0 auto 20px;
  border-radius: 999px;
  background: rgba(120, 108, 98, 0.35);
}

.installment-sheet-close {
  position: absolute;
  top: 18px;
  right: 18px;
}

.installment-sheet-card h3 {
  margin: 0 0 18px;
  font-size: 1.45rem;
}

.installment-sheet-list {
  display: grid;
  gap: 12px;
}

.installment-sheet-payment {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(245, 234, 223, 0.5);
}

.sheet-payment-main {
  display: grid;
  gap: 4px;
}

.installment-sheet-total {
  margin-top: 18px;
  font-weight: 850;
  text-align: center;
}

body.sheet-open {
  overflow: hidden;
}

@media (max-width: 760px) {
  .installment-head,
  .installment-table-head {
    display: grid;
  }

  .installment-table-head input {
    max-width: none;
  }

  .installment-calendar-top {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 14px;
  }

  .installment-weekdays {
    padding: 0 10px 8px;
    font-size: 0.85rem;
  }

  .installment-calendar-grid {
    padding: 0 10px 14px;
  }

  .installment-day {
    min-height: 64px;
  }

  .day-number {
    top: 8px;
    left: 8px;
    font-size: 1rem;
  }

  .payment-mark {
    bottom: 12px;
    width: 24px;
    height: 5px;
  }

  .payment-check {
    right: 7px;
    bottom: 6px;
    font-size: 1.45rem;
  }

  .day-amount {
    display: none;
  }

  .installment-month-summary {
    margin: 0 14px 14px;
    padding: 14px;
  }

  .installment-month-summary div {
    display: grid;
  }

  .installment-table .sticky-col {
    min-width: 190px;
    max-width: 210px;
  }

  .installment-table th,
  .installment-table td {
    min-width: 150px;
    padding: 12px;
  }

  .installment-sheet-card {
    width: 100%;
    margin: 0;
    border-radius: 26px 26px 0 0;
    padding: 22px;
  }
}
/* Update 35: installments section styles end */


/* Update 36: installments calendar/table cleanup */
.installment-head .muted {
  display: none !important;
}

.installment-day.empty {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  visibility: hidden;
}

.installment-day.has-unpaid {
  background: rgba(217, 93, 93, 0.15) !important;
  border-color: rgba(217, 93, 93, 0.28) !important;
}

.installment-day.all-paid {
  background: rgba(84, 160, 91, 0.15) !important;
  border-color: rgba(84, 160, 91, 0.28) !important;
}

.payment-mark,
.payment-check,
.day-amount {
  display: none !important;
}

.installment-day.has-unpaid:hover {
  background: rgba(217, 93, 93, 0.21) !important;
}

.installment-day.all-paid:hover {
  background: rgba(84, 160, 91, 0.21) !important;
}

.installment-month-table .sticky-col {
  vertical-align: middle;
}

.installment-title-link,
.installment-title-text {
  display: inline-block;
  max-width: 230px;
  color: inherit;
  text-decoration: none;
  overflow-wrap: anywhere;
  line-height: 1.18;
}

.installment-title-link:hover {
  color: var(--accent);
}

.installment-month-cell {
  min-width: 220px;
}

.installment-month-cell .month-payment {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 8px;
}

.installment-month-cell .month-payment:last-child {
  margin-bottom: 0;
}

.month-payment-info {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.month-payment-date {
  color: var(--muted);
  font-size: 0.82rem;
  white-space: nowrap;
}

.month-payment-info strong {
  white-space: nowrap;
}

@media (max-width: 760px) {
  .installment-head h2,
  .installment-table-head h2 {
    font-size: 2.05rem;
  }

  .installment-day {
    min-height: 58px;
  }

  .installment-day.has-unpaid,
  .installment-day.all-paid {
    box-shadow: inset 0 0 0 1px rgba(139, 75, 43, 0.03);
  }

  .installment-table-wrap {
    font-size: 0.72rem;
  }

  .installment-table th,
  .installment-table td {
    min-width: 128px;
    padding: 9px 8px;
  }

  .installment-table .sticky-col {
    min-width: min(46vw, 190px) !important;
    max-width: min(50vw, 205px) !important;
    width: min(46vw, 190px) !important;
  }

  .installment-title-link,
  .installment-title-text {
    display: -webkit-box;
    max-width: 100%;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.12;
    font-size: 0.72rem;
  }

  .installment-month-cell {
    min-width: 136px;
  }

  .installment-month-cell .month-payment {
    gap: 7px;
    margin-bottom: 7px;
  }

  .installment-check-cell input,
  .installment-sheet-payment input {
    width: 20px;
    height: 20px;
  }

  .month-payment-date {
    font-size: 0.64rem;
  }

  .month-payment-info strong {
    font-size: 0.72rem;
  }

  .installment-table thead th {
    font-size: 0.72rem;
    line-height: 1.15;
  }
}


/* Update 37: hover states for installments table/calendar */
@media (hover: hover) and (pointer: fine) {
  .installment-day:not(.empty) {
    transition: background-color .14s ease, border-color .14s ease, transform .14s ease, box-shadow .14s ease;
  }

  .installment-day:not(.empty):hover {
    transform: translateY(-1px);
    background: rgba(139, 75, 43, 0.07) !important;
    border-color: rgba(139, 75, 43, 0.20) !important;
    box-shadow: 0 8px 18px rgba(70, 45, 26, 0.08);
  }

  .installment-day.has-unpaid:hover {
    background: rgba(217, 93, 93, 0.24) !important;
    border-color: rgba(217, 93, 93, 0.34) !important;
  }

  .installment-day.all-paid:hover {
    background: rgba(84, 160, 91, 0.24) !important;
    border-color: rgba(84, 160, 91, 0.34) !important;
  }

  .installment-table tbody tr > th,
  .installment-table tbody tr > td {
    transition: background-color .14s ease, box-shadow .14s ease;
  }

  .installment-table tbody tr:hover > th,
  .installment-table tbody tr:hover > td {
    background: rgba(139, 75, 43, 0.045);
  }

  .installment-table tbody tr:hover > .sticky-col {
    background: rgba(139, 75, 43, 0.065);
  }

  .installment-table tbody td:hover {
    background: rgba(139, 75, 43, 0.085) !important;
    box-shadow: inset 0 0 0 2px rgba(139, 75, 43, 0.10);
  }

  .installment-month-cell .month-payment {
    border-radius: 14px;
    padding: 7px 8px;
    margin-left: -8px;
    margin-right: -8px;
    transition: background-color .14s ease, transform .14s ease, box-shadow .14s ease;
  }

  .installment-month-cell .month-payment:hover {
    background: rgba(139, 75, 43, 0.075);
    transform: translateY(-1px);
    box-shadow: inset 0 0 0 1px rgba(139, 75, 43, 0.08);
  }

  .installment-title-link {
    transition: color .14s ease, text-decoration-color .14s ease;
    text-decoration-color: transparent;
  }

  .installment-title-link:hover {
    color: var(--accent);
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 4px;
  }

  .installment-check-cell input,
  .installment-sheet-payment input {
    transition: box-shadow .14s ease, transform .14s ease;
  }

  .installment-check-cell input:hover,
  .installment-sheet-payment input:hover {
    transform: translateY(-1px);
    box-shadow: 0 0 0 4px rgba(139, 75, 43, 0.10);
  }
}

/* family-boardgames/app/static/css/70-randomizer.css */
/* randomizer-v38-css-start */
.randomizer-toolbar .sort-controls {
  align-items: end;
}

.randomizer-player-filter {
  position: relative;
  display: grid;
  gap: 6px;
}

.randomizer-filter-button {
  min-width: 190px;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 13px 16px;
  background: var(--paper-strong);
  color: var(--ink);
  font-weight: 780;
  text-align: left;
}

.randomizer-filter-button::after {
  content: '⌄';
  float: right;
  color: var(--muted);
}

.randomizer-filter-panel {
  position: absolute;
  z-index: 20;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  display: grid;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--paper-strong);
  box-shadow: 0 16px 30px rgba(70,45,26,.14);
}

.randomizer-filter-panel label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 720;
  color: var(--ink);
}

.randomizer-filter-panel input {
  width: auto;
  accent-color: var(--accent);
}

.randomizer-pool-panel {
  margin-bottom: 20px;
}

.randomizer-pool-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-end;
}

#randomizerSelectedHint {
  margin-bottom: 0;
}

.randomizer-pick-button:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.randomizer-selected-list {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 14px;
}

.randomizer-selected-chip {
  display: inline-flex;
  align-items: center;
  text-align: left;
  gap: 12px;
  min-width: 210px;
  max-width: 280px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 10px;
  background: rgba(255, 252, 247, 0.94);
  color: var(--ink);
  box-shadow: 0 7px 18px rgba(70, 45, 26, 0.08);
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
}

.randomizer-selected-chip:hover,
.randomizer-selected-chip:focus-visible {
  border-color: rgba(143, 77, 45, 0.38);
  background: rgba(255, 252, 247, 1);
  box-shadow: 0 10px 24px rgba(70, 45, 26, 0.12);
}

.randomizer-selected-thumb {
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  overflow: hidden;
  border-radius: 7px;
  background: rgba(177, 132, 96, 0.32);
}

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

.randomizer-selected-name {
  min-width: 0;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 650;
}

.randomizer-selected-remove {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  border: 0;
  border-radius: 999px;
  padding: 0;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.randomizer-selected-chip:hover .randomizer-selected-remove,
.randomizer-selected-chip:focus-visible .randomizer-selected-remove {
  background: rgba(143, 77, 45, 0.1);
  color: var(--accent-dark);
}

.randomizer-selected-remove span {
  width: 14px;
  height: 14px;
  background: currentColor;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round'%3E%3Cpath d='M5 5l10 10M15 5 5 15'/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat;
}

.randomizer-selected-chip input,
.randomizer-card-check input {
  width: auto;
  accent-color: var(--accent);
}

.randomizer-card {
  position: relative;
}

.randomizer-card-check {
  position: absolute;
  z-index: 9;
  top: 12px;
  right: 12px;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: rgba(255, 250, 243, .96);
  border: 1px solid var(--line);
  box-shadow: 0 8px 18px rgba(70, 45, 26, .13);
  display: flex;
  align-items: center;
  justify-content: center;
}

.randomizer-card-check input {
  width: 22px;
  height: 22px;
}

.randomizer-card-select-hint {
  position: absolute;
  z-index: 9;
  top: 0;
  left: 0;
  right: 0;
  min-height: 54px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 18px;
  border-radius: 24px 24px 0 0;
  border-bottom: 1px solid rgba(229, 215, 199, 0.9);
  background: rgba(255, 250, 243, 0.92);
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 850;
  box-shadow: 0 8px 18px rgba(70, 45, 26, 0.08);
  backdrop-filter: blur(10px);
  cursor: pointer;
}

.randomizer-card-select-hint input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.randomizer-select-icon {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  color: #8f7a6b;
}

.randomizer-select-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

#randomizerGrid .card-menu,
#randomizerGrid .card-menu-trigger {
  display: none !important;
}

.randomizer-result-modal-card {
  max-width: 560px;
  text-align: left;
  position: relative;
  overflow: hidden;
}

.randomizer-result-card-wrap {
  margin-top: 16px;
}

.randomizer-result-game {
  max-width: 420px;
  margin: 0 auto;
}

.randomizer-result-actions {
  display: flex;
  gap: 10px;
  margin-top: 18px;
  flex-wrap: wrap;
}

.randomizer-confetti span {
  position: absolute;
  width: 9px;
  height: 18px;
  border-radius: 4px;
  background: var(--accent);
  opacity: .75;
  animation: randomizerConfetti 1.3s ease-out both;
}

.randomizer-confetti span:nth-child(1) { left: 10%; top: 8%; transform: rotate(20deg); }
.randomizer-confetti span:nth-child(2) { left: 26%; top: 4%; background: #d8a56a; animation-delay: .05s; }
.randomizer-confetti span:nth-child(3) { right: 18%; top: 10%; background: #7a4f37; animation-delay: .1s; }
.randomizer-confetti span:nth-child(4) { right: 8%; top: 28%; background: #c65a52; animation-delay: .15s; }
.randomizer-confetti span:nth-child(5) { left: 12%; bottom: 22%; background: #6f9b65; animation-delay: .2s; }
.randomizer-confetti span:nth-child(6) { right: 16%; bottom: 12%; background: #d98249; animation-delay: .25s; }

@keyframes randomizerConfetti {
  0% { opacity: 0; transform: translateY(18px) scale(.8) rotate(0deg); }
  20% { opacity: 1; }
  100% { opacity: 0; transform: translateY(-18px) scale(1.1) rotate(160deg); }
}

@media (max-width: 820px) {
  .randomizer-pool-head {
    flex-direction: column;
    align-items: stretch;
  }

  .randomizer-filter-panel {
    left: 0;
    right: auto;
    width: 100%;
  }

  .randomizer-card-check {
    width: 42px;
    height: 42px;
    top: 8px;
    right: 8px;
  }

  .randomizer-card-check input {
    width: 18px;
    height: 18px;
  }

  .randomizer-card-select-hint {
    min-height: 46px;
    padding: 0 13px;
    gap: 8px;
    font-size: 0.76rem;
  }

  .randomizer-select-icon {
    width: 18px;
    height: 18px;
    flex-basis: 18px;
  }
}
/* randomizer-v38-css-end */










/* update43-guest-privacy-css-start */
body:not(.is-admin) [data-tab="installments"],
body:not(.is-admin) [data-tab="installment"],
body:not(.is-admin) #installmentsTab,
body:not(.is-admin) #installmentsPanel,
body:not(.is-admin) #installmentTab,
body:not(.is-admin) #installmentPanel,
body:not(.is-admin) [id*="installment"],
body:not(.is-admin) [id*="Installment"] {
  display: none !important;
}
/* update43-guest-privacy-css-end */



/* update52-randomizer-mobile-start */
/* Убираем салют в попапе рандомайзера */
.randomizer-confetti,
.randomizer-confetti span {
  display: none !important;
  animation: none !important;
}

/* На телефоне фильтры рандомайзера должны быть простой ровной колонкой */
@media (max-width: 820px) {
  #randomizerTab .randomizer-toolbar,
  #randomizerTab .toolbar.randomizer-toolbar {
    display: block !important;
    align-items: stretch !important;
  }

  #randomizerTab .randomizer-toolbar > div,
  #randomizerTab .randomizer-toolbar .randomizer-controls,
  #randomizerTab .randomizer-toolbar .sort-controls {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }

  #randomizerTab .randomizer-toolbar .randomizer-controls,
  #randomizerTab .randomizer-toolbar .sort-controls.randomizer-controls {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin-top: 24px !important;
    justify-items: stretch !important;
    align-items: stretch !important;
  }

  #randomizerTab .randomizer-controls > label,
  #randomizerTab .randomizer-controls .randomizer-player-filter,
  #randomizerTab .randomizer-player-filter {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    text-align: left !important;
  }

  #randomizerTab .randomizer-controls > label > select,
  #randomizerTab .randomizer-controls select,
  #randomizerTab #randomizerPlayerFilterButton,
  #randomizerTab .randomizer-filter-button {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 58px !important;
    padding: 14px 18px !important;
    box-sizing: border-box !important;
    text-align: left !important;
  }

  #randomizerTab .randomizer-player-filter > label {
    display: block !important;
    margin-bottom: 6px !important;
    text-align: left !important;
  }

  #randomizerTab .randomizer-filter-panel {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
}
/* update52-randomizer-mobile-end */
















/* randomizer-drum-v66-css-start */
.randomizer-drum.v66 {
  --drum-row-height: 58px;
  display: grid;
  place-items: center;
  gap: 18px;
  min-height: 330px;
  padding: 26px 18px 24px;
  text-align: center;
}

.randomizer-drum.v66 .randomizer-drum-kicker {
  color: var(--accent-dark);
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .78rem;
}

.randomizer-drum.v66 .randomizer-drum-window {
  width: min(100%, 650px);
  height: calc(var(--drum-row-height) * 3);
  display: block;
  border-radius: 30px;
  border: 1px solid rgba(143, 77, 45, .18);
  background:
    radial-gradient(circle at 20% 0%, rgba(217, 130, 73, .13), transparent 34%),
    linear-gradient(180deg, rgba(255, 252, 247, .98), rgba(245, 235, 224, .96));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8), 0 12px 28px rgba(70,45,26,.09);
  overflow: hidden;
  position: relative;
}

.randomizer-drum.v66 .randomizer-drum-window::before,
.randomizer-drum.v66 .randomizer-drum-window::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 52px;
  z-index: 3;
  pointer-events: none;
}

.randomizer-drum.v66 .randomizer-drum-window::before {
  top: 0;
  background: linear-gradient(180deg, rgba(255,252,247,.98), rgba(255,252,247,0));
}

.randomizer-drum.v66 .randomizer-drum-window::after {
  bottom: 0;
  background: linear-gradient(0deg, rgba(245,235,224,.98), rgba(245,235,224,0));
}

.randomizer-drum.v66 .randomizer-drum-track {
  width: 100%;
  transform: translateY(calc(-1 * var(--drum-row-height)));
  will-change: transform;
}

.randomizer-drum.v66 .randomizer-drum-item {
  height: var(--drum-row-height);
  max-width: 92%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Serif", Georgia, serif;
  line-height: 1.05;
  letter-spacing: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.randomizer-drum.v66 .randomizer-drum-item.side {
  color: var(--muted);
  opacity: .58;
  font-size: clamp(.95rem, 2.3vw, 1.22rem);
  filter: blur(.15px);
}

.randomizer-drum.v66 .randomizer-drum-item.ghost {
  color: var(--muted);
  opacity: .22;
  font-size: clamp(.9rem, 2vw, 1.08rem);
  filter: blur(.45px);
}

.randomizer-drum.v66 .randomizer-drum-item.center {
  color: var(--ink);
  font-size: clamp(1.45rem, 4vw, 2.5rem);
  font-weight: 850;
  text-shadow: 0 1px 0 rgba(255,255,255,.8);
}

.randomizer-drum.v66 .randomizer-drum-item.center.final {
  color: var(--accent-dark);
  animation: drumFinalPulseV66 .85s ease both;
}

.randomizer-drum.v66 .randomizer-drum-note {
  color: var(--muted);
  font-size: .95rem;
  font-weight: 700;
}

@keyframes drumFinalPulseV66 {
  0% { transform: scale(1); }
  45% { transform: scale(1.055); }
  100% { transform: scale(1); }
}

@media (max-width: 720px) {
  .randomizer-drum.v66 {
    --drum-row-height: 50px;
    min-height: 290px;
    padding: 22px 10px 18px;
  }

  .randomizer-drum.v66 .randomizer-drum-window {
    border-radius: 24px;
  }

  .randomizer-drum.v66 .randomizer-drum-item.center {
    font-size: clamp(1.18rem, 6vw, 1.65rem);
  }
}
/* randomizer-drum-v66-css-end */

/* randomizer-drum-v67-css-start */
.randomizer-drum.v66 .randomizer-drum-item.center {
  color: var(--ink);
  font-weight: 850;
  opacity: 1;
  filter: none;
  text-shadow: 0 1px 0 rgba(255,255,255,.8);
}

.randomizer-drum.v66 .randomizer-drum-item.side {
  font-weight: 650;
  opacity: .55;
}

.randomizer-drum.v66 .randomizer-drum-item.ghost {
  font-weight: 550;
  opacity: .22;
}
/* randomizer-drum-v67-css-end */

/* randomizer-result-mobile-modal-v108-css-start */
@media (max-width: 820px) {
  #randomizerResultModal {
    position: fixed !important;
    inset: 0 !important;
    width: 100dvw !important;
    height: 100dvh !important;
    padding: 10px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    place-items: center !important;
  }

  #randomizerResultModal.hidden {
    display: none !important;
  }

  #randomizerResultModal .randomizer-result-modal-card {
    width: min(100%, calc(100dvw - 20px)) !important;
    max-width: calc(100dvw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    margin: 0 !important;
    padding: 18px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    border-radius: 22px !important;
  }

  #randomizerResultModal .close-modal {
    top: 12px !important;
    right: 12px !important;
  }

  #randomizerResultModal .eyebrow,
  #randomizerResultModal h2,
  #randomizerResultCard,
  #randomizerResultCard .randomizer-result-game,
  #randomizerResultCard .game-card,
  #randomizerResultCard .card-button,
  #randomizerResultCard .showcase-content,
  #randomizerResultCard .metrics-grid {
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  #randomizerResultModal h2 {
    margin-right: 52px !important;
    font-size: clamp(1.45rem, 6.55vw, 1.72rem) !important;
    line-height: 1.12 !important;
    overflow-wrap: anywhere !important;
  }

  #randomizerResultCard {
    width: 100% !important;
    overflow: hidden !important;
  }

  #randomizerResultCard .randomizer-result-game {
    width: 100% !important;
    margin: 0 !important;
  }

  #randomizerResultCard .cover {
    width: 100% !important;
    height: auto !important;
    max-height: 45dvh !important;
    aspect-ratio: 1 / 1 !important;
  }

  #randomizerResultCard .cover img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  #randomizerResultModal .randomizer-result-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, .72fr) !important;
    gap: 10px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  #randomizerResultModal .randomizer-result-actions .button {
    width: 100% !important;
    min-width: 0 !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    white-space: normal !important;
  }
}

@media (max-width: 370px) {
  #randomizerResultModal .randomizer-result-actions {
    grid-template-columns: 1fr !important;
  }
}
/* randomizer-result-mobile-modal-v108-css-end */

/* randomizer-card-select-strip-v111-css-start */
#randomizerGrid .randomizer-card {
  overflow: hidden !important;
}

#randomizerGrid .randomizer-card-select-hint {
  position: relative !important;
  z-index: 2;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  min-height: 62px;
  border-radius: 0 !important;
  border-bottom: 1px solid rgba(229, 215, 199, 0.9);
  background: rgba(255, 250, 243, 0.98);
  box-shadow: none;
  backdrop-filter: none;
}

#randomizerGrid .randomizer-card .card-button {
  border-radius: 0 !important;
}

#randomizerGrid .randomizer-card .cover {
  border-radius: 0 !important;
  aspect-ratio: 1 / 1 !important;
}

#randomizerGrid .randomizer-card .cover img {
  object-fit: cover !important;
}

@media (max-width: 820px) {
  #randomizerGrid .randomizer-card-select-hint {
    min-height: 70px;
    align-items: center;
    padding: 0 16px;
    gap: 10px;
    font-size: 0.92rem;
    line-height: 1.28;
  }
}
/* randomizer-card-select-strip-v111-css-end */

/* family-boardgames/app/static/css/80-linked-expansions.css */
/* linked-expansions-v69-css-start */
.linked-expansion-hidden-v68,
.linked-expansion-hidden-v69 {
  display: none !important;
}

.linked-expansion-parent-v68,
.linked-expansion-parent-v69 {
  margin-top: 10px;
}

.linked-expansion-parent-v68.hidden,
.linked-expansion-parent-v69.hidden {
  display: none !important;
}

.linked-expansion-parent-v68 span,
.linked-expansion-parent-v69 span {
  display: block;
  margin-bottom: 7px;
}

#addBggForm .linked-expansion-parent-v68.compact,
#addBggForm .linked-expansion-parent-v69.compact {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  min-width: 0 !important;
  margin-top: 0;
}

#addBggForm .linked-expansion-parent-v68.compact input,
#addBggForm .linked-expansion-parent-v69.compact input {
  width: 100%;
  min-width: 0;
}

.linked-expansion-trigger-v68 {
  display: none !important;
}

.linked-expansion-trigger-v69 {
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 8;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid rgba(229, 215, 199, 0.95);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 250, 243, 0.96);
  color: var(--accent-dark, #8f4d2d);
  box-shadow: 0 8px 16px rgba(70, 45, 26, 0.12);
  font-weight: 900;
  cursor: pointer;
}

.linked-expansion-trigger-v69 .count {
  font-size: .95rem;
  line-height: 1;
}

.linked-expansion-trigger-v69:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(70, 45, 26, 0.16);
}

.linked-expansion-modal-v68 {
  display: none !important;
}

.linked-expansion-modal-v69.hidden {
  display: none !important;
}

.linked-expansion-modal-v69 {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  padding: 22px;
}

.linked-expansion-backdrop-v69 {
  position: absolute;
  inset: 0;
  background: rgba(43, 33, 27, 0.42);
  backdrop-filter: blur(5px);
}

.linked-expansion-dialog-v69 {
  position: relative;
  z-index: 1;
  width: min(1120px, 96vw);
  max-height: min(88vh, 900px);
  overflow: auto;
  border-radius: 26px;
  background: var(--paper, #fffaf3);
  border: 1px solid var(--line, #e5d7c7);
  box-shadow: 0 24px 60px rgba(70, 45, 26, 0.24);
  padding: 30px;
}

.linked-expansion-close-v69 {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: rgba(245, 235, 224, 0.9);
  color: var(--ink, #2d241f);
  font-size: 1.7rem;
  font-weight: 900;
  cursor: pointer;
}

.linked-expansion-dialog-v69 .eyebrow {
  color: var(--accent-dark, #8f4d2d);
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .78rem;
  margin-bottom: 8px;
}

.linked-expansion-dialog-v69 h2 {
  margin: 0 62px 22px 0;
  font-size: clamp(1.7rem, 4vw, 3rem);
  line-height: 1.05;
}

.linked-expansion-grid-v69 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 18px;
}

.linked-expansion-card-v69 {
  position: relative;
  min-height: 0;
}

.linked-expansion-card-v69 .linked-expansion-card-link-v69 {
  color: inherit;
  text-decoration: none;
}

.linked-expansion-card-v69 .cover {
  aspect-ratio: 1 / 1;
  height: auto !important;
  display: grid;
  place-items: center;
  background: #b88e6d;
  color: #fffaf3;
  font-weight: 800;
}

.linked-expansion-card-v69 .cover img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.linked-expansion-card-v69 .showcase-title {
  min-height: 2.12em;
}

.linked-expansion-card-v69 .card-menu {
  top: 10px;
  right: 10px;
  z-index: 10;
}

.linked-expansion-card-v69 .card-menu-trigger {
  width: 44px;
  height: 44px;
  font-size: 1.15rem;
}

.linked-expansion-card-v69 .card-menu-popover.hidden {
  display: none !important;
}

@media (max-width: 720px) {
  .linked-expansion-dialog-v69 {
    padding: 24px 18px;
    border-radius: 22px;
  }

  .linked-expansion-grid-v69 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .linked-expansion-trigger-v69 {
    left: 8px;
    top: 8px;
    width: 34px;
    height: 34px;
  }
}
/* linked-expansions-v69-css-end */


/* linked-expansion-parent-picker-v70-css-start */
.linked-expansion-parent-v70-ready {
  position: relative;
}

.metadata-suggest-field {
  position: relative;
}

.metadata-suggest-menu {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 12000;
  max-height: 330px;
  overflow: auto;
  border: 1px solid var(--line, #e5d7c7);
  border-radius: 18px;
  background: var(--paper, #fffaf3);
  box-shadow: 0 18px 44px rgba(70, 45, 26, 0.18);
  padding: 8px;
}

.metadata-suggest-menu.hidden {
  display: none !important;
}

.linked-expansion-suggest-v70.hidden {
  display: none !important;
}

.linked-expansion-suggest-v70 {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 12000;
  max-height: 330px;
  overflow: auto;
  border: 1px solid var(--line, #e5d7c7);
  border-radius: 18px;
  background: var(--paper, #fffaf3);
  box-shadow: 0 18px 44px rgba(70, 45, 26, 0.18);
  padding: 8px;
}

.linked-expansion-option-v70 {
  width: 100%;
  border: 0;
  border-radius: 12px;
  background: transparent;
  padding: 11px 12px;
  color: var(--ink, #2d241f);
  text-align: left;
  cursor: pointer;
  font: inherit;
  font-weight: 750;
}

.linked-expansion-option-v70:hover,
.linked-expansion-option-v70:focus {
  background: rgba(143, 77, 45, 0.09);
  color: var(--accent-dark, #8f4d2d);
  outline: none;
}

.linked-expansion-empty-v70 {
  padding: 12px;
  color: var(--muted, #7d6e64);
  font-weight: 700;
}
/* linked-expansion-parent-picker-v70-css-end */


/* linked-expansion-fixes-v71-css-start */
/* Добавление через BGG: поле базовой игры всегда отдельной строкой,
   а кнопка остаётся справа от выбора типа. */
#addBggForm .bgg-parent-row-v71,
#addBggForm .linked-expansion-parent-v70-ready,
#addBggForm .linked-expansion-parent-v69,
#addBggForm .linked-expansion-parent-v68 {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin-top: 8px !important;
}

@media (min-width: 900px) {
  #addBggForm {
    grid-template-columns: minmax(360px, 1fr) minmax(170px, 220px) max-content !important;
    align-items: end !important;
  }

  #addBggForm button[type="submit"],
  #addBggForm .button {
    grid-column: auto !important;
    width: auto !important;
    min-width: max-content !important;
    align-self: end !important;
  }
}

/* Мобильный попап дополнений — bottom sheet/шторка снизу. */
@media (max-width: 720px) {
  .linked-expansion-modal-v68,
  .linked-expansion-modal-v69 {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: center !important;
    padding: 0 !important;
  }

  .linked-expansion-modal-v68.hidden,
  .linked-expansion-modal-v69.hidden {
    display: none !important;
  }

  .linked-expansion-backdrop-v68,
  .linked-expansion-backdrop-v69 {
    position: absolute !important;
    inset: 0 !important;
  }

  .linked-expansion-dialog-v68,
  .linked-expansion-dialog-v69 {
    width: 100vw !important;
    max-width: 100vw !important;
    max-height: 86dvh !important;
    margin: 0 !important;
    border-radius: 28px 28px 0 0 !important;
    padding: 24px 18px max(22px, env(safe-area-inset-bottom)) !important;
    transform: translateY(0) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  .linked-expansion-dialog-v68::before,
  .linked-expansion-dialog-v69::before {
    content: '';
    display: block;
    width: 52px;
    height: 5px;
    border-radius: 999px;
    background: rgba(118, 106, 98, .28);
    margin: 0 auto 18px;
  }

  .linked-expansion-close-v68,
  .linked-expansion-close-v69 {
    width: 48px !important;
    height: 48px !important;
    top: 18px !important;
    right: 18px !important;
  }

  .linked-expansion-dialog-v68 h2,
  .linked-expansion-dialog-v69 h2 {
    margin-right: 58px !important;
    font-size: clamp(1.7rem, 9vw, 2.35rem) !important;
  }

  .linked-expansion-grid-v68,
  .linked-expansion-grid-v69 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .linked-expansion-card-v68 h3,
  .linked-expansion-card-v69 h3 {
    font-size: .9rem !important;
    line-height: 1.12 !important;
  }
}
/* linked-expansion-fixes-v71-css-end */





/* linked-expansion-picker-mobile-scroll-v74-css-start */
.linked-expansion-suggest-v70.linked-expansion-floating-v74,
.linked-expansion-suggest-v69.linked-expansion-floating-v74,
.linked-expansion-suggest-v68.linked-expansion-floating-v74 {
  position: fixed !important;
  z-index: 90000 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  box-sizing: border-box !important;
  border: 1px solid var(--line, #e5d7c7) !important;
  border-radius: 18px !important;
  background: var(--paper, #fffaf3) !important;
  box-shadow: 0 20px 48px rgba(70, 45, 26, 0.22) !important;
  padding: 8px !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  touch-action: pan-y !important;
}

.linked-expansion-suggest-v70.linked-expansion-floating-v74.hidden,
.linked-expansion-suggest-v69.linked-expansion-floating-v74.hidden,
.linked-expansion-suggest-v68.linked-expansion-floating-v74.hidden {
  display: none !important;
}

.linked-expansion-suggest-v70.linked-expansion-floating-v74 .linked-expansion-option-v70,
.linked-expansion-suggest-v69.linked-expansion-floating-v74 .linked-expansion-option-v69,
.linked-expansion-suggest-v68.linked-expansion-floating-v74 .linked-expansion-option-v68 {
  width: 100% !important;
  min-height: 56px !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: transparent !important;
  padding: 13px 16px !important;
  color: var(--ink, #2d241f) !important;
  text-align: left !important;
  cursor: pointer !important;
  font: inherit !important;
  font-weight: 800 !important;
  touch-action: manipulation !important;
}

@media (hover: hover) and (pointer: fine) {
  .linked-expansion-suggest-v70.linked-expansion-floating-v74 .linked-expansion-option-v70:hover,
  .linked-expansion-suggest-v69.linked-expansion-floating-v74 .linked-expansion-option-v69:hover,
  .linked-expansion-suggest-v68.linked-expansion-floating-v74 .linked-expansion-option-v68:hover {
    background: rgba(143, 77, 45, 0.09) !important;
    color: var(--accent-dark, #8f4d2d) !important;
  }
}
/* linked-expansion-picker-mobile-scroll-v74-css-end */


/* linked-expansion-mobile-sheet-v103-css-start */
@media (max-width: 820px) {
  .linked-expansion-modal-v69 {
    position: fixed !important;
    inset: 0 !important;
    z-index: 10000 !important;
    width: 100dvw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: center !important;
    overflow: hidden !important;
    transform: none !important;
  }

  .linked-expansion-modal-v69.hidden {
    display: none !important;
  }

  .linked-expansion-backdrop-v69 {
    position: fixed !important;
    inset: 0 !important;
    width: 100dvw !important;
    height: 100dvh !important;
  }

  .linked-expansion-dialog-v69 {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    max-height: min(82dvh, 760px) !important;
    margin: 0 !important;
    border-radius: 28px 28px 0 0 !important;
    padding: 24px 18px max(22px, env(safe-area-inset-bottom)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    transform: none !important;
    box-sizing: border-box !important;
  }

  .linked-expansion-dialog-v69 h2 {
    margin-right: 58px !important;
    font-size: clamp(1.55rem, 8vw, 2.2rem) !important;
    line-height: 1.08 !important;
  }

  .linked-expansion-grid-v69 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }
}
/* linked-expansion-mobile-sheet-v103-css-end */

/* family-boardgames/app/static/css/90-search-and-filters.css */
/* expansion-save-and-search-v75-css-start */
.library-search-input-v75 {
  width: 100%;
  min-width: 180px;
  height: 54px;
  border: 1px solid var(--line, #e5d7c7);
  border-radius: 16px;
  background: var(--paper-strong, #fffdf8);
  color: var(--ink, #2f251f);
  padding: 0 16px;
  font: inherit;
  font-weight: 750;
  outline: none;
}

.library-search-input-v75:focus {
  border-color: rgba(143, 77, 45, .42);
  box-shadow: 0 0 0 4px rgba(143, 77, 45, .10);
}

.randomizer-search-label-v75 {
  display: grid;
  gap: 6px;
}

.search-hidden-v75 {
  display: none !important;
}

@media (max-width: 820px) {
  .library-search-input-v75 {
    height: 52px;
    font-size: .95rem;
  }
}
/* expansion-save-and-search-v75-css-end */


/* expansion-create-fix-v76-css-start */
.library-search-input-v75,
#gameSearchInput,
#randomizerSearchInput {
  height: 48px !important;
  min-height: 48px !important;
  padding: 0 14px !important;
  font-size: .92rem !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  box-sizing: border-box !important;
}

.sort-controls label:has(#gameSearchInput),
.sort-controls label:has(#randomizerSearchInput),
.randomizer-search-label-v75 {
  min-width: 0 !important;
  width: 220px !important;
  max-width: 220px !important;
}

@media (max-width: 820px) {
  .sort-controls label:has(#gameSearchInput),
  .sort-controls label:has(#randomizerSearchInput),
  .randomizer-search-label-v75 {
    width: 100% !important;
    max-width: none !important;
  }

  .library-search-input-v75,
  #gameSearchInput,
  #randomizerSearchInput {
    height: 52px !important;
    min-height: 52px !important;
    font-size: .95rem !important;
  }
}
/* expansion-create-fix-v76-css-end */








/* search-status-filters-rename-v92-css-start */
.site-search-label-v92,
.site-search-label-v91,
.site-search-label-v90 {
  display: grid;
  gap: 6px;
}

.site-search-input-v92,
.site-search-input-v91,
.site-search-input-v90 {
  width: 100%;
  min-width: 0;
  height: 54px;
  border: 1px solid var(--line, #e5d7c7);
  border-radius: 16px;
  background: var(--paper-strong, #fffdf8);
  color: var(--ink, #2f251f);
  padding: 0 16px;
  font: inherit;
  font-weight: 750;
  outline: none;
}

.site-search-input-v92:focus,
.site-search-input-v91:focus,
.site-search-input-v90:focus {
  border-color: rgba(143, 77, 45, .42);
  box-shadow: 0 0 0 4px rgba(143, 77, 45, .10);
}

.site-filter-hidden-v92,
.site-filter-hidden-v91,
.site-filter-hidden-v90 {
  display: none !important;
}

.preorder-status-filter-v92 {
  position: relative;
  display: grid;
  gap: 6px;
}

.site-filter-button-v92 {
  min-width: 160px;
}

.site-filter-panel-v92,
.randomizer-filter-panel {
  z-index: 90;
}

.filter-divider-v92 {
  border-top: 1px solid rgba(229, 215, 199, .9);
  margin-top: 8px;
  padding-top: 8px;
}

.filter-divider-v92 > span {
  display: block;
  color: var(--muted, #7c6d63);
  font-weight: 850;
  font-size: .78rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin: 2px 0 8px;
}

.filter-divider-v92 label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 2px;
}

.preorder-toolbar-v92 {
  margin-bottom: 18px;
}

.preorder-controls-v92 {
  align-items: end;
}

@media (min-width: 901px) {
  #gameSearchInput,
  #randomizerSearchInput,
  #preorderSearchInputV92 {
    width: 230px;
  }
}

@media (max-width: 900px) {
  .site-search-input-v92,
  .site-search-input-v91,
  .site-search-input-v90 {
    height: 52px;
    font-size: .95rem;
  }
  .preorder-toolbar-v92 .sort-controls,
  .preorder-controls-v92 {
    grid-template-columns: 1fr;
  }
  .site-filter-button-v92,
  #gameSearchInput,
  #randomizerSearchInput,
  #preorderSearchInputV92 {
    width: 100%;
  }
}
/* search-status-filters-rename-v92-css-end */


/* game-search-by-expansions-v93-css-start */
#gameSearchInput::placeholder {
  font-size: .92em;
}
/* game-search-by-expansions-v93-css-end */


/* unified-toolbar-controls-v97-css-start */
:root {
  --control-field-height: 54px;
  --control-field-radius: 16px;
  --control-field-font-size: .95rem;
  --control-field-font-weight: 750;
  --control-field-pad-x: 16px;
}

.add-form input,
.add-form select,
.inline-select,
.sort-controls input[type="search"],
.sort-controls select,
.site-search-input-v92,
.site-search-input-v91,
.site-search-input-v90,
#gameSearchInput,
#randomizerSearchInput,
#preorderSearchInputV92,
.installment-table-head input,
.filter-button,
.randomizer-filter-button,
.site-filter-button-v92 {
  box-sizing: border-box !important;
  height: var(--control-field-height) !important;
  min-height: var(--control-field-height) !important;
  border: 1px solid var(--line, #e5d7c7) !important;
  border-radius: var(--control-field-radius) !important;
  background: var(--paper-strong, #fffdf8) !important;
  color: var(--ink, #2f251f) !important;
  font-family: inherit !important;
  font-size: var(--control-field-font-size) !important;
  font-weight: var(--control-field-font-weight) !important;
  line-height: 1 !important;
}

.add-form input,
.add-form select,
.inline-select,
.sort-controls input[type="search"],
.sort-controls select,
.site-search-input-v92,
.site-search-input-v91,
.site-search-input-v90,
#gameSearchInput,
#randomizerSearchInput,
#preorderSearchInputV92,
.installment-table-head input {
  padding: 0 var(--control-field-pad-x) !important;
}

.filter-button,
.randomizer-filter-button,
.site-filter-button-v92 {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 calc(var(--control-field-pad-x) + 26px) 0 var(--control-field-pad-x) !important;
  text-align: left !important;
}

.randomizer-filter-button::after,
.filter-button::after {
  color: var(--muted, #7c6d63) !important;
}

.add-form input::placeholder,
.sort-controls input[type="search"]::placeholder,
.site-search-input-v92::placeholder,
.site-search-input-v91::placeholder,
.site-search-input-v90::placeholder,
#gameSearchInput::placeholder,
#randomizerSearchInput::placeholder,
#preorderSearchInputV92::placeholder,
.installment-table-head input::placeholder {
  color: var(--muted, #7c6d63) !important;
  font-size: var(--control-field-font-size) !important;
  font-weight: var(--control-field-font-weight) !important;
  opacity: 1 !important;
}

@media (max-width: 900px) {
  :root {
    --control-field-height: 52px;
  }
}
/* unified-toolbar-controls-v97-css-end */


/* compact-toolbar-controls-v98-css-start */
.toolbar .sort-controls {
  gap: 10px;
  align-items: end;
}

.toolbar .sort-controls label,
.toolbar .filter-label,
.preorder-status-filter-v92 > label,
.randomizer-player-filter > label {
  gap: 5px;
  color: var(--muted, #76695f);
  font-size: .74rem;
  font-weight: 800;
}

.toolbar .sort-controls input[type="search"],
.toolbar .sort-controls select,
.toolbar .site-search-input-v92,
.toolbar .site-search-input-v91,
.toolbar .site-search-input-v90,
.toolbar #gameSearchInput,
.toolbar #randomizerSearchInput,
.toolbar #preorderSearchInputV92,
.toolbar .filter-button,
.toolbar .randomizer-filter-button,
.toolbar .site-filter-button-v92,
.installment-table-head input {
  height: 46px !important;
  min-height: 46px !important;
  border-radius: 14px !important;
  font-size: .86rem !important;
  font-weight: 750 !important;
}

.toolbar .sort-controls input[type="search"],
.toolbar .sort-controls select,
.toolbar .site-search-input-v92,
.toolbar .site-search-input-v91,
.toolbar .site-search-input-v90,
.toolbar #gameSearchInput,
.toolbar #randomizerSearchInput,
.toolbar #preorderSearchInputV92,
.installment-table-head input {
  width: 100% !important;
  padding: 0 13px !important;
}

.toolbar .filter-button,
.toolbar .randomizer-filter-button,
.toolbar .site-filter-button-v92 {
  padding: 0 38px 0 13px !important;
}

.toolbar .sort-controls label:has(#gameSearchInput),
.toolbar .sort-controls label:has(#randomizerSearchInput),
.toolbar .sort-controls label:has(#preorderSearchInputV92) {
  width: 260px !important;
  max-width: 260px !important;
}

.toolbar .sort-controls label:has(#sortSelect),
.toolbar .sort-controls label:has(#randomizerSort) {
  width: 220px !important;
  max-width: 220px !important;
}

.toolbar .sort-controls label:has(#dirSelect),
.toolbar .sort-controls label:has(#randomizerDir) {
  width: 190px !important;
  max-width: 190px !important;
}

.toolbar .filter-dropdown,
.toolbar .randomizer-player-filter,
.toolbar .preorder-status-filter-v92 {
  width: 174px;
  min-width: 174px;
}

.toolbar .sort-controls input[type="search"]::placeholder,
.toolbar .site-search-input-v92::placeholder,
.toolbar .site-search-input-v91::placeholder,
.toolbar .site-search-input-v90::placeholder,
.toolbar #gameSearchInput::placeholder,
.toolbar #randomizerSearchInput::placeholder,
.toolbar #preorderSearchInputV92::placeholder,
.installment-table-head input::placeholder {
  font-size: .86rem !important;
  font-weight: 750 !important;
}

@media (max-width: 900px) {
  .toolbar .sort-controls label:has(#gameSearchInput),
  .toolbar .sort-controls label:has(#randomizerSearchInput),
  .toolbar .sort-controls label:has(#preorderSearchInputV92),
  .toolbar .sort-controls label:has(#sortSelect),
  .toolbar .sort-controls label:has(#randomizerSort),
  .toolbar .sort-controls label:has(#dirSelect),
  .toolbar .sort-controls label:has(#randomizerDir),
  .toolbar .filter-dropdown,
  .toolbar .randomizer-player-filter,
  .toolbar .preorder-status-filter-v92 {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }
}
/* compact-toolbar-controls-v98-css-end */


/* compact-toolbar-controls-v99-css-start */
.toolbar .sort-controls {
  gap: 8px;
}

.toolbar .sort-controls label,
.toolbar .filter-label,
.preorder-status-filter-v92 > label,
.randomizer-player-filter > label {
  gap: 4px;
  font-size: .7rem;
}

.toolbar .sort-controls input[type="search"],
.toolbar .sort-controls select,
.toolbar .site-search-input-v92,
.toolbar .site-search-input-v91,
.toolbar .site-search-input-v90,
.toolbar #gameSearchInput,
.toolbar #randomizerSearchInput,
.toolbar #preorderSearchInputV92,
.toolbar .filter-button,
.toolbar .randomizer-filter-button,
.toolbar .site-filter-button-v92,
.installment-table-head input {
  height: 42px !important;
  min-height: 42px !important;
  border-radius: 13px !important;
  font-size: .8rem !important;
}

.toolbar .sort-controls input[type="search"],
.toolbar .sort-controls select,
.toolbar .site-search-input-v92,
.toolbar .site-search-input-v91,
.toolbar .site-search-input-v90,
.toolbar #gameSearchInput,
.toolbar #randomizerSearchInput,
.toolbar #preorderSearchInputV92,
.installment-table-head input {
  padding: 0 12px !important;
}

.toolbar .filter-button,
.toolbar .randomizer-filter-button,
.toolbar .site-filter-button-v92 {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  padding: 0 34px 0 12px !important;
}

.toolbar .sort-controls label:has(#gameSearchInput),
.toolbar .sort-controls label:has(#randomizerSearchInput) {
  width: 220px !important;
  max-width: 220px !important;
}

.toolbar .sort-controls label:has(#preorderSearchInputV92) {
  width: 210px !important;
  max-width: 210px !important;
}

.toolbar .sort-controls label:has(#sortSelect),
.toolbar .sort-controls label:has(#randomizerSort) {
  width: 190px !important;
  max-width: 190px !important;
}

.toolbar .sort-controls label:has(#dirSelect),
.toolbar .sort-controls label:has(#randomizerDir) {
  width: 164px !important;
  max-width: 164px !important;
}

.toolbar .filter-dropdown,
.toolbar .randomizer-player-filter,
.toolbar .preorder-status-filter-v92 {
  width: 142px !important;
  min-width: 142px !important;
}

.randomizer-toolbar .sort-controls {
  padding-right: 10px;
}

.toolbar .sort-controls input[type="search"]::placeholder,
.toolbar .site-search-input-v92::placeholder,
.toolbar .site-search-input-v91::placeholder,
.toolbar .site-search-input-v90::placeholder,
.toolbar #gameSearchInput::placeholder,
.toolbar #randomizerSearchInput::placeholder,
.toolbar #preorderSearchInputV92::placeholder,
.installment-table-head input::placeholder {
  font-size: .8rem !important;
}

@media (max-width: 900px) {
  .randomizer-toolbar .sort-controls {
    padding-right: 0;
  }
}
/* compact-toolbar-controls-v99-css-end */


/* custom-toolbar-selects-v100-css-start */
.native-select-hidden-v100 {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.custom-select-v100 {
  position: relative;
  width: 100%;
}

.custom-select-button-v100 {
  width: 100%;
  height: 42px;
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line, #e5d7c7);
  border-radius: 13px;
  padding: 0 34px 0 12px;
  background: var(--paper-strong, #fffdf8);
  color: var(--ink, #2f251f);
  font: inherit;
  font-size: .8rem;
  font-weight: 750;
  line-height: 1;
  text-align: left;
  white-space: nowrap;
  position: relative;
}

.custom-select-button-v100::after {
  content: '⌄';
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-54%);
  color: var(--muted, #7c6d63);
  font-size: 1rem;
}

.custom-select-button-v100:focus-visible {
  border-color: rgba(143, 77, 45, .62);
  box-shadow: 0 0 0 4px rgba(143, 77, 45, .12);
  outline: none;
}

.custom-select-panel-v100 {
  position: absolute;
  z-index: 110;
  top: calc(100% + 8px);
  left: 0;
  min-width: 100%;
  width: max-content;
  max-width: min(260px, calc(100vw - 32px));
  display: grid;
  gap: 4px;
  padding: 8px;
  border: 1px solid var(--line, #e5d7c7);
  border-radius: 16px;
  background: var(--paper-strong, #fffdf8);
  box-shadow: 0 12px 28px rgba(70, 45, 26, .13);
}

.custom-select-panel-v100.hidden,
.custom-select-v100:not(.open) .custom-select-panel-v100 {
  display: none !important;
}

.custom-select-option-v100 {
  width: 100%;
  min-height: 36px;
  border: 0;
  border-radius: 11px;
  padding: 9px 32px 9px 10px;
  background: transparent;
  color: var(--ink, #2f251f);
  font: inherit;
  font-size: .82rem;
  font-weight: 750;
  line-height: 1.12;
  text-align: left;
  white-space: nowrap;
  position: relative;
}

.custom-select-option-v100:hover,
.custom-select-option-v100:focus-visible {
  background: rgba(143, 77, 45, .09);
  outline: none;
}

.custom-select-option-v100.active {
  color: var(--accent-dark, #6f321b);
  background: rgba(143, 77, 45, .11);
}

.custom-select-option-v100.active::after {
  content: '✓';
  position: absolute;
  right: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--accent-dark, #6f321b);
  font-weight: 900;
}

.randomizer-toolbar .custom-select-panel-v100 {
  right: 0;
  left: auto;
}

@media (max-width: 900px) {
  .custom-select-panel-v100,
  .randomizer-toolbar .custom-select-panel-v100 {
    left: 0;
    right: auto;
    width: 100%;
    max-width: 100%;
  }
}
/* custom-toolbar-selects-v100-css-end */


/* mobile-toolbar-layout-v103-css-start */
@media (max-width: 820px) {
  .toolbar {
    align-items: stretch !important;
  }

  .toolbar .sort-controls,
  .toolbar .sort-controls.randomizer-controls,
  .preorder-controls-v92 {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    justify-items: stretch !important;
    align-items: stretch !important;
    margin-top: 18px !important;
    padding-right: 0 !important;
  }

  .toolbar .sort-controls > label,
  .toolbar .sort-controls > div,
  .toolbar .filter-dropdown,
  .toolbar .randomizer-player-filter,
  .toolbar .preorder-status-filter-v92,
  .toolbar .sort-controls label:has(#gameSearchInput),
  .toolbar .sort-controls label:has(#randomizerSearchInput),
  .toolbar .sort-controls label:has(#preorderSearchInputV92),
  .toolbar .sort-controls label:has(#sortSelect),
  .toolbar .sort-controls label:has(#randomizerSort),
  .toolbar .sort-controls label:has(#dirSelect),
  .toolbar .sort-controls label:has(#randomizerDir) {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    display: grid !important;
    justify-self: stretch !important;
    text-align: left !important;
  }

  .toolbar .sort-controls input[type="search"],
  .toolbar .site-search-input-v92,
  .toolbar .filter-button,
  .toolbar .randomizer-filter-button,
  .toolbar .site-filter-button-v92,
  .custom-select-v100,
  .custom-select-button-v100 {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
  }

  .custom-select-panel-v100,
  .randomizer-toolbar .custom-select-panel-v100 {
    left: 0 !important;
    right: auto !important;
    width: 100% !important;
    max-width: 100% !important;
  }
}
/* mobile-toolbar-layout-v103-css-end */

/* library-refresh-v110-css-start */
.login-card #adminState {
  margin: 16px 0 0;
  line-height: 1.45;
}

.login-card #logoutButton:not(.hidden) {
  margin-top: 16px;
}

.login-card .admin-actions #logoutButton {
  margin-top: 0;
}

.library-summary-panel {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  align-items: center;
  padding: 22px 26px;
}

.summary-metric {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  min-height: 62px;
  padding: 0 22px;
  border-right: 1px solid rgba(229, 215, 199, 0.9);
}

.summary-metric:last-child {
  border-right: 0;
}

.summary-metric strong {
  display: block;
  color: var(--ink);
  font-family: "Noto Serif", Georgia, serif;
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  line-height: 1;
  font-weight: 600;
}

.summary-metric span:last-child {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 750;
}

.summary-icon {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.summary-icon-game {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%235f8a66' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6.4 9.4h3.2M8 7.8V11M15 9h.01M17.6 11h.01'/%3E%3Cpath d='M7.2 5.2h9.6c2.12 0 3.5 1.4 3.84 3.5l.9 5.6c.27 1.68-.78 3.1-2.24 3.1-1.08 0-1.72-.48-2.42-1.42l-.88-1.18H8l-.88 1.18c-.7.94-1.34 1.42-2.42 1.42-1.46 0-2.51-1.42-2.24-3.1l.9-5.6C3.7 6.6 5.08 5.2 7.2 5.2Z'/%3E%3C/g%3E%3C/svg%3E");
}

.summary-icon-expansion {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3.4l2.42 4.9 5.4.78-3.91 3.82.92 5.38L12 15.73l-4.83 2.55.92-5.38-3.91-3.82 5.4-.78L12 3.4Z' fill='none' stroke='%23b27a35' stroke-width='1.8' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.summary-icon-price {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%235f8a66' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3.2' y='6' width='17.6' height='12' rx='2.2'/%3E%3Cpath d='M3.2 9.4h17.6M7.2 14.6h3.8'/%3E%3C/g%3E%3C/svg%3E");
}

.library-filter-panel {
  padding: 22px 26px;
}

.library-filter-controls {
  display: grid !important;
  grid-template-columns: minmax(220px, 1.45fr) minmax(170px, 1fr) minmax(160px, 0.85fr) minmax(150px, 0.9fr) minmax(132px, auto);
  gap: 18px !important;
  align-items: end !important;
  width: 100%;
}

.library-filter-controls > label,
.library-filter-controls > div {
  min-width: 0;
}

.library-filter-controls input[type="search"],
.library-filter-controls .custom-select-v100,
.library-filter-controls .custom-select-button-v100,
.library-filter-controls .filter-button {
  width: 100% !important;
  min-width: 0 !important;
}

.reset-filters-button {
  min-height: 48px;
  border: 0;
  border-radius: 14px;
  padding: 0 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: rgba(245, 234, 223, 0.72);
  color: #b07432;
  font-weight: 850;
}

.reset-filters-button:hover {
  background: rgba(245, 234, 223, 0.96);
}

.reset-icon {
  width: 19px;
  height: 19px;
  flex: 0 0 19px;
  background: currentColor;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v7'/%3E%3Cpath d='M7.05 5.85a8 8 0 1 0 9.9 0'/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat;
}

.game-card .card-button,
.preorder-card .card-button {
  overflow: hidden !important;
  border-radius: inherit !important;
}

.game-card .cover,
.preorder-card .cover,
.game-card.showcase-card .cover,
.preorder-card .cover {
  position: relative !important;
  border-radius: 23px 23px 0 0 !important;
  overflow: hidden !important;
  background-clip: padding-box !important;
  transform: translateZ(0);
}

.game-card .cover img,
.preorder-card .cover img,
.game-card.showcase-card .cover img,
.preorder-card .cover img {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  border-radius: 0 !important;
  object-fit: cover !important;
  clip-path: inset(0);
  margin: 0 !important;
  transform: none !important;
}

.game-card.showcase-card .cover:not(.no-photo) img,
.game-card .cover:not(.no-photo) img,
.preorder-card .cover:not(.no-photo) img,
.cover:not(.no-photo) img {
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  margin: 0 !important;
  transform: none !important;
}

@media (max-width: 900px) {
  .library-summary-panel {
    grid-template-columns: 1fr;
    padding: 8px 20px;
  }

  .summary-metric {
    justify-content: flex-start;
    border-right: 0;
    border-bottom: 1px solid rgba(229, 215, 199, 0.9);
    padding: 16px 0;
  }

  .summary-metric:last-child {
    border-bottom: 0;
  }

  body:not(.is-admin) .preorder-summary-panel .summary-metric:first-child {
    border-bottom: 0 !important;
  }

  .preorder-filter-panel.library-filter-panel {
    padding-top: 12px !important;
  }

  .library-filter-controls {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .reset-filters-button {
    width: 100%;
  }
}
/* library-refresh-v110-css-end */

/* filter-polish-v111-css-start */
:root {
  --filter-field-height-v111: 56px;
  --filter-field-radius-v111: 16px;
  --filter-field-gap-v111: 22px;
}

.library-summary-panel,
.preorder-summary-panel,
.library-filter-panel,
.preorder-filter-panel {
  border-radius: 24px;
}

.filter-bar-controls {
  display: grid !important;
  gap: var(--filter-field-gap-v111) !important;
  align-items: center !important;
  width: 100%;
}

.library-filter-controls {
  grid-template-columns:
    minmax(280px, 1.35fr)
    minmax(190px, 0.95fr)
    minmax(180px, 0.85fr)
    minmax(180px, 0.9fr)
    minmax(150px, 0.62fr) !important;
}

.preorder-filter-controls {
  grid-template-columns:
    minmax(320px, 1fr)
    minmax(220px, 0.42fr)
    minmax(150px, 0.25fr) !important;
}

.filter-bar-controls > label,
.filter-bar-controls > div,
.filter-field-label,
.filter-search-field,
.filter-bar-controls .filter-dropdown,
.filter-bar-controls .preorder-status-filter-v92 {
  position: relative;
  display: grid !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  gap: 0 !important;
}

.filter-bar-controls .control-caption {
  position: absolute;
  z-index: 3;
  top: -8px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  min-height: 16px;
  padding: 0 6px;
  background: var(--paper, #fff8ee);
  color: var(--muted, #76695f);
  font-size: 0.74rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0;
}

.library-filter-controls .filter-label.control-caption {
  font-size: 0.74rem !important;
  font-weight: 650 !important;
}

.filter-search-field .control-caption {
  width: 1px;
  height: 1px;
  min-height: 0;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.filter-search-field::before {
  content: "";
  position: absolute;
  z-index: 2;
  left: 18px;
  top: 50%;
  width: 21px;
  height: 21px;
  transform: translateY(-50%);
  background: #9a8f86;
  pointer-events: none;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='10.5' cy='10.5' r='6.2'/%3E%3Cpath d='m15.2 15.2 5 5'/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat;
}

.filter-bar-controls input[type="search"],
.filter-bar-controls .site-search-input-v92,
.filter-bar-controls .custom-select-button-v100,
.filter-bar-controls .filter-button,
.filter-bar-controls .site-filter-button-v92,
.filter-bar-controls .randomizer-filter-button,
.filter-bar-controls .reset-filters-button {
  box-sizing: border-box !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: var(--filter-field-height-v111) !important;
  min-height: var(--filter-field-height-v111) !important;
  border-radius: var(--filter-field-radius-v111) !important;
  font-size: 0.95rem !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

.filter-bar-controls input[type="search"],
.filter-bar-controls .site-search-input-v92 {
  padding: 0 18px 0 54px !important;
}

.filter-bar-controls #gameSearchInput,
.filter-bar-controls #preorderSearchInputV92 {
  width: 100% !important;
  max-width: none !important;
  height: var(--filter-field-height-v111) !important;
  min-height: var(--filter-field-height-v111) !important;
  padding: 0 18px 0 54px !important;
  font-size: 0.95rem !important;
}

.filter-bar-controls .custom-select-button-v100,
.filter-bar-controls .filter-button,
.filter-bar-controls .site-filter-button-v92,
.filter-bar-controls .randomizer-filter-button {
  padding: 0 44px 0 18px !important;
}

.filter-bar-controls input[type="search"]::placeholder,
.filter-bar-controls .site-search-input-v92::placeholder {
  color: #a69a92 !important;
  font-size: 0.92rem !important;
  font-weight: 700 !important;
}

.filter-bar-controls .custom-select-button-v100::after,
.filter-bar-controls .filter-button::after,
.filter-bar-controls .site-filter-button-v92::after,
.filter-bar-controls .randomizer-filter-button::after {
  right: 17px !important;
  color: var(--muted, #76695f) !important;
}

.filter-bar-controls .reset-filters-button {
  border: 0 !important;
  padding: 0 18px !important;
  justify-self: stretch;
  background: rgba(245, 234, 223, 0.78) !important;
  color: #b07432 !important;
  box-shadow: none !important;
}

.filter-bar-controls .reset-filters-button:hover {
  background: rgba(245, 234, 223, 1) !important;
}

.reset-icon {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  background: currentColor;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7.2 7.35a7 7 0 1 1-1.58 7.45'/%3E%3Cpath d='M7.25 3.75v3.6h3.6'/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat !important;
}

.summary-icon-preorder {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23b27a35' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='5.5' width='16' height='15' rx='2.4'/%3E%3Cpath d='M8 3.5v4M16 3.5v4M4 10h16M8 14h2.2M13.8 14H16M8 17h2.2'/%3E%3C/g%3E%3C/svg%3E");
}

.summary-icon-installment {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%235f8a66' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3.5' y='6' width='17' height='12.5' rx='2.2'/%3E%3Cpath d='M3.5 9.8h17M7.5 14.4h3.2M16.2 14.3h.01'/%3E%3C/g%3E%3C/svg%3E");
}

.game-card.showcase-card,
.preorder-card {
  overflow: hidden !important;
  border-radius: 24px !important;
  background: rgba(255, 252, 247, 0.96) !important;
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  mask-image: radial-gradient(white, black);
}

.game-card.showcase-card .card-button,
.preorder-card .card-button {
  overflow: hidden !important;
  border-radius: inherit !important;
  background: inherit !important;
}

.game-card.showcase-card .cover,
.game-card .cover,
.preorder-card .cover {
  position: relative !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  line-height: 0 !important;
  transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  mask-image: radial-gradient(white, black);
}

.game-card.showcase-card .cover img,
.game-card .cover img,
.preorder-card .cover img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  object-fit: cover !important;
  transform: none !important;
}

@media (max-width: 900px) {
  .filter-bar-controls,
  .library-filter-controls,
  .preorder-filter-controls {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .library-filter-panel,
  .preorder-filter-panel {
    padding: 20px !important;
  }

  .filter-bar-controls input[type="search"],
  .filter-bar-controls .site-search-input-v92,
  .filter-bar-controls .custom-select-button-v100,
  .filter-bar-controls .filter-button,
  .filter-bar-controls .site-filter-button-v92,
  .filter-bar-controls .randomizer-filter-button,
  .filter-bar-controls .reset-filters-button {
    height: 58px !important;
    min-height: 58px !important;
    border-radius: 18px !important;
    font-size: 1rem !important;
  }

  .filter-bar-controls #gameSearchInput,
  .filter-bar-controls #preorderSearchInputV92 {
    height: 58px !important;
    min-height: 58px !important;
    padding-left: 54px !important;
    font-size: 1rem !important;
  }
}
/* filter-polish-v111-css-end */

/* filter-and-cover-fixes-v112-css-start */
body:not(.is-admin) .admin-summary-metric {
  display: none !important;
}

body:not(.is-admin) .library-summary-panel .summary-metric:nth-child(2),
body:not(.is-admin) .preorder-summary-panel .summary-metric:nth-child(2) {
  border-right: 0 !important;
}

@media (min-width: 901px) {
  body:not(.is-admin) .library-summary-panel:not(.preorder-summary-panel) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body:not(.is-admin) .preorder-summary-panel {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.is-admin) .preorder-summary-panel .summary-metric:first-child {
    border-right: 0 !important;
  }
}

@media (min-width: 901px) {
  .library-filter-controls {
    grid-template-columns:
      minmax(390px, 1.45fr)
      minmax(260px, 1fr)
      minmax(250px, 0.95fr)
      minmax(250px, 0.95fr)
      minmax(190px, 0.7fr) !important;
    column-gap: 34px !important;
  }

  .randomizer-filter-controls {
    grid-template-columns:
      minmax(390px, 1.45fr)
      minmax(260px, 1fr)
      minmax(250px, 0.95fr)
      minmax(250px, 0.95fr) !important;
    column-gap: 34px !important;
  }
}

.randomizer-filter-controls {
  display: grid !important;
  align-items: center !important;
}

.toolbar .sort-controls.filter-bar-controls > label,
.toolbar .sort-controls.filter-bar-controls > div,
.toolbar .sort-controls.filter-bar-controls .filter-dropdown,
.toolbar .sort-controls.filter-bar-controls .randomizer-player-filter,
.toolbar .sort-controls.filter-bar-controls label:has(#randomizerSearchInput),
.toolbar .sort-controls.filter-bar-controls label:has(#randomizerSort),
.toolbar .sort-controls.filter-bar-controls label:has(#randomizerDir) {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
}

.filter-bar-controls #gameSearchInput,
.filter-bar-controls #randomizerSearchInput,
.filter-bar-controls #preorderSearchInputV92 {
  width: 100% !important;
  max-width: none !important;
  height: var(--filter-field-height-v111) !important;
  min-height: var(--filter-field-height-v111) !important;
  padding: 0 18px 0 54px !important;
  font-size: 0.95rem !important;
}

.filter-search-field::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='10.5' cy='10.5' r='6.2'/%3E%3Cpath d='m15.2 15.2 5 5'/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat;
}

.game-card.showcase-card .cover,
.game-card .cover,
.preorder-card .cover {
  border-bottom: 0 !important;
  background: transparent !important;
  box-sizing: border-box !important;
}

.game-card.showcase-card .cover:not(.no-photo),
.game-card .cover:not(.no-photo),
.preorder-card .cover:not(.no-photo),
.cover:not(.no-photo) {
  background: transparent !important;
}

#gamesGrid .game-card.showcase-card .cover,
#preordersGrid .preorder-card .cover {
  width: calc(100% + 2px) !important;
  margin: -1px -1px 0 !important;
}

#randomizerGrid .randomizer-card .cover {
  width: calc(100% + 2px) !important;
  margin: 0 -1px !important;
}

.game-card.showcase-card .cover img,
.game-card .cover img,
.preorder-card .cover img {
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
}

@media (max-width: 900px) {
  .filter-bar-controls,
  .library-filter-controls,
  .preorder-filter-controls,
  .randomizer-filter-controls {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .filter-bar-controls #gameSearchInput,
  .filter-bar-controls #randomizerSearchInput,
  .filter-bar-controls #preorderSearchInputV92 {
    height: 58px !important;
    min-height: 58px !important;
    padding-left: 54px !important;
    font-size: 1rem !important;
  }

  body:not(.is-admin) .library-summary-panel .summary-metric:nth-child(2),
  body:not(.is-admin) .preorder-summary-panel .summary-metric:nth-child(2) {
    border-bottom: 0 !important;
  }
}
/* filter-and-cover-fixes-v112-css-end */

/* desktop-filter-randomizer-cover-v113-css-start */
.randomizer-heading-panel {
  padding: 24px 30px;
}

.randomizer-heading-panel h2,
.randomizer-heading-panel p {
  margin-bottom: 0;
}

.randomizer-heading-panel p {
  margin-top: 6px;
}

.randomizer-filter-panel-shell {
  margin-top: 18px;
}

.randomizer-filter-panel-shell .randomizer-filter-controls {
  width: 100%;
}

.filter-bar-controls label:has(#gameSearchInput),
.filter-bar-controls label:has(#randomizerSearchInput),
.filter-bar-controls label:has(#preorderSearchInputV92) {
  width: 100% !important;
  max-width: none !important;
}

@media (min-width: 901px) {
  .filter-bar-controls,
  .library-filter-controls,
  .randomizer-filter-controls {
    max-width: 100% !important;
    overflow: visible !important;
  }

  .library-filter-controls {
    grid-template-columns:
      minmax(240px, 1.35fr)
      minmax(170px, 1fr)
      minmax(170px, 0.95fr)
      minmax(170px, 0.95fr)
      minmax(150px, 0.72fr) !important;
    column-gap: 24px !important;
  }

  .randomizer-filter-controls {
    grid-template-columns:
      minmax(240px, 1.35fr)
      minmax(170px, 1fr)
      minmax(170px, 0.95fr)
      minmax(170px, 0.95fr)
      minmax(150px, 0.72fr) !important;
    column-gap: 24px !important;
  }

  .summary-icon {
    width: 44px;
    height: 44px;
    flex-basis: 44px;
  }
}

#randomizerGrid .randomizer-card {
  overflow: hidden !important;
}

#randomizerGrid .randomizer-card-select-hint {
  height: 38px !important;
  min-height: 38px !important;
  padding: 0 14px !important;
  gap: 8px !important;
  border-radius: 0 !important;
  border-bottom: 1px solid rgba(229, 215, 199, 0.9) !important;
  background: rgba(255, 250, 243, 0.98) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  font-size: 0.78rem !important;
  line-height: 1 !important;
}

#randomizerGrid .randomizer-select-icon {
  width: 16px !important;
  height: 16px !important;
  flex-basis: 16px !important;
}

#randomizerGrid .randomizer-card .card-button {
  display: flex !important;
  flex-direction: column !important;
  margin-top: 0 !important;
  border-radius: 0 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

#randomizerGrid .randomizer-card .cover {
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  aspect-ratio: 1 / 1 !important;
}

#gamesGrid .game-card.showcase-card .cover img,
#preordersGrid .preorder-card .cover img,
#randomizerGrid .randomizer-card .cover img {
  inset: -1px !important;
  width: calc(100% + 2px) !important;
  height: calc(100% + 2px) !important;
  min-width: calc(100% + 2px) !important;
  min-height: calc(100% + 2px) !important;
  object-fit: cover !important;
}

@media (max-width: 900px) {
  .randomizer-heading-panel {
    padding: 20px;
  }

  .randomizer-filter-panel-shell {
    margin-top: 14px;
  }

  #randomizerGrid .randomizer-card-select-hint {
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    gap: 7px !important;
    font-size: 0.74rem !important;
  }

  #randomizerGrid .randomizer-select-icon {
    width: 15px !important;
    height: 15px !important;
    flex-basis: 15px !important;
  }

  #gamesGrid .game-card.showcase-card .cover,
  #preordersGrid .preorder-card .cover,
  #randomizerGrid .randomizer-card .cover {
    width: 100% !important;
    margin: 0 !important;
  }
}
/* desktop-filter-randomizer-cover-v113-css-end */

/* lighter-typography-v119-css-start */
body {
  font-weight: 400 !important;
}

h1 {
  font-size: 4.1rem !important;
  font-weight: 500 !important;
  line-height: 1.05 !important;
  letter-spacing: 0 !important;
  white-space: nowrap;
  margin-left: -5px;
}

h2,
h3 {
  font-weight: 650 !important;
}

.hero-text,
.muted,
.login-card p,
.card-meta,
.preorder-card .card-meta,
.installment-muted {
  font-weight: 400 !important;
}

.tab,
label,
.login-card label,
.manual-add summary,
.control-caption,
.metric-pill,
.badge,
.summary-metric span:last-child,
.showcase-title,
.card-content h3,
.preorder-card h3,
.randomizer-card-select-hint {
  font-weight: 650 !important;
}

button,
.button,
.tab,
.filter-button,
.randomizer-filter-button,
.site-filter-button-v92,
.reset-filters-button,
.icon-button,
.card-menu-trigger,
.randomizer-selected-chip {
  font-weight: 560 !important;
}

.summary-metric strong {
  font-weight: 500 !important;
}

.eyebrow {
  font-weight: 650 !important;
}

@media (max-width: 900px) {
  h1 {
    white-space: normal;
  }
}

@media (min-width: 901px) and (max-width: 1180px) {
  h1 {
    font-size: 3.15rem !important;
  }
}
/* lighter-typography-v119-css-end */

/* connected-desktop-hero-v120-css-start */
@media (min-width: 901px) {
  .hero {
    padding-top: 36px;
    padding-bottom: 0;
  }

  .hero .login-card {
    align-self: start;
  }

  .tabs {
    margin-top: -32px;
    margin-bottom: 26px;
  }
}

@media (min-width: 901px) and (max-width: 1180px) {
  .tabs {
    margin-top: -26px;
  }
}
/* connected-desktop-hero-v120-css-end */

/* mobile-cover-tightening-v125-css-start */
@media (max-width: 900px) {
  #gamesGrid .game-card.showcase-card,
  #preordersGrid .preorder-card,
  .detail-expansions-grid .game-card.showcase-card {
    overflow: hidden !important;
  }

  #gamesGrid .game-card.showcase-card .card-button,
  #preordersGrid .preorder-card .card-button,
  .detail-expansions-grid .game-card.showcase-card .card-button {
    overflow: hidden !important;
    border-radius: inherit !important;
    background: var(--paper, #fffaf3) !important;
  }

    #gamesGrid .game-card.showcase-card .cover,
    #gamesGrid .game-card .cover,
    #randomizerGrid .randomizer-card .cover,
    #preordersGrid .preorder-card .cover,
    .detail-expansions-grid .game-card.showcase-card .cover {
      width: calc(100% + 4px) !important;
      margin: -2px -2px 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

    #gamesGrid .game-card.showcase-card .cover img,
    #gamesGrid .game-card .cover img,
    #randomizerGrid .randomizer-card .cover img,
    #preordersGrid .preorder-card .cover img,
    .detail-expansions-grid .game-card.showcase-card .cover img {
      inset: -2px !important;
    width: calc(100% + 4px) !important;
    height: calc(100% + 4px) !important;
    min-width: calc(100% + 4px) !important;
    min-height: calc(100% + 4px) !important;
    object-fit: cover !important;
  }
}
/* mobile-cover-tightening-v125-css-end */

/* routed-pages-v134-css-start */
.tab {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.back-link {
  display: inline-flex;
  width: fit-content;
  color: var(--muted);
  font-weight: 650;
  text-decoration: none;
  margin-bottom: 18px;
}

.back-link:hover { color: var(--accent); }

.game-detail-page { padding-top: 0; }

.game-detail-panel {
  display: grid;
  gap: 26px;
}

.game-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.game-detail-head h2 {
  margin: 6px 0 0;
  font-size: clamp(34px, 4vw, 64px);
  line-height: 0.98;
  letter-spacing: 0;
}

@media (min-width: 901px) {
  .game-detail-head h2 {
    font-size: clamp(34px, 3.85vw, 60px);
  }
}

.detail-source-link {
  text-decoration: none;
  white-space: nowrap;
}

.game-detail-layout {
  display: grid;
  grid-template-columns: minmax(260px, 420px) minmax(0, 1fr);
  gap: 30px;
  align-items: start;
}

.game-detail-cover {
  border: 1px solid var(--line);
  border-radius: 28px;
  overflow: hidden;
  background: var(--card);
  box-shadow: var(--shadow);
}

.game-detail-cover img,
.game-detail-cover .no-photo {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

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

.game-detail-fields .wide { grid-column: 1 / -1; }

.game-detail-fields input:disabled,
.game-detail-fields textarea:disabled,
.game-detail-fields select:disabled {
  color: var(--ink);
  background: rgba(255, 252, 247, 0.68);
  opacity: 1;
}

.detail-save-row {
  display: flex;
  gap: 14px;
  align-items: center;
}

.detail-expansions-panel h2 { margin-top: 0; }
.detail-expansions-grid { margin-top: 18px; }
.lazy-image { background: rgba(255, 252, 247, 0.7); }

@media (max-width: 760px) {
  .game-detail-head { display: grid; }
  .game-detail-layout,
  .game-detail-fields { grid-template-columns: 1fr; }
  .game-detail-cover { border-radius: 22px; }
}
/* routed-pages-v134-css-end */

/* routed-detail-v136-css-start */
body.is-editing #detailLogoutButton,
body.is-editing #logoutButton {
  display: none !important;
}

:root {
  --detail-line-soft: rgba(126, 103, 83, 0.18);
}

.game-detail-readonly {
  display: grid;
  grid-template-columns: minmax(280px, 520px) minmax(0, 1fr);
  gap: 34px;
  align-items: start;
}

.game-detail-media {
  display: grid;
  gap: 16px;
  align-content: start;
}

.detail-cover-link {
  width: 100%;
  min-height: 54px;
  text-decoration: none;
}

.detail-cover-link-primary {
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
}

.detail-cover-link-primary:hover,
.detail-cover-link-primary:focus-visible {
  background: var(--accent-dark);
  border-color: var(--accent-dark);
  color: #fff;
}

.game-detail-edit-form {
  display: none;
}

body.is-editing .game-detail-readonly {
  display: none;
}

body.is-editing .game-detail-edit-form {
  display: grid;
}

.detail-info-list {
  display: grid;
  gap: 0;
  align-self: start;
  align-content: start;
}

.detail-info-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-bottom: 1px solid var(--detail-line-soft);
}

.detail-info-row:empty {
  display: none;
}

.detail-info-row-single {
  grid-template-columns: 1fr;
}

.detail-info-row:has(.detail-info-item:only-child) {
  grid-template-columns: 1fr;
}

.detail-info-item,
.detail-text-block {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  min-height: 78px;
  padding: 12px 20px;
  position: relative;
}

.detail-info-row .detail-info-item + .detail-info-item {
  border-left: 0;
}

.detail-info-row .detail-info-item + .detail-info-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 1px;
  background: var(--detail-line-soft);
}

.detail-info-item span:not(.detail-info-icon),
.detail-text-block span:not(.detail-info-icon) {
  display: block;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.detail-info-item strong {
  display: block;
  color: var(--ink);
  font-size: clamp(1.18rem, 1.65vw, 1.72rem);
  font-weight: 520;
  line-height: 1.08;
}

.detail-info-item strong .detail-fraction {
  display: inline;
  color: var(--muted);
  font-size: 0.72em;
  font-weight: 520;
  letter-spacing: 0;
  text-transform: none;
  margin: 0;
}

.detail-info-icon {
  width: 26px;
  height: 26px;
  color: var(--accent);
  background: currentColor;
  -webkit-mask: var(--detail-icon) center / contain no-repeat;
  mask: var(--detail-icon) center / contain no-repeat;
}

.detail-icon-star { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3.2l2.6 5.3 5.8.8-4.2 4.1 1 5.8-5.2-2.8-5.2 2.8 1-5.8-4.2-4.1 5.8-.8L12 3.2z' fill='none' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.detail-icon-rank { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 4h10v3.5c0 3.2-1.9 5.8-5 6.4-3.1-.6-5-3.2-5-6.4V4z' fill='none' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3Cpath d='M7 6H4.7c-.5 0-.9.4-.9.9 0 2.5 1.7 4.5 4.1 4.9M17 6h2.3c.5 0 .9.4.9.9 0 2.5-1.7 4.5-4.1 4.9M12 14v3.2M8.5 20h7M10 17.2h4' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.detail-icon-bars { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='4' y='15' width='3' height='5' rx='1' fill='black'/%3E%3Crect x='10.5' y='10' width='3' height='10' rx='1' fill='black'/%3E%3Crect x='17' y='5' width='3' height='15' rx='1' fill='black'/%3E%3C/svg%3E"); }
.detail-icon-ruble { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='12' cy='12' r='9' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M9 7h4.2a3 3 0 010 6H9m0 0h6M9 7v12m-2-3h8' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-user { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='12' cy='8' r='3.2' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M5.5 20c.5-4 3-6 6.5-6s6 2 6.5 6' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-users { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='9' cy='8' r='3' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M3 20c.5-4 2.8-6 6-6s5.5 2 6 6' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3Ccircle cx='17' cy='10' r='2.3' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M15.5 15c2.8.2 4.6 2 5 5' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-clock { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='12' cy='12' r='8.5' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M12 7v5l3.5 2' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-box { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 7.2L12 4l8 3.2v9.6L12 20l-8-3.2V7.2z' fill='none' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3Cpath d='M4.5 7.4L12 10.5l7.5-3.1M12 10.5V20' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-tag { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 5.5V12l7.7 7.7a2 2 0 002.8 0l5.2-5.2a2 2 0 000-2.8L12 4H5.5A1.5 1.5 0 004 5.5z' fill='none' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.4' fill='black'/%3E%3C/svg%3E"); }
.detail-icon-doc { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.5 3.5h7.2l3.8 3.8v13.2h-11V3.5z' fill='none' stroke='black' stroke-width='1.8' stroke-linejoin='round'/%3E%3Cpath d='M13.5 3.8v4h3.7M9.2 12.2h5.6M9.2 15.8h5.6' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.detail-icon-note { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 19l1.3-4.8L16.8 3.8a2.2 2.2 0 013.1 3.1L9.5 17.3 5 19z' fill='none' stroke='black' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.detail-icon-calendar { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='4' y='5' width='16' height='16' rx='3' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M8 3v4M16 3v4M4 10h16M8 14h2M14 14h2M8 17h2' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-card { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='3.5' y='6' width='17' height='12' rx='2.5' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M3.5 10h17M7 15h4' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }
.detail-icon-info { --detail-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='12' cy='12' r='8.5' fill='none' stroke='black' stroke-width='2'/%3E%3Cpath d='M12 10.5v6' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3Ccircle cx='12' cy='7.4' r='1.2' fill='black'/%3E%3C/svg%3E"); }

.detail-text-block {
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: start;
  min-height: auto;
  padding: 18px 20px;
  border-bottom: 1px solid var(--detail-line-soft);
}

.detail-info-row:last-child,
.detail-text-block:last-child {
  border-bottom: 0;
}

.detail-text-block p,
.preorder-payments-list p {
  margin: 0;
  color: var(--ink);
  font-size: 1.02rem;
  line-height: 1.55;
}

.preorder-payments-list {
  display: grid;
  gap: 8px;
}

.preorder-detail-panel .detail-info-list {
  align-content: start;
}

.detail-expansions-grid .card-button,
.detail-expansions-grid .showcase-title {
  text-decoration: none;
}

.detail-expansions-grid .cover {
  overflow: hidden;
  background: transparent !important;
}

.detail-expansions-grid .cover img,
.detail-expansions-grid .linked-expansion-card-v69 .cover img,
.detail-expansions-grid .game-card.showcase-card .cover img,
.detail-expansions-grid .game-card.showcase-card .cover:not(.no-photo) img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover !important;
}

.randomizer-selection-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  justify-content: flex-end;
}

.randomizer-clear-button {
  min-height: 46px;
  background: rgba(143, 95, 48, 0.09);
  color: var(--accent);
}

.randomizer-clear-button:hover,
.randomizer-clear-button:focus-visible {
  background: rgba(143, 95, 48, 0.14);
}

@media (max-width: 900px) {
  .game-detail-readonly {
    grid-template-columns: 1fr;
    gap: 22px;
  }

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

  .detail-info-row .detail-info-item + .detail-info-item {
    border-left: 0;
    border-top: 1px solid var(--detail-line-soft);
  }

  .detail-info-row .detail-info-item + .detail-info-item::before {
    display: none;
  }

  .detail-info-item {
    min-height: 72px;
    padding: 16px 4px;
  }

  .detail-text-block {
    padding: 18px 4px;
  }

  .randomizer-selection-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
    width: 100%;
  }

  .randomizer-selection-actions .button {
    width: 100%;
  }

  .randomizer-selection-actions .randomizer-clear-button.hidden + #randomizerPickButton {
    grid-column: 1 / -1;
  }
}

@media (min-width: 901px) {
  .detail-expansions-grid .game-card.showcase-card .showcase-title {
    font-size: clamp(1.08rem, 1.12vw, 1.32rem);
    line-height: 1.14;
  }
}
/* routed-detail-v136-css-end */

/* advanced-filters-and-genre-chips-v150-start */
.detail-info-item strong {
  font-size: clamp(1rem, 1.25vw, 1.34rem);
  line-height: 1.18;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.detail-info-item > div,
.detail-text-block > div {
  min-width: 0;
}

.detail-genre-pills,
.genre-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.genre-pill,
.genre-input-chip {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 252, 247, 0.98);
  color: var(--ink);
  font-size: 0.86rem;
  font-weight: 780;
  line-height: 1;
  white-space: nowrap;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin: 0 !important;
}

.genre-input-chip {
  border: 0;
  background: rgba(143, 77, 45, 0.1);
  color: var(--accent-dark);
  cursor: pointer;
}

.genre-input-chip span:last-child {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1;
}

.genre-chip-field {
  position: relative;
}

.genre-chip-input {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--paper-strong);
  padding: 7px 10px;
}

.genre-chip-input:focus-within {
  border-color: rgba(143, 77, 45, 0.42);
  box-shadow: 0 0 0 4px rgba(143, 77, 45, 0.1);
}

.genre-chip-input input {
  flex: 1 1 120px;
  min-width: 140px;
  min-height: 34px !important;
  height: 34px !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 2px !important;
  margin: 0 !important;
  line-height: 34px !important;
  border-radius: 0 !important;
  overflow: visible !important;
}

.genre-chip-input input::placeholder {
  line-height: 34px !important;
}

.advanced-filter-control {
  display: grid;
  gap: 6px;
}

.filter-bar-controls .advanced-filter-control > .control-caption {
  display: none !important;
}

.filter-bar-controls .control-caption {
  background: rgba(255, 250, 243, 0.82) !important;
  border-radius: 999px !important;
  padding: 1px 8px !important;
  box-shadow: 0 0 0 2px rgba(255, 250, 243, 0.42) !important;
}

.filter-bar-controls .advanced-filter-button,
.advanced-filter-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  min-width: 142px !important;
  height: var(--control-field-height, 54px) !important;
  min-height: var(--control-field-height, 54px) !important;
  border: 0 !important;
  border-radius: 18px !important;
  background: rgba(143, 77, 45, 0.1) !important;
  color: var(--accent-dark) !important;
  padding: 0 22px !important;
  font-weight: 850 !important;
  box-shadow: none !important;
}

.filter-bar-controls .advanced-filter-button::after,
.advanced-filter-button::after {
  display: none !important;
  content: none !important;
}

.advanced-filter-button::before {
  content: "";
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6h10M18 6h2M16 6a2 2 0 1 1-4 0 2 2 0 0 1 4 0ZM4 12h3M11 12h9M11 12a2 2 0 1 1-4 0 2 2 0 0 1 4 0ZM4 18h11M19 18h1M19 18a2 2 0 1 1-4 0 2 2 0 0 1 4 0Z' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6h10M18 6h2M16 6a2 2 0 1 1-4 0 2 2 0 0 1 4 0ZM4 12h3M11 12h9M11 12a2 2 0 1 1-4 0 2 2 0 0 1 4 0ZM4 18h11M19 18h1M19 18a2 2 0 1 1-4 0 2 2 0 0 1 4 0Z' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

.advanced-filter-button:hover,
.advanced-filter-button:focus-visible,
.advanced-filter-button.has-active-filters {
  background: rgba(143, 77, 45, 0.16) !important;
  color: var(--accent-dark) !important;
}

.advanced-filter-root {
  position: fixed;
  inset: 0;
  z-index: 300;
  pointer-events: none;
  visibility: hidden;
  transition: visibility 0s linear 240ms;
}

.advanced-filter-root:not(.hidden) {
  pointer-events: auto;
  visibility: visible;
  transition-delay: 0s;
}

.advanced-filter-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(45, 36, 29, 0.22);
  opacity: 0;
  transition: opacity 220ms ease;
}

.advanced-filter-root.is-open .advanced-filter-backdrop {
  opacity: 1;
}

.advanced-filter-drawer {
  position: absolute;
  top: 0;
  right: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  width: min(440px, calc(100vw - 28px));
  height: 100%;
  background: var(--paper);
  border-left: 1px solid var(--line);
  box-shadow: -24px 0 50px rgba(70, 45, 26, 0.18);
  transform: translateX(100%);
  transition: transform 260ms cubic-bezier(.22, .74, .22, 1);
}

.advanced-filter-root.is-open .advanced-filter-drawer {
  transform: translateX(0);
}

.advanced-filter-head,
.advanced-filter-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
}

.advanced-filter-actions {
  border-top: 1px solid var(--line);
  border-bottom: 0;
}

.advanced-filter-head h2 {
  margin: 0;
  font-size: 1.25rem;
}

.advanced-filter-body {
  overflow: auto;
  padding: 18px 22px 24px;
}

.advanced-filter-section {
  padding: 18px 0;
  border-bottom: 1px solid rgba(229, 215, 199, 0.82);
}

.advanced-filter-section:first-child {
  padding-top: 0;
}

.advanced-filter-section h3 {
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.advanced-filter-empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.advanced-filter-checks {
  display: grid;
  gap: 9px;
}

.advanced-filter-more {
  margin: 12px 0 0;
  border: 0;
  background: transparent;
  color: var(--accent-dark);
  padding: 0;
  font: inherit;
  font-weight: 850;
  cursor: pointer;
}

.advanced-filter-more:hover,
.advanced-filter-more:focus-visible {
  color: var(--accent);
  outline: none;
}

.advanced-filter-checks label,
.advanced-filter-segment label {
  display: flex;
  gap: 10px;
  align-items: center;
  color: var(--ink);
  font-weight: 650;
}

.advanced-filter-checks label[hidden] {
  display: none !important;
}

.advanced-filter-checks input,
.advanced-filter-segment input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.advanced-filter-segment {
  display: grid;
  gap: 10px;
}

.advanced-range {
  display: grid;
  gap: 16px;
}

.advanced-range-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.advanced-range-head span {
  height: 2px;
  background: #b8afa8;
}

.advanced-range-head input {
  width: 100%;
  height: 46px;
  border: 1px solid #bbb7b3;
  border-radius: 8px;
  background: var(--paper-strong);
  color: var(--ink);
  padding: 0 12px;
  font-weight: 720;
}

.advanced-range-sliders {
  --range-thumb-size: 24px;
  --range-thumb-inset: 28px;
  position: relative;
  height: 52px;
  margin: 0;
  overflow: visible;
}

.advanced-range-rail,
.advanced-range-track {
  position: absolute;
  left: var(--range-thumb-inset);
  right: var(--range-thumb-inset);
  top: 50%;
  transform: translateY(-50%);
  border-radius: 999px;
}

.advanced-range-rail {
  height: 3px;
  background: #dacabc;
}

.advanced-range-track {
  height: 6px;
  background: var(--accent);
  z-index: 1;
}

.advanced-range-thumb {
  position: absolute;
  top: 50%;
  width: var(--range-thumb-size);
  height: var(--range-thumb-size);
  border: 3px solid var(--accent);
  border-radius: 50%;
  background: var(--paper-strong);
  box-shadow: 0 0 0 5px var(--paper), 0 3px 8px rgba(70, 45, 26, 0.18);
  transform: translate(-50%, -50%);
  z-index: 3;
  padding: 0;
  cursor: grab;
  touch-action: none;
}

.advanced-range-thumb:active {
  cursor: grabbing;
}

.advanced-range.is-collapsed [data-range-thumb="max"] {
  opacity: 0;
  pointer-events: none;
}

body.advanced-filter-open {
  overflow: hidden;
}

@media (max-width: 640px) {
  .advanced-filter-drawer {
    width: min(390px, calc(100vw - 14px));
  }

  .advanced-filter-head,
  .advanced-filter-actions,
  .advanced-filter-body {
    padding-left: 16px;
    padding-right: 16px;
  }
}
/* advanced-filters-and-genre-chips-v150-end */
