:root {
  --bg: #0c0d10;
  --panel: #17181c;
  --panel-2: #1d1f24;
  --panel-3: #23252b;
  --border: rgba(255,255,255,0.08);
  --text: #f1f2f4;
  --muted: #a4a8b1;
  --soft: #7d8088;
  --blue: #1ea8ff;
  --blue-2: #1188dc;
  --shadow: 0 22px 60px rgba(0,0,0,0.35);
  --radius: 18px;
  --radius-sm: 12px;
}
* { box-sizing: border-box; }

html, body { margin: 0; min-height: 100%; background: #0b0c0f; color: var(--text); font-family: Inter, Arial, sans-serif; }
body[data-theme="light"] {
  --bg: #eef2f7;
  --panel: #ffffff;
  --panel-2: #f6f8fb;
  --panel-3: #edf1f7;
  --border: rgba(15,23,42,0.10);
  --text: #111827;
  --muted: #5b6472;
  --soft: #758093;
  --shadow: 0 20px 50px rgba(15, 23, 42, 0.10);
  background: #edf2f8;
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
body { padding: 14px; }
.topbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; margin-bottom: 14px; padding: 10px 14px;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: linear-gradient(180deg, #17191f, #111319); box-shadow: var(--shadow);
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand__mark {
  width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center;
  background: linear-gradient(180deg, #1ea8ff, #0f73cf); color: #fff; font-weight: 800;
}
.brand__title { font-weight: 700; letter-spacing: 0.02em; }
.brand__subtitle { font-size: 12px; color: var(--muted); }
.topbar__actions { display: flex; align-items: center; gap: 10px; }
.pill {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; border-radius: 999px;
  background: rgba(30,168,255,0.12); color: #9fd8ff; border: 1px solid rgba(30,168,255,0.16);
  font-size: 13px;
}
.flash-stack { display: grid; gap: 10px; margin-bottom: 14px; }
.flash {
  border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; background: #17191f;
}
.flash--success { border-color: rgba(74, 222, 128, 0.26); }
.flash--error { border-color: rgba(251, 113, 133, 0.28); }

.maker-layout {
  display: grid; grid-template-columns: 410px minmax(0,1fr); gap: 18px; align-items: start;
}
.maker-sidebar { display: grid; gap: 14px; }
.maker-stage { min-width: 0; }

.mw-card, .panel, .subpanel, .viewer-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #1a1c21, #14161b);
  box-shadow: var(--shadow);
}
.mw-card, .panel, .subpanel { padding: 14px; }
.panel--flat { padding: 16px; margin-top: 18px; }
.mw-card__header, .panel__header { margin-bottom: 12px; }
.mw-card__header--split, .panel__header--split {
  display: flex; justify-content: space-between; gap: 12px; align-items: flex-start;
}
.mw-card h2, .panel h2, .subpanel h2 {
  margin: 0; font-size: 15px; font-weight: 700;
}
.mw-card p, .panel p, .subpanel p { margin: 6px 0 0; color: var(--muted); font-size: 13px; line-height: 1.45; }

.selected-model {
  display: grid; grid-template-columns: 112px minmax(0,1fr); gap: 12px; padding: 10px;
  border-radius: 14px; background: #202329; border: 1px solid rgba(255,255,255,0.06); margin-bottom: 0; align-items: center;
}
.selected-model__thumb {
  height: 112px; border-radius: 12px; position: relative; overflow: hidden;
  background: linear-gradient(180deg, #171a20 0%, #101318 100%);
  border: 1px solid rgba(255,255,255,0.06);
}
.selected-model__thumb--viewer, .selected-model__thumb--image { display:flex; align-items:center; justify-content:center; background: radial-gradient(circle at 50% 18%, #222831 0%, #151922 50%, #10141b 100%); border-radius: 14px; overflow: hidden; position: relative; padding: 8px; }
.selected-model__thumb--viewer canvas { display: block; width: 100%; height: 100%; pointer-events: none; }
.selected-model__thumb-image { display:block; width:auto; height:auto; max-width:100%; max-height:100%; object-fit:contain; object-position:center center; margin:auto; background: transparent; }
.selected-model__name { font-size: 18px; font-weight: 700; line-height: 1.2; margin-bottom: 8px; }
.selected-model__subtitle { color: var(--muted); font-size: 13px; line-height: 1.4; }
.selected-model__thumb-actions { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.selected-model__thumb-actions .btn { padding: 8px 10px; }
.selected-model--text-only {
  grid-template-columns: minmax(0,1fr);
  align-items: start;
  justify-items: stretch;
  padding: 8px 10px;
}
.selected-model--text-only .selected-model__meta {
  min-width: 0;
  width: 100%;
}

.selected-model--text-only .selected-model__meta {
  display: block;
  width: 100%;
  max-width: none;
  min-width: 0;
}
.selected-model--text-only .selected-model__name,
.selected-model--text-only .selected-model__subtitle,
.selected-model--text-only .selected-model__thumb-actions {
  width: 100%;
  max-width: none;
}
.selected-model--text-only .selected-model__subtitle {
  margin-top: 4px;
}
.selected-model--text-only .selected-model__thumb { display:none !important; }
.selected-model--text-only .selected-model__name {
  margin-bottom: 6px;
}
.selected-model--text-only .selected-model__subtitle {
  margin-right: 0;
}
.selected-model--text-only .selected-model__thumb-actions {
  margin-top: 8px;
}

.input, .textarea, select.input {
  width: 100%; border: 1px solid rgba(255,255,255,0.10); background: #202228; color: var(--text);
  border-radius: 10px; padding: 11px 12px; outline: none; transition: border-color .18s ease, box-shadow .18s ease;
}
.input:focus, .textarea:focus, select.input:focus { border-color: rgba(30,168,255,0.5); box-shadow: 0 0 0 3px rgba(30,168,255,0.12); }
.input--dark { background: #17191e; }
.textarea { min-height: 120px; resize: vertical; }
.textarea--code { min-height: 180px; font-family: ui-monospace, SFMono-Regular, Consolas, monospace; }
.form-stack { display: grid; gap: 12px; }
.form-stack--small { max-width: 540px; }
.form-stack label, .field label { display: grid; gap: 6px; font-size: 13px; color: var(--muted); }
.field { display: grid; gap: 6px; }
.field small { color: #7b8089; }

.template-list { display: grid; gap: 10px; max-height: 360px; overflow: auto; padding-right: 4px; }
.template-list--compact { max-height: 218px; }
.template-list--modal { max-height: 58vh; }
.template-item {
  width: 100%; text-align: left; border: 1px solid rgba(255,255,255,0.06); background: #202329; color: var(--text);
  border-radius: 14px; padding: 12px; cursor: pointer; transition: transform .14s ease, border-color .14s ease, background .14s ease;
}
.template-item:hover { transform: translateY(-1px); border-color: rgba(255,255,255,0.14); }
.template-item.active { border-color: rgba(30,168,255,0.48); background: linear-gradient(180deg, rgba(30,168,255,0.12), rgba(30,168,255,0.05)); }
.template-item__title { font-weight: 700; font-size: 14px; margin-bottom: 6px; }
.template-item__meta { color: var(--muted); font-size: 12px; line-height: 1.45; }
.template-item__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
.tag {
  display: inline-flex; align-items: center; padding: 4px 8px; border-radius: 999px;
  background: #17191e; border: 1px solid rgba(255,255,255,0.06); color: #cfd2d8; font-size: 11px;
}

.hero-stats { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.hero-stats--sidebar { margin-top: 12px; }
.stat-card {
  border-radius: 12px; background: #1f2127; border: 1px solid rgba(255,255,255,0.05); padding: 10px 11px;
}
.stat-card__label { font-size: 11px; color: var(--soft); text-transform: uppercase; letter-spacing: 0.10em; }
.stat-card__value { font-size: 16px; font-weight: 700; margin-top: 5px; }

.dynamic-form { display: grid; gap: 14px; }
.dynamic-form--scroll { max-height: 480px; overflow: auto; padding-right: 4px; }
.form-group {
  border: 1px solid rgba(255,255,255,0.05); background: #1d2026; border-radius: 14px; padding: 12px;
}
.form-group__title { margin: 0 0 12px; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: #d7dbe3; }
.toggle { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); cursor: pointer; }
.toggle input { accent-color: var(--blue); }
.toggle--subtle { font-size: 12px; }
.sidebar-actions { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 8px; margin-top: 14px; }
.inline-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.wrap-actions { align-items: center; }

.btn {
  border: 1px solid transparent; border-radius: 11px; padding: 11px 14px; cursor: pointer;
  background: linear-gradient(180deg, var(--blue), var(--blue-2)); color: #fff; font-weight: 700;
  transition: transform .12s ease, filter .12s ease, background .12s ease, border-color .12s ease;
}
.btn:hover { filter: brightness(1.04); transform: translateY(-1px); }
.btn--ghost {
  background: #23262d; color: #eef0f4; border-color: rgba(255,255,255,0.08);
}
.btn--small { padding: 8px 10px; font-size: 12px; }


.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 16px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(19, 22, 29, 0.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 34px rgba(0,0,0,0.18);
}
.admin-toolbar__btn {
  border: 1px solid rgba(255,255,255,0.08);
  background: #202329;
  color: #eef0f4;
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 700;
  cursor: pointer;
  transition: transform .12s ease, filter .12s ease, border-color .12s ease, background .12s ease;
}
.admin-toolbar__btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  border-color: rgba(30,168,255,0.28);
  background: linear-gradient(180deg, rgba(30,168,255,0.16), rgba(30,168,255,0.08));
}
.admin-toolbar__btn--with-badge { position: relative; padding-right: 42px; }
.admin-toolbar__badge {
  position: absolute; top: -7px; right: -6px; min-width: 22px; height: 22px; padding: 0 6px;
  border-radius: 999px; background: #ef4444; color: #fff; font-size: 12px; font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 8px 20px rgba(239,68,68,0.34);
}
.status-dot {
  display: inline-block; width: 9px; height: 9px; border-radius: 50%; vertical-align: middle; margin-left: 6px;
}
.status-dot--new { background: #ef4444; box-shadow: 0 0 0 4px rgba(239,68,68,0.16); }
.admin-window__body {
  display: grid;
  gap: 16px;
}
.modal__dialog--admin-window {
  width: min(1120px, calc(100vw - 32px));
  max-height: calc(100vh - 40px);
}
.modal__dialog--admin-wide {
  width: min(1240px, calc(100vw - 32px));
}
.modal__dialog--admin-medium {
  width: min(980px, calc(100vw - 32px));
}
.modal__dialog--admin-small {
  width: min(640px, calc(100vw - 32px));
}
.admin-pricing-form {
  max-width: none;
}
.admin-panel-modal .request-list {
  max-height: min(62vh, 720px);
  overflow: auto;
  padding-right: 4px;
}
.admin-panel-modal .subpanel,
.admin-panel-modal .info-card,
.admin-panel-modal .request-card,
.admin-panel-modal .pricing-row,
.admin-panel-modal .pricing-select-group {
  background: #1b1f25;
}
@media (max-width: 980px) {
  .admin-toolbar {
    position: sticky;
    top: 8px;
    z-index: 20;
  }
}

.viewer-card { position: relative; padding: 0; overflow: hidden; min-height: calc(100vh - 120px); box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 18px 40px rgba(0,0,0,0.28); }
#viewer { width: 100%; min-height: calc(100vh - 120px); height: calc(100vh - 120px); background: radial-gradient(circle at 50% 14%, #1e232d 0%, #11151b 48%, #090b10 100%); }
#viewer canvas, .selected-model__thumb--viewer canvas { image-rendering: auto; }
.viewer-color-palette {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 6;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  max-width: min(200px, calc(100% - 28px));
  padding: 9px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(10,12,16,0.70);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.28);
}
.viewer-color-palette .color-swatch {
  width: 16px;
  height: 16px;
  min-height: 16px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.30);
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  transform: none;
  gap: 0;
}
.viewer-color-palette .color-swatch:hover {
  transform: scale(1.08);
  border-color: rgba(255,255,255,0.56);
  background: transparent;
}
.viewer-color-palette .color-swatch.is-active {
  border-color: rgba(255,255,255,0.96);
  box-shadow: 0 0 0 2px rgba(30,168,255,0.30);
  background: transparent;
}
.viewer-color-palette .color-swatch__dot {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  border: none;
}
.viewer-color-palette .color-swatch__label {
  display: none;
}
.viewer-badge {
  position: absolute; top: 16px; right: 16px; padding: 8px 12px; border-radius: 999px;
  background: rgba(0,0,0,0.38); border: 1px solid rgba(255,255,255,0.08); color: #d7dbe2; font-size: 12px;
}
.viewer-help {
  position: absolute; left: 50%; bottom: 14px; transform: translateX(-50%);
  display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; max-width: calc(100% - 30px);
}
.viewer-help span {
  padding: 7px 10px; border-radius: 10px; background: rgba(0,0,0,0.42);
  border: 1px solid rgba(255,255,255,0.08); color: #cfd4dc; font-size: 12px;
}
.code-card--compact pre {
  margin: 0; max-height: 220px; overflow: auto; border-radius: 12px; background: #101217; color: #d8dde6;
  border: 1px solid rgba(255,255,255,0.06); padding: 12px; font-size: 12px; line-height: 1.6;
}

.lower-stack { margin-top: 18px; }
.tab-buttons { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.tab-button {
  border: 1px solid rgba(255,255,255,0.08); background: #202329; color: #d7dbe3; border-radius: 10px;
  padding: 10px 14px; cursor: pointer; font-weight: 600;
}
.tab-button.active { background: linear-gradient(180deg, rgba(30,168,255,0.16), rgba(30,168,255,0.08)); border-color: rgba(30,168,255,0.28); color: #fff; }
.tab-content { display: none; }
.tab-content.active { display: block; }
.two-cols { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.three-stack { display: grid; gap: 16px; }
.request-list { display: grid; gap: 10px; }
.info-card {
  border: 1px solid rgba(255,255,255,0.07); border-radius: 12px; padding: 12px; background: #202329; color: var(--muted);
}
.request-card {
  border: 1px solid rgba(255,255,255,0.07); border-radius: 14px; padding: 12px; background: #202329;
}
.request-card__title { font-weight: 700; margin-bottom: 6px; }
.request-card__meta, .request-card__body { color: var(--muted); font-size: 13px; line-height: 1.5; }
.no-pad-header { margin-bottom: 12px; }

.auth-page { min-height: calc(100vh - 110px); display: grid; place-items: center; }
.auth-card {
  width: min(440px, 100%); border: 1px solid var(--border); border-radius: 22px; background: #17191f;
  box-shadow: var(--shadow); padding: 24px;
}
.auth-card h1 { margin: 0 0 10px; }
.auth-card p { margin: 0 0 16px; color: var(--muted); }
.auth-form { display: grid; gap: 12px; }
.link-back { display: inline-block; margin-top: 14px; color: #8ed0ff; }

@media (max-width: 1180px) {
  .maker-layout { grid-template-columns: 1fr; }
  .viewer-card, #viewer { min-height: 62vh; height: 62vh; }
}
@media (max-width: 760px) {
  body { padding: 10px; }
  .topbar { flex-direction: column; align-items: flex-start; }
  .selected-model { grid-template-columns: 1fr; }
  .sidebar-actions, .two-cols { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .viewer-help { position: static; transform: none; padding: 10px; }
}


body.user-mode { overflow: hidden; height: 100vh; }
body.user-mode .flash-stack { display: none; }
.user-mode .maker-layout { height: calc(100vh - 94px); align-items: stretch; }
.user-mode .maker-sidebar,
.user-mode .maker-stage { min-height: 0; }
.user-mode .maker-sidebar { grid-template-rows: auto minmax(0, 1fr); }
.user-mode .customize-card { display: flex; flex-direction: column; min-height: 0; }
.user-mode .dynamic-form--scroll { flex: 1 1 auto; min-height: 0; max-height: none; }
.user-mode .viewer-card,
.user-mode #viewer { min-height: calc(100vh - 110px); height: calc(100vh - 110px); }
.user-mode .maker-layout .model-card { margin-bottom: 0; }
.sidebar-actions--user { margin-top: 12px; }
.modal.hidden { display: none; }
.modal { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(4,5,8,0.72); backdrop-filter: blur(4px); }
.modal__dialog { position: relative; width: min(760px, calc(100vw - 24px)); max-height: calc(100vh - 24px); overflow: auto; border: 1px solid var(--border); border-radius: 22px; background: linear-gradient(180deg, #1a1c21, #13151a); box-shadow: 0 24px 80px rgba(0,0,0,0.42); padding: 18px; }
.modal__dialog--models { width: min(860px, calc(100vw - 24px)); }
.model-picker { display: grid; gap: 12px; }
.modal__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
.modal__header h2 { margin: 0; font-size: 20px; }
.modal__header p { margin: 6px 0 0; color: var(--muted); }
.modal__close { width: 38px; height: 38px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.08); background: #23262d; color: #eef0f4; cursor: pointer; font-size: 18px; }
.modal__actions { display: flex; justify-content: flex-end; gap: 10px; }
.two-cols--modal { align-items: end; }
.empty-state { border: 1px dashed rgba(255,255,255,0.10); border-radius: 12px; padding: 14px; color: var(--muted); background: rgba(255,255,255,0.02); }

.customize-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}
.part-picker {
  display: grid;
  gap: 10px;
}
.part-picker__summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  background: #202329;
  color: #eef1f5;
  font-weight: 600;
}
.part-picker__summary::-webkit-details-marker { display: none; }
.part-picker__summary::after {
  content: '▾';
  color: var(--muted);
  transition: transform .16s ease;
}
.part-picker[open] .part-picker__summary::after { transform: rotate(180deg); }
.part-picker__list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}
.part-pill {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  background: #1c1f25;
  color: #e9edf2;
  padding: 10px 12px;
  cursor: pointer;
}
.part-pill:hover { border-color: rgba(255,255,255,0.14); }
.part-pill.active {
  border-color: rgba(30,168,255,0.45);
  background: linear-gradient(180deg, rgba(30,168,255,0.13), rgba(30,168,255,0.05));
}
.part-pill__name { font-weight: 600; font-size: 13px; }
.part-pill__meta { margin-top: 4px; color: var(--muted); font-size: 12px; }
@media (max-width: 1180px) {
  body.user-mode { overflow: auto; height: auto; }
  .user-mode .maker-layout { height: auto; }
  .user-mode .viewer-card, .user-mode #viewer { min-height: 58vh; height: 58vh; }
}


.sr-only {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.info-card--soft { background: #1a1d23; color: #c1c6ce; }
.file-picker { display: grid; gap: 8px; }
.file-picker__row {
  display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: center;
  border: 1px solid rgba(255,255,255,0.08); background: #1b1e24; border-radius: 14px; padding: 10px;
}
.file-picker__name {
  min-height: 44px; display: flex; align-items: center; padding: 0 12px;
  border-radius: 10px; background: #111318; border: 1px solid rgba(255,255,255,0.06);
  color: #cfd5dd; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.auth-page--premium {
  min-height: calc(100vh - 100px);
  display: grid;
  place-items: center;
}
.auth-shell {
  width: min(1080px, 100%);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 22px;
  align-items: stretch;
}
.auth-hero {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 28px;
  padding: 34px;
  background:
    radial-gradient(circle at top left, rgba(30,168,255,0.18), transparent 42%),
    radial-gradient(circle at bottom right, rgba(116,84,255,0.18), transparent 38%),
    linear-gradient(180deg, #15181d, #101217);
  box-shadow: var(--shadow);
}
.auth-hero__badge {
  display: inline-flex; padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 700;
  letter-spacing: 0.12em; color: #98d7ff; background: rgba(30,168,255,0.12); border: 1px solid rgba(30,168,255,0.18);
}
.auth-hero h1 { margin: 18px 0 14px; font-size: 42px; line-height: 1.05; }
.auth-hero p { margin: 0; max-width: 540px; color: #c1c7d0; font-size: 16px; line-height: 1.7; }
.auth-hero__features { display: grid; gap: 12px; margin-top: 28px; }
.auth-feature {
  display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-radius: 16px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); color: #eef1f5;
}
.auth-feature__dot {
  width: 12px; height: 12px; border-radius: 999px; background: linear-gradient(180deg, #5cc2ff, #1ea8ff);
  box-shadow: 0 0 0 6px rgba(30,168,255,0.10);
}
.auth-card--premium {
  width: 100%; max-width: none; display: flex; flex-direction: column; justify-content: center;
  padding: 30px; border-radius: 28px; background: linear-gradient(180deg, #171a20, #121419);
}
.auth-card__top { display: grid; gap: 18px; margin-bottom: 22px; }
.brand--auth { align-items: center; }
.auth-hint {
  border-radius: 16px; padding: 14px 16px; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06); color: #d0d5de; font-size: 14px;
}
.auth-form--premium { gap: 14px; }
.auth-form--premium label span { color: #c5cad2; font-size: 13px; font-weight: 600; }
.auth-submit { width: 100%; margin-top: 4px; min-height: 48px; }
@media (max-width: 960px) {
  .auth-shell { grid-template-columns: 1fr; }
  .auth-hero { padding: 24px; }
  .auth-hero h1 { font-size: 32px; }
}

.toast-host {
  position: fixed; right: 18px; bottom: 18px; z-index: 1200;
  display: grid; gap: 10px; pointer-events: none;
}
.toast {
  min-width: 260px; max-width: 420px; padding: 12px 14px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(18,20,25,0.96); color: #f2f4f8;
  box-shadow: 0 20px 40px rgba(0,0,0,0.28); transform: translateY(8px); opacity: 0;
  transition: opacity .2s ease, transform .2s ease;
}
.toast--visible { opacity: 1; transform: translateY(0); }

.model-header-actions { display:flex; align-items:center; gap:8px; }
.modal__dialog--compact { width: min(620px, calc(100vw - 24px)); }

.material-panel { margin-top: 12px; border: 1px solid rgba(255,255,255,0.05); background: #1d2026; border-radius: 14px; padding: 12px; display: grid; gap: 12px; }
.material-panel__header { margin: 0; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: #d7dbe3; font-weight: 700; }
.material-row { display: grid; gap: 8px; }
.material-row--inline { display: flex; align-items: center; justify-content: space-between; }
.material-label, .material-row__label { font-size: 13px; color: #d9dde5; }
.material-row__label { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.material-color-wrap { display:flex; align-items:center; gap:12px; }
.material-color-wrap--stacked { display:grid; align-items:stretch; gap:10px; }
#model-color-input { min-width: 180px; height: 40px; }
#model-color-value { font-size: 12px; color: var(--muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.color-swatches { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:8px; }
.color-swatch { display:flex; align-items:center; gap:10px; min-height:40px; padding:8px 10px; border-radius:12px; border:1px solid rgba(255,255,255,0.08); background:#171a20; color:#eef1f5; cursor:pointer; transition:transform .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease; }
.color-swatch:hover { transform:translateY(-1px); border-color:rgba(255,255,255,0.18); background:#1d2128; }
.color-swatch.is-active { border-color:rgba(30,168,255,0.42); background:rgba(30,168,255,0.10); box-shadow:0 0 0 1px rgba(30,168,255,0.10) inset; }
.color-swatch__dot { width:18px; height:18px; border-radius:999px; border:1px solid rgba(255,255,255,0.18); flex:0 0 auto; }
.color-swatch__label { font-size:13px; font-weight:600; }
#model-opacity-input { width: 100%; accent-color: var(--blue); }

.input--readonly { display:flex; align-items:center; min-height:44px; background:#1d2026; color:#eef0f4; border:1px solid rgba(255,255,255,0.06); cursor:default; }
.template-item__select { all:unset; display:block; width:100%; cursor:pointer; }
.template-item__actions { display:flex; justify-content:flex-end; margin-top:10px; }

.assembly-parts-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.assembly-part-chip {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.07);
  background: #1c1f25;
  color: #eef1f5;
  cursor: pointer;
}
.assembly-part-chip.active {
  border-color: rgba(30,168,255,0.35);
  background: rgba(30,168,255,0.10);
}
.assembly-part-chip small {
  color: #a8b0bc;
  font-size: 12px;
}


.customer-topbar{display:flex;align-items:center;gap:12px}.customer-topbar__guest,.customer-topbar__auth{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.hidden{display:none!important}
.viewer-order-overlay{position:absolute;top:16px;right:16px;z-index:4;min-width:260px;max-width:min(320px,calc(100% - 32px));padding:14px 14px 12px;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(12,14,19,.78);backdrop-filter:blur(10px);box-shadow:0 18px 48px rgba(0,0,0,.28)}
.viewer-order-overlay__label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#98a2b8}.viewer-order-overlay__value{font-size:28px;font-weight:800;line-height:1.05;margin-top:8px}.viewer-order-overlay__hint{margin-top:8px;color:#a9b3c8;font-size:13px;line-height:1.45}.viewer-order-overlay__button{width:100%;margin-top:12px}
.success-card{display:grid;gap:10px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#1b1f26}.success-card__line{color:#e8edf6}.success-card__hint{margin-top:4px;color:#aab3c7;line-height:1.5}.order-details{margin-top:10px}.order-details summary{cursor:pointer;color:#d8def0}
.modal__dialog--orders{width:min(820px,calc(100vw - 24px))}
.price-breakdown{margin-top:12px;display:grid;gap:8px}.price-breakdown__row{display:flex;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.03);font-size:13px}
.auth-switcher{display:flex;gap:8px;margin-bottom:14px}.auth-switcher .is-active{background:rgba(255,255,255,.12)}
.form-stack label.checkbox-line, .checkbox-line{display:flex;flex-direction:row;gap:10px;align-items:center;font-size:13px;color:#cfd5e8;line-height:1.45}.form-stack label.checkbox-line{gap:10px}.checkbox-line input{margin:0;flex:0 0 auto;align-self:center}.checkbox-line span{display:block;flex:1 1 auto;margin:0}.checkbox-line a{color:#c2d1ff}
.doc-page{padding:28px}.doc-card{max-width:920px;margin:0 auto;padding:28px;border-radius:24px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}.doc-section+ .doc-section{margin-top:18px}
.pricing-fields{display:grid;gap:12px}.pricing-row,.pricing-select-group{padding:12px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}.pricing-select-group{display:grid;gap:8px}.pricing-select-group__title{font-weight:600;margin-bottom:2px}
.json-preview{margin-top:10px;padding:12px;border-radius:14px;max-height:220px;overflow:auto;background:#0d111c;color:#b9c4e0;font-size:12px;line-height:1.45}
@media (max-width: 980px){.viewer-color-palette{top:12px;left:12px;max-width:calc(100% - 24px);padding:8px 10px;gap:7px}.viewer-order-overlay{top:12px;right:12px;left:12px;max-width:none;min-width:0}.customer-topbar__guest,.customer-topbar__auth{flex-wrap:wrap}}

.captcha-box {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1c1f25;
}
.captcha-box__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.captcha-box__label {
  font-size: 12px;
  color: var(--muted);
}
.captcha-box__question {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 10px;
  background: linear-gradient(180deg, #242833, #1a1d24);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 0.08em;
}
.honeypot-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.text-danger{color:#fca5a5;}

/* Builder layout inspired by configurable storage-style tools */
.maker-layout--builder {
  grid-template-columns: 380px minmax(0, 1fr);
  gap: 20px;
  align-items: stretch;
}
.builder-sidebar {
  position: sticky;
  top: 14px;
  max-height: calc(100vh - 34px);
  overflow: auto;
  padding-right: 4px;
}
.builder-card {
  background: linear-gradient(180deg, #171a20 0%, #11141a 100%);
}
.builder-card--compact .selected-model {
  grid-template-columns: 84px minmax(0,1fr);
}
.builder-card--compact .selected-model__thumb {
  height: 84px;
}
.section-kicker {
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #8ca4bb;
  margin-bottom: 6px;
}
.dynamic-form--builder {
  max-height: none;
  overflow: visible;
}
.form-group--builder {
  padding: 0;
  overflow: hidden;
}
.form-group--builder > summary {
  list-style: none;
  cursor: pointer;
}
.form-group__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #e9edf3;
}
.form-group__summary::-webkit-details-marker { display:none; }
.form-group__body {
  display: grid;
  gap: 12px;
  padding: 0 16px 16px;
}
.display-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
.display-chip,
.viewer-toolbar__btn {
  border: 1px solid rgba(255,255,255,0.08);
  background: #1c2129;
  color: #f1f5f9;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
  transition: .14s ease;
}
.display-chip:hover,
.viewer-toolbar__btn:hover {
  transform: translateY(-1px);
  border-color: rgba(30,168,255,0.28);
}
.display-chip.is-active,
.viewer-toolbar__btn.is-active {
  background: linear-gradient(180deg, rgba(30,168,255,0.22), rgba(30,168,255,0.10));
  border-color: rgba(30,168,255,0.46);
  color: #dff2ff;
}
.display-slider {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.display-slider label {
  font-size: 12px;
  color: var(--muted);
}
.display-slider input[type="range"] {
  width: 100%;
}
.viewer-axes-toggle {
  margin-top: 12px;
}
.display-dimensions {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.display-dimension-modes {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.part-dimensions-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.part-dimensions-row {
  display: grid;
  gap: 4px;
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #171c23;
  color: #eef2f7;
  cursor: pointer;
}
.part-dimensions-row.is-active {
  border-color: rgba(30,168,255,0.46);
  background: linear-gradient(180deg, rgba(30,168,255,0.18), rgba(30,168,255,0.06));
}
.part-dimensions-row.is-muted { opacity: 0.6; }
.part-dimensions-row__name {
  font-size: 12px;
  font-weight: 700;
}
.part-dimensions-row__value {
  font-size: 12px;
  color: #9fb0c4;
}
.summary-stack {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
.summary-card {
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  background: #1a1f27;
}
.summary-card__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .10em;
  color: #8f9bab;
  margin-bottom: 6px;
}
.summary-card__value {
  font-size: 14px;
  line-height: 1.35;
  font-weight: 700;
  color: #f4f7fb;
}
.summary-actions {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.builder-stage {
  min-height: calc(100vh - 32px);
}
.viewer-card--builder {
  min-height: calc(100vh - 34px);
}
.viewer-card--builder #viewer {
  min-height: calc(100vh - 34px);
  height: calc(100vh - 34px);
}
.viewer-toolbar {
  position: absolute;
  left: 16px;
  right: 16px;
  top: 16px;
  z-index: 7;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.viewer-toolbar__left,
.viewer-toolbar__right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.viewer-toolbar__pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(11,14,18,0.74);
  border: 1px solid rgba(255,255,255,0.12);
  color: #f6f8fb;
  font-size: 13px;
  font-weight: 700;
  backdrop-filter: blur(10px);
}
.viewer-toolbar__pill--muted {
  color: #b7c2d0;
  font-weight: 600;
}
.viewer-toolbar__btn {
  background: rgba(11,14,18,0.74);
  backdrop-filter: blur(10px);
}
.viewer-color-palette {
  top: 72px;
}
.template-item__select {
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  color: inherit;
  padding: 0;
  cursor: pointer;
}
@media (max-width: 1180px) {
  .maker-layout--builder {
    grid-template-columns: 1fr;
  }
  .builder-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
  }
  .viewer-card--builder,
  .viewer-card--builder #viewer {
    min-height: 74vh;
    height: 74vh;
  }
}
@media (max-width: 740px) {
  .summary-stack,
  .display-grid {
    grid-template-columns: 1fr;
  }
  .viewer-toolbar {
    left: 10px;
    right: 10px;
    top: 10px;
  }
  .viewer-color-palette {
    top: 120px;
    left: 10px;
    right: 10px;
    max-width: none;
    border-radius: 16px;
  }
}
.viewer-color-palette .color-swatch__label { display: none; }
.viewer-color-palette .color-swatch { width: 18px; height: 18px; min-height: 18px; border-radius: 999px; }
.viewer-color-palette .color-swatch__dot { width: 100%; height: 100%; border-radius: 999px; display:block; }


/* v30 builder layout fixes */
body.user-mode.builder-page {
  overflow: auto;
  height: auto;
  min-height: 100vh;
}
body.user-mode.builder-page .maker-layout--builder {
  height: auto;
  min-height: calc(100vh - 110px);
  align-items: start;
}
body.user-mode.builder-page .maker-sidebar,
body.user-mode.builder-page .maker-stage {
  min-height: auto;
}
body.user-mode.builder-page .maker-sidebar {
  grid-template-rows: none;
}
.maker-layout--builder {
  grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}
.builder-sidebar {
  position: relative;
  top: auto;
  max-height: none;
  overflow: visible;
  padding-right: 0;
}
.builder-card {
  overflow: hidden;
}
.builder-card--controls {
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.dynamic-form--builder {
  display: grid;
  gap: 12px;
  max-height: min(50vh, 620px);
  overflow: auto;
  padding-right: 4px;
}
.form-group--builder {
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  background: #141921;
}
.form-group__summary {
  padding: 15px 16px;
}
.form-group__body {
  padding: 0 16px 16px;
}
.builder-stage {
  position: sticky;
  top: 14px;
  align-self: start;
  min-height: auto;
}
.viewer-card--builder {
  min-height: calc(100vh - 110px);
}
.viewer-card--builder #viewer {
  min-height: calc(100vh - 110px);
  height: calc(100vh - 110px);
}
.viewer-toolbar {
  align-items: flex-start;
}
.viewer-toolbar__left,
.viewer-toolbar__right {
  row-gap: 8px;
}
.viewer-toolbar__pill,
.viewer-toolbar__btn {
  min-height: 36px;
  font-size: 12px;
}
.viewer-color-palette {
  top: 70px;
  left: 16px;
  max-width: 220px;
}
.viewer-badge {
  top: 72px;
}
.viewer-order-overlay {
  top: 70px;
}
.viewer-help {
  bottom: 12px;
}
.viewer-help span {
  font-size: 11px;
}
.viewer-dimensions {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}
.viewer-dimensions__label {
  position: absolute;
  transform: translate(-50%, -50%);
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(10,12,16,0.74);
  border: 1px solid rgba(255,255,255,0.08);
  color: #eef3f9;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
  white-space: nowrap;
  box-shadow: 0 8px 18px rgba(0,0,0,0.22);
}
.viewer-dimensions__line {
  stroke: rgba(233,239,247,0.80);
  stroke-width: 1.15;
  stroke-linecap: round;
}
.viewer-dimensions__guide {
  stroke: rgba(233,239,247,0.26);
  stroke-width: 1;
  stroke-dasharray: 4 4;
}
.viewer-dimensions__tick {
  stroke: rgba(233,239,247,0.80);
  stroke-width: 1.15;
  stroke-linecap: round;
}
@media (max-width: 1280px) {
  .maker-layout--builder {
    grid-template-columns: minmax(300px, 350px) minmax(0, 1fr);
  }
}
@media (max-width: 1180px) {
  body.user-mode.builder-page {
    overflow: auto;
  }
  .maker-layout--builder {
    grid-template-columns: 1fr;
  }
  .builder-stage {
    position: static;
  }
  .dynamic-form--builder {
    max-height: none;
    overflow: visible;
  }
  .viewer-card--builder,
  .viewer-card--builder #viewer {
    min-height: 68vh;
    height: 68vh;
  }
}
@media (max-width: 760px) {
  .viewer-toolbar {
    position: absolute;
    left: 10px;
    right: 10px;
    top: 10px;
    gap: 8px;
  }
  .viewer-color-palette {
    top: 98px;
    left: 10px;
    max-width: calc(100% - 20px);
  }
  .viewer-badge {
    display: none;
  }
  .viewer-order-overlay {
    top: 144px;
  }
  .summary-stack,
  .display-grid,
  .customize-actions,
  .summary-actions {
    grid-template-columns: 1fr;
  }
}


.theme-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.theme-toggle-btn__icon {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  font-size: 12px;
}
.builder-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 8px;
}
.builder-nav__item {
  border: 1px solid rgba(255,255,255,0.08);
  background: #1b2028;
  color: #eef2f6;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
}
.builder-nav__item.is-active {
  background: linear-gradient(180deg, rgba(30,168,255,0.22), rgba(30,168,255,0.08));
  border-color: rgba(30,168,255,0.42);
  color: #dff2ff;
}
.display-parts {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.display-parts__title {
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #95a3b8;
}
.display-parts__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.display-part-row {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 8px;
  align-items: stretch;
}
.display-part-row.is-selected .display-part-pick {
  border-color: rgba(30,168,255,0.46);
  background: linear-gradient(180deg, rgba(30,168,255,0.18), rgba(30,168,255,0.06));
}
.display-part-pick {
  display: grid;
  gap: 4px;
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1a1f26;
  color: #eef2f7;
  cursor: pointer;
}
.display-part-pick__name {
  font-size: 13px;
  font-weight: 700;
}
.display-part-pick__meta {
  font-size: 12px;
  color: #95a3b8;
}
.display-part-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1a1f26;
  color: #eef2f7;
  min-width: 116px;
}
.display-part-toggle__name {
  font-size: 12px;
  font-weight: 700;
}
.display-part-toggle__switch {
  width: 34px;
  height: 20px;
  border-radius: 999px;
  position: relative;
  background: rgba(255,255,255,0.12);
  transition: .14s ease;
}
.display-part-toggle__switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: white;
  transition: .14s ease;
}
.display-part-toggle.is-active .display-part-toggle__switch {
  background: rgba(30,168,255,0.42);
}
.display-part-toggle.is-active .display-part-toggle__switch::after {
  transform: translateX(14px);
}
.field__title-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.field__title-row label { gap:0; }

.field__reset-btn {
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: #cbd5e1;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: .15s ease;
  flex: 0 0 auto;
}
.field__reset-btn:hover {
  background: rgba(30,168,255,0.16);
  border-color: rgba(30,168,255,0.35);
  color: #eff6ff;
}
.field__number-controls {
  display: grid;
  grid-template-columns: minmax(68px, 84px) 1fr;
  gap: 8px;
  align-items: center;
}
.field__number-input {
  min-width: 0;
  max-width: 84px;
  padding-inline: 10px;
}
.field__range {
  width: 100%;
  accent-color: #1ea8ff;
  cursor: pointer;
}
@media (max-width: 760px) {
  .field__number-controls {
    grid-template-columns: 1fr;
  }
}
.field__hint-range {
  font-size: 11px;
  color: #7f8ba0;
  white-space: nowrap;
}
body[data-theme="light"] .topbar {
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}
body[data-theme="light"] .mw-card,
body[data-theme="light"] .panel,
body[data-theme="light"] .subpanel,
body[data-theme="light"] .viewer-card,
body[data-theme="light"] .builder-card {
  background: linear-gradient(180deg, #ffffff, #f7f9fc);
  border-color: rgba(15,23,42,0.09);
}
body[data-theme="light"] .selected-model,
body[data-theme="light"] .template-item,
body[data-theme="light"] .summary-card,
body[data-theme="light"] .form-group,
body[data-theme="light"] .display-part-toggle,
body[data-theme="light"] .display-chip,
body[data-theme="light"] .viewer-toolbar__btn,
body[data-theme="light"] .builder-nav__item,
body[data-theme="light"] .input,
body[data-theme="light"] .textarea,
body[data-theme="light"] select.input {
  background: #ffffff;
  color: #111827;
  border-color: rgba(15,23,42,0.10);
}
body[data-theme="light"] .display-chip.is-active,
body[data-theme="light"] .viewer-toolbar__btn.is-active,
body[data-theme="light"] .builder-nav__item.is-active {
  background: linear-gradient(180deg, rgba(30,168,255,0.16), rgba(30,168,255,0.06));
  color: #0f3c63;
}
body[data-theme="light"] .section-kicker,
body[data-theme="light"] .summary-card__label,
body[data-theme="light"] .display-parts__title,

body[data-theme="light"] .field__reset-btn {
  background: #ffffff;
  color: #475569;
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .field__reset-btn:hover {
  background: rgba(30,168,255,0.10);
  color: #0f3c63;
  border-color: rgba(30,168,255,0.30);
}
body[data-theme="light"] .field__hint-range,
body[data-theme="light"] .field small,
body[data-theme="light"] .brand__subtitle,
body[data-theme="light"] .mw-card p,
body[data-theme="light"] .panel p,
body[data-theme="light"] .subpanel p,
body[data-theme="light"] .form-stack label,
body[data-theme="light"] .field label {
  color: #64748b;
}
body[data-theme="light"] .viewer-toolbar__pill,
body[data-theme="light"] .viewer-dimensions__label,
body[data-theme="light"] .viewer-badge,
body[data-theme="light"] .viewer-order-overlay {
  background: rgba(255,255,255,0.82);
  color: #0f172a;
  border-color: rgba(15,23,42,0.10);
}
body[data-theme="light"] .viewer-help span {
  background: rgba(255,255,255,0.82);
  color: #334155;
}
@media (max-width: 760px) {
  .builder-nav,
  .display-parts__list { grid-template-columns: 1fr; }
  .display-part-row { grid-template-columns: 1fr; }
  .theme-toggle-btn__text { display:none; }
}


#parts-section-card .display-parts{margin-top:0;padding-top:0;border-top:0}
.display-dimension-modes{display:flex;flex-wrap:nowrap;gap:10px}
.display-dimension-modes--icons .display-chip{flex:1 1 0;min-width:0;justify-content:center}
.display-chip--icon{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;white-space:nowrap}
.display-chip__icon{font-size:16px;line-height:1}
.display-chip__text{font-size:13px;line-height:1}
#display-section-card .mw-card__header{margin-bottom:10px}
#display-section-card .display-dimensions{margin-top:0;padding-top:0;border-top:0}
@media (max-width: 900px){.display-dimension-modes{flex-wrap:wrap}}

.selected-model__thumb--viewer img { align-self: center; justify-self: center; }


.viewer-rotation-control {
  position: absolute;
  right: 16px;
  bottom: 18px;
  z-index: 4;
  width: auto;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
.viewer-rotation-control__title,
.viewer-joystick__hint,
.viewer-rotation-readout {
  display: none !important;
}
.viewer-joystick {
  position: relative;
  width: 88px;
  height: 88px;
  margin: 0;
  touch-action: none;
  user-select: none;
  border-radius: 50%;
  box-shadow: 0 10px 24px rgba(0,0,0,0.28);
}
.viewer-joystick__ring,
.viewer-joystick__pad {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}
.viewer-joystick__ring {
  border: 1px solid rgba(147, 197, 253, 0.28);
  box-shadow: inset 0 0 0 7px rgba(255,255,255,0.03), 0 0 0 1px rgba(0,0,0,0.20);
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.02) 54%, rgba(30,168,255,0.06) 55%, rgba(30,168,255,0.018) 72%, rgba(255,255,255,0.02) 100%);
}
.viewer-joystick__pad {
  inset: 14px;
  border: 1px solid rgba(255,255,255,0.07);
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.12), rgba(255,255,255,0.035) 42%, rgba(9,12,18,0.34) 100%);
}
.viewer-joystick__knob {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 26px;
  height: 26px;
  margin-left: -13px;
  margin-top: -13px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.17);
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.9), rgba(203,213,225,0.88) 35%, rgba(96,165,250,0.84) 100%);
  box-shadow: 0 6px 18px rgba(0,0,0,0.32);
  pointer-events: none;
}
.selected-model__thumb--image { min-height: 164px; }
@media (max-width: 900px) {
  .viewer-rotation-control { right: 12px; bottom: 14px; }
  .viewer-joystick { width: 78px; height: 78px; }
  .viewer-joystick__pad { inset: 12px; }
  .viewer-joystick__knob {
    width: 24px;
    height: 24px;
    margin-left: -12px;
    margin-top: -12px;
  }
}



.builder-card--compact .selected-model.selected-model--text-only {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  padding: 10px 12px;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__meta {
  width: 100%;
  display: block;
  min-width: 0;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__name,
.builder-card--compact .selected-model.selected-model--text-only .selected-model__subtitle {
  width: 100%;
  max-width: none;
  display: block;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__subtitle {
  margin-top: 4px;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__thumb-actions {
  width: 100%;
  justify-content: flex-start;
  margin-top: 6px;
}

.selected-model--text-only {
  min-height: 0;
  width: 100%;
}
.selected-model--text-only .selected-model__meta {
  flex: 1 1 auto;
}

/* v90 Three.js visual upgrade */
#viewer.viewer--three {
  background:
    radial-gradient(circle at 48% 8%, rgba(74, 94, 130, 0.52) 0%, rgba(22, 28, 38, 0.92) 34%, rgba(8, 10, 16, 1) 78%),
    linear-gradient(145deg, #111827 0%, #070a10 100%);
}
#viewer.viewer--three canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
  image-rendering: auto;
  outline: none;
}
.viewer-three-controls {
  position: absolute;
  right: 16px;
  bottom: 62px;
  z-index: 8;
  display: grid;
  gap: 10px;
  max-width: min(390px, calc(100% - 32px));
  pointer-events: auto;
}
.viewer-three-controls__group {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  background: rgba(8, 11, 17, 0.72);
  box-shadow: 0 18px 48px rgba(0,0,0,0.26);
  backdrop-filter: blur(12px);
}
.viewer-three-controls__group--section {
  flex-wrap: wrap;
}
.viewer-three-controls__btn,
.viewer-three-controls__select {
  min-height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.06);
  color: #edf5ff;
  font-size: 12px;
  font-weight: 800;
  padding: 0 11px;
  cursor: pointer;
  transition: transform .14s ease, border-color .14s ease, background .14s ease;
}
.viewer-three-controls__btn:hover,
.viewer-three-controls__select:hover {
  transform: translateY(-1px);
  border-color: rgba(56,189,248,0.38);
}
.viewer-three-controls__btn.is-active {
  background: linear-gradient(180deg, rgba(56,189,248,0.28), rgba(56,189,248,0.12));
  border-color: rgba(56,189,248,0.56);
  color: #e6f8ff;
}
.viewer-three-controls__select {
  appearance: none;
  min-width: 52px;
  text-align: center;
  text-align-last: center;
}
.viewer-three-controls__range {
  width: 128px;
  accent-color: #38bdf8;
}
.viewer-dimensions__svg {
  position: absolute;
  inset: 0;
  overflow: visible;
}
body[data-theme="light"] #viewer.viewer--three {
  background:
    radial-gradient(circle at 48% 8%, rgba(190, 216, 245, 0.86) 0%, rgba(230, 236, 245, 0.96) 42%, rgba(246, 248, 252, 1) 100%),
    linear-gradient(145deg, #f8fafc 0%, #e5eaf2 100%);
}
body[data-theme="light"] .viewer-three-controls__group {
  background: rgba(255,255,255,0.76);
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .viewer-three-controls__btn,
body[data-theme="light"] .viewer-three-controls__select {
  background: rgba(15,23,42,0.04);
  color: #0f172a;
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .viewer-three-controls__btn.is-active {
  color: #0f3c63;
  background: linear-gradient(180deg, rgba(56,189,248,0.22), rgba(56,189,248,0.08));
}
@media (max-width: 740px) {
  .viewer-three-controls {
    left: 10px;
    right: 10px;
    bottom: 58px;
    max-width: none;
  }
  .viewer-three-controls__group {
    justify-content: center;
  }
  .viewer-three-controls__range {
    width: 100%;
    min-width: 160px;
  }
}


/* v105: светлая тема доведена без изменения Three.js-рендера моделей.
   ВАЖНО: геометрия, свет, материалы и загрузка STL/SCAD оставлены как в рабочей v99. */
body[data-theme="light"] {
  --bg: #eef3f8;
  --panel: #ffffff;
  --panel-2: #f7f9fc;
  --panel-3: #edf2f7;
  --border: rgba(15, 23, 42, 0.13);
  --text: #0f172a;
  --muted: #475569;
  --soft: #64748b;
  background:
    radial-gradient(circle at 18% 0%, rgba(96, 165, 250, 0.12), transparent 32%),
    linear-gradient(180deg, #f6f8fb 0%, #e9eef5 100%);
  color: var(--text);
}
body[data-theme="light"] .topbar,
body[data-theme="light"] .admin-toolbar {
  background: rgba(255,255,255,0.92);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 14px 36px rgba(15,23,42,0.10);
}
body[data-theme="light"] .mw-card,
body[data-theme="light"] .panel,
body[data-theme="light"] .subpanel,
body[data-theme="light"] .viewer-card,
body[data-theme="light"] .builder-card,
body[data-theme="light"] .modal__dialog,
body[data-theme="light"] .info-card,
body[data-theme="light"] .success-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  color: #0f172a;
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 18px 44px rgba(15,23,42,0.11);
}
body[data-theme="light"] .selected-model,
body[data-theme="light"] .template-item,
body[data-theme="light"] .summary-card,
body[data-theme="light"] .form-group,
body[data-theme="light"] .display-part-toggle,
body[data-theme="light"] .display-chip,
body[data-theme="light"] .viewer-toolbar__btn,
body[data-theme="light"] .builder-nav__item,
body[data-theme="light"] .tag,
body[data-theme="light"] .stat-card,
body[data-theme="light"] .input,
body[data-theme="light"] .textarea,
body[data-theme="light"] select.input {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15,23,42,0.14);
}
body[data-theme="light"] .template-item:hover,
body[data-theme="light"] .display-chip:hover,
body[data-theme="light"] .viewer-toolbar__btn:hover,
body[data-theme="light"] .builder-nav__item:hover,
body[data-theme="light"] .btn--ghost:hover {
  border-color: rgba(30, 136, 229, 0.34);
  background: #f8fbff;
}
body[data-theme="light"] .template-item.active,
body[data-theme="light"] .display-chip.is-active,
body[data-theme="light"] .viewer-toolbar__btn.is-active,
body[data-theme="light"] .builder-nav__item.is-active {
  background: linear-gradient(180deg, rgba(30,136,229,0.18), rgba(30,136,229,0.07));
  border-color: rgba(30,136,229,0.42);
  color: #0b3b66;
}
body[data-theme="light"] .btn--ghost,
body[data-theme="light"] .admin-toolbar__btn,
body[data-theme="light"] .modal__close {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15,23,42,0.14);
}
body[data-theme="light"] .pill {
  background: rgba(30,136,229,0.10);
  color: #0b3b66;
  border-color: rgba(30,136,229,0.20);
}
body[data-theme="light"] .brand__title,
body[data-theme="light"] .selected-model__name,
body[data-theme="light"] .template-item__title,
body[data-theme="light"] .form-group__title,
body[data-theme="light"] .mw-card h2,
body[data-theme="light"] .panel h2,
body[data-theme="light"] .subpanel h2,
body[data-theme="light"] .modal__header h2 {
  color: #0f172a;
}
body[data-theme="light"] .brand__subtitle,
body[data-theme="light"] .selected-model__subtitle,
body[data-theme="light"] .template-item__meta,
body[data-theme="light"] .summary-card__label,
body[data-theme="light"] .stat-card__label,
body[data-theme="light"] .field small,
body[data-theme="light"] .field__hint-range,
body[data-theme="light"] .mw-card p,
body[data-theme="light"] .panel p,
body[data-theme="light"] .subpanel p,
body[data-theme="light"] .form-stack label,
body[data-theme="light"] .field label {
  color: #475569;
}
body[data-theme="light"] .selected-model__thumb,
body[data-theme="light"] .selected-model__thumb--viewer,
body[data-theme="light"] .selected-model__thumb--image {
  background: radial-gradient(circle at 50% 18%, #eef3f8 0%, #dfe7f0 58%, #cfd8e3 100%);
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .viewer-toolbar__pill,
body[data-theme="light"] .viewer-dimensions__label,
body[data-theme="light"] .viewer-badge,
body[data-theme="light"] .viewer-order-overlay,
body[data-theme="light"] .viewer-help span {
  background: rgba(255,255,255,0.90);
  color: #0f172a;
  border-color: rgba(15,23,42,0.13);
  box-shadow: 0 8px 20px rgba(15,23,42,0.10);
}
body[data-theme="light"] .viewer-joystick {
  box-shadow: 0 10px 24px rgba(15,23,42,0.18);
}
body[data-theme="light"] .viewer-joystick__ring {
  border-color: rgba(30,136,229,0.34);
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.72) 0%, rgba(255,255,255,0.70) 54%, rgba(30,136,229,0.13) 55%, rgba(30,136,229,0.05) 74%, rgba(255,255,255,0.62) 100%);
}
body[data-theme="light"] .viewer-joystick__pad {
  border-color: rgba(15,23,42,0.12);
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.96), rgba(232,239,248,0.82) 45%, rgba(203,213,225,0.46) 100%);
}
body[data-theme="light"] .viewer-joystick__knob {
  border-color: rgba(15,23,42,0.18);
  background: radial-gradient(circle at 35% 30%, #ffffff, #dbeafe 42%, #60a5fa 100%);
  box-shadow: 0 7px 18px rgba(15,23,42,0.20);
}
body[data-theme="light"] .modal__backdrop {
  background: rgba(15, 23, 42, 0.34);
}
body[data-theme="light"] .flash {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] input::placeholder,
body[data-theme="light"] textarea::placeholder {
  color: #94a3b8;
}

/* v106: каталог, валидация, статус обработки, заказы, мобильная версия. 3D-рендер не изменён. */
.template-item--catalog {
  padding: 10px;
}
.catalog-model-card {
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 12px;
  align-items: stretch;
}
.catalog-model-card__thumb {
  min-height: 96px;
  border-radius: 14px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 50% 18%, #2b3340 0%, #171c24 58%, #0e1117 100%);
  border: 1px solid rgba(255,255,255,0.08);
  color: #8ed0ff;
  font-weight: 900;
  letter-spacing: .12em;
}
.catalog-model-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
  display: block;
}
.catalog-model-card__body {
  min-width: 0;
  display: grid;
  gap: 7px;
  align-content: start;
}
.catalog-model-card__topline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  color: var(--soft);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.catalog-model-card__topline b {
  color: #7dd3fc;
  font-size: 11px;
}
.catalog-model-card__cta {
  justify-self: start;
  margin-top: 2px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(30,168,255,0.13);
  border: 1px solid rgba(30,168,255,0.24);
  color: #c7eaff;
  font-size: 12px;
  font-weight: 800;
}
.field--error .input,
.field--error select.input,
.field--error .field__number-input {
  border-color: rgba(248, 113, 113, .85) !important;
  box-shadow: 0 0 0 3px rgba(248, 113, 113, .12);
}
.field__error {
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(248, 113, 113, .12);
  border: 1px solid rgba(248, 113, 113, .22);
  color: #fecaca;
  font-size: 12px;
  line-height: 1.35;
}
.viewer-processing {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 12;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: min(360px, calc(100% - 36px));
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(8,11,17,.78);
  backdrop-filter: blur(12px);
  box-shadow: 0 22px 70px rgba(0,0,0,.34);
  pointer-events: none;
}
.viewer-processing__spinner {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 3px solid rgba(255,255,255,.18);
  border-top-color: #38bdf8;
  animation: viewer-spin .8s linear infinite;
  flex: 0 0 auto;
}
.viewer-processing__title {
  font-weight: 900;
  color: #f8fafc;
}
.viewer-processing__hint {
  margin-top: 3px;
  color: #b6c2d2;
  font-size: 12px;
  line-height: 1.35;
}
@keyframes viewer-spin { to { transform: rotate(360deg); } }
.order-param-list {
  display: grid;
  grid-template-columns: minmax(120px, .8fr) minmax(0, 1fr);
  gap: 6px 12px;
  margin-top: 8px;
  font-size: 13px;
}
.order-param-list span {
  color: var(--muted);
}
.order-param-list b {
  color: var(--text);
  font-weight: 800;
}
.price-breakdown--compact {
  max-height: 78px;
  overflow: auto;
}
.price-breakdown--compact .price-breakdown__row {
  padding: 7px 8px;
}
.orders-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 10px;
}
.request-list--orders {
  gap: 12px;
}
.order-card {
  display: grid;
  gap: 12px;
}
.order-card__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}
.order-card__head h3 {
  margin: 0;
  font-size: 18px;
}
.order-card__date,
.order-card__muted {
  color: var(--muted);
  font-size: 12px;
  margin-top: 4px;
}
.order-card__price {
  white-space: nowrap;
  font-size: 22px;
  font-weight: 900;
  color: #dff2ff;
}
.order-card__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.order-card__grid > div {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.06);
  min-width: 0;
}
.order-card__grid span,
.order-status-select span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.order-card__grid b {
  color: var(--text);
  overflow-wrap: anywhere;
}
.order-card__comment {
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(30,168,255,.08);
  border: 1px solid rgba(30,168,255,.13);
  color: var(--text);
  line-height: 1.45;
}
.order-card__actions {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.order-status-select {
  display: grid;
  gap: 6px;
  min-width: min(240px, 100%);
}
.order-param-list--admin {
  padding-top: 10px;
}
.order-card--new { border-color: rgba(248,113,113,.25); }
.order-card--printing { border-color: rgba(56,189,248,.25); }
.order-card--ready { border-color: rgba(74,222,128,.25); }
body[data-theme="light"] .catalog-model-card__thumb {
  background: radial-gradient(circle at 50% 18%, #f8fafc 0%, #e2e8f0 62%, #cbd5e1 100%);
  border-color: rgba(15,23,42,.12);
  color: #0b70b8;
}
body[data-theme="light"] .catalog-model-card__cta {
  background: rgba(30,136,229,.10);
  border-color: rgba(30,136,229,.22);
  color: #0b3b66;
}
body[data-theme="light"] .field__error {
  background: rgba(239,68,68,.08);
  border-color: rgba(239,68,68,.22);
  color: #991b1b;
}
body[data-theme="light"] .viewer-processing {
  background: rgba(255,255,255,.88);
  border-color: rgba(15,23,42,.14);
  box-shadow: 0 22px 60px rgba(15,23,42,.16);
}
body[data-theme="light"] .viewer-processing__title { color: #0f172a; }
body[data-theme="light"] .viewer-processing__hint { color: #475569; }
body[data-theme="light"] .order-card__price { color: #075985; }
body[data-theme="light"] .order-card__grid > div {
  background: rgba(15,23,42,.035);
  border-color: rgba(15,23,42,.08);
}
@media (max-width: 1180px) {
  .maker-layout--builder {
    display: flex;
    flex-direction: column;
  }
  .builder-stage { order: 1; }
  .builder-sidebar { order: 2; }
}
@media (max-width: 760px) {
  body { padding: 8px; }
  .topbar {
    position: sticky;
    top: 0;
    z-index: 40;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 10px;
  }
  .topbar__actions,
  .customer-topbar,
  .customer-topbar__guest,
  .customer-topbar__auth {
    width: 100%;
  }
  .topbar__actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .customer-topbar__guest,
  .customer-topbar__auth {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .customer-topbar__auth .pill {
    grid-column: 1 / -1;
    justify-content: center;
    overflow-wrap: anywhere;
  }
  .maker-layout--builder {
    gap: 12px;
  }
  .builder-card { border-radius: 16px; }
  .viewer-card--builder,
  .viewer-card--builder #viewer {
    min-height: 56vh;
    height: 56vh;
  }
  .viewer-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }
  .viewer-toolbar__right {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .viewer-toolbar__btn { padding: 9px 8px; }
  .viewer-color-palette {
    top: 104px;
    right: 10px;
    justify-content: center;
  }
  .viewer-order-overlay {
    top: auto !important;
    left: 10px;
    right: 10px;
    bottom: 10px;
    padding: 10px;
    border-radius: 16px;
  }
  .viewer-order-overlay__value { font-size: 24px; }
  .viewer-order-overlay__hint { font-size: 12px; }
  .viewer-help { display: none; }
  .viewer-rotation-control {
    transform: scale(.86);
    transform-origin: right bottom;
  }
  .catalog-model-card {
    grid-template-columns: 76px minmax(0, 1fr);
  }
  .catalog-model-card__thumb { min-height: 78px; }
  .modal__dialog {
    width: calc(100vw - 14px);
    max-height: calc(100vh - 14px);
    padding: 14px;
    border-radius: 18px;
  }
  .orders-toolbar,
  .order-card__grid,
  .order-param-list {
    grid-template-columns: 1fr;
  }
  .order-card__head {
    flex-direction: column;
  }
  .order-card__price { font-size: 20px; }
  .field__number-controls {
    grid-template-columns: 86px minmax(0, 1fr);
  }
  .dynamic-form--builder {
    max-height: none;
    overflow: visible;
  }
}

/* v109: цена в каталоге и без служебного оверлея обработки */
.viewer-processing { display: none !important; }
.catalog-model-card__price {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  width: fit-content;
  margin-top: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(39, 174, 96, 0.14);
  border: 1px solid rgba(39, 174, 96, 0.26);
  color: #d8ffe9;
  font-size: 12px;
  font-weight: 700;
}
.catalog-model-card__price span { opacity: .75; font-weight: 600; }
.catalog-model-card__price b { font-size: 15px; }
.catalog-model-card__price--muted {
  color: var(--muted);
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.08);
  font-weight: 600;
}
body[data-theme="light"] .catalog-model-card__price {
  background: #e9fff2;
  border-color: #bbf7d0;
  color: #166534;
}
body[data-theme="light"] .catalog-model-card__price--muted {
  background: #f3f4f6;
  border-color: #e5e7eb;
  color: #64748b;
}
@media (max-width: 760px) {
  .catalog-model-card__price { margin-top: 7px; padding: 5px 9px; }
  .catalog-model-card__price b { font-size: 14px; }
}

/* v120: fixed one-screen configurator for customers.
   The page itself never scrolls; only the parameter panel scrolls. */
html {
  height: 100%;
}
body.user-mode.builder-page {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  min-height: 0;
  overflow: hidden !important;
  display: flex;
  flex-direction: column;
  padding: 10px;
}
body.user-mode.builder-page .flash-stack {
  display: none !important;
}
body.user-mode.builder-page .topbar {
  flex: 0 0 auto;
  margin-bottom: 10px;
}
body.user-mode.builder-page .maker-layout--builder {
  flex: 1 1 auto;
  height: auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(310px, 380px) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
}
body.user-mode.builder-page .builder-sidebar {
  position: relative !important;
  top: auto !important;
  order: 1;
  height: 100% !important;
  max-height: none !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column;
  gap: 10px;
  padding-right: 0;
}
body.user-mode.builder-page .builder-stage {
  position: relative !important;
  top: auto !important;
  order: 2;
  align-self: stretch;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.user-mode.builder-page .builder-sidebar > .builder-card {
  flex: 0 0 auto;
}
body.user-mode.builder-page .builder-card--compact,
body.user-mode.builder-page .builder-card--nav,
body.user-mode.builder-page #parts-section-card,
body.user-mode.builder-page #display-section-card {
  margin: 0;
}
body.user-mode.builder-page .builder-card--compact .selected-model {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 10px;
  padding: 8px;
}
body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
  height: 72px;
}
body.user-mode.builder-page .selected-model__name {
  font-size: 16px;
  margin-bottom: 4px;
}
body.user-mode.builder-page .selected-model__subtitle {
  font-size: 12px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
body.user-mode.builder-page .builder-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}
body.user-mode.builder-page .builder-nav__item {
  min-height: 32px;
  padding: 7px 8px;
  font-size: 12px;
}
body.user-mode.builder-page #parts-section-card .mw-card__header,
body.user-mode.builder-page #display-section-card .mw-card__header {
  margin-bottom: 8px;
}
body.user-mode.builder-page #parts-section-card h2,
body.user-mode.builder-page #display-section-card h2,
body.user-mode.builder-page .builder-card--controls h2 {
  font-size: 14px;
}
body.user-mode.builder-page .display-dimension-modes {
  gap: 6px;
}
body.user-mode.builder-page .display-chip {
  min-height: 30px;
  padding: 6px 8px;
  font-size: 12px;
}
body.user-mode.builder-page .builder-card--controls {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column;
}
body.user-mode.builder-page .builder-card--controls > .mw-card__header {
  flex: 0 0 auto;
  margin-bottom: 10px;
}
body.user-mode.builder-page .dynamic-form--builder,
body.user-mode.builder-page #dynamic-form {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain;
  padding-right: 6px;
}
body.user-mode.builder-page .customize-actions {
  flex: 0 0 auto;
  margin-top: 10px;
}
body.user-mode.builder-page .viewer-card--builder,
body.user-mode.builder-page .viewer-card--builder #viewer,
body.user-mode.builder-page .viewer-card,
body.user-mode.builder-page #viewer {
  width: 100%;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}
body.user-mode.builder-page .viewer-card--builder {
  position: relative;
}
body.user-mode.builder-page .viewer-help {
  bottom: 10px;
}
body.user-mode.builder-page .viewer-order-overlay {
  top: 64px;
}

@media (max-width: 1180px) and (min-width: 761px) {
  body.user-mode.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: minmax(300px, 350px) minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }
  body.user-mode.builder-page .builder-stage { order: 2; }
  body.user-mode.builder-page .builder-sidebar { order: 1; }
  body.user-mode.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder #viewer {
    height: 100% !important;
    min-height: 0 !important;
  }
}

@media (max-width: 760px) {
  body.user-mode.builder-page {
    padding: 8px;
  }
  body.user-mode.builder-page .topbar {
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding: 8px;
    margin-bottom: 8px;
    border-radius: 16px;
  }
  body.user-mode.builder-page .brand {
    gap: 8px;
    min-width: 0;
  }
  body.user-mode.builder-page .brand__mark {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    flex: 0 0 auto;
  }
  body.user-mode.builder-page .brand__title {
    font-size: 14px;
  }
  body.user-mode.builder-page .brand__subtitle {
    display: none;
  }
  body.user-mode.builder-page .topbar__actions {
    margin-left: auto;
    gap: 6px;
  }
  body.user-mode.builder-page .theme-toggle-btn {
    padding: 8px 9px;
    min-height: 34px;
  }
  body.user-mode.builder-page .theme-toggle-btn__text {
    display: none;
  }
  body.user-mode.builder-page .customer-topbar__guest,
  body.user-mode.builder-page .customer-topbar__auth {
    display: flex;
    width: auto;
    gap: 6px;
  }
  body.user-mode.builder-page .customer-topbar .btn,
  body.user-mode.builder-page .customer-topbar .pill {
    padding: 8px 9px;
    min-height: 34px;
    font-size: 12px;
  }
  body.user-mode.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 44%) minmax(0, 56%);
    gap: 8px;
  }
  body.user-mode.builder-page .builder-stage {
    order: 1;
    height: 100% !important;
  }
  body.user-mode.builder-page .builder-sidebar {
    order: 2;
    height: 100% !important;
    gap: 8px;
  }
  body.user-mode.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder #viewer,
  body.user-mode.builder-page #viewer {
    height: 100% !important;
    min-height: 0 !important;
  }
  body.user-mode.builder-page .viewer-toolbar {
    left: 8px;
    right: 8px;
    top: 8px;
    flex-direction: row;
    align-items: flex-start;
    gap: 8px;
  }
  body.user-mode.builder-page .viewer-toolbar__left {
    min-width: 0;
  }
  body.user-mode.builder-page .viewer-toolbar__right {
    width: auto;
    display: flex;
    gap: 5px;
  }
  body.user-mode.builder-page .viewer-toolbar__pill,
  body.user-mode.builder-page .viewer-toolbar__btn {
    min-height: 30px;
    padding: 6px 8px;
    font-size: 11px;
  }
  body.user-mode.builder-page .viewer-color-palette {
    top: 48px;
    left: 8px;
    right: auto;
    max-width: calc(100% - 16px);
    padding: 6px 8px;
  }
  body.user-mode.builder-page .viewer-badge,
  body.user-mode.builder-page .viewer-help {
    display: none;
  }
  body.user-mode.builder-page .viewer-order-overlay {
    top: auto !important;
    bottom: 8px;
    left: 8px;
    right: 8px;
    padding: 8px 10px;
    border-radius: 14px;
  }
  body.user-mode.builder-page .viewer-order-overlay__label,
  body.user-mode.builder-page .viewer-order-overlay__hint,
  body.user-mode.builder-page .price-breakdown--compact {
    display: none;
  }
  body.user-mode.builder-page .viewer-order-overlay__value {
    font-size: 22px;
    margin-top: 0;
  }
  body.user-mode.builder-page .viewer-order-overlay__button {
    margin-top: 7px;
    padding: 9px 10px;
  }
  body.user-mode.builder-page .viewer-rotation-control {
    transform: scale(.76);
    transform-origin: right bottom;
    right: 8px;
    bottom: 82px;
  }
  body.user-mode.builder-page .builder-card--nav,
  body.user-mode.builder-page #parts-section-card,
  body.user-mode.builder-page #display-section-card {
    display: none !important;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model {
    grid-template-columns: 54px minmax(0, 1fr);
    padding: 7px;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
    height: 54px;
    border-radius: 10px;
  }
  body.user-mode.builder-page .selected-model__name {
    font-size: 14px;
    margin-bottom: 2px;
  }
  body.user-mode.builder-page .selected-model__subtitle {
    -webkit-line-clamp: 1;
    font-size: 11px;
  }
  body.user-mode.builder-page .model-open-btn {
    width: 34px;
    height: 34px;
  }
  body.user-mode.builder-page .builder-card--controls {
    padding: 10px;
  }
  body.user-mode.builder-page .builder-card--controls > .mw-card__header {
    margin-bottom: 8px;
  }
  body.user-mode.builder-page .form-group__summary {
    padding: 12px 13px;
  }
  body.user-mode.builder-page .form-group__body {
    padding: 0 13px 13px;
  }
  body.user-mode.builder-page .customize-actions {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 430px) {
  body.user-mode.builder-page .customer-topbar .btn,
  body.user-mode.builder-page .customer-topbar .pill {
    font-size: 0;
    padding: 8px 10px;
  }
  body.user-mode.builder-page #open-login-modal-btn::after { content: 'Вход'; font-size: 12px; }
  body.user-mode.builder-page #open-register-modal-btn::after { content: 'Рег.'; font-size: 12px; }
  body.user-mode.builder-page #open-my-orders-auth-btn::after { content: 'Заказы'; font-size: 12px; }
  body.user-mode.builder-page #customer-logout-btn::after { content: 'Выйти'; font-size: 12px; }
}

/* v121: clean customer configurator.
   The customer page is one fixed screen; only the parameter list scrolls. */
body.user-mode.builder-page .builder-card--nav,
body.user-mode.builder-page #parts-section-card,
body.user-mode.builder-page #display-section-card {
  display: none !important;
}

body.user-mode.builder-page .builder-card--compact {
  padding: 10px !important;
}
body.user-mode.builder-page .builder-card--compact .section-kicker,
body.user-mode.builder-page .builder-card--compact h2 {
  display: none !important;
}
body.user-mode.builder-page .builder-card--compact .mw-card__header {
  margin: 0 0 8px !important;
  min-height: 0;
}
body.user-mode.builder-page .builder-card--compact .mw-card__header > div:first-child {
  display: none !important;
}
body.user-mode.builder-page .builder-card--compact .model-header-actions {
  width: 100%;
  justify-content: flex-end;
}
body.user-mode.builder-page .model-open-btn--customer {
  width: auto;
  min-width: 108px;
  border-radius: 999px;
  padding: 8px 12px;
}

body.user-mode.builder-page .builder-card--controls {
  padding: 12px !important;
}
body.user-mode.builder-page .builder-card--controls > .mw-card__header {
  display: none !important;
}
body.user-mode.builder-page .form-group__summary {
  display: none !important;
}
body.user-mode.builder-page .form-group--builder {
  padding: 12px !important;
}
body.user-mode.builder-page .form-group__body {
  padding: 0 !important;
}
body.user-mode.builder-page .dynamic-form--builder {
  gap: 10px !important;
}
body.user-mode.builder-page .field[data-field-key="sourceWidth"],
body.user-mode.builder-page .field[data-field-key="sourceHeight"],
body.user-mode.builder-page .field[data-field-key="sourceDepth"] {
  display: none !important;
}

body.user-mode.builder-page .builder-sidebar {
  overflow: hidden !important;
}
body.user-mode.builder-page .builder-card--controls {
  min-height: 0 !important;
  overflow: hidden !important;
}
body.user-mode.builder-page #dynamic-form {
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}

@media (max-width: 760px) {
  body.user-mode.builder-page .maker-layout--builder {
    grid-template-rows: minmax(0, 42%) minmax(0, 58%);
  }
  body.user-mode.builder-page .builder-card--compact {
    padding: 8px !important;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model {
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 8px;
    padding: 6px;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
    height: 54px;
  }
  body.user-mode.builder-page .selected-model__name {
    font-size: 14px;
  }
  body.user-mode.builder-page .selected-model__subtitle {
    font-size: 11px;
    -webkit-line-clamp: 1;
  }
  body.user-mode.builder-page .model-open-btn--customer {
    min-width: 86px;
    padding: 7px 10px;
    font-size: 12px;
  }
  body.user-mode.builder-page .customize-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  body.user-mode.builder-page .customize-actions .btn {
    width: 100%;
    padding: 10px 8px;
  }
}


/* v122: fixed one-screen configurator for customer + admin.
   The whole app stays in one viewport; only the SCAD/parameter list scrolls. */
html, body.builder-page {
  height: 100%;
}
body.builder-page {
  height: 100vh !important;
  max-height: 100vh !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
body.builder-page .topbar,
body.builder-page .admin-toolbar,
body.builder-page .flash-stack {
  flex: 0 0 auto;
}
body.builder-page .admin-toolbar {
  margin: 0 0 8px !important;
  padding: 8px !important;
  gap: 8px !important;
}
body.builder-page .admin-toolbar__btn {
  padding: 8px 11px !important;
  min-height: 36px !important;
}
body.builder-page .maker-layout--builder {
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: stretch !important;
}
body.builder-page .builder-sidebar {
  position: relative !important;
  top: auto !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding-right: 0 !important;
}
body.builder-page .builder-stage {
  position: relative !important;
  top: auto !important;
  align-self: stretch !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.builder-page .viewer-card--builder,
body.builder-page .viewer-card--builder #viewer,
body.builder-page .viewer-card,
body.builder-page #viewer {
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}
body.builder-page .builder-card--nav,
body.builder-page #parts-section-card,
body.builder-page #display-section-card {
  display: none !important;
}
body.builder-page .builder-card--compact {
  flex: 0 0 auto !important;
  padding: 10px !important;
}
body.builder-page .builder-card--compact .section-kicker,
body.builder-page .builder-card--compact h2,
body.builder-page .builder-card--controls > .mw-card__header,
body.builder-page .form-group__summary,
body.builder-page .form-group__title {
  display: none !important;
}
body.builder-page .builder-card--compact .mw-card__header {
  margin: 0 0 8px !important;
  min-height: 0 !important;
}
body.builder-page .builder-card--compact .mw-card__header > div:first-child {
  display: none !important;
}
body.builder-page .builder-card--compact .model-header-actions {
  width: 100% !important;
  justify-content: flex-end !important;
}
body.builder-page .builder-card--controls {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 12px !important;
}
body.builder-page #dynamic-form,
body.builder-page .dynamic-form--builder,
body.builder-page .dynamic-form--scroll {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  scrollbar-gutter: stable !important;
  padding-right: 6px !important;
}
body.builder-page .form-group--builder,
body.builder-page .form-group {
  padding: 10px !important;
  min-height: 0 !important;
}
body.builder-page .form-group__body {
  padding: 0 !important;
}
body.builder-page .field[data-field-key="sourceWidth"],
body.builder-page .field[data-field-key="sourceHeight"],
body.builder-page .field[data-field-key="sourceDepth"] {
  display: none !important;
}
body.builder-page .customize-actions {
  flex: 0 0 auto !important;
  margin-top: 10px !important;
}
body.builder-page.admin-mode .summary-stack,
body.builder-page.admin-mode .summary-actions {
  max-height: none;
}
body.builder-page.admin-mode .maker-layout--builder > .maker-sidebar > section:last-child {
  display: none !important;
}

@media (max-width: 1180px) and (min-width: 761px) {
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(280px, 350px) minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }
}
@media (max-width: 760px) {
  body.builder-page {
    padding: 8px !important;
  }
  body.builder-page .topbar {
    position: relative !important;
    margin-bottom: 8px !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px !important;
    border-radius: 16px !important;
  }
  body.builder-page .admin-toolbar {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    margin-bottom: 8px !important;
  }
  body.builder-page .brand__subtitle { display: none !important; }
  body.builder-page .brand__title { font-size: 14px !important; }
  body.builder-page .brand__mark { width: 34px !important; height: 34px !important; }
  body.builder-page .topbar__actions { margin-left: auto !important; gap: 6px !important; width: auto !important; }
  body.builder-page .theme-toggle-btn__text { display: none !important; }
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 42%) minmax(0, 58%) !important;
    gap: 8px !important;
  }
  body.builder-page .builder-stage { order: 1 !important; }
  body.builder-page .builder-sidebar { order: 2 !important; gap: 8px !important; }
  body.builder-page .builder-card--compact { padding: 8px !important; }
  body.builder-page .builder-card--controls { padding: 10px !important; }
  body.builder-page .selected-model__subtitle { -webkit-line-clamp: 1 !important; }
  body.builder-page .customize-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  body.builder-page .customize-actions .btn { width: 100% !important; padding: 10px 8px !important; }
}


/* v123: REAL fixed scroll for SCAD/user parameters.
   Previous versions set overflow, but the flex item still grew by content height.
   This forces a constrained app shell and makes only #dynamic-form scroll. */
html,
body.builder-page {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.builder-page {
  height: 100vh !important;
  height: 100dvh !important;
  max-height: 100vh !important;
  max-height: 100dvh !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 10px !important;
}
body.builder-page .topbar,
body.builder-page .admin-toolbar,
body.builder-page .flash-stack {
  flex: 0 0 auto !important;
}
body.builder-page .flash-stack { display: none !important; }
body.builder-page .maker-layout--builder {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  align-items: stretch !important;
}
body.builder-page .builder-sidebar,
body.builder-page .builder-stage,
body.builder-page .viewer-card--builder {
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
}
body.builder-page .builder-sidebar {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
body.builder-page .builder-sidebar > .builder-card {
  min-height: 0 !important;
}
body.builder-page .builder-card--compact {
  flex: 0 0 auto !important;
  max-height: 118px !important;
  overflow: hidden !important;
}
body.builder-page .builder-card--compact .selected-model {
  min-height: 0 !important;
  margin: 0 !important;
}
body.builder-page .builder-card--compact .selected-model__thumb {
  height: 64px !important;
}
body.builder-page .builder-card--controls {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
body.builder-page .builder-card--controls > .mw-card__header,
body.builder-page .builder-card--controls .form-group__summary,
body.builder-page .builder-card--controls .form-group__title {
  display: none !important;
}
body.builder-page #dynamic-form {
  display: block !important;
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: scroll !important;
  overflow-x: hidden !important;
  padding-right: 8px !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  touch-action: pan-y !important;
}
body.builder-page #dynamic-form > .form-group,
body.builder-page #dynamic-form > details.form-group,
body.builder-page #dynamic-form .form-group__body {
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}
body.builder-page #dynamic-form .field:last-child {
  margin-bottom: 14px !important;
}
body.builder-page .customize-actions {
  flex: 0 0 auto !important;
  margin-top: 10px !important;
}
body.builder-page .builder-card--nav,
body.builder-page #parts-section-card,
body.builder-page #display-section-card,
body.builder-page.admin-mode .maker-layout--builder > .maker-sidebar > section:last-child {
  display: none !important;
}
body.builder-page .field[data-field-key="sourceWidth"],
body.builder-page .field[data-field-key="sourceHeight"],
body.builder-page .field[data-field-key="sourceDepth"] {
  display: none !important;
}
@media (max-width: 760px) {
  body.builder-page { padding: 8px !important; }
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 42%) minmax(0, 58%) !important;
    gap: 8px !important;
  }
  body.builder-page .builder-stage { order: 1 !important; }
  body.builder-page .builder-sidebar { order: 2 !important; }
  body.builder-page .builder-card--compact {
    max-height: 82px !important;
    padding: 8px !important;
  }
  body.builder-page .builder-card--compact .selected-model {
    grid-template-columns: 48px minmax(0, 1fr) !important;
    gap: 8px !important;
    padding: 5px !important;
  }
  body.builder-page .builder-card--compact .selected-model__thumb {
    height: 48px !important;
  }
  body.builder-page .selected-model__subtitle { display: none !important; }
  body.builder-page .builder-card--controls { padding: 10px !important; }
  body.builder-page #dynamic-form { padding-right: 6px !important; }
}

/* v125 — StorageBuilder-style productivity layer */
.viewer-toolbar__right--pro {
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.viewer-toolbar__btn--primary {
  border-color: rgba(88, 166, 255, 0.5);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.24), rgba(14, 165, 233, 0.16));
  color: var(--text, #eaf0ff);
}
.viewer-toolbar__btn--square {
  min-width: 34px;
  width: 34px;
  padding-left: 0;
  padding-right: 0;
  font-weight: 800;
}
.saved-designs-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.saved-designs-list {
  display: grid;
  gap: 10px;
  max-height: min(62vh, 560px);
  overflow-y: auto;
  padding-right: 4px;
}
.saved-designs-empty,
.saved-design-card {
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(15, 23, 42, 0.48);
  border-radius: 18px;
  padding: 14px;
}
body.light .saved-designs-empty,
body.light .saved-design-card {
  background: rgba(255, 255, 255, 0.84);
  border-color: rgba(15, 23, 42, 0.12);
}
.saved-design-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}
.saved-design-card__title {
  font-weight: 800;
  font-size: 15px;
  color: var(--text, #eef5ff);
}
.saved-design-card__meta {
  margin-top: 3px;
  font-size: 12px;
  color: var(--muted, #93a4bb);
}
.saved-design-card__params {
  margin-top: 7px;
  font-size: 12px;
  line-height: 1.45;
  color: var(--muted, #a8b4c7);
  max-width: 720px;
}
.saved-design-card__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.shortcuts-list {
  display: grid;
  gap: 10px;
}
.shortcuts-list > div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 10px;
  align-items: center;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.36);
  border-radius: 14px;
  padding: 10px 12px;
}
.shortcuts-list kbd {
  display: inline-flex;
  min-width: 28px;
  justify-content: center;
  padding: 4px 7px;
  border-radius: 8px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(2, 6, 23, 0.62);
  color: var(--text, #eaf0ff);
  font: 700 12px/1 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}
.shortcuts-list span {
  color: var(--text, #eaf0ff);
  font-size: 14px;
}
body.light .shortcuts-list > div {
  background: rgba(255, 255, 255, 0.82);
  border-color: rgba(15, 23, 42, 0.12);
}
body.light .shortcuts-list kbd {
  background: rgba(241, 245, 249, 0.95);
  color: #0f172a;
}
@media (max-width: 880px) {
  .viewer-toolbar__right--pro {
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 2px;
  }
  .viewer-toolbar__right--pro .viewer-toolbar__btn {
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .saved-design-card {
    grid-template-columns: 1fr;
  }
  .saved-design-card__actions {
    justify-content: stretch;
  }
  .saved-design-card__actions .btn {
    flex: 1 1 120px;
  }
}

/* v126: customer-only premium tools and social auth */
.premium-action.is-locked {
  opacity: .55;
  filter: grayscale(.2);
  cursor: not-allowed;
  position: relative;
}
.premium-action.is-locked::after {
  content: '🔒';
  margin-left: 6px;
  font-size: 12px;
}
.social-auth-panel {
  display: grid;
  gap: 10px;
  margin: 0 0 16px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  background: rgba(255,255,255,.045);
}
.social-auth-panel__title {
  font-size: 13px;
  font-weight: 800;
  color: var(--muted, #aeb6c4);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.social-auth-buttons {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.social-auth-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  text-decoration: none;
  color: #f7f9ff;
  font-weight: 800;
  background: rgba(255,255,255,.07);
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.social-auth-btn:hover { transform: translateY(-1px); border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.11); }
.social-auth-btn--google { background: linear-gradient(135deg, rgba(66,133,244,.20), rgba(255,255,255,.06)); }
.social-auth-btn--vk { background: linear-gradient(135deg, rgba(0,119,255,.24), rgba(255,255,255,.06)); }
.social-auth-btn--telegram { background: linear-gradient(135deg, rgba(42,171,238,.24), rgba(255,255,255,.06)); }
.social-auth-btn--yandex { background: linear-gradient(135deg, rgba(252,63,29,.24), rgba(255,255,255,.06)); }
.social-auth-btn--max { background: linear-gradient(135deg, rgba(113,82,255,.23), rgba(255,255,255,.06)); }
.social-auth-btn.is-muted { opacity: .62; }
.social-auth-panel__hint { color: var(--muted, #9aa4b5); font-size: 12px; line-height: 1.35; }
body[data-theme="light"] .social-auth-panel { background: rgba(15,23,42,.045); border-color: rgba(15,23,42,.10); }
body[data-theme="light"] .social-auth-btn { color: #111827; background: rgba(15,23,42,.04); border-color: rgba(15,23,42,.12); }
@media (max-width: 560px) { .social-auth-buttons { grid-template-columns: 1fr; } }


/* v128: user profile, repeated orders and CSV export polish */
.customer-order-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.customer-order-card .order-details {
  margin-top: 10px;
}
.customer-topbar__auth {
  align-items: center;
  gap: 8px;
}
.orders-toolbar {
  align-items: center;
}
#admin-orders-export-btn {
  white-space: nowrap;
}
#customer-profile-modal .modal__dialog {
  max-width: 520px;
}
@media (max-width: 720px) {
  .customer-topbar__auth,
  .customer-topbar__guest {
    gap: 6px;
  }
  .customer-topbar__auth .pill {
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .customer-order-card__actions .btn {
    width: 100%;
  }
}

/* v129: order progress and history */
.order-progress{margin:10px 0 12px;padding:10px 12px;border-radius:16px;background:rgba(18,24,38,.06);border:1px solid rgba(125,140,170,.18)}
body.dark .order-progress,.theme-dark .order-progress{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1)}
.order-progress__bar{height:7px;border-radius:999px;background:rgba(125,140,170,.24);overflow:hidden;position:relative}
.order-progress__bar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,#22c55e);transition:width .28s ease}
.order-progress--cancelled .order-progress__bar i{background:linear-gradient(90deg,#ef4444,#f97316)}
.order-progress__steps{display:flex;justify-content:space-between;margin-top:7px;gap:6px}
.order-progress__step{width:10px;height:10px;border-radius:50%;background:rgba(125,140,170,.38);box-shadow:0 0 0 3px rgba(125,140,170,.12)}
.order-progress__step.is-done{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.16)}
.order-progress--cancelled .order-progress__step{background:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.14)}
.order-progress__label{margin-top:8px;font-size:12px;font-weight:800;color:var(--text-muted,#6b7280);text-transform:uppercase;letter-spacing:.04em}
.order-timeline{display:grid;gap:10px;margin-top:10px}
.order-timeline__item{display:grid;grid-template-columns:18px 1fr;gap:8px;align-items:start;position:relative}
.order-timeline__item:not(:last-child)::before{content:"";position:absolute;left:8px;top:18px;bottom:-10px;width:2px;background:rgba(125,140,170,.22)}
.order-timeline__dot{width:12px;height:12px;margin:3px auto 0;border-radius:999px;background:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.14)}
.order-timeline__item--created .order-timeline__dot{background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.14)}
.order-timeline__item--warning .order-timeline__dot{background:#f59e0b;box-shadow:0 0 0 4px rgba(245,158,11,.16)}
.order-timeline__item--status .order-timeline__dot{background:#8b5cf6;box-shadow:0 0 0 4px rgba(139,92,246,.14)}
.order-timeline__body{padding:9px 10px;border-radius:14px;background:rgba(125,140,170,.08);border:1px solid rgba(125,140,170,.14)}
.order-timeline__title{font-weight:800;font-size:13px;color:var(--text,#111827)}
.order-timeline__text{font-size:12px;line-height:1.35;margin-top:3px;color:var(--text-muted,#6b7280)}
.order-timeline__date{font-size:11px;margin-top:5px;color:var(--text-muted,#6b7280);opacity:.82}
.order-timeline__empty{font-size:12px;color:var(--text-muted,#6b7280);padding:8px 0}
.order-details--timeline summary{font-weight:800}

/* v130: admin order verification panel */
.order-details--admin-manage summary{font-weight:900;color:var(--text,#111827)}
.order-admin-manage{display:grid;grid-template-columns:minmax(120px,.7fr) minmax(130px,.7fr) 1.6fr auto;gap:10px;align-items:end;margin-top:10px}
.order-admin-manage label{display:grid;gap:6px;font-size:12px;font-weight:800;color:var(--text-muted,#6b7280)}
.order-admin-manage label span{text-transform:uppercase;letter-spacing:.04em;font-size:11px}
.order-admin-manage__note textarea{min-height:72px;resize:vertical;line-height:1.35}
.order-admin-manage .btn{white-space:nowrap;align-self:end}
body.dark .order-admin-manage .input,.theme-dark .order-admin-manage .input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#f8fafc}
@media (max-width: 900px){
  .order-admin-manage{grid-template-columns:1fr 1fr}
  .order-admin-manage__note{grid-column:1 / -1}
  .order-admin-manage .btn{grid-column:1 / -1;width:100%}
}
@media (max-width: 560px){
  .order-admin-manage{grid-template-columns:1fr}
  .order-admin-manage__note,.order-admin-manage .btn{grid-column:auto}
}

/* v131: production queue controls */
.orders-toolbar {
  grid-template-columns: minmax(0, 1fr) 190px 170px auto;
  align-items: center;
}
.order-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.order-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
  border: 1px solid rgba(125,140,170,.22);
  background: rgba(125,140,170,.10);
  color: var(--text, #e5e7eb);
}
.order-badge--priority-urgent,
.order-card--priority-urgent .order-card__price {
  color: #fecaca;
}
.order-badge--priority-urgent {
  background: rgba(239,68,68,.14);
  border-color: rgba(239,68,68,.30);
}
.order-badge--priority-hold {
  background: rgba(245,158,11,.15);
  border-color: rgba(245,158,11,.30);
  color: #fde68a;
}
.order-badge--due-soon {
  background: rgba(251,146,60,.16);
  border-color: rgba(251,146,60,.34);
  color: #fed7aa;
}
.order-card--due-soon {
  box-shadow: inset 3px 0 0 rgba(251,146,60,.75);
}
.order-card--priority-urgent {
  box-shadow: inset 3px 0 0 rgba(239,68,68,.75);
}
.order-card--priority-hold {
  opacity: .84;
}
.order-admin-manage {
  grid-template-columns: minmax(110px,.6fr) minmax(120px,.7fr) minmax(120px,.7fr) minmax(130px,.7fr) minmax(180px,1.2fr);
}
.order-admin-manage .btn {
  grid-column: 1 / -1;
  justify-self: end;
}
body[data-theme="light"] .order-badge {
  color: #0f172a;
  background: rgba(15,23,42,.06);
  border-color: rgba(15,23,42,.10);
}
body[data-theme="light"] .order-badge--priority-urgent {
  color: #991b1b;
  background: rgba(239,68,68,.10);
  border-color: rgba(239,68,68,.24);
}
body[data-theme="light"] .order-badge--priority-hold {
  color: #92400e;
  background: rgba(245,158,11,.12);
  border-color: rgba(245,158,11,.24);
}
body[data-theme="light"] .order-badge--due-soon {
  color: #9a3412;
  background: rgba(251,146,60,.12);
  border-color: rgba(251,146,60,.24);
}
@media (max-width: 900px) {
  .orders-toolbar { grid-template-columns: 1fr 1fr; }
  .orders-toolbar .input:first-child { grid-column: 1 / -1; }
  .orders-toolbar .btn { width: 100%; }
  .order-admin-manage { grid-template-columns: 1fr 1fr; }
  .order-admin-manage .btn { width: 100%; justify-self: stretch; }
}
@media (max-width: 560px) {
  .orders-toolbar { grid-template-columns: 1fr; }
  .orders-toolbar .input:first-child { grid-column: auto; }
}

/* v132: рабочая доска заказов и быстрая сводка */
#admin-orders-modal .admin-window__body {
  grid-template-rows: auto auto minmax(0, 1fr);
  max-height: calc(100vh - 156px);
  min-height: min(720px, calc(100vh - 156px));
}
#admin-orders-modal .request-list--orders,
#admin-orders-modal .orders-board {
  min-height: 0;
  max-height: none;
  overflow: auto;
}
#admin-orders-modal .orders-toolbar {
  grid-template-columns: minmax(210px, 1fr) minmax(150px, .42fr) minmax(150px, .42fr) auto auto;
}
.orders-view-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px;
  background: rgba(255,255,255,.04);
}
.orders-view-toggle__btn {
  border: 0;
  border-radius: 10px;
  padding: 8px 10px;
  background: transparent;
  color: var(--muted);
  font-weight: 900;
  cursor: pointer;
}
.orders-view-toggle__btn.is-active {
  background: linear-gradient(180deg, var(--blue), var(--blue-2));
  color: #fff;
  box-shadow: 0 10px 24px rgba(30,168,255,.22);
}
.orders-stats {
  display: grid;
  grid-template-columns: repeat(8, minmax(92px, 1fr));
  gap: 8px;
}
.orders-stat {
  display: grid;
  gap: 4px;
  text-align: left;
  padding: 10px 12px;
  min-height: 62px;
  border-radius: 15px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
  color: var(--text);
  cursor: default;
}
.orders-stat[data-orders-stat-status] { cursor: pointer; }
.orders-stat[data-orders-stat-status]:hover { border-color: rgba(30,168,255,.32); transform: translateY(-1px); }
.orders-stat span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.orders-stat b {
  font-size: 18px;
  line-height: 1.1;
  color: var(--text);
}
.orders-stat--new b,
.orders-stat--urgent b,
.orders-stat--due b { color: #fecaca; }
.orders-stat--ready b { color: #bbf7d0; }
.orders-stat--money b { color: #dff2ff; }
.order-card__quick-actions,
.orders-board-card__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.orders-board {
  display: grid;
  grid-template-columns: repeat(7, minmax(220px, 1fr));
  gap: 10px;
  padding-bottom: 4px;
}
.orders-board-column {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 440px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.028);
  overflow: hidden;
}
.orders-board-column header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 11px 12px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.035);
  font-weight: 900;
}
.orders-board-column header span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.orders-board-column header b {
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(30,168,255,.16);
  color: #dff2ff;
  font-size: 12px;
}
.orders-board-column__list {
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 10px;
  min-height: 0;
  overflow: auto;
}
.orders-board-card {
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(15,18,24,.72);
  box-shadow: 0 12px 26px rgba(0,0,0,.14);
}
.orders-board-card__top {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: flex-start;
}
.orders-board-card__top b { font-size: 13px; }
.orders-board-card__top span {
  white-space: nowrap;
  font-weight: 900;
  color: #dff2ff;
}
.orders-board-card__model {
  color: var(--text);
  font-weight: 800;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.orders-board-card__meta {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: 12px;
}
.orders-board-empty {
  padding: 20px 10px;
  text-align: center;
  color: var(--muted);
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.10);
}
body[data-theme="light"] .orders-view-toggle,
body[data-theme="light"] .orders-stat,
body[data-theme="light"] .orders-board-column,
body[data-theme="light"] .orders-board-card,
body[data-theme="light"] .orders-board-empty {
  border-color: rgba(15,23,42,.10);
  background: rgba(255,255,255,.70);
}
body[data-theme="light"] .orders-board-column header {
  border-bottom-color: rgba(15,23,42,.08);
  background: rgba(15,23,42,.035);
}
body[data-theme="light"] .orders-board-card {
  box-shadow: 0 12px 26px rgba(15,23,42,.08);
}
body[data-theme="light"] .orders-board-column header b,
body[data-theme="light"] .orders-board-card__top span,
body[data-theme="light"] .orders-stat--money b { color: #075985; }
body[data-theme="light"] .orders-stat--new b,
body[data-theme="light"] .orders-stat--urgent b,
body[data-theme="light"] .orders-stat--due b { color: #991b1b; }
body[data-theme="light"] .orders-stat--ready b { color: #166534; }
@media (max-width: 1180px) {
  .orders-stats { grid-template-columns: repeat(4, minmax(100px, 1fr)); }
  .orders-board { grid-template-columns: repeat(7, minmax(210px, 250px)); overflow-x: auto; }
}
@media (max-width: 900px) {
  #admin-orders-modal .orders-toolbar { grid-template-columns: 1fr 1fr; }
  #admin-orders-modal .orders-toolbar .input:first-child { grid-column: 1 / -1; }
  #admin-orders-modal .orders-toolbar .btn { width: 100%; }
  .orders-view-toggle { justify-content: center; }
  .orders-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  #admin-orders-modal .orders-toolbar { grid-template-columns: 1fr; }
  #admin-orders-modal .orders-toolbar .input:first-child { grid-column: auto; }
  .orders-stats { grid-template-columns: 1fr 1fr; }
  .orders-stat { min-height: 54px; padding: 9px; }
  .orders-board { grid-template-columns: repeat(7, minmax(190px, 82vw)); }
}

/* v134: admin order archive */
.order-card--archived,
.orders-board-card.order-card--archived {
  opacity: .68;
  filter: grayscale(.18);
  border-style: dashed;
}
.order-card--archived .order-card__price,
.orders-board-card.order-card--archived b {
  opacity: .82;
}
.order-badge--archive {
  background: rgba(148, 163, 184, .16);
  border-color: rgba(148, 163, 184, .34);
  color: #cbd5e1;
}
.orders-stat--archive b { color: #cbd5e1; }
body[data-theme="light"] .order-badge--archive {
  background: #f1f5f9;
  border-color: #cbd5e1;
  color: #475569;
}
body[data-theme="light"] .orders-stat--archive b { color: #475569; }
.orders-toolbar #admin-orders-archive-filter {
  min-width: 132px;
}

/* v135: professional model catalog — filters, categories, favorites, richer cards. */
.model-picker--pro {
  gap: 14px;
}
.catalog-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.catalog-stat {
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.085);
  display: grid;
  gap: 2px;
  min-width: 0;
}
.catalog-stat b {
  font-size: 18px;
  line-height: 1.05;
  color: #eef7ff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.catalog-stat span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.catalog-search-row,
.catalog-filter-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 170px;
  gap: 10px;
  align-items: center;
}
.catalog-filter-row {
  grid-template-columns: minmax(0, 1fr) 140px auto;
}
.catalog-chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 2px 2px 6px;
  scrollbar-width: thin;
}
.catalog-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
  color: #dbeafe;
  border-radius: 999px;
  padding: 8px 11px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
.catalog-chip b {
  min-width: 20px;
  height: 20px;
  display: inline-grid;
  place-items: center;
  padding: 0 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.09);
  color: #9bdcff;
  font-size: 11px;
}
.catalog-chip.is-active {
  border-color: rgba(30,168,255,.55);
  background: rgba(30,168,255,.16);
  color: #ffffff;
}
.template-list--catalog-pro {
  max-height: min(62vh, 640px);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}
.template-list--catalog-pro .template-item--catalog {
  position: relative;
  min-width: 0;
  height: 100%;
}
.template-list--catalog-pro .catalog-model-card {
  position: relative;
  height: 100%;
  padding-right: 36px;
}
.catalog-model-card__favorite {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(6, 9, 15, .72);
  color: #dbeafe;
  display: grid;
  place-items: center;
  cursor: pointer;
  font-size: 17px;
  line-height: 1;
  z-index: 2;
}
.catalog-model-card__favorite.is-active {
  color: #ffd84d;
  border-color: rgba(255,216,77,.42);
  background: rgba(255,216,77,.12);
}
.catalog-model-card__facts {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 1px;
}
.catalog-model-card__facts span {
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.045);
  color: var(--soft);
  font-size: 11px;
  font-weight: 700;
}
.hint-card--compact {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(30,168,255,.08);
  border: 1px solid rgba(30,168,255,.16);
  color: var(--soft);
  font-size: 12px;
}
body[data-theme="light"] .catalog-stat,
body[data-theme="light"] .catalog-chip,
body[data-theme="light"] .catalog-model-card__facts span {
  background: #ffffff;
  border-color: #e2e8f0;
  color: #0f172a;
}
body[data-theme="light"] .catalog-stat b { color: #0f172a; }
body[data-theme="light"] .catalog-chip b {
  background: #eaf3ff;
  color: #0369a1;
}
body[data-theme="light"] .catalog-chip.is-active {
  background: #e0f2fe;
  border-color: #7dd3fc;
}
body[data-theme="light"] .catalog-model-card__favorite {
  background: rgba(255,255,255,.92);
  color: #475569;
  border-color: #e2e8f0;
}
body[data-theme="light"] .catalog-model-card__favorite.is-active {
  color: #ca8a04;
  border-color: #fde68a;
  background: #fffbeb;
}
body[data-theme="light"] .hint-card--compact {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #334155;
}
@media (max-width: 920px) {
  .template-list--catalog-pro { grid-template-columns: 1fr; }
  .catalog-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .catalog-search-row,
  .catalog-filter-row { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .catalog-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .catalog-stat { padding: 9px 10px; }
  .catalog-stat b { font-size: 15px; }
  .template-list--catalog-pro .catalog-model-card { padding-right: 32px; }
}


/* v136: быстрые варианты конфигурации, как в полноценном продукте */
.config-smart-panel {
  flex: 0 0 auto;
  display: grid;
  gap: 10px;
  padding: 12px;
  margin-bottom: 10px;
  border-radius: 18px;
  border: 1px solid rgba(30,168,255,.18);
  background: linear-gradient(135deg, rgba(30,168,255,.10), rgba(255,255,255,.035));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.config-smart-panel.hidden { display: none !important; }
.config-smart-panel__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.config-smart-panel__top h3 {
  margin: 2px 0 0;
  font-size: 15px;
  line-height: 1.1;
  color: #eef7ff;
}
.config-smart-panel__status {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
  border: 1px solid rgba(34,197,94,.20);
  background: rgba(34,197,94,.10);
  color: #bbf7d0;
}
.config-smart-panel__status.is-bad {
  border-color: rgba(248,113,113,.28);
  background: rgba(248,113,113,.10);
  color: #fecaca;
}
.config-smart-panel__chips {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.config-preset-chip {
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color: #e2e8f0;
  border-radius: 999px;
  padding: 8px 9px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}
.config-preset-chip:hover { border-color: rgba(30,168,255,.42); background: rgba(30,168,255,.12); }
.config-preset-chip.is-primary {
  background: linear-gradient(135deg, rgba(30,168,255,.32), rgba(56,189,248,.16));
  border-color: rgba(56,189,248,.44);
  color: #ffffff;
}
.config-preset-chip:disabled { opacity: .45; cursor: not-allowed; }
.config-smart-panel__facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.config-smart-panel__facts span {
  min-width: 0;
  display: grid;
  gap: 2px;
  padding: 8px 9px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(6, 9, 15, .22);
}
.config-smart-panel__facts b {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #f8fafc;
  font-size: 13px;
}
.config-smart-panel__facts small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}
body[data-theme="light"] .config-smart-panel {
  background: linear-gradient(135deg, #eff6ff, #ffffff);
  border-color: #bfdbfe;
}
body[data-theme="light"] .config-smart-panel__top h3 { color: #0f172a; }
body[data-theme="light"] .config-smart-panel__status {
  background: #ecfdf5;
  border-color: #bbf7d0;
  color: #047857;
}
body[data-theme="light"] .config-smart-panel__status.is-bad {
  background: #fef2f2;
  border-color: #fecaca;
  color: #b91c1c;
}
body[data-theme="light"] .config-preset-chip {
  background: #ffffff;
  border-color: #dbeafe;
  color: #0f172a;
}
body[data-theme="light"] .config-preset-chip.is-primary {
  background: #e0f2fe;
  border-color: #7dd3fc;
  color: #075985;
}
body[data-theme="light"] .config-smart-panel__facts span {
  background: #ffffff;
  border-color: #e2e8f0;
}
body[data-theme="light"] .config-smart-panel__facts b { color: #0f172a; }
@media (max-width: 560px) {
  .config-smart-panel { padding: 10px; border-radius: 16px; }
  .config-smart-panel__chips,
  .config-smart-panel__facts { grid-template-columns: 1fr; }
  .config-preset-chip { padding: 9px 10px; }
}

/* v137 — StorageBuilder-style checkout review before order submit */
.modal__dialog--checkout {
  width: min(920px, calc(100vw - 24px));
  max-height: min(92vh, 860px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.modal__header--checkout {
  flex: 0 0 auto;
}
.checkout-form {
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
}
.checkout-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.checkout-step {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
  color: #aeb7c9;
  font-size: 13px;
}
.checkout-step b {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #eef4ff;
  font-size: 13px;
}
.checkout-step.is-done {
  border-color: rgba(34,197,94,.22);
  background: rgba(34,197,94,.08);
  color: #d6f8df;
}
.checkout-step.is-active {
  border-color: rgba(59,130,246,.35);
  background: rgba(59,130,246,.12);
  color: #e8f1ff;
}
.checkout-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, .75fr);
  gap: 14px;
}
.checkout-card {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  padding: 16px;
  min-width: 0;
}
.checkout-card__title {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #9eabc3;
  font-weight: 800;
  margin-bottom: 12px;
}
.checkout-model-line {
  display: grid;
  gap: 4px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.16);
  margin-bottom: 12px;
}
.checkout-model-line span,
.checkout-spec span {
  color: #9aa6bb;
  font-size: 12px;
}
.checkout-model-line strong {
  color: #f6f8ff;
  font-size: 18px;
  line-height: 1.2;
}
.checkout-model-line em {
  font-style: normal;
  color: #b4c4df;
  font-size: 13px;
}
.checkout-spec-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.checkout-spec {
  min-width: 0;
  padding: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  display: grid;
  gap: 6px;
}
.checkout-spec strong {
  color: #f7f9ff;
  font-size: 16px;
  line-height: 1.2;
}
.checkout-spec small {
  display: block;
  color: #a5b0c5;
  font-size: 12px;
  font-weight: 600;
  margin-top: 3px;
}
.checkout-price-main {
  display: block;
  font-size: 20px;
  font-weight: 900;
}
.checkout-color-dot {
  display: inline-block;
  width: 13px;
  height: 13px;
  border-radius: 999px;
  margin-right: 7px;
  border: 1px solid rgba(255,255,255,.28);
  vertical-align: -1px;
}
.checkout-params {
  display: grid;
  gap: 7px;
  max-height: 260px;
  overflow: auto;
  padding-right: 4px;
}
.checkout-param-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.035);
  font-size: 13px;
}
.checkout-param-row span { color: #a8b2c8; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.checkout-param-row b { color: #edf3ff; white-space: nowrap; }
.checkout-customer {
  display: grid;
  gap: 7px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.14);
  color: #dce5f5;
  margin-bottom: 12px;
}
.checkout-customer__name { font-size: 17px; font-weight: 800; color: #f4f7ff; }
.checkout-customer__row { color: #aeb8cb; font-size: 13px; }
.checkout-customer__row b { color: #edf3ff; }
.checkout-checklist {
  display: grid;
  gap: 8px;
}
.checkout-checklist__item {
  padding: 9px 10px;
  border-radius: 12px;
  background: rgba(34,197,94,.075);
  color: #d8f7e0;
  font-size: 13px;
  line-height: 1.35;
}
.checkout-comment {
  margin-top: 14px;
}
.checkout-legal {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.03);
  color: #aeb8c9;
  font-size: 13px;
  line-height: 1.45;
}
.checkout-legal a { color: #bcd4ff; }
.checkout-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  position: sticky;
  bottom: -1px;
  padding-top: 10px;
  background: linear-gradient(180deg, rgba(18,20,27,0), rgba(18,20,27,.96) 35%);
}
.checkout-submit {
  min-width: 190px;
}
body[data-theme="light"] .checkout-step,
body[data-theme="light"] .checkout-card,
body[data-theme="light"] .checkout-legal {
  border-color: rgba(15,23,42,.10);
  background: #ffffff;
}
body[data-theme="light"] .checkout-model-line,
body[data-theme="light"] .checkout-customer {
  background: #f5f7fb;
}
body[data-theme="light"] .checkout-spec,
body[data-theme="light"] .checkout-param-row {
  background: #f7f9fc;
}
body[data-theme="light"] .checkout-model-line strong,
body[data-theme="light"] .checkout-spec strong,
body[data-theme="light"] .checkout-param-row b,
body[data-theme="light"] .checkout-customer__name,
body[data-theme="light"] .checkout-customer__row b {
  color: #111827;
}
body[data-theme="light"] .checkout-model-line span,
body[data-theme="light"] .checkout-spec span,
body[data-theme="light"] .checkout-param-row span,
body[data-theme="light"] .checkout-customer__row,
body[data-theme="light"] .checkout-card__title,
body[data-theme="light"] .checkout-legal {
  color: #64748b;
}
body[data-theme="light"] .checkout-actions {
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.98) 35%);
}
body[data-theme="light"] .checkout-checklist__item {
  background: #ecfdf3;
  color: #166534;
}
@media (max-width: 760px) {
  .modal__dialog--checkout {
    width: calc(100vw - 16px);
    max-height: calc(100dvh - 16px);
  }
  .checkout-steps { grid-template-columns: 1fr; gap: 7px; }
  .checkout-step { padding: 8px 10px; }
  .checkout-grid { grid-template-columns: 1fr; }
  .checkout-spec-grid { grid-template-columns: 1fr; }
  .checkout-params { max-height: 210px; }
  .checkout-actions { display: grid; grid-template-columns: 1fr; }
  .checkout-submit { min-width: 0; }
}

/* v138 — undo/redo configuration history */
.viewer-toolbar__btn--history {
  min-width: 102px;
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.68);
  color: rgba(241, 245, 249, 0.92);
}
.viewer-toolbar__btn--history:not(:disabled):hover {
  border-color: rgba(88, 166, 255, 0.42);
  background: rgba(30, 41, 59, 0.86);
}
.viewer-toolbar__btn--history:disabled,
.viewer-toolbar__btn--history.is-disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none !important;
}
body[data-theme="light"] .viewer-toolbar__btn--history {
  background: rgba(255,255,255,0.82);
  color: #1f2937;
  border-color: rgba(15, 23, 42, 0.12);
}
@media (max-width: 760px) {
  .viewer-toolbar__btn--history {
    min-width: 82px;
    font-size: 11px;
    padding: 8px 8px;
  }
}

/* v139 — draft autosave and order readiness */
.viewer-toolbar__draft {
  align-self: center;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(114, 151, 255, 0.22);
  background: rgba(15, 23, 42, 0.68);
  color: #b9c7e8;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}
.viewer-toolbar__draft.is-saving { color: #f6d98d; border-color: rgba(246, 217, 141, .35); }
.viewer-toolbar__draft.is-saved { color: #a7f3d0; border-color: rgba(34, 197, 94, .35); }
.viewer-toolbar__draft.is-muted { color: #99a5ba; }
body[data-theme="light"] .viewer-toolbar__draft {
  background: rgba(255,255,255,.86);
  color: #42516c;
  border-color: rgba(55, 93, 180, .18);
}
.draft-restore-summary {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 16px;
  background: rgba(15, 23, 42, .42);
  color: #dbe7ff;
  font-size: 13px;
}
.draft-restore-summary b { color: #fff; }
.draft-restore-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 16px;
}
.checkout-readiness {
  display: grid;
  gap: 7px;
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(9, 14, 25, .33);
  color: #c9d5ea;
  font-size: 13px;
}
.checkout-readiness__title {
  font-weight: 900;
  color: #f4f7ff;
}
.checkout-readiness__item {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  line-height: 1.35;
}
.checkout-readiness__item.is-ok::before { content: '✓'; color: #86efac; font-weight: 900; }
.checkout-readiness__item.is-warn::before { content: '!'; color: #fde68a; font-weight: 900; }
.checkout-readiness__item.is-bad::before { content: '×'; color: #fca5a5; font-weight: 900; }
body[data-theme="light"] .draft-restore-summary,
body[data-theme="light"] .checkout-readiness {
  background: rgba(248,250,252,.9);
  border-color: rgba(33, 62, 122, .12);
  color: #44516a;
}
body[data-theme="light"] .draft-restore-summary b,
body[data-theme="light"] .checkout-readiness__title { color: #172033; }
@media (max-width: 720px) {
  .viewer-toolbar__draft { order: 99; width: 100%; text-align: center; }
  .draft-restore-actions { flex-direction: column-reverse; }
  .draft-restore-actions .btn { width: 100%; }
}

/* v140 — сравнение вариантов конфигурации */
.modal__dialog--compare-designs {
  width: min(980px, calc(100vw - 24px));
}
.compare-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}
.compare-designs-list {
  max-height: min(64vh, 620px);
  overflow-y: auto;
  padding-right: 4px;
}
.compare-designs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.compare-card {
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.62), rgba(15, 23, 42, 0.42));
  border-radius: 20px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 240px;
}
.compare-card.is-best {
  border-color: rgba(34, 197, 94, 0.55);
  box-shadow: 0 14px 36px rgba(34, 197, 94, 0.08);
}
.compare-card.is-high {
  border-color: rgba(249, 115, 22, 0.42);
}
.compare-card__top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}
.compare-card__title {
  font-weight: 900;
  color: var(--text, #eef5ff);
}
.compare-card__meta {
  margin-top: 3px;
  font-size: 12px;
  color: var(--muted, #93a4bb);
  line-height: 1.35;
}
.compare-card__color {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
  flex: 0 0 auto;
}
.compare-card__price {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: #f8fbff;
}
.compare-card__facts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.compare-card__facts span {
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(2, 6, 23, 0.22);
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 12px;
  color: var(--muted, #a8b4c7);
}
.compare-card__params {
  font-size: 12px;
  line-height: 1.45;
  color: var(--muted, #a8b4c7);
  flex: 1;
}
.compare-card__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: auto;
}
body[data-theme="light"] .compare-card,
body.light .compare-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.82));
  border-color: rgba(15, 23, 42, 0.12);
}
body[data-theme="light"] .compare-card__price,
body.light .compare-card__price {
  color: #0f172a;
}
body[data-theme="light"] .compare-card__facts span,
body.light .compare-card__facts span {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.12);
}
@media (max-width: 720px) {
  .modal__dialog--compare-designs {
    width: calc(100vw - 14px);
  }
  .compare-designs-grid {
    grid-template-columns: 1fr;
  }
  .compare-card {
    min-height: auto;
  }
}

/* v142: удобное управление моделями в админском каталоге */
.template-item__actions--admin {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 0 12px 12px;
}
.template-item__actions--admin .btn {
  justify-content: center;
  min-height: 34px;
  padding-inline: 10px;
}
.btn--danger-soft {
  color: #ffb4b4;
  border-color: rgba(255, 92, 92, 0.35);
  background: rgba(255, 92, 92, 0.08);
}
.btn--danger-soft:hover {
  border-color: rgba(255, 92, 92, 0.58);
  background: rgba(255, 92, 92, 0.14);
}
body[data-theme="light"] .btn--danger-soft,
body.light .btn--danger-soft {
  color: #b91c1c;
  border-color: rgba(185, 28, 28, 0.28);
  background: rgba(185, 28, 28, 0.06);
}


/* v143: customer showcase quick model switcher */
.customer-model-strip {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.customer-model-mini {
  width: 100%;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
  color: inherit;
  border-radius: 16px;
  padding: 8px;
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 10px;
  align-items: center;
  text-align: left;
  cursor: pointer;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
}
.customer-model-mini:hover,
.customer-model-mini.is-active {
  border-color: rgba(117, 198, 255, .62);
  background: rgba(117, 198, 255, .10);
  transform: translateY(-1px);
}
.customer-model-mini__thumb {
  width: 46px;
  height: 46px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  overflow: hidden;
  font-weight: 900;
  background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.035));
  color: rgba(255,255,255,.72);
}
.customer-model-mini__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.customer-model-mini__body {
  min-width: 0;
  display: grid;
  gap: 3px;
}
.customer-model-mini__body b {
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.customer-model-mini__body em {
  font-size: 12px;
  font-style: normal;
  opacity: .68;
}
.customer-model-mini--more {
  grid-template-columns: 1fr;
  justify-items: center;
  font-weight: 800;
  color: rgba(173, 219, 255, .96);
}
.customer-model-strip__empty {
  padding: 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.045);
  color: rgba(255,255,255,.68);
  font-size: 13px;
}
body[data-theme="light"] .customer-model-mini,
body[data-theme="light"] .customer-model-strip__empty {
  border-color: rgba(16, 24, 40, .10);
  background: rgba(16, 24, 40, .035);
}
body[data-theme="light"] .customer-model-mini__thumb {
  background: linear-gradient(135deg, rgba(15, 23, 42, .08), rgba(15, 23, 42, .025));
  color: rgba(15, 23, 42, .70);
}
body[data-theme="light"] .customer-model-mini--more { color: #0f6fb5; }

/* === V144 PARAMETER WORKBENCH === */
.param-workbench {
  display: grid;
  gap: 12px;
  padding: 12px;
  margin: 0 0 12px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.070), rgba(255,255,255,.035));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.param-workbench__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.param-workbench__head h3 { margin: 2px 0 0; font-size: 15px; }
.param-workbench__search .input { width: 100%; }
.param-workbench__quick {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.param-chip {
  border: 1px solid rgba(117,198,255,.22);
  background: rgba(117,198,255,.09);
  color: inherit;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
  font-size: 12px;
  cursor: pointer;
}
.param-chip:hover,
.param-chip.is-active { border-color: rgba(117,198,255,.70); background: rgba(117,198,255,.16); }
.param-workbench__pinned {
  display: grid;
  gap: 8px;
  padding-top: 2px;
}
.param-workbench__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.55);
  font-weight: 900;
}
.param-pinned-list { display: grid; gap: 8px; }
.param-pin-card {
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px;
  padding: 9px;
  background: rgba(0,0,0,.12);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}
.param-pin-card b { font-size: 12px; }
.param-pin-card small { opacity: .65; }
.param-pin-card button {
  border: 0;
  border-radius: 10px;
  padding: 6px 8px;
  color: inherit;
  background: rgba(255,255,255,.08);
  cursor: pointer;
}
.field.is-param-hidden { display: none !important; }
.field__pin-btn {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.055);
  color: inherit;
  border-radius: 10px;
  width: 26px;
  height: 26px;
  cursor: pointer;
  font-weight: 900;
}
.field__pin-btn.is-active { border-color: rgba(117,198,255,.65); background: rgba(117,198,255,.18); }
body[data-theme="light"] .param-workbench {
  border-color: rgba(16,24,40,.10);
  background: linear-gradient(180deg, rgba(16,24,40,.045), rgba(16,24,40,.022));
}
body[data-theme="light"] .param-workbench__label { color: rgba(16,24,40,.55); }
body[data-theme="light"] .param-pin-card { border-color: rgba(16,24,40,.08); background: rgba(16,24,40,.035); }


/* v147 admin production readiness */
.order-admin-checklist {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px 12px;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 14px;
  background: rgba(15, 23, 42, .26);
}
.order-admin-checklist label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text, #e5e7eb);
}
.order-admin-checklist input {
  width: 16px;
  height: 16px;
  accent-color: #22c55e;
}


/* v148 production queue */
.production-toolbar{display:grid;grid-template-columns:1fr 180px 180px;gap:10px;margin-bottom:14px}.production-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:14px}.production-stat{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.045);border-radius:16px;padding:12px}.production-stat span{display:block;color:var(--muted);font-size:12px}.production-stat b{font-size:22px}.production-list{display:grid;gap:12px}.production-card{display:flex;gap:14px;border:1px solid rgba(255,255,255,.09);background:linear-gradient(135deg,rgba(255,255,255,.065),rgba(255,255,255,.025));border-radius:20px;padding:14px;box-shadow:0 18px 60px rgba(0,0,0,.18)}.production-card--urgent{border-color:rgba(255,95,95,.45)}.production-card--hold{opacity:.72}.production-card__rank{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.08);font-weight:800}.production-card__main{flex:1;min-width:0}.production-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.production-card h3{margin:0;font-size:17px}.production-card p{margin:4px 0 0;color:var(--muted);font-size:13px}.production-badge{white-space:nowrap;border-radius:999px;padding:6px 10px;background:rgba(255,255,255,.08);font-size:12px;font-weight:700}.production-badge--printing{background:rgba(80,160,255,.18)}.production-badge--ready{background:rgba(90,220,150,.16)}.production-meta{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-top:12px}.production-meta span{border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:8px;background:rgba(0,0,0,.12);font-size:12px;min-width:0;overflow:hidden;text-overflow:ellipsis}.production-meta b{display:block;color:var(--muted);font-size:11px;margin-bottom:2px}.production-note{margin-top:10px;border-radius:14px;padding:10px;background:rgba(255,210,90,.08);color:var(--text);font-size:13px}.production-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}@media(max-width:900px){.production-toolbar{grid-template-columns:1fr}.production-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.production-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.production-card{flex-direction:column}.production-card__rank{width:100%}}

/* v149: professional model cards */
.admin-upload-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.catalog-model-card__pro-facts,
.catalog-model-card__highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.catalog-model-card__pro-facts span {
  border: 1px solid rgba(148, 163, 184, .22);
  background: rgba(15, 23, 42, .42);
  color: rgba(226, 232, 240, .88);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
}
.catalog-model-card__highlights span {
  color: rgba(190, 242, 100, .92);
  font-size: 11px;
  font-weight: 700;
}
body[data-theme="light"] .catalog-model-card__pro-facts span {
  background: rgba(241, 245, 249, .9);
  color: #334155;
  border-color: rgba(148, 163, 184, .42);
}
body[data-theme="light"] .catalog-model-card__highlights span {
  color: #166534;
}
@media (max-width: 720px) {
  .admin-upload-grid { grid-template-columns: 1fr; }
}

/* v150: материал, цвет и смета заказа */
.checkout-material-panel{
  margin: 12px 0 16px;
  padding: 14px;
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(15,23,42,.92), rgba(30,41,59,.72));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.checkout-material-panel__head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}
.checkout-material-panel__head strong{display:block;color:#f8fafc;font-size:14px;margin-bottom:3px}
.checkout-material-panel__head span{display:block;color:#94a3b8;font-size:12px;line-height:1.35}
.checkout-material-panel__badge{white-space:nowrap;border-radius:999px;padding:6px 10px;background:rgba(34,197,94,.14);color:#bbf7d0;font-weight:800;font-size:12px;border:1px solid rgba(34,197,94,.28)}
.checkout-material-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.checkout-material-grid label span{display:block;color:#cbd5e1;font-size:12px;margin-bottom:5px}
.checkout-material-help{margin-top:10px;color:#cbd5e1;font-size:12px;line-height:1.45;background:rgba(15,23,42,.55);border-radius:12px;padding:9px 10px;border:1px solid rgba(148,163,184,.16)}
@media (max-width: 720px){.checkout-material-grid{grid-template-columns:1fr}.checkout-material-panel__head{display:block}.checkout-material-panel__badge{display:inline-block;margin-top:8px}}

.checkout-color-swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.checkout-color-swatch {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid rgba(148,163,184,.24);
  background: rgba(15,23,42,.58);
  color: #dbeafe;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
.checkout-color-swatch span {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.45);
  box-shadow: 0 0 0 2px rgba(15,23,42,.4);
}
.checkout-color-swatch.is-active {
  border-color: rgba(56,189,248,.78);
  box-shadow: 0 0 0 3px rgba(56,189,248,.14);
}

/* === V154 LIVE SIZE CONFIGURATOR === */
.live-size-panel{
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
  border-radius:18px;
  padding:14px;
  margin:12px 0;
  box-shadow:0 14px 34px rgba(0,0,0,.16);
}
.live-size-panel.hidden{display:none!important;}
.live-size-panel__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;}
.live-size-panel__head h3{margin:2px 0 0;font-size:15px;line-height:1.15;}
.live-size-lock{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:rgba(255,255,255,.76);user-select:none;}
.live-size-lock input{accent-color:#67e8f9;}
.live-size-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;}
.live-size-control{display:flex;flex-direction:column;gap:5px;font-size:12px;color:rgba(255,255,255,.70);}
.live-size-control .input{height:36px;padding:0 9px;font-weight:700;}
.live-size-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px;}
.live-size-hint{font-size:11px;color:rgba(255,255,255,.52);text-align:right;}
@media (max-width:720px){.live-size-grid{grid-template-columns:1fr}.live-size-actions{align-items:flex-start;flex-direction:column}.live-size-hint{text-align:left}}

/* v155: modular assembly workbench */
.assembly-card{position:relative;overflow:hidden}
.assembly-badge{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(148,163,184,.28);background:rgba(15,23,42,.45);border-radius:999px;padding:6px 10px;font-size:12px;color:#cbd5e1;white-space:nowrap}
.assembly-active{border:1px solid rgba(59,130,246,.28);background:linear-gradient(135deg,rgba(59,130,246,.13),rgba(15,23,42,.24));border-radius:16px;padding:10px 12px;color:#dbeafe;font-size:13px;margin-bottom:12px}
.assembly-library{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
.assembly-add{border:1px solid rgba(148,163,184,.24);background:rgba(2,6,23,.35);color:#e5e7eb;border-radius:16px;padding:10px;text-align:left;cursor:pointer;transition:.18s ease;min-height:62px}
.assembly-add:hover{transform:translateY(-1px);border-color:rgba(59,130,246,.45);background:rgba(30,41,59,.55)}
.assembly-add b{display:block;font-size:13px;margin-bottom:3px}.assembly-add span{display:block;font-size:11px;color:#94a3b8}
.assembly-list{display:flex;flex-direction:column;gap:8px;max-height:240px;overflow:auto;padding-right:2px}
.assembly-row{display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;border:1px solid rgba(148,163,184,.22);background:rgba(15,23,42,.42);border-radius:16px;padding:8px;cursor:pointer}
.assembly-row.is-active{border-color:rgba(34,197,94,.5);box-shadow:0 0 0 1px rgba(34,197,94,.12) inset;background:rgba(20,83,45,.17)}
.assembly-row__thumb{width:34px;height:34px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(59,130,246,.32),rgba(14,165,233,.12));font-weight:800;color:#bfdbfe;overflow:hidden}
.assembly-row__thumb img{width:100%;height:100%;object-fit:cover}.assembly-row__title{font-size:13px;color:#f8fafc;font-weight:700;line-height:1.2}.assembly-row__meta{font-size:11px;color:#94a3b8;margin-top:2px}.assembly-row__actions{display:flex;gap:4px}.assembly-mini-btn{width:28px;height:28px;border-radius:10px;border:1px solid rgba(148,163,184,.24);background:rgba(2,6,23,.25);color:#cbd5e1;cursor:pointer}.assembly-mini-btn:hover{background:rgba(239,68,68,.18);color:#fecaca;border-color:rgba(239,68,68,.38)}
.assembly-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.assembly-empty{font-size:12px;color:#94a3b8;border:1px dashed rgba(148,163,184,.28);border-radius:14px;padding:12px;text-align:center}


/* v156: drag/drop assembly placement */
.assembly-row[draggable="true"]{user-select:none}
.assembly-row[draggable="true"]:active{cursor:grabbing}
.assembly-row__pos{font-size:10px;color:#7dd3fc;margin-top:3px;letter-spacing:.02em}
.assembly-transform{margin-top:12px;border:1px solid rgba(59,130,246,.24);background:rgba(2,6,23,.28);border-radius:18px;padding:12px}
.assembly-transform__head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;color:#f8fafc;font-size:13px}
.assembly-transform__head span{font-size:11px;color:#93c5fd}
.assembly-transform__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.assembly-transform__field{display:flex;flex-direction:column;gap:4px;font-size:11px;color:#94a3b8}
.assembly-transform__field input{width:100%;border:1px solid rgba(148,163,184,.24);background:rgba(15,23,42,.72);color:#e5e7eb;border-radius:11px;padding:8px 9px;outline:none}
.assembly-transform__field input:focus{border-color:rgba(59,130,246,.62);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.assembly-transform__actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
@media (max-width:760px){.assembly-transform__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.assembly-library{grid-template-columns:1fr}}


/* V157 CAD inspection mode */
.cad-hud {
  position: absolute;
  left: 18px;
  bottom: 76px;
  z-index: 8;
  width: 238px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(10, 14, 20, 0.78);
  border: 1px solid rgba(148, 163, 184, 0.22);
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.28);
  color: #eef3f9;
}
.cad-hud__title { font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: #93c5fd; margin-bottom: 8px; }
.cad-hud__row { display: flex; align-items: center; justify-content: space-between; gap: 10px; font-size: 12px; font-weight: 700; margin: 8px 0; }
.cad-hud input[type="range"] { width: 142px; accent-color: #38bdf8; }
.cad-hud__chips { justify-content: flex-start; }
.cad-chip { border: 1px solid rgba(148,163,184,.28); background: rgba(15,23,42,.72); color: #dbeafe; border-radius: 999px; padding: 5px 10px; font-weight: 800; cursor: pointer; }
.cad-chip.is-active { background: rgba(56,189,248,.20); border-color: rgba(125,211,252,.70); color: #fff; }
.cad-hud__hint { color: #aab6c5; font-size: 11px; margin-top: 6px; }
body[data-theme="light"] .cad-hud { background: rgba(255,255,255,.86); color: #0f172a; border-color: rgba(15,23,42,.12); }
body[data-theme="light"] .cad-chip { background: rgba(248,250,252,.86); color: #0f172a; }


/* v158: professional dimension overlay */
.dimension-hud {
  position: absolute;
  left: 18px;
  bottom: 86px;
  z-index: 7;
  min-width: 210px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(8, 12, 18, 0.68);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 32px rgba(0,0,0,0.26);
  pointer-events: none;
}
.dimension-hud__title {
  color: #e9f1fb;
  font-weight: 800;
  font-size: 12px;
  margin-bottom: 8px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.dimension-hud__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.dimension-hud__grid div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 8px;
  border-radius: 12px;
  background: rgba(255,255,255,0.055);
}
.dimension-hud__grid span { color: #9fb1c7; font-size: 11px; }
.dimension-hud__grid b { color: #f8fbff; font-size: 12px; }
.viewer-dimensions__line--arrow { stroke-width: 1.35; }
.viewer-dimensions__label::after {
  content: attr(data-part-name);
  display: block;
  font-size: 9px;
  color: rgba(233,239,247,0.62);
  font-weight: 600;
  margin-top: 1px;
}
body[data-theme="light"] .dimension-hud {
  background: rgba(248,250,252,0.82);
  border-color: rgba(15,23,42,0.10);
}
body[data-theme="light"] .dimension-hud__title,
body[data-theme="light"] .dimension-hud__grid b { color: #0f172a; }
body[data-theme="light"] .dimension-hud__grid span { color: #64748b; }
body[data-theme="light"] .dimension-hud__grid div { background: rgba(15,23,42,0.055); }


/* v159: premium render mode */
.viewer-card--builder:has(.viewer--beauty),
.viewer--beauty {
  background:
    radial-gradient(circle at 18% 12%, rgba(125, 211, 252, 0.16), transparent 32%),
    radial-gradient(circle at 78% 18%, rgba(167, 139, 250, 0.13), transparent 34%),
    linear-gradient(145deg, rgba(15, 23, 42, 0.98), rgba(2, 6, 23, 0.96));
}
.viewer--beauty canvas {
  filter: saturate(1.08) contrast(1.04) drop-shadow(0 24px 48px rgba(0,0,0,.36));
}
.viewer--beauty::after {
  content: 'Premium preview';
  position: absolute;
  left: 18px;
  bottom: 18px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .22);
  background: rgba(15, 23, 42, .55);
  color: rgba(226, 232, 240, .78);
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
  pointer-events: none;
  backdrop-filter: blur(10px);
}

.viewer-toolbar__btn--accent {
  border-color: rgba(34, 211, 238, .42);
  background: linear-gradient(135deg, rgba(34,211,238,.18), rgba(59,130,246,.16));
  color: #dffbff;
}
.viewer-toolbar__btn--accent:hover {
  border-color: rgba(34, 211, 238, .75);
  box-shadow: 0 10px 24px rgba(34,211,238,.16);
}


/* v165: облачные проекты в личном кабинете */
.cloud-projects-panel {
  display: grid;
  gap: 12px;
  margin: 0 0 14px;
}
.cloud-projects-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.cloud-projects-stat {
  padding: 12px 14px;
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 16px;
  background: rgba(15, 23, 42, .54);
}
.cloud-projects-stat b {
  display: block;
  font-size: 18px;
  line-height: 1.15;
  color: #f8fafc;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cloud-projects-stat span {
  display: block;
  margin-top: 4px;
  color: #94a3b8;
  font-size: 12px;
}
.cloud-projects-controls {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 190px;
  gap: 10px;
}
.cloud-projects-search,
.cloud-projects-filter {
  width: 100%;
}
.saved-design-card__status {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin: 7px 0 2px;
  padding: 4px 8px;
  border: 1px solid rgba(96, 165, 250, .32);
  border-radius: 999px;
  background: rgba(37, 99, 235, .14);
  color: #bfdbfe;
  font-size: 12px;
  font-weight: 700;
}
body.light .cloud-projects-stat {
  background: rgba(255, 255, 255, .82);
  border-color: rgba(15, 23, 42, .12);
}
body.light .cloud-projects-stat b { color: #0f172a; }
body.light .cloud-projects-stat span { color: #64748b; }
body.light .saved-design-card__status {
  background: rgba(37, 99, 235, .08);
  color: #1d4ed8;
}
@media (max-width: 760px) {
  .cloud-projects-stats,
  .cloud-projects-controls {
    grid-template-columns: 1fr;
  }
}

/* v166: админское управление проектами клиентов */
.admin-projects-head {
  margin-bottom: 14px;
}
.admin-design-projects-list {
  gap: 12px;
}
.admin-design-project-card {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  align-items: stretch;
}
.admin-design-project-card__controls {
  display: grid;
  gap: 8px;
  align-content: start;
}
.admin-design-project-card__controls textarea.input {
  min-height: 76px;
  resize: vertical;
}
@media (max-width: 920px) {
  .admin-design-project-card {
    grid-template-columns: 1fr;
  }
}

/* === V168 NOTIFICATIONS CENTER === */
.notifications-list {
  display: grid;
  gap: 12px;
}
.notification-card {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 18px;
  background: rgba(15, 23, 42, 0.72);
  box-shadow: 0 14px 34px rgba(2, 6, 23, 0.22);
}
.notification-card--new {
  border-color: rgba(56, 189, 248, 0.55);
  background: linear-gradient(135deg, rgba(14, 116, 144, 0.24), rgba(15, 23, 42, 0.82));
}
.notification-card__icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  font-size: 20px;
}
.notification-card__title {
  font-weight: 800;
  color: #f8fafc;
}
.notification-card__text,
.notification-card__date {
  margin-top: 4px;
  color: rgba(226, 232, 240, 0.78);
  font-size: 13px;
}
.notification-card__date {
  color: rgba(148, 163, 184, 0.9);
}
.floating-notifications-btn {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 40;
  border: 1px solid rgba(148, 163, 184, 0.24);
  border-radius: 999px;
  padding: 10px 14px;
  color: #f8fafc;
  background: rgba(15, 23, 42, 0.86);
  box-shadow: 0 18px 42px rgba(2, 6, 23, 0.32);
  cursor: pointer;
}
.floating-notifications-badge {
  margin-left: 6px;
  min-width: 20px;
  height: 20px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: #ef4444;
  color: white;
  font-size: 12px;
  font-weight: 900;
}
.cloud-projects-controls--compact {
  justify-content: flex-end;
  margin-bottom: 12px;
}
@media (max-width: 720px) {
  .notification-card { grid-template-columns: 36px minmax(0, 1fr); }
  .notification-card .btn { grid-column: 1 / -1; }
  .floating-notifications-btn { top: auto; bottom: 16px; right: 12px; }
}


/* V170 Smart Snap constructor */
.assembly-smart-snap{margin:10px 0 12px;padding:12px;border:1px solid rgba(148,163,184,.22);border-radius:16px;background:linear-gradient(145deg,rgba(15,23,42,.72),rgba(30,41,59,.48));box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.smart-snap-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.smart-snap-head b{display:block;color:#f8fafc;font-size:13px}
.smart-snap-head span{display:block;color:#94a3b8;font-size:11px;margin-top:2px}
.smart-snap-status{padding:4px 8px;border-radius:999px;background:rgba(148,163,184,.12);color:#cbd5e1;font-size:11px;white-space:nowrap}
.smart-snap-status.is-ready{background:rgba(34,197,94,.14);color:#86efac}
.smart-snap-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
.smart-snap-point{border:1px solid rgba(148,163,184,.22);background:rgba(15,23,42,.62);border-radius:12px;color:#e2e8f0;padding:7px 6px;text-align:left;cursor:pointer;transition:.15s ease}
.smart-snap-point:hover{border-color:rgba(56,189,248,.65);transform:translateY(-1px)}
.smart-snap-point span{display:block;font-size:12px;font-weight:700}
.smart-snap-point small{display:block;color:#93c5fd;font-size:10px;margin-top:2px}
.smart-snap-hint{margin-top:9px;color:#94a3b8;font-size:11px;line-height:1.35}
@media (max-width:760px){.smart-snap-points{grid-template-columns:repeat(2,minmax(0,1fr))}}

.compat-active{margin:-2px 0 9px;color:#cbd5e1;font-size:11px}.compat-active b{color:#f8fafc}.compat-matrix{display:grid;gap:6px;margin-top:9px}.compat-row{display:grid;grid-template-columns:1fr auto;gap:4px 8px;padding:8px 9px;border-radius:12px;border:1px solid rgba(148,163,184,.18);background:rgba(15,23,42,.5)}.compat-row span{font-size:12px;color:#e2e8f0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compat-row b{font-size:11px;text-transform:uppercase;letter-spacing:.04em}.compat-row small{grid-column:1/-1;color:#94a3b8;font-size:10px;line-height:1.25}.compat-row.is-ok{border-color:rgba(34,197,94,.28);background:rgba(22,101,52,.12)}.compat-row.is-ok b{color:#86efac}.compat-row.is-blocked{border-color:rgba(248,113,113,.26);background:rgba(127,29,29,.12)}.compat-row.is-blocked b{color:#fca5a5}.compat-empty{padding:8px;border-radius:12px;background:rgba(148,163,184,.08);color:#94a3b8;font-size:11px}

/* v172: section grid builder */
.assembly-section-builder{margin:12px 0;padding:12px;border:1px solid rgba(34,197,94,.24);border-radius:18px;background:linear-gradient(145deg,rgba(6,78,59,.22),rgba(15,23,42,.58));box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.section-builder-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.section-builder-head b{display:block;color:#f8fafc;font-size:13px}
.section-builder-head span{display:block;color:#94a3b8;font-size:11px;margin-top:2px;line-height:1.35}
.section-builder-head em{font-style:normal;border:1px solid rgba(34,197,94,.32);background:rgba(34,197,94,.12);color:#86efac;border-radius:999px;padding:4px 8px;font-size:11px;white-space:nowrap}
.section-builder-grid-preview{display:grid;gap:4px;margin-bottom:10px}
.section-builder-grid-preview span{min-height:26px;border:1px solid rgba(148,163,184,.24);background:rgba(15,23,42,.62);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#bbf7d0;font-size:10px;font-weight:800}
.section-builder-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.section-builder-fields label{display:flex;flex-direction:column;gap:4px;color:#94a3b8;font-size:11px}
.section-builder-fields input{width:100%;border:1px solid rgba(148,163,184,.24);background:rgba(15,23,42,.72);color:#e5e7eb;border-radius:11px;padding:8px 9px;outline:none}
.section-builder-fields input:focus{border-color:rgba(34,197,94,.58);box-shadow:0 0 0 3px rgba(34,197,94,.12)}
.section-builder-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.section-builder-btn{width:auto;min-width:92px;padding:0 10px;font-size:11px}.section-builder-btn.is-primary{background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.42);color:#bbf7d0}
.section-builder-note{margin-top:9px;color:#94a3b8;font-size:11px;line-height:1.35}
@media (max-width:760px){.section-builder-fields{grid-template-columns:1fr}.section-builder-grid-preview{grid-template-columns:repeat(3,minmax(0,1fr))!important}}


.section-template-library{display:grid;grid-template-columns:1fr;gap:7px;margin:10px 0 11px}
.section-template-card{position:relative;text-align:left;border:1px solid rgba(59,130,246,.24);background:linear-gradient(145deg,rgba(30,41,59,.72),rgba(15,23,42,.68));border-radius:14px;padding:9px 10px;color:#e5e7eb;cursor:pointer;transition:.18s ease;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.section-template-card:hover{transform:translateY(-1px);border-color:rgba(96,165,250,.55);background:linear-gradient(145deg,rgba(30,64,175,.28),rgba(15,23,42,.76))}
.section-template-card b{display:block;font-size:12px;color:#f8fafc;margin-bottom:3px}.section-template-card span{display:block;font-size:10.5px;color:#bfdbfe}.section-template-card small{display:block;font-size:10px;color:#94a3b8;margin-top:3px;line-height:1.25}.section-template-card em{position:absolute;right:8px;top:8px;font-style:normal;font-size:10px;color:#fecaca;border:1px solid rgba(248,113,113,.32);background:rgba(127,29,29,.24);border-radius:999px;padding:2px 6px}


/* === V174 PRINT PREFLIGHT === */
.print-preflight-panel{margin-top:14px;padding:14px;border:1px solid rgba(148,163,184,.22);border-radius:18px;background:linear-gradient(135deg,rgba(15,23,42,.92),rgba(30,41,59,.72));box-shadow:0 18px 40px rgba(0,0,0,.22)}
.print-preflight-panel__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;color:#e5edf7}
.print-preflight-score{min-width:78px;text-align:center;padding:8px 10px;border-radius:999px;background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.32);color:#bbf7d0;font-weight:800}
.print-preflight-score.is-warn{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.36);color:#fde68a}.print-preflight-score.is-danger{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.36);color:#fecaca}
.print-preflight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.print-preflight-cell{padding:10px;border-radius:14px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08)}.print-preflight-cell span{display:block;font-size:11px;color:#94a3b8;margin-bottom:4px}.print-preflight-cell strong{color:#f8fafc;font-size:13px}.print-preflight-warnings{display:grid;gap:7px;margin-top:10px}.print-preflight-warning{padding:9px 10px;border-radius:12px;background:rgba(245,158,11,.10);border:1px solid rgba(245,158,11,.25);color:#fde68a;font-size:12px}.print-preflight-warning.ok{background:rgba(16,185,129,.10);border-color:rgba(16,185,129,.25);color:#bbf7d0}.print-preflight-warning.bad{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.25);color:#fecaca}
@media(max-width:720px){.print-preflight-grid{grid-template-columns:1fr}}

/* === V177 BEGET SPEED === */
.performance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:14px}.performance-card{border:1px solid rgba(148,163,184,.22);border-radius:18px;padding:14px;background:rgba(15,23,42,.42)}.performance-card span{display:block;color:var(--muted,#94a3b8);font-size:12px;margin-bottom:5px}.performance-card strong{display:block;font-size:15px}.performance-status{white-space:pre-line;border:1px dashed rgba(148,163,184,.32);border-radius:18px;padding:14px;line-height:1.55;background:rgba(2,6,23,.25);color:var(--text,#e5e7eb)}

/* === V178 FINAL UI POLISH === */
:root{--xab-focus:rgba(56,189,248,.35);--xab-panel:rgba(15,23,42,.78);--xab-panel-border:rgba(148,163,184,.22)}
html{scroll-behavior:smooth}.builder-page{background-attachment:fixed}.admin-toolbar{position:sticky;top:0;z-index:70;backdrop-filter:blur(18px);box-shadow:0 18px 45px rgba(2,6,23,.28);overflow-x:auto;scrollbar-width:thin}.admin-toolbar::-webkit-scrollbar{height:6px}.admin-toolbar::-webkit-scrollbar-thumb{background:rgba(148,163,184,.35);border-radius:999px}.admin-toolbar__btn,.btn,.model-open-btn,.builder-nav__item,.display-chip{min-height:38px;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.admin-toolbar__btn:hover,.btn:hover,.model-open-btn:hover,.builder-nav__item:hover,.display-chip:hover{transform:translateY(-1px)}.admin-toolbar__btn:focus-visible,.btn:focus-visible,.model-open-btn:focus-visible,.builder-nav__item:focus-visible,.display-chip:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:0 0 0 3px var(--xab-focus)!important;border-color:rgba(56,189,248,.75)!important}.mw-card,.builder-card,.modal__dialog{box-shadow:0 20px 60px rgba(2,6,23,.24),inset 0 1px 0 rgba(255,255,255,.04)}.mw-card__header h2{letter-spacing:-.02em}.section-kicker{letter-spacing:.12em}.selected-model{position:relative;overflow:hidden}.selected-model::after{content:'Готово к настройке';position:absolute;right:10px;top:10px;font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#bae6fd;border:1px solid rgba(14,165,233,.32);background:rgba(14,165,233,.12);border-radius:999px;padding:4px 7px}.customer-model-strip:empty,.assembly-library:empty,.assembly-list:empty,.display-parts__list:empty,#admin-design-projects-list:empty,#admin-customers-list:empty,#notifications-list:empty{min-height:74px;border:1px dashed rgba(148,163,184,.28);border-radius:16px;background:rgba(15,23,42,.36);display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:12px;text-align:center;padding:12px}.customer-model-strip:empty::before{content:'Каталог пуст — админ должен включить модели для витрины.'}.assembly-library:empty::before{content:'Библиотека модулей появится после добавления моделей.'}.assembly-list:empty::before{content:'В сборке пока нет дополнительных модулей.'}.display-parts__list:empty::before{content:'Части модели появятся после анализа 3D-файла.'}#admin-design-projects-list:empty::before{content:'Проекты клиентов пока не найдены.'}#admin-customers-list:empty::before{content:'Клиентов пока нет.'}#notifications-list:empty::before{content:'Новых уведомлений нет.'}.btn.is-busy,.admin-toolbar__btn.is-busy{pointer-events:none;opacity:.78;position:relative}.btn.is-busy::after,.admin-toolbar__btn.is-busy::after{content:'';width:13px;height:13px;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;display:inline-block;margin-left:7px;vertical-align:-2px;animation:xabSpin .75s linear infinite}@keyframes xabSpin{to{transform:rotate(360deg)}}.modal:not(.hidden) .modal__dialog{animation:xabModalIn .18s ease-out both}@keyframes xabModalIn{from{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.ux-polish-toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(18px);z-index:120;background:rgba(15,23,42,.94);border:1px solid rgba(56,189,248,.28);color:#e0f2fe;border-radius:999px;padding:10px 14px;font-size:12px;box-shadow:0 18px 45px rgba(2,6,23,.34);opacity:0;pointer-events:none;transition:.2s ease}.ux-polish-toast.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}.builder-nav{position:sticky;top:66px;z-index:12;backdrop-filter:blur(14px)}.model-card,.assembly-card{scroll-margin-top:90px}.maker-viewer,.viewer-shell,#viewer{touch-action:none}.is-mobile-condensed .maker-sidebar{padding-bottom:84px}.is-mobile-condensed .builder-nav{position:fixed;left:10px;right:10px;bottom:10px;top:auto;z-index:85;border-radius:22px;background:rgba(15,23,42,.88);border:1px solid rgba(148,163,184,.22);box-shadow:0 18px 50px rgba(2,6,23,.42)}.is-mobile-condensed .builder-nav__item{font-size:11px;padding-inline:8px}.is-mobile-condensed .admin-toolbar{top:0}.compact-form-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.soft-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(148,163,184,.24),transparent);margin:12px 0}.polish-hint{font-size:11px;line-height:1.4;color:#93c5fd;background:rgba(37,99,235,.10);border:1px solid rgba(59,130,246,.22);border-radius:14px;padding:9px 10px;margin-top:9px}
@media(max-width:980px){.maker-layout--builder{grid-template-columns:1fr!important}.admin-toolbar{gap:6px;padding:8px}.admin-toolbar__btn{white-space:nowrap;font-size:12px}.mw-card__header--split{align-items:flex-start}.model-header-actions{display:flex;flex-wrap:wrap;justify-content:flex-start}.modal__dialog{width:min(96vw,760px)!important;max-height:88vh}.selected-model::after{display:none}}
@media(max-width:640px){.builder-card{border-radius:18px}.btn,.admin-toolbar__btn,.model-open-btn,.builder-nav__item,.display-chip{min-height:42px}.maker-sidebar{gap:10px}.customer-model-strip{grid-auto-columns:minmax(142px,1fr)}.section-builder-fields,.print-preflight-grid,.performance-grid{grid-template-columns:1fr!important}.modal__dialog{border-radius:22px}.ux-polish-toast{left:10px;right:10px;transform:translateY(18px);text-align:center}.ux-polish-toast.is-visible{transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}


/* ===== RESTORE V124 DESIGN BASELINE ===== */
:root {
  --bg: #0c0d10;
  --panel: #17181c;
  --panel-2: #1d1f24;
  --panel-3: #23252b;
  --border: rgba(255,255,255,0.08);
  --text: #f1f2f4;
  --muted: #a4a8b1;
  --soft: #7d8088;
  --blue: #1ea8ff;
  --blue-2: #1188dc;
  --shadow: 0 22px 60px rgba(0,0,0,0.35);
  --radius: 18px;
  --radius-sm: 12px;
}
* { box-sizing: border-box; }

html, body { margin: 0; min-height: 100%; background: #0b0c0f; color: var(--text); font-family: Inter, Arial, sans-serif; }
body[data-theme="light"] {
  --bg: #eef2f7;
  --panel: #ffffff;
  --panel-2: #f6f8fb;
  --panel-3: #edf1f7;
  --border: rgba(15,23,42,0.10);
  --text: #111827;
  --muted: #5b6472;
  --soft: #758093;
  --shadow: 0 20px 50px rgba(15, 23, 42, 0.10);
  background: #edf2f8;
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
body { padding: 14px; }
.topbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; margin-bottom: 14px; padding: 10px 14px;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: linear-gradient(180deg, #17191f, #111319); box-shadow: var(--shadow);
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand__mark {
  width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center;
  background: linear-gradient(180deg, #1ea8ff, #0f73cf); color: #fff; font-weight: 800;
}
.brand__title { font-weight: 700; letter-spacing: 0.02em; }
.brand__subtitle { font-size: 12px; color: var(--muted); }
.topbar__actions { display: flex; align-items: center; gap: 10px; }
.pill {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; border-radius: 999px;
  background: rgba(30,168,255,0.12); color: #9fd8ff; border: 1px solid rgba(30,168,255,0.16);
  font-size: 13px;
}
.flash-stack { display: grid; gap: 10px; margin-bottom: 14px; }
.flash {
  border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; background: #17191f;
}
.flash--success { border-color: rgba(74, 222, 128, 0.26); }
.flash--error { border-color: rgba(251, 113, 133, 0.28); }

.maker-layout {
  display: grid; grid-template-columns: 410px minmax(0,1fr); gap: 18px; align-items: start;
}
.maker-sidebar { display: grid; gap: 14px; }
.maker-stage { min-width: 0; }

.mw-card, .panel, .subpanel, .viewer-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #1a1c21, #14161b);
  box-shadow: var(--shadow);
}
.mw-card, .panel, .subpanel { padding: 14px; }
.panel--flat { padding: 16px; margin-top: 18px; }
.mw-card__header, .panel__header { margin-bottom: 12px; }
.mw-card__header--split, .panel__header--split {
  display: flex; justify-content: space-between; gap: 12px; align-items: flex-start;
}
.mw-card h2, .panel h2, .subpanel h2 {
  margin: 0; font-size: 15px; font-weight: 700;
}
.mw-card p, .panel p, .subpanel p { margin: 6px 0 0; color: var(--muted); font-size: 13px; line-height: 1.45; }

.selected-model {
  display: grid; grid-template-columns: 112px minmax(0,1fr); gap: 12px; padding: 10px;
  border-radius: 14px; background: #202329; border: 1px solid rgba(255,255,255,0.06); margin-bottom: 0; align-items: center;
}
.selected-model__thumb {
  height: 112px; border-radius: 12px; position: relative; overflow: hidden;
  background: linear-gradient(180deg, #171a20 0%, #101318 100%);
  border: 1px solid rgba(255,255,255,0.06);
}
.selected-model__thumb--viewer, .selected-model__thumb--image { display:flex; align-items:center; justify-content:center; background: radial-gradient(circle at 50% 18%, #222831 0%, #151922 50%, #10141b 100%); border-radius: 14px; overflow: hidden; position: relative; padding: 8px; }
.selected-model__thumb--viewer canvas { display: block; width: 100%; height: 100%; pointer-events: none; }
.selected-model__thumb-image { display:block; width:auto; height:auto; max-width:100%; max-height:100%; object-fit:contain; object-position:center center; margin:auto; background: transparent; }
.selected-model__name { font-size: 18px; font-weight: 700; line-height: 1.2; margin-bottom: 8px; }
.selected-model__subtitle { color: var(--muted); font-size: 13px; line-height: 1.4; }
.selected-model__thumb-actions { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.selected-model__thumb-actions .btn { padding: 8px 10px; }
.selected-model--text-only {
  grid-template-columns: minmax(0,1fr);
  align-items: start;
  justify-items: stretch;
  padding: 8px 10px;
}
.selected-model--text-only .selected-model__meta {
  min-width: 0;
  width: 100%;
}

.selected-model--text-only .selected-model__meta {
  display: block;
  width: 100%;
  max-width: none;
  min-width: 0;
}
.selected-model--text-only .selected-model__name,
.selected-model--text-only .selected-model__subtitle,
.selected-model--text-only .selected-model__thumb-actions {
  width: 100%;
  max-width: none;
}
.selected-model--text-only .selected-model__subtitle {
  margin-top: 4px;
}
.selected-model--text-only .selected-model__thumb { display:none !important; }
.selected-model--text-only .selected-model__name {
  margin-bottom: 6px;
}
.selected-model--text-only .selected-model__subtitle {
  margin-right: 0;
}
.selected-model--text-only .selected-model__thumb-actions {
  margin-top: 8px;
}

.input, .textarea, select.input {
  width: 100%; border: 1px solid rgba(255,255,255,0.10); background: #202228; color: var(--text);
  border-radius: 10px; padding: 11px 12px; outline: none; transition: border-color .18s ease, box-shadow .18s ease;
}
.input:focus, .textarea:focus, select.input:focus { border-color: rgba(30,168,255,0.5); box-shadow: 0 0 0 3px rgba(30,168,255,0.12); }
.input--dark { background: #17191e; }
.textarea { min-height: 120px; resize: vertical; }
.textarea--code { min-height: 180px; font-family: ui-monospace, SFMono-Regular, Consolas, monospace; }
.form-stack { display: grid; gap: 12px; }
.form-stack--small { max-width: 540px; }
.form-stack label, .field label { display: grid; gap: 6px; font-size: 13px; color: var(--muted); }
.field { display: grid; gap: 6px; }
.field small { color: #7b8089; }

.template-list { display: grid; gap: 10px; max-height: 360px; overflow: auto; padding-right: 4px; }
.template-list--compact { max-height: 218px; }
.template-list--modal { max-height: 58vh; }
.template-item {
  width: 100%; text-align: left; border: 1px solid rgba(255,255,255,0.06); background: #202329; color: var(--text);
  border-radius: 14px; padding: 12px; cursor: pointer; transition: transform .14s ease, border-color .14s ease, background .14s ease;
}
.template-item:hover { transform: translateY(-1px); border-color: rgba(255,255,255,0.14); }
.template-item.active { border-color: rgba(30,168,255,0.48); background: linear-gradient(180deg, rgba(30,168,255,0.12), rgba(30,168,255,0.05)); }
.template-item__title { font-weight: 700; font-size: 14px; margin-bottom: 6px; }
.template-item__meta { color: var(--muted); font-size: 12px; line-height: 1.45; }
.template-item__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
.tag {
  display: inline-flex; align-items: center; padding: 4px 8px; border-radius: 999px;
  background: #17191e; border: 1px solid rgba(255,255,255,0.06); color: #cfd2d8; font-size: 11px;
}

.hero-stats { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
.hero-stats--sidebar { margin-top: 12px; }
.stat-card {
  border-radius: 12px; background: #1f2127; border: 1px solid rgba(255,255,255,0.05); padding: 10px 11px;
}
.stat-card__label { font-size: 11px; color: var(--soft); text-transform: uppercase; letter-spacing: 0.10em; }
.stat-card__value { font-size: 16px; font-weight: 700; margin-top: 5px; }

.dynamic-form { display: grid; gap: 14px; }
.dynamic-form--scroll { max-height: 480px; overflow: auto; padding-right: 4px; }
.form-group {
  border: 1px solid rgba(255,255,255,0.05); background: #1d2026; border-radius: 14px; padding: 12px;
}
.form-group__title { margin: 0 0 12px; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: #d7dbe3; }
.toggle { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); cursor: pointer; }
.toggle input { accent-color: var(--blue); }
.toggle--subtle { font-size: 12px; }
.sidebar-actions { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 8px; margin-top: 14px; }
.inline-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.wrap-actions { align-items: center; }

.btn {
  border: 1px solid transparent; border-radius: 11px; padding: 11px 14px; cursor: pointer;
  background: linear-gradient(180deg, var(--blue), var(--blue-2)); color: #fff; font-weight: 700;
  transition: transform .12s ease, filter .12s ease, background .12s ease, border-color .12s ease;
}
.btn:hover { filter: brightness(1.04); transform: translateY(-1px); }
.btn--ghost {
  background: #23262d; color: #eef0f4; border-color: rgba(255,255,255,0.08);
}
.btn--small { padding: 8px 10px; font-size: 12px; }


.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 16px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(19, 22, 29, 0.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 34px rgba(0,0,0,0.18);
}
.admin-toolbar__btn {
  border: 1px solid rgba(255,255,255,0.08);
  background: #202329;
  color: #eef0f4;
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 700;
  cursor: pointer;
  transition: transform .12s ease, filter .12s ease, border-color .12s ease, background .12s ease;
}
.admin-toolbar__btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  border-color: rgba(30,168,255,0.28);
  background: linear-gradient(180deg, rgba(30,168,255,0.16), rgba(30,168,255,0.08));
}
.admin-toolbar__btn--with-badge { position: relative; padding-right: 42px; }
.admin-toolbar__badge {
  position: absolute; top: -7px; right: -6px; min-width: 22px; height: 22px; padding: 0 6px;
  border-radius: 999px; background: #ef4444; color: #fff; font-size: 12px; font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 8px 20px rgba(239,68,68,0.34);
}
.status-dot {
  display: inline-block; width: 9px; height: 9px; border-radius: 50%; vertical-align: middle; margin-left: 6px;
}
.status-dot--new { background: #ef4444; box-shadow: 0 0 0 4px rgba(239,68,68,0.16); }
.admin-window__body {
  display: grid;
  gap: 16px;
}
.modal__dialog--admin-window {
  width: min(1120px, calc(100vw - 32px));
  max-height: calc(100vh - 40px);
}
.modal__dialog--admin-wide {
  width: min(1240px, calc(100vw - 32px));
}
.modal__dialog--admin-medium {
  width: min(980px, calc(100vw - 32px));
}
.modal__dialog--admin-small {
  width: min(640px, calc(100vw - 32px));
}
.admin-pricing-form {
  max-width: none;
}
.admin-panel-modal .request-list {
  max-height: min(62vh, 720px);
  overflow: auto;
  padding-right: 4px;
}
.admin-panel-modal .subpanel,
.admin-panel-modal .info-card,
.admin-panel-modal .request-card,
.admin-panel-modal .pricing-row,
.admin-panel-modal .pricing-select-group {
  background: #1b1f25;
}
@media (max-width: 980px) {
  .admin-toolbar {
    position: sticky;
    top: 8px;
    z-index: 20;
  }
}

.viewer-card { position: relative; padding: 0; overflow: hidden; min-height: calc(100vh - 120px); box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 18px 40px rgba(0,0,0,0.28); }
#viewer { width: 100%; min-height: calc(100vh - 120px); height: calc(100vh - 120px); background: radial-gradient(circle at 50% 14%, #1e232d 0%, #11151b 48%, #090b10 100%); }
#viewer canvas, .selected-model__thumb--viewer canvas { image-rendering: auto; }
.viewer-color-palette {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 6;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  max-width: min(200px, calc(100% - 28px));
  padding: 9px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(10,12,16,0.70);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.28);
}
.viewer-color-palette .color-swatch {
  width: 16px;
  height: 16px;
  min-height: 16px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.30);
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  transform: none;
  gap: 0;
}
.viewer-color-palette .color-swatch:hover {
  transform: scale(1.08);
  border-color: rgba(255,255,255,0.56);
  background: transparent;
}
.viewer-color-palette .color-swatch.is-active {
  border-color: rgba(255,255,255,0.96);
  box-shadow: 0 0 0 2px rgba(30,168,255,0.30);
  background: transparent;
}
.viewer-color-palette .color-swatch__dot {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  border: none;
}
.viewer-color-palette .color-swatch__label {
  display: none;
}
.viewer-badge {
  position: absolute; top: 16px; right: 16px; padding: 8px 12px; border-radius: 999px;
  background: rgba(0,0,0,0.38); border: 1px solid rgba(255,255,255,0.08); color: #d7dbe2; font-size: 12px;
}
.viewer-help {
  position: absolute; left: 50%; bottom: 14px; transform: translateX(-50%);
  display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; max-width: calc(100% - 30px);
}
.viewer-help span {
  padding: 7px 10px; border-radius: 10px; background: rgba(0,0,0,0.42);
  border: 1px solid rgba(255,255,255,0.08); color: #cfd4dc; font-size: 12px;
}
.code-card--compact pre {
  margin: 0; max-height: 220px; overflow: auto; border-radius: 12px; background: #101217; color: #d8dde6;
  border: 1px solid rgba(255,255,255,0.06); padding: 12px; font-size: 12px; line-height: 1.6;
}

.lower-stack { margin-top: 18px; }
.tab-buttons { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.tab-button {
  border: 1px solid rgba(255,255,255,0.08); background: #202329; color: #d7dbe3; border-radius: 10px;
  padding: 10px 14px; cursor: pointer; font-weight: 600;
}
.tab-button.active { background: linear-gradient(180deg, rgba(30,168,255,0.16), rgba(30,168,255,0.08)); border-color: rgba(30,168,255,0.28); color: #fff; }
.tab-content { display: none; }
.tab-content.active { display: block; }
.two-cols { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.three-stack { display: grid; gap: 16px; }
.request-list { display: grid; gap: 10px; }
.info-card {
  border: 1px solid rgba(255,255,255,0.07); border-radius: 12px; padding: 12px; background: #202329; color: var(--muted);
}
.request-card {
  border: 1px solid rgba(255,255,255,0.07); border-radius: 14px; padding: 12px; background: #202329;
}
.request-card__title { font-weight: 700; margin-bottom: 6px; }
.request-card__meta, .request-card__body { color: var(--muted); font-size: 13px; line-height: 1.5; }
.no-pad-header { margin-bottom: 12px; }

.auth-page { min-height: calc(100vh - 110px); display: grid; place-items: center; }
.auth-card {
  width: min(440px, 100%); border: 1px solid var(--border); border-radius: 22px; background: #17191f;
  box-shadow: var(--shadow); padding: 24px;
}
.auth-card h1 { margin: 0 0 10px; }
.auth-card p { margin: 0 0 16px; color: var(--muted); }
.auth-form { display: grid; gap: 12px; }
.link-back { display: inline-block; margin-top: 14px; color: #8ed0ff; }

@media (max-width: 1180px) {
  .maker-layout { grid-template-columns: 1fr; }
  .viewer-card, #viewer { min-height: 62vh; height: 62vh; }
}
@media (max-width: 760px) {
  body { padding: 10px; }
  .topbar { flex-direction: column; align-items: flex-start; }
  .selected-model { grid-template-columns: 1fr; }
  .sidebar-actions, .two-cols { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .viewer-help { position: static; transform: none; padding: 10px; }
}


body.user-mode { overflow: hidden; height: 100vh; }
body.user-mode .flash-stack { display: none; }
.user-mode .maker-layout { height: calc(100vh - 94px); align-items: stretch; }
.user-mode .maker-sidebar,
.user-mode .maker-stage { min-height: 0; }
.user-mode .maker-sidebar { grid-template-rows: auto minmax(0, 1fr); }
.user-mode .customize-card { display: flex; flex-direction: column; min-height: 0; }
.user-mode .dynamic-form--scroll { flex: 1 1 auto; min-height: 0; max-height: none; }
.user-mode .viewer-card,
.user-mode #viewer { min-height: calc(100vh - 110px); height: calc(100vh - 110px); }
.user-mode .maker-layout .model-card { margin-bottom: 0; }
.sidebar-actions--user { margin-top: 12px; }
.modal.hidden { display: none; }
.modal { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(4,5,8,0.72); backdrop-filter: blur(4px); }
.modal__dialog { position: relative; width: min(760px, calc(100vw - 24px)); max-height: calc(100vh - 24px); overflow: auto; border: 1px solid var(--border); border-radius: 22px; background: linear-gradient(180deg, #1a1c21, #13151a); box-shadow: 0 24px 80px rgba(0,0,0,0.42); padding: 18px; }
.modal__dialog--models { width: min(860px, calc(100vw - 24px)); }
.model-picker { display: grid; gap: 12px; }
.modal__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
.modal__header h2 { margin: 0; font-size: 20px; }
.modal__header p { margin: 6px 0 0; color: var(--muted); }
.modal__close { width: 38px; height: 38px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.08); background: #23262d; color: #eef0f4; cursor: pointer; font-size: 18px; }
.modal__actions { display: flex; justify-content: flex-end; gap: 10px; }
.two-cols--modal { align-items: end; }
.empty-state { border: 1px dashed rgba(255,255,255,0.10); border-radius: 12px; padding: 14px; color: var(--muted); background: rgba(255,255,255,0.02); }

.customize-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}
.part-picker {
  display: grid;
  gap: 10px;
}
.part-picker__summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  background: #202329;
  color: #eef1f5;
  font-weight: 600;
}
.part-picker__summary::-webkit-details-marker { display: none; }
.part-picker__summary::after {
  content: '▾';
  color: var(--muted);
  transition: transform .16s ease;
}
.part-picker[open] .part-picker__summary::after { transform: rotate(180deg); }
.part-picker__list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}
.part-pill {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  background: #1c1f25;
  color: #e9edf2;
  padding: 10px 12px;
  cursor: pointer;
}
.part-pill:hover { border-color: rgba(255,255,255,0.14); }
.part-pill.active {
  border-color: rgba(30,168,255,0.45);
  background: linear-gradient(180deg, rgba(30,168,255,0.13), rgba(30,168,255,0.05));
}
.part-pill__name { font-weight: 600; font-size: 13px; }
.part-pill__meta { margin-top: 4px; color: var(--muted); font-size: 12px; }
@media (max-width: 1180px) {
  body.user-mode { overflow: auto; height: auto; }
  .user-mode .maker-layout { height: auto; }
  .user-mode .viewer-card, .user-mode #viewer { min-height: 58vh; height: 58vh; }
}


.sr-only {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.info-card--soft { background: #1a1d23; color: #c1c6ce; }
.file-picker { display: grid; gap: 8px; }
.file-picker__row {
  display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: center;
  border: 1px solid rgba(255,255,255,0.08); background: #1b1e24; border-radius: 14px; padding: 10px;
}
.file-picker__name {
  min-height: 44px; display: flex; align-items: center; padding: 0 12px;
  border-radius: 10px; background: #111318; border: 1px solid rgba(255,255,255,0.06);
  color: #cfd5dd; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.auth-page--premium {
  min-height: calc(100vh - 100px);
  display: grid;
  place-items: center;
}
.auth-shell {
  width: min(1080px, 100%);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 22px;
  align-items: stretch;
}
.auth-hero {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 28px;
  padding: 34px;
  background:
    radial-gradient(circle at top left, rgba(30,168,255,0.18), transparent 42%),
    radial-gradient(circle at bottom right, rgba(116,84,255,0.18), transparent 38%),
    linear-gradient(180deg, #15181d, #101217);
  box-shadow: var(--shadow);
}
.auth-hero__badge {
  display: inline-flex; padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 700;
  letter-spacing: 0.12em; color: #98d7ff; background: rgba(30,168,255,0.12); border: 1px solid rgba(30,168,255,0.18);
}
.auth-hero h1 { margin: 18px 0 14px; font-size: 42px; line-height: 1.05; }
.auth-hero p { margin: 0; max-width: 540px; color: #c1c7d0; font-size: 16px; line-height: 1.7; }
.auth-hero__features { display: grid; gap: 12px; margin-top: 28px; }
.auth-feature {
  display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-radius: 16px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); color: #eef1f5;
}
.auth-feature__dot {
  width: 12px; height: 12px; border-radius: 999px; background: linear-gradient(180deg, #5cc2ff, #1ea8ff);
  box-shadow: 0 0 0 6px rgba(30,168,255,0.10);
}
.auth-card--premium {
  width: 100%; max-width: none; display: flex; flex-direction: column; justify-content: center;
  padding: 30px; border-radius: 28px; background: linear-gradient(180deg, #171a20, #121419);
}
.auth-card__top { display: grid; gap: 18px; margin-bottom: 22px; }
.brand--auth { align-items: center; }
.auth-hint {
  border-radius: 16px; padding: 14px 16px; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06); color: #d0d5de; font-size: 14px;
}
.auth-form--premium { gap: 14px; }
.auth-form--premium label span { color: #c5cad2; font-size: 13px; font-weight: 600; }
.auth-submit { width: 100%; margin-top: 4px; min-height: 48px; }
@media (max-width: 960px) {
  .auth-shell { grid-template-columns: 1fr; }
  .auth-hero { padding: 24px; }
  .auth-hero h1 { font-size: 32px; }
}

.toast-host {
  position: fixed; right: 18px; bottom: 18px; z-index: 1200;
  display: grid; gap: 10px; pointer-events: none;
}
.toast {
  min-width: 260px; max-width: 420px; padding: 12px 14px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(18,20,25,0.96); color: #f2f4f8;
  box-shadow: 0 20px 40px rgba(0,0,0,0.28); transform: translateY(8px); opacity: 0;
  transition: opacity .2s ease, transform .2s ease;
}
.toast--visible { opacity: 1; transform: translateY(0); }

.model-header-actions { display:flex; align-items:center; gap:8px; }
.modal__dialog--compact { width: min(620px, calc(100vw - 24px)); }

.material-panel { margin-top: 12px; border: 1px solid rgba(255,255,255,0.05); background: #1d2026; border-radius: 14px; padding: 12px; display: grid; gap: 12px; }
.material-panel__header { margin: 0; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: #d7dbe3; font-weight: 700; }
.material-row { display: grid; gap: 8px; }
.material-row--inline { display: flex; align-items: center; justify-content: space-between; }
.material-label, .material-row__label { font-size: 13px; color: #d9dde5; }
.material-row__label { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.material-color-wrap { display:flex; align-items:center; gap:12px; }
.material-color-wrap--stacked { display:grid; align-items:stretch; gap:10px; }
#model-color-input { min-width: 180px; height: 40px; }
#model-color-value { font-size: 12px; color: var(--muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.color-swatches { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:8px; }
.color-swatch { display:flex; align-items:center; gap:10px; min-height:40px; padding:8px 10px; border-radius:12px; border:1px solid rgba(255,255,255,0.08); background:#171a20; color:#eef1f5; cursor:pointer; transition:transform .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease; }
.color-swatch:hover { transform:translateY(-1px); border-color:rgba(255,255,255,0.18); background:#1d2128; }
.color-swatch.is-active { border-color:rgba(30,168,255,0.42); background:rgba(30,168,255,0.10); box-shadow:0 0 0 1px rgba(30,168,255,0.10) inset; }
.color-swatch__dot { width:18px; height:18px; border-radius:999px; border:1px solid rgba(255,255,255,0.18); flex:0 0 auto; }
.color-swatch__label { font-size:13px; font-weight:600; }
#model-opacity-input { width: 100%; accent-color: var(--blue); }

.input--readonly { display:flex; align-items:center; min-height:44px; background:#1d2026; color:#eef0f4; border:1px solid rgba(255,255,255,0.06); cursor:default; }
.template-item__select { all:unset; display:block; width:100%; cursor:pointer; }
.template-item__actions { display:flex; justify-content:flex-end; margin-top:10px; }

.assembly-parts-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.assembly-part-chip {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.07);
  background: #1c1f25;
  color: #eef1f5;
  cursor: pointer;
}
.assembly-part-chip.active {
  border-color: rgba(30,168,255,0.35);
  background: rgba(30,168,255,0.10);
}
.assembly-part-chip small {
  color: #a8b0bc;
  font-size: 12px;
}


.customer-topbar{display:flex;align-items:center;gap:12px}.customer-topbar__guest,.customer-topbar__auth{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.hidden{display:none!important}
.viewer-order-overlay{position:absolute;top:16px;right:16px;z-index:4;min-width:260px;max-width:min(320px,calc(100% - 32px));padding:14px 14px 12px;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(12,14,19,.78);backdrop-filter:blur(10px);box-shadow:0 18px 48px rgba(0,0,0,.28)}
.viewer-order-overlay__label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#98a2b8}.viewer-order-overlay__value{font-size:28px;font-weight:800;line-height:1.05;margin-top:8px}.viewer-order-overlay__hint{margin-top:8px;color:#a9b3c8;font-size:13px;line-height:1.45}.viewer-order-overlay__button{width:100%;margin-top:12px}
.success-card{display:grid;gap:10px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#1b1f26}.success-card__line{color:#e8edf6}.success-card__hint{margin-top:4px;color:#aab3c7;line-height:1.5}.order-details{margin-top:10px}.order-details summary{cursor:pointer;color:#d8def0}
.modal__dialog--orders{width:min(820px,calc(100vw - 24px))}
.price-breakdown{margin-top:12px;display:grid;gap:8px}.price-breakdown__row{display:flex;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.03);font-size:13px}
.auth-switcher{display:flex;gap:8px;margin-bottom:14px}.auth-switcher .is-active{background:rgba(255,255,255,.12)}
.form-stack label.checkbox-line, .checkbox-line{display:flex;flex-direction:row;gap:10px;align-items:center;font-size:13px;color:#cfd5e8;line-height:1.45}.form-stack label.checkbox-line{gap:10px}.checkbox-line input{margin:0;flex:0 0 auto;align-self:center}.checkbox-line span{display:block;flex:1 1 auto;margin:0}.checkbox-line a{color:#c2d1ff}
.doc-page{padding:28px}.doc-card{max-width:920px;margin:0 auto;padding:28px;border-radius:24px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}.doc-section+ .doc-section{margin-top:18px}
.pricing-fields{display:grid;gap:12px}.pricing-row,.pricing-select-group{padding:12px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}.pricing-select-group{display:grid;gap:8px}.pricing-select-group__title{font-weight:600;margin-bottom:2px}
.json-preview{margin-top:10px;padding:12px;border-radius:14px;max-height:220px;overflow:auto;background:#0d111c;color:#b9c4e0;font-size:12px;line-height:1.45}
@media (max-width: 980px){.viewer-color-palette{top:12px;left:12px;max-width:calc(100% - 24px);padding:8px 10px;gap:7px}.viewer-order-overlay{top:12px;right:12px;left:12px;max-width:none;min-width:0}.customer-topbar__guest,.customer-topbar__auth{flex-wrap:wrap}}

.captcha-box {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1c1f25;
}
.captcha-box__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.captcha-box__label {
  font-size: 12px;
  color: var(--muted);
}
.captcha-box__question {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 10px;
  background: linear-gradient(180deg, #242833, #1a1d24);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 0.08em;
}
.honeypot-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.text-danger{color:#fca5a5;}

/* Builder layout inspired by configurable storage-style tools */
.maker-layout--builder {
  grid-template-columns: 380px minmax(0, 1fr);
  gap: 20px;
  align-items: stretch;
}
.builder-sidebar {
  position: sticky;
  top: 14px;
  max-height: calc(100vh - 34px);
  overflow: auto;
  padding-right: 4px;
}
.builder-card {
  background: linear-gradient(180deg, #171a20 0%, #11141a 100%);
}
.builder-card--compact .selected-model {
  grid-template-columns: 84px minmax(0,1fr);
}
.builder-card--compact .selected-model__thumb {
  height: 84px;
}
.section-kicker {
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #8ca4bb;
  margin-bottom: 6px;
}
.dynamic-form--builder {
  max-height: none;
  overflow: visible;
}
.form-group--builder {
  padding: 0;
  overflow: hidden;
}
.form-group--builder > summary {
  list-style: none;
  cursor: pointer;
}
.form-group__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #e9edf3;
}
.form-group__summary::-webkit-details-marker { display:none; }
.form-group__body {
  display: grid;
  gap: 12px;
  padding: 0 16px 16px;
}
.display-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
.display-chip,
.viewer-toolbar__btn {
  border: 1px solid rgba(255,255,255,0.08);
  background: #1c2129;
  color: #f1f5f9;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
  transition: .14s ease;
}
.display-chip:hover,
.viewer-toolbar__btn:hover {
  transform: translateY(-1px);
  border-color: rgba(30,168,255,0.28);
}
.display-chip.is-active,
.viewer-toolbar__btn.is-active {
  background: linear-gradient(180deg, rgba(30,168,255,0.22), rgba(30,168,255,0.10));
  border-color: rgba(30,168,255,0.46);
  color: #dff2ff;
}
.display-slider {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.display-slider label {
  font-size: 12px;
  color: var(--muted);
}
.display-slider input[type="range"] {
  width: 100%;
}
.viewer-axes-toggle {
  margin-top: 12px;
}
.display-dimensions {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.display-dimension-modes {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.part-dimensions-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.part-dimensions-row {
  display: grid;
  gap: 4px;
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #171c23;
  color: #eef2f7;
  cursor: pointer;
}
.part-dimensions-row.is-active {
  border-color: rgba(30,168,255,0.46);
  background: linear-gradient(180deg, rgba(30,168,255,0.18), rgba(30,168,255,0.06));
}
.part-dimensions-row.is-muted { opacity: 0.6; }
.part-dimensions-row__name {
  font-size: 12px;
  font-weight: 700;
}
.part-dimensions-row__value {
  font-size: 12px;
  color: #9fb0c4;
}
.summary-stack {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
.summary-card {
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  background: #1a1f27;
}
.summary-card__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .10em;
  color: #8f9bab;
  margin-bottom: 6px;
}
.summary-card__value {
  font-size: 14px;
  line-height: 1.35;
  font-weight: 700;
  color: #f4f7fb;
}
.summary-actions {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.builder-stage {
  min-height: calc(100vh - 32px);
}
.viewer-card--builder {
  min-height: calc(100vh - 34px);
}
.viewer-card--builder #viewer {
  min-height: calc(100vh - 34px);
  height: calc(100vh - 34px);
}
.viewer-toolbar {
  position: absolute;
  left: 16px;
  right: 16px;
  top: 16px;
  z-index: 7;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.viewer-toolbar__left,
.viewer-toolbar__right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.viewer-toolbar__pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(11,14,18,0.74);
  border: 1px solid rgba(255,255,255,0.12);
  color: #f6f8fb;
  font-size: 13px;
  font-weight: 700;
  backdrop-filter: blur(10px);
}
.viewer-toolbar__pill--muted {
  color: #b7c2d0;
  font-weight: 600;
}
.viewer-toolbar__btn {
  background: rgba(11,14,18,0.74);
  backdrop-filter: blur(10px);
}
.viewer-color-palette {
  top: 72px;
}
.template-item__select {
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  color: inherit;
  padding: 0;
  cursor: pointer;
}
@media (max-width: 1180px) {
  .maker-layout--builder {
    grid-template-columns: 1fr;
  }
  .builder-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
  }
  .viewer-card--builder,
  .viewer-card--builder #viewer {
    min-height: 74vh;
    height: 74vh;
  }
}
@media (max-width: 740px) {
  .summary-stack,
  .display-grid {
    grid-template-columns: 1fr;
  }
  .viewer-toolbar {
    left: 10px;
    right: 10px;
    top: 10px;
  }
  .viewer-color-palette {
    top: 120px;
    left: 10px;
    right: 10px;
    max-width: none;
    border-radius: 16px;
  }
}
.viewer-color-palette .color-swatch__label { display: none; }
.viewer-color-palette .color-swatch { width: 18px; height: 18px; min-height: 18px; border-radius: 999px; }
.viewer-color-palette .color-swatch__dot { width: 100%; height: 100%; border-radius: 999px; display:block; }


/* v30 builder layout fixes */
body.user-mode.builder-page {
  overflow: auto;
  height: auto;
  min-height: 100vh;
}
body.user-mode.builder-page .maker-layout--builder {
  height: auto;
  min-height: calc(100vh - 110px);
  align-items: start;
}
body.user-mode.builder-page .maker-sidebar,
body.user-mode.builder-page .maker-stage {
  min-height: auto;
}
body.user-mode.builder-page .maker-sidebar {
  grid-template-rows: none;
}
.maker-layout--builder {
  grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}
.builder-sidebar {
  position: relative;
  top: auto;
  max-height: none;
  overflow: visible;
  padding-right: 0;
}
.builder-card {
  overflow: hidden;
}
.builder-card--controls {
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.dynamic-form--builder {
  display: grid;
  gap: 12px;
  max-height: min(50vh, 620px);
  overflow: auto;
  padding-right: 4px;
}
.form-group--builder {
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  background: #141921;
}
.form-group__summary {
  padding: 15px 16px;
}
.form-group__body {
  padding: 0 16px 16px;
}
.builder-stage {
  position: sticky;
  top: 14px;
  align-self: start;
  min-height: auto;
}
.viewer-card--builder {
  min-height: calc(100vh - 110px);
}
.viewer-card--builder #viewer {
  min-height: calc(100vh - 110px);
  height: calc(100vh - 110px);
}
.viewer-toolbar {
  align-items: flex-start;
}
.viewer-toolbar__left,
.viewer-toolbar__right {
  row-gap: 8px;
}
.viewer-toolbar__pill,
.viewer-toolbar__btn {
  min-height: 36px;
  font-size: 12px;
}
.viewer-color-palette {
  top: 70px;
  left: 16px;
  max-width: 220px;
}
.viewer-badge {
  top: 72px;
}
.viewer-order-overlay {
  top: 70px;
}
.viewer-help {
  bottom: 12px;
}
.viewer-help span {
  font-size: 11px;
}
.viewer-dimensions {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}
.viewer-dimensions__label {
  position: absolute;
  transform: translate(-50%, -50%);
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(10,12,16,0.74);
  border: 1px solid rgba(255,255,255,0.08);
  color: #eef3f9;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
  white-space: nowrap;
  box-shadow: 0 8px 18px rgba(0,0,0,0.22);
}
.viewer-dimensions__line {
  stroke: rgba(233,239,247,0.80);
  stroke-width: 1.15;
  stroke-linecap: round;
}
.viewer-dimensions__guide {
  stroke: rgba(233,239,247,0.26);
  stroke-width: 1;
  stroke-dasharray: 4 4;
}
.viewer-dimensions__tick {
  stroke: rgba(233,239,247,0.80);
  stroke-width: 1.15;
  stroke-linecap: round;
}
@media (max-width: 1280px) {
  .maker-layout--builder {
    grid-template-columns: minmax(300px, 350px) minmax(0, 1fr);
  }
}
@media (max-width: 1180px) {
  body.user-mode.builder-page {
    overflow: auto;
  }
  .maker-layout--builder {
    grid-template-columns: 1fr;
  }
  .builder-stage {
    position: static;
  }
  .dynamic-form--builder {
    max-height: none;
    overflow: visible;
  }
  .viewer-card--builder,
  .viewer-card--builder #viewer {
    min-height: 68vh;
    height: 68vh;
  }
}
@media (max-width: 760px) {
  .viewer-toolbar {
    position: absolute;
    left: 10px;
    right: 10px;
    top: 10px;
    gap: 8px;
  }
  .viewer-color-palette {
    top: 98px;
    left: 10px;
    max-width: calc(100% - 20px);
  }
  .viewer-badge {
    display: none;
  }
  .viewer-order-overlay {
    top: 144px;
  }
  .summary-stack,
  .display-grid,
  .customize-actions,
  .summary-actions {
    grid-template-columns: 1fr;
  }
}


.theme-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.theme-toggle-btn__icon {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  font-size: 12px;
}
.builder-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 8px;
}
.builder-nav__item {
  border: 1px solid rgba(255,255,255,0.08);
  background: #1b2028;
  color: #eef2f6;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
}
.builder-nav__item.is-active {
  background: linear-gradient(180deg, rgba(30,168,255,0.22), rgba(30,168,255,0.08));
  border-color: rgba(30,168,255,0.42);
  color: #dff2ff;
}
.display-parts {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.display-parts__title {
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #95a3b8;
}
.display-parts__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.display-part-row {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 8px;
  align-items: stretch;
}
.display-part-row.is-selected .display-part-pick {
  border-color: rgba(30,168,255,0.46);
  background: linear-gradient(180deg, rgba(30,168,255,0.18), rgba(30,168,255,0.06));
}
.display-part-pick {
  display: grid;
  gap: 4px;
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1a1f26;
  color: #eef2f7;
  cursor: pointer;
}
.display-part-pick__name {
  font-size: 13px;
  font-weight: 700;
}
.display-part-pick__meta {
  font-size: 12px;
  color: #95a3b8;
}
.display-part-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1a1f26;
  color: #eef2f7;
  min-width: 116px;
}
.display-part-toggle__name {
  font-size: 12px;
  font-weight: 700;
}
.display-part-toggle__switch {
  width: 34px;
  height: 20px;
  border-radius: 999px;
  position: relative;
  background: rgba(255,255,255,0.12);
  transition: .14s ease;
}
.display-part-toggle__switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: white;
  transition: .14s ease;
}
.display-part-toggle.is-active .display-part-toggle__switch {
  background: rgba(30,168,255,0.42);
}
.display-part-toggle.is-active .display-part-toggle__switch::after {
  transform: translateX(14px);
}
.field__title-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.field__title-row label { gap:0; }

.field__reset-btn {
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: #cbd5e1;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: .15s ease;
  flex: 0 0 auto;
}
.field__reset-btn:hover {
  background: rgba(30,168,255,0.16);
  border-color: rgba(30,168,255,0.35);
  color: #eff6ff;
}
.field__number-controls {
  display: grid;
  grid-template-columns: minmax(68px, 84px) 1fr;
  gap: 8px;
  align-items: center;
}
.field__number-input {
  min-width: 0;
  max-width: 84px;
  padding-inline: 10px;
}
.field__range {
  width: 100%;
  accent-color: #1ea8ff;
  cursor: pointer;
}
@media (max-width: 760px) {
  .field__number-controls {
    grid-template-columns: 1fr;
  }
}
.field__hint-range {
  font-size: 11px;
  color: #7f8ba0;
  white-space: nowrap;
}
body[data-theme="light"] .topbar {
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}
body[data-theme="light"] .mw-card,
body[data-theme="light"] .panel,
body[data-theme="light"] .subpanel,
body[data-theme="light"] .viewer-card,
body[data-theme="light"] .builder-card {
  background: linear-gradient(180deg, #ffffff, #f7f9fc);
  border-color: rgba(15,23,42,0.09);
}
body[data-theme="light"] .selected-model,
body[data-theme="light"] .template-item,
body[data-theme="light"] .summary-card,
body[data-theme="light"] .form-group,
body[data-theme="light"] .display-part-toggle,
body[data-theme="light"] .display-chip,
body[data-theme="light"] .viewer-toolbar__btn,
body[data-theme="light"] .builder-nav__item,
body[data-theme="light"] .input,
body[data-theme="light"] .textarea,
body[data-theme="light"] select.input {
  background: #ffffff;
  color: #111827;
  border-color: rgba(15,23,42,0.10);
}
body[data-theme="light"] .display-chip.is-active,
body[data-theme="light"] .viewer-toolbar__btn.is-active,
body[data-theme="light"] .builder-nav__item.is-active {
  background: linear-gradient(180deg, rgba(30,168,255,0.16), rgba(30,168,255,0.06));
  color: #0f3c63;
}
body[data-theme="light"] .section-kicker,
body[data-theme="light"] .summary-card__label,
body[data-theme="light"] .display-parts__title,

body[data-theme="light"] .field__reset-btn {
  background: #ffffff;
  color: #475569;
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .field__reset-btn:hover {
  background: rgba(30,168,255,0.10);
  color: #0f3c63;
  border-color: rgba(30,168,255,0.30);
}
body[data-theme="light"] .field__hint-range,
body[data-theme="light"] .field small,
body[data-theme="light"] .brand__subtitle,
body[data-theme="light"] .mw-card p,
body[data-theme="light"] .panel p,
body[data-theme="light"] .subpanel p,
body[data-theme="light"] .form-stack label,
body[data-theme="light"] .field label {
  color: #64748b;
}
body[data-theme="light"] .viewer-toolbar__pill,
body[data-theme="light"] .viewer-dimensions__label,
body[data-theme="light"] .viewer-badge,
body[data-theme="light"] .viewer-order-overlay {
  background: rgba(255,255,255,0.82);
  color: #0f172a;
  border-color: rgba(15,23,42,0.10);
}
body[data-theme="light"] .viewer-help span {
  background: rgba(255,255,255,0.82);
  color: #334155;
}
@media (max-width: 760px) {
  .builder-nav,
  .display-parts__list { grid-template-columns: 1fr; }
  .display-part-row { grid-template-columns: 1fr; }
  .theme-toggle-btn__text { display:none; }
}


#parts-section-card .display-parts{margin-top:0;padding-top:0;border-top:0}
.display-dimension-modes{display:flex;flex-wrap:nowrap;gap:10px}
.display-dimension-modes--icons .display-chip{flex:1 1 0;min-width:0;justify-content:center}
.display-chip--icon{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;white-space:nowrap}
.display-chip__icon{font-size:16px;line-height:1}
.display-chip__text{font-size:13px;line-height:1}
#display-section-card .mw-card__header{margin-bottom:10px}
#display-section-card .display-dimensions{margin-top:0;padding-top:0;border-top:0}
@media (max-width: 900px){.display-dimension-modes{flex-wrap:wrap}}

.selected-model__thumb--viewer img { align-self: center; justify-self: center; }


.viewer-rotation-control {
  position: absolute;
  right: 16px;
  bottom: 18px;
  z-index: 4;
  width: auto;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
.viewer-rotation-control__title,
.viewer-joystick__hint,
.viewer-rotation-readout {
  display: none !important;
}
.viewer-joystick {
  position: relative;
  width: 88px;
  height: 88px;
  margin: 0;
  touch-action: none;
  user-select: none;
  border-radius: 50%;
  box-shadow: 0 10px 24px rgba(0,0,0,0.28);
}
.viewer-joystick__ring,
.viewer-joystick__pad {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}
.viewer-joystick__ring {
  border: 1px solid rgba(147, 197, 253, 0.28);
  box-shadow: inset 0 0 0 7px rgba(255,255,255,0.03), 0 0 0 1px rgba(0,0,0,0.20);
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.02) 54%, rgba(30,168,255,0.06) 55%, rgba(30,168,255,0.018) 72%, rgba(255,255,255,0.02) 100%);
}
.viewer-joystick__pad {
  inset: 14px;
  border: 1px solid rgba(255,255,255,0.07);
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.12), rgba(255,255,255,0.035) 42%, rgba(9,12,18,0.34) 100%);
}
.viewer-joystick__knob {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 26px;
  height: 26px;
  margin-left: -13px;
  margin-top: -13px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.17);
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.9), rgba(203,213,225,0.88) 35%, rgba(96,165,250,0.84) 100%);
  box-shadow: 0 6px 18px rgba(0,0,0,0.32);
  pointer-events: none;
}
.selected-model__thumb--image { min-height: 164px; }
@media (max-width: 900px) {
  .viewer-rotation-control { right: 12px; bottom: 14px; }
  .viewer-joystick { width: 78px; height: 78px; }
  .viewer-joystick__pad { inset: 12px; }
  .viewer-joystick__knob {
    width: 24px;
    height: 24px;
    margin-left: -12px;
    margin-top: -12px;
  }
}



.builder-card--compact .selected-model.selected-model--text-only {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  padding: 10px 12px;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__meta {
  width: 100%;
  display: block;
  min-width: 0;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__name,
.builder-card--compact .selected-model.selected-model--text-only .selected-model__subtitle {
  width: 100%;
  max-width: none;
  display: block;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__subtitle {
  margin-top: 4px;
}
.builder-card--compact .selected-model.selected-model--text-only .selected-model__thumb-actions {
  width: 100%;
  justify-content: flex-start;
  margin-top: 6px;
}

.selected-model--text-only {
  min-height: 0;
  width: 100%;
}
.selected-model--text-only .selected-model__meta {
  flex: 1 1 auto;
}

/* v90 Three.js visual upgrade */
#viewer.viewer--three {
  background:
    radial-gradient(circle at 48% 8%, rgba(74, 94, 130, 0.52) 0%, rgba(22, 28, 38, 0.92) 34%, rgba(8, 10, 16, 1) 78%),
    linear-gradient(145deg, #111827 0%, #070a10 100%);
}
#viewer.viewer--three canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
  image-rendering: auto;
  outline: none;
}
.viewer-three-controls {
  position: absolute;
  right: 16px;
  bottom: 62px;
  z-index: 8;
  display: grid;
  gap: 10px;
  max-width: min(390px, calc(100% - 32px));
  pointer-events: auto;
}
.viewer-three-controls__group {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  background: rgba(8, 11, 17, 0.72);
  box-shadow: 0 18px 48px rgba(0,0,0,0.26);
  backdrop-filter: blur(12px);
}
.viewer-three-controls__group--section {
  flex-wrap: wrap;
}
.viewer-three-controls__btn,
.viewer-three-controls__select {
  min-height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.06);
  color: #edf5ff;
  font-size: 12px;
  font-weight: 800;
  padding: 0 11px;
  cursor: pointer;
  transition: transform .14s ease, border-color .14s ease, background .14s ease;
}
.viewer-three-controls__btn:hover,
.viewer-three-controls__select:hover {
  transform: translateY(-1px);
  border-color: rgba(56,189,248,0.38);
}
.viewer-three-controls__btn.is-active {
  background: linear-gradient(180deg, rgba(56,189,248,0.28), rgba(56,189,248,0.12));
  border-color: rgba(56,189,248,0.56);
  color: #e6f8ff;
}
.viewer-three-controls__select {
  appearance: none;
  min-width: 52px;
  text-align: center;
  text-align-last: center;
}
.viewer-three-controls__range {
  width: 128px;
  accent-color: #38bdf8;
}
.viewer-dimensions__svg {
  position: absolute;
  inset: 0;
  overflow: visible;
}
body[data-theme="light"] #viewer.viewer--three {
  background:
    radial-gradient(circle at 48% 8%, rgba(190, 216, 245, 0.86) 0%, rgba(230, 236, 245, 0.96) 42%, rgba(246, 248, 252, 1) 100%),
    linear-gradient(145deg, #f8fafc 0%, #e5eaf2 100%);
}
body[data-theme="light"] .viewer-three-controls__group {
  background: rgba(255,255,255,0.76);
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .viewer-three-controls__btn,
body[data-theme="light"] .viewer-three-controls__select {
  background: rgba(15,23,42,0.04);
  color: #0f172a;
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .viewer-three-controls__btn.is-active {
  color: #0f3c63;
  background: linear-gradient(180deg, rgba(56,189,248,0.22), rgba(56,189,248,0.08));
}
@media (max-width: 740px) {
  .viewer-three-controls {
    left: 10px;
    right: 10px;
    bottom: 58px;
    max-width: none;
  }
  .viewer-three-controls__group {
    justify-content: center;
  }
  .viewer-three-controls__range {
    width: 100%;
    min-width: 160px;
  }
}


/* v105: светлая тема доведена без изменения Three.js-рендера моделей.
   ВАЖНО: геометрия, свет, материалы и загрузка STL/SCAD оставлены как в рабочей v99. */
body[data-theme="light"] {
  --bg: #eef3f8;
  --panel: #ffffff;
  --panel-2: #f7f9fc;
  --panel-3: #edf2f7;
  --border: rgba(15, 23, 42, 0.13);
  --text: #0f172a;
  --muted: #475569;
  --soft: #64748b;
  background:
    radial-gradient(circle at 18% 0%, rgba(96, 165, 250, 0.12), transparent 32%),
    linear-gradient(180deg, #f6f8fb 0%, #e9eef5 100%);
  color: var(--text);
}
body[data-theme="light"] .topbar,
body[data-theme="light"] .admin-toolbar {
  background: rgba(255,255,255,0.92);
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 14px 36px rgba(15,23,42,0.10);
}
body[data-theme="light"] .mw-card,
body[data-theme="light"] .panel,
body[data-theme="light"] .subpanel,
body[data-theme="light"] .viewer-card,
body[data-theme="light"] .builder-card,
body[data-theme="light"] .modal__dialog,
body[data-theme="light"] .info-card,
body[data-theme="light"] .success-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  color: #0f172a;
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 18px 44px rgba(15,23,42,0.11);
}
body[data-theme="light"] .selected-model,
body[data-theme="light"] .template-item,
body[data-theme="light"] .summary-card,
body[data-theme="light"] .form-group,
body[data-theme="light"] .display-part-toggle,
body[data-theme="light"] .display-chip,
body[data-theme="light"] .viewer-toolbar__btn,
body[data-theme="light"] .builder-nav__item,
body[data-theme="light"] .tag,
body[data-theme="light"] .stat-card,
body[data-theme="light"] .input,
body[data-theme="light"] .textarea,
body[data-theme="light"] select.input {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15,23,42,0.14);
}
body[data-theme="light"] .template-item:hover,
body[data-theme="light"] .display-chip:hover,
body[data-theme="light"] .viewer-toolbar__btn:hover,
body[data-theme="light"] .builder-nav__item:hover,
body[data-theme="light"] .btn--ghost:hover {
  border-color: rgba(30, 136, 229, 0.34);
  background: #f8fbff;
}
body[data-theme="light"] .template-item.active,
body[data-theme="light"] .display-chip.is-active,
body[data-theme="light"] .viewer-toolbar__btn.is-active,
body[data-theme="light"] .builder-nav__item.is-active {
  background: linear-gradient(180deg, rgba(30,136,229,0.18), rgba(30,136,229,0.07));
  border-color: rgba(30,136,229,0.42);
  color: #0b3b66;
}
body[data-theme="light"] .btn--ghost,
body[data-theme="light"] .admin-toolbar__btn,
body[data-theme="light"] .modal__close {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15,23,42,0.14);
}
body[data-theme="light"] .pill {
  background: rgba(30,136,229,0.10);
  color: #0b3b66;
  border-color: rgba(30,136,229,0.20);
}
body[data-theme="light"] .brand__title,
body[data-theme="light"] .selected-model__name,
body[data-theme="light"] .template-item__title,
body[data-theme="light"] .form-group__title,
body[data-theme="light"] .mw-card h2,
body[data-theme="light"] .panel h2,
body[data-theme="light"] .subpanel h2,
body[data-theme="light"] .modal__header h2 {
  color: #0f172a;
}
body[data-theme="light"] .brand__subtitle,
body[data-theme="light"] .selected-model__subtitle,
body[data-theme="light"] .template-item__meta,
body[data-theme="light"] .summary-card__label,
body[data-theme="light"] .stat-card__label,
body[data-theme="light"] .field small,
body[data-theme="light"] .field__hint-range,
body[data-theme="light"] .mw-card p,
body[data-theme="light"] .panel p,
body[data-theme="light"] .subpanel p,
body[data-theme="light"] .form-stack label,
body[data-theme="light"] .field label {
  color: #475569;
}
body[data-theme="light"] .selected-model__thumb,
body[data-theme="light"] .selected-model__thumb--viewer,
body[data-theme="light"] .selected-model__thumb--image {
  background: radial-gradient(circle at 50% 18%, #eef3f8 0%, #dfe7f0 58%, #cfd8e3 100%);
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] .viewer-toolbar__pill,
body[data-theme="light"] .viewer-dimensions__label,
body[data-theme="light"] .viewer-badge,
body[data-theme="light"] .viewer-order-overlay,
body[data-theme="light"] .viewer-help span {
  background: rgba(255,255,255,0.90);
  color: #0f172a;
  border-color: rgba(15,23,42,0.13);
  box-shadow: 0 8px 20px rgba(15,23,42,0.10);
}
body[data-theme="light"] .viewer-joystick {
  box-shadow: 0 10px 24px rgba(15,23,42,0.18);
}
body[data-theme="light"] .viewer-joystick__ring {
  border-color: rgba(30,136,229,0.34);
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.72) 0%, rgba(255,255,255,0.70) 54%, rgba(30,136,229,0.13) 55%, rgba(30,136,229,0.05) 74%, rgba(255,255,255,0.62) 100%);
}
body[data-theme="light"] .viewer-joystick__pad {
  border-color: rgba(15,23,42,0.12);
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.96), rgba(232,239,248,0.82) 45%, rgba(203,213,225,0.46) 100%);
}
body[data-theme="light"] .viewer-joystick__knob {
  border-color: rgba(15,23,42,0.18);
  background: radial-gradient(circle at 35% 30%, #ffffff, #dbeafe 42%, #60a5fa 100%);
  box-shadow: 0 7px 18px rgba(15,23,42,0.20);
}
body[data-theme="light"] .modal__backdrop {
  background: rgba(15, 23, 42, 0.34);
}
body[data-theme="light"] .flash {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15,23,42,0.12);
}
body[data-theme="light"] input::placeholder,
body[data-theme="light"] textarea::placeholder {
  color: #94a3b8;
}

/* v106: каталог, валидация, статус обработки, заказы, мобильная версия. 3D-рендер не изменён. */
.template-item--catalog {
  padding: 10px;
}
.catalog-model-card {
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 12px;
  align-items: stretch;
}
.catalog-model-card__thumb {
  min-height: 96px;
  border-radius: 14px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 50% 18%, #2b3340 0%, #171c24 58%, #0e1117 100%);
  border: 1px solid rgba(255,255,255,0.08);
  color: #8ed0ff;
  font-weight: 900;
  letter-spacing: .12em;
}
.catalog-model-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
  display: block;
}
.catalog-model-card__body {
  min-width: 0;
  display: grid;
  gap: 7px;
  align-content: start;
}
.catalog-model-card__topline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  color: var(--soft);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.catalog-model-card__topline b {
  color: #7dd3fc;
  font-size: 11px;
}
.catalog-model-card__cta {
  justify-self: start;
  margin-top: 2px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(30,168,255,0.13);
  border: 1px solid rgba(30,168,255,0.24);
  color: #c7eaff;
  font-size: 12px;
  font-weight: 800;
}
.field--error .input,
.field--error select.input,
.field--error .field__number-input {
  border-color: rgba(248, 113, 113, .85) !important;
  box-shadow: 0 0 0 3px rgba(248, 113, 113, .12);
}
.field__error {
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(248, 113, 113, .12);
  border: 1px solid rgba(248, 113, 113, .22);
  color: #fecaca;
  font-size: 12px;
  line-height: 1.35;
}
.viewer-processing {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 12;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: min(360px, calc(100% - 36px));
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(8,11,17,.78);
  backdrop-filter: blur(12px);
  box-shadow: 0 22px 70px rgba(0,0,0,.34);
  pointer-events: none;
}
.viewer-processing__spinner {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 3px solid rgba(255,255,255,.18);
  border-top-color: #38bdf8;
  animation: viewer-spin .8s linear infinite;
  flex: 0 0 auto;
}
.viewer-processing__title {
  font-weight: 900;
  color: #f8fafc;
}
.viewer-processing__hint {
  margin-top: 3px;
  color: #b6c2d2;
  font-size: 12px;
  line-height: 1.35;
}
@keyframes viewer-spin { to { transform: rotate(360deg); } }
.order-param-list {
  display: grid;
  grid-template-columns: minmax(120px, .8fr) minmax(0, 1fr);
  gap: 6px 12px;
  margin-top: 8px;
  font-size: 13px;
}
.order-param-list span {
  color: var(--muted);
}
.order-param-list b {
  color: var(--text);
  font-weight: 800;
}
.price-breakdown--compact {
  max-height: 78px;
  overflow: auto;
}
.price-breakdown--compact .price-breakdown__row {
  padding: 7px 8px;
}
.orders-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 10px;
}
.request-list--orders {
  gap: 12px;
}
.order-card {
  display: grid;
  gap: 12px;
}
.order-card__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}
.order-card__head h3 {
  margin: 0;
  font-size: 18px;
}
.order-card__date,
.order-card__muted {
  color: var(--muted);
  font-size: 12px;
  margin-top: 4px;
}
.order-card__price {
  white-space: nowrap;
  font-size: 22px;
  font-weight: 900;
  color: #dff2ff;
}
.order-card__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.order-card__grid > div {
  display: grid;
  gap: 4px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.06);
  min-width: 0;
}
.order-card__grid span,
.order-status-select span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.order-card__grid b {
  color: var(--text);
  overflow-wrap: anywhere;
}
.order-card__comment {
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(30,168,255,.08);
  border: 1px solid rgba(30,168,255,.13);
  color: var(--text);
  line-height: 1.45;
}
.order-card__actions {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.order-status-select {
  display: grid;
  gap: 6px;
  min-width: min(240px, 100%);
}
.order-param-list--admin {
  padding-top: 10px;
}
.order-card--new { border-color: rgba(248,113,113,.25); }
.order-card--printing { border-color: rgba(56,189,248,.25); }
.order-card--ready { border-color: rgba(74,222,128,.25); }
body[data-theme="light"] .catalog-model-card__thumb {
  background: radial-gradient(circle at 50% 18%, #f8fafc 0%, #e2e8f0 62%, #cbd5e1 100%);
  border-color: rgba(15,23,42,.12);
  color: #0b70b8;
}
body[data-theme="light"] .catalog-model-card__cta {
  background: rgba(30,136,229,.10);
  border-color: rgba(30,136,229,.22);
  color: #0b3b66;
}
body[data-theme="light"] .field__error {
  background: rgba(239,68,68,.08);
  border-color: rgba(239,68,68,.22);
  color: #991b1b;
}
body[data-theme="light"] .viewer-processing {
  background: rgba(255,255,255,.88);
  border-color: rgba(15,23,42,.14);
  box-shadow: 0 22px 60px rgba(15,23,42,.16);
}
body[data-theme="light"] .viewer-processing__title { color: #0f172a; }
body[data-theme="light"] .viewer-processing__hint { color: #475569; }
body[data-theme="light"] .order-card__price { color: #075985; }
body[data-theme="light"] .order-card__grid > div {
  background: rgba(15,23,42,.035);
  border-color: rgba(15,23,42,.08);
}
@media (max-width: 1180px) {
  .maker-layout--builder {
    display: flex;
    flex-direction: column;
  }
  .builder-stage { order: 1; }
  .builder-sidebar { order: 2; }
}
@media (max-width: 760px) {
  body { padding: 8px; }
  .topbar {
    position: sticky;
    top: 0;
    z-index: 40;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 10px;
  }
  .topbar__actions,
  .customer-topbar,
  .customer-topbar__guest,
  .customer-topbar__auth {
    width: 100%;
  }
  .topbar__actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .customer-topbar__guest,
  .customer-topbar__auth {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .customer-topbar__auth .pill {
    grid-column: 1 / -1;
    justify-content: center;
    overflow-wrap: anywhere;
  }
  .maker-layout--builder {
    gap: 12px;
  }
  .builder-card { border-radius: 16px; }
  .viewer-card--builder,
  .viewer-card--builder #viewer {
    min-height: 56vh;
    height: 56vh;
  }
  .viewer-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }
  .viewer-toolbar__right {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .viewer-toolbar__btn { padding: 9px 8px; }
  .viewer-color-palette {
    top: 104px;
    right: 10px;
    justify-content: center;
  }
  .viewer-order-overlay {
    top: auto !important;
    left: 10px;
    right: 10px;
    bottom: 10px;
    padding: 10px;
    border-radius: 16px;
  }
  .viewer-order-overlay__value { font-size: 24px; }
  .viewer-order-overlay__hint { font-size: 12px; }
  .viewer-help { display: none; }
  .viewer-rotation-control {
    transform: scale(.86);
    transform-origin: right bottom;
  }
  .catalog-model-card {
    grid-template-columns: 76px minmax(0, 1fr);
  }
  .catalog-model-card__thumb { min-height: 78px; }
  .modal__dialog {
    width: calc(100vw - 14px);
    max-height: calc(100vh - 14px);
    padding: 14px;
    border-radius: 18px;
  }
  .orders-toolbar,
  .order-card__grid,
  .order-param-list {
    grid-template-columns: 1fr;
  }
  .order-card__head {
    flex-direction: column;
  }
  .order-card__price { font-size: 20px; }
  .field__number-controls {
    grid-template-columns: 86px minmax(0, 1fr);
  }
  .dynamic-form--builder {
    max-height: none;
    overflow: visible;
  }
}

/* v109: цена в каталоге и без служебного оверлея обработки */
.viewer-processing { display: none !important; }
.catalog-model-card__price {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  width: fit-content;
  margin-top: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(39, 174, 96, 0.14);
  border: 1px solid rgba(39, 174, 96, 0.26);
  color: #d8ffe9;
  font-size: 12px;
  font-weight: 700;
}
.catalog-model-card__price span { opacity: .75; font-weight: 600; }
.catalog-model-card__price b { font-size: 15px; }
.catalog-model-card__price--muted {
  color: var(--muted);
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.08);
  font-weight: 600;
}
body[data-theme="light"] .catalog-model-card__price {
  background: #e9fff2;
  border-color: #bbf7d0;
  color: #166534;
}
body[data-theme="light"] .catalog-model-card__price--muted {
  background: #f3f4f6;
  border-color: #e5e7eb;
  color: #64748b;
}
@media (max-width: 760px) {
  .catalog-model-card__price { margin-top: 7px; padding: 5px 9px; }
  .catalog-model-card__price b { font-size: 14px; }
}

/* v120: fixed one-screen configurator for customers.
   The page itself never scrolls; only the parameter panel scrolls. */
html {
  height: 100%;
}
body.user-mode.builder-page {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  min-height: 0;
  overflow: hidden !important;
  display: flex;
  flex-direction: column;
  padding: 10px;
}
body.user-mode.builder-page .flash-stack {
  display: none !important;
}
body.user-mode.builder-page .topbar {
  flex: 0 0 auto;
  margin-bottom: 10px;
}
body.user-mode.builder-page .maker-layout--builder {
  flex: 1 1 auto;
  height: auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(310px, 380px) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
}
body.user-mode.builder-page .builder-sidebar {
  position: relative !important;
  top: auto !important;
  order: 1;
  height: 100% !important;
  max-height: none !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column;
  gap: 10px;
  padding-right: 0;
}
body.user-mode.builder-page .builder-stage {
  position: relative !important;
  top: auto !important;
  order: 2;
  align-self: stretch;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.user-mode.builder-page .builder-sidebar > .builder-card {
  flex: 0 0 auto;
}
body.user-mode.builder-page .builder-card--compact,
body.user-mode.builder-page .builder-card--nav,
body.user-mode.builder-page #parts-section-card,
body.user-mode.builder-page #display-section-card {
  margin: 0;
}
body.user-mode.builder-page .builder-card--compact .selected-model {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 10px;
  padding: 8px;
}
body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
  height: 72px;
}
body.user-mode.builder-page .selected-model__name {
  font-size: 16px;
  margin-bottom: 4px;
}
body.user-mode.builder-page .selected-model__subtitle {
  font-size: 12px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
body.user-mode.builder-page .builder-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}
body.user-mode.builder-page .builder-nav__item {
  min-height: 32px;
  padding: 7px 8px;
  font-size: 12px;
}
body.user-mode.builder-page #parts-section-card .mw-card__header,
body.user-mode.builder-page #display-section-card .mw-card__header {
  margin-bottom: 8px;
}
body.user-mode.builder-page #parts-section-card h2,
body.user-mode.builder-page #display-section-card h2,
body.user-mode.builder-page .builder-card--controls h2 {
  font-size: 14px;
}
body.user-mode.builder-page .display-dimension-modes {
  gap: 6px;
}
body.user-mode.builder-page .display-chip {
  min-height: 30px;
  padding: 6px 8px;
  font-size: 12px;
}
body.user-mode.builder-page .builder-card--controls {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column;
}
body.user-mode.builder-page .builder-card--controls > .mw-card__header {
  flex: 0 0 auto;
  margin-bottom: 10px;
}
body.user-mode.builder-page .dynamic-form--builder,
body.user-mode.builder-page #dynamic-form {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain;
  padding-right: 6px;
}
body.user-mode.builder-page .customize-actions {
  flex: 0 0 auto;
  margin-top: 10px;
}
body.user-mode.builder-page .viewer-card--builder,
body.user-mode.builder-page .viewer-card--builder #viewer,
body.user-mode.builder-page .viewer-card,
body.user-mode.builder-page #viewer {
  width: 100%;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}
body.user-mode.builder-page .viewer-card--builder {
  position: relative;
}
body.user-mode.builder-page .viewer-help {
  bottom: 10px;
}
body.user-mode.builder-page .viewer-order-overlay {
  top: 64px;
}

@media (max-width: 1180px) and (min-width: 761px) {
  body.user-mode.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: minmax(300px, 350px) minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }
  body.user-mode.builder-page .builder-stage { order: 2; }
  body.user-mode.builder-page .builder-sidebar { order: 1; }
  body.user-mode.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder #viewer {
    height: 100% !important;
    min-height: 0 !important;
  }
}

@media (max-width: 760px) {
  body.user-mode.builder-page {
    padding: 8px;
  }
  body.user-mode.builder-page .topbar {
    flex-direction: row;
    align-items: center;
    gap: 8px;
    padding: 8px;
    margin-bottom: 8px;
    border-radius: 16px;
  }
  body.user-mode.builder-page .brand {
    gap: 8px;
    min-width: 0;
  }
  body.user-mode.builder-page .brand__mark {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    flex: 0 0 auto;
  }
  body.user-mode.builder-page .brand__title {
    font-size: 14px;
  }
  body.user-mode.builder-page .brand__subtitle {
    display: none;
  }
  body.user-mode.builder-page .topbar__actions {
    margin-left: auto;
    gap: 6px;
  }
  body.user-mode.builder-page .theme-toggle-btn {
    padding: 8px 9px;
    min-height: 34px;
  }
  body.user-mode.builder-page .theme-toggle-btn__text {
    display: none;
  }
  body.user-mode.builder-page .customer-topbar__guest,
  body.user-mode.builder-page .customer-topbar__auth {
    display: flex;
    width: auto;
    gap: 6px;
  }
  body.user-mode.builder-page .customer-topbar .btn,
  body.user-mode.builder-page .customer-topbar .pill {
    padding: 8px 9px;
    min-height: 34px;
    font-size: 12px;
  }
  body.user-mode.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 44%) minmax(0, 56%);
    gap: 8px;
  }
  body.user-mode.builder-page .builder-stage {
    order: 1;
    height: 100% !important;
  }
  body.user-mode.builder-page .builder-sidebar {
    order: 2;
    height: 100% !important;
    gap: 8px;
  }
  body.user-mode.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder #viewer,
  body.user-mode.builder-page #viewer {
    height: 100% !important;
    min-height: 0 !important;
  }
  body.user-mode.builder-page .viewer-toolbar {
    left: 8px;
    right: 8px;
    top: 8px;
    flex-direction: row;
    align-items: flex-start;
    gap: 8px;
  }
  body.user-mode.builder-page .viewer-toolbar__left {
    min-width: 0;
  }
  body.user-mode.builder-page .viewer-toolbar__right {
    width: auto;
    display: flex;
    gap: 5px;
  }
  body.user-mode.builder-page .viewer-toolbar__pill,
  body.user-mode.builder-page .viewer-toolbar__btn {
    min-height: 30px;
    padding: 6px 8px;
    font-size: 11px;
  }
  body.user-mode.builder-page .viewer-color-palette {
    top: 48px;
    left: 8px;
    right: auto;
    max-width: calc(100% - 16px);
    padding: 6px 8px;
  }
  body.user-mode.builder-page .viewer-badge,
  body.user-mode.builder-page .viewer-help {
    display: none;
  }
  body.user-mode.builder-page .viewer-order-overlay {
    top: auto !important;
    bottom: 8px;
    left: 8px;
    right: 8px;
    padding: 8px 10px;
    border-radius: 14px;
  }
  body.user-mode.builder-page .viewer-order-overlay__label,
  body.user-mode.builder-page .viewer-order-overlay__hint,
  body.user-mode.builder-page .price-breakdown--compact {
    display: none;
  }
  body.user-mode.builder-page .viewer-order-overlay__value {
    font-size: 22px;
    margin-top: 0;
  }
  body.user-mode.builder-page .viewer-order-overlay__button {
    margin-top: 7px;
    padding: 9px 10px;
  }
  body.user-mode.builder-page .viewer-rotation-control {
    transform: scale(.76);
    transform-origin: right bottom;
    right: 8px;
    bottom: 82px;
  }
  body.user-mode.builder-page .builder-card--nav,
  body.user-mode.builder-page #parts-section-card,
  body.user-mode.builder-page #display-section-card {
    display: none !important;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model {
    grid-template-columns: 54px minmax(0, 1fr);
    padding: 7px;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
    height: 54px;
    border-radius: 10px;
  }
  body.user-mode.builder-page .selected-model__name {
    font-size: 14px;
    margin-bottom: 2px;
  }
  body.user-mode.builder-page .selected-model__subtitle {
    -webkit-line-clamp: 1;
    font-size: 11px;
  }
  body.user-mode.builder-page .model-open-btn {
    width: 34px;
    height: 34px;
  }
  body.user-mode.builder-page .builder-card--controls {
    padding: 10px;
  }
  body.user-mode.builder-page .builder-card--controls > .mw-card__header {
    margin-bottom: 8px;
  }
  body.user-mode.builder-page .form-group__summary {
    padding: 12px 13px;
  }
  body.user-mode.builder-page .form-group__body {
    padding: 0 13px 13px;
  }
  body.user-mode.builder-page .customize-actions {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 430px) {
  body.user-mode.builder-page .customer-topbar .btn,
  body.user-mode.builder-page .customer-topbar .pill {
    font-size: 0;
    padding: 8px 10px;
  }
  body.user-mode.builder-page #open-login-modal-btn::after { content: 'Вход'; font-size: 12px; }
  body.user-mode.builder-page #open-register-modal-btn::after { content: 'Рег.'; font-size: 12px; }
  body.user-mode.builder-page #open-my-orders-auth-btn::after { content: 'Заказы'; font-size: 12px; }
  body.user-mode.builder-page #customer-logout-btn::after { content: 'Выйти'; font-size: 12px; }
}

/* v121: clean customer configurator.
   The customer page is one fixed screen; only the parameter list scrolls. */
body.user-mode.builder-page .builder-card--nav,
body.user-mode.builder-page #parts-section-card,
body.user-mode.builder-page #display-section-card {
  display: none !important;
}

body.user-mode.builder-page .builder-card--compact {
  padding: 10px !important;
}
body.user-mode.builder-page .builder-card--compact .section-kicker,
body.user-mode.builder-page .builder-card--compact h2 {
  display: none !important;
}
body.user-mode.builder-page .builder-card--compact .mw-card__header {
  margin: 0 0 8px !important;
  min-height: 0;
}
body.user-mode.builder-page .builder-card--compact .mw-card__header > div:first-child {
  display: none !important;
}
body.user-mode.builder-page .builder-card--compact .model-header-actions {
  width: 100%;
  justify-content: flex-end;
}
body.user-mode.builder-page .model-open-btn--customer {
  width: auto;
  min-width: 108px;
  border-radius: 999px;
  padding: 8px 12px;
}

body.user-mode.builder-page .builder-card--controls {
  padding: 12px !important;
}
body.user-mode.builder-page .builder-card--controls > .mw-card__header {
  display: none !important;
}
body.user-mode.builder-page .form-group__summary {
  display: none !important;
}
body.user-mode.builder-page .form-group--builder {
  padding: 12px !important;
}
body.user-mode.builder-page .form-group__body {
  padding: 0 !important;
}
body.user-mode.builder-page .dynamic-form--builder {
  gap: 10px !important;
}
body.user-mode.builder-page .field[data-field-key="sourceWidth"],
body.user-mode.builder-page .field[data-field-key="sourceHeight"],
body.user-mode.builder-page .field[data-field-key="sourceDepth"] {
  display: none !important;
}

body.user-mode.builder-page .builder-sidebar {
  overflow: hidden !important;
}
body.user-mode.builder-page .builder-card--controls {
  min-height: 0 !important;
  overflow: hidden !important;
}
body.user-mode.builder-page #dynamic-form {
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}

@media (max-width: 760px) {
  body.user-mode.builder-page .maker-layout--builder {
    grid-template-rows: minmax(0, 42%) minmax(0, 58%);
  }
  body.user-mode.builder-page .builder-card--compact {
    padding: 8px !important;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model {
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 8px;
    padding: 6px;
  }
  body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
    height: 54px;
  }
  body.user-mode.builder-page .selected-model__name {
    font-size: 14px;
  }
  body.user-mode.builder-page .selected-model__subtitle {
    font-size: 11px;
    -webkit-line-clamp: 1;
  }
  body.user-mode.builder-page .model-open-btn--customer {
    min-width: 86px;
    padding: 7px 10px;
    font-size: 12px;
  }
  body.user-mode.builder-page .customize-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  body.user-mode.builder-page .customize-actions .btn {
    width: 100%;
    padding: 10px 8px;
  }
}


/* v122: fixed one-screen configurator for customer + admin.
   The whole app stays in one viewport; only the SCAD/parameter list scrolls. */
html, body.builder-page {
  height: 100%;
}
body.builder-page {
  height: 100vh !important;
  max-height: 100vh !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
body.builder-page .topbar,
body.builder-page .admin-toolbar,
body.builder-page .flash-stack {
  flex: 0 0 auto;
}
body.builder-page .admin-toolbar {
  margin: 0 0 8px !important;
  padding: 8px !important;
  gap: 8px !important;
}
body.builder-page .admin-toolbar__btn {
  padding: 8px 11px !important;
  min-height: 36px !important;
}
body.builder-page .maker-layout--builder {
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: stretch !important;
}
body.builder-page .builder-sidebar {
  position: relative !important;
  top: auto !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding-right: 0 !important;
}
body.builder-page .builder-stage {
  position: relative !important;
  top: auto !important;
  align-self: stretch !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.builder-page .viewer-card--builder,
body.builder-page .viewer-card--builder #viewer,
body.builder-page .viewer-card,
body.builder-page #viewer {
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}
body.builder-page .builder-card--nav,
body.builder-page #parts-section-card,
body.builder-page #display-section-card {
  display: none !important;
}
body.builder-page .builder-card--compact {
  flex: 0 0 auto !important;
  padding: 10px !important;
}
body.builder-page .builder-card--compact .section-kicker,
body.builder-page .builder-card--compact h2,
body.builder-page .builder-card--controls > .mw-card__header,
body.builder-page .form-group__summary,
body.builder-page .form-group__title {
  display: none !important;
}
body.builder-page .builder-card--compact .mw-card__header {
  margin: 0 0 8px !important;
  min-height: 0 !important;
}
body.builder-page .builder-card--compact .mw-card__header > div:first-child {
  display: none !important;
}
body.builder-page .builder-card--compact .model-header-actions {
  width: 100% !important;
  justify-content: flex-end !important;
}
body.builder-page .builder-card--controls {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 12px !important;
}
body.builder-page #dynamic-form,
body.builder-page .dynamic-form--builder,
body.builder-page .dynamic-form--scroll {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  scrollbar-gutter: stable !important;
  padding-right: 6px !important;
}
body.builder-page .form-group--builder,
body.builder-page .form-group {
  padding: 10px !important;
  min-height: 0 !important;
}
body.builder-page .form-group__body {
  padding: 0 !important;
}
body.builder-page .field[data-field-key="sourceWidth"],
body.builder-page .field[data-field-key="sourceHeight"],
body.builder-page .field[data-field-key="sourceDepth"] {
  display: none !important;
}
body.builder-page .customize-actions {
  flex: 0 0 auto !important;
  margin-top: 10px !important;
}
body.builder-page.admin-mode .summary-stack,
body.builder-page.admin-mode .summary-actions {
  max-height: none;
}
body.builder-page.admin-mode .maker-layout--builder > .maker-sidebar > section:last-child {
  display: none !important;
}

@media (max-width: 1180px) and (min-width: 761px) {
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(280px, 350px) minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }
}
@media (max-width: 760px) {
  body.builder-page {
    padding: 8px !important;
  }
  body.builder-page .topbar {
    position: relative !important;
    margin-bottom: 8px !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px !important;
    border-radius: 16px !important;
  }
  body.builder-page .admin-toolbar {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    margin-bottom: 8px !important;
  }
  body.builder-page .brand__subtitle { display: none !important; }
  body.builder-page .brand__title { font-size: 14px !important; }
  body.builder-page .brand__mark { width: 34px !important; height: 34px !important; }
  body.builder-page .topbar__actions { margin-left: auto !important; gap: 6px !important; width: auto !important; }
  body.builder-page .theme-toggle-btn__text { display: none !important; }
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 42%) minmax(0, 58%) !important;
    gap: 8px !important;
  }
  body.builder-page .builder-stage { order: 1 !important; }
  body.builder-page .builder-sidebar { order: 2 !important; gap: 8px !important; }
  body.builder-page .builder-card--compact { padding: 8px !important; }
  body.builder-page .builder-card--controls { padding: 10px !important; }
  body.builder-page .selected-model__subtitle { -webkit-line-clamp: 1 !important; }
  body.builder-page .customize-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  body.builder-page .customize-actions .btn { width: 100% !important; padding: 10px 8px !important; }
}


/* v123: REAL fixed scroll for SCAD/user parameters.
   Previous versions set overflow, but the flex item still grew by content height.
   This forces a constrained app shell and makes only #dynamic-form scroll. */
html,
body.builder-page {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.builder-page {
  height: 100vh !important;
  height: 100dvh !important;
  max-height: 100vh !important;
  max-height: 100dvh !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 10px !important;
}
body.builder-page .topbar,
body.builder-page .admin-toolbar,
body.builder-page .flash-stack {
  flex: 0 0 auto !important;
}
body.builder-page .flash-stack { display: none !important; }
body.builder-page .maker-layout--builder {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  align-items: stretch !important;
}
body.builder-page .builder-sidebar,
body.builder-page .builder-stage,
body.builder-page .viewer-card--builder {
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
}
body.builder-page .builder-sidebar {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
body.builder-page .builder-sidebar > .builder-card {
  min-height: 0 !important;
}
body.builder-page .builder-card--compact {
  flex: 0 0 auto !important;
  max-height: 118px !important;
  overflow: hidden !important;
}
body.builder-page .builder-card--compact .selected-model {
  min-height: 0 !important;
  margin: 0 !important;
}
body.builder-page .builder-card--compact .selected-model__thumb {
  height: 64px !important;
}
body.builder-page .builder-card--controls {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
body.builder-page .builder-card--controls > .mw-card__header,
body.builder-page .builder-card--controls .form-group__summary,
body.builder-page .builder-card--controls .form-group__title {
  display: none !important;
}
body.builder-page #dynamic-form {
  display: block !important;
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: scroll !important;
  overflow-x: hidden !important;
  padding-right: 8px !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  touch-action: pan-y !important;
}
body.builder-page #dynamic-form > .form-group,
body.builder-page #dynamic-form > details.form-group,
body.builder-page #dynamic-form .form-group__body {
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}
body.builder-page #dynamic-form .field:last-child {
  margin-bottom: 14px !important;
}
body.builder-page .customize-actions {
  flex: 0 0 auto !important;
  margin-top: 10px !important;
}
body.builder-page .builder-card--nav,
body.builder-page #parts-section-card,
body.builder-page #display-section-card,
body.builder-page.admin-mode .maker-layout--builder > .maker-sidebar > section:last-child {
  display: none !important;
}
body.builder-page .field[data-field-key="sourceWidth"],
body.builder-page .field[data-field-key="sourceHeight"],
body.builder-page .field[data-field-key="sourceDepth"] {
  display: none !important;
}
@media (max-width: 760px) {
  body.builder-page { padding: 8px !important; }
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 42%) minmax(0, 58%) !important;
    gap: 8px !important;
  }
  body.builder-page .builder-stage { order: 1 !important; }
  body.builder-page .builder-sidebar { order: 2 !important; }
  body.builder-page .builder-card--compact {
    max-height: 82px !important;
    padding: 8px !important;
  }
  body.builder-page .builder-card--compact .selected-model {
    grid-template-columns: 48px minmax(0, 1fr) !important;
    gap: 8px !important;
    padding: 5px !important;
  }
  body.builder-page .builder-card--compact .selected-model__thumb {
    height: 48px !important;
  }
  body.builder-page .selected-model__subtitle { display: none !important; }
  body.builder-page .builder-card--controls { padding: 10px !important; }
  body.builder-page #dynamic-form { padding-right: 6px !important; }
}

/* ===== v193: V124 design + full functionality integration ===== */
:root {
  --xl-sidebar: clamp(320px, 27vw, 390px);
  --xl-gap: 14px;
}
body.builder-page {
  background: radial-gradient(circle at 20% -10%, rgba(44, 76, 148, .24), transparent 34%), linear-gradient(180deg, #0f1117, #0b0d12) !important;
}
body.builder-page .topbar {
  box-shadow: 0 12px 30px rgba(0,0,0,.22) !important;
}
body.builder-page .maker-layout--builder {
  grid-template-columns: var(--xl-sidebar) minmax(0, 1fr) !important;
  gap: var(--xl-gap) !important;
}
body.builder-page .builder-sidebar {
  overflow: hidden !important;
  gap: 10px !important;
}
body.builder-page .builder-card--compact {
  max-height: 128px !important;
  min-height: 104px !important;
  border-radius: 18px !important;
}
body.builder-page .builder-card--compact .mw-card__header {
  display: flex !important;
}
body.builder-page .builder-card--compact .model-header-actions {
  display: flex !important;
  gap: 7px !important;
  width: 100% !important;
  justify-content: flex-end !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
body.builder-page .builder-card--compact .model-header-actions .btn,
body.builder-page .builder-card--compact .model-open-btn {
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 10px !important;
  border-radius: 12px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
body.builder-page .builder-card--compact .selected-model {
  grid-template-columns: 66px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: center !important;
  padding: 8px !important;
  border-radius: 16px !important;
}
body.builder-page .builder-card--compact .selected-model__thumb {
  width: 66px !important;
  height: 58px !important;
  min-height: 58px !important;
  border-radius: 12px !important;
}
body.builder-page .selected-model__meta { min-width: 0 !important; }
body.builder-page .selected-model__name {
  font-size: 15px !important;
  line-height: 1.15 !important;
  margin-bottom: 4px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
body.builder-page .selected-model__subtitle {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}
body.builder-page .customer-model-strip,
body.builder-page .builder-card--nav,
body.builder-page #parts-section-card,
body.builder-page #display-section-card,
body.builder-page #live-size-panel,
body.builder-page #config-smart-panel,
body.builder-page #param-workbench,
body.builder-page #print-preflight-panel,
body.builder-page .cad-hud,
body.builder-page .dimension-hud,
body.builder-page #assembly-section-card {
  display: none !important;
}
body.builder-page #assembly-section-card.is-open {
  display: block !important;
  position: fixed !important;
  left: 16px !important;
  top: 112px !important;
  bottom: 16px !important;
  width: min(430px, calc(100vw - 32px)) !important;
  z-index: 920 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.55) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
}
body.builder-page .builder-card--controls {
  border-radius: 18px !important;
  padding: 12px !important;
}
body.builder-page .builder-card--controls::before {
  content: 'Настройка';
  display: block;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .02em;
  color: #fff;
  margin: 0 0 10px;
}
body.builder-page #dynamic-form {
  border-radius: 14px !important;
  scrollbar-width: thin;
}
body.builder-page .form-group,
body.builder-page .field {
  max-width: 100% !important;
}
body.builder-page .field {
  padding: 10px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.035) !important;
  border: 1px solid rgba(255,255,255,.075) !important;
}
body.builder-page .field label,
body.builder-page .field__label {
  font-size: 12px !important;
  line-height: 1.2 !important;
}
body.builder-page .field input,
body.builder-page .field select,
body.builder-page .field textarea,
body.builder-page .input,
body.builder-page .textarea {
  min-height: 38px !important;
  border-radius: 12px !important;
}
body.builder-page .customize-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}
body.builder-page .customize-actions .btn {
  width: 100% !important;
  min-height: 40px !important;
  border-radius: 12px !important;
}
body.builder-page .viewer-card--builder {
  border-radius: 22px !important;
  overflow: hidden !important;
  background: radial-gradient(circle at 50% 10%, rgba(68,82,116,.22), transparent 32%), linear-gradient(180deg, #171b24, #0d1017) !important;
}
body.builder-page .viewer-toolbar {
  left: 14px !important;
  right: 14px !important;
  top: 14px !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  z-index: 30 !important;
  pointer-events: none !important;
}
body.builder-page .viewer-toolbar__left,
body.builder-page .viewer-toolbar__right {
  pointer-events: auto !important;
}
body.builder-page .viewer-toolbar__right {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  max-width: min(720px, 62vw) !important;
  max-height: 78px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 2px !important;
  scrollbar-width: thin;
}
body.builder-page .viewer-toolbar__btn,
body.builder-page .viewer-toolbar__pill,
body.builder-page .viewer-toolbar__draft {
  min-height: 32px !important;
  height: 32px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
body.builder-page #undo-config-btn,
body.builder-page #redo-config-btn {
  width: 32px !important;
  min-width: 32px !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: transparent !important;
  position: relative !important;
}
body.builder-page #undo-config-btn::after { content: '↶'; }
body.builder-page #redo-config-btn::after { content: '↷'; }
body.builder-page #undo-config-btn::after,
body.builder-page #redo-config-btn::after {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 18px;
}
body.builder-page #viewer-cut-btn-top,
body.builder-page #viewer-cut-range,
body.builder-page #viewer-dimensions-btn-top {
  display: none !important;
}
body.builder-page #viewer-dimensions {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 25 !important;
}
body.builder-page .viewer-order-overlay {
  top: 86px !important;
  right: 16px !important;
  max-width: 245px !important;
  border-radius: 18px !important;
  z-index: 24 !important;
}
body.builder-page .viewer-badge { display: none !important; }
body.builder-page .viewer-help {
  left: 14px !important;
  bottom: 12px !important;
  right: auto !important;
  max-width: calc(100% - 250px) !important;
  overflow: hidden !important;
}
body.builder-page .modal {
  z-index: 1000 !important;
}
body.builder-page .modal.hidden { display: none !important; }
body.builder-page .modal:not(.hidden) {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 14px !important;
}
body.builder-page .modal__dialog {
  max-height: min(860px, calc(100dvh - 28px)) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  border-radius: 24px !important;
}
body.builder-page .modal__header {
  flex: 0 0 auto !important;
}
body.builder-page .modal__body,
body.builder-page .admin-window__body,
body.builder-page .modal__dialog > form,
body.builder-page .modal__dialog > .request-list,
body.builder-page .modal__dialog > .saved-designs-list,
body.builder-page .modal__dialog > .notifications-list {
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 4px !important;
}
body.builder-page .modal__dialog--models {
  width: min(760px, calc(100vw - 24px)) !important;
}
body.builder-page .template-list--catalog-pro,
body.builder-page #template-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  max-height: min(590px, calc(100dvh - 250px)) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 6px !important;
}
body.builder-page .template-item--catalog {
  width: 100% !important;
  min-width: 0 !important;
}
body.builder-page .catalog-model-card {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 94px minmax(0, 1fr) !important;
  gap: 12px !important;
  padding: 10px !important;
  min-height: 112px !important;
  align-items: center !important;
  text-align: left !important;
}
body.builder-page .catalog-model-card__thumb {
  width: 94px !important;
  height: 94px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}
body.builder-page .catalog-model-card__thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}
body.builder-page .catalog-model-card__body { min-width: 0 !important; }
body.builder-page .catalog-model-card__topline,
body.builder-page .catalog-model-card__facts,
body.builder-page .catalog-model-card__pro-facts,
body.builder-page .catalog-model-card__highlights,
body.builder-page .template-item__tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
  min-width: 0 !important;
}
body.builder-page .template-item__title {
  font-size: 15px !important;
  line-height: 1.2 !important;
  margin: 3px 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
body.builder-page .template-item__meta {
  font-size: 12px !important;
  line-height: 1.25 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
body.builder-page .catalog-model-card__cta,
body.builder-page .catalog-model-card__price {
  margin-top: 4px !important;
}
body.builder-page .admin-toolbar {
  overflow-x: auto !important;
  flex-wrap: nowrap !important;
  scrollbar-width: thin !important;
}
body.builder-page .admin-toolbar__btn {
  flex: 0 0 auto !important;
}
body.builder-page .social-login-grid,
body.builder-page .auth-provider-grid {
  display: flex !important;
  gap: 8px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}
body.builder-page .social-login-grid a,
body.builder-page .auth-provider-grid a,
body.builder-page .social-login-btn,
body.builder-page .auth-provider-btn {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  padding: 0 !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  font-size: 0 !important;
  display: inline-grid !important;
  place-items: center !important;
}
body.builder-page .social-login-grid a::first-letter,
body.builder-page .social-login-btn::first-letter,
body.builder-page .auth-provider-btn::first-letter { font-size: 16px !important; }

@media (max-width: 1180px) and (min-width: 761px) {
  body.builder-page .maker-layout--builder { grid-template-columns: minmax(290px, 350px) minmax(0, 1fr) !important; }
  body.builder-page .viewer-toolbar__right { max-width: 58vw !important; }
}
@media (max-width: 760px) {
  body.builder-page { padding: 8px !important; }
  body.builder-page .maker-layout--builder {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 43%) minmax(0, 57%) !important;
  }
  body.builder-page .viewer-toolbar__right {
    max-width: 70vw !important;
    max-height: 66px !important;
  }
  body.builder-page .viewer-toolbar__left .viewer-toolbar__pill:not(:first-child) { display: none !important; }
  body.builder-page .catalog-model-card { grid-template-columns: 72px minmax(0,1fr) !important; min-height: 90px !important; }
  body.builder-page .catalog-model-card__thumb { width: 72px !important; height: 72px !important; }
  body.builder-page .viewer-order-overlay { top: auto !important; bottom: 8px !important; left: 8px !important; right: 8px !important; max-width: none !important; }
  body.builder-page .viewer-help { display: none !important; }
}


/* === V194: compact auth, official icon buttons, checkbox and notification layout fix === */
body.builder-page .field .toggle,
body.builder-page .toggle {
  min-height: 24px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  color: rgba(226,232,240,.82) !important;
}
body.builder-page input[type="checkbox"],
body.builder-page .field input[type="checkbox"],
body.builder-page .toggle input[type="checkbox"],
body.builder-page .checkbox-line input[type="checkbox"],
body.builder-page .live-size-lock input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  padding: 0 !important;
  margin: 0 !important;
  flex: 0 0 16px !important;
  border-radius: 4px !important;
  accent-color: #38bdf8 !important;
  box-shadow: none !important;
}
body.builder-page .field .toggle span { font-size: 12px !important; }
body.builder-page .checkbox-line { gap: 8px !important; align-items: flex-start !important; }
body.builder-page .checkbox-line span { font-size: 11.5px !important; line-height: 1.25 !important; }

body.builder-page .floating-notifications-btn {
  top: auto !important;
  right: 18px !important;
  bottom: 18px !important;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  padding: 0 !important;
  border-radius: 16px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 19px !important;
  line-height: 1 !important;
  z-index: 130 !important;
  background: rgba(15,23,42,.88) !important;
  backdrop-filter: blur(16px) !important;
  border-color: rgba(148,163,184,.28) !important;
}
body.builder-page .floating-notifications-icon { display: block !important; line-height: 1 !important; }
body.builder-page .floating-notifications-badge {
  position: absolute !important;
  top: -6px !important;
  right: -6px !important;
  margin: 0 !important;
  min-width: 18px !important;
  height: 18px !important;
  font-size: 10px !important;
  border: 2px solid rgba(15,23,42,.96) !important;
}

body.builder-page #customer-auth-modal .modal__dialog {
  width: min(430px, calc(100vw - 22px)) !important;
  max-height: calc(100dvh - 24px) !important;
  overflow: hidden !important;
  border-radius: 22px !important;
}
body.builder-page #customer-auth-modal .modal__header {
  padding: 13px 14px 8px !important;
  margin: 0 !important;
}
body.builder-page #customer-auth-modal .modal__header h2 {
  font-size: 18px !important;
  line-height: 1.15 !important;
  margin: 0 !important;
}
body.builder-page #customer-auth-modal .modal__header p,
body.builder-page #customer-auth-modal .social-auth-panel__title,
body.builder-page #customer-auth-modal .social-auth-panel__hint,
body.builder-page #customer-auth-modal .access-matrix {
  display: none !important;
}
body.builder-page #customer-auth-modal .auth-switcher {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 7px !important;
  padding: 0 14px !important;
  margin: 0 0 8px !important;
}
body.builder-page #customer-auth-modal .auth-switcher .btn {
  min-height: 34px !important;
  height: 34px !important;
  padding: 0 10px !important;
  font-size: 12px !important;
  border-radius: 12px !important;
}
body.builder-page #customer-auth-modal .social-auth-panel {
  display: block !important;
  margin: 0 14px 9px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
body.builder-page .social-auth-buttons--icons,
body.builder-page #customer-auth-modal .social-auth-buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  flex-wrap: nowrap !important;
}
body.builder-page .social-auth-btn--icon,
body.builder-page #customer-auth-modal .social-auth-btn {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  padding: 0 !important;
  border-radius: 13px !important;
  display: inline-grid !important;
  place-items: center !important;
  font-size: 0 !important;
  line-height: 0 !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
}
body.builder-page .social-auth-btn--icon img,
body.builder-page #customer-auth-modal .social-auth-btn img {
  display: block !important;
  width: 23px !important;
  height: 23px !important;
  object-fit: contain !important;
  pointer-events: none !important;
}
body.builder-page #customer-auth-modal .form-stack {
  gap: 7px !important;
  padding: 0 14px 14px !important;
  margin: 0 !important;
}
body.builder-page #customer-auth-modal .form-stack label:not(.checkbox-line) {
  display: block !important;
  margin: 0 !important;
}
body.builder-page #customer-auth-modal .form-stack label:not(.checkbox-line) > span {
  display: none !important;
}
body.builder-page #customer-auth-modal .input {
  min-height: 34px !important;
  height: 34px !important;
  padding: 0 11px !important;
  border-radius: 11px !important;
  font-size: 13px !important;
}
body.builder-page #customer-auth-modal .captcha-box {
  padding: 7px !important;
  border-radius: 12px !important;
  margin: 0 !important;
  display: grid !important;
  gap: 6px !important;
}
body.builder-page #customer-auth-modal .captcha-box__row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}
body.builder-page #customer-auth-modal .captcha-box__label { font-size: 11px !important; }
body.builder-page #customer-auth-modal #refresh-captcha-btn {
  min-height: 26px !important;
  height: 26px !important;
  padding: 0 8px !important;
  font-size: 11px !important;
  border-radius: 9px !important;
}
body.builder-page #customer-auth-modal .captcha-box__question {
  min-height: 26px !important;
  padding: 3px 8px !important;
  border-radius: 9px !important;
  font-size: 15px !important;
  line-height: 20px !important;
}
body.builder-page #customer-auth-modal .btn[type="submit"] {
  min-height: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
  font-size: 13px !important;
}
body.builder-page #customer-auth-modal .checkbox-line {
  margin: 0 !important;
  padding: 0 !important;
}
@media (max-height: 720px) {
  body.builder-page #customer-auth-modal .modal__dialog { transform: scale(.94) !important; transform-origin: center !important; }
  body.builder-page #customer-auth-modal .form-stack { gap: 5px !important; }
  body.builder-page #customer-auth-modal .input { height: 31px !important; min-height: 31px !important; }
  body.builder-page #customer-auth-modal .captcha-box { padding: 6px !important; gap: 4px !important; }
}
body[data-theme="light"].builder-page .social-auth-btn--icon,
body[data-theme="light"].builder-page #customer-auth-modal .social-auth-btn {
  background: #fff !important;
  border-color: rgba(15,23,42,.12) !important;
  box-shadow: 0 4px 12px rgba(15,23,42,.08) !important;
}
body[data-theme="light"].builder-page .floating-notifications-btn {
  background: rgba(255,255,255,.92) !important;
  color: #0f172a !important;
}



/* === V195: clean topbar controls and remove noisy viewer labels === */
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.topbar__actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.topbar-icon-btn {
  position: relative !important;
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  padding: 0 !important;
  border-radius: 14px !important;
  border: 1px solid rgba(148,163,184,.22) !important;
  background: rgba(15,23,42,.60) !important;
  color: #e5eefb !important;
  display: inline-grid !important;
  place-items: center !important;
  cursor: pointer !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 8px 24px rgba(2,6,23,.18) !important;
  backdrop-filter: blur(14px) !important;
}
.topbar-icon-btn:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(56,189,248,.45) !important;
  background: rgba(15,23,42,.78) !important;
}
.topbar-icon-btn__glyph { font-size: 18px !important; line-height: 1 !important; }
.topbar-icon-btn__badge {
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  min-width: 18px !important;
  height: 18px !important;
  padding: 0 4px !important;
  border-radius: 999px !important;
  background: #ef4444 !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  line-height: 18px !important;
  text-align: center !important;
  border: 2px solid rgba(15,23,42,.96) !important;
}
.theme-toggle-btn {
  font-size: 0 !important;
  gap: 0 !important;
}
.theme-toggle-btn__icon,
.theme-toggle-btn__icon img {
  display: block !important;
  width: 24px !important;
  height: 24px !important;
}
.theme-toggle-btn__text { display: none !important; }
body[data-theme="light"] .topbar-icon-btn {
  background: rgba(255,255,255,.86) !important;
  color: #0f172a !important;
  border-color: rgba(15,23,42,.12) !important;
  box-shadow: 0 8px 22px rgba(15,23,42,.08) !important;
}
body[data-theme="light"] .topbar-icon-btn__badge { border-color: #fff !important; }
body.builder-page .floating-notifications-btn { display: none !important; }
body.builder-page .viewer-toolbar__left--clean,
body.builder-page #viewer-template-pill,
body.builder-page #viewer-mode-pill,
body.builder-page .viewer-badge { display: none !important; }
body.builder-page #viewer-grid-btn-top,
body.builder-page #viewer-cut-btn-top,
body.builder-page #cad-hud { display: none !important; }
body.builder-page .viewer-toolbar__right--pro {
  max-width: 100% !important;
  justify-content: flex-start !important;
}
body.builder-page .viewer-toolbar__btn--help {
  min-width: 116px !important;
  white-space: nowrap !important;
  padding-inline: 12px !important;
  font-weight: 750 !important;
}
body.builder-page .viewer-toolbar__btn--history.viewer-toolbar__btn--square {
  width: 38px !important;
  min-width: 38px !important;
  padding: 0 !important;
  font-size: 18px !important;
  font-weight: 800 !important;
}
body.builder-page .admin-toolbar [data-admin-panel-open="notifications-modal"] { display: none !important; }
@media (max-width: 760px) {
  .topbar-icon-btn { width: 38px !important; height: 38px !important; min-width: 38px !important; min-height: 38px !important; border-radius: 13px !important; }
  .theme-toggle-btn__icon, .theme-toggle-btn__icon img { width: 22px !important; height: 22px !important; }
  body.builder-page .viewer-toolbar__btn--help { min-width: 104px !important; padding-inline: 10px !important; font-size: 11px !important; }
}

/* === V196: centered viewer info HUD - price, dimensions and hotkeys never leave the 3D window === */
body.builder-page .viewer-card--builder {
  position: relative !important;
  min-height: clamp(520px, calc(100dvh - 118px), 820px) !important;
  overflow: hidden !important;
}
body.builder-page .viewer-card--builder #viewer {
  min-height: inherit !important;
}

/* Старые плавающие метки Ш/В/Г больше не уходят за пределы сцены; точные значения дублируются в нижнем блоке. */
body.builder-page .viewer-dimensions__label {
  display: none !important;
}
body.builder-page .viewer-dimensions__svg {
  opacity: .78 !important;
}

/* Always visible exact dimensions, centered in the model window */
body.builder-page .dimension-hud,
body.builder-page .dimension-hud.hidden {
  display: block !important;
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: 246px !important;
  transform: translateX(-50%) !important;
  z-index: 34 !important;
  width: min(430px, calc(100% - 36px)) !important;
  max-width: calc(100% - 36px) !important;
  padding: 10px 12px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(148,163,184,.20) !important;
  background: rgba(9,12,18,.70) !important;
  backdrop-filter: blur(18px) saturate(125%) !important;
  box-shadow: 0 18px 55px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.05) !important;
  pointer-events: none !important;
}
body.builder-page .dimension-hud__title {
  margin: 0 0 8px !important;
  color: rgba(226,232,240,.82) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .13em !important;
  text-align: center !important;
}
body.builder-page .dimension-hud__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 7px !important;
}
body.builder-page .dimension-hud__grid div {
  min-width: 0 !important;
  padding: 8px 7px !important;
  border-radius: 13px !important;
  background: rgba(255,255,255,.055) !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  text-align: center !important;
}
body.builder-page .dimension-hud__grid span {
  display: block !important;
  margin-bottom: 3px !important;
  color: rgba(148,163,184,.96) !important;
  font-size: 10px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
body.builder-page .dimension-hud__grid b {
  display: block !important;
  color: #f8fafc !important;
  font-size: 14px !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Price/order card is no longer glued to the corner; it sits centered inside the viewer. */
body.builder-page .viewer-order-overlay {
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: 66px !important;
  transform: translateX(-50%) !important;
  width: min(310px, calc(100% - 36px)) !important;
  min-width: 0 !important;
  max-width: calc(100% - 36px) !important;
  max-height: 168px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 10px 12px 11px !important;
  border-radius: 18px !important;
  z-index: 35 !important;
  scrollbar-width: thin !important;
}
body.builder-page .viewer-order-overlay__label {
  font-size: 10px !important;
  letter-spacing: .12em !important;
  line-height: 1 !important;
}
body.builder-page .viewer-order-overlay__value {
  margin-top: 5px !important;
  font-size: 23px !important;
  line-height: 1.05 !important;
}
body.builder-page .viewer-order-overlay__hint {
  margin-top: 5px !important;
  font-size: 11px !important;
  line-height: 1.25 !important;
}
body.builder-page .price-breakdown--compact {
  margin-top: 6px !important;
  font-size: 11px !important;
  line-height: 1.25 !important;
}
body.builder-page .viewer-order-overlay__button {
  margin-top: 7px !important;
  min-height: 34px !important;
  height: 34px !important;
  border-radius: 12px !important;
  font-size: 12px !important;
}

/* Hotkeys are centered at the very bottom of the 3D window and never run out of bounds. */
body.builder-page .viewer-help {
  left: 50% !important;
  right: auto !important;
  bottom: 12px !important;
  transform: translateX(-50%) !important;
  max-width: calc(100% - 36px) !important;
  width: auto !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
  overflow: visible !important;
  z-index: 33 !important;
  pointer-events: none !important;
}
body.builder-page .viewer-help span {
  max-width: 190px !important;
  min-height: 24px !important;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

body[data-theme="light"].builder-page .dimension-hud,
body[data-theme="light"].builder-page .dimension-hud.hidden {
  background: rgba(255,255,255,.82) !important;
  border-color: rgba(15,23,42,.12) !important;
  box-shadow: 0 18px 45px rgba(15,23,42,.12) !important;
}
body[data-theme="light"].builder-page .dimension-hud__title,
body[data-theme="light"].builder-page .dimension-hud__grid b { color: #0f172a !important; }
body[data-theme="light"].builder-page .dimension-hud__grid span { color: #64748b !important; }
body[data-theme="light"].builder-page .dimension-hud__grid div {
  background: rgba(15,23,42,.045) !important;
  border-color: rgba(15,23,42,.06) !important;
}

@media (max-height: 700px) {
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    bottom: 220px !important;
    padding: 8px 10px !important;
  }
  body.builder-page .viewer-order-overlay {
    bottom: 56px !important;
    max-height: 150px !important;
  }
  body.builder-page .viewer-help span:nth-child(n+3) { display: none !important; }
}
@media (max-width: 760px) {
  body.builder-page .viewer-card--builder {
    min-height: 560px !important;
  }
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    width: calc(100% - 24px) !important;
    bottom: 230px !important;
    padding: 8px !important;
  }
  body.builder-page .dimension-hud__title { display: none !important; }
  body.builder-page .dimension-hud__grid { gap: 5px !important; }
  body.builder-page .dimension-hud__grid div { padding: 7px 4px !important; }
  body.builder-page .dimension-hud__grid b { font-size: 12px !important; }
  body.builder-page .viewer-order-overlay {
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    bottom: 56px !important;
  }
  body.builder-page .viewer-help {
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
  }
  body.builder-page .viewer-help span { font-size: 10px !important; max-width: 46% !important; }
}

/* === V197: restore price card position + move exact size HUD to lower-left === */
body.builder-page .viewer-card--builder {
  position: relative !important;
  overflow: hidden !important;
}

/* Price card back to the right side, below the top toolbar */
body.builder-page .viewer-order-overlay {
  left: auto !important;
  right: 16px !important;
  top: 86px !important;
  bottom: auto !important;
  transform: none !important;
  width: 245px !important;
  min-width: 0 !important;
  max-width: min(245px, calc(100% - 32px)) !important;
  max-height: calc(100% - 118px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 12px 13px 12px !important;
  border-radius: 18px !important;
  z-index: 34 !important;
  scrollbar-width: thin !important;
}
body.builder-page .viewer-order-overlay__label {
  font-size: 10px !important;
  letter-spacing: .12em !important;
  line-height: 1 !important;
}
body.builder-page .viewer-order-overlay__value {
  margin-top: 6px !important;
  font-size: 25px !important;
  line-height: 1.05 !important;
}
body.builder-page .viewer-order-overlay__hint,
body.builder-page .price-breakdown--compact {
  font-size: 11px !important;
  line-height: 1.28 !important;
}
body.builder-page .viewer-order-overlay__button {
  min-height: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
}

/* Exact dimensions are always visible in the lower-left corner of the model viewport */
body.builder-page .dimension-hud,
body.builder-page .dimension-hud.hidden {
  display: block !important;
  position: absolute !important;
  left: 16px !important;
  right: auto !important;
  top: auto !important;
  bottom: 18px !important;
  transform: none !important;
  z-index: 34 !important;
  width: 236px !important;
  max-width: calc(100% - 32px) !important;
  padding: 10px !important;
  border-radius: 16px !important;
  pointer-events: none !important;
}
body.builder-page .dimension-hud__title {
  display: block !important;
  text-align: left !important;
  margin: 0 0 8px !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
}
body.builder-page .dimension-hud__grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 6px !important;
}
body.builder-page .dimension-hud__grid div {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  min-height: 28px !important;
  padding: 6px 8px !important;
  border-radius: 11px !important;
  text-align: left !important;
}
body.builder-page .dimension-hud__grid span {
  margin: 0 !important;
  font-size: 10px !important;
  line-height: 1 !important;
}
body.builder-page .dimension-hud__grid b {
  font-size: 13px !important;
  line-height: 1 !important;
  text-align: right !important;
}

/* Hotkeys stay visible but move away from the lower-left dimensions HUD */
body.builder-page .viewer-help {
  left: 270px !important;
  right: 278px !important;
  bottom: 16px !important;
  transform: none !important;
  width: auto !important;
  max-width: none !important;
  justify-content: flex-start !important;
  pointer-events: none !important;
}
body.builder-page .viewer-help span {
  max-width: 190px !important;
}

@media (max-width: 980px) {
  body.builder-page .viewer-order-overlay {
    top: 78px !important;
    right: 12px !important;
    width: 230px !important;
    max-width: calc(100% - 24px) !important;
  }
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    left: 12px !important;
    bottom: 12px !important;
    width: 218px !important;
    max-width: calc(100% - 24px) !important;
  }
  body.builder-page .viewer-help {
    left: 12px !important;
    right: 12px !important;
    bottom: 116px !important;
    justify-content: center !important;
  }
}

@media (max-width: 720px) {
  body.builder-page .viewer-card--builder {
    min-height: 560px !important;
  }
  body.builder-page .viewer-order-overlay {
    top: 72px !important;
    right: 12px !important;
    width: min(220px, calc(100% - 24px)) !important;
  }
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    width: 190px !important;
    padding: 8px !important;
  }
  body.builder-page .dimension-hud__title {
    display: none !important;
  }
  body.builder-page .viewer-help span:nth-child(n+3) {
    display: none !important;
  }
}


/* v198: frameless Bootstrap star icons for favorites and pinned parameters. */
body.builder-page .catalog-model-card__favorite,
body.builder-page .field__pin-btn {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  color: #94a3b8 !important;
  font-size: 0 !important;
  line-height: 0 !important;
  padding: 0 !important;
  display: inline-grid !important;
  place-items: center !important;
  cursor: pointer !important;
  transition: color .16s ease, transform .16s ease, opacity .16s ease !important;
}
body.builder-page .catalog-model-card__favorite {
  width: 30px !important;
  height: 30px !important;
  border-radius: 10px !important;
  top: 10px !important;
  right: 10px !important;
}
body.builder-page .field__pin-btn {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
  border-radius: 8px !important;
  margin-left: 6px !important;
}
body.builder-page .catalog-model-card__favorite::before,
body.builder-page .field__pin-btn::before {
  content: "" !important;
  display: block !important;
  width: 18px !important;
  height: 18px !important;
  background-color: currentColor !important;
  -webkit-mask: url('../icons/star.svg') center / contain no-repeat !important;
  mask: url('../icons/star.svg') center / contain no-repeat !important;
}
body.builder-page .field__pin-btn::before {
  width: 16px !important;
  height: 16px !important;
}
body.builder-page .catalog-model-card__favorite:hover,
body.builder-page .field__pin-btn:hover {
  color: #f8d76a !important;
  transform: translateY(-1px) scale(1.08) !important;
}
body.builder-page .catalog-model-card__favorite.is-active,
body.builder-page .field__pin-btn.is-active {
  color: #facc15 !important;
  background: transparent !important;
  border: 0 !important;
}
body.builder-page .catalog-model-card__favorite.is-active::before,
body.builder-page .field__pin-btn.is-active::before {
  -webkit-mask-image: url('../icons/star-fill.svg') !important;
  mask-image: url('../icons/star-fill.svg') !important;
}
body.builder-page .catalog-model-card__favorite:focus-visible,
body.builder-page .field__pin-btn:focus-visible {
  outline: 2px solid rgba(250,204,21,.55) !important;
  outline-offset: 2px !important;
}
body.builder-page .catalog-model-card__favorite:active,
body.builder-page .field__pin-btn:active {
  transform: scale(.94) !important;
}
body[data-theme="light"].builder-page .catalog-model-card__favorite,
body[data-theme="light"].builder-page .field__pin-btn {
  color: #64748b !important;
  background: transparent !important;
  border: 0 !important;
}
body[data-theme="light"].builder-page .catalog-model-card__favorite.is-active,
body[data-theme="light"].builder-page .field__pin-btn.is-active {
  color: #eab308 !important;
}


/* === v199: selected model card normalization ===
   Верх карточки: мини-изображение слева, название и описание справа.
   Остальная служебная информация уходит отдельной строкой под ними. */
body.builder-page .model-card.builder-card--compact {
  flex: 0 0 auto !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 10px !important;
}
body.builder-page .model-card .mw-card__header {
  margin: 0 0 8px !important;
}
body.builder-page .model-card .model-header-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  justify-content: flex-start !important;
  width: 100% !important;
}
body.builder-page .model-card .model-header-actions .btn,
body.builder-page .model-card .model-header-actions .model-open-btn,
body.builder-page .model-card .model-header-actions .model-open-btn--customer {
  min-height: 32px !important;
  padding: 7px 9px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
body.builder-page .builder-card--compact .selected-model,
body.builder-page .builder-card--compact .selected-model.selected-model--text-only,
body.user-mode.builder-page .builder-card--compact .selected-model {
  display: grid !important;
  grid-template-columns: 74px minmax(0, 1fr) !important;
  grid-template-rows: auto auto !important;
  gap: 8px 10px !important;
  align-items: start !important;
  width: 100% !important;
  min-height: 96px !important;
  max-height: none !important;
  overflow: hidden !important;
  padding: 9px !important;
  margin: 0 !important;
  border-radius: 14px !important;
}
body.builder-page .builder-card--compact .selected-model__thumb,
body.builder-page .builder-card--compact .selected-model.selected-model--text-only .selected-model__thumb,
body.user-mode.builder-page .builder-card--compact .selected-model__thumb {
  display: flex !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 74px !important;
  height: 74px !important;
  min-width: 74px !important;
  min-height: 74px !important;
  max-width: 74px !important;
  max-height: 74px !important;
  padding: 5px !important;
  border-radius: 12px !important;
}
body.builder-page .selected-model__thumb::before {
  content: "3D";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: rgba(226, 232, 240, .28);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: .08em;
  pointer-events: none;
}
body.builder-page .selected-model__thumb img,
body.builder-page .selected-model__thumb canvas {
  position: relative;
  z-index: 1;
}
body.builder-page .selected-model__meta,
body.builder-page .selected-model--text-only .selected-model__meta {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-width: 0 !important;
  width: 100% !important;
  display: block !important;
  overflow: hidden !important;
}
body.builder-page .selected-model__name,
body.user-mode.builder-page .selected-model__name {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  margin: 0 0 5px !important;
  font-size: 15px !important;
  line-height: 1.18 !important;
  font-weight: 800 !important;
  max-width: 100% !important;
}
body.builder-page .selected-model__subtitle,
body.user-mode.builder-page .selected-model__subtitle {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  margin: 0 !important;
  font-size: 12px !important;
  line-height: 1.3 !important;
  color: var(--muted) !important;
  max-width: 100% !important;
}
body.builder-page .selected-model__details,
body.builder-page .selected-model__thumb-actions,
body.builder-page #selected-model-card .polish-hint {
  grid-column: 1 / -1 !important;
  grid-row: auto !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
}
body.builder-page .selected-model__thumb-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  padding-top: 2px !important;
}
body.builder-page .selected-model__thumb-actions .btn {
  min-height: 30px !important;
  padding: 6px 8px !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
}
body.builder-page #selected-model-card .polish-hint {
  padding: 7px 9px !important;
  border-radius: 10px !important;
  background: rgba(96, 165, 250, .08) !important;
  border: 1px solid rgba(96, 165, 250, .14) !important;
  color: #aebad0 !important;
  font-size: 11px !important;
  line-height: 1.3 !important;
  white-space: normal !important;
}
body.builder-page .builder-card--controls {
  min-height: 0 !important;
}
@media (max-width: 760px) {
  body.builder-page .builder-card--compact .selected-model,
  body.builder-page .builder-card--compact .selected-model.selected-model--text-only {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    min-height: 74px !important;
    gap: 7px !important;
    padding: 7px !important;
  }
  body.builder-page .builder-card--compact .selected-model__thumb,
  body.builder-page .builder-card--compact .selected-model.selected-model--text-only .selected-model__thumb {
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
    min-height: 58px !important;
    max-width: 58px !important;
    max-height: 58px !important;
  }
  body.builder-page .selected-model__name { font-size: 13px !important; }
  body.builder-page .selected-model__subtitle { font-size: 11px !important; -webkit-line-clamp: 2 !important; }
  body.builder-page #selected-model-card .polish-hint { display: none !important; }
}

/* v200: remove selected model ready badge */
.selected-model::after{
  content: none !important;
  display: none !important;
}


/* v201: вернуть размеры прямо на модель + оставить компактный HUD снизу слева */
body.builder-page #viewer-dimensions {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 32 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}
body.builder-page .viewer-dimensions__svg {
  display: block !important;
  opacity: .86 !important;
  position: absolute !important;
  inset: 0 !important;
}
body.builder-page .viewer-dimensions__label {
  display: block !important;
  position: absolute !important;
  transform: translate(-50%, -50%) !important;
  max-width: 132px !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: rgba(9, 12, 18, .78) !important;
  border: 1px solid rgba(226, 232, 240, .32) !important;
  color: #f8fafc !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter: blur(12px) saturate(130%) !important;
  font-size: 11px !important;
  line-height: 1.05 !important;
  font-weight: 800 !important;
  letter-spacing: .02em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  pointer-events: none !important;
}
body.builder-page .viewer-dimensions__line--arrow,
body.builder-page .viewer-dimensions__line,
body.builder-page .viewer-dimensions__tick {
  display: block !important;
  opacity: .95 !important;
}
body[data-theme="light"].builder-page .viewer-dimensions__label {
  background: rgba(255,255,255,.88) !important;
  border-color: rgba(15,23,42,.16) !important;
  color: #0f172a !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.14) !important;
}
@media (max-width: 760px) {
  body.builder-page .viewer-dimensions__label {
    max-width: 104px !important;
    padding: 4px 7px !important;
    font-size: 10px !important;
  }
}

/* v203: hotkey hints are centered inside the 3D viewport */
body.builder-page .viewer-help {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: 18px !important;
  transform: translateX(-50%) !important;
  width: min(620px, calc(100% - 360px)) !important;
  max-width: calc(100% - 360px) !important;
  min-width: 360px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  text-align: center !important;
  z-index: 33 !important;
  pointer-events: none !important;
}
body.builder-page .viewer-help span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 26px !important;
  max-width: none !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  text-align: center !important;
}
@media (max-width: 980px) {
  body.builder-page .viewer-help {
    left: 50% !important;
    right: auto !important;
    bottom: 112px !important;
    transform: translateX(-50%) !important;
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    min-width: 0 !important;
    justify-content: center !important;
  }
}
@media (max-width: 720px) {
  body.builder-page .viewer-help {
    bottom: 104px !important;
    gap: 5px !important;
  }
  body.builder-page .viewer-help span {
    max-width: calc(50% - 6px) !important;
    padding: 5px 8px !important;
    font-size: 10px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  body.builder-page .viewer-help span:nth-child(n+3) {
    display: inline-flex !important;
  }
}


/* v204: аккуратное окно успешной отправки заказа */
body.builder-page #order-success-modal .modal__dialog {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
body.builder-page #order-success-modal .modal__header {
  margin-bottom: 2px !important;
}
body.builder-page #order-success-modal .modal__header p {
  margin-top: 6px !important;
  max-width: 440px !important;
  line-height: 1.45 !important;
}
body.builder-page #order-success-modal .success-card {
  margin-top: 4px !important;
}
body.builder-page #order-success-modal .modal__actions {
  margin-top: 18px !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
  justify-content: center !important;
}
body.builder-page #order-success-modal .modal__actions .btn {
  min-width: 150px !important;
}
body[data-theme="light"].builder-page #order-success-modal .modal__actions {
  border-top-color: rgba(15,23,42,.10) !important;
}


/* === v205: admin viewport alignment + centered draft badge ===
   Fixes admin mode where the 3D model window could visually slide down.
   Keeps the admin toolbar compact and forces the viewer to fill the remaining height. */
body.admin-mode.builder-page {
  width: 100% !important;
  height: 100vh !important;
  height: 100dvh !important;
  min-height: 0 !important;
  max-height: 100vh !important;
  max-height: 100dvh !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 10px !important;
}
body.admin-mode.builder-page .topbar {
  flex: 0 0 auto !important;
  margin-bottom: 8px !important;
  min-height: 56px !important;
}
body.admin-mode.builder-page .admin-toolbar {
  flex: 0 0 auto !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 0 !important;
  max-height: 50px !important;
  margin: 0 0 8px !important;
  padding: 7px 8px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  border-radius: 16px !important;
  scrollbar-width: thin !important;
}
body.admin-mode.builder-page .admin-toolbar__btn {
  flex: 0 0 auto !important;
  min-height: 34px !important;
  height: 34px !important;
  padding: 0 11px !important;
  border-radius: 11px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}
body.admin-mode.builder-page .maker-layout--builder {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(320px, 380px) minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: stretch !important;
}
body.admin-mode.builder-page .builder-sidebar {
  order: 1 !important;
  position: relative !important;
  top: auto !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
body.admin-mode.builder-page .builder-stage {
  order: 2 !important;
  position: relative !important;
  top: auto !important;
  align-self: stretch !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
}
body.admin-mode.builder-page .viewer-card--builder,
body.admin-mode.builder-page .viewer-card,
body.admin-mode.builder-page #viewer {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
}
body.admin-mode.builder-page .model-card {
  flex: 0 0 auto !important;
  max-height: 385px !important;
  overflow: hidden !important;
}
body.admin-mode.builder-page .builder-card--controls {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
body.admin-mode.builder-page #dynamic-form {
  flex: 1 1 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
body.admin-mode.builder-page .summary-stack,
body.admin-mode.builder-page .summary-actions,
body.admin-mode.builder-page .print-preflight-panel {
  display: none !important;
}

/* Center the “Черновик сохранён” pill as a neat floating status, not mixed with the buttons. */
body.builder-page .viewer-toolbar {
  overflow: visible !important;
}
body.builder-page .viewer-toolbar__draft {
  position: absolute !important;
  left: 50% !important;
  top: 42px !important;
  transform: translateX(-50%) !important;
  z-index: 36 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 148px !important;
  max-width: min(260px, calc(100% - 32px)) !important;
  height: 30px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  text-align: center !important;
  font-size: 12px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  background: rgba(9, 12, 18, .78) !important;
  border: 1px solid rgba(148, 163, 184, .25) !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.22) !important;
  backdrop-filter: blur(14px) saturate(130%) !important;
  pointer-events: none !important;
}
body.builder-page .viewer-toolbar__draft.hidden {
  display: none !important;
}
body.builder-page .viewer-toolbar__draft.is-saved {
  color: #a7f3d0 !important;
  border-color: rgba(34, 197, 94, .35) !important;
}
body.builder-page .viewer-toolbar__draft.is-saving {
  color: #fde68a !important;
  border-color: rgba(245, 158, 11, .35) !important;
}
body.builder-page .viewer-toolbar__draft.is-muted {
  color: #cbd5e1 !important;
}
body[data-theme="light"].builder-page .viewer-toolbar__draft {
  background: rgba(255,255,255,.88) !important;
  color: #334155 !important;
  border-color: rgba(15,23,42,.14) !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.12) !important;
}
body[data-theme="light"].builder-page .viewer-toolbar__draft.is-saved { color: #166534 !important; }
body[data-theme="light"].builder-page .viewer-toolbar__draft.is-saving { color: #92400e !important; }

@media (max-width: 1180px) and (min-width: 761px) {
  body.admin-mode.builder-page .maker-layout--builder {
    grid-template-columns: minmax(300px, 350px) minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }
}
@media (max-width: 760px) {
  body.admin-mode.builder-page {
    overflow: hidden !important;
  }
  body.admin-mode.builder-page .admin-toolbar {
    max-height: 44px !important;
    padding: 6px !important;
    margin-bottom: 7px !important;
  }
  body.admin-mode.builder-page .maker-layout--builder {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 44%) minmax(0, 56%) !important;
    gap: 8px !important;
  }
  body.admin-mode.builder-page .builder-stage { order: 1 !important; }
  body.admin-mode.builder-page .builder-sidebar { order: 2 !important; }
  body.builder-page .viewer-toolbar__draft {
    top: 38px !important;
    height: 28px !important;
    min-width: 136px !important;
    font-size: 11px !important;
  }
}

/* v206 — password reset UI */
.auth-help-row {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: -6px;
  margin-bottom: 2px;
}
.auth-forgot-link {
  color: var(--accent, #7dd3fc);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
}
.auth-forgot-link:hover { text-decoration: underline; }
.auth-page--compact-reset {
  min-height: calc(100vh - 80px);
  display: grid;
  place-items: center;
  padding: 24px;
}
.auth-shell--single {
  width: min(460px, 100%);
  display: block;
}
.auth-card--reset {
  width: 100%;
  max-width: 460px;
  padding: 24px;
}
.auth-card__top--center {
  justify-content: center;
  text-align: left;
  margin-bottom: 16px;
}
.auth-form--reset {
  gap: 12px;
}
.reset-link-card {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgba(125, 211, 252, .28);
  border-radius: 16px;
  background: rgba(125, 211, 252, .08);
  display: grid;
  gap: 10px;
}
.reset-link-card--error {
  border-color: rgba(248, 113, 113, .32);
  background: rgba(248, 113, 113, .08);
}
.reset-link-card__title {
  font-weight: 900;
  letter-spacing: -.02em;
}
.reset-link-card p {
  margin: 0;
  color: var(--muted, #94a3b8);
  font-size: 13px;
  line-height: 1.45;
}
.reset-link-card__input {
  font-size: 12px;
  padding: 9px 10px;
}


/* v207: modules/assembly feature fully removed from UI */
#open-assembly-modal-btn,
#close-assembly-modal-btn,
#assembly-section-card,
.assembly-card,
.assembly-library,
.assembly-list,
.assembly-transform,
.assembly-section-builder,
.assembly-smart-snap,
[data-scroll-target="assembly-section-card"] {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}


/* v209 — final cleanup: silent drafts, wider order modal, no material wording in UI */
body.builder-page .viewer-toolbar__draft,
body.builder-page .viewer-toolbar__draft.hidden,
.viewer-toolbar__draft,
#draft-status-pill {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
.material-ui-hidden,
#checkout-material-badge,
#checkout-material-help,
#checkout-material-select,
#checkout-material-select + *,
label:has(#checkout-material-select) {
  display: none !important;
}
#checkout-material-panel {
  padding: 12px !important;
  margin-top: 8px !important;
}
#checkout-material-panel .checkout-material-panel__head {
  margin-bottom: 10px !important;
}
#checkout-material-panel .checkout-material-grid {
  grid-template-columns: 1fr !important;
}
#admin-orders-modal .modal__dialog--admin-window,
#admin-orders-modal .modal__dialog--admin-wide {
  width: min(1560px, calc(100vw - 20px)) !important;
  max-width: calc(100vw - 20px) !important;
  max-height: calc(100vh - 20px) !important;
  overflow: hidden !important;
  padding: 16px !important;
}
#admin-orders-modal .admin-window__body {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  max-height: calc(100vh - 112px) !important;
  overflow: hidden !important;
}
#admin-orders-modal .orders-toolbar {
  display: grid !important;
  grid-template-columns: minmax(280px, 1.4fr) repeat(3, minmax(138px, .5fr)) auto auto !important;
  gap: 8px !important;
  align-items: center !important;
  flex: 0 0 auto !important;
}
#admin-orders-modal .orders-stats {
  flex: 0 0 auto !important;
}
#admin-orders-modal #orders-list,
#admin-orders-modal .request-list--orders {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 8px !important;
  scroll-behavior: smooth;
}
#admin-orders-modal .order-card {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
}
#admin-orders-modal .order-card__head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
}
#admin-orders-modal .order-card__grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}
#admin-orders-modal .order-card__actions {
  align-items: end !important;
  justify-content: flex-start !important;
}
#admin-orders-modal .order-card__quick-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
#admin-orders-modal .order-admin-manage {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  align-items: end !important;
}
#admin-orders-modal .order-admin-manage__note,
#admin-orders-modal .order-admin-checklist {
  grid-column: 1 / -1 !important;
}
#admin-orders-modal .order-admin-checklist {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
#admin-orders-modal .order-admin-manage .btn {
  justify-self: start !important;
}
@media (max-width: 1120px) {
  #admin-orders-modal .orders-toolbar { grid-template-columns: 1fr 1fr !important; }
  #admin-orders-modal .orders-toolbar .input:first-child { grid-column: 1 / -1 !important; }
  #admin-orders-modal .order-card__grid,
  #admin-orders-modal .order-admin-manage,
  #admin-orders-modal .order-admin-checklist { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 680px) {
  #admin-orders-modal .modal__dialog--admin-window,
  #admin-orders-modal .modal__dialog--admin-wide { width: calc(100vw - 10px) !important; max-width: calc(100vw - 10px) !important; padding: 12px !important; }
  #admin-orders-modal .orders-toolbar,
  #admin-orders-modal .order-card__grid,
  #admin-orders-modal .order-admin-manage,
  #admin-orders-modal .order-admin-checklist { grid-template-columns: 1fr !important; }
  #admin-orders-modal .order-card__head { grid-template-columns: 1fr !important; }
  #admin-orders-modal .order-card__price { white-space: normal !important; }
}

/* v210 — нормализация окна «Мои дизайны» */
#saved-designs-modal {
  z-index: 160 !important;
}
#saved-designs-modal .modal__dialog--saved-designs {
  width: min(1040px, calc(100vw - 24px)) !important;
  max-width: calc(100vw - 24px) !important;
  height: min(82vh, 760px) !important;
  max-height: calc(100vh - 24px) !important;
  display: grid !important;
  grid-template-rows: auto auto auto minmax(0, 1fr) !important;
  gap: 12px !important;
  overflow: hidden !important;
  padding: 16px !important;
  box-sizing: border-box !important;
}
#saved-designs-modal .modal__header {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  gap: 14px !important;
  margin: 0 !important;
  padding: 0 0 10px !important;
  border-bottom: 1px solid rgba(148, 163, 184, .18) !important;
}
#saved-designs-modal .modal__header h2 {
  margin: 0 !important;
  font-size: 21px !important;
  line-height: 1.15 !important;
  letter-spacing: -.03em !important;
}
#saved-designs-modal .modal__header p {
  margin: 4px 0 0 !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: var(--muted, #94a3b8) !important;
}
#saved-designs-modal .modal__close {
  width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 !important;
  flex: 0 0 auto !important;
}
#saved-designs-modal .cloud-projects-panel {
  display: grid !important;
  gap: 10px !important;
  min-width: 0 !important;
}
#saved-designs-modal .cloud-projects-stats {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  min-width: 0 !important;
}
#saved-designs-modal .cloud-projects-stat {
  min-width: 0 !important;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  overflow: hidden !important;
}
#saved-designs-modal .cloud-projects-stat b {
  font-size: 16px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
#saved-designs-modal .cloud-projects-stat span {
  font-size: 11px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
#saved-designs-modal .cloud-projects-controls {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 210px !important;
  gap: 8px !important;
  min-width: 0 !important;
}
#saved-designs-modal .cloud-projects-controls .input,
#saved-designs-modal .saved-designs-toolbar .btn {
  min-height: 36px !important;
  height: 36px !important;
  font-size: 12px !important;
  border-radius: 12px !important;
}
#saved-designs-modal .saved-designs-toolbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 0 !important;
}
#saved-designs-modal .saved-designs-toolbar .btn {
  padding: 0 12px !important;
  white-space: nowrap !important;
}
#saved-designs-modal #saved-designs-list.saved-designs-list {
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 2px 6px 2px 0 !important;
  display: grid !important;
  gap: 10px !important;
  align-content: start !important;
  scrollbar-width: thin !important;
}
#saved-designs-modal .saved-designs-empty {
  min-height: 120px !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}
#saved-designs-modal .saved-design-card {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: start !important;
  padding: 13px !important;
  border-radius: 18px !important;
  overflow: hidden !important;
}
#saved-designs-modal .saved-design-card > div:first-child {
  min-width: 0 !important;
}
#saved-designs-modal .saved-design-card__title {
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
}
#saved-designs-modal .saved-design-card__meta {
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 11px !important;
}
#saved-designs-modal .saved-design-card__status {
  margin: 7px 0 0 !important;
  padding: 4px 9px !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
}
#saved-designs-modal .saved-design-card__params {
  max-width: 100% !important;
  margin-top: 8px !important;
  padding: 8px 10px !important;
  border-radius: 12px !important;
  background: rgba(15, 23, 42, .34) !important;
  border: 1px solid rgba(148, 163, 184, .14) !important;
  font-size: 11px !important;
  line-height: 1.4 !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  max-height: 70px !important;
  overflow-y: auto !important;
}
body.light #saved-designs-modal .saved-design-card__params,
body[data-theme="light"] #saved-designs-modal .saved-design-card__params {
  background: rgba(241, 245, 249, .76) !important;
  border-color: rgba(15, 23, 42, .09) !important;
}
#saved-designs-modal .saved-design-card__actions {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  justify-content: stretch !important;
  align-items: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
}
#saved-designs-modal .saved-design-card__action-group {
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(78px, 1fr)) !important;
  gap: 6px !important;
  padding: 8px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(148, 163, 184, .14) !important;
  background: rgba(2, 6, 23, .18) !important;
}
#saved-designs-modal .saved-design-card__action-group--main {
  background: rgba(37, 99, 235, .11) !important;
  border-color: rgba(96, 165, 250, .22) !important;
}
#saved-designs-modal .saved-design-card__action-group--danger {
  background: rgba(15, 23, 42, .12) !important;
}
#saved-designs-modal .saved-design-card__actions .btn {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 32px !important;
  height: 32px !important;
  padding: 0 8px !important;
  font-size: 11px !important;
  line-height: 1 !important;
  border-radius: 10px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  justify-content: center !important;
  transform: none !important;
}
#saved-designs-modal .saved-design-card__actions .btn[disabled] {
  opacity: .45 !important;
}
@media (max-width: 980px) {
  #saved-designs-modal .modal__dialog--saved-designs {
    width: min(96vw, 820px) !important;
    height: min(86vh, 760px) !important;
  }
  #saved-designs-modal .cloud-projects-controls {
    grid-template-columns: 1fr !important;
  }
  #saved-designs-modal .saved-design-card__actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 620px) {
  #saved-designs-modal .modal__dialog--saved-designs {
    width: calc(100vw - 12px) !important;
    max-width: calc(100vw - 12px) !important;
    height: calc(100vh - 12px) !important;
    max-height: calc(100vh - 12px) !important;
    padding: 12px !important;
    gap: 10px !important;
  }
  #saved-designs-modal .cloud-projects-stats {
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 6px !important;
  }
  #saved-designs-modal .cloud-projects-stat {
    padding: 8px 7px !important;
    text-align: center !important;
  }
  #saved-designs-modal .saved-designs-toolbar {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }
  #saved-designs-modal .saved-designs-toolbar .btn {
    width: 100% !important;
    padding-inline: 8px !important;
  }
  #saved-designs-modal .saved-design-card__actions {
    grid-template-columns: 1fr !important;
  }
}

/* v214 — Ozon Pay order lock */
.btn--ozon-pay{
  background: linear-gradient(135deg,#005bff,#1d4ed8) !important;
  color:#fff !important;
  border-color: transparent !important;
  box-shadow: 0 10px 26px rgba(0,91,255,.22);
  text-decoration:none !important;
}
.success-card__pay{ margin:14px 0 10px; display:flex; justify-content:center; }
.request-card__meta--warning{ color:#a16207; background:#fffbeb; border:1px solid #fde68a; border-radius:12px; padding:8px 10px; }
.order-card--payment-locked{ border-color:#fbbf24 !important; background:linear-gradient(180deg,#fff,#fffbeb); }
.order-payment-lock{ margin:8px 0; padding:9px 11px; border-radius:14px; border:1px solid #fde68a; background:#fffbeb; color:#92400e; font-size:12px; font-weight:800; line-height:1.35; }
.order-payment-lock--wide{ font-size:13px; margin:10px 0 12px; }
.order-badge--payment-lock{ background:#fef3c7 !important; color:#92400e !important; border-color:#fde68a !important; }
.btn--danger{ color:#b91c1c !important; border-color:#fecaca !important; background:#fff5f5 !important; }
.btn--danger:hover{ background:#fee2e2 !important; }
.order-card--payment-locked .order-status-select select:disabled{ opacity:.7; cursor:not-allowed; background:#f8fafc; }
.customer-order-card__actions{ display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.orders-board-card .btn--danger{ padding-inline:10px; }


/* v215 — скрытие материала и русификация видимых блоков */
.material-ui-hidden,
#checkout-material-select,
#checkout-material-badge,
#checkout-material-help,
[data-order-material],
.order-material,
.admin-material-row { display: none !important; }

/* v218 — чистовая стабилизация интерфейса */
.selected-model::after { content: none !important; display: none !important; }
#draft-status-pill, .viewer-toolbar__draft { display: none !important; }
.assembly-card, .assembly-panel, .assembly-library, .assembly-list, #assembly-section-card, #open-assembly-modal-btn { display: none !important; }
.material-ui-hidden, #checkout-material-panel, #checkout-material-select, #checkout-material-badge, #checkout-material-help, [data-order-material], .order-material, .admin-material-row { display: none !important; }
.viewer-dimensions__label { white-space: nowrap; }
.modal__dialog { overflow: hidden; }
.modal__body, .admin-window__body { overflow: auto; }

/* v225: human-readable order parameters instead of raw JSON */
.order-param-list--full {
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(125,140,170,.08);
  border: 1px solid rgba(125,140,170,.16);
  max-height: 320px;
  overflow: auto;
}
.order-param-list--full span {
  line-height: 1.35;
}
.order-param-list--full b {
  line-height: 1.35;
  word-break: break-word;
}
body.dark .order-param-list--full,
.theme-dark .order-param-list--full {
  background: rgba(255,255,255,.055);
  border-color: rgba(255,255,255,.10);
}


/* v231: отдельные страницы документов должны прокручиваться полностью.
   Раньше privacy/consent наследовали body.user-mode { overflow:hidden; height:100vh; },
   из-за чего нижняя часть согласия на обработку персональных данных могла быть недоступна. */
body.user-mode.document-page {
  height: auto !important;
  min-height: 100vh !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  display: block !important;
  padding: 14px;
}
body.user-mode.document-page .flash-stack {
  display: block !important;
}
body.user-mode.document-page .topbar {
  position: static !important;
  margin-bottom: 16px;
}
body.user-mode.document-page .doc-page {
  min-height: auto;
  padding: 22px 0 40px;
  overflow: visible;
}
body.user-mode.document-page .doc-card {
  max-height: none;
  overflow: visible;
}
body.user-mode.document-page .doc-section p {
  white-space: normal;
  overflow-wrap: anywhere;
}
@media (max-width: 760px) {
  body.user-mode.document-page {
    padding: 8px;
  }
  body.user-mode.document-page .doc-page {
    padding: 12px 0 28px;
  }
  body.user-mode.document-page .doc-card {
    padding: 16px;
    border-radius: 18px;
  }
  body.user-mode.document-page .doc-card h1 {
    font-size: 24px;
    line-height: 1.15;
  }
  body.user-mode.document-page .doc-section h2 {
    font-size: 17px;
  }
}


/* v232: прокрутка юридических документов и окон согласия.
   Исправляет случай, когда ссылка "Согласие · Политика" открывается,
   но документ или модальное окно нельзя прокрутить вниз. */
html.document-page {
  height: auto !important;
  min-height: 100% !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
}
body.document-page,
body.user-mode.document-page {
  position: static !important;
  height: auto !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  display: block !important;
  touch-action: auto !important;
  -webkit-overflow-scrolling: touch;
}
body.document-page .doc-actions {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 16px;
}
body.document-page .doc-card {
  max-height: none !important;
  overflow: visible !important;
}
body.document-page .doc-page {
  height: auto !important;
  min-height: auto !important;
  overflow: visible !important;
  padding-bottom: 72px !important;
}

/* В режиме конструктора сама страница фиксированная, поэтому прокрутку
   обязательно отдаём открытому окну и его форме. */
body.user-mode.builder-page .modal {
  overflow-y: auto !important;
  align-items: start !important;
  place-items: start center !important;
  padding: 12px !important;
  -webkit-overflow-scrolling: touch;
}
body.user-mode.builder-page .modal__dialog,
body.user-mode.builder-page #customer-auth-modal .modal__dialog,
body.user-mode.builder-page #order-modal .modal__dialog,
body.user-mode.builder-page #customer-profile-modal .modal__dialog,
body.user-mode.builder-page #my-orders-modal .modal__dialog {
  max-height: calc(100vh - 24px) !important;
  max-height: calc(100dvh - 24px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
}
body.user-mode.builder-page #customer-auth-modal .form-stack,
body.user-mode.builder-page #order-modal .checkout-form {
  min-height: 0 !important;
  overflow: visible !important;
}
@media (max-width: 760px) {
  body.user-mode.builder-page .modal {
    padding: 8px !important;
  }
  body.user-mode.builder-page .modal__dialog,
  body.user-mode.builder-page #customer-auth-modal .modal__dialog,
  body.user-mode.builder-page #order-modal .modal__dialog {
    width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
  }
}


/* === v242: мобильная версия конструктора без перекрытия окна модели ===
   На телефоне 3D-окно остаётся чистым: все панели, цена, палитра и джойстик
   выводятся отдельными блоками вокруг viewport, а не поверх модели. */
@media (max-width: 760px) {
  html,
  body.builder-page,
  body.user-mode.builder-page,
  body.admin-mode.builder-page {
    height: auto !important;
    max-height: none !important;
    min-height: 100svh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    display: block !important;
    padding: 8px !important;
    touch-action: manipulation !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.builder-page .topbar {
    position: sticky !important;
    top: 0 !important;
    z-index: 90 !important;
    margin-bottom: 8px !important;
    border-radius: 16px !important;
  }

  body.builder-page .maker-layout--builder {
    display: flex !important;
    flex-direction: column !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    gap: 10px !important;
  }

  body.builder-page .builder-stage,
  body.builder-page .builder-sidebar {
    position: relative !important;
    top: auto !important;
    order: initial !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.builder-page .builder-stage { order: 1 !important; }
  body.builder-page .builder-sidebar { order: 2 !important; gap: 10px !important; }

  body.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-areas:
      "tools"
      "colors"
      "viewer"
      "price"
      "rotate"
      "sizes"
      "help" !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 0 !important;
    border-radius: 18px !important;
    background: #0b0f16 !important;
  }

  body.builder-page .viewer-toolbar {
    grid-area: tools !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: block !important;
    width: auto !important;
    max-width: none !important;
    padding: 8px !important;
    margin: 0 !important;
    border-radius: 18px 18px 0 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    background: rgba(15, 20, 30, .98) !important;
    overflow: hidden !important;
  }

  body.builder-page .viewer-toolbar__left { display: none !important; }

  body.builder-page .viewer-toolbar__right {
    width: 100% !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 0 0 2px !important;
    scrollbar-width: thin !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.builder-page .viewer-toolbar__btn,
  body.builder-page .viewer-toolbar__pill {
    flex: 0 0 auto !important;
    min-height: 34px !important;
    height: 34px !important;
    padding: 8px 10px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  body.builder-page .viewer-toolbar__draft,
  body.builder-page .viewer-toolbar__draft.hidden {
    display: none !important;
  }

  body.builder-page .viewer-color-palette {
    grid-area: colors !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    width: auto !important;
    max-width: none !important;
    margin: 8px !important;
    padding: 8px 10px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.06) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    backdrop-filter: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.builder-page .viewer-color-palette::before {
    content: 'Цвет';
    flex: 0 0 auto;
    margin-right: 2px;
    color: rgba(226,232,240,.86);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .02em;
  }

  body.builder-page .viewer-color-palette .color-swatch {
    flex: 0 0 auto !important;
    width: 22px !important;
    height: 22px !important;
    min-width: 22px !important;
    min-height: 22px !important;
  }

  body.builder-page #viewer {
    grid-area: viewer !important;
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: clamp(310px, 54svh, 520px) !important;
    min-height: 310px !important;
    max-height: 520px !important;
    overflow: hidden !important;
    border-top: 1px solid rgba(255,255,255,.06) !important;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
    border-radius: 0 !important;
  }

  body.builder-page #viewer canvas {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
  }

  /* На телефоне линии/плашки размеров не кладём поверх модели. Точные размеры ниже отдельным блоком. */
  body.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions,
  body.builder-page .viewer-dimensions__svg,
  body.builder-page .viewer-dimensions__label {
    display: none !important;
  }

  body.builder-page .viewer-badge { display: none !important; }

  body.builder-page .viewer-order-overlay {
    grid-area: price !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px 10px !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    max-height: none !important;
    margin: 8px !important;
    padding: 10px !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.07) !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    box-shadow: none !important;
    overflow: visible !important;
    backdrop-filter: none !important;
  }

  body.builder-page .viewer-order-overlay__label {
    grid-column: 1 / -1 !important;
    display: block !important;
    margin: 0 !important;
    color: rgba(226,232,240,.70) !important;
    font-size: 10px !important;
    line-height: 1 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
  }

  body.builder-page .viewer-order-overlay__value {
    margin: 0 !important;
    font-size: 23px !important;
    line-height: 1 !important;
  }

  body.builder-page .viewer-order-overlay__hint,
  body.builder-page .price-breakdown--compact {
    display: none !important;
  }

  body.builder-page .viewer-order-overlay__button {
    width: auto !important;
    min-width: 132px !important;
    height: 38px !important;
    min-height: 38px !important;
    margin: 0 !important;
    padding: 10px 13px !important;
    border-radius: 12px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
  }

  body.builder-page .viewer-rotation-control {
    grid-area: rotate !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    width: auto !important;
    margin: 0 8px 8px !important;
    padding: 10px 12px !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    background: rgba(255,255,255,.055) !important;
    box-shadow: none !important;
  }

  body.builder-page .viewer-rotation-control::before {
    content: 'Поворот модели';
    color: rgba(226,232,240,.86);
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
  }

  body.builder-page .viewer-joystick {
    flex: 0 0 auto !important;
    width: 70px !important;
    height: 70px !important;
    box-shadow: none !important;
  }

  body.builder-page .viewer-joystick__pad { inset: 11px !important; }
  body.builder-page .viewer-joystick__knob {
    width: 22px !important;
    height: 22px !important;
    margin-left: -11px !important;
    margin-top: -11px !important;
  }

  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    grid-area: sizes !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: block !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 8px 8px !important;
    padding: 10px !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.055) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: none !important;
    pointer-events: auto !important;
    backdrop-filter: none !important;
  }

  body.builder-page .dimension-hud__title {
    display: block !important;
    margin: 0 0 8px !important;
    color: rgba(226,232,240,.76) !important;
    font-size: 11px !important;
    text-align: left !important;
  }

  body.builder-page .dimension-hud__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  body.builder-page .dimension-hud__grid div {
    padding: 8px 5px !important;
    border-radius: 12px !important;
    text-align: center !important;
    background: rgba(255,255,255,.045) !important;
  }

  body.builder-page .viewer-help {
    grid-area: help !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 6px !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 8px 10px !important;
    pointer-events: none !important;
  }

  body.builder-page .viewer-help span {
    display: inline-flex !important;
    align-items: center !important;
    max-width: none !important;
    min-height: 24px !important;
    padding: 5px 8px !important;
    border-radius: 999px !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
  }

  body.builder-page .builder-card--compact,
  body.builder-page .builder-card--controls {
    border-radius: 18px !important;
    overflow: visible !important;
  }

  body.builder-page .builder-card--compact .selected-model,
  body.builder-page .builder-card--compact .selected-model.selected-model--text-only {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    min-height: 74px !important;
    gap: 8px !important;
    padding: 7px !important;
  }

  body.builder-page .builder-card--compact .selected-model__thumb,
  body.builder-page .builder-card--compact .selected-model.selected-model--text-only .selected-model__thumb {
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
    min-height: 58px !important;
    max-width: 58px !important;
    max-height: 58px !important;
  }

  body.builder-page .builder-card--controls,
  body.builder-page .dynamic-form--builder,
  body.builder-page #dynamic-form {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.builder-page .form-group--builder {
    padding: 12px !important;
    border-radius: 16px !important;
  }

  body.builder-page .customize-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 10px !important;
  }

  body.builder-page .customize-actions .btn {
    width: 100% !important;
    min-height: 42px !important;
  }

  body[data-theme="light"].builder-page .viewer-card--builder {
    background: #f8fafc !important;
  }
  body[data-theme="light"].builder-page .viewer-toolbar,
  body[data-theme="light"].builder-page .viewer-color-palette,
  body[data-theme="light"].builder-page .viewer-order-overlay,
  body[data-theme="light"].builder-page .viewer-rotation-control,
  body[data-theme="light"].builder-page .dimension-hud {
    background: rgba(255,255,255,.94) !important;
    border-color: rgba(15,23,42,.10) !important;
    color: #0f172a !important;
  }
  body[data-theme="light"].builder-page .viewer-color-palette::before,
  body[data-theme="light"].builder-page .viewer-rotation-control::before,
  body[data-theme="light"].builder-page .dimension-hud__title {
    color: #334155 !important;
  }
}

@media (max-width: 420px) {
  body.builder-page #viewer {
    height: clamp(290px, 50svh, 460px) !important;
    min-height: 290px !important;
  }
  body.builder-page .viewer-order-overlay {
    grid-template-columns: 1fr !important;
  }
  body.builder-page .viewer-order-overlay__button {
    width: 100% !important;
  }
  body.builder-page .viewer-help span:nth-child(n+3) {
    display: none !important;
  }
}

/* === v243: абсолютная адаптация интерфейса + чистое окно 3D-модели ===
   На всех ширинах экрана кнопки, цена, цвет, джойстик и размеры находятся
   вокруг viewer, а не поверх canvas. Это защищает 3D-окно на телефоне,
   планшете, ноутбуке, широком мониторе и в низкой landscape-ориентации. */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body.builder-page { overflow-x: hidden !important; }
body.builder-page button,
body.builder-page input,
body.builder-page select,
body.builder-page textarea { font: inherit; }
body.builder-page .topbar {
  width: min(100%, calc(100vw - 16px));
  margin-inline: auto;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
body.builder-page .topbar__actions,
body.builder-page .customer-topbar__guest,
body.builder-page .customer-topbar__auth {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  min-width: 0 !important;
}
body.builder-page .topbar .btn,
body.builder-page .topbar-icon-btn {
  min-height: 38px !important;
  white-space: nowrap !important;
}
body.builder-page .admin-toolbar {
  width: min(100%, calc(100vw - 16px)) !important;
  margin-inline: auto !important;
  display: flex !important;
  gap: 8px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scrollbar-width: thin !important;
  -webkit-overflow-scrolling: touch !important;
}
body.builder-page .admin-toolbar__btn { flex: 0 0 auto !important; }

@media (min-width: 1181px) {
  body.builder-page,
  body.user-mode.builder-page,
  body.admin-mode.builder-page {
    height: 100dvh !important;
    max-height: 100dvh !important;
    overflow: hidden !important;
    padding: 8px !important;
  }
  body.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: clamp(320px, 27vw, 410px) minmax(0, 1fr) !important;
    gap: 12px !important;
    width: 100% !important;
    height: calc(100dvh - 92px) !important;
    min-height: 0 !important;
    max-height: calc(100dvh - 92px) !important;
    overflow: hidden !important;
    padding: 0 !important;
  }
  body.admin-mode.builder-page .maker-layout--builder {
    height: calc(100dvh - 146px) !important;
    max-height: calc(100dvh - 146px) !important;
  }
  body.builder-page .builder-sidebar,
  body.builder-page .builder-stage {
    min-height: 0 !important;
    max-height: 100% !important;
  }
  body.builder-page .builder-sidebar {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 2px !important;
    -webkit-overflow-scrolling: touch !important;
  }
  body.builder-page .builder-stage {
    overflow: hidden !important;
  }
}

/* Единая сетка viewer для всех не совсем маленьких экранов */
@media (min-width: 981px) {
  body.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) clamp(230px, 22vw, 320px) !important;
    grid-template-areas:
      "tools tools"
      "viewer colors"
      "viewer price"
      "viewer rotate"
      "viewer sizes"
      "help help" !important;
    grid-template-rows: auto auto auto auto minmax(0, 1fr) auto !important;
    gap: 10px !important;
    height: 100% !important;
    min-height: 0 !important;
    max-height: 100% !important;
    overflow: hidden !important;
    padding: 10px !important;
  }
  body.builder-page .viewer-toolbar {
    grid-area: tools !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: hidden !important;
  }
  body.builder-page .viewer-toolbar__left { display: none !important; }
  body.builder-page .viewer-toolbar__right {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 2px 2px 6px !important;
    scrollbar-width: thin !important;
    -webkit-overflow-scrolling: touch !important;
  }
  body.builder-page .viewer-toolbar__btn,
  body.builder-page .viewer-toolbar__pill {
    flex: 0 0 auto !important;
    min-height: 36px !important;
    white-space: nowrap !important;
  }
  body.builder-page #viewer {
    grid-area: viewer !important;
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 420px !important;
    max-height: none !important;
    overflow: hidden !important;
    border-radius: 20px !important;
  }
  body.builder-page #viewer canvas {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
  }
  body.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.builder-page .dimension-hud,
  body.builder-page .viewer-help {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
  }
  body.builder-page .viewer-color-palette { grid-area: colors !important; display: flex !important; flex-wrap: wrap !important; align-content: flex-start !important; gap: 8px !important; padding: 12px !important; }
  body.builder-page .viewer-order-overlay { grid-area: price !important; display: grid !important; gap: 8px !important; padding: 14px !important; }
  body.builder-page .viewer-rotation-control { grid-area: rotate !important; display: flex !important; justify-content: space-between !important; align-items: center !important; gap: 12px !important; padding: 12px !important; }
  body.builder-page .dimension-hud { grid-area: sizes !important; display: block !important; overflow: auto !important; padding: 12px !important; }
  body.builder-page .viewer-help { grid-area: help !important; display: flex !important; flex-wrap: wrap !important; justify-content: center !important; gap: 7px !important; pointer-events: none !important; }
  body.builder-page .viewer-badge { display: none !important; }
  body.builder-page .viewer-dimensions,
  body.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions__svg,
  body.builder-page .viewer-dimensions__label { display: none !important; }
}

@media (min-width: 1181px) and (max-width: 1380px) {
  body.builder-page .viewer-card--builder {
    grid-template-columns: minmax(0, 1fr) 260px !important;
    gap: 8px !important;
  }
  body.builder-page .viewer-toolbar__btn { padding-inline: 10px !important; font-size: 12px !important; }
  body.builder-page .viewer-order-overlay__value { font-size: 25px !important; }
}

@media (max-width: 1180px) {
  body.builder-page,
  body.user-mode.builder-page,
  body.admin-mode.builder-page {
    height: auto !important;
    max-height: none !important;
    min-height: 100svh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    display: block !important;
    padding: 8px !important;
    -webkit-overflow-scrolling: touch !important;
  }
  body.builder-page .maker-layout--builder {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    height: auto !important;
    max-height: none !important;
    min-height: 0 !important;
    overflow: visible !important;
    padding: 0 !important;
  }
  body.builder-page .builder-stage { order: 1 !important; overflow: visible !important; }
  body.builder-page .builder-sidebar { order: 2 !important; overflow: visible !important; }
  body.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-areas:
      "tools"
      "colors"
      "viewer"
      "price"
      "rotate"
      "sizes"
      "help" !important;
    grid-template-rows: auto auto auto auto auto auto auto !important;
    gap: 8px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 8px !important;
  }
  body.builder-page #viewer {
    grid-area: viewer !important;
    position: relative !important;
    height: clamp(340px, 58svh, 620px) !important;
    min-height: 340px !important;
    overflow: hidden !important;
    border-radius: 18px !important;
  }
  body.builder-page .viewer-toolbar { grid-area: tools !important; position: static !important; inset: auto !important; transform: none !important; display: block !important; width: 100% !important; margin: 0 !important; padding: 0 !important; background: transparent !important; box-shadow: none !important; }
  body.builder-page .viewer-toolbar__right { display: flex !important; flex-wrap: nowrap !important; gap: 7px !important; overflow-x: auto !important; overflow-y: hidden !important; padding-bottom: 4px !important; scrollbar-width: thin !important; -webkit-overflow-scrolling: touch !important; }
  body.builder-page .viewer-toolbar__left { display: none !important; }
  body.builder-page .viewer-toolbar__btn { flex: 0 0 auto !important; white-space: nowrap !important; }
  body.builder-page .viewer-color-palette { grid-area: colors !important; position: static !important; display: flex !important; width: 100% !important; overflow-x: auto !important; overflow-y: hidden !important; margin: 0 !important; }
  body.builder-page .viewer-order-overlay { grid-area: price !important; position: static !important; width: 100% !important; margin: 0 !important; }
  body.builder-page .viewer-rotation-control { grid-area: rotate !important; position: static !important; width: 100% !important; margin: 0 !important; }
  body.builder-page .dimension-hud { grid-area: sizes !important; position: static !important; width: 100% !important; margin: 0 !important; display: block !important; }
  body.builder-page .viewer-help { grid-area: help !important; position: static !important; display: flex !important; flex-wrap: wrap !important; justify-content: center !important; width: 100% !important; margin: 0 !important; }
  body.builder-page .viewer-badge,
  body.builder-page .viewer-dimensions,
  body.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions__svg,
  body.builder-page .viewer-dimensions__label { display: none !important; }
}

@media (max-width: 760px) {
  body.builder-page { padding: 6px !important; }
  body.builder-page .topbar {
    position: sticky !important;
    top: 0 !important;
    z-index: 80 !important;
    border-radius: 16px !important;
    padding: 8px !important;
    gap: 8px !important;
  }
  body.builder-page .brand { min-width: 0 !important; }
  body.builder-page .brand__title { font-size: 14px !important; }
  body.builder-page .brand__subtitle { display: none !important; }
  body.builder-page .brand__mark { width: 34px !important; height: 34px !important; min-width: 34px !important; }
  body.builder-page .topbar__actions { width: 100% !important; justify-content: flex-start !important; overflow-x: auto !important; flex-wrap: nowrap !important; padding-bottom: 2px !important; }
  body.builder-page .customer-topbar,
  body.builder-page .customer-topbar__guest,
  body.builder-page .customer-topbar__auth { width: auto !important; flex-wrap: nowrap !important; }
  body.builder-page .topbar .btn,
  body.builder-page .topbar-icon-btn { flex: 0 0 auto !important; min-height: 34px !important; height: 34px !important; padding: 8px 10px !important; font-size: 12px !important; }
  body.builder-page .viewer-card--builder { border-radius: 18px !important; padding: 8px !important; gap: 8px !important; }
  body.builder-page #viewer { height: clamp(300px, 52svh, 520px) !important; min-height: 300px !important; border-radius: 16px !important; }
  body.builder-page .viewer-toolbar__btn { min-height: 34px !important; height: 34px !important; padding: 8px 10px !important; font-size: 12px !important; }
  body.builder-page .viewer-color-palette { padding: 8px 10px !important; gap: 8px !important; border-radius: 14px !important; }
  body.builder-page .viewer-color-palette::before { content: 'Цвет'; flex: 0 0 auto; margin-right: 2px; color: rgba(226,232,240,.86); font-size: 12px; font-weight: 800; }
  body.builder-page .viewer-order-overlay { display: grid !important; grid-template-columns: minmax(0,1fr) auto !important; align-items: center !important; gap: 8px !important; padding: 10px !important; border-radius: 16px !important; }
  body.builder-page .viewer-order-overlay__label { grid-column: 1 / -1 !important; }
  body.builder-page .viewer-order-overlay__value { font-size: 23px !important; line-height: 1 !important; }
  body.builder-page .viewer-order-overlay__hint,
  body.builder-page .price-breakdown--compact { display: none !important; }
  body.builder-page .viewer-order-overlay__button { min-width: 132px !important; min-height: 38px !important; white-space: nowrap !important; }
  body.builder-page .viewer-rotation-control { display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 12px !important; padding: 10px 12px !important; border-radius: 16px !important; }
  body.builder-page .viewer-rotation-control::before { content: 'Поворот модели'; color: rgba(226,232,240,.86); font-size: 13px; font-weight: 800; }
  body.builder-page .viewer-joystick { width: 70px !important; height: 70px !important; min-width: 70px !important; }
  body.builder-page .dimension-hud { padding: 10px !important; border-radius: 16px !important; }
  body.builder-page .dimension-hud__grid { display: grid !important; grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 6px !important; }
  body.builder-page .builder-card,
  body.builder-page .mw-card { border-radius: 18px !important; }
  body.builder-page .mw-card__header--split,
  body.builder-page .mw-card__header { gap: 10px !important; align-items: flex-start !important; }
  body.builder-page .model-header-actions { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; }
  body.builder-page .live-size-grid { grid-template-columns: 1fr !important; }
  body.builder-page .customize-actions { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
  body.builder-page .modal { padding: 8px !important; align-items: flex-start !important; overflow-y: auto !important; }
  body.builder-page .modal__dialog { width: calc(100vw - 16px) !important; max-height: calc(100dvh - 16px) !important; overflow-y: auto !important; }
}

@media (max-width: 430px) {
  body.builder-page #viewer { height: clamp(280px, 48svh, 440px) !important; min-height: 280px !important; }
  body.builder-page .viewer-order-overlay { grid-template-columns: 1fr !important; }
  body.builder-page .viewer-order-overlay__button { width: 100% !important; }
  body.builder-page .dimension-hud__grid { grid-template-columns: 1fr !important; }
  body.builder-page .viewer-help span:nth-child(n+3) { display: none !important; }
  body.builder-page .customize-actions { grid-template-columns: 1fr !important; }
}

@media (max-height: 680px) and (orientation: landscape) {
  body.builder-page,
  body.user-mode.builder-page,
  body.admin-mode.builder-page { overflow-y: auto !important; height: auto !important; max-height: none !important; }
  body.builder-page .maker-layout--builder { height: auto !important; max-height: none !important; overflow: visible !important; }
  body.builder-page #viewer { height: clamp(260px, 68svh, 430px) !important; min-height: 260px !important; }
  body.builder-page .viewer-help { display: none !important; }
}

body[data-theme="light"].builder-page .viewer-card--builder { background: #f8fafc !important; }
body[data-theme="light"].builder-page .viewer-color-palette::before,
body[data-theme="light"].builder-page .viewer-rotation-control::before { color: #334155 !important; }
body[data-theme="light"].builder-page .app-preloader { color: #fff !important; }

/* === V244: adaptive layout, compact panels and mobile hamburger menu === */
.mobile-menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  min-width: 42px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  border: 1px solid rgba(148, 163, 184, .26);
  border-radius: 14px;
  background: rgba(15, 23, 42, .56);
  color: #e5e7eb;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(2, 6, 23, .18);
}
.mobile-menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 99px;
  background: currentColor;
  transition: transform .18s ease, opacity .18s ease;
}
.topbar.is-menu-open .mobile-menu-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.topbar.is-menu-open .mobile-menu-toggle span:nth-child(2) { opacity: 0; }
.topbar.is-menu-open .mobile-menu-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.customer-topbar__auth.hidden,
.customer-topbar__guest.hidden,
#customer-auth-actions.hidden,
#customer-guest-actions.hidden { display: none !important; }

body.builder-page .dimension-hud {
  overflow: visible !important;
  max-height: none !important;
  padding: 8px !important;
}
body.builder-page .dimension-hud__title {
  margin-bottom: 5px !important;
  font-size: 10px !important;
  line-height: 1.1 !important;
  letter-spacing: .08em !important;
}
body.builder-page .dimension-hud__grid {
  gap: 4px !important;
}
body.builder-page .dimension-hud__grid div {
  padding: 5px 6px !important;
  min-height: 0 !important;
  line-height: 1.05 !important;
  border-radius: 9px !important;
}
body.builder-page .dimension-hud__grid span {
  display: block !important;
  margin-bottom: 2px !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
}
body.builder-page .dimension-hud__grid b {
  display: block !important;
  font-size: 11px !important;
  line-height: 1.08 !important;
}
body.builder-page .viewer-order-overlay {
  overflow: visible !important;
  max-height: none !important;
  align-self: start !important;
}
body.builder-page .viewer-order-overlay__label { font-size: 10px !important; line-height: 1 !important; }
body.builder-page .viewer-order-overlay__value { margin-top: 4px !important; }
body.builder-page .viewer-order-overlay__hint,
body.builder-page .price-breakdown--compact {
  line-height: 1.25 !important;
  white-space: normal !important;
  overflow: visible !important;
  max-height: none !important;
}
body.builder-page .viewer-order-overlay__button {
  width: 100% !important;
  white-space: nowrap !important;
}
.admin-panel-modal .modal__dialog--admin-small {
  width: min(760px, calc(100vw - 24px)) !important;
  max-height: min(820px, calc(100dvh - 24px)) !important;
}
.admin-panel-modal #admin-customers-list {
  overflow-x: hidden !important;
}
.admin-panel-modal .request-card--customer {
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
.admin-panel-modal .request-card--customer .request-card__top,
.admin-panel-modal .request-card--customer .request-card__meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.admin-panel-modal .request-card--customer .request-card__top > div { min-width: 0 !important; }

@media (min-width: 981px) {
  body.builder-page .viewer-card--builder {
    grid-template-columns: minmax(0, 1fr) clamp(220px, 19vw, 285px) !important;
    grid-template-rows: auto auto auto auto auto minmax(86px, 1fr) auto !important;
  }
  body.builder-page .viewer-order-overlay {
    gap: 6px !important;
    padding: 10px !important;
  }
  body.builder-page .viewer-order-overlay__value {
    font-size: clamp(21px, 2.05vw, 26px) !important;
    line-height: 1 !important;
  }
  body.builder-page .viewer-order-overlay__hint,
  body.builder-page .price-breakdown--compact {
    font-size: 11px !important;
  }
  body.builder-page .viewer-order-overlay__button {
    min-height: 36px !important;
    padding: 9px 11px !important;
    font-size: 12px !important;
    margin-top: 4px !important;
  }
  body.builder-page .dimension-hud__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  body.builder-page .topbar,
  body.user-mode.builder-page .topbar,
  body.admin-mode.builder-page .topbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    overflow: visible !important;
  }
  .mobile-menu-toggle { display: inline-flex !important; justify-self: end !important; }
  body.builder-page .topbar__actions,
  body.user-mode.builder-page .topbar__actions,
  body.admin-mode.builder-page .topbar__actions {
    grid-column: 1 / -1 !important;
    display: none !important;
    width: 100% !important;
    overflow: visible !important;
    overflow-x: visible !important;
    padding: 8px 0 0 !important;
    margin: 0 !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
  }
  body.builder-page .topbar.is-menu-open .topbar__actions,
  body.user-mode.builder-page .topbar.is-menu-open .topbar__actions,
  body.admin-mode.builder-page .topbar.is-menu-open .topbar__actions {
    display: flex !important;
  }
  body.builder-page .customer-topbar,
  body.builder-page .customer-topbar__guest,
  body.builder-page .customer-topbar__auth {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    overflow: visible !important;
  }
  body.builder-page .customer-topbar__guest.hidden,
  body.builder-page .customer-topbar__auth.hidden { display: none !important; }
  body.builder-page .topbar .btn,
  body.builder-page .topbar-icon-btn,
  body.builder-page .topbar .pill {
    width: 100% !important;
    min-height: 40px !important;
    height: auto !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: 13px !important;
    padding: 10px 12px !important;
  }
  body.builder-page .topbar-icon-btn { display: flex !important; }
  body.builder-page .viewer-order-overlay {
    grid-template-columns: minmax(0, 1fr) auto !important;
    row-gap: 5px !important;
    padding: 10px 11px !important;
  }
  body.builder-page .viewer-order-overlay__value { font-size: 22px !important; }
  body.builder-page .price-breakdown--compact {
    display: block !important;
    grid-column: 1 / -1 !important;
    font-size: 11px !important;
    color: rgba(226,232,240,.78) !important;
  }
  body.builder-page .viewer-order-overlay__hint { display: none !important; }
  body.builder-page .viewer-order-overlay__button {
    min-width: 142px !important;
    min-height: 40px !important;
    margin-top: 0 !important;
  }
  body.builder-page .dimension-hud {
    padding: 8px !important;
  }
  body.builder-page .dimension-hud__title { font-size: 10px !important; margin-bottom: 4px !important; }
  body.builder-page .dimension-hud__grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 4px !important; }
  body.builder-page .dimension-hud__grid div { padding: 5px !important; }
  .admin-panel-modal .modal__dialog--admin-small,
  body.builder-page .modal__dialog--admin-small {
    width: calc(100vw - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
  }
}

@media (max-width: 430px) {
  body.builder-page .viewer-order-overlay {
    grid-template-columns: 1fr !important;
  }
  body.builder-page .viewer-order-overlay__button {
    width: 100% !important;
  }
  body.builder-page .dimension-hud__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  body.builder-page .dimension-hud__grid span { font-size: 9px !important; }
  body.builder-page .dimension-hud__grid b { font-size: 10px !important; }
}


/* === V245: вернуть нормальный размер окна модели, вертикальные размеры и быстрые иконки вне меню === */
body.builder-page .topbar__quick-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
}
body.builder-page .topbar__quick-actions .topbar-icon-btn {
  flex: 0 0 auto !important;
  width: 42px !important;
  min-width: 42px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
body.builder-page .topbar__quick-actions .theme-toggle-btn__text { display: none !important; }

/* Главное: v244 сжал правую колонку и из-за этого уменьшилось окно модели. Возвращаем ширину панели как в адаптивной версии v243. */
@media (min-width: 981px) {
  body.builder-page .viewer-card--builder {
    grid-template-columns: minmax(0, 1fr) clamp(230px, 22vw, 320px) !important;
    grid-template-rows: auto auto auto auto minmax(0, 1fr) auto !important;
  }
  body.builder-page #viewer {
    min-height: 420px !important;
    height: 100% !important;
    max-height: none !important;
  }
}
@media (max-width: 1180px) {
  body.builder-page #viewer {
    height: clamp(340px, 58svh, 620px) !important;
    min-height: 340px !important;
    max-height: none !important;
  }
}
@media (max-width: 430px) {
  body.builder-page #viewer {
    height: clamp(280px, 48svh, 440px) !important;
    min-height: 280px !important;
  }
}
@media (max-height: 680px) and (orientation: landscape) {
  body.builder-page #viewer {
    height: clamp(260px, 68svh, 430px) !important;
    min-height: 260px !important;
  }
}

/* Размеры модели: три независимые строки друг под другом, без сетки 3 колонки и без лишней высоты. */
body.builder-page .dimension-hud {
  overflow: visible !important;
  max-height: none !important;
  padding: 8px !important;
}
body.builder-page .dimension-hud__title {
  display: block !important;
  margin: 0 0 6px !important;
  font-size: 10px !important;
  line-height: 1.1 !important;
  letter-spacing: .08em !important;
}
body.builder-page .dimension-hud__grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 5px !important;
}
body.builder-page .dimension-hud__grid div {
  display: grid !important;
  grid-template-columns: 1fr !important;
  align-items: center !important;
  gap: 2px !important;
  min-height: 0 !important;
  padding: 6px 8px !important;
  border-radius: 10px !important;
  line-height: 1.05 !important;
}
body.builder-page .dimension-hud__grid span {
  display: block !important;
  margin: 0 !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
}
body.builder-page .dimension-hud__grid b {
  display: block !important;
  font-size: 12px !important;
  line-height: 1.08 !important;
}

/* Стоимость: не даём карточке создавать внутреннюю прокрутку; кнопка и цена всегда видны целиком. */
body.builder-page .viewer-order-overlay {
  overflow: visible !important;
  max-height: none !important;
  align-self: start !important;
}
body.builder-page .viewer-order-overlay__hint,
body.builder-page .price-breakdown--compact {
  white-space: normal !important;
  overflow: visible !important;
  max-height: none !important;
}
body.builder-page .viewer-order-overlay__button {
  width: 100% !important;
  white-space: nowrap !important;
}

@media (max-width: 760px) {
  body.builder-page .topbar,
  body.user-mode.builder-page .topbar,
  body.admin-mode.builder-page .topbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px !important;
    overflow: visible !important;
  }
  body.builder-page .topbar__quick-actions {
    grid-column: 2 !important;
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
  }
  .mobile-menu-toggle { display: inline-flex !important; }
  body.builder-page .topbar__actions,
  body.user-mode.builder-page .topbar__actions,
  body.admin-mode.builder-page .topbar__actions {
    grid-column: 1 / -1 !important;
    display: none !important;
    width: 100% !important;
    overflow: visible !important;
    padding: 8px 0 0 !important;
    margin: 0 !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
  }
  body.builder-page .topbar.is-menu-open .topbar__actions,
  body.user-mode.builder-page .topbar.is-menu-open .topbar__actions,
  body.admin-mode.builder-page .topbar.is-menu-open .topbar__actions {
    display: flex !important;
  }
  body.builder-page .topbar__quick-actions .topbar-icon-btn,
  body.builder-page .mobile-menu-toggle {
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
    min-height: 38px !important;
    border-radius: 12px !important;
  }
  body.builder-page .topbar__actions .topbar-icon-btn,
  body.user-mode.builder-page .topbar__actions .topbar-icon-btn,
  body.admin-mode.builder-page .topbar__actions .topbar-icon-btn {
    display: none !important;
  }
  body.builder-page .topbar .btn,
  body.builder-page .topbar .pill {
    width: 100% !important;
    min-height: 40px !important;
    height: auto !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: 13px !important;
    padding: 10px 12px !important;
  }
  body.builder-page .customer-topbar,
  body.builder-page .customer-topbar__guest,
  body.builder-page .customer-topbar__auth {
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    overflow: visible !important;
  }
  body.builder-page .customer-topbar__guest.hidden,
  body.builder-page .customer-topbar__auth.hidden,
  body.builder-page #customer-guest-actions.hidden,
  body.builder-page #customer-auth-actions.hidden {
    display: none !important;
  }
  body.builder-page .dimension-hud__grid {
    grid-template-columns: 1fr !important;
  }
  body.builder-page .viewer-order-overlay {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
  body.builder-page .viewer-order-overlay__button {
    min-width: 142px !important;
    width: auto !important;
  }
}
@media (max-width: 430px) {
  body.builder-page .viewer-order-overlay {
    grid-template-columns: 1fr !important;
  }
  body.builder-page .viewer-order-overlay__button {
    width: 100% !important;
  }
  body.builder-page .dimension-hud__grid {
    grid-template-columns: 1fr !important;
  }
}


/* === V246: подсказка снова внутри окна модели, размеры компактно вниз и без смещения вправо === */
body.builder-page .viewer-card--builder {
  position: relative !important;
}

/* Подсказки управления снова являются HUD прямо внутри 3D-окна. */
body.builder-page .viewer-help {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: 16px !important;
  transform: translateX(-50%) !important;
  z-index: 42 !important;
  width: min(640px, calc(100% - 560px)) !important;
  min-width: 260px !important;
  max-width: calc(100% - 36px) !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  pointer-events: none !important;
}
body.builder-page .viewer-help span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 26px !important;
  max-width: none !important;
  padding: 6px 9px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  background: rgba(5, 9, 16, .58) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: rgba(241,245,249,.92) !important;
  box-shadow: 0 8px 20px rgba(2,6,23,.22) !important;
  backdrop-filter: blur(12px) saturate(120%) !important;
}

/* Блок размеров: вертикально, компактно, ниже; значения больше не уезжают вправо на мобильных. */
body.builder-page .dimension-hud,
body.builder-page .dimension-hud.hidden {
  position: absolute !important;
  left: 16px !important;
  right: auto !important;
  top: auto !important;
  bottom: 16px !important;
  transform: none !important;
  z-index: 43 !important;
  width: 218px !important;
  max-width: calc(100% - 32px) !important;
  display: block !important;
  margin: 0 !important;
  padding: 8px !important;
  border-radius: 15px !important;
  overflow: visible !important;
  max-height: none !important;
  pointer-events: none !important;
  background: rgba(7, 11, 18, .66) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 12px 32px rgba(2,6,23,.28) !important;
  backdrop-filter: blur(14px) saturate(120%) !important;
}
body.builder-page .dimension-hud__title {
  display: block !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  text-align: left !important;
  color: rgba(226,232,240,.84) !important;
  font-size: 10px !important;
  line-height: 1.1 !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
body.builder-page .dimension-hud__grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 5px !important;
  width: 100% !important;
  margin: 0 !important;
}
body.builder-page .dimension-hud__grid div {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  justify-content: stretch !important;
  gap: 8px !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 28px !important;
  padding: 5px 7px !important;
  border-radius: 10px !important;
  text-align: left !important;
  line-height: 1.05 !important;
  background: rgba(255,255,255,.055) !important;
  border: 1px solid rgba(255,255,255,.055) !important;
}
body.builder-page .dimension-hud__grid span {
  display: block !important;
  min-width: 0 !important;
  margin: 0 !important;
  text-align: left !important;
  color: rgba(148,163,184,.96) !important;
  font-size: 10px !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
}
body.builder-page .dimension-hud__grid b {
  display: block !important;
  margin: 0 !important;
  text-align: right !important;
  color: #f8fafc !important;
  font-size: 12px !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
}

/* На планшетах подсказка остаётся внутри 3D-окна, а размеры остаются снизу слева. */
@media (max-width: 1180px) {
  body.builder-page .viewer-help {
    width: min(620px, calc(100% - 280px)) !important;
    min-width: 240px !important;
    bottom: 16px !important;
  }
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    left: 14px !important;
    bottom: 14px !important;
    width: 210px !important;
  }
}

/* На телефонах подсказка тоже внутри окна модели, но уходит наверх, чтобы не перекрывать цену и размеры. */
@media (max-width: 760px) {
  body.builder-page .viewer-help {
    left: 10px !important;
    right: 10px !important;
    top: 10px !important;
    bottom: auto !important;
    transform: none !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: flex !important;
    justify-content: center !important;
    gap: 5px !important;
  }
  body.builder-page .viewer-help span {
    min-height: 24px !important;
    padding: 5px 7px !important;
    font-size: 10px !important;
  }
  body.builder-page .viewer-help span:nth-child(n+3) {
    display: none !important;
  }
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    left: 10px !important;
    right: auto !important;
    bottom: 10px !important;
    width: 178px !important;
    max-width: calc(100% - 20px) !important;
    padding: 7px !important;
  }
  body.builder-page .dimension-hud__title {
    display: block !important;
    margin-bottom: 5px !important;
    text-align: left !important;
    font-size: 9px !important;
  }
  body.builder-page .dimension-hud__grid {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }
  body.builder-page .dimension-hud__grid div {
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 6px !important;
    min-height: 25px !important;
    padding: 4px 6px !important;
    text-align: left !important;
  }
  body.builder-page .dimension-hud__grid span {
    text-align: left !important;
    font-size: 9px !important;
  }
  body.builder-page .dimension-hud__grid b {
    text-align: right !important;
    font-size: 11px !important;
  }
}

/* На очень узких экранах размеры не превращаются в кривую колонку справа: подпись и значение остаются ровно в одной строке. */
@media (max-width: 430px) {
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    width: 166px !important;
    left: 8px !important;
    bottom: 8px !important;
  }
  body.builder-page .dimension-hud__grid div {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
  body.builder-page .viewer-help span:nth-child(n+2) {
    display: none !important;
  }
}

/* В низкой горизонтальной ориентации не убираем подсказку полностью, а оставляем её внутри viewer в компактном виде. */
@media (max-height: 680px) and (orientation: landscape) {
  body.builder-page .viewer-help {
    display: flex !important;
    top: 10px !important;
    bottom: auto !important;
  }
  body.builder-page .viewer-help span:nth-child(n+3) {
    display: none !important;
  }
}

body[data-theme="light"].builder-page .dimension-hud,
body[data-theme="light"].builder-page .dimension-hud.hidden,
body[data-theme="light"].builder-page .viewer-help span {
  background: rgba(255,255,255,.86) !important;
  border-color: rgba(15,23,42,.10) !important;
  color: #0f172a !important;
}
body[data-theme="light"].builder-page .dimension-hud__title,
body[data-theme="light"].builder-page .dimension-hud__grid b { color: #0f172a !important; }
body[data-theme="light"].builder-page .dimension-hud__grid span { color: #64748b !important; }


/* === V247: одинаковая ширина карточек цвета/стоимости и подсказка по центру в окне модели === */
body.builder-page {
  --viewer-side-card-width: 218px;
}

/* После JS-переноса подсказка находится внутри #viewer, поэтому центрируется именно в окне модели. */
body.builder-page #viewer {
  position: relative !important;
}
body.builder-page #viewer .viewer-help,
body.builder-page .viewer-help {
  position: absolute !important;
  left: 50% !important;
  top: auto !important;
  right: auto !important;
  bottom: 18px !important;
  transform: translateX(-50%) !important;
  z-index: 46 !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: calc(100% - 40px) !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  pointer-events: none !important;
}
body.builder-page #viewer .viewer-help span,
body.builder-page .viewer-help span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 26px !important;
  padding: 6px 9px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
}

/* Цвет и стоимость теперь равны по ширине блоку "Размеры модели". */
body.builder-page .viewer-color-palette,
body.builder-page .viewer-order-overlay,
body.builder-page .dimension-hud,
body.builder-page .dimension-hud.hidden {
  box-sizing: border-box !important;
  width: var(--viewer-side-card-width) !important;
  max-width: calc(100% - 32px) !important;
}
body.builder-page .viewer-color-palette,
body.builder-page .viewer-order-overlay {
  justify-self: start !important;
  align-self: start !important;
  overflow: visible !important;
}
body.builder-page .viewer-color-palette {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  padding: 9px 10px !important;
}
body.builder-page .viewer-color-palette::before {
  flex: 0 0 100% !important;
  margin: 0 0 2px !important;
  line-height: 1 !important;
}
body.builder-page .viewer-order-overlay {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 7px !important;
  padding: 10px !important;
}
body.builder-page .viewer-order-overlay__label,
body.builder-page .viewer-order-overlay__value,
body.builder-page .viewer-order-overlay__hint,
body.builder-page .price-breakdown--compact,
body.builder-page .viewer-order-overlay__button {
  grid-column: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}
body.builder-page .viewer-order-overlay__button {
  white-space: nowrap !important;
}

@media (max-width: 1180px) {
  body.builder-page {
    --viewer-side-card-width: 210px;
  }
  body.builder-page #viewer .viewer-help,
  body.builder-page .viewer-help {
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: 14px !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    max-width: calc(100% - 34px) !important;
  }
  body.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden {
    width: var(--viewer-side-card-width) !important;
    max-width: calc(100% - 28px) !important;
  }
}

@media (max-width: 760px) {
  body.builder-page {
    --viewer-side-card-width: 210px;
  }
  body.builder-page #viewer .viewer-help,
  body.builder-page .viewer-help {
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: 12px !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    max-width: calc(100% - 24px) !important;
    gap: 5px !important;
  }
  body.builder-page #viewer .viewer-help span,
  body.builder-page .viewer-help span {
    min-height: 24px !important;
    padding: 5px 7px !important;
    font-size: 10px !important;
  }
  body.builder-page #viewer .viewer-help span:nth-child(n+3),
  body.builder-page .viewer-help span:nth-child(n+3) {
    display: none !important;
  }
  body.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay {
    justify-self: start !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }
  body.builder-page .viewer-order-overlay__value {
    font-size: 22px !important;
  }
}

@media (max-width: 430px) {
  body.builder-page {
    --viewer-side-card-width: 196px;
  }
  body.builder-page #viewer .viewer-help,
  body.builder-page .viewer-help {
    bottom: 10px !important;
  }
  body.builder-page #viewer .viewer-help span:nth-child(n+2),
  body.builder-page .viewer-help span:nth-child(n+2) {
    display: none !important;
  }
  body.builder-page .viewer-order-overlay__button {
    font-size: 12px !important;
    padding-left: 9px !important;
    padding-right: 9px !important;
  }
}

/* === V248: mobile/tablet no-overlap layout safety layer ===
   На узких экранах все элементы управления выводятся отдельными блоками в потоке.
   Ничего, кроме компактной подсказки внутри самого viewer, не накладывается на 3D-окно. */
@media (max-width: 980px) {
  body.builder-page,
  body.user-mode.builder-page {
    overflow-x: hidden !important;
  }

  body.builder-page .maker-layout--builder,
  body.user-mode.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: auto !important;
    gap: 12px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.builder-page .builder-stage,
  body.user-mode.builder-page .builder-stage,
  body.builder-page .maker-stage,
  body.user-mode.builder-page .maker-stage {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-areas:
      "toolbar"
      "viewer"
      "sizes"
      "colors"
      "price"
      "rotate" !important;
    gap: 10px !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 0 0 12px !important;
    border-radius: 20px !important;
  }

  body.builder-page .viewer-toolbar,
  body.user-mode.builder-page .viewer-toolbar {
    grid-area: toolbar !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
    padding: 10px !important;
    margin: 0 !important;
    z-index: auto !important;
  }

  body.builder-page .viewer-toolbar__right,
  body.user-mode.builder-page .viewer-toolbar__right {
    width: auto !important;
    max-width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    grid-area: viewer !important;
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: clamp(300px, 54svh, 520px) !important;
    min-height: 300px !important;
    max-height: 520px !important;
    overflow: hidden !important;
    border-radius: 18px !important;
    z-index: 1 !important;
  }

  body.builder-page #viewer canvas,
  body.user-mode.builder-page #viewer canvas {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
  }

  /* На мобильных не кладём линии размеров поверх модели — числовой блок ниже остаётся главным. */
  body.builder-page .viewer-dimensions,
  body.user-mode.builder-page .viewer-dimensions,
  body.builder-page .viewer-dimensions__svg,
  body.user-mode.builder-page .viewer-dimensions__svg,
  body.builder-page .viewer-dimensions__label,
  body.user-mode.builder-page .viewer-dimensions__label {
    display: none !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    box-sizing: border-box !important;
    width: min(100%, var(--viewer-side-card-width, 218px)) !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin: 0 0 0 10px !important;
    overflow: visible !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden { grid-area: sizes !important; }

  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette { grid-area: colors !important; }

  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay { grid-area: price !important; }

  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control { grid-area: rotate !important; }

  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    padding: 10px !important;
  }

  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 7px !important;
    padding: 10px !important;
  }

  body.builder-page .viewer-order-overlay__label,
  body.user-mode.builder-page .viewer-order-overlay__label,
  body.builder-page .viewer-order-overlay__value,
  body.user-mode.builder-page .viewer-order-overlay__value,
  body.builder-page .viewer-order-overlay__hint,
  body.user-mode.builder-page .viewer-order-overlay__hint,
  body.builder-page .price-breakdown--compact,
  body.user-mode.builder-page .price-breakdown--compact,
  body.builder-page .viewer-order-overlay__button,
  body.user-mode.builder-page .viewer-order-overlay__button {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
    white-space: normal !important;
  }

  body.builder-page .viewer-order-overlay__value,
  body.user-mode.builder-page .viewer-order-overlay__value {
    font-size: 22px !important;
    line-height: 1.05 !important;
    margin: 0 !important;
  }

  body.builder-page .viewer-order-overlay__hint,
  body.user-mode.builder-page .viewer-order-overlay__hint,
  body.builder-page .price-breakdown--compact,
  body.user-mode.builder-page .price-breakdown--compact {
    font-size: 12px !important;
    line-height: 1.3 !important;
    margin: 0 !important;
  }

  body.builder-page .viewer-order-overlay__button,
  body.user-mode.builder-page .viewer-order-overlay__button {
    min-height: 40px !important;
    margin-top: 2px !important;
    white-space: nowrap !important;
  }

  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 10px !important;
  }

  body.builder-page .dimension-hud__grid,
  body.user-mode.builder-page .dimension-hud__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 5px !important;
  }

  body.builder-page .dimension-hud__grid div,
  body.user-mode.builder-page .dimension-hud__grid div {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 28px !important;
    padding: 5px 8px !important;
    gap: 10px !important;
    text-align: left !important;
  }

  body.builder-page .dimension-hud__grid span,
  body.user-mode.builder-page .dimension-hud__grid span { text-align: left !important; }
  body.builder-page .dimension-hud__grid b,
  body.user-mode.builder-page .dimension-hud__grid b { text-align: right !important; }

  /* Подсказка остаётся внутри 3D-окна, но не пересекается с панелями, так как панели теперь ниже viewer. */
  body.builder-page #viewer .viewer-help,
  body.user-mode.builder-page #viewer .viewer-help {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: 12px !important;
    transform: translateX(-50%) !important;
    z-index: 8 !important;
    max-width: calc(100% - 20px) !important;
    margin: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 5px !important;
    pointer-events: none !important;
  }

  body.builder-page #viewer .viewer-help span,
  body.user-mode.builder-page #viewer .viewer-help span {
    min-height: 23px !important;
    padding: 5px 7px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  body.builder-page .viewer-badge,
  body.user-mode.builder-page .viewer-badge { display: none !important; }
}

@media (max-width: 520px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-card-width: calc(100vw - 24px) !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    gap: 8px !important;
    border-radius: 16px !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    height: clamp(280px, 50svh, 430px) !important;
    min-height: 280px !important;
    border-radius: 16px !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: calc(100vw - 24px) !important;
    margin-left: 0 !important;
    justify-self: center !important;
  }

  body.builder-page .viewer-toolbar,
  body.user-mode.builder-page .viewer-toolbar {
    padding: 8px !important;
  }

  body.builder-page .viewer-toolbar__right,
  body.user-mode.builder-page .viewer-toolbar__right {
    justify-content: flex-start !important;
  }

  body.builder-page #viewer .viewer-help span:nth-child(n+3),
  body.user-mode.builder-page #viewer .viewer-help span:nth-child(n+3) {
    display: none !important;
  }
}

@media (max-width: 380px) {
  body.builder-page #viewer .viewer-help span:nth-child(n+2),
  body.user-mode.builder-page #viewer .viewer-help span:nth-child(n+2) {
    display: none !important;
  }

  body.builder-page .viewer-order-overlay__button,
  body.user-mode.builder-page .viewer-order-overlay__button {
    font-size: 12px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

/* Горизонтальный телефон: модель не сжимается в ноль, все панели уходят ниже и страница прокручивается. */
@media (max-width: 980px) and (orientation: landscape) and (max-height: 520px) {
  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    height: 300px !important;
    min-height: 300px !important;
  }
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    overflow: visible !important;
  }
}

/* === V249: adaptive viewer expansion ===
   Карточки размеров/цвета/стоимости остаются компактными и одинаковой ширины,
   а свободное место получает окно 3D-модели. На телефонах всё снова уходит в одну колонку. */
body.builder-page {
  --viewer-side-card-width: clamp(210px, 18vw, 250px);
}

/* Большие экраны: вместо пустого пространства внутри viewer-card используем двухколоночную сетку. */
@media (min-width: 981px) {
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(520px, 1fr) var(--viewer-side-card-width) !important;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto !important;
    grid-template-areas:
      "toolbar toolbar"
      "viewer sizes"
      "viewer colors"
      "viewer price"
      "viewer rotate" !important;
    column-gap: 14px !important;
    row-gap: 10px !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  body.builder-page .viewer-toolbar,
  body.user-mode.builder-page .viewer-toolbar {
    grid-area: toolbar !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: none !important;
    z-index: 10 !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    grid-area: viewer !important;
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    box-sizing: border-box !important;
    width: var(--viewer-side-card-width) !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin: 0 !important;
    overflow: visible !important;
    align-self: start !important;
    justify-self: stretch !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden { grid-area: sizes !important; }

  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette { grid-area: colors !important; }

  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay { grid-area: price !important; }

  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control { grid-area: rotate !important; }

  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 10px !important;
  }

  body.builder-page .viewer-card--builder #viewer .viewer-help,
  body.user-mode.builder-page .viewer-card--builder #viewer .viewer-help {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: 16px !important;
    top: auto !important;
    transform: translateX(-50%) !important;
    z-index: 8 !important;
    max-width: calc(100% - 28px) !important;
  }
}

/* Средние экраны: оставляем 3D-окно слева, панели справа. Ничего не накладывается. */
@media (max-width: 980px) and (min-width: 681px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-card-width: clamp(205px, 24vw, 245px) !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) var(--viewer-side-card-width) !important;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto !important;
    grid-template-areas:
      "toolbar toolbar"
      "viewer sizes"
      "viewer colors"
      "viewer price"
      "viewer rotate" !important;
    column-gap: 12px !important;
    row-gap: 10px !important;
    width: 100% !important;
    overflow: visible !important;
    padding: 0 0 12px !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    grid-area: viewer !important;
    width: 100% !important;
    height: clamp(380px, 64svh, 660px) !important;
    min-height: 380px !important;
    max-height: 660px !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-side-card-width) !important;
    margin: 0 !important;
    justify-self: stretch !important;
    align-self: start !important;
  }
}

/* Телефоны: одна колонка, 3D-окно максимально широкое, карточки тоже на всю доступную ширину. */
@media (max-width: 680px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-card-width: 100% !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-areas:
      "toolbar"
      "viewer"
      "sizes"
      "colors"
      "price"
      "rotate" !important;
    gap: 9px !important;
    padding: 0 0 12px !important;
    width: 100% !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    grid-area: viewer !important;
    width: 100% !important;
    height: clamp(330px, 56svh, 520px) !important;
    min-height: 330px !important;
    max-height: 520px !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    justify-self: stretch !important;
  }

  body.builder-page .viewer-toolbar,
  body.user-mode.builder-page .viewer-toolbar {
    width: 100% !important;
  }
}

@media (max-width: 420px) {
  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    height: clamp(300px, 52svh, 460px) !important;
    min-height: 300px !important;
  }
}

@media (max-width: 980px) and (orientation: landscape) and (max-height: 520px) {
  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    height: 340px !important;
    min-height: 340px !important;
    max-height: none !important;
  }
}


/* === V250: аккуратный левый отступ правой колонки управления ===
   Размеры модели / Цвет / Стоимость / Поворот остаются одинаковой ширины,
   но получают одинаковый небольшой воздух слева относительно зоны модели.
   На телефонах отступ отключён, чтобы карточки занимали всю доступную ширину. */
body.builder-page,
body.user-mode.builder-page {
  --viewer-side-left-inset: 14px;
}

@media (min-width: 981px) {
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(520px, 1fr) calc(var(--viewer-side-card-width) + var(--viewer-side-left-inset)) !important;
    column-gap: 14px !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-side-card-width) !important;
    justify-self: end !important;
    margin-left: var(--viewer-side-left-inset) !important;
    margin-right: 0 !important;
  }
}

@media (max-width: 980px) and (min-width: 681px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-left-inset: 12px !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(0, 1fr) calc(var(--viewer-side-card-width) + var(--viewer-side-left-inset)) !important;
    column-gap: 12px !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-side-card-width) !important;
    justify-self: end !important;
    margin-left: var(--viewer-side-left-inset) !important;
    margin-right: 0 !important;
  }
}

@media (max-width: 680px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-left-inset: 0px !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    margin-left: 0 !important;
    margin-right: 0 !important;
    justify-self: stretch !important;
  }
}


/* === V251: размеры снова отображаются прямо на самой модели ===
   Причина предыдущего скрытия была защита мобильной вёрстки от наложений.
   Теперь overlay размеров занимает ту же grid-area, что и #viewer, поэтому
   он находится только внутри окна модели и не перекрывает внешние карточки. */
body.builder-page .viewer-card--builder,
body.user-mode.builder-page .viewer-card--builder {
  position: relative !important;
}

body.builder-page #viewer,
body.user-mode.builder-page #viewer {
  grid-area: viewer !important;
  position: relative !important;
  z-index: 1 !important;
}

body.builder-page #viewer-dimensions,
body.user-mode.builder-page #viewer-dimensions,
body.builder-page .viewer-dimensions,
body.user-mode.builder-page .viewer-dimensions {
  grid-area: viewer !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative !important;
  inset: auto !important;
  transform: none !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: none !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
  z-index: 18 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body.builder-page #viewer-dimensions.hidden,
body.user-mode.builder-page #viewer-dimensions.hidden,
body.builder-page .viewer-dimensions.hidden,
body.user-mode.builder-page .viewer-dimensions.hidden {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

body.builder-page .viewer-dimensions__svg,
body.user-mode.builder-page .viewer-dimensions__svg {
  display: block !important;
  visibility: visible !important;
  opacity: .88 !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  overflow: visible !important;
}

body.builder-page .viewer-dimensions__line,
body.user-mode.builder-page .viewer-dimensions__line,
body.builder-page .viewer-dimensions__line--arrow,
body.user-mode.builder-page .viewer-dimensions__line--arrow,
body.builder-page .viewer-dimensions__guide,
body.user-mode.builder-page .viewer-dimensions__guide,
body.builder-page .viewer-dimensions__tick,
body.user-mode.builder-page .viewer-dimensions__tick {
  display: block !important;
  visibility: visible !important;
  opacity: .92 !important;
  vector-effect: non-scaling-stroke !important;
}

body.builder-page .viewer-dimensions__label,
body.user-mode.builder-page .viewer-dimensions__label {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: absolute !important;
  transform: translate(-50%, -50%) !important;
  max-width: 132px !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: rgba(5, 9, 16, .76) !important;
  border: 1px solid rgba(226, 232, 240, .34) !important;
  color: #f8fafc !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter: blur(12px) saturate(130%) !important;
  -webkit-backdrop-filter: blur(12px) saturate(130%) !important;
  font-size: 11px !important;
  line-height: 1.05 !important;
  font-weight: 800 !important;
  letter-spacing: .02em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  pointer-events: none !important;
}

body[data-theme="light"].builder-page .viewer-dimensions__label,
body[data-theme="light"].user-mode.builder-page .viewer-dimensions__label {
  background: rgba(255,255,255,.90) !important;
  border-color: rgba(15,23,42,.16) !important;
  color: #0f172a !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.14) !important;
}

@media (max-width: 1180px) {
  body.builder-page #viewer-dimensions,
  body.user-mode.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions,
  body.user-mode.builder-page .viewer-dimensions {
    grid-area: viewer !important;
    display: block !important;
    position: relative !important;
    z-index: 16 !important;
  }
}

@media (max-width: 760px) {
  body.builder-page #viewer-dimensions,
  body.user-mode.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions,
  body.user-mode.builder-page .viewer-dimensions {
    grid-area: viewer !important;
    display: block !important;
    position: relative !important;
    z-index: 14 !important;
    opacity: .92 !important;
  }

  body.builder-page .viewer-dimensions__svg,
  body.user-mode.builder-page .viewer-dimensions__svg {
    opacity: .64 !important;
  }

  body.builder-page .viewer-dimensions__label,
  body.user-mode.builder-page .viewer-dimensions__label {
    max-width: 94px !important;
    padding: 3px 6px !important;
    font-size: 9px !important;
    line-height: 1 !important;
    border-radius: 999px !important;
  }

  body.builder-page .viewer-dimensions__line,
  body.user-mode.builder-page .viewer-dimensions__line,
  body.builder-page .viewer-dimensions__line--arrow,
  body.user-mode.builder-page .viewer-dimensions__line--arrow,
  body.builder-page .viewer-dimensions__guide,
  body.user-mode.builder-page .viewer-dimensions__guide,
  body.builder-page .viewer-dimensions__tick,
  body.user-mode.builder-page .viewer-dimensions__tick {
    opacity: .58 !important;
  }
}

@media (max-width: 430px) {
  body.builder-page .viewer-dimensions__label,
  body.user-mode.builder-page .viewer-dimensions__label {
    max-width: 84px !important;
    padding: 3px 5px !important;
    font-size: 8.5px !important;
  }
}

/* === V252: верхняя панель, выравнивание кнопок и симметричный отступ правой колонки ===
   Колокольчик и тема визуально стоят справа рядом с Войти/Регистрация,
   кнопки над моделью центрированы по высоте, а правая колонка получила
   одинаковый внутренний отступ слева и справа. */
body.builder-page .topbar,
body.user-mode.builder-page .topbar,
body.admin-mode.builder-page .topbar {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
body.builder-page .brand,
body.user-mode.builder-page .brand,
body.admin-mode.builder-page .brand {
  order: 1 !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
}
body.builder-page .topbar__actions,
body.user-mode.builder-page .topbar__actions,
body.admin-mode.builder-page .topbar__actions {
  order: 2 !important;
  margin-left: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  min-width: 0 !important;
}
body.builder-page .topbar__quick-actions,
body.user-mode.builder-page .topbar__quick-actions,
body.admin-mode.builder-page .topbar__quick-actions {
  order: 3 !important;
  margin-left: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
}
body.builder-page .topbar__quick-actions .topbar-icon-btn,
body.user-mode.builder-page .topbar__quick-actions .topbar-icon-btn,
body.admin-mode.builder-page .topbar__quick-actions .topbar-icon-btn {
  width: 42px !important;
  min-width: 42px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Верхняя панель над моделью: все кнопки одной высоты и по центру. */
body.builder-page .viewer-toolbar,
body.user-mode.builder-page .viewer-toolbar {
  align-items: center !important;
}
body.builder-page .viewer-toolbar__right,
body.user-mode.builder-page .viewer-toolbar__right {
  display: flex !important;
  align-items: center !important;
  align-content: center !important;
  gap: 7px !important;
}
body.builder-page .viewer-toolbar__btn,
body.user-mode.builder-page .viewer-toolbar__btn,
body.builder-page .viewer-toolbar__pill,
body.user-mode.builder-page .viewer-toolbar__pill {
  min-height: 36px !important;
  height: 36px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  vertical-align: middle !important;
}
body.builder-page .viewer-toolbar__btn--square,
body.user-mode.builder-page .viewer-toolbar__btn--square {
  width: 36px !important;
  min-width: 36px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.builder-page,
body.user-mode.builder-page {
  --viewer-side-left-inset: 14px;
  --viewer-side-right-inset: 14px;
}
@media (min-width: 981px) {
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(520px, 1fr) calc(var(--viewer-side-card-width) + var(--viewer-side-left-inset) + var(--viewer-side-right-inset)) !important;
    column-gap: 14px !important;
  }
  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-side-card-width) !important;
    justify-self: start !important;
    margin-left: var(--viewer-side-left-inset) !important;
    margin-right: var(--viewer-side-right-inset) !important;
  }
}
@media (max-width: 980px) and (min-width: 681px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-left-inset: 12px !important;
    --viewer-side-right-inset: 12px !important;
  }
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(0, 1fr) calc(var(--viewer-side-card-width) + var(--viewer-side-left-inset) + var(--viewer-side-right-inset)) !important;
    column-gap: 12px !important;
  }
  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-side-card-width) !important;
    justify-self: start !important;
    margin-left: var(--viewer-side-left-inset) !important;
    margin-right: var(--viewer-side-right-inset) !important;
  }
}
@media (max-width: 680px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-left-inset: 0px !important;
    --viewer-side-right-inset: 0px !important;
  }
  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    margin-left: 0 !important;
    margin-right: 0 !important;
    justify-self: stretch !important;
  }
}
@media (max-width: 760px) {
  body.builder-page .topbar,
  body.user-mode.builder-page .topbar,
  body.admin-mode.builder-page .topbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px !important;
  }
  body.builder-page .topbar__quick-actions,
  body.user-mode.builder-page .topbar__quick-actions,
  body.admin-mode.builder-page .topbar__quick-actions {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
  }
  body.builder-page .topbar__actions,
  body.user-mode.builder-page .topbar__actions,
  body.admin-mode.builder-page .topbar__actions {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    margin-left: 0 !important;
    display: none !important;
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    padding-top: 8px !important;
  }
  body.builder-page .topbar.is-menu-open .topbar__actions,
  body.user-mode.builder-page .topbar.is-menu-open .topbar__actions,
  body.admin-mode.builder-page .topbar.is-menu-open .topbar__actions {
    display: flex !important;
  }
  body.builder-page .topbar__quick-actions .topbar-icon-btn,
  body.user-mode.builder-page .topbar__quick-actions .topbar-icon-btn,
  body.admin-mode.builder-page .topbar__quick-actions .topbar-icon-btn,
  body.builder-page .mobile-menu-toggle,
  body.user-mode.builder-page .mobile-menu-toggle,
  body.admin-mode.builder-page .mobile-menu-toggle {
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
    min-height: 38px !important;
    border-radius: 12px !important;
  }
  body.builder-page .viewer-toolbar__right,
  body.user-mode.builder-page .viewer-toolbar__right {
    align-items: center !important;
    align-content: center !important;
  }
  body.builder-page .viewer-toolbar__btn,
  body.user-mode.builder-page .viewer-toolbar__btn,
  body.builder-page .viewer-toolbar__pill,
  body.user-mode.builder-page .viewer-toolbar__pill {
    min-height: 34px !important;
    height: 34px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
}


/* === V253: правый блок рядом с входом, равные отступы кнопок и окна модели ===
   1) Колокольчик и тема находятся в общем правом блоке рядом с Войти/Регистрация.
   2) Кнопки над 3D-окном имеют одинаковые небольшие отступы сверху/снизу.
   3) Само окно модели получает симметричный небольшой отступ слева/справа. */
body.builder-page .topbar,
body.user-mode.builder-page .topbar,
body.admin-mode.builder-page .topbar {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
body.builder-page .brand,
body.user-mode.builder-page .brand,
body.admin-mode.builder-page .brand {
  flex: 0 1 auto !important;
  min-width: 0 !important;
}
body.builder-page .topbar__right-cluster,
body.user-mode.builder-page .topbar__right-cluster,
body.admin-mode.builder-page .topbar__right-cluster {
  margin-left: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: 0 !important;
}
body.builder-page .topbar__actions,
body.user-mode.builder-page .topbar__actions,
body.admin-mode.builder-page .topbar__actions {
  order: 1 !important;
  margin-left: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: 0 !important;
}
body.builder-page .topbar__quick-actions,
body.user-mode.builder-page .topbar__quick-actions,
body.admin-mode.builder-page .topbar__quick-actions {
  order: 2 !important;
  margin-left: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  flex: 0 0 auto !important;
}
body.builder-page .customer-topbar,
body.user-mode.builder-page .customer-topbar,
body.admin-mode.builder-page .customer-topbar,
body.builder-page .customer-topbar__guest,
body.user-mode.builder-page .customer-topbar__guest,
body.admin-mode.builder-page .customer-topbar__guest,
body.builder-page .customer-topbar__auth,
body.user-mode.builder-page .customer-topbar__auth,
body.admin-mode.builder-page .customer-topbar__auth {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: nowrap !important;
  min-width: 0 !important;
}
body.builder-page .customer-topbar__guest.hidden,
body.user-mode.builder-page .customer-topbar__guest.hidden,
body.admin-mode.builder-page .customer-topbar__guest.hidden,
body.builder-page .customer-topbar__auth.hidden,
body.user-mode.builder-page .customer-topbar__auth.hidden,
body.admin-mode.builder-page .customer-topbar__auth.hidden {
  display: none !important;
}
body.builder-page .topbar__quick-actions .topbar-icon-btn,
body.user-mode.builder-page .topbar__quick-actions .topbar-icon-btn,
body.admin-mode.builder-page .topbar__quick-actions .topbar-icon-btn,
body.builder-page .mobile-menu-toggle,
body.user-mode.builder-page .mobile-menu-toggle,
body.admin-mode.builder-page .mobile-menu-toggle {
  width: 40px !important;
  min-width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Кнопки над окном модели: одинаковый небольшой воздух сверху/снизу. */
body.builder-page .viewer-toolbar,
body.user-mode.builder-page .viewer-toolbar {
  padding: 7px var(--viewer-window-side-gap, 12px) !important;
  box-sizing: border-box !important;
  align-items: center !important;
}
body.builder-page .viewer-toolbar__right,
body.user-mode.builder-page .viewer-toolbar__right {
  display: flex !important;
  align-items: center !important;
  align-content: center !important;
  gap: 7px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  min-height: 36px !important;
}
body.builder-page .viewer-toolbar__btn,
body.user-mode.builder-page .viewer-toolbar__btn,
body.builder-page .viewer-toolbar__pill,
body.user-mode.builder-page .viewer-toolbar__pill {
  height: 34px !important;
  min-height: 34px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  box-sizing: border-box !important;
  vertical-align: middle !important;
}
body.builder-page .viewer-toolbar__btn--square,
body.user-mode.builder-page .viewer-toolbar__btn--square {
  width: 34px !important;
  min-width: 34px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Симметричный небольшой отступ слева/справа именно у окна модели. */
body.builder-page,
body.user-mode.builder-page {
  --viewer-window-side-gap: 12px;
}
body.builder-page #viewer,
body.user-mode.builder-page #viewer,
body.builder-page #viewer-dimensions,
body.user-mode.builder-page #viewer-dimensions,
body.builder-page .viewer-dimensions,
body.user-mode.builder-page .viewer-dimensions {
  width: calc(100% - (var(--viewer-window-side-gap) * 2)) !important;
  margin-left: var(--viewer-window-side-gap) !important;
  margin-right: var(--viewer-window-side-gap) !important;
  justify-self: stretch !important;
  box-sizing: border-box !important;
}
body.builder-page #viewer,
body.user-mode.builder-page #viewer {
  border-radius: 18px !important;
  overflow: hidden !important;
}
body.builder-page #viewer .viewer-help,
body.user-mode.builder-page #viewer .viewer-help {
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  max-width: calc(100% - 26px) !important;
}

@media (max-width: 760px) {
  body.builder-page .topbar,
  body.user-mode.builder-page .topbar,
  body.admin-mode.builder-page .topbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px !important;
  }
  body.builder-page .topbar__right-cluster,
  body.user-mode.builder-page .topbar__right-cluster,
  body.admin-mode.builder-page .topbar__right-cluster {
    display: contents !important;
  }
  body.builder-page .topbar__quick-actions,
  body.user-mode.builder-page .topbar__quick-actions,
  body.admin-mode.builder-page .topbar__quick-actions {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
  }
  body.builder-page .topbar__actions,
  body.user-mode.builder-page .topbar__actions,
  body.admin-mode.builder-page .topbar__actions {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    margin-left: 0 !important;
    width: 100% !important;
    display: none !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    padding-top: 8px !important;
  }
  body.builder-page .topbar.is-menu-open .topbar__actions,
  body.user-mode.builder-page .topbar.is-menu-open .topbar__actions,
  body.admin-mode.builder-page .topbar.is-menu-open .topbar__actions {
    display: flex !important;
  }
  body.builder-page .customer-topbar,
  body.user-mode.builder-page .customer-topbar,
  body.admin-mode.builder-page .customer-topbar,
  body.builder-page .customer-topbar__guest,
  body.user-mode.builder-page .customer-topbar__guest,
  body.admin-mode.builder-page .customer-topbar__guest,
  body.builder-page .customer-topbar__auth,
  body.user-mode.builder-page .customer-topbar__auth,
  body.admin-mode.builder-page .customer-topbar__auth {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }
  body.builder-page .customer-topbar__guest.hidden,
  body.user-mode.builder-page .customer-topbar__guest.hidden,
  body.admin-mode.builder-page .customer-topbar__guest.hidden,
  body.builder-page .customer-topbar__auth.hidden,
  body.user-mode.builder-page .customer-topbar__auth.hidden,
  body.admin-mode.builder-page .customer-topbar__auth.hidden {
    display: none !important;
  }
  body.builder-page .viewer-toolbar,
  body.user-mode.builder-page .viewer-toolbar {
    padding-top: 6px !important;
    padding-bottom: 6px !important;
  }
  body.builder-page .viewer-toolbar__right,
  body.user-mode.builder-page .viewer-toolbar__right {
    min-height: 34px !important;
  }
  body.builder-page .viewer-toolbar__btn,
  body.user-mode.builder-page .viewer-toolbar__btn,
  body.builder-page .viewer-toolbar__pill,
  body.user-mode.builder-page .viewer-toolbar__pill {
    height: 32px !important;
    min-height: 32px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  body.builder-page .viewer-toolbar__btn--square,
  body.user-mode.builder-page .viewer-toolbar__btn--square {
    width: 32px !important;
    min-width: 32px !important;
  }
}

@media (max-width: 520px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-window-side-gap: 8px;
  }
}

/* === V254: DESKTOP ONLY — не смешиваем ПК и мобильную раскладку ===
   Правки ниже применяются только для экранов ПК/ноутбуков шире 980px.
   Мобильные media-зоны (<=980px) не меняются. */
@media (min-width: 981px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-window-side-gap: 12px;
    --viewer-desktop-side-card-width: var(--viewer-side-card-width, 218px);
    --viewer-desktop-side-right-gap: 12px;
  }

  /* Убираем лишнюю пустоту между 3D-окном и правыми карточками.
     Промежуток теперь равен правому отступу карточек, а освободившееся место получает окно модели. */
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(560px, 1fr) calc(var(--viewer-desktop-side-card-width) + var(--viewer-desktop-side-right-gap)) !important;
    column-gap: 0 !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer,
  body.builder-page #viewer-dimensions,
  body.user-mode.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions,
  body.user-mode.builder-page .viewer-dimensions {
    width: calc(100% - (var(--viewer-window-side-gap) * 2)) !important;
    margin-left: var(--viewer-window-side-gap) !important;
    margin-right: var(--viewer-window-side-gap) !important;
    justify-self: stretch !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-desktop-side-card-width) !important;
    justify-self: start !important;
    margin-left: 0 !important;
    margin-right: var(--viewer-desktop-side-right-gap) !important;
  }

  /* Верхняя панель ПК: колокольчик и тема стоят строго рядом с Войти/Регистрация. */
  body.builder-page .topbar__right-cluster,
  body.user-mode.builder-page .topbar__right-cluster,
  body.admin-mode.builder-page .topbar__right-cluster {
    margin-left: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 8px !important;
  }

  body.builder-page .topbar__actions,
  body.user-mode.builder-page .topbar__actions,
  body.admin-mode.builder-page .topbar__actions,
  body.builder-page .topbar__quick-actions,
  body.user-mode.builder-page .topbar__quick-actions,
  body.admin-mode.builder-page .topbar__quick-actions {
    display: inline-flex !important;
    align-items: center !important;
  }

  body.builder-page .mobile-menu-toggle,
  body.user-mode.builder-page .mobile-menu-toggle,
  body.admin-mode.builder-page .mobile-menu-toggle {
    display: none !important;
  }

  /* Кнопки над моделью: одинаковый небольшой отступ сверху/снизу только на ПК. */
  body.builder-page .viewer-toolbar,
  body.user-mode.builder-page .viewer-toolbar {
    padding: 7px var(--viewer-window-side-gap) !important;
    align-items: center !important;
  }
  body.builder-page .viewer-toolbar__right,
  body.user-mode.builder-page .viewer-toolbar__right {
    align-items: center !important;
    align-content: center !important;
    gap: 7px !important;
  }
  body.builder-page .viewer-toolbar__btn,
  body.user-mode.builder-page .viewer-toolbar__btn,
  body.builder-page .viewer-toolbar__pill,
  body.user-mode.builder-page .viewer-toolbar__pill {
    height: 34px !important;
    min-height: 34px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
}


/* === V255: ПК — вернуть бренд слева, иконки темы/уведомлений слева от входа === */
@media (min-width: 981px) {
  body.builder-page .topbar,
  body.user-mode.builder-page .topbar,
  body.admin-mode.builder-page .topbar {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 16px !important;
  }

  body.builder-page .brand,
  body.user-mode.builder-page .brand,
  body.admin-mode.builder-page .brand {
    flex: 0 0 auto !important;
    margin-right: 0 !important;
    order: 1 !important;
  }

  body.builder-page .topbar__right-cluster,
  body.user-mode.builder-page .topbar__right-cluster,
  body.admin-mode.builder-page .topbar__right-cluster {
    order: 2 !important;
    margin-left: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    flex: 0 0 auto !important;
  }

  /* На ПК порядок такой: 🔔 / тема / Войти / Регистрация. */
  body.builder-page .topbar__quick-actions,
  body.user-mode.builder-page .topbar__quick-actions,
  body.admin-mode.builder-page .topbar__quick-actions {
    order: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin: 0 !important;
  }

  body.builder-page .topbar__actions,
  body.user-mode.builder-page .topbar__actions,
  body.admin-mode.builder-page .topbar__actions {
    order: 2 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    width: auto !important;
  }

  body.builder-page .customer-topbar,
  body.user-mode.builder-page .customer-topbar,
  body.admin-mode.builder-page .customer-topbar,
  body.builder-page .customer-topbar__guest,
  body.user-mode.builder-page .customer-topbar__guest,
  body.admin-mode.builder-page .customer-topbar__guest,
  body.builder-page .customer-topbar__auth,
  body.user-mode.builder-page .customer-topbar__auth,
  body.admin-mode.builder-page .customer-topbar__auth {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    width: auto !important;
  }

  body.builder-page .customer-topbar__guest.hidden,
  body.user-mode.builder-page .customer-topbar__guest.hidden,
  body.admin-mode.builder-page .customer-topbar__guest.hidden,
  body.builder-page .customer-topbar__auth.hidden,
  body.user-mode.builder-page .customer-topbar__auth.hidden,
  body.admin-mode.builder-page .customer-topbar__auth.hidden {
    display: none !important;
  }
}

/* === V256: ПК — боковые карточки чуть уже, окно модели шире ===
   Правка только для desktop >=981px. Мобильную и планшетную раскладку не трогаем. */
@media (min-width: 981px) {
  body.builder-page,
  body.user-mode.builder-page {
    --viewer-desktop-side-card-width: 198px !important;
    --viewer-side-card-width: 198px !important;
    --viewer-desktop-side-right-gap: 12px !important;
    --viewer-window-side-gap: 12px !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(620px, 1fr) calc(var(--viewer-desktop-side-card-width) + var(--viewer-desktop-side-right-gap)) !important;
    column-gap: 0 !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-desktop-side-card-width) !important;
    max-width: var(--viewer-desktop-side-card-width) !important;
    margin-left: 0 !important;
    margin-right: var(--viewer-desktop-side-right-gap) !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer,
  body.builder-page #viewer-dimensions,
  body.user-mode.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions,
  body.user-mode.builder-page .viewer-dimensions {
    width: calc(100% - (var(--viewer-window-side-gap) * 2)) !important;
    margin-left: var(--viewer-window-side-gap) !important;
    margin-right: var(--viewer-window-side-gap) !important;
  }
}

/* === V257: ПК — сужаем левую колонку, правую возвращаем как было ===
   Правка только для desktop >=981px. Мобильную и планшетную версии не трогаем.
   Левая колонка: блоки «Выбрать модель» и «Настройки» чуть уже.
   Правая колонка: «Размеры модели / Цвет / Стоимость / Поворот» возвращена к ширине до v256. */
@media (min-width: 981px) {
  body.builder-page .maker-layout--builder,
  body.user-mode.builder-page .maker-layout--builder {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr) !important;
    gap: 14px !important;
  }

  body.builder-page,
  body.user-mode.builder-page {
    --viewer-side-card-width: 218px !important;
    --viewer-desktop-side-card-width: 218px !important;
    --viewer-desktop-side-right-gap: 12px !important;
    --viewer-window-side-gap: 12px !important;
  }

  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(560px, 1fr) calc(var(--viewer-desktop-side-card-width) + var(--viewer-desktop-side-right-gap)) !important;
    column-gap: 0 !important;
  }

  body.builder-page .dimension-hud,
  body.user-mode.builder-page .dimension-hud,
  body.builder-page .dimension-hud.hidden,
  body.user-mode.builder-page .dimension-hud.hidden,
  body.builder-page .viewer-color-palette,
  body.user-mode.builder-page .viewer-color-palette,
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay,
  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    width: var(--viewer-desktop-side-card-width) !important;
    max-width: var(--viewer-desktop-side-card-width) !important;
    justify-self: start !important;
    margin-left: 0 !important;
    margin-right: var(--viewer-desktop-side-right-gap) !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer,
  body.builder-page #viewer-dimensions,
  body.user-mode.builder-page #viewer-dimensions,
  body.builder-page .viewer-dimensions,
  body.user-mode.builder-page .viewer-dimensions {
    width: calc(100% - (var(--viewer-window-side-gap) * 2)) !important;
    margin-left: var(--viewer-window-side-gap) !important;
    margin-right: var(--viewer-window-side-gap) !important;
  }
}

/* === V258: ПК — джойстик по центру свободной зоны под стоимостью ===
   Только desktop >=981px. Мобильную/планшетную версию не трогаем.
   Правая колонка: Размеры -> Цвет -> Стоимость -> свободная зона с джойстиком по центру. */
@media (min-width: 981px) {
  body.builder-page .viewer-card--builder,
  body.user-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(560px, 1fr) calc(var(--viewer-desktop-side-card-width) + var(--viewer-desktop-side-right-gap)) !important;
    grid-template-rows: auto auto auto auto minmax(120px, 1fr) !important;
    grid-template-areas:
      "toolbar toolbar"
      "viewer sizes"
      "viewer colors"
      "viewer price"
      "viewer rotate" !important;
    column-gap: 0 !important;
    row-gap: 10px !important;
  }

  body.builder-page .viewer-rotation-control,
  body.user-mode.builder-page .viewer-rotation-control {
    grid-area: rotate !important;
    align-self: center !important;
    justify-self: start !important;
    width: var(--viewer-desktop-side-card-width) !important;
    max-width: var(--viewer-desktop-side-card-width) !important;
    margin-left: 0 !important;
    margin-right: var(--viewer-desktop-side-right-gap) !important;
  }

  body.builder-page #viewer,
  body.user-mode.builder-page #viewer {
    grid-area: viewer !important;
    align-self: stretch !important;
  }
}


/* === V259: плоский 2D-колокольчик уведомлений на всех устройствах ===
   Заменяет emoji-колокольчик на простой SVG без 3D-эмодзи, перспективы,
   поворотов, фильтров и декоративной глубины. */
body.builder-page .topbar-notification-btn .topbar-icon-btn__glyph,
body.user-mode.builder-page .topbar-notification-btn .topbar-icon-btn__glyph,
body.admin-mode.builder-page .topbar-notification-btn .topbar-icon-btn__glyph {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  font-size: 0 !important;
  line-height: 0 !important;
  transform: none !important;
  perspective: none !important;
  filter: none !important;
  text-shadow: none !important;
  box-shadow: none !important;
  background: transparent !important;
}
body.builder-page .topbar-notification-btn .bell2d-icon,
body.user-mode.builder-page .topbar-notification-btn .bell2d-icon,
body.admin-mode.builder-page .topbar-notification-btn .bell2d-icon {
  display: block !important;
  width: 22px !important;
  height: 22px !important;
  fill: currentColor !important;
  stroke: none !important;
  transform: none !important;
  filter: none !important;
  backface-visibility: visible !important;
}
body.builder-page .topbar-notification-btn,
body.user-mode.builder-page .topbar-notification-btn,
body.admin-mode.builder-page .topbar-notification-btn {
  transform-style: flat !important;
}
body.builder-page .topbar-notification-btn:hover,
body.user-mode.builder-page .topbar-notification-btn:hover,
body.admin-mode.builder-page .topbar-notification-btn:hover {
  transform: none !important;
}
@media (max-width: 760px) {
  body.builder-page .topbar-notification-btn .bell2d-icon,
  body.user-mode.builder-page .topbar-notification-btn .bell2d-icon,
  body.admin-mode.builder-page .topbar-notification-btn .bell2d-icon {
    width: 20px !important;
    height: 20px !important;
  }
}


/* === V260: жёлтый 2D-колокольчик уведомлений === */
body.builder-page .topbar-notification-btn,
body.user-mode.builder-page .topbar-notification-btn,
body.admin-mode.builder-page .topbar-notification-btn {
  color: #facc15 !important;
}
body.builder-page .topbar-notification-btn .bell2d-icon,
body.user-mode.builder-page .topbar-notification-btn .bell2d-icon,
body.admin-mode.builder-page .topbar-notification-btn .bell2d-icon {
  fill: #facc15 !important;
}
body.builder-page .topbar-notification-btn:hover,
body.user-mode.builder-page .topbar-notification-btn:hover,
body.admin-mode.builder-page .topbar-notification-btn:hover {
  color: #fde047 !important;
}
body.builder-page .topbar-notification-btn:hover .bell2d-icon,
body.user-mode.builder-page .topbar-notification-btn:hover .bell2d-icon,
body.admin-mode.builder-page .topbar-notification-btn:hover .bell2d-icon {
  fill: #fde047 !important;
}

/* === V261: окно входа/регистрации клиента строго по центру экрана ===
   Ранее общий мобильный/пользовательский режим сдвигал все модальные окна к верху.
   Для кнопки «Войти» возвращаем центрирование именно customer-auth-modal. */
body.builder-page #customer-auth-modal:not(.hidden),
body.user-mode.builder-page #customer-auth-modal:not(.hidden),
body.admin-mode.builder-page #customer-auth-modal:not(.hidden) {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  place-items: center !important;
  padding: 16px !important;
  overflow: auto !important;
  -webkit-overflow-scrolling: touch !important;
}
body.builder-page #customer-auth-modal .modal__dialog,
body.user-mode.builder-page #customer-auth-modal .modal__dialog,
body.admin-mode.builder-page #customer-auth-modal .modal__dialog {
  margin: auto !important;
  max-height: calc(100vh - 32px) !important;
  max-height: calc(100dvh - 32px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
@media (max-width: 760px) {
  body.builder-page #customer-auth-modal:not(.hidden),
  body.user-mode.builder-page #customer-auth-modal:not(.hidden),
  body.admin-mode.builder-page #customer-auth-modal:not(.hidden) {
    padding: 10px !important;
    align-items: center !important;
    justify-content: center !important;
  }
  body.builder-page #customer-auth-modal .modal__dialog,
  body.user-mode.builder-page #customer-auth-modal .modal__dialog,
  body.admin-mode.builder-page #customer-auth-modal .modal__dialog {
    width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    margin: auto !important;
  }
}


/* === V262: все всплывающие окна строго по центру экрана ===
   Применяется ко всем модальным окнам: вход, регистрация, профиль, мои заказы,
   мои дизайны, сравнение, ссылка, горячие кнопки, оформление заказа,
   уведомления и админские окна. Окно центрируется, а содержимое прокручивается
   внутри диалога, если оно выше экрана. */
html body .modal:not(.hidden),
html body.builder-page .modal:not(.hidden),
html body.user-mode.builder-page .modal:not(.hidden),
html body.admin-mode.builder-page .modal:not(.hidden) {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  place-items: center !important;
  padding: 18px !important;
  overflow: auto !important;
  -webkit-overflow-scrolling: touch !important;
  box-sizing: border-box !important;
}

html body .modal.hidden,
html body.builder-page .modal.hidden,
html body.user-mode.builder-page .modal.hidden,
html body.admin-mode.builder-page .modal.hidden {
  display: none !important;
}

html body .modal:not(.hidden) > .modal__dialog,
html body.builder-page .modal:not(.hidden) > .modal__dialog,
html body.user-mode.builder-page .modal:not(.hidden) > .modal__dialog,
html body.admin-mode.builder-page .modal:not(.hidden) > .modal__dialog,
html body .modal:not(.hidden) .modal__dialog,
html body.builder-page .modal:not(.hidden) .modal__dialog,
html body.user-mode.builder-page .modal:not(.hidden) .modal__dialog,
html body.admin-mode.builder-page .modal:not(.hidden) .modal__dialog {
  margin: auto !important;
  max-height: calc(100vh - 36px) !important;
  max-height: calc(100dvh - 36px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  align-self: center !important;
  justify-self: center !important;
  box-sizing: border-box !important;
}

/* Крупные админские/заказные окна тоже центрируем, но не даём им вылезать за экран. */
html body .modal:not(.hidden) .modal__dialog--admin-window,
html body .modal:not(.hidden) .modal__dialog--admin-wide,
html body .modal:not(.hidden) .modal__dialog--checkout,
html body .modal:not(.hidden) .modal__dialog--orders,
html body .modal:not(.hidden) .modal__dialog--compare-designs,
html body .modal:not(.hidden) .modal__dialog--saved-designs {
  max-height: calc(100vh - 36px) !important;
  max-height: calc(100dvh - 36px) !important;
  margin-top: auto !important;
  margin-bottom: auto !important;
}

@media (max-width: 760px) {
  html body .modal:not(.hidden),
  html body.builder-page .modal:not(.hidden),
  html body.user-mode.builder-page .modal:not(.hidden),
  html body.admin-mode.builder-page .modal:not(.hidden) {
    align-items: center !important;
    justify-content: center !important;
    place-items: center !important;
    padding: 10px !important;
  }

  html body .modal:not(.hidden) > .modal__dialog,
  html body.builder-page .modal:not(.hidden) > .modal__dialog,
  html body.user-mode.builder-page .modal:not(.hidden) > .modal__dialog,
  html body.admin-mode.builder-page .modal:not(.hidden) > .modal__dialog,
  html body .modal:not(.hidden) .modal__dialog,
  html body.builder-page .modal:not(.hidden) .modal__dialog,
  html body.user-mode.builder-page .modal:not(.hidden) .modal__dialog,
  html body.admin-mode.builder-page .modal:not(.hidden) .modal__dialog {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    margin: auto !important;
  }
}

/* === v263 COLOR SWATCH BLACK OUTLINE ===
   Все цветовые маркеры получили чёрную обводку, чтобы белый цвет
   был виден на светлом фоне и внутри модальных окон. */
.color-swatch__dot,
.viewer-color-palette .color-swatch__dot,
.checkout-color-dot,
.checkout-color-swatch span,
.compare-card__color {
  border: 2px solid #050505 !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.38),
    0 3px 10px rgba(0,0,0,0.25) !important;
  box-sizing: border-box !important;
}

.viewer-color-palette .color-swatch {
  border: 1px solid rgba(5,5,5,0.88) !important;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.22) !important;
}

.color-swatch.is-active .color-swatch__dot,
.viewer-color-palette .color-swatch.is-active .color-swatch__dot,
.checkout-color-swatch.is-active span {
  border-color: #000 !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.50),
    0 0 0 4px rgba(30,168,255,0.22),
    0 5px 14px rgba(0,0,0,0.28) !important;
}


/* === v264 LIGHT THEME CONTRAST + COLOR PANEL CLEANUP ===
   Убирает серый/тёмный фон в выборе цвета на светлой теме и усиливает
   читаемость текста, полей, карточек и модальных окон на белом фоне.
   Тёмная тема не меняется. */
body[data-theme="light"] {
  --bg: #f3f6fb !important;
  --panel: #ffffff !important;
  --panel-2: #f8fafc !important;
  --panel-3: #eef2f7 !important;
  --border: rgba(15, 23, 42, 0.16) !important;
  --text: #0f172a !important;
  --muted: #475569 !important;
  --soft: #64748b !important;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%) !important;
  color: #0f172a !important;
}

/* Основные окна и карточки на белой теме — белые, без мутного серого слоя. */
body[data-theme="light"] .topbar,
body[data-theme="light"] .admin-toolbar,
body[data-theme="light"] .mw-card,
body[data-theme="light"] .panel,
body[data-theme="light"] .subpanel,
body[data-theme="light"] .builder-card,
body[data-theme="light"] .modal__dialog,
body[data-theme="light"] .info-card,
body[data-theme="light"] .success-card,
body[data-theme="light"] .auth-card,
body[data-theme="light"] .auth-card--premium,
body[data-theme="light"] .material-panel,
body[data-theme="light"] .summary-card,
body[data-theme="light"] .form-group,
body[data-theme="light"] .stat-card,
body[data-theme="light"] .checkout-card,
body[data-theme="light"] .checkout-step,
body[data-theme="light"] .checkout-legal,
body[data-theme="light"] .config-smart-panel,
body[data-theme="light"] .compare-card,
body[data-theme="light"] .orders-stat,
body[data-theme="light"] .orders-board-column,
body[data-theme="light"] .orders-board-card,
body[data-theme="light"] .doc-card {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.14) !important;
  box-shadow: 0 16px 42px rgba(15, 23, 42, 0.10) !important;
}

/* Вторичные строки/поля: светлый фон, контрастный текст. */
body[data-theme="light"] .selected-model,
body[data-theme="light"] .template-item,
body[data-theme="light"] .display-part-toggle,
body[data-theme="light"] .display-chip,
body[data-theme="light"] .builder-nav__item,
body[data-theme="light"] .viewer-toolbar__btn,
body[data-theme="light"] .input,
body[data-theme="light"] .input--readonly,
body[data-theme="light"] .textarea,
body[data-theme="light"] select.input,
body[data-theme="light"] .pricing-row,
body[data-theme="light"] .pricing-select-group,
body[data-theme="light"] .price-breakdown__row,
body[data-theme="light"] .checkout-model-line,
body[data-theme="light"] .checkout-customer,
body[data-theme="light"] .checkout-spec,
body[data-theme="light"] .checkout-param-row,
body[data-theme="light"] .order-card__grid > div,
body[data-theme="light"] .draft-restore-summary,
body[data-theme="light"] .checkout-readiness,
body[data-theme="light"] .customer-model-mini,
body[data-theme="light"] .customer-model-strip__empty,
body[data-theme="light"] .config-preset-chip,
body[data-theme="light"] .config-smart-panel__facts span,
body[data-theme="light"] .orders-board-empty,
body[data-theme="light"] .orders-view-toggle {
  background: #f8fafc !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.14) !important;
}

body[data-theme="light"] .input:focus,
body[data-theme="light"] .textarea:focus,
body[data-theme="light"] select.input:focus {
  border-color: rgba(2, 132, 199, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.18) !important;
}

/* Заголовки, важные значения и обычный текст — читаемые на белом фоне. */
body[data-theme="light"] .brand__title,
body[data-theme="light"] .mw-card h2,
body[data-theme="light"] .panel h2,
body[data-theme="light"] .subpanel h2,
body[data-theme="light"] .modal__header h2,
body[data-theme="light"] .selected-model__name,
body[data-theme="light"] .template-item__title,
body[data-theme="light"] .form-group__title,
body[data-theme="light"] .material-panel__header,
body[data-theme="light"] .material-label,
body[data-theme="light"] .material-row__label,
body[data-theme="light"] .summary-card__value,
body[data-theme="light"] .checkout-model-line strong,
body[data-theme="light"] .checkout-spec strong,
body[data-theme="light"] .checkout-param-row b,
body[data-theme="light"] .checkout-customer__name,
body[data-theme="light"] .checkout-customer__row b,
body[data-theme="light"] .compare-card__price,
body[data-theme="light"] .orders-board-column header b,
body[data-theme="light"] .orders-board-card__top span,
body[data-theme="light"] .orders-stat b,
body[data-theme="light"] .config-smart-panel__top h3,
body[data-theme="light"] .config-smart-panel__facts b {
  color: #0f172a !important;
}

body[data-theme="light"] .brand__subtitle,
body[data-theme="light"] .mw-card p,
body[data-theme="light"] .panel p,
body[data-theme="light"] .subpanel p,
body[data-theme="light"] .selected-model__subtitle,
body[data-theme="light"] .template-item__meta,
body[data-theme="light"] .summary-card__label,
body[data-theme="light"] .stat-card__label,
body[data-theme="light"] .field small,
body[data-theme="light"] .field__hint-range,
body[data-theme="light"] .form-stack label,
body[data-theme="light"] .field label,
body[data-theme="light"] .checkout-model-line span,
body[data-theme="light"] .checkout-spec span,
body[data-theme="light"] .checkout-param-row span,
body[data-theme="light"] .checkout-customer__row,
body[data-theme="light"] .checkout-card__title,
body[data-theme="light"] .checkout-legal,
body[data-theme="light"] .config-smart-panel__status,
body[data-theme="light"] .catalog-model-card__price--muted {
  color: #475569 !important;
}

/* Кнопки на светлой теме. */
body[data-theme="light"] .btn--ghost,
body[data-theme="light"] .admin-toolbar__btn,
body[data-theme="light"] .modal__close,
body[data-theme="light"] .theme-toggle-btn,
body[data-theme="light"] .topbar-icon-btn,
body[data-theme="light"] .viewer-toolbar__btn,
body[data-theme="light"] .builder-nav__item {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.16) !important;
}
body[data-theme="light"] .btn--ghost:hover,
body[data-theme="light"] .admin-toolbar__btn:hover,
body[data-theme="light"] .modal__close:hover,
body[data-theme="light"] .theme-toggle-btn:hover,
body[data-theme="light"] .topbar-icon-btn:hover,
body[data-theme="light"] .viewer-toolbar__btn:hover,
body[data-theme="light"] .builder-nav__item:hover {
  background: #f1f5f9 !important;
  border-color: rgba(2, 132, 199, 0.35) !important;
  color: #075985 !important;
}
body[data-theme="light"] .viewer-toolbar__btn.is-active,
body[data-theme="light"] .builder-nav__item.is-active,
body[data-theme="light"] .display-chip.is-active,
body[data-theme="light"] .config-preset-chip.is-primary {
  background: #e0f2fe !important;
  color: #075985 !important;
  border-color: rgba(2, 132, 199, 0.45) !important;
}

/* Выбор цвета: убираем серую подложку на светлом фоне. Белый цвет виден за счёт чёрной обводки. */
body[data-theme="light"] .viewer-color-palette,
body[data-theme="light"] .material-panel .color-swatches,
body[data-theme="light"] #model-color-swatches {
  background: transparent !important;
  box-shadow: none !important;
}
body[data-theme="light"] .viewer-color-palette {
  border-color: rgba(15,23,42,0.14) !important;
}
body[data-theme="light"] .color-swatch,
body[data-theme="light"] .viewer-color-palette .color-swatch,
body[data-theme="light"] .checkout-color-swatch {
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,0.18) !important;
  box-shadow: none !important;
}
body[data-theme="light"] .color-swatch:hover,
body[data-theme="light"] .viewer-color-palette .color-swatch:hover,
body[data-theme="light"] .checkout-color-swatch:hover {
  background: #f8fafc !important;
  border-color: rgba(2,132,199,0.38) !important;
}
body[data-theme="light"] .color-swatch.is-active,
body[data-theme="light"] .viewer-color-palette .color-swatch.is-active,
body[data-theme="light"] .checkout-color-swatch.is-active {
  background: #eff6ff !important;
  border-color: rgba(2,132,199,0.55) !important;
  color: #075985 !important;
}
body[data-theme="light"] .color-swatch__label,
body[data-theme="light"] .viewer-color-palette .color-swatch__label {
  color: #0f172a !important;
}
body[data-theme="light"] .color-swatch__dot,
body[data-theme="light"] .viewer-color-palette .color-swatch__dot,
body[data-theme="light"] .checkout-color-dot,
body[data-theme="light"] .checkout-color-swatch span,
body[data-theme="light"] .compare-card__color {
  border: 2px solid #000000 !important;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.75), 0 2px 8px rgba(15,23,42,0.18) !important;
}

/* JSON/кодовые блоки и предупреждения читаемы на светлой теме. */
body[data-theme="light"] .json-preview,
body[data-theme="light"] .code-card--compact pre {
  background: #f8fafc !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,0.14) !important;
}
body[data-theme="light"] .empty-state,
body[data-theme="light"] .info-card--soft {
  background: #f8fafc !important;
  color: #475569 !important;
  border-color: rgba(15,23,42,0.14) !important;
}

/* Тёмная 3D-сцена сохраняется, но подписи/оверлеи на ней читаются. */
body[data-theme="light"] #viewer,
body[data-theme="light"] #viewer.viewer--three {
  background: radial-gradient(circle at 50% 14%, #eaf1f9 0%, #d9e3ee 46%, #cbd5e1 100%) !important;
}
body[data-theme="light"] .viewer-help span,
body[data-theme="light"] .viewer-toolbar__pill,
body[data-theme="light"] .viewer-badge,
body[data-theme="light"] .viewer-order-overlay,
body[data-theme="light"] .viewer-dimensions__label {
  background: rgba(255,255,255,0.92) !important;
  color: #0f172a !important;
  border-color: rgba(15,23,42,0.16) !important;
}

/* === v265: светлая тема — видимые Отменить/Вернуть и Да/Нет ===
   Исправляет невидимые стрелки истории на белом фоне и нечитаемые подписи
   переключателя «Сохранять пропорции». Также усиливает контраст кнопок
   «Отменить» и «Вернуть» в заказах/админке. */
body[data-theme="light"].builder-page #undo-config-btn::after,
body[data-theme="light"].builder-page #redo-config-btn::after,
body[data-theme="light"] #undo-config-btn::after,
body[data-theme="light"] #redo-config-btn::after {
  color: #0f172a !important;
  text-shadow: none !important;
}

body[data-theme="light"].builder-page #undo-config-btn:not(:disabled),
body[data-theme="light"].builder-page #redo-config-btn:not(:disabled),
body[data-theme="light"] #undo-config-btn:not(:disabled),
body[data-theme="light"] #redo-config-btn:not(:disabled) {
  background: #ffffff !important;
  border-color: rgba(15, 23, 42, 0.22) !important;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.10) !important;
}

body[data-theme="light"].builder-page #undo-config-btn:not(:disabled):hover,
body[data-theme="light"].builder-page #redo-config-btn:not(:disabled):hover,
body[data-theme="light"] #undo-config-btn:not(:disabled):hover,
body[data-theme="light"] #redo-config-btn:not(:disabled):hover {
  background: #e0f2fe !important;
  border-color: rgba(2, 132, 199, 0.45) !important;
}

body[data-theme="light"].builder-page #undo-config-btn:disabled::after,
body[data-theme="light"].builder-page #redo-config-btn:disabled::after,
body[data-theme="light"].builder-page #undo-config-btn.is-disabled::after,
body[data-theme="light"].builder-page #redo-config-btn.is-disabled::after,
body[data-theme="light"] #undo-config-btn:disabled::after,
body[data-theme="light"] #redo-config-btn:disabled::after,
body[data-theme="light"] #undo-config-btn.is-disabled::after,
body[data-theme="light"] #redo-config-btn.is-disabled::after {
  color: #64748b !important;
  opacity: .86 !important;
}

/* Заказные кнопки «Отменить» и «Вернуть» должны быть видны на белом фоне. */
body[data-theme="light"] button[data-order-quick-status="cancelled"],
body[data-theme="light"] button[data-order-archive],
body[data-theme="light"] .orders-board-card button[data-order-quick-status="cancelled"],
body[data-theme="light"] .orders-board-card button[data-order-archive],
body[data-theme="light"] .request-card button[data-order-quick-status="cancelled"],
body[data-theme="light"] .request-card button[data-order-archive] {
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15, 23, 42, 0.24) !important;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08) !important;
}
body[data-theme="light"] button[data-order-quick-status="cancelled"] {
  color: #991b1b !important;
  border-color: rgba(185, 28, 28, 0.32) !important;
  background: #fff7f7 !important;
}
body[data-theme="light"] button[data-order-quick-status="cancelled"]:hover {
  color: #7f1d1d !important;
  border-color: rgba(185, 28, 28, 0.48) !important;
  background: #fee2e2 !important;
}
body[data-theme="light"] button[data-order-archive]:hover {
  color: #075985 !important;
  border-color: rgba(2, 132, 199, 0.42) !important;
  background: #e0f2fe !important;
}

/* Переключатели «Да / Нет» в настройках модели. */
body[data-theme="light"].builder-page .field .toggle,
body[data-theme="light"].builder-page .toggle,
body[data-theme="light"] .field .toggle,
body[data-theme="light"] .toggle {
  color: #0f172a !important;
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.16) !important;
  border-radius: 12px !important;
  padding: 6px 9px !important;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.07) !important;
}
body[data-theme="light"].builder-page .field .toggle span,
body[data-theme="light"].builder-page .toggle span,
body[data-theme="light"] .field .toggle span,
body[data-theme="light"] .toggle span {
  color: #0f172a !important;
  font-weight: 800 !important;
  letter-spacing: .01em !important;
}
body[data-theme="light"].builder-page .toggle input[type="checkbox"],
body[data-theme="light"] .toggle input[type="checkbox"] {
  accent-color: #0284c7 !important;
  outline: 1px solid rgba(15, 23, 42, 0.28) !important;
  outline-offset: 1px !important;
}


/* === v266: Да/Нет без рамки + стабильный блок стоимости ===
   Убираем лишнюю обводку/подложку у переключателя «Сохранять пропорции»,
   но оставляем текст читаемым на светлой теме. Блок стоимости получает
   стабильную высоту и табличные цифры, чтобы не дёргался при пересчёте. */
body[data-theme="light"].builder-page .field .toggle,
body[data-theme="light"].builder-page .toggle,
body[data-theme="light"] .field .toggle,
body[data-theme="light"] .toggle {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  color: #0f172a !important;
}
body[data-theme="light"].builder-page .field .toggle span,
body[data-theme="light"].builder-page .toggle span,
body[data-theme="light"] .field .toggle span,
body[data-theme="light"] .toggle span {
  color: #0f172a !important;
  font-weight: 800 !important;
}
body[data-theme="light"].builder-page .toggle input[type="checkbox"],
body[data-theme="light"] .toggle input[type="checkbox"] {
  accent-color: #0284c7 !important;
  outline: none !important;
  box-shadow: none !important;
}

body.builder-page .viewer-order-overlay,
body.user-mode.builder-page .viewer-order-overlay {
  min-height: 138px !important;
  box-sizing: border-box !important;
  contain: layout paint !important;
}
body.builder-page .viewer-order-overlay__value,
body.user-mode.builder-page .viewer-order-overlay__value {
  min-height: 30px !important;
  display: flex !important;
  align-items: center !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
  line-height: 1 !important;
}
body.builder-page .viewer-order-overlay__hint,
body.user-mode.builder-page .viewer-order-overlay__hint,
body.builder-page .price-breakdown--compact,
body.user-mode.builder-page .price-breakdown--compact {
  min-height: 16px !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}
body.builder-page .viewer-order-overlay__button,
body.user-mode.builder-page .viewer-order-overlay__button {
  min-height: 40px !important;
}
@media (max-width: 760px) {
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay {
    min-height: 136px !important;
  }
}

/* === v267: тёмная тема — убрать лишние внутренние рамки полей настроек ===
   В светлой теме поля настроек выглядят без отдельных карточек. В тёмной теме
   убираем внутреннюю обводку у строк Ширина / Высота / Глубина / Сохранение
   пропорций / Поворот X, оставляя сами поля ввода и подписи читаемыми. */
body.builder-page:not([data-theme="light"]) #dynamic-form .field,
body[data-theme="dark"].builder-page #dynamic-form .field {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 4px 0 !important;
  border-radius: 0 !important;
}

body.builder-page:not([data-theme="light"]) #dynamic-form .field label,
body[data-theme="dark"].builder-page #dynamic-form .field label,
body.builder-page:not([data-theme="light"]) #dynamic-form .field__label,
body[data-theme="dark"].builder-page #dynamic-form .field__label {
  color: rgba(226, 232, 240, 0.82) !important;
}

body.builder-page:not([data-theme="light"]) #dynamic-form .field small,
body[data-theme="dark"].builder-page #dynamic-form .field small,
body.builder-page:not([data-theme="light"]) #dynamic-form .field__hint-range,
body[data-theme="dark"].builder-page #dynamic-form .field__hint-range {
  color: rgba(148, 163, 184, 0.82) !important;
}

body.builder-page:not([data-theme="light"]) #dynamic-form .toggle,
body[data-theme="dark"].builder-page #dynamic-form .toggle {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: rgba(226, 232, 240, 0.86) !important;
}

body.builder-page:not([data-theme="light"]) #dynamic-form .toggle span,
body[data-theme="dark"].builder-page #dynamic-form .toggle span {
  color: rgba(226, 232, 240, 0.86) !important;
  font-weight: 800 !important;
}


/* === v268: Стоимость + вес изделия без расчёта и без дёргания ===
   В карточке стоимости оставляем только итоговую стоимость и вес изделия.
   Расчёт вида «г × ₽/г» и подробная разбивка скрыты. Карточка имеет
   стабильную геометрию, чтобы переключатель «Да / Нет» не сдвигал layout. */
body.builder-page .viewer-order-overlay,
body.user-mode.builder-page .viewer-order-overlay {
  min-height: 128px !important;
  height: 128px !important;
  max-height: 128px !important;
  display: grid !important;
  grid-template-rows: 14px 34px 20px 40px !important;
  align-content: start !important;
  gap: 6px !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  contain: layout paint size !important;
}
body.builder-page .viewer-order-overlay__label,
body.user-mode.builder-page .viewer-order-overlay__label {
  min-height: 14px !important;
  line-height: 14px !important;
}
body.builder-page .viewer-order-overlay__value,
body.user-mode.builder-page .viewer-order-overlay__value {
  min-height: 34px !important;
  height: 34px !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}
body.builder-page .viewer-order-overlay__hint,
body.user-mode.builder-page .viewer-order-overlay__hint {
  min-height: 20px !important;
  height: 20px !important;
  line-height: 20px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}
body.builder-page .price-breakdown--compact,
body.user-mode.builder-page .price-breakdown--compact {
  display: none !important;
}
body.builder-page .viewer-order-overlay__button,
body.user-mode.builder-page .viewer-order-overlay__button {
  min-height: 40px !important;
  height: 40px !important;
  align-self: end !important;
  white-space: nowrap !important;
}
@media (max-width: 760px) {
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay {
    height: auto !important;
    max-height: none !important;
    min-height: 122px !important;
    grid-template-rows: auto auto auto auto !important;
    overflow: visible !important;
    contain: layout paint !important;
  }
}

/* === v269: нормализация окна «Стоимость» — кнопка всегда видна ===
   После удаления расчёта оставляем только стоимость + вес изделия + кнопку.
   Карточка не обрезает содержимое и сохраняет стабильную геометрию при
   переключении «Да / Нет». */
body.builder-page .viewer-order-overlay,
body.user-mode.builder-page .viewer-order-overlay {
  min-height: 156px !important;
  height: auto !important;
  max-height: none !important;
  display: grid !important;
  grid-template-rows: 14px 34px 20px 40px !important;
  align-content: start !important;
  gap: 8px !important;
  padding: 12px !important;
  overflow: visible !important;
  box-sizing: border-box !important;
  contain: layout paint !important;
}
body.builder-page .viewer-order-overlay__label,
body.user-mode.builder-page .viewer-order-overlay__label {
  height: 14px !important;
  min-height: 14px !important;
  line-height: 14px !important;
  margin: 0 !important;
}
body.builder-page .viewer-order-overlay__value,
body.user-mode.builder-page .viewer-order-overlay__value {
  height: 34px !important;
  min-height: 34px !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  white-space: nowrap !important;
}
body.builder-page .viewer-order-overlay__hint,
body.user-mode.builder-page .viewer-order-overlay__hint {
  height: 20px !important;
  min-height: 20px !important;
  margin: 0 !important;
  line-height: 20px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
body.builder-page .price-breakdown--compact,
body.user-mode.builder-page .price-breakdown--compact {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.builder-page .viewer-order-overlay__button,
body.user-mode.builder-page .viewer-order-overlay__button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 40px !important;
  min-height: 40px !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  white-space: nowrap !important;
  overflow: visible !important;
}
@media (max-width: 760px) {
  body.builder-page .viewer-order-overlay,
  body.user-mode.builder-page .viewer-order-overlay {
    min-height: 148px !important;
    grid-template-rows: auto auto auto auto !important;
  }
}


/* v270: светлая тема — размерные стрелки на модели чёрные, проверка регистрации светлая */
body[data-theme="light"].builder-page .viewer-dimensions__line--arrow,
body[data-theme="light"].builder-page .viewer-dimensions__line,
body[data-theme="light"].builder-page .viewer-dimensions__guide,
body[data-theme="light"].builder-page .viewer-dimensions__tick {
  stroke: rgba(15, 23, 42, 0.92) !important;
  opacity: 0.96 !important;
}

body[data-theme="light"] .captcha-box,
body[data-theme="light"].builder-page #customer-auth-modal .captcha-box {
  background: #ffffff !important;
  border-color: rgba(15, 23, 42, 0.14) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08) !important;
  color: #0f172a !important;
}

body[data-theme="light"] .captcha-box__label,
body[data-theme="light"].builder-page #customer-auth-modal .captcha-box__label {
  color: #475569 !important;
}

body[data-theme="light"] .captcha-box__question,
body[data-theme="light"].builder-page #customer-auth-modal .captcha-box__question {
  background: #f8fafc !important;
  border-color: rgba(15, 23, 42, 0.16) !important;
  color: #0f172a !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 4px 12px rgba(15, 23, 42, 0.06) !important;
}

body[data-theme="light"] .captcha-box input,
body[data-theme="light"].builder-page #customer-auth-modal .captcha-box input {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.18) !important;
}

/* v271: светлая тема — заголовок «Стоимость» в карточке стоимости чёрный */
body[data-theme="light"].builder-page .viewer-order-overlay__label,
body[data-theme="light"].user-mode.builder-page .viewer-order-overlay__label,
body.light.builder-page .viewer-order-overlay__label,
body.light.user-mode.builder-page .viewer-order-overlay__label {
  color: #0f172a !important;
  opacity: 1 !important;
}


/* === v272: общий фикс светлой темы, верхней панели и мобильных подписей ===
   1) Светлая тема применяется на всех страницах, включая документы, вход и восстановление пароля.
   2) Кнопка выбора темы не проваливается под «Войти».
   3) Удалены старые CSS-подписи, из-за которых в бургере было «ВойтиВход» и «РегистрацияРег».
   4) Ссылки «Согласие · Политика» — жирные и синие. */

html[data-theme="light"],
html[data-theme="light"] body,
body[data-theme="light"] {
  background: #ffffff !important;
  color: #0f172a !important;
}

html[data-theme="light"] body::before,
body[data-theme="light"]::before {
  background: #ffffff !important;
}

body[data-theme="light"] .doc-page,
body[data-theme="light"] .auth-page,
body[data-theme="light"] .auth-page--premium,
body[data-theme="light"] main,
body[data-theme="light"].document-page,
body[data-theme="light"].user-mode.document-page {
  background: #ffffff !important;
  color: #0f172a !important;
}

body[data-theme="light"] .auth-shell,
body[data-theme="light"] .auth-card,
body[data-theme="light"] .auth-card--premium,
body[data-theme="light"] .reset-link-card,
body[data-theme="light"] .doc-card,
body[data-theme="light"] .modal__dialog {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15,23,42,.14) !important;
}

body[data-theme="light"] .auth-form label span,
body[data-theme="light"] .auth-card p,
body[data-theme="light"] .doc-card p,
body[data-theme="light"] .doc-section p,
body[data-theme="light"] .reset-link-card p {
  color: #334155 !important;
}

body[data-theme="light"] .auth-card h1,
body[data-theme="light"] .auth-card h2,
body[data-theme="light"] .doc-card h1,
body[data-theme="light"] .doc-section h2,
body[data-theme="light"] .reset-link-card__title {
  color: #0f172a !important;
}

/* Верхняя панель: бренд слева, справа одна строка — уведомления/тема/вход. */
.topbar__right-cluster {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  margin-left: auto !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}
.topbar__quick-actions {
  order: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
}
.topbar__actions {
  order: 2 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
}
.theme-toggle-btn,
.topbar-icon-btn,
.mobile-menu-toggle {
  flex: 0 0 auto !important;
}

/* Убираем старые псевдоподписи: они дублировали текст кнопок в мобильном меню. */
#open-login-modal-btn::after,
#open-register-modal-btn::after,
body.user-mode.builder-page #open-login-modal-btn::after,
body.user-mode.builder-page #open-register-modal-btn::after {
  content: none !important;
  display: none !important;
}

/* Согласие и политика — заметные ссылки. */
.checkbox-line a,
.checkout-legal a,
.auth-form a[href*="personal"],
.auth-form a[href*="privacy"],
a[href*="personal-data-consent"],
a[href*="privacy"] {
  color: #0b63ce !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}
.checkbox-line a:hover,
.checkout-legal a:hover,
a[href*="personal-data-consent"]:hover,
a[href*="privacy"]:hover {
  color: #084aa0 !important;
  text-decoration: underline !important;
}

body[data-theme="light"] .checkbox-line a,
body[data-theme="light"] .checkout-legal a,
body[data-theme="light"] a[href*="personal-data-consent"],
body[data-theme="light"] a[href*="privacy"] {
  color: #075ec4 !important;
}

@media (max-width: 760px) {
  .topbar {
    flex-wrap: nowrap !important;
    align-items: center !important;
  }
  .brand {
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }
  .topbar__right-cluster {
    flex: 0 0 auto !important;
    gap: 6px !important;
  }
  .topbar__quick-actions {
    position: static !important;
    gap: 6px !important;
  }
  .topbar__actions {
    display: none !important;
    position: absolute !important;
    top: calc(100% + 8px) !important;
    right: 8px !important;
    left: 8px !important;
    z-index: 80 !important;
    width: auto !important;
    padding: 10px !important;
    border-radius: 16px !important;
    background: var(--panel, #17181c) !important;
    border: 1px solid var(--border, rgba(255,255,255,.10)) !important;
    box-shadow: 0 18px 46px rgba(0,0,0,.22) !important;
  }
  .topbar.is-menu-open .topbar__actions {
    display: block !important;
  }
  .customer-topbar,
  .customer-topbar__guest,
  .customer-topbar__auth {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .customer-topbar__guest.hidden,
  .customer-topbar__auth.hidden {
    display: none !important;
  }
  .customer-topbar .btn,
  .customer-topbar .pill {
    width: 100% !important;
    justify-content: center !important;
    white-space: nowrap !important;
  }
  body[data-theme="light"] .topbar__actions {
    background: #ffffff !important;
    border-color: rgba(15,23,42,.14) !important;
    box-shadow: 0 18px 46px rgba(15,23,42,.14) !important;
  }
}


/* v273: окно входа/регистрации — вверху показывается только переход в противоположный режим. */
body.builder-page #customer-auth-modal .auth-switcher {
  justify-content: flex-end;
  min-height: 38px;
}
body.builder-page #customer-auth-modal .auth-switcher .btn.hidden {
  display: none !important;
}
body.builder-page #customer-auth-modal .auth-switcher .btn {
  white-space: nowrap;
}

/* v274: кнопка переключения Вход/Регистрация в модальном окне по центру. */
body.builder-page #customer-auth-modal .auth-switcher,
#customer-auth-modal .auth-switcher {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 38px !important;
  padding-left: 14px !important;
  padding-right: 14px !important;
  text-align: center !important;
}
body.builder-page #customer-auth-modal .auth-switcher .btn.hidden,
#customer-auth-modal .auth-switcher .btn.hidden {
  display: none !important;
}
body.builder-page #customer-auth-modal .auth-switcher .btn,
#customer-auth-modal .auth-switcher .btn {
  flex: 0 0 auto !important;
  min-width: 132px !important;
  justify-content: center !important;
  text-align: center !important;
  white-space: nowrap !important;
}
@media (max-width: 560px) {
  body.builder-page #customer-auth-modal .auth-switcher .btn,
  #customer-auth-modal .auth-switcher .btn {
    min-width: 128px !important;
    max-width: 100% !important;
  }
}

/* === v276 ADMIN NORMALIZATION + SAFE MODEL DELETE ===
   Отдельный слой для админки: панели не уезжают за экран, длинные строки
   переносятся, модальные окна центрируются, удаление модели выглядит как
   нормальное подтверждение вместо системного окна браузера. */
body.admin-mode,
body.admin-mode.builder-page {
  overflow-x: hidden !important;
}

body.admin-mode.builder-page .admin-toolbar {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: min(100% - 24px, 1320px) !important;
  margin: 10px auto 12px !important;
  padding: 10px !important;
  border-radius: 18px !important;
  overflow: visible !important;
  scrollbar-width: none !important;
  box-sizing: border-box !important;
}
body.admin-mode.builder-page .admin-toolbar::-webkit-scrollbar { display: none !important; }
body.admin-mode.builder-page .admin-toolbar__btn {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  min-height: 38px !important;
  max-width: 190px !important;
  padding: 9px 12px !important;
  white-space: normal !important;
  text-align: center !important;
  line-height: 1.15 !important;
}

body.admin-mode .admin-panel-modal:not(.hidden),
body.admin-mode #admin-upload-model-modal:not(.hidden),
body.admin-mode .xab-confirm-modal:not(.hidden),
body.admin-mode .xab-confirm-modal {
  display: grid !important;
  place-items: center !important;
  padding: 18px !important;
  overflow: hidden !important;
}
body.admin-mode .admin-panel-modal .modal__dialog,
body.admin-mode #admin-upload-model-modal .modal__dialog,
body.admin-mode .xab-confirm-modal .modal__dialog {
  margin: auto !important;
  max-height: calc(100dvh - 36px) !important;
  overflow: auto !important;
  box-sizing: border-box !important;
}
body.admin-mode .modal__dialog--admin-wide {
  width: min(1240px, calc(100vw - 36px)) !important;
  max-width: calc(100vw - 36px) !important;
}
body.admin-mode .modal__dialog--admin-medium,
body.admin-mode .modal__dialog--admin-upload {
  width: min(940px, calc(100vw - 36px)) !important;
  max-width: calc(100vw - 36px) !important;
}
body.admin-mode .modal__dialog--admin-small {
  width: min(680px, calc(100vw - 36px)) !important;
  max-width: calc(100vw - 36px) !important;
}

body.admin-mode .admin-window__body,
body.admin-mode .modal__dialog--admin-window .admin-window__body {
  display: grid !important;
  gap: 14px !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
}
body.admin-mode .admin-panel-modal .modal__header,
body.admin-mode #admin-upload-model-modal .modal__header,
body.admin-mode .xab-confirm-modal .modal__header {
  align-items: flex-start !important;
  gap: 12px !important;
}
body.admin-mode .admin-panel-modal .modal__header > div,
body.admin-mode #admin-upload-model-modal .modal__header > div,
body.admin-mode .xab-confirm-modal .modal__header > div {
  min-width: 0 !important;
}
body.admin-mode .admin-panel-modal .modal__header h2,
body.admin-mode #admin-upload-model-modal .modal__header h2,
body.admin-mode .xab-confirm-modal .modal__header h2,
body.admin-mode .admin-window__subtitle {
  overflow-wrap: anywhere !important;
}
body.admin-mode .admin-panel-modal p,
body.admin-mode .admin-panel-modal span,
body.admin-mode .admin-panel-modal b,
body.admin-mode .admin-panel-modal strong,
body.admin-mode .admin-panel-modal a,
body.admin-mode #admin-upload-model-modal p,
body.admin-mode #admin-upload-model-modal span,
body.admin-mode #admin-upload-model-modal b,
body.admin-mode #admin-upload-model-modal strong,
body.admin-mode #admin-upload-model-modal a {
  overflow-wrap: anywhere !important;
}

body.admin-mode .production-toolbar,
body.admin-mode .orders-toolbar,
body.admin-mode .admin-upload-grid,
body.admin-mode .social-provider-grid,
body.admin-mode .performance-grid,
body.admin-mode .three-stack,
body.admin-mode .print-preflight-grid {
  min-width: 0 !important;
  max-width: 100% !important;
}
body.admin-mode .production-toolbar,
body.admin-mode .orders-toolbar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: stretch !important;
}
body.admin-mode .production-toolbar > *,
body.admin-mode .orders-toolbar > * {
  min-width: min(220px, 100%) !important;
  flex: 1 1 220px !important;
}
body.admin-mode .orders-view-toggle,
body.admin-mode .modal__actions,
body.admin-mode .inline-actions,
body.admin-mode .template-item__actions,
body.admin-mode .template-item__actions--admin {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-width: 0 !important;
}
body.admin-mode .inline-actions .btn,
body.admin-mode .template-item__actions .btn,
body.admin-mode .template-item__actions--admin .btn {
  min-width: 0 !important;
  flex: 0 1 auto !important;
  white-space: normal !important;
}
body.admin-mode .template-item,
body.admin-mode .request-card,
body.admin-mode .order-card,
body.admin-mode .production-card,
body.admin-mode .admin-design-project-card,
body.admin-mode .customer-card,
body.admin-mode .notification-card,
body.admin-mode .info-card,
body.admin-mode .hint-card,
body.admin-mode .subpanel {
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  overflow-wrap: anywhere !important;
  box-sizing: border-box !important;
}
body.admin-mode .template-item__title,
body.admin-mode .template-item__meta,
body.admin-mode .request-card__title,
body.admin-mode .order-card__title,
body.admin-mode .production-card__title {
  overflow-wrap: anywhere !important;
}
body.admin-mode .input,
body.admin-mode .textarea,
body.admin-mode select,
body.admin-mode textarea,
body.admin-mode input {
  max-width: 100% !important;
  box-sizing: border-box !important;
}
body.admin-mode .textarea--code,
body.admin-mode #admin-categories-input,
body.admin-mode #admin-material-profiles-input,
body.admin-mode #schema-json,
body.admin-mode #defaults-json {
  min-height: 220px !important;
  max-height: 52vh !important;
  overflow: auto !important;
  white-space: pre-wrap !important;
  word-break: break-word !important;
}
body.admin-mode .request-list,
body.admin-mode .production-list,
body.admin-mode #admin-customers-list,
body.admin-mode #admin-design-projects-list,
body.admin-mode #notifications-list,
body.admin-mode #orders-list {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

.xab-confirm-dialog {
  width: min(520px, calc(100vw - 36px)) !important;
}
.xab-confirm-body {
  display: grid;
  gap: 10px;
  margin: 10px 0 4px;
}
.xab-confirm-name {
  border-radius: 16px;
  border: 1px solid rgba(239,68,68,.28);
  background: rgba(239,68,68,.10);
  color: #fecaca;
  padding: 12px 14px;
  font-weight: 800;
  overflow-wrap: anywhere;
}
.xab-confirm-warning {
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.20);
  background: rgba(15,23,42,.32);
  color: var(--muted);
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.45;
}
.xab-confirm-actions {
  justify-content: center !important;
}
.btn--danger,
.btn.btn--danger {
  background: linear-gradient(180deg, #ef4444, #dc2626) !important;
  color: #fff !important;
  border-color: rgba(185,28,28,.55) !important;
  box-shadow: 0 12px 26px rgba(220,38,38,.24) !important;
}
.btn--danger:hover,
.btn.btn--danger:hover {
  filter: brightness(1.05) !important;
}

body[data-theme="light"] .xab-confirm-name {
  background: #fef2f2 !important;
  border-color: #fecaca !important;
  color: #991b1b !important;
}
body[data-theme="light"] .xab-confirm-warning {
  background: #f8fafc !important;
  border-color: #dbe4f0 !important;
  color: #334155 !important;
}

@media (max-width: 980px) {
  body.admin-mode.builder-page .admin-toolbar {
    width: calc(100% - 16px) !important;
    margin: 8px auto !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    scrollbar-width: thin !important;
  }
  body.admin-mode.builder-page .admin-toolbar__btn {
    flex: 0 0 auto !important;
    max-width: none !important;
    white-space: nowrap !important;
  }
  body.admin-mode .admin-panel-modal:not(.hidden),
  body.admin-mode #admin-upload-model-modal:not(.hidden),
  body.admin-mode .xab-confirm-modal:not(.hidden),
  body.admin-mode .xab-confirm-modal {
    padding: 10px !important;
  }
  body.admin-mode .modal__dialog--admin-wide,
  body.admin-mode .modal__dialog--admin-medium,
  body.admin-mode .modal__dialog--admin-small,
  body.admin-mode .modal__dialog--admin-upload,
  body.admin-mode .xab-confirm-dialog {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
  }
  body.admin-mode .production-toolbar > *,
  body.admin-mode .orders-toolbar > * {
    flex: 1 1 100% !important;
    min-width: 0 !important;
  }
}

/* === V277: dark theme dimension lines on the model are also black === */
body[data-theme="dark"].builder-page .viewer-dimensions__line--arrow,
body[data-theme="dark"].builder-page .viewer-dimensions__line,
body[data-theme="dark"].builder-page .viewer-dimensions__guide,
body[data-theme="dark"].builder-page .viewer-dimensions__tick {
  stroke: #000 !important;
}
body[data-theme="dark"].builder-page .viewer-dimensions__label {
  color: #000 !important;
  background: rgba(255,255,255,0.88) !important;
  border-color: rgba(0,0,0,0.18) !important;
}
body[data-theme="dark"].builder-page .viewer-dimensions__label::after {
  background: rgba(255,255,255,0.88) !important;
}

/* === V278: dimension arrows, markers and lines are black in all themes === */
body.builder-page .viewer-dimensions__line--arrow,
body.user-mode.builder-page .viewer-dimensions__line--arrow,
body.builder-page .viewer-dimensions__line,
body.user-mode.builder-page .viewer-dimensions__line,
body.builder-page .viewer-dimensions__guide,
body.user-mode.builder-page .viewer-dimensions__guide,
body.builder-page .viewer-dimensions__tick,
body.user-mode.builder-page .viewer-dimensions__tick {
  stroke: #000 !important;
}
body.builder-page .viewer-dimensions__svg marker path,
body.user-mode.builder-page .viewer-dimensions__svg marker path,
body.builder-page .viewer-dimensions__svg defs path,
body.user-mode.builder-page .viewer-dimensions__svg defs path {
  fill: #000 !important;
  stroke: #000 !important;
}

/* === V279: admin interface normalized, isolated from customer layout === */
body.admin-mode.builder-page {
  overflow-x: hidden !important;
}

body.admin-mode.builder-page .topbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  width: 100% !important;
  max-width: none !important;
}

body.admin-mode.builder-page .brand {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

body.admin-mode.builder-page .topbar__actions {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: 0 !important;
}

body.admin-mode.builder-page .admin-toolbar {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  margin: 0 0 14px !important;
  padding: 10px !important;
  overflow: visible !important;
  border-radius: 18px !important;
  box-sizing: border-box !important;
}

body.admin-mode.builder-page .admin-toolbar__btn {
  flex: 0 0 auto !important;
  min-width: 0 !important;
  max-width: 190px !important;
  min-height: 38px !important;
  padding: 9px 12px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1.15 !important;
}

body.admin-mode.builder-page .maker-layout--builder {
  display: grid !important;
  grid-template-columns: minmax(280px, 340px) minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: start !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

body.admin-mode.builder-page .maker-sidebar,
body.admin-mode.builder-page .builder-sidebar {
  min-width: 0 !important;
  max-width: 340px !important;
  width: 100% !important;
  display: grid !important;
  gap: 12px !important;
}

body.admin-mode.builder-page .maker-stage,
body.admin-mode.builder-page .builder-stage,
body.admin-mode.builder-page .viewer-card,
body.admin-mode.builder-page #viewer {
  min-width: 0 !important;
  max-width: 100% !important;
}

body.admin-mode.builder-page .viewer-card--builder {
  border-radius: 20px !important;
  overflow: hidden !important;
}

body.admin-mode.builder-page .viewer-toolbar {
  min-width: 0 !important;
  max-width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  padding: 10px 12px !important;
  overflow: visible !important;
}

body.admin-mode.builder-page .viewer-toolbar__right,
body.admin-mode.builder-page .viewer-toolbar__right--pro {
  min-width: 0 !important;
  max-width: 100% !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 7px !important;
  overflow: visible !important;
}

body.admin-mode.builder-page .viewer-toolbar__btn {
  min-height: 34px !important;
  padding: 7px 10px !important;
  font-size: 12px !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
}

body.admin-mode .modal.admin-panel-modal:not(.hidden),
body.admin-mode #admin-upload-model-modal:not(.hidden),
body.admin-mode .xab-confirm-modal:not(.hidden),
body.admin-mode #notifications-modal:not(.hidden) {
  position: fixed !important;
  inset: 0 !important;
  z-index: 9000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 22px !important;
  overflow: hidden !important;
}

body.admin-mode .admin-panel-modal .modal__backdrop,
body.admin-mode #admin-upload-model-modal .modal__backdrop,
body.admin-mode .xab-confirm-modal .modal__backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(2, 6, 23, 0.72) !important;
  backdrop-filter: blur(8px) !important;
}

body.admin-mode .modal__dialog--admin-window,
body.admin-mode .modal__dialog--admin-wide,
body.admin-mode .modal__dialog--admin-medium,
body.admin-mode .modal__dialog--admin-small,
body.admin-mode .modal__dialog--admin-upload,
body.admin-mode .xab-confirm-dialog {
  position: relative !important;
  inset: auto !important;
  transform: none !important;
  margin: 0 !important;
  width: min(1120px, calc(100vw - 44px)) !important;
  max-width: calc(100vw - 44px) !important;
  max-height: calc(100dvh - 44px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  box-sizing: border-box !important;
}

body.admin-mode .modal__dialog--admin-wide {
  width: min(1240px, calc(100vw - 44px)) !important;
}
body.admin-mode .modal__dialog--admin-medium,
body.admin-mode .modal__dialog--admin-upload {
  width: min(980px, calc(100vw - 44px)) !important;
}
body.admin-mode .modal__dialog--admin-small,
body.admin-mode .xab-confirm-dialog {
  width: min(640px, calc(100vw - 44px)) !important;
}

body.admin-mode .modal__header {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 18px 20px 14px !important;
  border-bottom: 1px solid var(--border) !important;
}
body.admin-mode .modal__header h2 {
  margin: 0 !important;
  font-size: 20px !important;
  line-height: 1.15 !important;
}
body.admin-mode .modal__header p {
  margin: 5px 0 0 !important;
  line-height: 1.35 !important;
  max-width: 780px !important;
}
body.admin-mode .modal__close {
  flex: 0 0 auto !important;
}

body.admin-mode .admin-window__body,
body.admin-mode .modal__dialog--admin-window > form,
body.admin-mode #admin-upload-model-form,
body.admin-mode #admin-categories-form {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: auto !important;
  padding: 18px 20px 20px !important;
  box-sizing: border-box !important;
}

body.admin-mode .admin-window__body,
body.admin-mode .form-stack,
body.admin-mode .three-stack,
body.admin-mode .social-provider-grid,
body.admin-mode .performance-grid,
body.admin-mode .admin-upload-grid {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

body.admin-mode .request-list,
body.admin-mode .production-list,
body.admin-mode #admin-customers-list,
body.admin-mode #admin-design-projects-list,
body.admin-mode #notifications-list,
body.admin-mode #orders-list,
body.admin-mode .orders-board {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
}

body.admin-mode .request-card,
body.admin-mode .order-card,
body.admin-mode .production-card,
body.admin-mode .customer-card,
body.admin-mode .admin-design-project-card,
body.admin-mode .notification-card,
body.admin-mode .template-item,
body.admin-mode .subpanel,
body.admin-mode .info-card,
body.admin-mode .hint-card {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

body.admin-mode .input,
body.admin-mode .textarea,
body.admin-mode select,
body.admin-mode input,
body.admin-mode textarea {
  min-width: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

body.admin-mode .orders-toolbar,
body.admin-mode .production-toolbar,
body.admin-mode .modal__actions,
body.admin-mode .inline-actions,
body.admin-mode .template-item__actions,
body.admin-mode .template-item__actions--admin,
body.admin-mode .form-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-width: 0 !important;
  max-width: 100% !important;
}

body.admin-mode .orders-toolbar > *,
body.admin-mode .production-toolbar > * {
  flex: 1 1 210px !important;
  min-width: min(210px, 100%) !important;
}

body.admin-mode .btn,
body.admin-mode button {
  max-width: 100% !important;
}

body.admin-mode .textarea--code,
body.admin-mode #admin-categories-input,
body.admin-mode #admin-material-profiles-input,
body.admin-mode #schema-json,
body.admin-mode #defaults-json {
  max-height: 46vh !important;
  overflow: auto !important;
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
}

body[data-theme="light"].admin-mode .admin-toolbar,
body[data-theme="light"].admin-mode .modal__dialog--admin-window,
body[data-theme="light"].admin-mode .modal__dialog--admin-wide,
body[data-theme="light"].admin-mode .modal__dialog--admin-medium,
body[data-theme="light"].admin-mode .modal__dialog--admin-small,
body[data-theme="light"].admin-mode .modal__dialog--admin-upload,
body[data-theme="light"].admin-mode .xab-confirm-dialog {
  background: #ffffff !important;
  border-color: #dbe4f0 !important;
  color: #0f172a !important;
}

body[data-theme="light"].admin-mode .admin-toolbar__btn,
body[data-theme="light"].admin-mode .request-card,
body[data-theme="light"].admin-mode .order-card,
body[data-theme="light"].admin-mode .production-card,
body[data-theme="light"].admin-mode .customer-card,
body[data-theme="light"].admin-mode .admin-design-project-card,
body[data-theme="light"].admin-mode .notification-card,
body[data-theme="light"].admin-mode .template-item,
body[data-theme="light"].admin-mode .subpanel,
body[data-theme="light"].admin-mode .info-card,
body[data-theme="light"].admin-mode .hint-card {
  background: #f8fafc !important;
  border-color: #dbe4f0 !important;
  color: #0f172a !important;
}

body[data-theme="light"].admin-mode .input,
body[data-theme="light"].admin-mode .textarea,
body[data-theme="light"].admin-mode select,
body[data-theme="light"].admin-mode input,
body[data-theme="light"].admin-mode textarea {
  background: #ffffff !important;
  border-color: #cbd5e1 !important;
  color: #0f172a !important;
}

@media (max-width: 980px) {
  body.admin-mode.builder-page .maker-layout--builder {
    grid-template-columns: 1fr !important;
  }
  body.admin-mode.builder-page .maker-sidebar,
  body.admin-mode.builder-page .builder-sidebar {
    max-width: 100% !important;
  }
  body.admin-mode.builder-page .admin-toolbar {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: thin !important;
  }
  body.admin-mode.builder-page .admin-toolbar__btn {
    max-width: none !important;
    flex: 0 0 auto !important;
  }
  body.admin-mode .modal.admin-panel-modal:not(.hidden),
  body.admin-mode #admin-upload-model-modal:not(.hidden),
  body.admin-mode .xab-confirm-modal:not(.hidden),
  body.admin-mode #notifications-modal:not(.hidden) {
    padding: 10px !important;
  }
  body.admin-mode .modal__dialog--admin-window,
  body.admin-mode .modal__dialog--admin-wide,
  body.admin-mode .modal__dialog--admin-medium,
  body.admin-mode .modal__dialog--admin-small,
  body.admin-mode .modal__dialog--admin-upload,
  body.admin-mode .xab-confirm-dialog {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    border-radius: 18px !important;
  }
  body.admin-mode .modal__header,
  body.admin-mode .admin-window__body,
  body.admin-mode .modal__dialog--admin-window > form,
  body.admin-mode #admin-upload-model-form,
  body.admin-mode #admin-categories-form {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
  body.admin-mode .orders-toolbar > *,
  body.admin-mode .production-toolbar > * {
    flex: 1 1 100% !important;
    min-width: 0 !important;
  }
}

/* === V280: админка — широкие читаемые окна и отдельная desktop-сетка без наложений ===
   Пользовательскую часть не трогаем: все правила ограничены body.admin-mode. */
@media (min-width: 981px) {
  body.admin-mode.builder-page .maker-layout--builder {
    display: grid !important;
    grid-template-columns: minmax(280px, 320px) minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page .maker-sidebar,
  body.admin-mode.builder-page .builder-sidebar {
    width: 100% !important;
    max-width: 320px !important;
    min-width: 0 !important;
  }

  body.admin-mode.builder-page .maker-stage,
  body.admin-mode.builder-page .builder-stage {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page .viewer-card--builder {
    --admin-viewer-side-width: 236px;
    display: grid !important;
    grid-template-columns: minmax(640px, 1fr) var(--admin-viewer-side-width) !important;
    grid-template-rows: auto auto auto minmax(190px, 1fr) !important;
    grid-template-areas:
      "toolbar toolbar"
      "viewer sizes"
      "viewer colors"
      "viewer rotate" !important;
    column-gap: 12px !important;
    row-gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 0 12px 12px 12px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page .viewer-toolbar {
    grid-area: toolbar !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 8px 0 !important;
    position: static !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page .viewer-toolbar__right,
  body.admin-mode.builder-page .viewer-toolbar__right--pro {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: flex-start !important;
    align-items: center !important;
    align-content: center !important;
    flex-wrap: wrap !important;
    gap: 7px !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page #viewer,
  body.admin-mode.builder-page #viewer-dimensions,
  body.admin-mode.builder-page .viewer-dimensions {
    grid-area: viewer !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    position: relative !important;
    align-self: stretch !important;
    justify-self: stretch !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page #viewer {
    height: clamp(560px, 72vh, 860px) !important;
    min-height: 560px !important;
    overflow: hidden !important;
    border-radius: 18px !important;
  }

  body.admin-mode.builder-page .dimension-hud,
  body.admin-mode.builder-page .dimension-hud.hidden,
  body.admin-mode.builder-page .viewer-color-palette,
  body.admin-mode.builder-page .viewer-rotation-control {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    z-index: auto !important;
    width: var(--admin-viewer-side-width) !important;
    max-width: var(--admin-viewer-side-width) !important;
    min-width: 0 !important;
    height: auto !important;
    max-height: none !important;
    margin: 0 !important;
    justify-self: stretch !important;
    align-self: start !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page .dimension-hud,
  body.admin-mode.builder-page .dimension-hud.hidden { grid-area: sizes !important; }
  body.admin-mode.builder-page .viewer-color-palette { grid-area: colors !important; }
  body.admin-mode.builder-page .viewer-rotation-control {
    grid-area: rotate !important;
    align-self: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px !important;
  }

  body.admin-mode.builder-page .viewer-badge,
  body.admin-mode.builder-page .viewer-help {
    z-index: 8 !important;
  }

  body.admin-mode .modal.admin-panel-modal:not(.hidden),
  body.admin-mode #admin-upload-model-modal:not(.hidden),
  body.admin-mode #notifications-modal:not(.hidden) {
    padding: 18px !important;
  }

  body.admin-mode .admin-panel-modal .modal__dialog,
  body.admin-mode .modal__dialog--admin-window,
  body.admin-mode .modal__dialog--admin-wide,
  body.admin-mode .modal__dialog--admin-medium,
  body.admin-mode .modal__dialog--admin-upload {
    width: min(1440px, calc(100vw - 36px)) !important;
    max-width: calc(100vw - 36px) !important;
    min-width: min(980px, calc(100vw - 36px)) !important;
    max-height: calc(100dvh - 36px) !important;
  }

  body.admin-mode .modal__dialog--admin-wide,
  body.admin-mode #admin-orders-modal .modal__dialog,
  body.admin-mode #admin-production-modal .modal__dialog,
  body.admin-mode #admin-customers-modal .modal__dialog,
  body.admin-mode #admin-security-modal .modal__dialog,
  body.admin-mode #admin-design-projects-modal .modal__dialog {
    width: min(1520px, calc(100vw - 36px)) !important;
    min-width: min(1100px, calc(100vw - 36px)) !important;
  }

  body.admin-mode .modal__dialog--admin-small,
  body.admin-mode .xab-confirm-dialog {
    width: min(760px, calc(100vw - 36px)) !important;
    min-width: min(560px, calc(100vw - 36px)) !important;
  }

  body.admin-mode .admin-window__body,
  body.admin-mode .modal__dialog--admin-window > form,
  body.admin-mode #admin-upload-model-form,
  body.admin-mode #admin-categories-form {
    padding: 20px 24px 24px !important;
    overflow: auto !important;
  }

  body.admin-mode .orders-board,
  body.admin-mode .request-list,
  body.admin-mode .production-list,
  body.admin-mode #admin-customers-list,
  body.admin-mode #admin-design-projects-list,
  body.admin-mode #notifications-list,
  body.admin-mode #orders-list {
    overflow-x: auto !important;
    overflow-y: visible !important;
  }

  body.admin-mode .order-card,
  body.admin-mode .request-card,
  body.admin-mode .production-card,
  body.admin-mode .customer-card,
  body.admin-mode .admin-design-project-card,
  body.admin-mode .notification-card {
    padding: 16px !important;
  }
}

@media (min-width: 981px) and (max-width: 1280px) {
  body.admin-mode.builder-page .maker-layout--builder {
    grid-template-columns: minmax(250px, 300px) minmax(0, 1fr) !important;
    gap: 12px !important;
  }
  body.admin-mode.builder-page .viewer-card--builder {
    --admin-viewer-side-width: 218px;
    grid-template-columns: minmax(0, 1fr) var(--admin-viewer-side-width) !important;
  }
  body.admin-mode.builder-page #viewer {
    height: clamp(500px, 68vh, 760px) !important;
    min-height: 500px !important;
  }
}

/* === V281: админка — нормализация левой колонки и панели кнопок ===
   Только admin-mode. Пользовательскую часть не трогаем. */
@media (min-width: 981px) {
  body.admin-mode.builder-page .admin-toolbar {
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    margin: 12px auto 12px auto !important;
    padding: 10px 12px !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    overflow: visible !important;
    border-radius: 18px !important;
  }

  body.admin-mode.builder-page .admin-toolbar__btn {
    flex: 0 0 auto !important;
    min-height: 36px !important;
    padding: 8px 12px !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
    max-width: none !important;
  }

  body.admin-mode.builder-page .maker-layout--builder {
    grid-template-columns: minmax(340px, 380px) minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page .maker-sidebar,
  body.admin-mode.builder-page .builder-sidebar {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 380px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }

  body.admin-mode.builder-page .maker-sidebar .mw-card,
  body.admin-mode.builder-page .builder-sidebar .mw-card,
  body.admin-mode.builder-page .builder-card,
  body.admin-mode.builder-page .model-card,
  body.admin-mode.builder-page .builder-card--controls {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  body.admin-mode.builder-page .maker-sidebar .mw-card__header,
  body.admin-mode.builder-page .builder-sidebar .mw-card__header,
  body.admin-mode.builder-page .mw-card__header--split {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
  }

  body.admin-mode.builder-page .model-header-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  body.admin-mode.builder-page .model-header-actions .btn,
  body.admin-mode.builder-page .model-header-actions .model-open-btn {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: normal !important;
    line-height: 1.15 !important;
  }

  body.admin-mode.builder-page .selected-model {
    display: grid !important;
    grid-template-columns: 92px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page .selected-model__thumb {
    width: 92px !important;
    height: 92px !important;
    min-width: 92px !important;
    border-radius: 14px !important;
  }

  body.admin-mode.builder-page .selected-model__meta,
  body.admin-mode.builder-page .selected-model__name,
  body.admin-mode.builder-page .selected-model__subtitle {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
  }

  body.admin-mode.builder-page .selected-model__thumb-actions {
    grid-column: 1 / -1 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  body.admin-mode.builder-page .selected-model__thumb-actions .btn {
    flex: 1 1 150px !important;
    min-width: 0 !important;
    white-space: normal !important;
  }

  body.admin-mode.builder-page .builder-nav {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body.admin-mode.builder-page .builder-nav__item {
    min-width: 0 !important;
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: normal !important;
  }

  body.admin-mode.builder-page .dynamic-form,
  body.admin-mode.builder-page #dynamic-form,
  body.admin-mode.builder-page .param-workbench,
  body.admin-mode.builder-page .config-smart-panel,
  body.admin-mode.builder-page .live-size-panel {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page .field,
  body.admin-mode.builder-page .param-field,
  body.admin-mode.builder-page .live-size-control,
  body.admin-mode.builder-page .control-card,
  body.admin-mode.builder-page .form-row,
  body.admin-mode.builder-page .form-grid > * {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  body.admin-mode.builder-page input,
  body.admin-mode.builder-page select,
  body.admin-mode.builder-page textarea {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page .builder-stage,
  body.admin-mode.builder-page .maker-stage {
    min-width: 0 !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page .viewer-card--builder {
    grid-template-columns: minmax(0, 1fr) var(--admin-viewer-side-width, 236px) !important;
    column-gap: 12px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

@media (min-width: 981px) and (max-width: 1280px) {
  body.admin-mode.builder-page .maker-layout--builder {
    grid-template-columns: minmax(300px, 330px) minmax(0, 1fr) !important;
  }
  body.admin-mode.builder-page .maker-sidebar,
  body.admin-mode.builder-page .builder-sidebar {
    max-width: 330px !important;
  }
  body.admin-mode.builder-page .selected-model {
    grid-template-columns: 78px minmax(0, 1fr) !important;
  }
  body.admin-mode.builder-page .selected-model__thumb {
    width: 78px !important;
    height: 78px !important;
    min-width: 78px !important;
  }
}

/* === V282: admin selected model preview card gets a taller, cleaner lower info area === */
@media (min-width: 981px) {
  body.admin-mode.builder-page #selected-model-card .selected-model {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: stretch !important;
    padding: 2px 0 4px !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__thumb {
    width: 104px !important;
    height: 112px !important;
    min-width: 104px !important;
    min-height: 112px !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__meta {
    min-height: 112px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 7px !important;
    padding: 4px 2px !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__name {
    font-size: 15px !important;
    line-height: 1.25 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__subtitle {
    font-size: 12px !important;
    line-height: 1.35 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__details {
    margin-top: 2px !important;
    line-height: 1.3 !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__thumb-actions {
    margin-top: 12px !important;
    padding-top: 12px !important;
    border-top: 1px solid rgba(148, 163, 184, 0.18) !important;
    gap: 10px !important;
  }

  body.admin-mode.builder-page #selected-model-card .selected-model__thumb-actions .btn {
    min-height: 40px !important;
    padding: 10px 12px !important;
    flex: 1 1 160px !important;
  }
}

@media (min-width: 981px) and (max-width: 1280px) {
  body.admin-mode.builder-page #selected-model-card .selected-model {
    grid-template-columns: 92px minmax(0, 1fr) !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__thumb {
    width: 92px !important;
    height: 104px !important;
    min-width: 92px !important;
    min-height: 104px !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__meta {
    min-height: 104px !important;
  }
}


/* === V284: admin model settings title and preview info area final polish === */
@media (min-width: 981px) {
  /* Только админка: левое мини-окно модели получает больше высоты под текст и кнопки. */
  body.admin-mode.builder-page #selected-model-card .selected-model {
    grid-template-columns: 108px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: stretch !important;
    padding: 4px 0 8px !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__thumb {
    width: 108px !important;
    height: 126px !important;
    min-width: 108px !important;
    min-height: 126px !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__meta {
    min-height: 126px !important;
    padding: 8px 4px 8px 2px !important;
    justify-content: flex-start !important;
    gap: 8px !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__name {
    -webkit-line-clamp: 3 !important;
    line-height: 1.25 !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__subtitle {
    -webkit-line-clamp: 4 !important;
    line-height: 1.35 !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__details {
    min-height: 22px !important;
    margin-top: 0 !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__thumb-actions {
    margin-top: 14px !important;
    padding-top: 14px !important;
    padding-bottom: 4px !important;
    gap: 10px !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__thumb-actions .btn {
    min-height: 42px !important;
    padding: 11px 12px !important;
  }
}
@media (min-width: 981px) and (max-width: 1280px) {
  body.admin-mode.builder-page #selected-model-card .selected-model {
    grid-template-columns: 96px minmax(0, 1fr) !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__thumb {
    width: 96px !important;
    height: 118px !important;
    min-width: 96px !important;
    min-height: 118px !important;
  }
  body.admin-mode.builder-page #selected-model-card .selected-model__meta {
    min-height: 118px !important;
  }
}

/* === V285: admin selected model card vertical height fix ===
   Исправляет именно левое окно с мини-фото модели в админке.
   Важно: #selected-model-card сам является .selected-model, поэтому используем селектор без пробела. */
@media (min-width: 981px) {
  body.admin-mode.builder-page #selected-model-card.selected-model {
    display: grid !important;
    grid-template-columns: 128px minmax(0, 1fr) !important;
    grid-template-rows: minmax(160px, auto) auto !important;
    gap: 16px !important;
    align-items: stretch !important;
    width: 100% !important;
    min-height: 248px !important;
    padding: 14px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__thumb {
    width: 128px !important;
    height: 160px !important;
    min-width: 128px !important;
    min-height: 160px !important;
    align-self: stretch !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__meta {
    min-height: 160px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    gap: 9px !important;
    padding: 4px 2px 6px 0 !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__name {
    font-size: 15px !important;
    line-height: 1.28 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__subtitle {
    font-size: 12.5px !important;
    line-height: 1.42 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 5 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__thumb-actions {
    grid-column: 1 / -1 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    width: 100% !important;
    margin-top: 2px !important;
    padding-top: 14px !important;
    border-top: 1px solid rgba(148, 163, 184, 0.20) !important;
    box-sizing: border-box !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__thumb-actions .btn {
    flex: 1 1 170px !important;
    min-height: 42px !important;
    padding: 10px 12px !important;
    white-space: normal !important;
    line-height: 1.18 !important;
  }
}

@media (min-width: 981px) and (max-width: 1280px) {
  body.admin-mode.builder-page #selected-model-card.selected-model {
    grid-template-columns: 112px minmax(0, 1fr) !important;
    grid-template-rows: minmax(142px, auto) auto !important;
    min-height: 230px !important;
    padding: 12px !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__thumb {
    width: 112px !important;
    height: 142px !important;
    min-width: 112px !important;
    min-height: 142px !important;
  }

  body.admin-mode.builder-page #selected-model-card.selected-model .selected-model__meta {
    min-height: 142px !important;
  }
}


/* === V286: admin model preview card height fixed exactly as requested === */
@media (min-width: 981px) {
  body.admin-mode.builder-page .model-card {
    max-height: 385px !important;
    min-height: 320px !important;
    height: auto !important;
    overflow: hidden !important;
  }
}

/* === V287: main internet shop page + menu link to modeling laboratory === */
.site-main-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: clamp(14px, 2vw, 34px);
  flex: 1 1 auto;
  min-width: 0;
}
.site-main-nav__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 9px 14px;
  border-radius: 999px;
  color: rgba(226,232,240,.78);
  text-decoration: none;
  font-weight: 800;
  font-size: 13px;
  border: 1px solid transparent;
  white-space: nowrap;
}
.site-main-nav__link:hover,
.site-main-nav__link.is-active {
  color: #fff;
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.14);
}
body[data-theme="light"] .site-main-nav__link { color: #334155; }
body[data-theme="light"] .site-main-nav__link:hover,
body[data-theme="light"] .site-main-nav__link.is-active {
  color: #0f172a;
  background: #eef6ff;
  border-color: #bfdbfe;
}
.shop-home {
  width: min(1420px, calc(100vw - 36px));
  margin: 22px auto 58px;
  display: grid;
  gap: 18px;
}
.shop-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
  gap: 22px;
  min-height: 360px;
  padding: clamp(26px, 4vw, 58px);
  border-radius: 34px;
  border: 1px solid rgba(148,163,184,.22);
  background:
    radial-gradient(circle at 82% 16%, rgba(56,189,248,.18), transparent 32%),
    radial-gradient(circle at 12% 84%, rgba(249,115,22,.16), transparent 30%),
    linear-gradient(135deg, rgba(15,23,42,.98), rgba(30,41,59,.96));
  box-shadow: 0 30px 90px rgba(2,6,23,.28);
}
.shop-hero__content { position: relative; z-index: 2; align-self: center; max-width: 820px; }
.shop-kicker {
  display: inline-flex;
  margin-bottom: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(56,189,248,.14);
  color: #7dd3fc;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.shop-hero h1 {
  margin: 0;
  max-width: 780px;
  color: #f8fafc;
  font-size: clamp(34px, 5.6vw, 72px);
  line-height: .94;
  letter-spacing: -.055em;
}
.shop-hero p {
  max-width: 650px;
  margin: 18px 0 0;
  color: rgba(226,232,240,.78);
  font-size: clamp(15px, 1.5vw, 19px);
  line-height: 1.55;
  font-weight: 550;
}
.shop-hero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.shop-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 12px 18px;
  border-radius: 16px;
  background: #2563eb;
  color: #fff;
  text-decoration: none;
  font-weight: 900;
  border: 1px solid rgba(37,99,235,.15);
  box-shadow: 0 16px 34px rgba(37,99,235,.24);
}
.shop-btn:hover { transform: translateY(-1px); }
.shop-btn--ghost { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); box-shadow: none; }
.shop-btn--small { min-height: 38px; padding: 9px 13px; border-radius: 13px; font-size: 13px; }
.shop-hero__visual { position: relative; min-height: 260px; }
.shop-visual-card {
  position: absolute;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.1);
  box-shadow: 0 30px 80px rgba(0,0,0,.25);
  backdrop-filter: blur(18px);
  color: #fff;
}
.shop-visual-card--main {
  inset: 28px 36px 28px 0;
  display: grid;
  place-content: center;
  text-align: center;
  gap: 10px;
}
.shop-visual-card--main span { font-size: 84px; font-weight: 950; letter-spacing: -.08em; color: rgba(255,255,255,.85); }
.shop-visual-card--main strong { font-size: 23px; }
.shop-visual-card--main small { color: rgba(226,232,240,.75); font-weight: 700; }
.shop-visual-card--float { right: 0; top: 0; padding: 16px 18px; font-weight: 900; }
.shop-visual-card--float2 { left: 12px; bottom: 0; padding: 16px 18px; font-weight: 900; }
.shop-panel {
  border-radius: 24px;
  background: rgba(15,23,42,.78);
  border: 1px solid rgba(148,163,184,.18);
  box-shadow: 0 18px 50px rgba(2,6,23,.18);
}
.shop-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: 14px;
  padding: 14px;
  align-items: center;
}
.shop-search { position: relative; }
.shop-search__icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: #94a3b8; font-size: 20px; }
.shop-search input,
.shop-select {
  width: 100%;
  min-height: 48px;
  border-radius: 16px;
  border: 1px solid rgba(148,163,184,.28);
  background: rgba(2,6,23,.38);
  color: #f8fafc;
  padding: 0 16px;
  font-weight: 750;
  outline: none;
}
.shop-search input { padding-left: 46px; }
.shop-toolbar__right { display: flex; gap: 10px; }
.shop-select { min-width: 190px; }
.shop-category-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 4px 2px;
}
.shop-chip {
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(15,23,42,.75);
  color: #dbeafe;
  border-radius: 999px;
  padding: 9px 14px;
  font-weight: 900;
  cursor: pointer;
}
.shop-chip.is-active { background: #2563eb; border-color: #2563eb; color: #fff; }
.shop-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.shop-product-card {
  overflow: hidden;
  border-radius: 28px;
  background: rgba(15,23,42,.86);
  border: 1px solid rgba(148,163,184,.18);
  box-shadow: 0 18px 46px rgba(2,6,23,.18);
  min-width: 0;
}
.shop-product-card__image {
  position: relative;
  display: block;
  aspect-ratio: 1.18 / 1;
  background:
    radial-gradient(circle at 50% 34%, rgba(148,163,184,.32), transparent 38%),
    linear-gradient(145deg, rgba(30,41,59,.96), rgba(15,23,42,.98));
  overflow: hidden;
}
.shop-product-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.shop-product-placeholder { width: 100%; height: 100%; display: grid; place-items: center; }
.shop-product-placeholder span { font-size: 58px; font-weight: 950; letter-spacing: -.08em; color: rgba(226,232,240,.6); }
.shop-product-card__badge {
  position: absolute;
  left: 12px;
  top: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(2,6,23,.72);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  backdrop-filter: blur(10px);
}
.shop-product-card__body { padding: 16px; }
.shop-product-card h2 { margin: 0; color: #f8fafc; font-size: 17px; line-height: 1.15; letter-spacing: -.02em; }
.shop-product-card p { min-height: 40px; margin: 8px 0 12px; color: rgba(203,213,225,.78); font-size: 13px; line-height: 1.45; }
.shop-product-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.shop-product-tags span { padding: 5px 8px; border-radius: 999px; background: rgba(56,189,248,.12); color: #bae6fd; font-size: 11px; font-weight: 850; }
.shop-product-meta { display: grid; grid-template-columns: 1fr; gap: 8px; margin: 12px 0; }
.shop-product-meta div { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 10px; border-radius: 14px; background: rgba(255,255,255,.055); }
.shop-product-meta span { color: #94a3b8; font-size: 12px; font-weight: 800; }
.shop-product-meta b { color: #f8fafc; font-size: 12px; text-align: right; }
.shop-product-card__footer { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 12px; }
.shop-product-price span { display: block; color: #94a3b8; font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
.shop-product-price strong { display: block; color: #f97316; font-size: 20px; line-height: 1.1; font-weight: 950; }
.shop-empty {
  grid-column: 1 / -1;
  padding: 40px;
  border-radius: 28px;
  background: rgba(15,23,42,.82);
  border: 1px dashed rgba(148,163,184,.3);
  text-align: center;
}
.shop-empty h2 { margin: 0 0 8px; color: #fff; }
.shop-empty p { color: #94a3b8; }
body[data-theme="light"].shop-page {
  background: #f6f8fb !important;
  color: #0f172a !important;
}
body[data-theme="light"] .shop-hero {
  background:
    radial-gradient(circle at 82% 16%, rgba(59,130,246,.12), transparent 32%),
    radial-gradient(circle at 12% 84%, rgba(249,115,22,.12), transparent 30%),
    linear-gradient(135deg, #ffffff, #eef4ff);
  border-color: #dbe4f0;
  box-shadow: 0 26px 70px rgba(15,23,42,.12);
}
body[data-theme="light"] .shop-kicker { background: #e0f2fe; color: #0369a1; }
body[data-theme="light"] .shop-hero h1 { color: #0f172a; }
body[data-theme="light"] .shop-hero p { color: #475569; }
body[data-theme="light"] .shop-btn--ghost { color: #0f172a; background: #fff; border-color: #dbe4f0; }
body[data-theme="light"] .shop-visual-card { color: #0f172a; background: rgba(255,255,255,.8); border-color: #dbe4f0; box-shadow: 0 26px 70px rgba(15,23,42,.1); }
body[data-theme="light"] .shop-visual-card--main span { color: rgba(37,99,235,.28); }
body[data-theme="light"] .shop-visual-card--main small { color: #64748b; }
body[data-theme="light"] .shop-panel,
body[data-theme="light"] .shop-product-card,
body[data-theme="light"] .shop-empty { background: #fff; border-color: #dbe4f0; box-shadow: 0 18px 46px rgba(15,23,42,.08); }
body[data-theme="light"] .shop-search input,
body[data-theme="light"] .shop-select { background: #f8fafc; color: #0f172a; border-color: #dbe4f0; }
body[data-theme="light"] .shop-chip { background: #fff; color: #334155; border-color: #dbe4f0; }
body[data-theme="light"] .shop-chip.is-active { background: #2563eb; color: #fff; border-color: #2563eb; }
body[data-theme="light"] .shop-product-card__image { background: linear-gradient(145deg, #f8fafc, #e2e8f0); }
body[data-theme="light"] .shop-product-placeholder span { color: rgba(37,99,235,.22); }
body[data-theme="light"] .shop-product-card h2,
body[data-theme="light"] .shop-product-meta b,
body[data-theme="light"] .shop-empty h2 { color: #0f172a; }
body[data-theme="light"] .shop-product-card p,
body[data-theme="light"] .shop-empty p { color: #64748b; }
body[data-theme="light"] .shop-product-meta div { background: #f8fafc; }
body[data-theme="light"] .shop-product-tags span { background: #e0f2fe; color: #075985; }
@media (max-width: 1180px) {
  .shop-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .shop-hero { grid-template-columns: 1fr; }
  .shop-hero__visual { display: none; }
}
@media (max-width: 980px) {
  .topbar { gap: 10px; }
  .site-main-nav { order: 3; flex: 1 1 100%; margin: 8px 0 0; overflow-x: auto; padding-bottom: 2px; }
  .shop-home { width: min(100% - 22px, 760px); margin-top: 14px; }
  .shop-toolbar { grid-template-columns: 1fr; }
  .shop-toolbar__right { flex-direction: column; }
  .shop-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
}
@media (max-width: 620px) {
  .shop-hero { min-height: 0; padding: 24px; border-radius: 24px; }
  .shop-hero__actions { flex-direction: column; }
  .shop-btn { width: 100%; }
  .shop-grid { grid-template-columns: 1fr; }
  .shop-product-card { border-radius: 22px; }
  .shop-category-row { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 8px; }
  .shop-chip { flex: 0 0 auto; }
}

/* === V288: marketplace-style shop page with cart, separate from builder/admin === */
body.user-mode.shop-page,
html:has(body.shop-page) {
  height: auto !important;
  min-height: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
body.shop-page {
  min-height: 100vh !important;
  overflow-y: auto !important;
  background: #0b1220 !important;
}
body[data-theme="light"].shop-page {
  background: #f4f6fb !important;
  color: #111827 !important;
}
body.shop-page.is-modal-open { overflow: hidden !important; }
.marketplace-home {
  width: min(1480px, calc(100vw - 32px));
  margin: 18px auto 72px;
  display: grid;
  gap: 18px;
}
.marketplace-strip {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 72px;
  padding: 14px 16px;
  border-radius: 24px;
  background: rgba(15,23,42,.88);
  border: 1px solid rgba(148,163,184,.2);
  box-shadow: 0 18px 46px rgba(2,6,23,.22);
}
.marketplace-strip__left { margin-right: auto; min-width: 0; }
.marketplace-title { color: #f8fafc; font-weight: 950; font-size: 22px; line-height: 1.05; letter-spacing: -.03em; }
.marketplace-subtitle { margin-top: 4px; color: #94a3b8; font-size: 13px; font-weight: 700; }
.marketplace-lab-link,
.marketplace-cart-btn,
.marketplace-add-cart,
.shop-cart-checkout {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  min-height: 42px;
  border-radius: 14px;
  padding: 10px 15px;
  background: #2563eb;
  color: #fff;
  font-weight: 950;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 14px 30px rgba(37,99,235,.22);
}
.marketplace-cart-btn {
  background: #f97316;
  box-shadow: 0 14px 30px rgba(249,115,22,.24);
}
.marketplace-cart-btn b {
  min-width: 23px;
  height: 23px;
  padding: 0 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #fff;
  color: #ea580c;
  font-size: 12px;
}
.marketplace-hero {
  overflow: hidden;
  position: relative;
  min-height: 260px;
  border-radius: 32px;
  padding: clamp(26px, 4vw, 50px);
  background:
    radial-gradient(circle at 90% 10%, rgba(249,115,22,.2), transparent 30%),
    radial-gradient(circle at 12% 100%, rgba(37,99,235,.24), transparent 34%),
    linear-gradient(135deg, rgba(15,23,42,.98), rgba(30,41,59,.96));
  border: 1px solid rgba(148,163,184,.2);
  box-shadow: 0 28px 80px rgba(2,6,23,.26);
}
.marketplace-hero__content { max-width: 900px; }
.marketplace-hero__badge {
  display: inline-flex;
  margin-bottom: 14px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(249,115,22,.14);
  color: #fed7aa;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.marketplace-hero h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(30px, 4vw, 56px);
  line-height: .98;
  letter-spacing: -.055em;
}
.marketplace-hero p {
  margin: 14px 0 0;
  max-width: 680px;
  color: rgba(226,232,240,.78);
  font-size: 16px;
  line-height: 1.5;
  font-weight: 600;
}
.marketplace-hero__search {
  position: relative;
  max-width: 760px;
  margin-top: 26px;
}
.marketplace-hero__search span {
  position: absolute;
  left: 17px;
  top: 50%;
  transform: translateY(-50%);
  color: #94a3b8;
  font-size: 22px;
  z-index: 2;
}
.marketplace-hero__search input {
  width: 100%;
  min-height: 58px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.25);
  background: rgba(255,255,255,.94);
  color: #0f172a;
  padding: 0 18px 0 52px;
  font-size: 15px;
  font-weight: 850;
  outline: none;
  box-shadow: 0 20px 55px rgba(2,6,23,.22);
}
.marketplace-controls {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border-radius: 24px;
  background: rgba(15,23,42,.84);
  border: 1px solid rgba(148,163,184,.2);
}
.marketplace-categories {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.marketplace-chip,
.marketplace-side-link {
  border: 1px solid rgba(148,163,184,.24);
  background: rgba(15,23,42,.72);
  color: #dbeafe;
  border-radius: 999px;
  padding: 9px 13px;
  font-size: 13px;
  font-weight: 950;
  cursor: pointer;
}
.marketplace-chip.is-active,
.marketplace-side-link.is-active {
  background: #2563eb;
  border-color: #2563eb;
  color: #fff;
}
.marketplace-filters { display: flex; gap: 10px; flex: 0 0 auto; }
.marketplace-select {
  min-height: 42px;
  min-width: 180px;
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.24);
  background: rgba(2,6,23,.36);
  color: #f8fafc;
  padding: 0 12px;
  font-weight: 850;
  outline: none;
}
.marketplace-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.marketplace-sidebar {
  position: sticky;
  top: 88px;
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 24px;
  background: rgba(15,23,42,.86);
  border: 1px solid rgba(148,163,184,.2);
  box-shadow: 0 18px 46px rgba(2,6,23,.18);
}
.marketplace-sidebar__title {
  color: #f8fafc;
  font-size: 14px;
  font-weight: 950;
  padding: 4px 4px 8px;
}
.marketplace-side-link {
  width: 100%;
  border-radius: 15px;
  text-align: left;
  justify-content: flex-start;
  padding: 10px 12px;
}
.marketplace-sidebar__note {
  margin-top: 8px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(37,99,235,.12);
  border: 1px solid rgba(59,130,246,.25);
  color: #bfdbfe;
  font-size: 12px;
  line-height: 1.42;
}
.marketplace-sidebar__note b,
.marketplace-sidebar__note span,
.marketplace-sidebar__note a { display: block; }
.marketplace-sidebar__note a { margin-top: 8px; color: #93c5fd; font-weight: 950; text-decoration: none; }
.marketplace-products-wrap { min-width: 0; }
.marketplace-products-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.marketplace-products-head h2 {
  margin: 0;
  color: #f8fafc;
  font-size: 24px;
  line-height: 1.1;
  letter-spacing: -.03em;
}
.marketplace-products-head span { color: #94a3b8; font-weight: 850; }
.marketplace-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}
.marketplace-card {
  min-width: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-radius: 22px;
  background: rgba(15,23,42,.88);
  border: 1px solid rgba(148,163,184,.19);
  box-shadow: 0 18px 44px rgba(2,6,23,.18);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.marketplace-card:hover {
  transform: translateY(-2px);
  border-color: rgba(59,130,246,.45);
  box-shadow: 0 24px 60px rgba(2,6,23,.24);
}
.marketplace-card__image {
  position: relative;
  aspect-ratio: 1 / .82;
  background: radial-gradient(circle at 50% 35%, rgba(148,163,184,.28), transparent 42%), linear-gradient(145deg, #1e293b, #0f172a);
  overflow: hidden;
}
.marketplace-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.marketplace-card__placeholder { width: 100%; height: 100%; display: grid; place-items: center; }
.marketplace-card__placeholder span { color: rgba(226,232,240,.58); font-size: 54px; font-weight: 950; letter-spacing: -.08em; }
.marketplace-card__badge {
  position: absolute;
  left: 10px;
  top: 10px;
  max-width: calc(100% - 56px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(2,6,23,.72);
  color: #fff;
  font-size: 11px;
  font-weight: 950;
  backdrop-filter: blur(10px);
}
.marketplace-card__fav {
  position: absolute;
  right: 10px;
  top: 10px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(2,6,23,.58);
  color: #fff;
  font-size: 18px;
  cursor: pointer;
}
.marketplace-card__body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
}
.marketplace-card h3 {
  margin: 0;
  min-height: 40px;
  color: #f8fafc;
  font-size: 16px;
  line-height: 1.22;
  letter-spacing: -.02em;
}
.marketplace-card p {
  margin: 0;
  min-height: 38px;
  color: rgba(203,213,225,.78);
  font-size: 12px;
  line-height: 1.42;
}
.marketplace-card__tags { display: flex; flex-wrap: wrap; gap: 5px; }
.marketplace-card__tags span {
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(56,189,248,.12);
  color: #bae6fd;
  font-size: 10px;
  font-weight: 900;
}
.marketplace-card__meta {
  display: grid;
  gap: 6px;
  margin-top: auto;
}
.marketplace-card__meta span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 7px 9px;
  border-radius: 12px;
  background: rgba(255,255,255,.055);
  color: #94a3b8;
  font-size: 11px;
  font-weight: 850;
}
.marketplace-card__meta b { color: #f8fafc; text-align: right; }
.marketplace-card__bottom {
  display: grid;
  gap: 10px;
  margin-top: 2px;
}
.marketplace-card__price strong {
  display: block;
  color: #f97316;
  font-size: 22px;
  line-height: 1;
  font-weight: 950;
}
.marketplace-card__price span { color: #94a3b8; font-size: 11px; font-weight: 850; }
.marketplace-add-cart { width: 100%; background: #f97316; box-shadow: 0 12px 26px rgba(249,115,22,.22); }
.marketplace-add-cart.is-added { background: #16a34a; }
.marketplace-empty {
  grid-column: 1 / -1;
  padding: 42px;
  border-radius: 24px;
  text-align: center;
  background: rgba(15,23,42,.86);
  border: 1px dashed rgba(148,163,184,.35);
  color: #cbd5e1;
}
.shop-cart-drawer.hidden { display: none !important; }
.shop-cart-drawer { position: fixed; inset: 0; z-index: 130; display: block; }
.shop-cart-drawer__backdrop { position: absolute; inset: 0; background: rgba(2,6,23,.64); backdrop-filter: blur(4px); }
.shop-cart-drawer__panel {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: min(460px, 100vw);
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px;
  background: #0f172a;
  color: #f8fafc;
  box-shadow: -18px 0 70px rgba(2,6,23,.35);
  overflow-y: auto;
}
.shop-cart-drawer__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.shop-cart-drawer__header h2 { margin: 0; font-size: 24px; }
.shop-cart-drawer__header p { margin: 4px 0 0; color: #94a3b8; }
.shop-cart-drawer__close {
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor: pointer;
}
.shop-cart-list { display: grid; gap: 10px; }
.shop-cart-empty {
  padding: 18px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  color: #cbd5e1;
  text-align: center;
}
.shop-cart-item {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(148,163,184,.16);
}
.shop-cart-item__thumb {
  width: 68px;
  height: 68px;
  border-radius: 14px;
  background: rgba(255,255,255,.08);
  display: grid;
  place-items: center;
  overflow: hidden;
  color: #94a3b8;
  font-weight: 950;
}
.shop-cart-item__thumb img { width: 100%; height: 100%; object-fit: cover; }
.shop-cart-item__info { min-width: 0; display: grid; gap: 4px; }
.shop-cart-item__info b { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.shop-cart-item__info span { color: #94a3b8; font-size: 12px; }
.shop-cart-item__info strong { color: #f97316; }
.shop-cart-item__qty { display: grid; grid-template-columns: 28px 30px 28px; align-items: center; gap: 4px; grid-column: 3; grid-row: 1; }
.shop-cart-item__qty button,
.shop-cart-item__remove {
  min-height: 28px;
  border: 0;
  border-radius: 10px;
  background: rgba(255,255,255,.1);
  color: #fff;
  cursor: pointer;
  font-weight: 900;
}
.shop-cart-item__qty em { text-align: center; font-style: normal; font-weight: 900; }
.shop-cart-item__remove { grid-column: 3; grid-row: 2; padding: 0 8px; font-size: 11px; color: #fecaca; }
.shop-cart-summary {
  margin-top: auto;
  display: grid;
  gap: 8px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.07);
}
.shop-cart-summary div { display: flex; justify-content: space-between; gap: 12px; }
.shop-cart-summary span { color: #94a3b8; font-weight: 850; }
.shop-cart-summary strong { color: #f97316; font-size: 24px; }
.shop-cart-checkout { width: 100%; min-height: 50px; background: #16a34a; box-shadow: 0 16px 32px rgba(22,163,74,.23); }
.shop-cart-hint { margin: 0; color: #94a3b8; font-size: 12px; line-height: 1.45; }
body[data-theme="light"] .marketplace-strip,
body[data-theme="light"] .marketplace-controls,
body[data-theme="light"] .marketplace-sidebar,
body[data-theme="light"] .marketplace-card,
body[data-theme="light"] .marketplace-empty {
  background: #fff;
  color: #0f172a;
  border-color: #dbe4f0;
  box-shadow: 0 18px 44px rgba(15,23,42,.08);
}
body[data-theme="light"] .marketplace-title,
body[data-theme="light"] .marketplace-products-head h2,
body[data-theme="light"] .marketplace-sidebar__title,
body[data-theme="light"] .marketplace-card h3,
body[data-theme="light"] .marketplace-card__meta b { color: #0f172a; }
body[data-theme="light"] .marketplace-subtitle,
body[data-theme="light"] .marketplace-products-head span,
body[data-theme="light"] .marketplace-card p,
body[data-theme="light"] .marketplace-card__meta span { color: #64748b; }
body[data-theme="light"] .marketplace-hero {
  background:
    radial-gradient(circle at 90% 10%, rgba(249,115,22,.14), transparent 30%),
    radial-gradient(circle at 12% 100%, rgba(37,99,235,.14), transparent 34%),
    linear-gradient(135deg, #fff, #eef4ff);
  border-color: #dbe4f0;
  box-shadow: 0 26px 70px rgba(15,23,42,.1);
}
body[data-theme="light"] .marketplace-hero h1 { color: #0f172a; }
body[data-theme="light"] .marketplace-hero p { color: #475569; }
body[data-theme="light"] .marketplace-chip,
body[data-theme="light"] .marketplace-side-link,
body[data-theme="light"] .marketplace-select {
  background: #f8fafc;
  color: #334155;
  border-color: #dbe4f0;
}
body[data-theme="light"] .marketplace-chip.is-active,
body[data-theme="light"] .marketplace-side-link.is-active { background: #2563eb; color: #fff; }
body[data-theme="light"] .marketplace-card__image { background: linear-gradient(145deg, #f8fafc, #e2e8f0); }
body[data-theme="light"] .marketplace-card__placeholder span { color: rgba(37,99,235,.22); }
body[data-theme="light"] .marketplace-card__meta span { background: #f8fafc; }
body[data-theme="light"] .marketplace-sidebar__note { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
body[data-theme="light"] .shop-cart-drawer__panel { background: #fff; color: #0f172a; }
body[data-theme="light"] .shop-cart-drawer__close,
body[data-theme="light"] .shop-cart-item,
body[data-theme="light"] .shop-cart-summary,
body[data-theme="light"] .shop-cart-empty,
body[data-theme="light"] .shop-cart-item__qty button,
body[data-theme="light"] .shop-cart-item__remove { background: #f8fafc; color: #0f172a; border-color: #dbe4f0; }
body[data-theme="light"] .shop-cart-item__info span,
body[data-theme="light"] .shop-cart-hint,
body[data-theme="light"] .shop-cart-summary span,
body[data-theme="light"] .shop-cart-drawer__header p { color: #64748b; }
@media (max-width: 1280px) {
  .marketplace-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 980px) {
  body.shop-page .site-main-nav { order: 3; width: 100%; overflow-x: auto; padding-bottom: 2px; }
  .marketplace-home { width: min(100% - 22px, 860px); margin-top: 12px; }
  .marketplace-strip { flex-wrap: wrap; }
  .marketplace-strip__left { flex: 1 1 100%; }
  .marketplace-layout { grid-template-columns: 1fr; }
  .marketplace-sidebar { position: static; display: none; }
  .marketplace-controls { align-items: stretch; flex-direction: column; }
  .marketplace-categories { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 4px; }
  .marketplace-chip { flex: 0 0 auto; }
  .marketplace-filters { width: 100%; flex-direction: column; }
  .marketplace-select { width: 100%; }
  .marketplace-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
}
@media (max-width: 620px) {
  .marketplace-home { width: min(100% - 16px, 520px); margin-bottom: 40px; }
  .marketplace-hero { min-height: 0; padding: 22px; border-radius: 24px; }
  .marketplace-hero h1 { font-size: 30px; }
  .marketplace-hero__search input { min-height: 52px; }
  .marketplace-grid { grid-template-columns: 1fr; }
  .marketplace-card { border-radius: 20px; }
  .marketplace-strip { border-radius: 20px; }
  .marketplace-lab-link,
  .marketplace-cart-btn { flex: 1 1 100%; width: 100%; }
  .shop-cart-item { grid-template-columns: 58px minmax(0, 1fr); }
  .shop-cart-item__thumb { width: 58px; height: 58px; }
  .shop-cart-item__qty { grid-column: 2; grid-row: auto; justify-self: start; }
  .shop-cart-item__remove { grid-column: 2; grid-row: auto; justify-self: start; }
}


/* === V289: clean marketplace background and remove duplicated hero promo copy === */
body.shop-page,
body.user-mode.shop-page {
  background: #0b1220 !important;
}
body[data-theme="light"].shop-page,
body[data-theme="light"].user-mode.shop-page {
  background: #f4f6fb !important;
}
body.shop-page .marketplace-home {
  gap: 14px !important;
}
body.shop-page .marketplace-hero {
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
body.shop-page .marketplace-hero__content,
body.shop-page .marketplace-hero__content--search-only {
  max-width: none !important;
}
body.shop-page .marketplace-hero__badge,
body.shop-page .marketplace-hero h1,
body.shop-page .marketplace-hero p {
  display: none !important;
}
body.shop-page .marketplace-hero__search {
  max-width: none !important;
  margin-top: 0 !important;
  border-radius: 22px !important;
  background: rgba(15,23,42,.88) !important;
  border: 1px solid rgba(148,163,184,.2) !important;
  box-shadow: 0 18px 46px rgba(2,6,23,.18) !important;
  padding: 10px !important;
}
body.shop-page .marketplace-hero__search input {
  min-height: 54px !important;
  background: rgba(255,255,255,.06) !important;
  border-color: rgba(148,163,184,.2) !important;
}
body[data-theme="light"].shop-page .marketplace-hero {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
body[data-theme="light"].shop-page .marketplace-hero__search {
  background: #fff !important;
  border-color: #dbe4f0 !important;
  box-shadow: 0 18px 44px rgba(15,23,42,.08) !important;
}
body[data-theme="light"].shop-page .marketplace-hero__search input {
  background: #f8fafc !important;
  color: #0f172a !important;
  border-color: #dbe4f0 !important;
}
body.shop-page .marketplace-strip,
body.shop-page .marketplace-controls,
body.shop-page .marketplace-sidebar,
body.shop-page .marketplace-products-wrap,
body.shop-page .marketplace-card {
  background-clip: padding-box !important;
}
body[data-theme="light"].shop-page .marketplace-strip,
body[data-theme="light"].shop-page .marketplace-controls,
body[data-theme="light"].shop-page .marketplace-sidebar,
body[data-theme="light"].shop-page .marketplace-products-wrap,
body[data-theme="light"].shop-page .marketplace-card {
  background: #fff !important;
}
@media (max-width: 620px) {
  body.shop-page .marketplace-hero {
    padding: 0 !important;
    border-radius: 0 !important;
  }
  body.shop-page .marketplace-hero__search {
    border-radius: 18px !important;
  }
}

/* === V290: единый фон магазина без второго слоя у внутренних окон ===
   Оставляем один общий фон страницы, а панели магазина больше не рисуют
   собственные большие подложки. Карточки товаров сохраняют отдельный фон,
   чтобы каталог читался как маркетплейс. */
body.shop-page,
body.user-mode.shop-page,
body[data-theme="dark"].shop-page,
body[data-theme="dark"].user-mode.shop-page {
  background: #0b1220 !important;
}

body[data-theme="light"].shop-page,
body[data-theme="light"].user-mode.shop-page {
  background: #f4f6fb !important;
}

body.shop-page::before,
body.user-mode.shop-page::before,
body[data-theme="light"].shop-page::before,
body[data-theme="light"].user-mode.shop-page::before {
  background: transparent !important;
  opacity: 0 !important;
}

body.shop-page main,
body.shop-page .marketplace-home,
body.shop-page .marketplace-layout,
body.shop-page .marketplace-products-wrap,
body.shop-page .marketplace-strip,
body.shop-page .marketplace-controls,
body.shop-page .marketplace-sidebar,
body.shop-page .marketplace-hero,
body.shop-page .marketplace-hero__content,
body.shop-page .marketplace-hero__content--search-only {
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

body.shop-page .marketplace-strip,
body.shop-page .marketplace-controls,
body.shop-page .marketplace-sidebar,
body.shop-page .marketplace-products-wrap,
body.shop-page .marketplace-hero {
  border-color: transparent !important;
}

body.shop-page .marketplace-products-wrap {
  padding: 0 !important;
  border: 0 !important;
}

body.shop-page .marketplace-sidebar {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.shop-page .marketplace-hero__search {
  background: rgba(15,23,42,.88) !important;
  border: 1px solid rgba(148,163,184,.2) !important;
  box-shadow: 0 18px 46px rgba(2,6,23,.18) !important;
}

body[data-theme="light"].shop-page .marketplace-hero__search {
  background: #ffffff !important;
  border-color: #dbe4f0 !important;
  box-shadow: 0 14px 34px rgba(15,23,42,.07) !important;
}

body[data-theme="light"].shop-page main,
body[data-theme="light"].shop-page .marketplace-home,
body[data-theme="light"].shop-page .marketplace-layout,
body[data-theme="light"].shop-page .marketplace-products-wrap,
body[data-theme="light"].shop-page .marketplace-strip,
body[data-theme="light"].shop-page .marketplace-controls,
body[data-theme="light"].shop-page .marketplace-sidebar,
body[data-theme="light"].shop-page .marketplace-hero,
body[data-theme="light"].shop-page .marketplace-hero__content,
body[data-theme="light"].shop-page .marketplace-hero__content--search-only {
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}


/* === V291: корзина в верхней панели + единый фон поиска и шапки магазина === */
body.shop-page .topbar-cart-btn {
  display: inline-grid !important;
}
body.shop-page .topbar-cart-btn .topbar-icon-btn__badge {
  display: inline-flex !important;
  align-items: center !important;
}
body.shop-page .marketplace-strip {
  display: none !important;
}
body.shop-page .marketplace-hero__search,
body[data-theme="light"].shop-page .marketplace-hero__search {
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}
body.shop-page .marketplace-hero__search input,
body[data-theme="light"].shop-page .marketplace-hero__search input {
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}
body.shop-page .marketplace-hero__search span {
  color: rgba(226,232,240,.72) !important;
}
body[data-theme="light"].shop-page .marketplace-hero__search span {
  color: #64748b !important;
}
@media (max-width: 620px) {
  body.shop-page .marketplace-lab-link,
  body.shop-page .marketplace-cart-btn {
    display: none !important;
  }
}

/* V292: подпись магазина в шапке под логотипом */
body.shop-page .brand__subtitle--shop {
  display: flex !important;
  flex-direction: column !important;
  gap: 1px !important;
  line-height: 1.18 !important;
  max-width: 430px !important;
}
body.shop-page .brand__subtitle--shop span:first-child {
  font-weight: 800 !important;
  color: var(--text) !important;
}
body.shop-page .brand__subtitle--shop span:last-child {
  color: var(--muted) !important;
  font-weight: 500 !important;
}
body[data-theme="light"].shop-page .brand__subtitle--shop span:first-child {
  color: #111827 !important;
}
body[data-theme="light"].shop-page .brand__subtitle--shop span:last-child {
  color: #4b5563 !important;
}


/* v299 — Ozon sync progress bar */
.ozon-sync-progress{
  margin-top: 12px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.045);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.ozon-sync-progress.hidden{display:none!important;}
.ozon-sync-progress__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-size:14px;
  color: var(--text-main, #f7f9ff);
}
.ozon-sync-progress__top strong{font-variant-numeric: tabular-nums;}
.ozon-sync-progress__bar{
  position:relative;
  height:10px;
  margin-top:10px;
  overflow:hidden;
  border-radius:999px;
  background: rgba(255,255,255,.12);
}
.ozon-sync-progress__bar i{
  display:block;
  height:100%;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(89,142,255,.95), rgba(84,255,185,.95));
  transition: width .35s ease;
}
.ozon-sync-progress.is-error .ozon-sync-progress__bar i{
  background: linear-gradient(90deg, rgba(255,101,101,.95), rgba(255,181,71,.95));
}
.ozon-sync-progress.is-done .ozon-sync-progress__bar i{
  background: linear-gradient(90deg, rgba(84,255,185,.95), rgba(142,255,128,.95));
}
.ozon-sync-progress__steps{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.ozon-sync-progress__steps span{
  padding:5px 9px;
  border-radius:999px;
  font-size:12px;
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.09);
}
.ozon-sync-progress__steps span.is-active{
  color:#fff;
  background:rgba(89,142,255,.22);
  border-color:rgba(89,142,255,.45);
}
.ozon-sync-progress__steps span.is-done{
  color:rgba(255,255,255,.88);
  background:rgba(84,255,185,.14);
  border-color:rgba(84,255,185,.28);
}
body.light-theme .ozon-sync-progress,
html[data-theme="light"] .ozon-sync-progress{
  background:rgba(255,255,255,.82);
  border-color:rgba(18,28,45,.12);
}
body.light-theme .ozon-sync-progress__top,
html[data-theme="light"] .ozon-sync-progress__top{color:#162033;}
body.light-theme .ozon-sync-progress__bar,
html[data-theme="light"] .ozon-sync-progress__bar{background:rgba(18,28,45,.12);}
body.light-theme .ozon-sync-progress__steps span,
html[data-theme="light"] .ozon-sync-progress__steps span{color:rgba(18,28,45,.72); background:rgba(18,28,45,.06); border-color:rgba(18,28,45,.09);}

/* === V302: product card title overflow fix === */
.ozon-product-page,
.product-detail-card,
.product-info,
.product-section,
.product-characteristics {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.product-detail-card {
  display: grid;
  grid-template-columns: minmax(320px, 540px) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
  overflow: hidden !important;
}
.product-info h1 {
  display: block !important;
  max-width: 100% !important;
  margin: 8px 0 14px !important;
  font-size: clamp(26px, 2.2vw, 42px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.04em !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  hyphens: auto !important;
}
.product-info__meta,
.product-info__meta span,
.product-info__meta b,
.product-section p,
.product-characteristics__grid div,
.product-characteristics__grid span,
.product-characteristics__grid b {
  min-width: 0 !important;
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
@media (max-width: 980px) {
  .product-detail-card {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    overflow: visible !important;
  }
  .product-info h1 {
    font-size: clamp(22px, 7vw, 32px) !important;
  }
}

/* === V303: Ozon product color variants and image lightbox === */
.product-gallery__zoom{
  position:relative;
  display:block;
  width:100%;
  padding:0;
  border:0;
  background:transparent;
  cursor:zoom-in;
  border-radius:22px;
  overflow:hidden;
}
.product-gallery__zoom img{display:block;width:100%;height:auto;}
.product-gallery__zoom span{
  position:absolute;
  right:14px;
  bottom:14px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(5,12,26,.72);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  font-size:12px;
  font-weight:800;
  opacity:0;
  transform:translateY(6px);
  transition:.18s ease;
  pointer-events:none;
}
.product-gallery__zoom:hover span{opacity:1;transform:translateY(0);}
.product-variants{
  margin:16px 0 18px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.09);
}
.product-variants__head{
  display:flex;
  align-items:baseline;
  gap:10px;
  margin-bottom:10px;
}
.product-variants__head h2{
  margin:0!important;
  font-size:16px!important;
  line-height:1.2!important;
  letter-spacing:0!important;
}
.product-variants__head span,
.product-single-color span{
  color:rgba(255,255,255,.62);
  font-size:13px;
  font-weight:700;
}
.product-variants__grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.product-variant{
  display:flex;
  align-items:center;
  gap:8px;
  max-width:220px;
  min-height:44px;
  padding:6px 10px 6px 6px;
  border-radius:14px;
  color:#fff;
  text-decoration:none;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.11);
  font-size:13px;
  font-weight:850;
  overflow:hidden;
}
.product-variant:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);}
.product-variant.is-active{border-color:rgba(105,154,255,.85);box-shadow:0 0 0 3px rgba(105,154,255,.16);}
.product-variant img{
  width:34px;
  height:34px;
  flex:0 0 34px;
  object-fit:cover;
  border-radius:10px;
  background:#fff;
}
.product-variant span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.product-single-color{
  display:inline-flex;
  gap:8px;
  align-items:center;
  margin:12px 0 8px;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.1);
}
.product-single-color b{color:#fff;font-size:13px;}
.product-lightbox.hidden{display:none!important;}
.product-lightbox{
  position:fixed;
  inset:0;
  z-index:10000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
}
.product-lightbox__backdrop{
  position:absolute;
  inset:0;
  border:0;
  background:rgba(0,0,0,.76);
  backdrop-filter:blur(8px);
}
.product-lightbox__panel{
  position:relative;
  width:min(1180px, 94vw);
  height:min(820px, 88vh);
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:28px;
  background:rgba(9,15,29,.92);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 30px 90px rgba(0,0,0,.48);
  overflow:hidden;
}
.product-lightbox__panel img{
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  background:#fff;
}
.product-lightbox__close,
.product-lightbox__nav{
  position:absolute;
  z-index:2;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(5,12,26,.72);
  color:#fff;
  cursor:pointer;
  box-shadow:0 12px 34px rgba(0,0,0,.22);
}
.product-lightbox__close{
  top:16px;
  right:16px;
  width:44px;
  height:44px;
  border-radius:999px;
  font-size:20px;
}
.product-lightbox__nav{
  top:50%;
  width:54px;
  height:74px;
  margin-top:-37px;
  border-radius:18px;
  font-size:48px;
  line-height:1;
}
.product-lightbox__nav--prev{left:16px;}
.product-lightbox__nav--next{right:16px;}
.product-lightbox__counter{
  position:absolute;
  left:50%;
  bottom:16px;
  transform:translateX(-50%);
  padding:8px 12px;
  border-radius:999px;
  background:rgba(5,12,26,.72);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  font-size:13px;
  font-weight:850;
}
body.light-theme .product-variants,
html[data-theme="light"] .product-variants,
body.light-theme .product-single-color,
html[data-theme="light"] .product-single-color{
  background:rgba(18,28,45,.045);
  border-color:rgba(18,28,45,.1);
}
body.light-theme .product-variant,
html[data-theme="light"] .product-variant{
  color:#172033;
  background:rgba(18,28,45,.04);
  border-color:rgba(18,28,45,.12);
}
body.light-theme .product-variants__head span,
html[data-theme="light"] .product-variants__head span,
body.light-theme .product-single-color span,
html[data-theme="light"] .product-single-color span{color:rgba(18,28,45,.62);}
body.light-theme .product-single-color b,
html[data-theme="light"] .product-single-color b{color:#172033;}
@media (max-width:720px){
  .product-lightbox{padding:10px;}
  .product-lightbox__panel{width:96vw;height:84vh;border-radius:18px;}
  .product-lightbox__nav{width:42px;height:58px;font-size:36px;border-radius:14px;}
  .product-lightbox__nav--prev{left:8px;}
  .product-lightbox__nav--next{right:8px;}
  .product-variant{max-width:100%;flex:1 1 150px;}
}

/* === V304: Ozon-like product sections === */
.product-tabs{
  position:sticky;
  top:74px;
  z-index:12;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:10px 0 18px;
  padding:10px;
  border-radius:20px;
  background:rgba(8,15,29,.74);
  border:1px solid rgba(255,255,255,.09);
  backdrop-filter:blur(14px);
}
.product-tabs a{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:8px 13px;
  border-radius:999px;
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:900;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.1);
}
.product-tabs a:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);}
.product-about-box{margin-top:18px;}
.product-about-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.product-about-grid div{
  min-width:0;
  padding:12px;
  border-radius:14px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
}
.product-about-grid span,
.product-characteristics__grid span{display:block;color:rgba(255,255,255,.62);font-size:12px;font-weight:800;margin-bottom:5px;}
.product-about-grid b,
.product-characteristics__grid b{display:block;color:#fff;font-size:14px;line-height:1.28;overflow-wrap:anywhere;}
.product-market-section{
  margin-top:22px;
  padding:20px;
  border-radius:24px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.09);
  box-shadow:0 18px 48px rgba(0,0,0,.16);
}
.product-market-section__head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:14px;
  margin-bottom:16px;
}
.product-market-section__head h2{margin:0!important;font-size:clamp(20px,2vw,30px)!important;line-height:1.12!important;letter-spacing:-.03em!important;color:#fff;}
.product-market-section__head span{color:rgba(255,255,255,.62);font-size:13px;font-weight:800;}
.product-mini-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:14px;
}
.product-mini-grid--compact{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}
.product-mini-card{
  display:flex;
  flex-direction:column;
  min-width:0;
  overflow:hidden;
  border-radius:18px;
  color:#fff;
  text-decoration:none;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.1);
  transition:transform .16s ease, background .16s ease, border-color .16s ease;
}
.product-mini-card:hover{transform:translateY(-2px);background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.2);}
.product-mini-card__image{
  aspect-ratio:1/1;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:rgba(255,255,255,.9);
}
.product-mini-card__image img{width:100%;height:100%;object-fit:cover;display:block;}
.product-mini-card__image span{color:#1a2434;font-size:30px;font-weight:950;}
.product-mini-card__body{display:flex;flex-direction:column;gap:9px;padding:12px;min-width:0;}
.product-mini-card__body b{
  min-height:38px;
  color:#fff;
  font-size:13px;
  line-height:1.2;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  overflow-wrap:anywhere;
}
.product-mini-card__body strong{color:#fff;font-size:18px;line-height:1.1;font-weight:950;}
.product-description-text{
  max-width:980px;
  color:rgba(255,255,255,.84);
  font-size:16px;
  line-height:1.62;
  white-space:pre-line;
  overflow-wrap:anywhere;
}
.product-empty-block{
  padding:16px;
  border-radius:16px;
  color:rgba(255,255,255,.72);
  background:rgba(255,255,255,.045);
  border:1px dashed rgba(255,255,255,.14);
}
body.light-theme .product-tabs,
html[data-theme="light"] .product-tabs{
  background:rgba(245,248,255,.86);
  border-color:rgba(18,28,45,.1);
}
body.light-theme .product-tabs a,
html[data-theme="light"] .product-tabs a,
body.light-theme .product-mini-card,
html[data-theme="light"] .product-mini-card{
  color:#172033;
  background:rgba(18,28,45,.04);
  border-color:rgba(18,28,45,.12);
}
body.light-theme .product-market-section,
html[data-theme="light"] .product-market-section,
body.light-theme .product-about-grid div,
html[data-theme="light"] .product-about-grid div{
  background:rgba(255,255,255,.78);
  border-color:rgba(18,28,45,.1);
}
body.light-theme .product-market-section__head h2,
html[data-theme="light"] .product-market-section__head h2,
body.light-theme .product-mini-card__body b,
html[data-theme="light"] .product-mini-card__body b,
body.light-theme .product-mini-card__body strong,
html[data-theme="light"] .product-mini-card__body strong,
body.light-theme .product-about-grid b,
html[data-theme="light"] .product-about-grid b,
body.light-theme .product-characteristics__grid b,
html[data-theme="light"] .product-characteristics__grid b{color:#172033;}
body.light-theme .product-market-section__head span,
html[data-theme="light"] .product-market-section__head span,
body.light-theme .product-about-grid span,
html[data-theme="light"] .product-about-grid span,
body.light-theme .product-characteristics__grid span,
html[data-theme="light"] .product-characteristics__grid span,
body.light-theme .product-description-text,
html[data-theme="light"] .product-description-text,
body.light-theme .product-empty-block,
html[data-theme="light"] .product-empty-block{color:rgba(18,28,45,.72);}
@media (max-width:720px){
  .product-tabs{position:static;overflow:auto;flex-wrap:nowrap;margin-left:-4px;margin-right:-4px;}
  .product-tabs a{white-space:nowrap;}
  .product-about-grid{grid-template-columns:1fr;}
  .product-market-section{padding:15px;border-radius:20px;}
  .product-market-section__head{align-items:flex-start;flex-direction:column;gap:6px;}
  .product-mini-grid,.product-mini-grid--compact{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
  .product-mini-card__body{padding:10px;}
  .product-mini-card__body strong{font-size:15px;}
}

/* === V305: fix Ozon shop admin window after product sections update === */
body.admin-mode #admin-ozon-shop-modal:not(.hidden) {
  display: grid !important;
  place-items: center !important;
  padding: 18px !important;
  overflow: hidden !important;
}
body.admin-mode #admin-ozon-shop-modal .modal__dialog--admin-window,
body.admin-mode #admin-ozon-shop-modal .modal__dialog--admin-wide {
  width: min(1280px, calc(100vw - 36px)) !important;
  max-width: calc(100vw - 36px) !important;
  height: min(860px, calc(100dvh - 36px)) !important;
  max-height: calc(100dvh - 36px) !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}
body.admin-mode #admin-ozon-shop-modal .modal__header {
  flex: 0 0 auto !important;
  min-height: 0 !important;
}
body.admin-mode #admin-ozon-shop-modal .admin-window__body {
  min-height: 0 !important;
  height: 100% !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(360px, .9fr) minmax(0, 1.45fr) !important;
  gap: 16px !important;
  align-items: stretch !important;
}
body.admin-mode #admin-ozon-shop-modal .subpanel {
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: auto !important;
  box-sizing: border-box !important;
}
body.admin-mode #admin-ozon-shop-modal #ozon-products-list {
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  display: grid !important;
  gap: 10px !important;
}
body.admin-mode #admin-ozon-shop-modal .request-card,
body.admin-mode #admin-ozon-shop-modal .info-card,
body.admin-mode #admin-ozon-shop-modal .empty-state {
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}
body.admin-mode #admin-ozon-shop-modal .request-card p,
body.admin-mode #admin-ozon-shop-modal .request-card h3,
body.admin-mode #admin-ozon-shop-modal .request-card strong {
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
body.admin-mode #admin-ozon-shop-modal .two-cols,
body.admin-mode #admin-ozon-shop-modal .two-cols--compact {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}
body.admin-mode #admin-ozon-shop-modal .inline-actions,
body.admin-mode #admin-ozon-shop-modal .wrap-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
@media (max-width: 920px) {
  body.admin-mode #admin-ozon-shop-modal .modal__dialog--admin-window,
  body.admin-mode #admin-ozon-shop-modal .modal__dialog--admin-wide {
    width: calc(100vw - 18px) !important;
    max-width: calc(100vw - 18px) !important;
    height: calc(100dvh - 18px) !important;
    max-height: calc(100dvh - 18px) !important;
  }
  body.admin-mode #admin-ozon-shop-modal .admin-window__body {
    grid-template-columns: 1fr !important;
    overflow: auto !important;
  }
  body.admin-mode #admin-ozon-shop-modal .subpanel {
    overflow: visible !important;
  }
  body.admin-mode #admin-ozon-shop-modal .two-cols,
  body.admin-mode #admin-ozon-shop-modal .two-cols--compact {
    grid-template-columns: 1fr !important;
  }
}

/* === V305: keep Ozon categories visible and not duplicated visually === */
body.shop-page .marketplace-controls,
body.shop-page .marketplace-sidebar {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}
body.shop-page .marketplace-filters,
body.shop-page .marketplace-filters--right {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 10px !important;
}
body.shop-page .marketplace-side-link {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}
@media (max-width: 980px) {
  body.shop-page .marketplace-sidebar {
    display: none !important;
  }
}

/* === V306: Ozon categories from API + real product image carousel === */
.ozon-product-page{
  width:min(1480px, calc(100vw - 28px)) !important;
  margin:0 auto !important;
  padding:18px 0 46px !important;
}
.product-detail-card{
  grid-template-columns:minmax(520px, 680px) minmax(0, 1fr) !important;
  gap:32px !important;
  padding:22px !important;
  border-radius:28px !important;
  background:rgba(255,255,255,.055) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  overflow:visible !important;
}
.product-gallery{
  display:grid !important;
  grid-template-columns:86px minmax(0, 1fr) !important;
  gap:14px !important;
  align-items:start !important;
  min-width:0 !important;
  position:sticky !important;
  top:132px !important;
}
.product-gallery__main{
  grid-column:2 !important;
  grid-row:1 !important;
  min-width:0 !important;
  border-radius:24px !important;
  background:#fff !important;
  border:1px solid rgba(18,28,45,.10) !important;
  overflow:hidden !important;
  aspect-ratio:1 / 1 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.product-gallery__zoom{
  height:100% !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:#fff !important;
}
.product-gallery__zoom img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  padding:10px !important;
  box-sizing:border-box !important;
}
.product-gallery__thumbs{
  grid-column:1 !important;
  grid-row:1 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  max-height:min(650px, calc(100vh - 180px)) !important;
  overflow:auto !important;
  padding:2px 4px 2px 2px !important;
  scrollbar-width:thin !important;
}
.product-gallery__thumb{
  width:78px !important;
  height:78px !important;
  flex:0 0 78px !important;
  padding:4px !important;
  border-radius:16px !important;
  border:2px solid transparent !important;
  background:#fff !important;
  box-shadow:0 8px 22px rgba(0,0,0,.10) !important;
  cursor:pointer !important;
  overflow:hidden !important;
}
.product-gallery__thumb.is-active{
  border-color:#6b8cff !important;
  box-shadow:0 0 0 4px rgba(107,140,255,.16), 0 8px 22px rgba(0,0,0,.10) !important;
}
.product-gallery__thumb img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block !important;
}
.product-info{
  padding:4px 4px 8px !important;
  align-self:start !important;
}
.product-info h1{
  font-size:clamp(24px, 2vw, 34px) !important;
  line-height:1.12 !important;
  max-height:none !important;
}
.product-tabs{
  top:78px !important;
  overflow:auto !important;
  flex-wrap:nowrap !important;
}
.product-tabs a{white-space:nowrap !important;}
.product-market-section{
  scroll-margin-top:132px !important;
}
.product-lightbox__panel{
  background:#fff !important;
}
.product-lightbox__panel img{
  padding:10px !important;
  box-sizing:border-box !important;
}
body.light-theme .product-detail-card,
html[data-theme="light"] .product-detail-card{
  background:rgba(255,255,255,.88) !important;
  border-color:rgba(18,28,45,.10) !important;
}
@media (max-width:1100px){
  .product-detail-card{grid-template-columns:1fr !important;}
  .product-gallery{position:relative !important;top:auto !important;}
}
@media (max-width:720px){
  .ozon-product-page{width:min(100%, calc(100vw - 16px)) !important;padding-top:10px !important;}
  .product-detail-card{padding:12px !important;border-radius:20px !important;gap:16px !important;}
  .product-gallery{
    grid-template-columns:1fr !important;
    grid-template-rows:auto auto !important;
    gap:10px !important;
  }
  .product-gallery__main{grid-column:1 !important;grid-row:1 !important;border-radius:18px !important;}
  .product-gallery__thumbs{
    grid-column:1 !important;
    grid-row:2 !important;
    flex-direction:row !important;
    max-height:none !important;
    overflow-x:auto !important;
    overflow-y:hidden !important;
    padding:2px 2px 8px !important;
  }
  .product-gallery__thumb{width:66px !important;height:66px !important;flex-basis:66px !important;border-radius:14px !important;}
}


/* === V307: расстояние между категориями + чистый выбор цвета без цифр === */
body.shop-page .marketplace-sidebar {
  display: flex !important;
  flex-direction: column !important;
  gap: 9px !important;
}
body.shop-page .marketplace-sidebar__title {
  margin-bottom: 2px !important;
}
body.shop-page .marketplace-side-link {
  margin: 0 0 8px 0 !important;
  line-height: 1.25 !important;
}
body.shop-page .marketplace-side-link + .marketplace-side-link {
  margin-top: 2px !important;
}
.product-variants__grid {
  gap: 12px !important;
}
.product-variant {
  min-width: 56px !important;
  width: auto !important;
  max-width: 140px !important;
  justify-content: center !important;
}
.product-variant span {
  font-size: 0 !important;
  width: 0 !important;
  max-width: 0 !important;
  overflow: hidden !important;
}
.product-variant img {
  margin: 0 !important;
}
.product-variants__head span:empty,
.product-single-color:has(b:empty) {
  display: none !important;
}
@media (max-width: 980px) {
  body.shop-page .marketplace-sidebar {
    display: none !important;
  }
}


/* === V309: компактный аккуратный отступ между категориями === */
body.shop-page .marketplace-categories {
  gap: 5px !important;
}
body.shop-page .marketplace-sidebar {
  gap: 4px !important;
}
body.shop-page .marketplace-side-link {
  margin: 0 0 4px 0 !important;
}
body.shop-page .marketplace-side-link + .marketplace-side-link {
  margin-top: 0 !important;
}
body.shop-page .marketplace-chip {
  margin: 0 !important;
}

/* V314: ручная цена Ozon в админке */
.ozon-admin-product-card .ozon-manual-price-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 10px 0 6px;
}
.ozon-admin-product-card .ozon-manual-price-input {
  width: 130px;
  min-width: 110px;
}
.ozon-admin-product-card .ozon-manual-price-toggle {
  margin: 0;
  white-space: nowrap;
}

/* === V315 rebuilt: product photos in 3:4 format === */
.marketplace-card__image,
.shop-product-card__image,
.ozon-shop-product-image,
.admin-ozon-product__image,
.ozon-product-thumb,
.product-mini-card__image {
  aspect-ratio: 3 / 4 !important;
  height: auto !important;
}

.marketplace-card__image-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.marketplace-card__image img,
.shop-product-card__image img,
.ozon-shop-product-image img,
.admin-ozon-product__image img,
.ozon-product-thumb img,
.product-mini-card__image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

.product-gallery__main {
  aspect-ratio: 3 / 4 !important;
  max-height: min(760px, calc(100vh - 180px)) !important;
}
.product-gallery__zoom img {
  object-fit: contain !important;
}

/* V316: аккуратный поиск в окне «Озон магазин» */
.ozon-admin-search {
  display: grid;
  gap: 6px;
  margin: 8px 0 12px;
}
.ozon-admin-search span {
  font-size: 13px;
  opacity: .78;
}


/* === V317: Ozon-like description and characteristics formatting === */
.product-description-text{
  max-width: 1040px !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}
.product-description-text p{
  margin: 0 0 14px !important;
  color: rgba(255,255,255,.86);
  font-size: 16px;
  line-height: 1.68;
}
.product-description-text p:last-child{margin-bottom:0 !important;}
.product-description-text ul{
  margin: 8px 0 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid;
  gap: 8px;
}
.product-description-text li{
  position: relative;
  padding-left: 22px;
  color: rgba(255,255,255,.86);
  line-height: 1.52;
}
.product-description-text li::before{
  content: "";
  position: absolute;
  left: 4px;
  top: .7em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,.45);
}
.product-characteristics-table{
  width: min(100%, 980px);
  display: grid;
  gap: 0;
}
.product-characteristics-row{
  display: grid;
  grid-template-columns: minmax(190px, 38%) minmax(0, 1fr);
  gap: 22px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.10);
  align-items: start;
}
.product-characteristics-row:last-child{border-bottom:0;}
.product-characteristics-name{
  min-width: 0;
  position: relative;
  color: rgba(255,255,255,.52);
  font-size: 14px;
  line-height: 1.35;
}
.product-characteristics-name span{
  background: transparent;
  padding-right: 8px;
}
.product-characteristics-value{
  min-width: 0;
  color: rgba(255,255,255,.90);
  font-size: 15px;
  line-height: 1.42;
  font-weight: 750;
  overflow-wrap: anywhere;
}
.product-characteristics-value b{font-weight:750;color:inherit;}
body.light-theme .product-description-text p,
html[data-theme="light"] .product-description-text p,
body.light-theme .product-description-text li,
html[data-theme="light"] .product-description-text li,
body.light-theme .product-characteristics-value,
html[data-theme="light"] .product-characteristics-value{color:rgba(18,28,45,.82);}
body.light-theme .product-description-text li::before,
html[data-theme="light"] .product-description-text li::before{background:rgba(18,28,45,.35);}
body.light-theme .product-characteristics-row,
html[data-theme="light"] .product-characteristics-row{border-bottom-color:rgba(18,28,45,.11);}
body.light-theme .product-characteristics-name,
html[data-theme="light"] .product-characteristics-name{color:rgba(18,28,45,.55);}
@media (max-width: 720px){
  .product-characteristics-row{
    grid-template-columns: 1fr;
    gap: 5px;
    padding: 12px 0;
  }
  .product-characteristics-name{font-size:13px;}
  .product-characteristics-value{font-size:14px;}
}

/* V319: ручная цена со скидкой для товаров Ozon */
.ozon-manual-price-row--discount {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  gap: 8px;
}
.ozon-price-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 130px;
}
.ozon-price-field span {
  font-size: 12px;
  opacity: .78;
  font-weight: 700;
}
.ozon-admin-old-price,
.marketplace-card__old-price {
  display: inline-block;
  margin-left: 6px;
  opacity: .65;
  text-decoration: line-through;
  font-style: normal;
  font-weight: 700;
}
.marketplace-card__price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 4px 6px;
}


/* V321: главная витрина без описания, описание только внутри полной карточки товара */
.marketplace-card p,
.shop-product-card p,
.ozon-shop-card p,
.product-card__description,
.shop-card__description {
  display: none !important;
}

/* V321: характеристики в полной карточке товара — аккуратная таблица как на Ozon */
.product-page #characteristics .product-characteristics-table {
  display: block !important;
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
}
.product-page #characteristics .product-characteristics-row {
  display: grid !important;
  grid-template-columns: minmax(190px, 34%) 1fr;
  gap: 18px;
  align-items: start;
  padding: 13px 0;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.product-page #characteristics .product-characteristics-name {
  color: rgba(255,255,255,.58);
  font-size: 14px;
  line-height: 1.35;
}
.product-page #characteristics .product-characteristics-value {
  color: rgba(255,255,255,.92);
  font-size: 14px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.product-page #characteristics .product-characteristics-value b {
  font-weight: 650;
}
body.light-theme .product-page #characteristics .product-characteristics-row,
html[data-theme="light"] .product-page #characteristics .product-characteristics-row {
  border-bottom-color: rgba(18,28,45,.12);
}
body.light-theme .product-page #characteristics .product-characteristics-name,
html[data-theme="light"] .product-page #characteristics .product-characteristics-name {
  color: rgba(18,28,45,.55);
}
body.light-theme .product-page #characteristics .product-characteristics-value,
html[data-theme="light"] .product-page #characteristics .product-characteristics-value {
  color: rgba(18,28,45,.88);
}
@media (max-width: 720px) {
  .product-page #characteristics .product-characteristics-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }
}

/* V325 real rebuilt: compact categories and shop filters */
.marketplace-side-categories{display:flex;flex-direction:column;gap:6px}.marketplace-side-show-all{margin-top:8px;width:100%;border:1px solid rgba(148,163,184,.25);background:rgba(255,255,255,.06);color:inherit;border-radius:12px;padding:10px 12px;font-weight:700;cursor:pointer}.marketplace-side-show-all:hover{background:rgba(255,255,255,.1)}.marketplace-filters--right{gap:10px;align-items:center;flex-wrap:wrap}.shop-price-filter{display:flex;align-items:center;gap:8px}.marketplace-input--price{width:110px;min-height:40px;border-radius:12px;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.08);color:inherit;padding:0 12px;outline:none}.marketplace-input--price:focus{border-color:rgba(96,165,250,.7)}.shop-discount-toggle{display:inline-flex;align-items:center;gap:8px;min-height:40px;border-radius:12px;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.06);padding:0 12px;font-size:13px;font-weight:700;white-space:nowrap}.shop-discount-toggle input{width:16px;height:16px}.hidden{display:none!important}@media(max-width:760px){.shop-price-filter{width:100%}.marketplace-input--price{flex:1;width:auto}.shop-discount-toggle{width:100%;justify-content:center}}

/* V327: жёстко фиксируем верхний меню-бар при прокрутке */
html {
  scroll-padding-top: 104px !important;
}

body {
  padding-top: 96px !important;
}

.topbar {
  position: fixed !important;
  top: 14px !important;
  left: 14px !important;
  right: 14px !important;
  width: auto !important;
  z-index: 99999 !important;
  margin-bottom: 0 !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

body.shop-page .topbar,
body.builder-page .topbar,
body.admin-mode .topbar,
body.user-mode .topbar,
body.admin-mode.builder-page .topbar {
  position: fixed !important;
  top: 14px !important;
  left: 14px !important;
  right: 14px !important;
  z-index: 99999 !important;
}

/* Чтобы якоря/контент не прятались под фиксированной шапкой */
.main-content,
.maker-layout,
.shop-page-shell,
.marketplace-page,
.product-page {
  scroll-margin-top: 104px !important;
}

@media (max-width: 980px) {
  body {
    padding-top: 118px !important;
  }
}

@media (max-width: 760px) {
  body {
    padding-top: 136px !important;
  }
  .topbar,
  body.shop-page .topbar,
  body.builder-page .topbar,
  body.admin-mode .topbar,
  body.user-mode .topbar {
    top: 8px !important;
    left: 8px !important;
    right: 8px !important;
  }
}


/* V328: поиск товаров внутри верхнего меню-бара */
body.shop-page .topbar {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.topbar-shop-search {
  flex: 1 1 360px;
  max-width: 520px;
  min-width: 220px;
  position: relative;
  display: flex;
  align-items: center;
}
.topbar-shop-search__icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(148, 163, 184, .9);
  font-size: 18px;
  pointer-events: none;
}
.topbar-shop-search input {
  width: 100%;
  min-height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .28);
  background: rgba(15, 23, 42, .72);
  color: #fff;
  padding: 0 16px 0 42px;
  outline: none;
  font-weight: 650;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.topbar-shop-search input::placeholder { color: rgba(203, 213, 225, .68); }
.topbar-shop-search input:focus {
  border-color: rgba(56,189,248,.68);
  box-shadow: 0 0 0 4px rgba(56,189,248,.13);
}
body[data-theme="light"] .topbar-shop-search input,
html[data-theme="light"] .topbar-shop-search input {
  background: rgba(255,255,255,.94);
  color: #0f172a;
  border-color: rgba(15, 23, 42, .14);
}
body[data-theme="light"] .topbar-shop-search input::placeholder,
html[data-theme="light"] .topbar-shop-search input::placeholder { color: rgba(71,85,105,.72); }
body.shop-page .marketplace-hero { display: none !important; }
@media (max-width: 1080px) {
  .topbar-shop-search { order: 3; flex-basis: 100%; max-width: none; width: 100%; }
  body.shop-page .topbar { flex-wrap: wrap !important; }
  body.shop-page { padding-top: 148px !important; }
}
@media (max-width: 760px) {
  .topbar-shop-search input { min-height: 40px; }
  body.shop-page { padding-top: 168px !important; }
}

/* V329: магазин — фильтры слева вместо отдельного блока "Разделы" */
body.shop-page .marketplace-controls--compact {
  display: none !important;
}
body.shop-page .marketplace-sidebar--filters {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  align-self: start !important;
}
body.shop-page .marketplace-sidebar--filters .marketplace-sidebar__title {
  display: none !important;
}
body.shop-page .marketplace-sidebar-filter,
body.shop-page .marketplace-sidebar-filter--price {
  width: 100% !important;
}
body.shop-page .marketplace-select--sidebar,
body.shop-page .marketplace-sidebar--filters .marketplace-select {
  width: 100% !important;
  min-height: 42px !important;
}
body.shop-page .marketplace-sidebar-filter--price {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}
body.shop-page .marketplace-sidebar--filters .marketplace-input--price {
  width: 100% !important;
  min-width: 0 !important;
}
body.shop-page .shop-discount-toggle--sidebar {
  width: 100% !important;
  justify-content: flex-start !important;
  min-height: 42px !important;
}
body.shop-page .marketplace-sidebar--filters .marketplace-side-categories {
  margin-top: 2px !important;
}
@media (max-width: 980px) {
  body.shop-page .marketplace-sidebar--filters {
    position: static !important;
    display: flex !important;
  }
}
@media (max-width: 760px) {
  body.shop-page .marketplace-sidebar-filter--price {
    grid-template-columns: 1fr !important;
  }
}


/* V330: слева только фильтры, без списка категорий; блок фильтров держится при прокрутке */
body.shop-page .marketplace-sidebar--filters .marketplace-side-categories,
body.shop-page .marketplace-sidebar--filters .marketplace-side-show-all {
  display: none !important;
}
body.shop-page .marketplace-sidebar--filters {
  position: sticky !important;
  top: 112px !important;
  max-height: calc(100vh - 132px) !important;
  overflow: visible !important;
  z-index: 30 !important;
}
body.shop-page .marketplace-layout {
  align-items: flex-start !important;
}
@media (max-width: 980px) {
  body.shop-page .marketplace-sidebar--filters {
    position: static !important;
    max-height: none !important;
  }
}

/* === V331: левое меню фильтров зафиксировано при прокрутке === */
@media (min-width: 981px) {
  body.shop-page .marketplace-layout {
    display: block !important;
    position: relative !important;
  }

  body.shop-page .marketplace-sidebar--filters {
    position: fixed !important;
    top: 96px !important;
    left: max(16px, calc((100vw - 1480px) / 2 + 16px)) !important;
    width: 230px !important;
    max-height: calc(100vh - 116px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    z-index: 9000 !important;
    padding: 12px !important;
    box-sizing: border-box !important;
    border-radius: 22px !important;
    background: rgba(15, 23, 42, .92) !important;
    border: 1px solid rgba(148, 163, 184, .18) !important;
    backdrop-filter: blur(14px) !important;
  }

  body[data-theme="light"].shop-page .marketplace-sidebar--filters {
    background: rgba(255, 255, 255, .94) !important;
    border-color: rgba(203, 213, 225, .9) !important;
  }

  body.shop-page .marketplace-products-wrap {
    margin-left: 252px !important;
    width: calc(100% - 252px) !important;
    min-width: 0 !important;
  }
}

@media (max-width: 980px) {
  body.shop-page .marketplace-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  body.shop-page .marketplace-sidebar--filters {
    position: static !important;
    width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    z-index: auto !important;
  }

  body.shop-page .marketplace-products-wrap {
    margin-left: 0 !important;
    width: 100% !important;
  }
}

/* === V332: аккуратные отступы для закреплённого левого блока фильтров === */
@media (min-width: 981px) {
  body.shop-page .marketplace-sidebar--filters {
    top: 112px !important;
    left: max(28px, calc((100vw - 1480px) / 2 + 28px)) !important;
    width: 240px !important;
    max-height: calc(100vh - 144px) !important;
    padding: 14px !important;
    border-radius: 24px !important;
    box-shadow: 0 18px 46px rgba(2, 6, 23, .26) !important;
  }

  body.shop-page .marketplace-products-wrap {
    margin-left: 288px !important;
    width: calc(100% - 288px) !important;
  }
}

/* === V333: дополнительный зазор между левым фильтром и карточками товаров === */
@media (min-width: 981px) {
  body.shop-page .marketplace-sidebar--filters {
    left: max(32px, calc((100vw - 1480px) / 2 + 32px)) !important;
    width: 240px !important;
  }

  body.shop-page .marketplace-products-wrap {
    margin-left: 332px !important;
    width: calc(100% - 332px) !important;
  }
}


/* === V334: зазор фильтр/товары уменьшен в 2 раза + поиск по центру между меню и корзиной === */
@media (min-width: 981px) {
  body.shop-page .marketplace-products-wrap {
    margin-left: 286px !important;
    width: calc(100% - 286px) !important;
  }

  body.shop-page .topbar {
    grid-template-columns: auto auto minmax(320px, 520px) auto !important;
  }

  body.shop-page .topbar-shop-search {
    flex: 0 1 500px !important;
    width: min(500px, 30vw) !important;
    max-width: 500px !important;
    min-width: 320px !important;
    margin-left: clamp(18px, 2vw, 42px) !important;
    margin-right: clamp(18px, 2vw, 42px) !important;
    justify-self: center !important;
  }

  body.shop-page .site-main-nav {
    flex: 0 0 auto !important;
  }

  body.shop-page .topbar__right-cluster {
    flex: 0 0 auto !important;
    margin-left: 0 !important;
  }
}

@media (max-width: 1280px) and (min-width: 981px) {
  body.shop-page .topbar-shop-search {
    width: min(420px, 28vw) !important;
    min-width: 260px !important;
    margin-left: 16px !important;
    margin-right: 16px !important;
  }
}


/* === V337: мягкое скрытие товаров под фиксированным меню без анимации карточек === */
body.shop-page .marketplace-card {
  opacity: 1 !important;
  transform: none !important;
  filter: none !important;
  transition: box-shadow .22s ease, border-color .22s ease, transform .18s ease !important;
}
body.shop-page .marketplace-card:hover {
  transform: translateY(-2px) !important;
}

body.shop-page::before {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  top: 76px;
  height: 72px;
  z-index: 99990;
  pointer-events: none;
  background:
    linear-gradient(180deg,
      rgba(15, 23, 42, .78) 0%,
      rgba(15, 23, 42, .46) 42%,
      rgba(15, 23, 42, 0) 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.88) 45%, transparent 100%);
          mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.88) 45%, transparent 100%);
}

body[data-theme="light"].shop-page::before,
html[data-theme="light"] body.shop-page::before {
  background:
    linear-gradient(180deg,
      rgba(248, 250, 252, .86) 0%,
      rgba(248, 250, 252, .54) 42%,
      rgba(248, 250, 252, 0) 100%);
}

@media (max-width: 1080px) {
  body.shop-page::before {
    top: 128px;
    height: 64px;
  }
}

@media (max-width: 760px) {
  body.shop-page::before {
    top: 150px;
    height: 58px;
  }
}

/* === V338: видимая стеклянная маска под верхним меню при прокрутке === */
body.shop-page .topbar {
  background: rgba(15, 23, 42, .86) !important;
  border: 1px solid rgba(148, 163, 184, .22) !important;
  box-shadow: 0 16px 42px rgba(2, 6, 23, .34) !important;
  backdrop-filter: blur(22px) saturate(1.25) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.25) !important;
}

body[data-theme="light"].shop-page .topbar,
html[data-theme="light"] body.shop-page .topbar {
  background: rgba(255, 255, 255, .88) !important;
  border-color: rgba(15, 23, 42, .12) !important;
  box-shadow: 0 16px 38px rgba(15, 23, 42, .14) !important;
}

body.shop-page::after {
  content: "" !important;
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  height: 150px !important;
  z-index: 99998 !important;
  pointer-events: none !important;
  background: linear-gradient(180deg,
    rgba(15, 23, 42, .96) 0%,
    rgba(15, 23, 42, .78) 42%,
    rgba(15, 23, 42, .28) 72%,
    rgba(15, 23, 42, 0) 100%) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 58%, rgba(0,0,0,.65) 76%, transparent 100%) !important;
          mask-image: linear-gradient(180deg, #000 0%, #000 58%, rgba(0,0,0,.65) 76%, transparent 100%) !important;
}

body[data-theme="light"].shop-page::after,
html[data-theme="light"] body.shop-page::after {
  background: linear-gradient(180deg,
    rgba(248, 250, 252, .98) 0%,
    rgba(248, 250, 252, .82) 42%,
    rgba(248, 250, 252, .34) 72%,
    rgba(248, 250, 252, 0) 100%) !important;
}

@media (max-width: 1080px) {
  body.shop-page::after {
    height: 190px !important;
  }
}

@media (max-width: 760px) {
  body.shop-page::after {
    height: 210px !important;
  }
}

/* === V340: исправленная маска ухода товаров под меню без перекрытия заголовков === */
body.shop-page::before,
body.shop-page::after {
  content: none !important;
  display: none !important;
  background: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.shop-page .topbar {
  overflow: visible !important;
  isolation: isolate !important;
  z-index: 99999 !important;
  background: rgba(15, 23, 42, .90) !important;
  backdrop-filter: blur(22px) saturate(1.18) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.18) !important;
}

body.shop-page .topbar::after {
  content: "" !important;
  position: absolute !important;
  left: -14px !important;
  right: -14px !important;
  top: calc(100% + 2px) !important;
  height: 24px !important;
  pointer-events: none !important;
  z-index: -1 !important;
  background: linear-gradient(180deg,
    rgba(15, 23, 42, .42) 0%,
    rgba(15, 23, 42, .18) 48%,
    rgba(15, 23, 42, 0) 100%) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.72) 55%, transparent 100%) !important;
          mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.72) 55%, transparent 100%) !important;
}

body[data-theme="light"].shop-page .topbar,
html[data-theme="light"] body.shop-page .topbar {
  background: rgba(255, 255, 255, .92) !important;
}

body[data-theme="light"].shop-page .topbar::after,
html[data-theme="light"] body.shop-page .topbar::after {
  background: linear-gradient(180deg,
    rgba(248, 250, 252, .54) 0%,
    rgba(248, 250, 252, .24) 48%,
    rgba(248, 250, 252, 0) 100%) !important;
}

@media (max-width: 760px) {
  body.shop-page .topbar::after {
    height: 18px !important;
  }
}

/* === V341: аккуратное затухание товаров под фиксированным меню без перекрытия заголовка === */
body.shop-page::before,
body.shop-page::after,
body.shop-page .topbar::after {
  content: none !important;
  display: none !important;
  background: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.shop-page .topbar {
  z-index: 100000 !important;
  background: rgba(15, 23, 42, .92) !important;
  backdrop-filter: blur(18px) saturate(1.18) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.18) !important;
}

body[data-theme="light"].shop-page .topbar,
html[data-theme="light"] body.shop-page .topbar {
  background: rgba(255, 255, 255, .94) !important;
}

body.shop-page .shop-scroll-fade-mask {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: 84px !important;
  height: 38px !important;
  z-index: 99999 !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transition: opacity .18s ease !important;
  background: linear-gradient(180deg,
    rgba(15, 23, 42, .76) 0%,
    rgba(15, 23, 42, .34) 54%,
    rgba(15, 23, 42, 0) 100%) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.72) 64%, transparent 100%) !important;
          mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.72) 64%, transparent 100%) !important;
}

body.shop-page.shop-scrolled .shop-scroll-fade-mask {
  opacity: 1 !important;
}

body[data-theme="light"].shop-page .shop-scroll-fade-mask,
html[data-theme="light"] body.shop-page .shop-scroll-fade-mask {
  background: linear-gradient(180deg,
    rgba(248, 250, 252, .82) 0%,
    rgba(248, 250, 252, .40) 54%,
    rgba(248, 250, 252, 0) 100%) !important;
}

@media (max-width: 1080px) {
  body.shop-page .shop-scroll-fade-mask {
    top: 118px !important;
    height: 34px !important;
  }
}

@media (max-width: 760px) {
  body.shop-page .shop-scroll-fade-mask {
    top: 142px !important;
    height: 30px !important;
  }
}


/* === V342: убрать заголовок товаров и сделать заметное плавное скрытие карточек под верхним меню === */
body.shop-page .marketplace-products-head h2,
body.shop-page .marketplace-products-head .shop-products-title,
body.shop-page h2.shop-products-title {
  display: none !important;
}

body.shop-page .marketplace-products-head--compact,
body.shop-page .marketplace-products-head {
  justify-content: flex-end !important;
  min-height: 0 !important;
  margin-bottom: 12px !important;
}

body.shop-page .marketplace-products-head--compact #shop-visible-count,
body.shop-page .marketplace-products-head #shop-visible-count {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 32px !important;
  padding: 6px 12px !important;
  border-radius: 999px !important;
  background: rgba(15, 23, 42, .72) !important;
  border: 1px solid rgba(148, 163, 184, .18) !important;
  color: #cbd5e1 !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

/* Старые неудачные слои blur отключаем, чтобы они не мешали */
body.shop-page .shop-scroll-fade-mask,
body.shop-page::before,
body.shop-page::after,
body.shop-page .topbar::after {
  display: none !important;
  content: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Новый рабочий эффект: товары плавно исчезают именно в зоне под фиксированным меню */
@media (min-width: 981px) {
  body.shop-page .marketplace-products-wrap::before {
    content: '' !important;
    position: fixed !important;
    top: 78px !important;
    left: max(318px, calc((100vw - 1480px) / 2 + 318px)) !important;
    right: 0 !important;
    height: 78px !important;
    z-index: 9500 !important;
    pointer-events: none !important;
    background: linear-gradient(180deg,
      rgba(11, 18, 32, .98) 0%,
      rgba(11, 18, 32, .88) 28%,
      rgba(11, 18, 32, .42) 66%,
      rgba(11, 18, 32, 0) 100%) !important;
    backdrop-filter: blur(12px) saturate(1.05) !important;
    -webkit-backdrop-filter: blur(12px) saturate(1.05) !important;
    -webkit-mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.78) 58%, transparent 100%) !important;
            mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.78) 58%, transparent 100%) !important;
  }

  body.shop-page .marketplace-grid {
    position: relative !important;
    z-index: 1 !important;
  }
}

body[data-theme="light"].shop-page .marketplace-products-wrap::before,
html[data-theme="light"] body.shop-page .marketplace-products-wrap::before {
  background: linear-gradient(180deg,
    rgba(248, 250, 252, .98) 0%,
    rgba(248, 250, 252, .88) 28%,
    rgba(248, 250, 252, .45) 66%,
    rgba(248, 250, 252, 0) 100%) !important;
}

@media (max-width: 980px) {
  body.shop-page .marketplace-products-wrap::before {
    content: '' !important;
    position: fixed !important;
    top: 112px !important;
    left: 0 !important;
    right: 0 !important;
    height: 48px !important;
    z-index: 9500 !important;
    pointer-events: none !important;
    background: linear-gradient(180deg, rgba(11,18,32,.92), rgba(11,18,32,0)) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
  }
}

@media (max-width: 760px) {
  body.shop-page .marketplace-products-wrap::before {
    top: 138px !important;
    height: 44px !important;
  }
}
