/* =========================================================
   Theme overrides v1
   CRM «Мелодия флаконов»
   Цель: единая цветовая система, читаемость, контраст
   ========================================================= */

/* ---------- Базовые токены ---------- */

:root {
  --font-brand-serif: "Cormorant Garamond", "Playfair Display", Georgia, "Times New Roman", serif;

  --radius-sm: 0.375rem;
  --radius-md: 0.75rem;
  --radius-lg: 1rem;
  --radius-pill: 999px;

  --shadow-card: 0 8px 24px rgba(15, 23, 42, 0.08);
  --shadow-soft: 0 4px 12px rgba(15, 23, 42, 0.06);

  --focus-ring: 0 0 0 3px rgba(184, 137, 91, 0.28);
}

/* ---------- NEUTRAL: Сапфировое золото ---------- */

html[data-theme="neutral"] {
  --color-bg: #EDE7DD;
  --color-surface: #FFFFFF;
  --color-surface-soft: #F2EBE2;
  --color-surface-muted: #E4D8CD;

  --color-text: #172033;
  --color-heading: #0F1B33;
  --color-text-muted: #687385;
  --color-border: #C9BAB0;

  --color-primary: #3C5070;
  --color-primary-hover: #112250;
  --color-primary-text: #FFFFFF;

  --color-accent: #E0C68F;
  --color-accent-soft: #F3E6C8;

  --color-success: #2F6B4F;
  --color-success-bg: #EAF4EE;

  --color-warning: #8A5A14;
  --color-warning-bg: #FFF3D6;

  --color-danger: #9F2F2F;
  --color-danger-bg: #F8EAEA;

  --color-info: #3C5070;
  --color-info-bg: #EAF0F7;
}

/* ---------- LIGHT: Пудровый винный люкс ---------- */

html[data-theme="light"] {
  --color-bg: #F8F1F4;
  --color-surface: #FFFDFE;
  --color-surface-soft: #FCF6F8;
  --color-surface-muted: #F1E4EA;

  --color-text: #241C20;
  --color-heading: #331B25;
  --color-text-muted: #75636B;
  --color-border: #E9D8E0;

  --color-primary: #8A3D5A;
  --color-primary-hover: #6E2E47;
  --color-primary-text: #FFFFFF;

  --color-accent: #C4A69B;
  --color-accent-soft: #EFE2DC;

  --color-success: #5E7356;
  --color-success-bg: #EEF4EA;

  --color-warning: #8A5A14;
  --color-warning-bg: #FFF3D6;

  --color-danger: #9F3A35;
  --color-danger-bg: #F8EAEA;

  --color-info: #6F7E8D;
  --color-info-bg: #EDF1F4;
}

/* ---------- DARK: Тёмный бутик ---------- */

html[data-theme="dark"] {
  --color-bg: #17131A;
  --color-surface: #241F29;
  --color-surface-soft: #2D2633;
  --color-surface-muted: #352C3B;

  --color-text: #F8F1E8;
  --color-heading: #FFF8ED;
  --color-text-muted: #C7B8A8;
  --color-border: #3A303F;

  --color-primary: #C89B5A;
  --color-primary-hover: #A87F46;
  --color-primary-text: #24180C;

  --color-accent: #E2B76C;
  --color-accent-soft: rgba(200, 155, 90, 0.16);

  --color-success: #6DD39D;
  --color-success-bg: #173827;

  --color-warning: #F3B95F;
  --color-warning-bg: #3E2D16;

  --color-danger: #FF8A80;
  --color-danger-bg: #3F2222;

  --color-info: #8AB4F8;
  --color-info-bg: #1C2D45;
}

/* =========================================================
   Привязка старых переменных проекта к новой системе
   ========================================================= */

body.app-body-luxury {
  background: var(--color-bg) !important;
  color: var(--color-text) !important;

  --panel-text-primary: var(--color-text);
  --panel-text-secondary: var(--color-text-muted);
  --panel-text-muted: var(--color-text-muted);
  --panel-heading: var(--color-heading);
  --panel-link: var(--color-primary);
  --panel-link-hover: var(--color-primary-hover);

  --panel-glass-bg: var(--color-surface);
  --panel-glass-border: var(--color-border);
  --panel-input-bg: var(--color-surface);
  --panel-input-border: var(--color-border);

  --sidebar-text: var(--color-text);
  --sidebar-text-secondary: var(--color-text-muted);
  --sidebar-text-muted: var(--color-text-muted);
  --sidebar-icon: var(--color-accent);
  --sidebar-logo: var(--color-heading);
}

/* =========================================================
   Основной layout
   ========================================================= */

.app-main,
.app-content {
  color: var(--color-text);
}

.topbar-title,
.page-title,
.page-section-title,
.card-title,
h1, h2, h3, h4, h5, h6 {
  color: var(--color-heading) !important;
}

.text-muted,
.form-text,
small.text-muted {
  color: var(--color-text-muted) !important;
}

/* =========================================================
   Карточки, панели, формы
   ========================================================= */

.card,
.stat-card,
.modal-content,
.dropdown-menu,
.list-group-item,
.accordion-item {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
}

.card-header,
.card-footer,
.modal-header,
.modal-footer,
.accordion-button {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
  border-color: var(--color-border) !important;
}

.card-body,
.modal-body,
.accordion-body {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
}

/* Формы */

.form-control,
.form-select,
.input-group-text,
textarea,
select {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
}

.form-control::placeholder,
textarea::placeholder {
  color: var(--color-text-muted) !important;
  opacity: 1;
}

.form-control:focus,
.form-select:focus,
textarea:focus,
select:focus,
.btn:focus,
.nav-link:focus {
  border-color: var(--color-primary) !important;
  box-shadow: var(--focus-ring) !important;
  outline: none !important;
}

/* =========================================================
   Таблицы
   ========================================================= */

.table {
  color: var(--color-text) !important;
  border-color: var(--color-border) !important;
}

.table th,
.table td,
.dashboard-page .table th,
.dashboard-page .table td {
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
  border-color: var(--color-border) !important;
}

.table thead th,
.dashboard-page .table thead th {
  color: var(--color-text-muted) !important;
  background: var(--color-surface-soft) !important;
  border-color: var(--color-border) !important;
  font-weight: 700;
}

.table-hover tbody tr:hover td {
  background: var(--color-surface-soft) !important;
}

/* Пустые строки / сообщения */

.table .text-muted,
td.text-muted,
.text-center.text-muted {
  color: var(--color-text-muted) !important;
}

/* =========================================================
   Кнопки
   ========================================================= */

.btn-primary,
.btn-golden-glossy,
.btn-topbar-golden {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border: 1px solid var(--color-primary) !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.btn-primary:hover,
.btn-golden-glossy:hover,
.btn-topbar-golden:hover {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
  color: var(--color-primary-text) !important;
}

.btn-secondary,
.btn-outline-secondary {
  background: var(--color-surface-soft) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-pill) !important;
}

.btn-secondary:hover,
.btn-outline-secondary:hover {
  background: var(--color-surface-muted) !important;
  color: var(--color-heading) !important;
  border-color: var(--color-border) !important;
}

.btn-danger {
  background: var(--color-danger) !important;
  color: #FFFFFF !important;
  border-color: var(--color-danger) !important;
}

.btn-success {
  background: var(--color-success) !important;
  color: #FFFFFF !important;
  border-color: var(--color-success) !important;
}

html[data-theme="dark"] .btn-success,
html[data-theme="dark"] .btn-danger {
  color: #17131A !important;
}

/* =========================================================
   Статусы и бейджи
   Не использовать белый текст на ярких статусах
   ========================================================= */

.badge,
.order-status {
  border-radius: var(--radius-pill);
  font-weight: 600;
  border: 1px solid transparent;
}

.badge.bg-success,
.order-status.status-paid,
.order-status.status-delivered {
  background: var(--color-success-bg) !important;
  color: var(--color-success) !important;
  border-color: var(--color-success) !important;
}

.badge.bg-warning,
.order-status.status-waiting-payment,
.order-status.status-pending-client-approval {
  background: var(--color-warning-bg) !important;
  color: var(--color-warning) !important;
  border-color: var(--color-warning) !important;
}

.badge.bg-danger,
.order-status.status-cancelled,
.order-status.status-returned {
  background: var(--color-danger-bg) !important;
  color: var(--color-danger) !important;
  border-color: var(--color-danger) !important;
}

.badge.bg-info,
.order-status.status-new,
.order-status.status-packing,
.order-status.status-shipped {
  background: var(--color-info-bg) !important;
  color: var(--color-info) !important;
  border-color: var(--color-info) !important;
}

.badge.bg-primary {
  background: var(--color-info-bg) !important;
  color: var(--color-info) !important;
  border-color: var(--color-info) !important;
}

.badge.bg-secondary {
  background: var(--color-surface-muted) !important;
  color: var(--color-text-muted) !important;
  border-color: var(--color-border) !important;
}

/* Select статуса заказа */

.order-status-select {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
}

.order-status-select option {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
}

/* =========================================================
   Sidebar
   ========================================================= */

body.app-body-luxury .sidebar {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border-right: 1px solid var(--color-border) !important;
  box-shadow: var(--shadow-card) !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar {
  background: #1D1821 !important;
}

body.app-body-luxury .sidebar-brand-line1,
body.app-body-luxury .sidebar-brand-line2 {
  color: var(--color-heading) !important;
  text-shadow: none !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar-brand-line1,
html[data-theme="dark"] body.app-body-luxury .sidebar-brand-line2 {
  color: var(--color-accent) !important;
}

body.app-body-luxury .sidebar .nav-link {
  color: var(--color-text-muted) !important;
  border-radius: var(--radius-md);
}

body.app-body-luxury .sidebar .nav-link .nav-icon {
  color: var(--color-accent) !important;
}

body.app-body-luxury .sidebar .nav-link:hover {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
}

body.app-body-luxury .sidebar .nav-link.active {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .sidebar .nav-link.active .nav-icon {
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .sidebar-brand-logo {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  box-shadow:
    0 8px 22px rgba(91, 58, 41, 0.22),
    0 0 0 1px rgba(184, 137, 91, 0.35);
}

html[data-theme="dark"] body.app-body-luxury .sidebar-brand-logo {
  box-shadow:
    0 10px 28px rgba(200, 155, 90, 0.28),
    0 0 0 1px rgba(200, 155, 90, 0.45);
}

body.app-body-luxury .sidebar-brand-premium {
  justify-content: flex-start !important;
  align-items: center !important;
}

body.app-body-luxury .sidebar-brand-title {
  align-items: flex-start !important;
  text-align: left !important;
}

body.app-body-luxury .theme-hero {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 0 0 1.25rem 0;
  padding: 1.1rem 1.35rem;
  border-radius: 24px;
  border: 1px solid var(--color-border);
  background:
    radial-gradient(circle at top left, rgba(184, 137, 91, 0.14), transparent 34%),
    var(--color-surface);
  box-shadow: var(--shadow-card);
}

html[data-theme="light"] body.app-body-luxury .theme-hero {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

html[data-theme="dark"] body.app-body-luxury .theme-hero {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

body.app-body-luxury .theme-hero-logo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  box-shadow:
    0 12px 30px rgba(91, 58, 41, 0.22),
    0 0 0 1px rgba(184, 137, 91, 0.35);
}

html[data-theme="dark"] body.app-body-luxury .theme-hero-logo {
  box-shadow:
    0 14px 34px rgba(200, 155, 90, 0.28),
    0 0 0 1px rgba(200, 155, 90, 0.45);
}

body.app-body-luxury .theme-hero-title {
  font-size: clamp(1.5rem, 2.4vw, 2.4rem);
  font-weight: 800;
  letter-spacing: 0.06em;
  color: var(--color-heading);
  line-height: 1.1;
}

body.app-body-luxury .theme-hero-tags {
  display: inline-flex;
  margin-top: 0.45rem;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  background: var(--color-surface-soft);
  color: var(--color-text-muted);
  font-size: 0.9rem;
  font-weight: 600;
}

html[data-theme="neutral"] .theme-hero-title--light,
html[data-theme="neutral"] .theme-hero-title--dark,
html[data-theme="neutral"] .theme-hero-tags--light,
html[data-theme="neutral"] .theme-hero-tags--dark {
  display: none;
}

html[data-theme="light"] .theme-hero-title--neutral,
html[data-theme="light"] .theme-hero-title--dark,
html[data-theme="light"] .theme-hero-tags--neutral,
html[data-theme="light"] .theme-hero-tags--dark {
  display: none;
}

html[data-theme="dark"] .theme-hero-title--neutral,
html[data-theme="dark"] .theme-hero-title--light,
html[data-theme="dark"] .theme-hero-tags--neutral,
html[data-theme="dark"] .theme-hero-tags--light {
  display: none;
}

@media (max-width: 767px) {
  body.app-body-luxury .theme-hero {
    padding: 0.85rem 1rem;
    border-radius: 18px;
  }

  body.app-body-luxury .theme-hero-logo {
    width: 52px;
    height: 52px;
  }

  body.app-body-luxury .theme-hero-title {
    font-size: 1.25rem;
  }

  body.app-body-luxury .theme-hero-tags {
    font-size: 0.78rem;
    padding: 0.25rem 0.55rem;
  }
}


/* =========================================================
   Portal UI Kit v1
   ========================================================= */

body.app-body-luxury .app-content {
  color: var(--color-text) !important;
}

body.app-body-luxury .page-section-title,
body.app-body-luxury .page-title,
body.app-body-luxury h1,
body.app-body-luxury h2,
body.app-body-luxury h3,
body.app-body-luxury h4,
body.app-body-luxury h5 {
  color: var(--color-heading) !important;
  text-shadow: none !important;
}

body.app-body-luxury .card,
body.app-body-luxury .crm-panel-card,
body.app-body-luxury .glass-panel {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 20px !important;
  box-shadow:
    0 14px 34px rgba(31, 41, 51, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.65) inset !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

html[data-theme="dark"] body.app-body-luxury .card,
html[data-theme="dark"] body.app-body-luxury .crm-panel-card,
html[data-theme="dark"] body.app-body-luxury .glass-panel {
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.36),
    0 1px 0 rgba(255, 255, 255, 0.04) inset !important;
}

body.app-body-luxury .card-header {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

body.app-body-luxury .text-theme-muted,
body.app-body-luxury .text-muted {
  color: var(--color-text-muted) !important;
}

body.app-body-luxury .table {
  width: 100%;
  color: var(--color-text) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .table thead th {
  background: var(--color-surface-soft) !important;
  color: var(--color-accent) !important;
  border-bottom: 1px solid var(--color-border) !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

body.app-body-luxury .table tbody td {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

body.app-body-luxury .table tbody tr:hover td {
  background: var(--color-surface-soft) !important;
}

body.app-body-luxury .table strong,
body.app-body-luxury .table .fw-bold {
  color: var(--color-heading) !important;
}

body.app-body-luxury .price-value,
body.app-body-luxury .money-value,
body.app-body-luxury .cart-total,
body.app-body-luxury .order-total,
body.app-body-luxury .summary-total {
  color: var(--color-heading) !important;
  font-weight: 700 !important;
}

body.app-body-luxury .price-cart-summary {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
  border-top: 1px solid var(--color-border);
  font-size: 1.05rem;
  font-weight: 700;
}

body.app-body-luxury .price-cart-summary,
body.app-body-luxury .price-cart-summary * {
  color: var(--color-heading) !important;
  text-shadow: none !important;
}

html[data-theme="dark"] body.app-body-luxury .price-cart-summary {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
}

body.app-body-luxury .price-page .price-table-name-cell,
body.app-body-luxury .price-page .price-table-name-cell * {
  color: var(--color-text) !important;
}

body.app-body-luxury .price-page .price-table-col-partner-price,
body.app-body-luxury .price-page .price-table-col-partner-price *,
body.app-body-luxury .price-page .price-table-col-zakupka,
body.app-body-luxury .price-page .price-table-col-zakupka * {
  color: var(--color-heading) !important;
  font-weight: 700 !important;
}

body.app-body-luxury .price-page .price-table-actions-cell .btn,
body.app-body-luxury .price-page .price-table-actions-cell .btn *,
body.app-body-luxury .price-page .price-table-actions-cell button:not(.price-cart-qty-btn),
body.app-body-luxury .price-page .price-table-actions-cell button:not(.price-cart-qty-btn) * {
  color: var(--color-primary-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td a,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td span,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td div {
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-table-col-partner-price,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-col-partner-price *,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-col-zakupka,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-col-zakupka * {
  color: var(--color-heading) !important;
  font-weight: 700 !important;
}

body.app-body-luxury .btn-primary,
body.app-body-luxury .btn-golden-glossy,
body.app-body-luxury .btn-topbar-golden,
body.app-body-luxury .btn-cart {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border-color: var(--color-primary) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 18px rgba(91, 58, 41, 0.16) !important;
  text-shadow: none !important;
}

body.app-body-luxury .btn-primary:hover,
body.app-body-luxury .btn-golden-glossy:hover,
body.app-body-luxury .btn-topbar-golden:hover,
body.app-body-luxury .btn-cart:hover {
  background: var(--color-primary-hover) !important;
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .btn-danger {
  color: #ffffff !important;
}

body.app-body-luxury .btn-success {
  color: #ffffff !important;
}

body.app-body-luxury .portal-chat-widget {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

body.app-body-luxury .portal-chat-panel {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: var(--shadow-card) !important;
}

body.app-body-luxury .portal-chat-header,
body.app-body-luxury .portal-chat-toggle,
body.app-body-luxury .portal-chat-send {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .portal-chat-message {
  background: var(--color-surface-soft) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
}

body.app-body-luxury .portal-chat-compose,
body.app-body-luxury #portal-chat-input {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury #portal-chat-input::placeholder {
  color: var(--color-text-muted) !important;
}

/* =========================================================
   Price search table readability fixes
   ========================================================= */

body.app-body-luxury .price-page .price-table-custom {
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
}

body.app-body-luxury .price-page .price-table-custom thead th {
  color: var(--color-accent) !important;
  background: var(--color-surface-soft) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .price-page .price-table-custom tbody td {
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .price-page .price-table-custom tbody tr:hover td {
  color: var(--color-text) !important;
  background: var(--color-surface-soft) !important;
}

/* Фактический порядок в admin + favorites режиме:
   1 звезда, 2 артикул, 3 каталог, 4 наименование, 5 цена партнёра, 6 закупка, 7 действия */
body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-favorite-col.price-table-custom--with-catalog-col tbody td:nth-child(1) {
  color: var(--color-text-muted) !important;
}

body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-favorite-col tbody td:nth-child(2) {
  color: var(--color-text) !important;
  font-weight: 600;
}

body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(3) {
  color: var(--color-text-muted) !important;
}

body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(4),
body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(4) * {
  color: var(--color-text) !important;
}

body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(5),
body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(5) * {
  color: var(--color-heading) !important;
  font-weight: 700;
}

body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(6),
body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(6) * {
  color: var(--color-heading) !important;
  font-weight: 700;
}

body.app-body-luxury .price-page .price-table-custom.price-table-custom--with-catalog-col tbody td:nth-child(7) {
  color: var(--color-text) !important;
}

/* Стабильные селекторы для всех конфигураций колонок */
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-article {
  color: var(--color-text) !important;
  font-weight: 600;
}

body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-catalog {
  color: var(--color-text-muted) !important;
}

body.app-body-luxury .price-page .price-table-custom tbody td.price-table-name-cell,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-name-cell a,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-name-cell span,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-name-cell div {
  color: var(--color-text) !important;
}

body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-partner-price,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-partner-price span,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-partner-price div {
  color: var(--color-heading) !important;
  font-weight: 700;
}

body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-zakupka,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-zakupka span,
body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-zakupka div {
  color: var(--color-heading) !important;
  font-weight: 700;
}

body.app-body-luxury .price-page .price-table-custom tbody td.price-table-actions-cell {
  color: var(--color-text) !important;
}

body.app-body-luxury .price-page .price-table-custom .btn,
body.app-body-luxury .price-page .price-table-custom .btn-cart,
body.app-body-luxury .price-page .price-table-custom button:not(.price-cart-qty-btn) {
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .price-page .price-table-custom .btn i,
body.app-body-luxury .price-page .price-table-custom .btn-cart i,
body.app-body-luxury .price-page .price-table-custom button:not(.price-cart-qty-btn) i {
  color: var(--color-primary-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td a,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td span,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td div {
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-partner-price,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-partner-price span,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-zakupka,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom tbody td.price-table-col-zakupka span {
  color: var(--color-heading) !important;
  font-weight: 700;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom .btn,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom .btn-cart,
html[data-theme="dark"] body.app-body-luxury .price-page .price-table-custom button:not(.price-cart-qty-btn) {
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .nav-link-logout {
  color: var(--color-danger) !important;
}

/* =========================================================
   Topbar
   ========================================================= */

body.app-body-luxury .topbar,
body.app-body-luxury .topbar-luxury {
  background: transparent !important;
  border-bottom: none !important;
}

.theme-switcher-btn,
.topbar-user-chip {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-pill) !important;
}

.topbar-user-avatar {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
}

.topbar-user-name {
  color: var(--color-heading) !important;
}

.topbar-user-role {
  color: var(--color-text-muted) !important;
}

/* =========================================================
   Ссылки
   ========================================================= */

a {
  color: var(--color-primary);
}

a:hover {
  color: var(--color-primary-hover);
}

body.app-body-luxury a {
  color: var(--color-primary);
}

body.app-body-luxury a:hover {
  color: var(--color-primary-hover);
}

.link-theme {
  color: var(--color-primary) !important;
}

.link-theme:hover {
  color: var(--color-primary-hover) !important;
}

/* =========================================================
   Alerts
   ========================================================= */

.alert-success {
  background: var(--color-success-bg) !important;
  color: var(--color-success) !important;
  border-color: var(--color-success) !important;
}

.alert-warning {
  background: var(--color-warning-bg) !important;
  color: var(--color-warning) !important;
  border-color: var(--color-warning) !important;
}

.alert-danger {
  background: var(--color-danger-bg) !important;
  color: var(--color-danger) !important;
  border-color: var(--color-danger) !important;
}

.alert-info {
  background: var(--color-info-bg) !important;
  color: var(--color-info) !important;
  border-color: var(--color-info) !important;
}

/* =========================================================
   Утилиты
   ========================================================= */

.bg-white,
.bg-light {
  background: var(--color-surface) !important;
}

.text-white {
  color: var(--color-text) !important;
}

.text-theme {
  color: var(--color-text) !important;
}

.text-theme-heading {
  color: var(--color-heading) !important;
}

.text-theme-muted {
  color: var(--color-text-muted) !important;
}

.app-card-header-accent {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border-color: var(--color-primary) !important;
}

.app-card-header-muted {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
  border-color: var(--color-border) !important;
}

.modal-header.bg-danger,
.modal-header.bg-success {
  color: #FFFFFF !important;
}

html[data-theme="dark"] .modal-header.bg-danger,
html[data-theme="dark"] .modal-header.bg-success {
  color: #17131A !important;
}

.border-top,
.border-bottom,
.border,
hr {
  border-color: var(--color-border) !important;
}

/* =========================================================
   Мобильное меню
   ========================================================= */

.mobile-menu-toggle {
  color: var(--color-heading) !important;
}

.sidebar-backdrop {
  background: rgba(0, 0, 0, 0.45) !important;
}

/* =========================================================
   Dashboard readability fixes
   ========================================================= */

body.app-body-luxury .dashboard-page,
body.app-body-luxury .dashboard-page .app-content {
  color: var(--color-text) !important;
}

body.app-body-luxury .dashboard-page .card,
body.app-body-luxury .dashboard-page .stat-card {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: var(--shadow-card) !important;
}

body.app-body-luxury .dashboard-page .card-header,
body.app-body-luxury .dashboard-page .card-footer {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .dashboard-page .card-title,
body.app-body-luxury .dashboard-page .stat-card .card-title,
body.app-body-luxury .dashboard-page .stat-value,
body.app-body-luxury .dashboard-page h1,
body.app-body-luxury .dashboard-page h2,
body.app-body-luxury .dashboard-page h3,
body.app-body-luxury .dashboard-page h4,
body.app-body-luxury .dashboard-page h5,
body.app-body-luxury .dashboard-page h6 {
  color: var(--color-heading) !important;
  text-shadow: none !important;
}

body.app-body-luxury .dashboard-page .stat-growth,
body.app-body-luxury .dashboard-page .chart-luxury-caption,
body.app-body-luxury .dashboard-page .text-theme-muted,
body.app-body-luxury .dashboard-page small,
body.app-body-luxury .dashboard-page .small {
  color: var(--color-text-muted) !important;
  text-shadow: none !important;
}

body.app-body-luxury .dashboard-page .table th,
body.app-body-luxury .dashboard-page .table td {
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .dashboard-page .table thead th {
  color: var(--color-text-muted) !important;
  background: var(--color-surface-soft) !important;
}

body.app-body-luxury .dashboard-page .dashboard-stats .stat-card,
body.app-body-luxury .dashboard-page .stats-grid .stat-card,
body.app-body-luxury .dashboard-page .stats-grid-item .stat-card {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
}

body.app-body-luxury .dashboard-page .dashboard-stats .stat-card *,
body.app-body-luxury .dashboard-page .stats-grid .stat-card *,
body.app-body-luxury .dashboard-page .stats-grid-item .stat-card * {
  text-shadow: none !important;
}

body.app-body-luxury .dashboard-page .dashboard-stats .stat-card .stat-value,
body.app-body-luxury .dashboard-page .stats-grid .stat-card .stat-value,
body.app-body-luxury .dashboard-page .stats-grid-item .stat-card .stat-value {
  color: var(--color-heading) !important;
}

body.app-body-luxury .theme-switcher-menu,
body.app-body-luxury .theme-switcher .dropdown-menu {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: var(--shadow-card) !important;
}

body.app-body-luxury .theme-switcher-menu .dropdown-item,
body.app-body-luxury .theme-switcher .dropdown-menu .dropdown-item {
  color: var(--color-text) !important;
  background: transparent !important;
}

body.app-body-luxury .theme-switcher-menu .dropdown-item:hover,
body.app-body-luxury .theme-switcher .dropdown-menu .dropdown-item:hover {
  color: var(--color-heading) !important;
  background: var(--color-surface-soft) !important;
}

html[data-theme="dark"] body.app-body-luxury .theme-switcher-menu,
html[data-theme="dark"] body.app-body-luxury .theme-switcher .dropdown-menu {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .theme-switcher-menu .dropdown-item,
html[data-theme="dark"] body.app-body-luxury .theme-switcher .dropdown-menu .dropdown-item {
  color: var(--color-text) !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar {
  background: linear-gradient(180deg, #FFFDFE 0%, #F1E4EA 100%) !important;
  border-right: 1px solid #E9D8E0 !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar .nav-link {
  color: #75636B !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar .nav-link:hover {
  background: rgba(196, 166, 155, 0.18) !important;
  color: #331B25 !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar .nav-link.active {
  background: #8A3D5A !important;
  color: #FFFFFF !important;
  box-shadow: 0 8px 20px rgba(138, 61, 90, 0.22) !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar .nav-link.active .nav-icon {
  color: #FFFFFF !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar .nav-icon {
  color: #B8798E !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar-brand-line1,
html[data-theme="light"] body.app-body-luxury .sidebar-brand-line2,
html[data-theme="light"] body.app-body-luxury .sidebar-brand-title {
  color: #331B25 !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar-toggle {
  background: #FFFDFE !important;
  color: #8A3D5A !important;
  border-color: #E9D8E0 !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar-toggle:hover {
  background: #EFE2DC !important;
  color: #331B25 !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar {
  background: linear-gradient(180deg, #1D1821 0%, #17131A 100%) !important;
  border-right: 1px solid var(--color-border) !important;
}

body.app-body-luxury .sidebar .nav-link {
  font-weight: 600;
}

body.app-body-luxury .sidebar .nav-link.active {
  box-shadow: 0 8px 20px rgba(91, 58, 41, 0.22) !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar .nav-link.active {
  box-shadow: 0 8px 20px rgba(200, 155, 90, 0.18) !important;
}

body.app-body-luxury {
  background:
    radial-gradient(circle at top left, rgba(184, 137, 91, 0.12), transparent 30%),
    radial-gradient(circle at bottom right, rgba(110, 38, 63, 0.08), transparent 28%),
    var(--color-bg) !important;
}

html[data-theme="dark"] body.app-body-luxury {
  background:
    radial-gradient(circle at top left, rgba(200, 155, 90, 0.12), transparent 32%),
    radial-gradient(circle at bottom right, rgba(110, 38, 63, 0.16), transparent 30%),
    var(--color-bg) !important;
}

body.app-body-luxury .card,
body.app-body-luxury .stat-card {
  box-shadow:
    0 10px 28px rgba(15, 23, 42, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.5) inset !important;
}

html[data-theme="dark"] body.app-body-luxury .card,
html[data-theme="dark"] body.app-body-luxury .stat-card {
  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.35),
    0 1px 0 rgba(255, 255, 255, 0.04) inset !important;
}

/* =========================================================
   Premium visual alignment (phase 3)
   ========================================================= */

html[data-theme="dark"] body.app-body-luxury .price-search-page,
html[data-theme="dark"] body.app-body-luxury .price-search-page .card,
html[data-theme="dark"] body.app-body-luxury .price-search-page .table,
html[data-theme="dark"] body.app-body-luxury .price-search-page .table td,
html[data-theme="dark"] body.app-body-luxury .price-search-page .table th {
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-search-page .table td:not(.price-actions-cell),
html[data-theme="dark"] body.app-body-luxury .price-search-page .table td:not(.price-actions-cell) * {
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-search-page .table thead th {
  color: var(--color-accent) !important;
  background: var(--color-surface-soft) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-search-page .table tbody tr:hover td {
  background: var(--color-surface-soft) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-search-page .btn-cart,
html[data-theme="dark"] body.app-body-luxury .price-search-page .price-actions-cell .btn {
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .table {
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
}

body.app-body-luxury .table thead th {
  color: var(--color-accent) !important;
  background: var(--color-surface-soft) !important;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--color-border) !important;
}

body.app-body-luxury .table tbody td {
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

body.app-body-luxury .table tbody tr:hover td {
  background: var(--color-surface-soft) !important;
}

body.app-body-luxury .card,
body.app-body-luxury .stat-card,
body.app-body-luxury .table-responsive {
  border-radius: 18px !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-surface) !important;
  box-shadow:
    0 14px 34px rgba(31, 41, 51, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.6) inset !important;
}

html[data-theme="dark"] body.app-body-luxury .card,
html[data-theme="dark"] body.app-body-luxury .stat-card,
html[data-theme="dark"] body.app-body-luxury .table-responsive {
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.36),
    0 1px 0 rgba(255, 255, 255, 0.04) inset !important;
}

body.app-body-luxury .btn-primary,
body.app-body-luxury .btn-golden-glossy,
body.app-body-luxury .btn-topbar-golden,
body.app-body-luxury .btn-cart {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border-color: var(--color-primary) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 18px rgba(91, 58, 41, 0.18) !important;
}

body.app-body-luxury .btn-primary:hover,
body.app-body-luxury .btn-golden-glossy:hover,
body.app-body-luxury .btn-topbar-golden:hover,
body.app-body-luxury .btn-cart:hover {
  background: var(--color-primary-hover) !important;
  color: var(--color-primary-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .btn-primary,
html[data-theme="dark"] body.app-body-luxury .btn-golden-glossy,
html[data-theme="dark"] body.app-body-luxury .btn-topbar-golden,
html[data-theme="dark"] body.app-body-luxury .btn-cart {
  box-shadow: 0 8px 18px rgba(200, 155, 90, 0.18) !important;
}

body.app-body-luxury .portal-chat-widget {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

body.app-body-luxury .portal-chat-panel {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: var(--shadow-card) !important;
}

body.app-body-luxury .portal-chat-header {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .portal-chat-header .portal-chat-title,
body.app-body-luxury .portal-chat-header .portal-chat-subtitle,
body.app-body-luxury .portal-chat-header .portal-chat-icon-btn {
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .portal-chat-toggle,
body.app-body-luxury .portal-chat-send {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border-color: var(--color-primary) !important;
}

body.app-body-luxury .portal-chat-toggle:hover,
body.app-body-luxury .portal-chat-send:hover {
  background: var(--color-primary-hover) !important;
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .portal-chat-message {
  background: var(--color-surface-soft) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
}

body.app-body-luxury .portal-chat-message--mine {
  background: var(--color-info-bg) !important;
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .portal-chat-message,
html[data-theme="dark"] body.app-body-luxury .portal-chat-message--mine,
html[data-theme="dark"] body.app-body-luxury .portal-chat-message--operator,
html[data-theme="dark"] body.app-body-luxury .portal-chat-message-text,
html[data-theme="dark"] body.app-body-luxury .portal-chat-message a,
html[data-theme="dark"] body.app-body-luxury .portal-chat-message--mine a {
  color: #ffffff !important;
}

body.app-body-luxury .portal-chat-compose,
body.app-body-luxury .portal-chat-visitor-fields {
  background: var(--color-surface) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .portal-chat-compose textarea,
body.app-body-luxury #portal-chat-widget .form-control,
body.app-body-luxury #portal-chat-widget textarea,
body.app-body-luxury #portal-chat-input {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .portal-chat-compose textarea::placeholder,
body.app-body-luxury #portal-chat-widget .form-control::placeholder,
body.app-body-luxury #portal-chat-input::placeholder {
  color: var(--color-text-muted) !important;
}

body.app-body-luxury .sidebar {
  border-radius: 0 24px 24px 0 !important;
}

body.app-body-luxury .sidebar .nav-link {
  margin: 0.18rem 0.75rem;
  padding: 0.72rem 1rem;
  border-radius: 14px !important;
}

body.app-body-luxury .sidebar .nav-link.active {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .sidebar .nav-link.active .nav-icon {
  color: var(--color-primary-text) !important;
}

/* =========================================================
   6. Navigation
   ========================================================= */

body.app-body-luxury .topbar-luxury {
  min-height: 0 !important;
}

@media (min-width: 1024px) {
  body.app-body-luxury .sidebar {
    width: 260px !important;
    border-radius: 0 !important;
    box-shadow: 10px 0 28px rgba(31, 41, 51, 0.08) !important;
  }
}

body.app-body-luxury .sidebar .nav-link {
  min-height: 40px !important;
  margin: 0.16rem 0.65rem !important;
  padding: 0.62rem 0.85rem !important;
  border-radius: 10px !important;
  font-size: 0.94rem !important;
  font-weight: 600 !important;
  color: var(--color-text-muted) !important;
}

body.app-body-luxury .sidebar .nav-link.active {
  background: var(--color-surface-soft) !important;
  color: var(--color-primary) !important;
  box-shadow: none !important;
}

body.app-body-luxury .sidebar .nav-link.active .nav-icon {
  color: var(--color-primary) !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar .nav-link.active {
  background: rgba(200, 155, 90, 0.12) !important;
  color: var(--color-accent) !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar .nav-link.active .nav-icon {
  color: var(--color-accent) !important;
}

/* =========================================================
   7. Branding
   ========================================================= */

body.app-body-luxury .sidebar-brand-row {
  padding: 2.25rem 1.45rem 1.65rem 1.45rem !important;
}

body.app-body-luxury .sidebar-brand-premium {
  gap: 1rem !important;
  min-height: 96px !important;
  align-items: center !important;
}

body.app-body-luxury .sidebar-brand-logo {
  width: 81px !important;
  height: 81px !important;
  flex: 0 0 81px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center !important;
  background: #050302 !important;
  box-shadow:
    0 8px 20px rgba(91, 58, 41, 0.18),
    0 0 0 1px rgba(184, 137, 91, 0.42) !important;
}

html[data-theme="light"] body.app-body-luxury .sidebar-brand-logo {
  box-shadow:
    0 8px 22px rgba(138, 61, 90, 0.12),
    0 0 0 1px rgba(233, 216, 224, 0.95) !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar-brand-logo {
  box-shadow:
    0 0 22px rgba(212, 175, 106, 0.18),
    0 0 0 1px rgba(212, 175, 106, 0.48) !important;
}

body.app-body-luxury .sidebar-brand-title {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

body.app-body-luxury .sidebar-brand-line1,
body.app-body-luxury .sidebar-brand-line2 {
  font-family: var(--font-brand-serif) !important;
  font-weight: 700 !important;
  line-height: 0.95 !important;
  letter-spacing: 0 !important;
  color: #6B4A35 !important;
  text-shadow: none !important;
  filter: none !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
}

body.app-body-luxury .sidebar-brand-line1 {
  font-size: 1.77rem !important;
}

body.app-body-luxury .sidebar-brand-line2 {
  font-size: 1.77rem !important;
}


html[data-theme="dark"] body.app-body-luxury .sidebar-brand-line1,
html[data-theme="dark"] body.app-body-luxury .sidebar-brand-line2 {
  color: #D4AF6A !important;
}

body.app-body-luxury .theme-hero-premium {
  position: static !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: 100% !important;
  min-height: auto !important;
  margin: 0 0 1rem 0 !important;
  padding: 1rem 1rem 0.85rem 1rem !important;
  gap: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.app-body-luxury .theme-hero-copy {
  text-align: center !important;
  align-items: center !important;
  justify-content: center !important;
  transform: none !important;
}

body.app-body-luxury .theme-hero-variant {
  display: none !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero-variant--neutral {
  display: block !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero-variant--light {
  display: block !important;
}

html[data-theme="dark"] body.app-body-luxury .theme-hero-variant--dark {
  display: block !important;
}

body.app-body-luxury .theme-hero-premium .theme-hero-title {
  font-family: var(--font-brand-serif) !important;
  font-size: clamp(2.7rem, 4vw, 4.3rem) !important;
  line-height: 0.95 !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em !important;
  text-transform: uppercase !important;
}

body.app-body-luxury .theme-hero-premium .theme-hero-tags {
  display: inline-flex !important;
  margin-top: 0.45rem !important;
  padding: 0.24rem 0.75rem !important;
  border-radius: 999px !important;
  background: rgba(91, 58, 41, 0.08) !important;
  border: none !important;
  box-shadow: none !important;
  font-size: 0.86rem !important;
  line-height: 1.1 !important;
  color: var(--color-text-muted) !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero-premium .theme-hero-title {
  color: #331B25 !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero-premium .theme-hero-tags {
  background: #EFE2DC !important;
  color: #8A3D5A !important;
  border: 1px solid #E9D8E0 !important;
}

html[data-theme="dark"] body.app-body-luxury .theme-hero-premium .theme-hero-title {
  color: #D4AF6A !important;
}

html[data-theme="dark"] body.app-body-luxury .theme-hero-premium .theme-hero-tags {
  background: rgba(212, 175, 106, 0.10) !important;
}

/* =========================================================
   8. Pages (targeted overrides kept from current final)
   ========================================================= */
/* Dashboard/price/cart/fragrances/orders/clients/settings page-specific styles
   remain in their dedicated earlier sections and template-local styles. */

/* =========================================================
   9. Chat widget (kept above in one final block)
   ========================================================= */

/* =========================================================
   10. Responsive
   ========================================================= */

@media (max-width: 767px) {
  body.app-body-luxury .sidebar-brand-logo {
    width: 62px !important;
    height: 62px !important;
    flex-basis: 62px !important;
  }

  body.app-body-luxury .sidebar-brand-line1 {
    font-size: 1.35rem !important;
  }

  body.app-body-luxury .sidebar-brand-line2 {
    font-size: 1.35rem !important;
  }

  body.app-body-luxury .theme-hero-premium .theme-hero-title {
    font-size: 1.95rem !important;
  }

  body.app-body-luxury .theme-hero-premium .theme-hero-tags {
    font-size: 0.68rem !important;
    padding: 0.2rem 0.55rem !important;
  }
}

/* =========================================================
   11. Temporary legacy cleanup
   ========================================================= */

body.app-body-luxury .theme-hero-logo,
body.app-body-luxury .theme-hero-logo-neutral,
body.app-body-luxury .theme-hero-mark,
body.app-body-luxury .theme-hero-mark-bottle,
body.app-body-luxury .theme-hero-emblem,
body.app-body-luxury .theme-hero-emblem-img,
body.app-body-luxury .theme-hero-actions {
  display: none !important;
}

/* =========================================================
   Hotfix: price search visible money values
   ========================================================= */

body.app-body-luxury .price-page #products-table-container {
  --price-table-article-price-text: var(--color-heading) !important;
  --price-table-text: var(--color-text) !important;
}

html[data-theme="neutral"] body.app-body-luxury .price-page #products-table-container,
html[data-theme="light"] body.app-body-luxury .price-page #products-table-container {
  --price-table-article-price-text: var(--color-heading) !important;
  --price-table-text: var(--color-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page #products-table-container {
  --price-table-article-price-text: var(--color-heading) !important;
  --price-table-text: var(--color-text) !important;
}

body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-partner-price,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-partner-price *,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-zakupka,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-zakupka * {
  color: var(--color-heading) !important;
  font-weight: 700 !important;
  opacity: 1 !important;
}

body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-article {
  color: var(--color-text) !important;
  font-weight: 600 !important;
  opacity: 1 !important;
}

body.app-body-luxury .price-page #products-table-container .price-table-custom .price-table-name-cell,
body.app-body-luxury .price-page #products-table-container .price-table-custom .price-table-name-cell * {
  color: var(--color-text) !important;
  opacity: 1 !important;
}


/* =========================================================
   Pages / Price Search
   ========================================================= */

.price-page-hero {
        padding-bottom: 0.25rem;
    }
    .price-page-hero-title {
        font-family: 'Inter', system-ui, sans-serif;
        font-weight: 700;
        font-size: clamp(1.5rem, 1.2rem + 1vw, 1.875rem);
        letter-spacing: 0.08em;
        color: #1e293b;
        margin: 0;
    }
    .price-page-hero-meta {
        font-size: 1rem;
        color: #475569;
        line-height: 1.5;
    }
    .price-page-hero-meta-empty {
        color: #94a3b8;
    }
    body.app-body-luxury .price-page-hero-title {
        color: var(--panel-heading, #f3f7ff);
    }
    body.app-body-luxury .price-page-hero-meta {
        color: var(--panel-text-secondary, #d8e4f8);
    }
    body.app-body-luxury .price-page-hero-meta-empty {
        color: var(--panel-text-muted, #9fb2c9);
    }
    .price-search-block {
        border-radius: 22px;
    }
    .price-search-block .price-search-heading {
        font-family: 'Inter', system-ui, sans-serif;
        font-weight: 700;
        font-size: clamp(1.25rem, 1.1rem + 0.45vw, 1.5rem);
        color: #1e293b;
        margin: 0;
    }
    body.app-body-luxury .price-search-block .price-search-heading {
        color: var(--panel-heading, #f3f7ff);
    }
    .price-search-block .price-search-count {
        font-size: 0.95rem;
        color: #334155;
    }
    body.app-body-luxury .price-search-block .price-search-count {
        color: var(--panel-text-secondary, #d8e4f8);
    }
    .price-search-block .price-search-label {
        font-weight: 600;
        font-size: 0.95rem;
        color: #334155;
        display: block;
        margin-bottom: 0.35rem;
    }
    .price-search-block .price-search-row {
        width: 100%;
        flex-wrap: nowrap;
    }
    .price-search-block .price-search-controls {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }
    .price-search-block .price-search-field-wrap {
        flex: 1 1 0%;
        min-width: 0;
        max-width: 100%;
        width: 100%;
        box-sizing: border-box;
    }
    .price-search-block .price-search-field-wrap .form-control {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }
    /* Одинаковые горизонтальные отступы у панели поиска и блока результатов (в т.ч. luxury crm-panel-card) */
    .price-page .price-search-block.search-panel > .card-body,
    .price-page #products-table-container > .card-body {
        padding-left: clamp(0.3rem, 0.85vw, 0.75rem);
        padding-right: clamp(0.3rem, 0.85vw, 0.75rem);
        box-sizing: border-box;
    }
    body.app-body-luxury .app-content .price-page .price-search-block.search-panel.crm-panel-card > .card-body,
    body.app-body-luxury .app-content .price-page #products-table-container.card > .card-body {
        padding-left: clamp(0.3rem, 0.85vw, 0.75rem) !important;
        padding-right: clamp(0.3rem, 0.85vw, 0.75rem) !important;
    }
    .price-search-block .price-search-actions-row {
        display: flex;
        flex-direction: row;
        align-items: stretch;
    }
    body.app-body-luxury .price-search-block .price-search-label {
        color: var(--panel-text-secondary, #d8e4f8);
    }
    /* Кнопки поиска: один каркас (размер, тень, рамка), отличаются только заливка и цвет текста */
    .price-search-block .price-search-actions-row .price-search-btn {
        width: 6.85rem;
        height: 2.75rem;
        margin: 0;
        padding: 0 0.5rem;
        white-space: nowrap;
        border-radius: 14px;
        font-weight: 600;
        font-size: 0.9375rem;
        line-height: 1.2;
        font-family: inherit;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        box-sizing: border-box;
        border-width: 1px;
        border-style: solid;
        cursor: pointer;
        text-align: center;
        text-decoration: none;
        -webkit-appearance: none;
        appearance: none;
        vertical-align: middle;
        box-shadow: 0 6px 20px rgba(15, 23, 42, 0.18);
    }

    body.app-body-luxury .price-search-block .price-search-actions-row .price-search-btn {
        box-shadow: 0 6px 22px rgba(0, 0, 0, 0.28);
    }
    .filters-bar {
        margin-bottom: 1rem;
    }

    .chips-row {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        align-items: center;
    }

    .chip {
        display: inline-flex;
        align-items: center;
        padding: 8px 16px;
        border-radius: 16px;
        border: 1px solid #dee2e6;
        background-color: #ffffff;
        color: var(--color-text);
        font-size: 0.875rem;
        font-weight: 500;
        cursor: pointer;
        transition: opacity 0.15s ease, background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
        white-space: nowrap;
        text-decoration: none !important;
        outline: none;
        box-shadow: none;
        user-select: none;
        -webkit-user-select: none;
    }

    .chip:hover {
        background-color: #f8f9fa;
        border-color: #adb5bd;
        color: var(--color-text);
    }

    .chip:focus {
        outline: none;
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
    }

    .chip.active {
        background-color: #0d6efd;
        border-color: #0d6efd;
        color: var(--color-primary-text);
    }

    .chip.active:hover {
        background-color: #0b5ed7;
        border-color: #0a58ca;
        color: var(--color-primary-text);
    }

    .chip.active:focus {
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.5);
    }

    .chip .check {
        margin-right: 6px;
        font-weight: bold;
    }

    /* Счётчик «Найдено позиций» над таблицей */
    #products-table-container #price-search-results-count {
        font-size: 1.2rem;
        font-weight: 700;
        color: var(--panel-heading, #241a14) !important;
        letter-spacing: 0.02em;
    }
    html[data-theme="light"] #products-table-container #price-search-results-count {
        color: #0f172a !important;
    }

    /* --- Таблица результатов прайса: ровная сетка, без лишних линий --- */
    #products-table-container {
        --price-table-border: rgba(255, 255, 255, 0.1);
        --price-table-head-border: rgba(255, 255, 255, 0.15);
        --price-table-text: var(--color-text);
        --price-table-head-text: #b8956a;
        --price-table-muted: rgba(186, 198, 218, 0.88);
        --price-table-article-price-text: var(--color-heading);
    }
    html[data-theme="light"] #products-table-container {
        --price-table-border: rgba(15, 23, 42, 0.1);
        --price-table-head-border: rgba(15, 23, 42, 0.14);
        --price-table-head-text: #6b4423;
        --price-table-muted: #64748b;
        --price-table-article-price-text: var(--color-heading);
    }

    /* Одна линия между строками: только border у ячеек (без дубля tr + td от Bootstrap) */
    #products-table-container .price-table-custom.table {
        table-layout: auto;
        width: 100%;
        margin-bottom: 0;
        --bs-table-bg: transparent;
        --bs-table-border-color: var(--price-table-border);
        border-collapse: collapse;
        border-color: transparent;
        box-shadow: none;
    }
    /* Лёгкий фон ячеек — без полос от глобального .table (styles.css) */
    #products-table-container .price-table-custom.table th,
    #products-table-container .price-table-custom.table td {
        background: rgba(255, 255, 255, 0.05) !important;
        color: var(--price-table-text);
    }
    html[data-theme="light"] #products-table-container .price-table-custom.table th,
    html[data-theme="light"] #products-table-container .price-table-custom.table td {
        background: rgba(255, 255, 255, 0.55) !important;
    }
    /* Перебиваем фон ячеек с !important — иначе нет подсветки строки при наведении (как .table-cart в корзине) */
    body.app-body-luxury .price-page #products-table-container .price-table-custom.table tbody tr:hover td {
        background: var(--color-surface-soft) !important;
    }
    #products-table-container .price-table-custom.table thead th {
        color: var(--price-table-head-text) !important;
        text-align: center !important;
    }
    /* Артикул и цены в строках данных (заголовки — коричневые выше) */
    #products-table-container .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) tbody td:first-child,
    #products-table-container .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) tbody td:nth-child(n+3):not(:last-child),
    #products-table-container .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) tbody td:first-child,
    #products-table-container .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) tbody td:nth-child(n+4):not(:last-child) {
        color: var(--price-table-article-price-text) !important;
    }
    #products-table-container .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) tbody td:nth-child(2),
    #products-table-container .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) tbody td:nth-child(n+4):not(:last-child),
    #products-table-container .price-table-custom.price-table-custom--with-favorite-col.price-table-custom--with-catalog-col tbody td:nth-child(3),
    #products-table-container .price-table-custom.price-table-custom--with-favorite-col.price-table-custom--with-catalog-col tbody td:nth-child(n+5):not(:last-child) {
        color: var(--price-table-article-price-text) !important;
    }
    #products-table-container .price-table-custom.table .text-muted {
        color: var(--price-table-muted) !important;
    }
    #products-table-container .price-table-custom.table > :not(caption) > * > * {
        box-shadow: none;
        border-left: none;
        border-right: none;
        border-top: none;
        border-bottom: 1px solid var(--price-table-border);
        background-clip: padding-box;
    }
    #products-table-container .price-table-custom.table thead > tr > th {
        border-bottom-color: var(--price-table-head-border);
        font-weight: 700;
    }

    /* Колонки по содержимому (наименование гибкое, цены партнёра/закупки без переноса) */
    .price-table-custom {
        table-layout: auto;
        width: 100%;
    }

    /* Заголовки столбцов — по центру (дублируем для специфичности с #products-table-container) */
    #products-table-container .price-table-custom thead th {
        text-align: center !important;
        vertical-align: middle;
    }
    .price-table-custom thead th {
        text-align: center;
        vertical-align: middle;
    }

    /* Ячейки тела: единый вертикальный ритм */
    .price-table-custom tbody td {
        padding: 0.5rem 0.5rem;
        vertical-align: top;
    }
    .price-table-custom thead th {
        padding: 0.55rem 0.5rem;
    }

    .price-table-custom:not(.price-table-custom--with-favorite-col) th:first-child,
    .price-table-custom:not(.price-table-custom--with-favorite-col) td:first-child {
        width: 120px;
        min-width: 100px;
        max-width: 130px;
    }
    .price-table-custom:not(.price-table-custom--with-favorite-col) tbody td:first-child {
        text-align: center;
    }
    .price-table-custom.price-table-custom--with-favorite-col th.price-table-col-favorite,
    .price-table-custom.price-table-custom--with-favorite-col td.price-table-col-favorite {
        width: 2.85rem !important;
        min-width: 2.5rem !important;
        max-width: 3.25rem !important;
        text-align: center !important;
        vertical-align: middle !important;
        padding: 0.35rem 0.2rem !important;
        box-sizing: border-box;
    }

    /* Без колонки «Каталог»: 2 = наименование (широкая) */
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) th:nth-child(2),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) td:nth-child(2) {
        width: auto;
        min-width: 0;
    }
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) tbody td:nth-child(2) {
        text-align: left;
    }
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) th:nth-child(3),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) td:nth-child(3),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) th:nth-child(4),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) td:nth-child(4),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) th:nth-child(5),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) td:nth-child(5) {
        width: 150px;
        min-width: 120px;
    }
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) tbody td:nth-child(3),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) tbody td:nth-child(4),
    .price-table-custom:not(.price-table-custom--with-catalog-col):not(.price-table-custom--with-favorite-col) tbody td:nth-child(5) {
        text-align: right;
    }
    .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) th:nth-child(3),
    .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) td:nth-child(3) {
        width: auto;
        min-width: 0;
    }
    .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) tbody td:nth-child(3) {
        text-align: left;
    }
    .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) th:nth-child(n+4):not(:last-child),
    .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) td:nth-child(n+4):not(:last-child) {
        width: 150px;
        min-width: 120px;
    }
    .price-table-custom.price-table-custom--with-favorite-col:not(.price-table-custom--with-catalog-col) tbody td:nth-child(n+4):not(:last-child) {
        text-align: right;
    }

    /* С колонкой «Каталог» (админ): 2 — визуал в #products-table-container .price-table-col-catalog */
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) th:nth-child(2),
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) td:nth-child(2) {
        box-sizing: border-box;
    }
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) th:nth-child(3),
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) td:nth-child(3) {
        width: auto;
        min-width: 0;
        max-width: 100%;
        padding-left: 0.65rem;
        word-break: normal;
    }
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) tbody td:nth-child(3) {
        text-align: left;
    }
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) th:nth-child(n+4):not(:last-child),
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) td:nth-child(n+4):not(:last-child) {
        width: 150px;
        min-width: 110px;
        max-width: 180px;
    }
    .price-table-custom--with-catalog-col:not(.price-table-custom--with-favorite-col) tbody td:nth-child(n+4):not(:last-child) {
        text-align: right;
    }
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col th:nth-child(2),
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col td:nth-child(2) {
        box-sizing: border-box;
    }
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col th:nth-child(3),
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col td:nth-child(3) {
        box-sizing: border-box;
    }
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col th:nth-child(4),
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col td:nth-child(4) {
        width: auto;
        min-width: 0;
        max-width: 100%;
        padding-left: 0.65rem;
        word-break: normal;
    }
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col tbody td:nth-child(4) {
        text-align: left;
    }
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col th:nth-child(n+5):not(:last-child),
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col td:nth-child(n+5):not(:last-child) {
        width: 150px;
        min-width: 110px;
        max-width: 180px;
    }
    .price-table-custom--with-catalog-col.price-table-custom--with-favorite-col tbody td:nth-child(n+5):not(:last-child) {
        text-align: right;
    }

    /* «Артикул», «Каталог»: узкая колонка по центру */
    #products-table-container .price-table-custom .price-table-col-article,
    #products-table-container .price-table-custom .price-table-col-catalog {
        width: 6.25rem;
        min-width: 5.5rem;
        max-width: 7.5rem;
        text-align: center !important;
        padding-left: 0.35rem;
        padding-right: 0.35rem;
        box-sizing: border-box;
        vertical-align: middle;
    }
    /* «Цена партнёра», «Закупка (price_1)»: заголовок как раньше — переносится; суммы — одна строка, колонка по ширине числа */
    #products-table-container .price-table-custom thead th.price-table-col-partner-price {
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        white-space: normal !important;
        text-align: center !important;
        line-height: 1.25;
        hyphens: manual;
        padding-left: 0.35rem;
        padding-right: 0.2rem;
        box-sizing: border-box;
        vertical-align: middle;
    }
    #products-table-container .price-table-custom thead th.price-table-col-zakupka {
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        white-space: normal !important;
        text-align: center !important;
        line-height: 1.25;
        hyphens: manual;
        padding-left: 0.2rem;
        padding-right: 0.35rem;
        box-sizing: border-box;
        vertical-align: middle;
    }
    #products-table-container .price-table-custom td.price-table-col-partner-price {
        width: auto !important;
        min-width: max-content !important;
        max-width: none !important;
        white-space: nowrap !important;
        text-align: center !important;
        padding-left: 0.35rem;
        padding-right: 0.15rem;
        box-sizing: border-box;
        vertical-align: middle;
        word-wrap: normal !important;
        overflow-wrap: normal !important;
    }
    #products-table-container .price-table-custom td.price-table-col-zakupka {
        width: auto !important;
        min-width: max-content !important;
        max-width: none !important;
        white-space: nowrap !important;
        text-align: center !important;
        padding-left: 0.15rem;
        padding-right: 0.3rem;
        box-sizing: border-box;
        vertical-align: middle;
        word-wrap: normal !important;
        overflow-wrap: normal !important;
    }
    #products-table-container .price-table-custom .price-table-col-catalog {
        border-right: 1px solid var(--price-table-border);
    }
    #products-table-container .price-table-custom thead th.price-table-col-article,
    #products-table-container .price-table-custom thead th.price-table-col-catalog {
        white-space: normal !important;
        line-height: 1.25;
        hyphens: manual;
    }
    #products-table-container .price-table-custom thead th.price-table-col-name {
        text-align: center !important;
    }

    .price-table-custom th:last-child,
    .price-table-custom td:last-child {
        width: auto;
        min-width: 118px;
        max-width: 150px;
        white-space: nowrap;
        vertical-align: middle;
    }
    .price-table-custom tbody td:last-child {
        text-align: right;
    }

    .price-table-custom td:last-child .btn {
        white-space: nowrap;
    }

    /* Наименование: перенос только внутри ячейки, без обрезки ellipsis */
    #products-table-container .price-table-name-cell {
        min-width: 0;
        overflow: visible;
        overflow-wrap: break-word;
        word-wrap: break-word;
        word-break: normal;
        line-height: 1.5;
        text-align: left;
    }
    #products-table-container .price-table-name-cell a {
        display: inline-block;
        max-width: 100%;
        text-align: left;
    }
    #products-table-container .price-table-name-cell a:focus-visible {
        outline: 2px solid rgba(125, 211, 252, 0.55);
        outline-offset: 2px;
        border-radius: 4px;
    }

    /* Кнопки в последней колонке — одна вертикаль, выравнивание по центру строки */
    #products-table-container .price-table-actions-cell {
        vertical-align: middle;
        text-align: right;
        white-space: nowrap;
        padding-left: 0.2rem;
    }
    #products-table-container .price-table-actions-cell .btn {
        vertical-align: middle;
    }
    #products-table-container .price-table-actions-cell .add-to-order-btn--icon-only,
    .price-mobile-actions .add-to-order-btn--icon-only {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.35rem;
        white-space: nowrap;
        padding-left: 0.65rem;
        padding-right: 0.65rem;
    }

    .price-cart-action-slot {
        display: inline-flex;
        flex-direction: column;
        align-items: flex-end;
        max-width: 100%;
    }
    .price-mobile-actions .price-cart-action-slot {
        align-items: stretch;
        width: 100%;
    }
    .price-cart-qty-control {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0;
        border-radius: 10px;
        border: 1px solid rgba(107, 79, 58, 0.28);
        background: rgba(255, 255, 255, 0.35);
        overflow: hidden;
        flex-shrink: 0;
        max-width: 100%;
        /* Один цвет для цифры и ± по текущей теме (см. усиление ниже для luxury). */
        color: var(--color-text);
    }
    [data-theme="dark"] .price-cart-qty-control {
        border-color: rgba(148, 163, 184, 0.35);
        background: rgba(15, 23, 42, 0.45);
        color: var(--color-text);
    }
    .price-cart-qty-btn {
        appearance: none;
        border: none;
        background: transparent;
        color: inherit;
        width: 2rem;
        min-width: 2rem;
        height: 2rem;
        padding: 0;
        font-size: 1.15rem;
        font-weight: 700;
        line-height: 1;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: background 0.15s ease, opacity 0.15s ease;
        opacity: 1;
    }
    .price-cart-qty-btn:hover {
        background: rgba(107, 79, 58, 0.12);
    }
    [data-theme="dark"] .price-cart-qty-btn:hover {
        background: rgba(148, 163, 184, 0.15);
    }
    .price-cart-qty-value {
        min-width: 1.5rem;
        text-align: center;
        font-weight: 600;
        font-size: 0.875rem;
        padding: 0 0.25rem;
        color: inherit;
    }

    /* Перебивает legacy «белый текст на всех button» в ячейке прайса (app-body-luxury). */
    body.app-body-luxury .price-page .price-cart-qty-control,
    .price-page .price-cart-qty-control {
        color: var(--color-text) !important;
    }
    html[data-theme="dark"] body.app-body-luxury .price-page .price-cart-qty-control,
    html[data-theme="dark"] .price-page .price-cart-qty-control {
        color: var(--color-text) !important;
    }
    body.app-body-luxury .price-page .price-cart-qty-control .price-cart-qty-btn,
    body.app-body-luxury .price-page .price-cart-qty-control .price-cart-qty-value,
    .price-page .price-cart-qty-control .price-cart-qty-btn,
    .price-page .price-cart-qty-control .price-cart-qty-value {
        color: inherit !important;
        opacity: 1 !important;
    }

    .price-table-custom td:not(.price-table-name-cell) {
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    .price-table-custom td:last-child {
        word-wrap: normal;
        overflow-wrap: normal;
    }
    .price-mobile-list {
        display: none;
    }
    .price-mobile-card {
        border: 1px solid rgba(173, 196, 233, 0.32);
        border-radius: 18px;
        padding: 0.95rem;
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.1) 100%);
        box-shadow: 0 10px 28px rgba(15, 23, 42, 0.12);
    }
    .price-mobile-card + .price-mobile-card {
        margin-top: 0.85rem;
    }
    .price-mobile-card-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.75rem;
        margin-bottom: 0.75rem;
    }
    .price-mobile-article {
        font-size: 0.82rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        color: #6b4f3a;
    }
    .price-mobile-article-line {
        display: flex;
        align-items: flex-start;
        flex-wrap: wrap;
        gap: 0.45rem;
        justify-content: flex-start;
    }
    .price-mobile-article-line > .price-mobile-article {
        margin: 0;
        flex: 1 1 auto;
        min-width: 0;
    }
    .price-mobile-article-line > .add-to-favorites-btn {
        flex-shrink: 0;
        margin-left: auto;
    }
    .price-mobile-name {
        font-size: 0.98rem;
        line-height: 1.4;
        font-weight: 600;
        color: #1f2937;
        text-align: center;
        word-break: break-word;
        overflow-wrap: anywhere;
        white-space: normal !important;
        max-width: 100%;
    }
    .price-mobile-name a {
        color: inherit;
        text-decoration: none;
        display: block;
        text-align: center;
        max-width: 100%;
    }
    .price-mobile-article a {
        color: inherit;
        text-decoration: none;
    }
    .price-mobile-article a:hover {
        text-decoration: underline;
    }
    .price-mobile-badges {
        display: flex;
        flex-wrap: wrap;
        gap: 0.4rem;
        margin-top: 0.5rem;
    }
    .price-mobile-prices {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.55rem;
        margin-top: 0.75rem;
    }
    .price-mobile-price-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.55rem 0.7rem;
        border-radius: 12px;
        background: rgba(255, 255, 255, 0.2);
    }
    .price-mobile-client-pricelist {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
    }
    .price-mobile-client-pricelist .price-mobile-price-value {
        text-align: center;
    }
    .price-mobile-price-label {
        font-size: 0.8rem;
        font-weight: 600;
        color: #475569;
    }
    .price-mobile-price-value {
        font-size: 0.92rem;
        font-weight: 700;
        color: var(--color-text);
        text-align: right;
    }
    .price-mobile-actions {
        display: flex;
        flex-direction: column;
        gap: 0.55rem;
        margin-top: 0.85rem;
    }
    .price-mobile-actions .btn,
    .price-mobile-actions .badge {
        width: 100%;
        justify-content: center;
        text-align: center;
        white-space: normal;
    }
    body.app-body-luxury .price-mobile-card {
        background: linear-gradient(180deg, rgba(128, 150, 205, 0.2) 0%, rgba(95, 126, 177, 0.12) 100%);
        border-color: rgba(173, 196, 233, 0.28);
        box-shadow: 0 12px 30px rgba(3, 7, 18, 0.24);
    }
    body.app-body-luxury .price-mobile-article {
        color: rgba(255, 255, 255, 0.96);
    }
    body.app-body-luxury .price-mobile-name {
        color: #f8fbff;
    }
    body.app-body-luxury .price-mobile-price-row {
        background: rgba(255, 255, 255, 0.08);
    }
    body.app-body-luxury .price-mobile-price-label {
        color: rgba(216, 228, 248, 0.78);
    }
    body.app-body-luxury .price-mobile-price-value {
        color: var(--panel-text-primary, #1f2937);
    }

    /* Neumorphic Toggle Switch */
    .neumorphic-toggle-container {
        margin-top: 0.5rem;
    }

    .neumorphic-toggle-input {
        display: none;
    }

    .neumorphic-toggle-label {
        position: relative;
        display: inline-block;
        width: 80px;
        height: 40px;
        cursor: pointer;
    }

    .neumorphic-toggle-slider {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: #e0e0e0;
        border-radius: 20px;
        transition: 0.3s;
        box-shadow:
            inset 4px 4px 8px rgba(0, 0, 0, 0.1),
            inset -4px -4px 8px rgba(255, 255, 255, 0.8);
    }

    .neumorphic-toggle-slider:before {
        content: "";
        position: absolute;
        height: 32px;
        width: 32px;
        left: 4px;
        bottom: 4px;
        background: #ffffff;
        border-radius: 50%;
        transition: 0.3s;
        box-shadow:
            2px 2px 4px rgba(0, 0, 0, 0.2),
            -2px -2px 4px rgba(255, 255, 255, 0.8);
    }

    .neumorphic-toggle-input:checked + .neumorphic-toggle-label .neumorphic-toggle-slider {
        background: #4ade80;
        box-shadow:
            inset 4px 4px 8px rgba(0, 0, 0, 0.1),
            inset -4px -4px 8px rgba(255, 255, 255, 0.3);
    }

    .neumorphic-toggle-input:checked + .neumorphic-toggle-label .neumorphic-toggle-slider:before {
        transform: translateX(40px);
        box-shadow:
            2px 2px 4px rgba(0, 0, 0, 0.2),
            -2px -2px 4px rgba(255, 255, 255, 0.8);
    }

    .neumorphic-toggle-text {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        font-size: 10px;
        font-weight: 600;
        color: rgba(0, 0, 0, 0.4);
        transition: 0.3s;
        pointer-events: none;
    }

    .neumorphic-toggle-input:not(:checked) + .neumorphic-toggle-label .neumorphic-toggle-text {
        left: 12px;
        color: rgba(0, 0, 0, 0.4);
    }

    .neumorphic-toggle-input:checked + .neumorphic-toggle-label .neumorphic-toggle-text {
        right: 12px;
        color: rgba(255, 255, 255, 0.9);
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    }

    /* Стр. X из Y, стрелки «» и Показать — фон rgba(255, 250, 240, 0.28) */
    .price-page #page-size-select {
        background-color: rgba(255, 250, 240, 0.28) !important;
        color: var(--color-text);
    }
    .price-page #page-size-select option {
        background-color: rgb(255, 250, 240);
        color: var(--color-text);
    }
    .price-page .pagination .page-link {
        background-color: rgba(255, 250, 240, 0.28) !important;
        color: var(--color-text);
        border-color: #dee2e6;
    }
    .price-page .pagination .page-link:hover {
        background-color: rgba(255, 250, 240, 0.5) !important;
        color: var(--color-text);
        border-color: #dee2e6;
    }

    .price-filters-panel .btn-light {
        background: rgba(255, 255, 255, 0.85);
    }
    .price-filters-panel .btn-light:hover {
        background: rgba(248, 250, 252, 0.95);
    }
    body.app-body-luxury .price-filters-panel .btn-light {
        background: rgba(255, 255, 255, 0.06);
        color: var(--panel-heading, #f3f7ff);
    }
    body.app-body-luxury .price-filters-panel .btn-light:hover {
        background: rgba(255, 255, 255, 0.1);
        color: var(--panel-heading, #f3f7ff);
    }
    body.app-body-luxury .price-filters-panel .border-top {
        border-color: rgba(255, 255, 255, 0.12) !important;
    }
    .price-filters-panel .chip-title {
        font-weight: 600;
        font-size: 0.9rem;
        color: #334155;
    }
    .price-filters-actions {
        width: 100%;
        display: flex;
        justify-content: flex-end;
        align-items: stretch;
        flex-wrap: wrap;
        gap: 0.6rem;
    }
    .price-filters-btn {
        min-width: 0;
        max-width: 100%;
        min-height: 2.75rem;
        height: auto;
        padding: 0.4rem 0.55rem;
        border-radius: 14px;
        border: 1px solid transparent;
        font-family: inherit;
        font-weight: 600;
        font-size: 0.82rem;
        line-height: 1.15;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        white-space: normal;
        overflow-wrap: anywhere;
        word-break: normal;
        box-sizing: border-box;
        text-decoration: none !important;
        box-shadow: 0 6px 18px rgba(15, 23, 42, 0.2);
    }
    .price-filters-btn .price-filters-btn-stack {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.08rem;
        max-width: 100%;
    }
    .price-filters-btn-line {
        display: block;
        max-width: 100%;
        line-height: 1.15;
        overflow-wrap: anywhere;
    }
    .price-filters-btn-line--verb {
        font-size: 0.82rem;
        font-weight: 700;
    }
    .price-filters-btn-line--noun {
        font-size: 0.72rem;
        font-weight: 600;
        letter-spacing: 0.02em;
        text-transform: lowercase;
    }

    @media (max-width: 767px) {
        .price-filters-actions {
            justify-content: stretch;
        }
        .price-filters-btn {
            flex: 1 1 calc(50% - 0.3rem);
            width: calc(50% - 0.3rem);
            max-width: calc(50% - 0.3rem);
        }
    }
    .price-search-block.search-panel,
    .price-filters-panel,
    #priceFiltersCollapse {
        position: relative;
        z-index: 40;
    }
    #priceFiltersCollapse.collapse.show {
        overflow: visible;
    }
    #priceFiltersCollapse.collapsing,
    #priceFiltersCollapse.collapse:not(.show) {
        overflow: hidden;
    }
    #priceFiltersCollapse.collapsing,
    #priceFiltersCollapse.collapsing .row,
    #priceFiltersCollapse.collapsing .position-relative,
    #priceFiltersCollapse.collapse:not(.show),
    #priceFiltersCollapse.collapse:not(.show) .row,
    #priceFiltersCollapse.collapse:not(.show) .position-relative {
        overflow: hidden !important;
    }
    #priceFiltersCollapse.is-hiding .p-3 {
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.12s ease;
    }
    #priceFiltersCollapse.collapsing .order-form-dropdown-menu,
    #priceFiltersCollapse.collapse:not(.show) .order-form-dropdown-menu {
        display: none !important;
    }
    .price-filters-panel .position-relative {
        position: relative !important;
        z-index: auto;
    }
    .price-filters-panel .position-relative.is-open {
        z-index: 1800;
    }
    .price-filters-panel .order-form-dropdown-menu {
        position: absolute !important;
        z-index: 1500 !important;
        top: calc(100% + 0.2rem);
        left: 0;
        right: 0;
        transform: none !important;
        max-height: 240px;
        overflow-y: auto;
    }
    #price-gender-filter-dropdown {
        max-height: 208px !important;
    }
    /* Портал: подписи и заголовки полей фильтра — как основной акцент заголовков, заметнее вторичного текста */
    body.app-body-luxury .app-content .price-filters-panel .form-label {
        color: var(--panel-heading, #f3f7ff) !important;
    }
    body.app-body-luxury .price-filters-panel .chip-title {
        color: var(--panel-heading, #f3f7ff);
        letter-spacing: 0.02em;
    }

    .price-brand-input {
        border-radius: 14px !important;
        padding-right: 2.2rem;
    }
    .price-brand-caret {
        position: absolute;
        right: 0.85rem;
        top: 50%;
        transform: translateY(-50%);
        pointer-events: none;
        opacity: 0.75;
        z-index: 4;
    }
    #brand-suggest-dropdown {
        top: calc(100% + 0.25rem);
        left: 0;
        right: 0;
    }
    @media (max-width: 991.98px) {
        .price-page-hero {
            padding-bottom: 0;
        }
        .price-search-block .price-search-actions-row {
            width: 100%;
        }
        .price-search-block .price-search-actions-row .price-search-btn {
            width: calc(50% - 0.25rem);
            min-width: 0;
        }
        #products-table-container .table-responsive {
            display: none;
        }
        .price-mobile-list {
            display: block;
        }
        /* Карточки мобильного списка — внутренний отступ от краёв блока результатов */
        #products-table-container #products-mobile-list {
            padding-left: 0.75rem;
            padding-right: 0.75rem;
            box-sizing: border-box;
        }
        .page-info-display {
            display: none !important;
        }
    }
    /* Планшет: кнопки уже — поле поиска шире в одной строке с «Найти / Сбросить» */
    @media (min-width: 768px) and (max-width: 991.98px) {
        .price-search-block .price-search-actions-row .price-search-btn {
            width: 5.65rem;
            padding-left: 0.35rem;
            padding-right: 0.35rem;
            font-size: 0.8125rem;
        }
        .price-search-block .price-search-row {
            gap: 0.45rem !important;
        }
    }
    /* Мобильный прайс: поле на всю ширину, кнопки в одну линию, плотнее отступы, фильтры чуть шире карточки */
    @media (max-width: 767.98px) {
        .price-page .price-search-block.search-panel > .card-body,
        .price-page #products-table-container > .card-body {
            padding-left: 0.3rem !important;
            padding-right: 0.3rem !important;
        }
        .price-page .price-search-block.search-panel > .card-body {
            padding-top: 0.75rem;
        }
        .price-search-block .price-search-heading {
            margin-bottom: 0.65rem !important;
        }
        .price-search-block .price-search-controls {
            margin-bottom: 0.5rem !important;
        }
        .price-search-block .price-search-label {
            margin-bottom: 0.25rem;
        }
        .price-search-block .price-search-row {
            flex-direction: column !important;
            align-items: stretch !important;
            flex-wrap: nowrap !important;
            gap: 0.45rem !important;
        }
        .price-search-block .price-search-field-wrap {
            width: 100% !important;
            max-width: 100% !important;
            flex: 1 1 auto !important;
        }
        .price-search-block .price-search-field-wrap .form-control {
            width: 100%;
        }
        .price-search-block .price-search-actions-row {
            width: 100% !important;
            max-width: 100% !important;
            margin-left: 0 !important;
            margin-top: 0;
            display: flex !important;
            flex-direction: row !important;
            align-items: stretch !important;
            flex-wrap: nowrap !important;
            justify-content: stretch;
            gap: 0.45rem !important;
        }
        .price-search-block .price-search-actions-row .price-search-btn {
            flex: 1 1 0;
            width: auto !important;
            min-width: 0;
            height: 2.6rem;
            white-space: nowrap;
        }
        .price-search-block .price-filters-panel {
            margin-top: 0.35rem;
            margin-left: -0.5rem;
            margin-right: -0.5rem;
            width: calc(100% + 1rem);
            max-width: none;
        }
        .price-search-block .price-filters-panel > .btn {
            padding-top: 0.65rem !important;
            padding-bottom: 0.65rem !important;
        }
    }


#products-table-container .price-table-custom td.price-table-col-partner-price,
#products-table-container .price-table-custom td.price-table-col-zakupka {
    font-weight: 600;
}

/* =========================================================
   Pages / Price Cart
   ========================================================= */

/* Скругление и рамка корзины — в шаблоне, чтобы не зависеть от кэша /static/css/styles.css */
    body.app-body-luxury .app-content .price-cart-page .price-cart-panel-shell {
        border-radius: 1.5rem !important;
        overflow: hidden !important;
        isolation: isolate !important;
        transform: translateZ(0);
        box-shadow:
            0 10px 40px rgba(15, 23, 42, 0.28),
            0 0 0 1px rgba(255, 255, 255, 0.14) !important;
    }
    html[data-theme="light"] body.app-body-luxury .app-content .price-cart-page .price-cart-panel-shell {
        box-shadow:
            0 10px 40px rgba(15, 23, 42, 0.12),
            0 0 0 1px rgba(15, 23, 42, 0.08) !important;
    }
    body.app-body-luxury .app-content .price-cart-page .price-cart-panel-shell .price-cart-panel.card {
        border: none !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        outline: none !important;
    }
    .price-cart-page .price-cart-panel-shell .price-cart-panel.card > .card-body {
        overflow: hidden;
    }
    /* Корзина прайса: старая цена и скидка по прайсу */
    .price-cart-page .price-cart-price-stack {
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        gap: 0.15rem;
        line-height: 1.25;
    }
    .price-cart-page .price-cart-old-unit {
        font-size: 0.8em;
        color: var(--text-muted, #94a3b8);
        text-decoration: line-through;
        font-weight: 500;
    }
    body.app-body-luxury .app-content .price-cart-page .price-cart-old-unit {
        color: rgba(226, 232, 240, 0.55);
    }
    html[data-theme="light"] body.app-body-luxury .app-content .price-cart-page .price-cart-old-unit {
        color: rgba(15, 23, 42, 0.45);
    }
    .price-cart-page .price-cart-discount-amount {
        font-size: 0.78em;
        font-weight: 600;
        color: var(--success, #16a34a);
    }
    body.app-body-luxury .app-content .price-cart-page .price-cart-discount-amount {
        color: #86efac;
    }
    html[data-theme="light"] body.app-body-luxury .app-content .price-cart-page .price-cart-discount-amount {
        color: #15803d;
    }
    .orders-list-page .orders-list-discount-badge {
        font-weight: 600;
        font-size: 0.7rem;
        vertical-align: middle;
        margin-left: 0.15rem;
        background: rgba(34, 197, 94, 0.2) !important;
        color: var(--success, #16a34a) !important;
        border: 1px solid rgba(34, 197, 94, 0.35);
    }
    html[data-theme="light"] .orders-list-page .orders-list-discount-badge {
        background: rgba(22, 163, 74, 0.12) !important;
        color: #15803d !important;
        border-color: rgba(22, 163, 74, 0.28);
    }
    /* Мобилка: не обрезать карточки корзины (иначе текст и цены «пропадают» за краем) */
    @media (max-width: 767.98px) {
        .price-cart-page .price-cart-panel-shell {
            overflow: visible !important;
            box-shadow: none !important;
            border: none !important;
        }
        body.app-body-luxury .app-content .price-cart-page .price-cart-panel-shell {
            overflow: visible !important;
            box-shadow: none !important;
            border: none !important;
        }
        .price-cart-page .price-cart-panel-shell .price-cart-panel.card > .card-body {
            overflow: visible !important;
        }
    }
    /* Внутренний «серый» блок таблицы — скругление */
    .price-cart-page .price-cart-table-inner,
    .order-form-page .order-form-items-table-inner,
    .orders-list-page .orders-list-table-inner {
        border-radius: 0.85rem;
        overflow: hidden;
    }
    @media (max-width: 767px) {
        .price-cart-page .table-responsive,
        .order-form-page .order-form-items-table-wrap,
        .orders-list-page .orders-list-table-wrap {
            margin: 0 !important;
            padding: 0 !important;
        }
    }
    .price-cart-page .table-cart th,
    .price-cart-page .table-cart td,
    .order-form-page .order-form-items-table-inner .table-cart th,
    .order-form-page .order-form-items-table-inner .table-cart td,
    .orders-list-page .orders-list-table-inner .table-cart th,
    .orders-list-page .orders-list-table-inner .table-cart td {
        vertical-align: middle;
    }
    .price-cart-page .cart-qty-input,
    .order-form-page .order-form-items-table-inner .cart-qty-input,
    .orders-list-page .orders-list-table-inner .cart-qty-input {
        max-width: 5rem;
        -moz-appearance: textfield;
        appearance: textfield;
    }
    .price-cart-page .cart-qty-input::-webkit-outer-spin-button,
    .price-cart-page .cart-qty-input::-webkit-inner-spin-button,
    .order-form-page .order-form-items-table-inner .cart-qty-input::-webkit-outer-spin-button,
    .order-form-page .order-form-items-table-inner .cart-qty-input::-webkit-inner-spin-button,
    .orders-list-page .orders-list-table-inner .cart-qty-input::-webkit-outer-spin-button,
    .orders-list-page .orders-list-table-inner .cart-qty-input::-webkit-inner-spin-button {
        -webkit-appearance: none;
        margin: 0;
    }
    .price-cart-page .table-cart td.price-cart-name-cell,
    .orders-list-page .orders-list-table-inner .table-cart td.price-cart-name-cell {
        max-width: 22rem;
        color: var(--color-text) !important;
        font-size: 1em;
        line-height: inherit;
    }
    .price-cart-page .table-cart th.price-cart-col-article,
    .price-cart-page .table-cart td.price-cart-col-article {
        text-align: center;
        font-size: 1em;
        line-height: inherit;
    }
    .price-cart-page .table-cart th.price-cart-col-price,
    .price-cart-page .table-cart td.price-cart-col-price,
    .price-cart-page .table-cart th.price-cart-col-qty,
    .price-cart-page .table-cart td.price-cart-col-qty,
    .price-cart-page .table-cart th.price-cart-col-sum,
    .price-cart-page .table-cart td.price-cart-col-sum {
        text-align: center;
        vertical-align: middle;
        font-size: 1em;
        line-height: inherit;
    }
    /* Современные чекбоксы (корзина) */
    .price-cart-page .price-cart-check {
        appearance: none;
        -webkit-appearance: none;
        width: 1.3125rem;
        height: 1.3125rem;
        margin: 0;
        border: 2px solid rgba(255, 255, 255, 0.38);
        border-radius: 0.42rem;
        background: rgba(255, 255, 255, 0.08);
        cursor: pointer;
        vertical-align: middle;
        /* Без transition — галочка появляется сразу при тапе */
        transition: none;
        flex-shrink: 0;
    }
    .price-cart-page .price-cart-check:hover:not(:disabled) {
        border-color: rgba(255, 255, 255, 0.58);
        background: rgba(255, 255, 255, 0.12);
    }
    .price-cart-page .price-cart-check:active:not(:disabled) {
        transform: scale(0.94);
    }
    .price-cart-page .price-cart-check:focus {
        outline: none;
        box-shadow: 0 0 0 3px rgba(94, 234, 212, 0.35);
    }
    .price-cart-page .price-cart-check:focus:not(:focus-visible) {
        box-shadow: none;
    }
    .price-cart-page .price-cart-check:focus-visible {
        box-shadow: 0 0 0 3px rgba(94, 234, 212, 0.4);
    }
    .price-cart-page .price-cart-check:checked {
        border-color: rgba(139, 105, 20, 0.95);
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.4) inset,
            0 2px 10px rgba(0, 0, 0, 0.2);
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%231a1510' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' d='M3.5 8.2 6.8 11.5 12.5 4.5'/%3E%3C/svg%3E"),
            linear-gradient(165deg, #f5e6b3 0%, #e8c547 35%, #d4af37 70%, #b8860b 100%);
        background-size: 0.92rem, 100%;
        background-position: center, center;
        background-repeat: no-repeat;
    }
    .price-cart-page .price-cart-check:disabled {
        opacity: 0.42;
        cursor: not-allowed;
        transform: none;
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-check {
        border-color: rgba(15, 23, 42, 0.22);
        background: rgba(255, 255, 255, 0.92);
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-check:hover:not(:disabled) {
        border-color: rgba(15, 23, 42, 0.38);
        background: #fff;
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-check:focus-visible {
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.35);
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-check:checked {
        border-color: #8b6914;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%231a1510' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' d='M3.5 8.2 6.8 11.5 12.5 4.5'/%3E%3C/svg%3E"),
            linear-gradient(165deg, #f5e6b3 0%, #e8c547 35%, #d4af37 70%, #b8860b 100%);
        background-size: 0.92rem, 100%;
        background-position: center, center;
        background-repeat: no-repeat;
    }
    .price-cart-page .price-cart-table-inner,
    .order-form-page .order-form-items-table-inner,
    .orders-list-page .orders-list-table-inner {
        --price-table-head-text: #b8956a;
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-table-inner,
    html[data-theme="light"] body.app-body-luxury .order-form-page .order-form-items-table-inner,
    html[data-theme="light"] body.app-body-luxury .orders-list-page .orders-list-table-inner {
        --price-table-head-text: #6b4423;
    }
    .price-cart-page .table-cart.table th,
    .price-cart-page .table-cart.table td,
    .order-form-page .order-form-items-table-inner .table-cart.table th,
    .order-form-page .order-form-items-table-inner .table-cart.table td,
    .orders-list-page .orders-list-table-inner .table-cart.table th,
    .orders-list-page .orders-list-table-inner .table-cart.table td {
        background: rgba(255, 255, 255, 0.05) !important;
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .table-cart.table th,
    html[data-theme="light"] body.app-body-luxury .price-cart-page .table-cart.table td,
    html[data-theme="light"] body.app-body-luxury .order-form-page .order-form-items-table-inner .table-cart.table th,
    html[data-theme="light"] body.app-body-luxury .order-form-page .order-form-items-table-inner .table-cart.table td,
    html[data-theme="light"] body.app-body-luxury .orders-list-page .orders-list-table-inner .table-cart.table th,
    html[data-theme="light"] body.app-body-luxury .orders-list-page .orders-list-table-inner .table-cart.table td {
        background: rgba(255, 255, 255, 0.55) !important;
    }
    /* Единый фон строки при наведении (как прайс .price-table-custom и общие .table-hover) */
    body.app-body-luxury .price-cart-page .price-cart-table-inner .table-cart.table tbody tr:hover td,
    body.app-body-luxury .order-form-page .order-form-items-table-inner .table-cart.table tbody tr:hover td,
    body.app-body-luxury .orders-list-page .orders-list-table-inner .table-cart.table tbody tr:hover td,
    body.app-body-luxury .price-fav-page .price-fav-table-inner .table-cart.table tbody tr:hover td {
        background: var(--color-surface-soft) !important;
        color: var(--color-text) !important;
    }
    /* Заголовок таблицы корзины — как в /price/search */
    .price-cart-page .table-cart.table thead th,
    .order-form-page .order-form-items-table-inner .table-cart.table thead th,
    .orders-list-page .orders-list-table-inner .table-cart.table thead th {
        text-align: center !important;
        text-transform: uppercase;
        letter-spacing: 0.03em;
        font-size: 0.875rem !important;
        font-weight: 700 !important;
        line-height: 1.2 !important;
        color: var(--price-table-head-text) !important;
    }
    /* Удаление строки — кнопка с текстом */
    .price-cart-page .table-cart .price-cart-remove.btn-crm-danger,
    .order-form-page .order-form-items-table-inner .table-cart .price-cart-remove.btn-crm-danger,
    .orders-list-page .orders-list-table-inner .table-cart .price-cart-remove.btn-crm-danger {
        width: auto;
        min-width: 5.5rem;
        height: 2.125rem;
        padding: 0.25rem 0.75rem !important;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        line-height: 1;
        font-size: 0.85rem;
        font-weight: 600;
        border-radius: 12px;
        white-space: nowrap;
    }
    .price-cart-page .table-cart .price-cart-remove.price-cart-remove-mobile.btn-crm-danger {
        width: 100% !important;
        min-width: 0 !important;
        height: auto;
        min-height: 2.25rem;
        padding: 0.375rem 0.75rem !important;
        font-size: 0.875rem;
        font-weight: 600;
        line-height: 1.5;
        white-space: nowrap;
    }
    /* Заказ: компактная круглая «×» */
    .order-form-page .order-form-items-table-inner .table-cart .remove-row.price-cart-remove.btn-crm-danger {
        min-width: 2.125rem !important;
        width: 2.125rem !important;
        height: 2.125rem !important;
        padding: 0 !important;
        border-radius: 999px !important;
        font-size: 1.05rem;
        line-height: 1;
    }
    .order-form-page .order-form-items-table-inner .table-cart.table thead th:first-child,
    .orders-list-page .orders-list-table-inner .table-cart.table thead th:first-child {
        text-align: start !important;
        padding-inline-start: 0.85rem;
    }
    /* Итого под таблицей, над разделительной чертой */
    .price-cart-page .price-cart-summary-text {
        font-size: 1.2rem;
        font-weight: 600;
        line-height: 1.35;
        color: rgba(226, 232, 240, 0.92);
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-summary-text {
        color: rgba(30, 41, 59, 0.92);
    }
    .price-cart-page .price-cart-summary-text:empty {
        display: none;
        margin-top: 0 !important;
    }
    /* Низ карточки: Прайс слева, очистить/оформить справа (одинаковая ширина у пары справа) */
    .price-cart-page .price-cart-footer-actions {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: center;
        gap: 0.5rem;
    }
    .price-cart-page .price-cart-footer-main-btns {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem;
        margin-left: auto;
        justify-content: flex-end;
    }
    .price-cart-page .price-cart-footer-main-btns > .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 13.5rem;
        max-width: 100%;
        box-sizing: border-box;
        text-align: center;
        /* Одинаковый силуэт: у btn-crm-gold нет .btn-sm в styles.css, у danger — есть */
        min-height: 2.375rem;
        padding: 0.35rem 0.75rem !important;
        font-size: 0.875rem !important;
        line-height: 1.25;
        border-radius: 12px !important;
    }
    /*
     * Карточки как на странице прайса (price_search.html): те же классы .price-mobile-*.
     * Область .price-cart-page — чтобы не пересекаться с другими страницами.
     */
    .price-cart-page .price-mobile-card {
        border: 1px solid rgba(173, 196, 233, 0.32);
        border-radius: 18px;
        padding: 0.95rem;
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.1) 100%);
        box-shadow: 0 10px 28px rgba(15, 23, 42, 0.12);
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        min-width: 0;
    }
    .price-cart-page .price-mobile-card-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.75rem;
        margin-bottom: 0.75rem;
        min-width: 0;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-article {
        font-size: 0.82rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        color: #6b4f3a;
    }
    .price-cart-page .price-mobile-article-line {
        display: flex;
        align-items: flex-start;
        flex-wrap: nowrap;
        gap: 0.45rem;
        min-width: 0;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-article-line > .price-mobile-article {
        margin: 0;
        flex: 1 1 auto;
        min-width: 0;
        white-space: normal !important;
        overflow-wrap: anywhere;
        word-break: break-word;
    }
    .price-cart-page .price-mobile-name {
        font-size: 0.98rem;
        line-height: 1.4;
        font-weight: 600;
        color: #1f2937;
        text-align: center;
        word-break: break-word;
        overflow-wrap: anywhere;
        white-space: normal !important;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-prices {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 0.55rem;
        margin-top: 0.75rem;
        min-width: 0;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-price-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.55rem 0.7rem;
        border-radius: 12px;
        background: rgba(255, 255, 255, 0.2);
        min-width: 0;
        max-width: 100%;
        box-sizing: border-box;
    }
    .price-cart-page .price-mobile-client-pricelist {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }
    .price-cart-page .price-mobile-client-pricelist .price-mobile-price-label {
        width: 100%;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-client-pricelist .price-mobile-price-value {
        text-align: center;
        width: 100%;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-price-label {
        font-size: 0.8rem;
        font-weight: 600;
        color: #475569;
    }
    .price-cart-page .price-mobile-price-value {
        font-size: 0.92rem;
        font-weight: 700;
        color: var(--color-text);
        text-align: right;
        white-space: normal !important;
        overflow-wrap: anywhere;
        word-break: break-word;
        min-width: 0;
        max-width: 100%;
    }
    .price-cart-page .price-mobile-card .price-cart-unit-display,
    .price-cart-page .price-mobile-card .price-cart-line-total {
        white-space: normal !important;
        overflow-wrap: anywhere;
        word-break: break-word;
        display: block;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }
    .price-cart-page .price-mobile-actions {
        display: flex;
        flex-direction: column;
        gap: 0.55rem;
        margin-top: 0.85rem;
    }
    .price-cart-page .price-mobile-actions .btn,
    .price-cart-page .price-mobile-actions .badge {
        width: 100%;
        justify-content: center;
        text-align: center;
        white-space: normal;
    }
    body.app-body-luxury .price-cart-page .price-mobile-card {
        background: linear-gradient(180deg, rgba(128, 150, 205, 0.2) 0%, rgba(95, 126, 177, 0.12) 100%);
        border-color: rgba(173, 196, 233, 0.28);
        box-shadow: 0 12px 30px rgba(3, 7, 18, 0.24);
    }
    body.app-body-luxury .price-cart-page .price-mobile-article {
        color: rgba(255, 255, 255, 0.96);
    }
    body.app-body-luxury .price-cart-page .price-mobile-name {
        color: #f8fbff;
    }
    body.app-body-luxury .price-cart-page .price-mobile-price-row {
        background: rgba(255, 255, 255, 0.08);
    }
    body.app-body-luxury .price-cart-page .price-mobile-price-label {
        color: rgba(216, 228, 248, 0.78);
    }
    body.app-body-luxury .price-cart-page .price-mobile-price-value {
        color: var(--panel-text-primary, #1f2937);
    }
    /* Жёстко читаемые суммы на тёмной карточке (перебиваем Bootstrap / таблицу) */
    body.app-body-luxury .price-cart-page .price-mobile-card .price-mobile-price-value,
    body.app-body-luxury .price-cart-page .price-mobile-card .price-cart-unit-display,
    body.app-body-luxury .price-cart-page .price-mobile-card .price-cart-line-total {
        color: #f8fafc !important;
    }
    body.app-body-luxury .price-cart-page .price-mobile-card .price-mobile-price-label {
        color: rgba(226, 232, 240, 0.9) !important;
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-mobile-card .price-mobile-price-value,
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-mobile-card .price-cart-unit-display,
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-mobile-card .price-cart-line-total {
        color: #0f172a !important;
    }
    html[data-theme="light"] body.app-body-luxury .price-cart-page .price-mobile-card .price-mobile-price-label {
        color: #475569 !important;
    }
    /* Чекбокс в строке артикула — габариты как у кнопки «избранное» в прайсе */
    .price-cart-page .price-mobile-article-line .price-cart-check {
        width: 2.125rem;
        height: 2.125rem;
        border-radius: 0.45rem;
    }
    /* Мобильная корзина: кнопка «Удалить» на всю ширину под кол-во/суммой */
    .price-cart-page .price-cart-mobile-actions.price-mobile-actions {
        align-items: stretch;
    }
    .price-cart-page .price-cart-mobile-actions.price-mobile-actions .price-cart-remove-mobile.btn {
        width: 100%;
        align-self: stretch;
        justify-content: center;
        text-align: center;
        white-space: nowrap;
    }
    .price-cart-page .price-cart-mobile-actions .price-cart-remove-mobile.btn-crm-danger {
        width: 100% !important;
        min-width: 0 !important;
    }
    .price-cart-page .price-cart-mobile-qty-sum-row {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        align-items: end;
        gap: 0.65rem 0.75rem;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .price-cart-page .price-cart-mobile-qty-sum-row > div {
        min-width: 0;
        max-width: 100%;
    }
    .price-cart-page .price-cart-mobile-qty-sum-row > div:first-child {
        justify-self: start;
    }
    .price-cart-page .price-cart-mobile-qty-sum-row > div:last-child {
        justify-self: end;
        text-align: right;
    }
    .price-cart-page .price-cart-mobile-qty-sum-row .cart-qty-input {
        width: 4rem !important;
        max-width: 100% !important;
        min-width: 0;
        min-height: 2.25rem;
        text-align: center;
        font-size: 1rem;
        font-weight: 600;
        border-radius: 10px;
        box-sizing: border-box;
    }
    .price-cart-page .price-cart-mobile-qty-sum-row > div:last-child .price-cart-line-total {
        text-align: right;
    }

    @media (max-width: 767.98px) {
        /* Таблица + tbody в разных display даёт min-width по содержимому — раздувает карточку */
        .price-cart-page.container-fluid {
            min-width: 0;
            max-width: 100%;
            box-sizing: border-box;
        }
        .price-cart-page .price-cart-panel-shell,
        .price-cart-page .price-cart-panel.card {
            width: 100%;
            max-width: 100%;
            box-sizing: border-box;
        }
        .price-cart-page .price-cart-table-inner,
        .price-cart-page .table-responsive {
            width: 100%;
            max-width: 100%;
            min-width: 0;
            box-sizing: border-box;
        }
        .price-cart-page .table-cart {
            display: block !important;
            width: 100% !important;
            max-width: 100% !important;
            min-width: 0 !important;
            border: 0 !important;
            background: transparent !important;
        }
        .price-cart-page .card-body { padding: 0.65rem !important; }
        .price-cart-page .table-cart thead { display: none; }
        .price-cart-page .table-cart tbody { display: block !important; width: 100% !important; max-width: 100% !important; min-width: 0 !important; }
        .price-cart-page .table-cart tbody tr.price-cart-row-mobile {
            display: block !important;
            margin-bottom: 0.85rem;
            background: transparent !important;
        }
        .price-cart-page .table-cart tbody tr.price-cart-row-mobile > td {
            display: block !important;
            width: 100% !important;
            max-width: 100% !important;
            border: none !important;
            padding: 0 !important;
            background: transparent !important;
            white-space: normal !important;
            box-sizing: border-box;
        }
        .price-cart-page .price-cart-table-inner {
            background: transparent !important;
            border-radius: 0 !important;
            overflow: visible;
        }
        .price-cart-page .table-responsive { overflow: visible !important; }

        .price-cart-page .price-cart-mobile-toolbar {
            padding: 0.65rem 0.85rem;
            border-radius: 18px;
            border: 1px solid rgba(173, 196, 233, 0.32);
            background: linear-gradient(180deg, rgba(128, 150, 205, 0.2) 0%, rgba(95, 126, 177, 0.12) 100%);
            box-shadow: 0 10px 28px rgba(3, 7, 18, 0.2);
            margin-bottom: 0.85rem;
        }
        html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-mobile-toolbar {
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.22) 0%, rgba(248, 250, 252, 0.92) 100%);
            border-color: rgba(15, 23, 42, 0.1);
            box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
        }
        html[data-theme="light"] body.app-body-luxury .price-cart-page .price-cart-mobile-toolbar span {
            color: rgba(30, 41, 59, 0.82) !important;
        }

        .price-cart-page .table-cart tbody tr.price-cart-row-message {
            display: block;
            margin-bottom: 0.5rem;
        }
        .price-cart-page .table-cart tbody tr.price-cart-row-message td {
            display: block;
            width: 100% !important;
            text-align: center !important;
            border: none !important;
            padding: 1.25rem 0.85rem !important;
            border-radius: 18px;
            border: 1px solid rgba(173, 196, 233, 0.32);
            background: linear-gradient(180deg, rgba(128, 150, 205, 0.2) 0%, rgba(95, 126, 177, 0.12) 100%);
        }
        .price-cart-page .table-cart tbody tr.price-cart-row-message td::before { content: none !important; }

        .price-cart-page .table-cart tbody tr.price-cart-row-error {
            display: block;
            margin-bottom: 0.85rem;
        }
        .price-cart-page .table-cart tbody tr.price-cart-row-error > td {
            border: none !important;
        }
        .price-cart-page .table-cart tbody tr.price-cart-row-error > td::before { content: none !important; }

        .price-cart-page .price-cart-summary-text {
            font-size: 1.05rem;
            text-align: center;
        }
        .price-cart-page .price-cart-footer-actions {
            flex-direction: column;
            align-items: stretch;
        }
        .price-cart-page .price-cart-footer-main-btns {
            margin-left: 0;
            width: 100%;
            flex-direction: column;
        }
        .price-cart-page .price-cart-footer-main-btns > .btn {
            width: 100%;
        }
        .price-cart-page .price-cart-footer-actions > a.btn {
            width: 100%;
            justify-content: center;
        }
    }


html[data-theme="dark"] body.app-body-luxury .price-cart-page .table-cart td.price-cart-name-cell,
html[data-theme="dark"] body.app-body-luxury .price-cart-page .table-cart td.price-cart-name-cell *,
html[data-theme="dark"] body.app-body-luxury .price-cart-page .price-cart-summary-text,
html[data-theme="dark"] body.app-body-luxury .price-cart-page .price-cart-summary-text * {
    color: var(--color-heading) !important;
}

html[data-theme="neutral"] body.app-body-luxury .price-cart-page .price-cart-check {
    border-color: #C9BAB0;
    background: #FFFFFF;
}

html[data-theme="neutral"] body.app-body-luxury .price-cart-page .price-cart-check:hover:not(:disabled) {
    border-color: rgba(60, 80, 112, 0.45);
    background: #FFFFFF;
}

html[data-theme="neutral"] body.app-body-luxury .price-cart-page .price-cart-check:checked {
    border-color: #8b6914;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%231a1510' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' d='M3.5 8.2 6.8 11.5 12.5 4.5'/%3E%3C/svg%3E"),
        linear-gradient(165deg, #f5e6b3 0%, #e8c547 35%, #d4af37 70%, #b8860b 100%);
    background-size: 0.92rem, 100%;
    background-position: center, center;
    background-repeat: no-repeat;
}

body.app-body-luxury .price-cart-page .price-cart-footer-actions .btn,
body.app-body-luxury .price-cart-page .price-cart-footer-main-btns > .btn {
    color: var(--color-text) !important;
}

body.app-body-luxury .price-cart-page .price-search-btn.price-search-btn--submit {
    background: var(--color-primary) !important;
    color: var(--color-primary-text) !important;
    border: 1px solid var(--color-primary) !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 18px rgba(31, 41, 51, 0.12) !important;
    text-shadow: none !important;
    font-weight: 700 !important;
    min-height: 44px;
}

body.app-body-luxury .price-cart-page .price-search-btn.price-search-btn--submit:hover {
    background: var(--color-primary-hover) !important;
    color: var(--color-primary-text) !important;
    border-color: var(--color-primary-hover) !important;
}

body.app-body-luxury .price-cart-page .price-search-btn.price-search-btn--reset {
    background: var(--color-surface-soft) !important;
    color: var(--color-text) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    text-shadow: none !important;
    font-weight: 700 !important;
    min-height: 44px;
}

body.app-body-luxury .price-cart-page .price-search-btn.price-search-btn--reset:hover {
    background: var(--color-surface-muted) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-cart-page .price-cart-footer-actions .btn,
html[data-theme="dark"] body.app-body-luxury .price-cart-page .price-cart-footer-main-btns > .btn {
    color: var(--color-heading) !important;
}

/* =========================================================
   Pages / Fragrance Catalog
   ========================================================= */

body.app-body-luxury .fragrance-client-wrap {
  background: #f7f5f2;
  color: #1f1f1f;
  border-radius: 16px;
}

body.app-body-luxury .fragrance-client-wrap .fragrance-header {
  background: #ffffff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

body.app-body-luxury .fragrance-client-wrap .catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 24px;
}

body.app-body-luxury .fragrance-client-wrap .card {
  border-radius: 16px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

body.app-body-luxury .fragrance-client-wrap .card .btn-cart {
  border-radius: 12px;
}


/* =========================================================
   Theme Hero final
   ========================================================= */

body.app-body-luxury .theme-hero.theme-hero-premium {
  width: 100% !important;
  min-height: 85px !important;
  max-height: 85px !important;
  margin: 0 0 0.9rem 0 !important;
  padding: 0.7rem 1rem !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  overflow: hidden !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-copy {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-title {
  font-size: clamp(2.25rem, 3.1vw, 3.15rem) !important;
  line-height: 0.96 !important;
  margin: 0 !important;
}

body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-tags {
  margin-top: 0.35rem !important;
  font-size: 0.82rem !important;
  line-height: 1.1 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

@media (max-width: 767px) {
  body.app-body-luxury .theme-hero.theme-hero-premium {
    min-height: 74px !important;
    max-height: none !important;
    padding: 0.6rem 0.75rem !important;
  }

  body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-title {
    font-size: 1.55rem !important;
  }

  body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-tags {
    font-size: 0.66rem !important;
    margin-top: 0.2rem !important;
  }
}

/* Блок темы в app-content: без обрезки, чтобы были видны и название, и теги */
body.app-body-luxury .app-content .theme-hero.theme-hero-premium {
  min-height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

/* =========================================================
   Sidebar usability polish: toggle top position and readable nav
   Не задавать position на .sidebar глобально — ломает drawer (fixed + left)
   на max-width: 1023px в styles.css.
   ========================================================= */

body.app-body-luxury .sidebar-top-controls {
  position: absolute !important;
  top: 0.85rem !important;
  right: 0.75rem !important;
  z-index: 20 !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
}

body.app-body-luxury .sidebar-toggle {
  width: 30px !important;
  height: 30px !important;
  min-width: 30px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  background: var(--color-surface) !important;
  color: var(--color-text-muted) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: 0 6px 16px rgba(31, 41, 51, 0.12) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.app-body-luxury .sidebar-toggle:hover {
  background: var(--color-surface-soft) !important;
  color: var(--color-heading) !important;
  border-color: var(--color-accent) !important;
}

html[data-theme="dark"] body.app-body-luxury .sidebar-toggle {
  background: var(--color-surface-soft) !important;
  color: var(--color-accent) !important;
  border-color: rgba(226, 183, 108, 0.35) !important;
}

body.app-body-luxury .sidebar-brand-row {
  padding-top: 2.8rem !important;
  padding-bottom: 1.15rem !important;
}

body.app-body-luxury .sidebar-brand-premium {
  align-items: center !important;
}

body.app-body-luxury .sidebar .nav-link {
  font-size: 1.02rem !important;
  line-height: 1.25 !important;
  font-weight: 650 !important;
  letter-spacing: 0.005em !important;
}

body.app-body-luxury .sidebar .nav-link .nav-icon {
  font-size: 1.05rem !important;
}

body.app-body-luxury .sidebar .nav-link span,
body.app-body-luxury .sidebar .nav-link .nav-label {
  font-size: 1.02rem !important;
}

@media (min-width: 1024px) {
  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar-top-controls,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar-top-controls {
    top: 0.75rem !important;
    right: 50% !important;
    transform: translateX(50%) !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar-toggle,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar-toggle {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    position: static !important;
    transform: none !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar-brand-row,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar-brand-row {
    padding-top: 3.6rem !important;
    padding-left: 0.35rem !important;
    padding-right: 0.35rem !important;
    justify-content: center !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar-brand-logo,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar-brand-logo {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    margin: 0 auto !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar-brand-title,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar-brand-title {
    display: none !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar .nav-link,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar .nav-link {
    justify-content: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar .nav-link .nav-icon,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar .nav-link .nav-icon {
    font-size: 1.12rem !important;
  }
}

/* =========================================================
   Auth / Login
   ========================================================= */

html:not([data-theme]),
html[data-theme=""] {
  color-scheme: light;
}

body.auth-body,
body.auth-body.app-body-luxury {
  min-height: 100vh;
  margin: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(200, 155, 90, 0.18), transparent 30%),
    radial-gradient(circle at 82% 20%, rgba(110, 38, 63, 0.10), transparent 28%),
    linear-gradient(135deg, var(--color-bg), var(--color-surface-soft)) !important;
  color: var(--color-text) !important;
}

html[data-theme="dark"] body.auth-body,
html[data-theme="dark"] body.auth-body.app-body-luxury {
  background:
    radial-gradient(circle at 18% 18%, rgba(200, 155, 90, 0.16), transparent 30%),
    radial-gradient(circle at 82% 20%, rgba(110, 38, 63, 0.24), transparent 28%),
    linear-gradient(135deg, #17131A, #241F29) !important;
}

body.auth-body .auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}

body.auth-body .auth-card {
  width: min(100%, 460px);
  padding: 2.25rem;
  border-radius: 28px;
  background: color-mix(in srgb, var(--color-surface) 88%, transparent);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  box-shadow:
    0 24px 60px rgba(31, 41, 51, 0.18),
    0 1px 0 rgba(255, 255, 255, 0.55) inset;
  backdrop-filter: blur(14px);
}

html[data-theme="dark"] body.auth-body .auth-card {
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.42),
    0 1px 0 rgba(255, 255, 255, 0.05) inset;
}

body.auth-body .auth-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.85rem;
  margin-bottom: 1.4rem;
}

body.auth-body .auth-brand-logo {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow:
    0 10px 26px rgba(91, 58, 41, 0.22),
    0 0 0 1px rgba(200, 155, 90, 0.45);
}

body.auth-body .auth-brand-title {
  color: var(--color-heading);
  font-family: var(--font-brand-serif, Georgia, serif);
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1;
}

body.auth-body .auth-brand-subtitle {
  color: var(--color-text-muted);
  font-size: 0.9rem;
  margin-top: 0.2rem;
}

body.auth-body .auth-title {
  text-align: center;
  color: var(--color-heading) !important;
  font-size: 1.75rem;
  font-weight: 800;
  margin-bottom: 0.35rem;
}

body.auth-body .auth-subtitle {
  text-align: center;
  color: var(--color-text-muted) !important;
  font-size: 1rem;
  margin-bottom: 1.75rem;
}

body.auth-body label,
body.auth-body .form-label {
  color: var(--color-heading) !important;
  font-weight: 700;
}

body.auth-body .form-control {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 14px !important;
  min-height: 48px;
}

body.auth-body .form-control:focus {
  border-color: var(--color-accent) !important;
  box-shadow: var(--focus-ring) !important;
}

body.auth-body .btn-primary,
body.auth-body .auth-submit,
body.auth-body .auth-button {
  width: 100%;
  min-height: 52px;
  border-radius: 999px !important;
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border-color: var(--color-primary) !important;
  font-weight: 800;
}

body.auth-body .btn-primary:hover,
body.auth-body .auth-submit:hover,
body.auth-body .auth-button:hover {
  background: var(--color-primary-hover) !important;
  color: var(--color-primary-text) !important;
}

body.auth-body .auth-link,
body.auth-body a {
  color: var(--color-primary) !important;
  font-weight: 700;
  text-decoration: none;
}

body.auth-body .auth-link:hover,
body.auth-body a:hover {
  color: var(--color-primary-hover) !important;
  text-decoration: underline;
}

html[data-theme="dark"] body.auth-body .auth-link,
html[data-theme="dark"] body.auth-body a {
  color: var(--color-accent) !important;
}

@media (max-width: 576px) {
  body.auth-body .auth-page {
    padding: 1rem;
  }

  body.auth-body .auth-card {
    padding: 1.5rem;
    border-radius: 22px;
  }

  body.auth-body .auth-title {
    font-size: 1.45rem;
  }
}

/* =========================================================
   Price Search buttons theme fix
   ========================================================= */

body.app-body-luxury .price-page .price-search-btn.price-search-btn--submit,
body.app-body-luxury .price-page .price-filters-btn.price-filters-btn--submit,
body.app-body-luxury .price-page .filters-actions .btn.btn-primary,
body.app-body-luxury .price-page .price-filter-actions .btn.btn-primary,
body.app-body-luxury .price-page .filter-actions .btn.btn-primary {
  background: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  border: 1px solid var(--color-primary) !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 18px rgba(31, 41, 51, 0.12) !important;
  text-shadow: none !important;
  font-weight: 700 !important;
  min-height: 44px;
}

body.app-body-luxury .price-page .price-search-btn.price-search-btn--submit:hover,
body.app-body-luxury .price-page .price-filters-btn.price-filters-btn--submit:hover,
body.app-body-luxury .price-page .filters-actions .btn.btn-primary:hover,
body.app-body-luxury .price-page .price-filter-actions .btn.btn-primary:hover,
body.app-body-luxury .price-page .filter-actions .btn.btn-primary:hover {
  background: var(--color-primary-hover) !important;
  color: var(--color-primary-text) !important;
  border-color: var(--color-primary-hover) !important;
}

body.app-body-luxury .price-page .price-search-btn.price-search-btn--reset,
body.app-body-luxury .price-page .price-filters-btn.price-filters-btn--reset,
body.app-body-luxury .price-page .btn-info,
body.app-body-luxury .price-page .btn-reset,
body.app-body-luxury .price-page .filter-reset-btn,
body.app-body-luxury .price-page .filters-actions .btn.btn-secondary,
body.app-body-luxury .price-page .price-filter-actions .btn.btn-secondary,
body.app-body-luxury .price-page .filter-actions .btn.btn-secondary {
  background: var(--color-surface-soft) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 14px !important;
  box-shadow: none !important;
  text-shadow: none !important;
  font-weight: 700 !important;
  min-height: 44px;
}

body.app-body-luxury .price-page .price-search-btn.price-search-btn--reset:hover,
body.app-body-luxury .price-page .price-filters-btn.price-filters-btn--reset:hover,
body.app-body-luxury .price-page .btn-info:hover,
body.app-body-luxury .price-page .btn-reset:hover,
body.app-body-luxury .price-page .filter-reset-btn:hover,
body.app-body-luxury .price-page .filters-actions .btn.btn-secondary:hover,
body.app-body-luxury .price-page .price-filter-actions .btn.btn-secondary:hover,
body.app-body-luxury .price-page .filter-actions .btn.btn-secondary:hover {
  background: var(--color-surface-muted) !important;
  color: var(--color-heading) !important;
  border-color: var(--color-accent) !important;
}

body.app-body-luxury .price-page .filters-actions .btn,
body.app-body-luxury .price-page .price-filter-actions .btn,
body.app-body-luxury .price-page .filter-actions .btn,
body.app-body-luxury .price-page .price-filters-btn {
  border-radius: 14px !important;
  min-height: 42px;
  text-shadow: none !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-search-btn.price-search-btn--reset,
html[data-theme="dark"] body.app-body-luxury .price-page .price-filters-btn.price-filters-btn--reset,
html[data-theme="dark"] body.app-body-luxury .price-page .btn-info,
html[data-theme="dark"] body.app-body-luxury .price-page .btn-reset,
html[data-theme="dark"] body.app-body-luxury .price-page .filter-reset-btn {
  background: var(--color-surface-soft) !important;
  color: var(--color-text) !important;
  border-color: var(--color-border) !important;
}

body.app-body-luxury .price-page .price-product-link,
body.app-body-luxury .price-page .price-product-link:visited {
  color: var(--color-text) !important;
  text-decoration: none !important;
}

body.app-body-luxury .price-page .price-product-link:hover {
  color: var(--color-primary) !important;
  text-decoration: underline !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .price-product-link:hover {
  color: var(--color-accent) !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn {
  width: 30px !important;
  height: 30px !important;
  min-width: 30px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--color-surface-soft) !important;
  color: var(--color-accent) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: none !important;
  opacity: 1 !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn i {
  color: var(--color-accent) !important;
  opacity: 1 !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn:hover {
  background: var(--color-accent-soft) !important;
  color: var(--color-primary) !important;
  border-color: var(--color-accent) !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn:hover i {
  color: var(--color-primary) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .add-to-favorites-btn {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--color-accent) !important;
  border-color: rgba(226, 183, 108, 0.35) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .add-to-favorites-btn:hover {
  background: rgba(226, 183, 108, 0.14) !important;
  border-color: var(--color-accent) !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn.active,
body.app-body-luxury .price-page .add-to-favorites-btn[aria-pressed="true"] {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
  box-shadow: 0 8px 18px rgba(91, 58, 41, 0.18) !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn.active i,
body.app-body-luxury .price-page .add-to-favorites-btn[aria-pressed="true"] i {
  color: var(--color-primary-text) !important;
}

body.app-body-luxury .price-page .add-to-favorites-btn.active:hover,
body.app-body-luxury .price-page .add-to-favorites-btn[aria-pressed="true"]:hover {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
}

html[data-theme="neutral"] body.app-body-luxury .price-page .add-to-favorites-btn.active,
html[data-theme="neutral"] body.app-body-luxury .price-page .add-to-favorites-btn[aria-pressed="true"] {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-primary-text) !important;
}

html[data-theme="dark"] body.app-body-luxury .price-page .add-to-favorites-btn.active,
html[data-theme="dark"] body.app-body-luxury .price-page .add-to-favorites-btn[aria-pressed="true"] {
  box-shadow: 0 8px 18px rgba(200, 155, 90, 0.18) !important;
}

/* PR4.1: final /price/search normalization after palette swap */
body.app-body-luxury .price-page .price-table-col-partner-price,
body.app-body-luxury .price-page .price-table-col-partner-price *,
body.app-body-luxury .price-page .price-table-col-zakupka,
body.app-body-luxury .price-page .price-table-col-zakupka *,
body.app-body-luxury .price-page .price-mobile-price-value,
body.app-body-luxury .price-page .price-mobile-price-value * {
  font-weight: 600 !important;
}

/* Price table: article / partner price / purchase columns should not be bold */
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-article,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-partner-price,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-partner-price *,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-zakupka,
body.app-body-luxury .price-page #products-table-container .price-table-custom td.price-table-col-zakupka * {
  font-weight: 400 !important;
}

/* ---------- NEUTRAL: Сапфировое золото — layout (after Theme Hero final / sidebar polish) ---------- */

html[data-theme="neutral"] body.app-body-luxury {
  background:
    radial-gradient(circle at 10% 8%, rgba(60, 80, 112, 0.16), transparent 30%),
    radial-gradient(circle at 88% 18%, rgba(224, 198, 143, 0.18), transparent 28%),
    radial-gradient(circle at 55% 92%, rgba(17, 34, 80, 0.10), transparent 34%),
    linear-gradient(135deg, #EDE7DD 0%, #F2EBE2 48%, #E4D8CD 100%) !important;
  color: var(--color-text) !important;
}

html[data-theme="neutral"] body.app-body-luxury .app-content {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(237, 231, 221, 0.06)) !important;
}

html[data-theme="neutral"] body.app-body-luxury .card,
html[data-theme="neutral"] body.app-body-luxury .stat-card,
html[data-theme="neutral"] body.app-body-luxury .glass-panel {
  background: rgba(255, 253, 252, 0.94) !important;
  border-color: rgba(201, 186, 176, 0.96) !important;
  box-shadow:
    0 14px 34px rgba(17, 34, 80, 0.10),
    0 10px 26px rgba(91, 58, 41, 0.06),
    0 1px 0 rgba(255, 255, 255, 0.72) inset !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar {
  background: linear-gradient(180deg, #112250 0%, #0B1738 100%) !important;
  border-right: 1px solid rgba(224, 198, 143, 0.24) !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar .nav-link {
  color: rgba(245, 240, 233, 0.82) !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar .nav-link:hover {
  background: rgba(224, 198, 143, 0.10) !important;
  color: #F5F0E9 !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar .nav-link.active {
  background: #3C5070 !important;
  color: #FFFFFF !important;
  box-shadow: 0 8px 20px rgba(17, 34, 80, 0.35) !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar .nav-link.active .nav-icon {
  color: #FFFFFF !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar .nav-icon {
  color: #E0C68F !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar-brand-line1,
html[data-theme="neutral"] body.app-body-luxury .sidebar-brand-line2,
html[data-theme="neutral"] body.app-body-luxury .sidebar-brand-title {
  color: #F5F0E9 !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar-toggle {
  background: rgba(245, 240, 233, 0.10) !important;
  color: #E0C68F !important;
  border-color: rgba(224, 198, 143, 0.38) !important;
}

html[data-theme="neutral"] body.app-body-luxury .sidebar-toggle:hover {
  background: rgba(224, 198, 143, 0.16) !important;
  color: #F5F0E9 !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero.theme-hero-premium {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-title {
  color: #0F1B33 !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-tags {
  background: #E4D8CD !important;
  color: #3C5070 !important;
  border: 1px solid #C9BAB0 !important;
  box-shadow: none !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero-title {
  color: #0F1B33 !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero-tags {
  background: #E4D8CD !important;
  color: #3C5070 !important;
  border: 1px solid #C9BAB0 !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero-premium .theme-hero-title {
  color: #0F1B33 !important;
}

html[data-theme="neutral"] body.app-body-luxury .theme-hero-premium .theme-hero-tags {
  background: #E4D8CD !important;
  color: #3C5070 !important;
  border: 1px solid #C9BAB0 !important;
}

/* ---------- LIGHT: Пудровый винный люкс — layout (after Theme Hero final) ---------- */

html[data-theme="light"] body.app-body-luxury {
  background:
    radial-gradient(circle at 12% 10%, rgba(196, 166, 155, 0.22), transparent 32%),
    radial-gradient(circle at 88% 18%, rgba(138, 61, 90, 0.08), transparent 30%),
    radial-gradient(circle at 56% 92%, rgba(186, 184, 162, 0.10), transparent 34%),
    linear-gradient(135deg, #F8F1F4 0%, #FFFDFE 48%, #F1E4EA 100%) !important;
  color: var(--color-text) !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero.theme-hero-premium {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-title {
  color: #331B25 !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero.theme-hero-premium .theme-hero-tags {
  background: #EFE2DC !important;
  color: #8A3D5A !important;
  border: 1px solid #E9D8E0 !important;
  box-shadow: none !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero-title {
  color: #331B25 !important;
}

html[data-theme="light"] body.app-body-luxury .theme-hero-tags {
  background: #EFE2DC !important;
  color: #8A3D5A !important;
  border: 1px solid #E9D8E0 !important;
}

/* =========================================================
   App layout: fixed sidebar, scrollable content (desktop)
   Ширины: в проекте заданы 280px / 72px; переменные — опциональный хук.
   Прокрутка меню: .sidebar-nav-scroll (см. partials/sidebar.html).
   ========================================================= */

@media (min-width: 1024px) {
  html,
  body {
    min-height: 100%;
  }

  body.app-body-luxury {
    height: 100vh !important;
    overflow: hidden !important;
  }

  body.app-body-luxury .app-shell {
    height: 100vh !important;
    min-height: 100vh !important;
    display: flex !important;
    align-items: stretch !important;
    overflow: hidden !important;
  }

  body.app-body-luxury .sidebar {
    position: sticky !important;
    top: 0 !important;
    height: 100vh !important;
    min-height: 100vh !important;
    flex: 0 0 var(--crm-sidebar-width, var(--sidebar-width, 280px)) !important;
    overflow: hidden !important;
    align-self: stretch !important;
    z-index: 30 !important;
  }

  body.app-body-luxury .sidebar-inner {
    height: 100vh !important;
    min-height: 100vh !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }

  body.app-body-luxury .sidebar-header-row,
  body.app-body-luxury .sidebar-brand-row {
    flex: 0 0 auto !important;
  }

  body.app-body-luxury .sidebar-nav-scroll {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    min-height: 0 !important;
  }

  body.app-body-luxury .sidebar-nav-main,
  body.app-body-luxury .sidebar-nav-primary {
    flex: 0 0 auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  body.app-body-luxury .sidebar-footer,
  body.app-body-luxury .sidebar-footer-sticky {
    flex: 0 0 auto !important;
  }

  body.app-body-luxury .app-main {
    flex: 1 1 auto !important;
    align-self: stretch !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  body.app-body-luxury .app-content {
    min-height: 100vh !important;
  }

  body.app-body-luxury .app-shell.sidebar-collapsed .sidebar,
  body.app-body-luxury #appShell.sidebar-collapsed .sidebar {
    flex: 0 0 var(--crm-sidebar-collapsed-width, var(--sidebar-collapsed-width, 72px)) !important;
    flex-basis: var(--crm-sidebar-collapsed-width, var(--sidebar-collapsed-width, 72px)) !important;
    width: var(--crm-sidebar-collapsed-width, var(--sidebar-collapsed-width, 72px)) !important;
  }
}

/* Форма заказа: компактный промокод (не на всю ширину карточки товаров) */
.order-form-promo-compact {
  max-width: min(40rem, 100%);
}

@media (min-width: 768px) {
  .order-form-promo-compact .order-form-promo-row {
    flex-wrap: nowrap !important;
    align-items: flex-end !important;
  }

  .order-form-promo-compact .order-form-promo-field {
    flex: 1 1 auto;
    min-width: 0;
    max-width: 22rem;
  }

  .order-form-promo-compact .order-form-promo-submit .btn {
    white-space: nowrap;
  }
}

body.app-body-luxury .order-form-promo-compact #order-promo-applied-banner.alert-success {
  background: var(--color-success-bg, rgba(34, 197, 94, 0.12)) !important;
  color: var(--color-success, #15803d) !important;
  border-color: var(--color-success, rgba(34, 197, 94, 0.45)) !important;
}

html[data-theme="dark"] body.app-body-luxury .order-form-promo-compact #order-promo-applied-banner.alert-success {
  color: var(--color-text, #e2e8f0) !important;
  border-color: var(--color-border, rgba(226, 232, 240, 0.25)) !important;
}
