:root {
  --blue-dark: #0a1628;
  --blue-main: #1a3a6b;
  --blue-medium: #1e4d9b;
  --blue-light: #2d6fd4;
  --blue-sky: #4a90d9;
  --blue-pale: #e8f1fb;
  --white: #ffffff;
  --gray-text: #4a5568;
  --gray-light: #f7f9fc;
  --orange-cta: #e8660a;
  --orange-hover: #c9530a;
  --green-badge: #27ae60;
  --red-sale: #e53e3e;
  --gray-border: #d8e2f0;
  --shadow: 0 8px 24px rgba(10, 22, 40, 0.10);
  --shadow-soft: 0 4px 16px rgba(10, 22, 40, 0.06);
  --header-height: 156px;
}

/* Базові налаштування сторінки */
* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: "Roboto", sans-serif;
  color: var(--gray-text);
  background:
    radial-gradient(circle at top right, rgba(74, 144, 217, 0.16), transparent 24%),
    linear-gradient(180deg, #f9fbff 0%, var(--gray-light) 45%, #eef4fb 100%);
}

body.no-scroll {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

button {
  cursor: pointer;
  border: none;
}

img {
  max-width: 100%;
}

.container {
  width: min(1200px, calc(100% - 32px));
  margin: 0 auto;
}

.section {
  padding: 84px 0;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  margin-bottom: 32px;
}

.section-head h2,
.hero h1 {
  margin: 8px 0 0;
  font-family: "Roboto Condensed", sans-serif;
  color: var(--blue-dark);
  letter-spacing: 0.02em;
}

.section-head h2 {
  font-size: clamp(2rem, 3vw, 2.8rem);
}

.section-head p {
  max-width: 500px;
  margin: 0;
  line-height: 1.6;
}

.section-label {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(45, 111, 212, 0.12);
  color: var(--blue-medium);
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.inverse-head h2,
.inverse-head p {
  color: var(--white);
}

.main-button,
.secondary-button,
.sort-button,
.filter-toggle {
  transition: 0.3s;
}

.main-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 14px;
  background: var(--orange-cta);
  color: var(--white);
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(232, 102, 10, 0.28);
}

.main-button:hover {
  background: var(--orange-hover);
  transform: translateY(-2px);
}

.main-button:active {
  transform: scale(0.97);
}

.secondary-button,
.filter-toggle {
  min-height: 46px;
  padding: 0 18px;
  border-radius: 12px;
  background: var(--blue-pale);
  color: var(--blue-main);
  font-weight: 700;
}

.secondary-button:hover,
.filter-toggle:hover {
  background: #dbe9fb;
}

.link-button {
  padding: 0;
  background: transparent;
  color: var(--blue-light);
  font-weight: 700;
}

/* Шапка сайту */
.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: var(--blue-dark);
  box-shadow: 0 4px 12px rgba(10, 22, 40, 0.18);
}

.header-top {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.header-main {
  display: grid;
  grid-template-columns: 235px minmax(280px, 1fr) auto;
  align-items: center;
  gap: 24px;
  min-height: 92px;
}

.logo-block {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--white);
}

.logo-image {
  display: block;
  width: min(58px, 100%);
  height: auto;
  flex: 0 0 auto;
}

.logo-copy {
  display: grid;
  gap: 3px;
}

.logo-title {
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--white);
}

.logo-subtitle {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.14em;
}

.search-block {
  position: relative;
}

.search-box {
  display: flex;
  align-items: center;
  overflow: hidden;
  border-radius: 15px;
  background: var(--white);
  box-shadow: inset 0 0 0 1px rgba(30, 77, 155, 0.12);
}

.search-box input {
  flex: 1;
  min-width: 0;
  padding: 13px 15px;
  border: none;
  outline: none;
}

.search-box button {
  width: 48px;
  height: 48px;
  background: var(--blue-medium);
  color: var(--white);
  font-size: 1rem;
}

.search-box button:hover {
  background: var(--blue-light);
}

.search-suggestions {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  display: none;
  background: var(--white);
  border-radius: 18px;
  box-shadow: var(--shadow);
  overflow: hidden;
}

.search-suggestions.active {
  display: block;
}

.search-item {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--gray-border);
  transition: 0.3s;
}

.search-item:last-child {
  border-bottom: none;
}

.search-item:hover {
  background: var(--blue-pale);
}

.search-item strong {
  color: var(--blue-dark);
}

.search-item span {
  color: var(--blue-light);
  font-weight: 700;
}

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: nowrap;
}

.header-actions-inner {
  display: flex;
  align-items: center;
  gap: 10px;
}

.language-switcher {
  display: inline-flex;
  align-items: center;
  padding: 4px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1.5px solid rgba(255, 255, 255, 0.22);
}

.language-button {
  min-width: 42px;
  height: 36px;
  padding: 0 12px;
  border-radius: 8px;
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  font-weight: 700;
  transition: 0.25s;
}

.language-button.active,
.language-button:hover {
  background: var(--white);
  color: var(--blue-dark);
}

.phone-group {
  position: relative;
}

.phone-main {
  cursor: pointer;
  background: none;
  border: none;
  color: inherit;
  font: inherit;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.phone-arrow {
  font-size: 0.7rem;
  opacity: 0.6;
  transition: 0.3s;
}

.phone-group.open .phone-arrow {
  opacity: 1;
  transform: rotate(180deg);
}

.phone-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 100%;
  display: none;
  flex-direction: column;
  gap: 4px;
  padding: 8px;
  padding-top: 14px;
  border-radius: 14px;
  background: var(--blue-dark);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.1);
  z-index: 50;
}

.phone-dropdown::before {
  content: "";
  position: absolute;
  top: -6px;
  left: 0;
  right: 0;
  height: 6px;
}

.phone-group.open .phone-dropdown {
  display: flex;
}

.phone-dropdown-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  height: 44px;
  border-radius: 10px;
  color: var(--white);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-weight: 600;
  font-size: 0.84rem;
  white-space: nowrap;
  text-decoration: none;
  transition: 0.3s;
}

.phone-dropdown-item:hover {
  background: rgba(255, 255, 255, 0.14);
}

.messenger-viber:hover { background: rgba(124, 82, 199, 0.25); }
.messenger-telegram:hover { background: rgba(36, 161, 222, 0.25); }
.messenger-whatsapp:hover { background: rgba(37, 211, 102, 0.25); }
.messenger-icon { font-size: 1.1rem; }

.phone-item,
.account-button,
.cart-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 14px;
  height: 46px;
  border-radius: 12px;
  color: var(--white);
  background: rgba(255, 255, 255, 0.06);
  border: 1.5px solid rgba(255, 255, 255, 0.22);
  transition: all 0.25s ease;
}

.phone-item:hover,
.account-button:hover,
.cart-button:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.38);
}

.phone-item {
  padding: 0 12px;
  font-weight: 600;
  font-size: 0.84rem;
  white-space: nowrap;
  text-decoration: none;
}

.account-button {
  font-weight: 700;
}

.account-button.active {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.35);
}

.account-button-icon {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  color: var(--white);
}

.account-button-icon svg {
  width: 18px;
  height: 18px;
}

.phone-icon {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  font-size: 0.8rem;
}



.cart-button {
  position: relative;
}

.cart-count {
  display: grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--orange-cta);
  font-size: 0.8rem;
  font-weight: 700;
}

.header-nav {
  background: linear-gradient(90deg, var(--blue-main), var(--blue-medium));
}

.category-nav {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 6px;
  padding: 9px 0 12px;
}

.nav-link {
  flex: 0 1 auto;
  padding: 7px 10px;
  border-radius: 999px;
  color: var(--white);
  background: rgba(255, 255, 255, 0.1);
  font-size: 0.79rem;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: 0.01em;
  transition: 0.3s;
}

.nav-link:hover {
  background: rgba(255, 255, 255, 0.2);
}

/* Головний екран */
.hero {
  position: relative;
  overflow: hidden;
  padding: calc(var(--header-height) + 36px) 0 88px;
  background: linear-gradient(135deg, #102542, #1f4478);
  color: var(--white);
}

.hero::before,
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
}

.hero::before {
  z-index: 0;
  inset: -24px;
  background:
    linear-gradient(135deg, rgba(10, 22, 40, 0.42), rgba(26, 58, 107, 0.18)),
    url("fon.jpg") 66% 38% / cover no-repeat;
  filter: blur(10px);
  transform: scale(1.08);
}

.hero::after {
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(8, 20, 38, 0.88) 0%, rgba(15, 37, 68, 0.72) 36%, rgba(28, 67, 121, 0.58) 100%),
    radial-gradient(circle at top right, rgba(93, 145, 220, 0.18), transparent 22%),
    radial-gradient(circle at bottom left, rgba(232, 102, 10, 0.14), transparent 18%);
}

.hero-content {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 380px);
  gap: 32px;
  align-items: center;
}

.hero-text h1 {
  font-size: clamp(2.5rem, 5vw, 4.4rem);
  line-height: 1.02;
  color: var(--white);
}

.hero-text p {
  max-width: 620px;
  margin: 20px 0 28px;
  font-size: 1.1rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.78);
}

.hero-badge {
  display: inline-flex;
  padding: 10px 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  font-size: 0.92rem;
}

.hero-benefits {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 28px;
}

.hero-benefit {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
}

.hero-benefit-icon,
.info-icon,
.reason-icon,
.category-card-icon,
.product-image-icon,
.cart-item-preview {
  color: currentColor;
}

.hero-benefit-icon,
.info-icon,
.reason-icon {
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.hero-benefit-icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.14);
}

.hero-benefit-icon svg,
.info-icon svg,
.reason-icon svg,
.category-card-icon svg,
.product-image-icon svg,
.cart-item-preview svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hero-panel {
  padding: 26px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
}

.hero-panel-card {
  padding: 24px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(74, 144, 217, 0.3), rgba(10, 22, 40, 0.28));
}

.panel-title {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.8);
}

.panel-number {
  margin: 14px 0 6px;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 3rem;
  font-weight: 700;
}

.panel-text {
  color: rgba(255, 255, 255, 0.74);
}

.hero-panel-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 14px;
}

.mini-card {
  padding: 18px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.08);
}

.mini-card span {
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
  color: var(--white);
}

.mini-card small {
  color: rgba(255, 255, 255, 0.72);
}

/* Смуга довіри */
.trust-strip {
  position: relative;
  z-index: 2;
  padding: 24px 0 32px;
}

.trust-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}

.trust-card {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 88px;
  padding: 18px;
  border-radius: 22px;
  background: var(--blue-pale);
  color: var(--blue-dark);
  box-shadow: var(--shadow-soft);
  text-align: center;
}

.info-icon {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(26, 58, 107, 0.1), rgba(45, 111, 212, 0.22));
  color: var(--blue-main);
}

/* Картки категорій */
.categories-section {
  padding-top: 44px;
}

.popular-categories {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.category-card {
  display: flex;
  flex-direction: column;
  padding: 24px;
  border: 1px solid rgba(30, 77, 155, 0.1);
  border-radius: 24px;
  background: linear-gradient(180deg, var(--white), #f0f6ff);
  box-shadow: var(--shadow-soft);
  transition: 0.3s;
  overflow: hidden;
}

.category-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow);
}

.category-card-media {
  position: relative;
  height: 178px;
  margin: -24px -24px 18px;
  overflow: hidden;
  background: linear-gradient(180deg, #eef5ff, #dbe8f9);
}

.category-card-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(11, 33, 66, 0.04), rgba(11, 33, 66, 0.28));
}

.category-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.12);
  transition: transform 0.35s ease;
}

.category-card:hover .category-card-media img {
  transform: scale(1.18);
}

.category-card-icon {
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(26, 58, 107, 0.08), rgba(45, 111, 212, 0.2));
  color: var(--blue-main);
}

.category-card h3 {
  margin: 18px 0 10px;
  font-size: 1.2rem;
  color: var(--blue-dark);
  line-height: 1.3;
}

.category-card p {
  margin: auto 0 0;
  padding-top: 18px;
  color: var(--gray-text);
  line-height: 1.5;
}

.category-card-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.category-card-list span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(26, 58, 107, 0.08);
  color: var(--blue-main);
  font-size: 0.82rem;
  font-weight: 500;
}

/* Блок каталогу */
.catalog-section {
  padding-top: 30px;
}

.catalog-head {
  align-items: center;
}

.catalog-layout {
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.filters-panel {
  position: sticky;
  top: calc(var(--header-height) + 24px);
  padding: 24px;
  border-radius: 24px;
  background: var(--white);
  box-shadow: var(--shadow-soft);
}

.filters-header,
.filters-header-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.filters-header {
  margin-bottom: 18px;
}

.filters-header h3 {
  margin: 0;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.6rem;
  color: var(--blue-dark);
}

.close-filters {
  display: none;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--blue-pale);
  color: var(--blue-dark);
}

.filter-group {
  padding-top: 18px;
  border-top: 1px solid var(--gray-border);
  margin-top: 18px;
}

.filter-group:first-of-type {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.filter-title {
  display: flex;
  width: 100%;
  padding: 0;
  margin-bottom: 14px;
  background: transparent;
  color: var(--blue-dark);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.filter-list,
.radio-list {
  display: grid;
  gap: 10px;
}

.filter-list label,
.radio-list label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--gray-text);
}

.filter-list input,
.radio-list input {
  margin-right: 8px;
}

.filter-name {
  display: inline-flex;
  align-items: center;
}

.filter-count {
  color: #70829b;
}

/* Brand dropdown filter */
.brand-dropdown {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.brand-search {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: 0.88rem;
  background: var(--white);
  color: var(--blue-dark);
  outline: none;
  transition: border-color 0.2s;
}

.brand-search:focus {
  border-color: var(--blue-main);
}

.brand-dropdown-list {
  max-height: 220px;
  overflow-y: auto;
  display: grid;
  gap: 4px;
}

.brand-dropdown-list label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 8px;
  border-radius: 8px;
  color: var(--gray-text);
  cursor: pointer;
  transition: background 0.15s;
}

.brand-dropdown-list label:hover {
  background: var(--blue-pale);
}

.brand-dropdown-list label.hidden {
  display: none;
}

.brand-dropdown-list .filter-name {
  display: inline-flex;
  align-items: center;
}

.brand-dropdown-list input {
  margin-right: 8px;
}

.brand-selected-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}

.brand-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 8px;
  background: var(--blue-pale);
  color: var(--blue-main);
  font-size: 0.78rem;
  font-weight: 600;
}

.brand-tag-remove {
  cursor: pointer;
  font-size: 0.9rem;
  line-height: 1;
  opacity: 0.7;
}

.brand-tag-remove:hover {
  opacity: 1;
}

.price-filter {
  display: grid;
  gap: 18px;
}

.range-track {
  position: relative;
  height: 40px;
}

.range-track::before {
  content: "";
  position: absolute;
  top: 17px;
  left: 0;
  right: 0;
  height: 6px;
  border-radius: 999px;
  background: #d7e4f8;
}

.range-line {
  position: absolute;
  top: 17px;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue-light), var(--orange-cta));
}

.range-track input[type="range"] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 40px;
  margin: 0;
  pointer-events: none;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
}

.range-track input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border: 3px solid var(--white);
  border-radius: 50%;
  background: var(--blue-medium);
  box-shadow: 0 4px 10px rgba(10, 22, 40, 0.22);
  pointer-events: auto;
}

.range-track input[type="range"]::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border: 3px solid var(--white);
  border-radius: 50%;
  background: var(--blue-medium);
  box-shadow: 0 4px 10px rgba(10, 22, 40, 0.22);
  pointer-events: auto;
}

.price-inputs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.price-inputs label {
  display: grid;
  gap: 8px;
}

.price-inputs span {
  color: var(--blue-dark);
  font-weight: 700;
}

.price-inputs input,
.promo-code-box input,
.quick-order-form input {
  width: 100%;
  height: 48px;
  padding: 0 14px;
  border: 1px solid var(--gray-border);
  border-radius: 12px;
  outline: none;
  transition: 0.3s;
}

.price-inputs input:focus,
.promo-code-box input:focus,
.quick-order-form input:focus {
  border-color: var(--blue-light);
  box-shadow: 0 0 0 3px rgba(45, 111, 212, 0.12);
}

.catalog-content {
  min-width: 0;
}

/* Breadcrumbs */
.breadcrumbs {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #64748b;
  margin-bottom: 12px;
  padding: 0 4px;
}

.breadcrumbs a {
  color: var(--accent);
  text-decoration: none;
}

.breadcrumbs a:hover {
  text-decoration: underline;
}

.breadcrumb-separator {
  color: #cbd5e1;
}

.catalog-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 20px 22px;
  margin-bottom: 18px;
  border-radius: 20px;
  background: var(--white);
  box-shadow: var(--shadow-soft);
}

.sort-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sort-button {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--blue-pale);
  color: var(--blue-main);
  font-weight: 700;
}

.sort-button.active,
.sort-button:hover {
  background: var(--blue-main);
  color: var(--white);
}

.found-counter {
  color: var(--blue-dark);
  font-weight: 700;
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.product-card {
  display: flex;
  flex-direction: column;
  border-radius: 24px;
  background: var(--white);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  transition: transform 0.3s, box-shadow 0.3s;
  contain: layout style;
}

.product-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow);
}

.product-image {
  position: relative;
  height: 260px;
  padding: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(180deg, #f8fbff, #eef4fb);
  color: var(--blue-dark);
}

.wishlist-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 5;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.85);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.2s, color 0.2s;
  color: #94a3b8;
}

.wishlist-btn:hover {
  transform: scale(1.15);
  color: #e11d48;
}

.wishlist-btn.active {
  color: #e11d48;
}

.product-image img {
  position: relative;
  z-index: 2;
  background: #fff;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 8px;
  transition: transform 0.35s ease;
}

.product-card:hover .product-image img {
  transform: scale(1.05);
}

.product-image::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 2px dashed #c9d9ee;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
}

.product-image-icon {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: rgba(26, 58, 107, 0.08);
  color: var(--blue-main);
}

.product-image-caption {
  position: relative;
  z-index: 2;
  text-align: center;
}

.product-image-caption p {
  max-width: 240px;
  margin: 16px 0 0;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.1rem;
  color: var(--blue-dark);
}

.product-image-label {
  margin-top: 10px;
  color: #7b8aa2;
  font-size: 0.9rem;
}

.product-badges {
  position: absolute;
  inset: 18px 18px auto 18px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  z-index: 2;
}

.badge-group {
  display: flex;
  gap: 8px;
}

.badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.badge-sale {
  background: var(--red-sale);
  color: var(--white);
}

.badge-hit {
  background: rgba(232, 102, 10, 0.14);
  color: var(--orange-cta);
}

.badge-stock {
  background: rgba(39, 174, 96, 0.14);
  color: var(--green-badge);
}

.badge-order {
  background: rgba(74, 144, 217, 0.14);
  color: var(--blue-light);
}

.badge-out {
  background: rgba(74, 85, 104, 0.14);
  color: var(--gray-text);
}

.product-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 22px 22px 24px;
}

.product-title {
  min-height: 54px;
  margin: 0 0 14px;
  color: var(--blue-dark);
  font-size: 1.12rem;
  line-height: 1.35;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color 0.2s;
}

.product-title:hover {
  color: var(--blue-light);
}

.product-brand,
.product-unit,
.product-description {
  margin: 0 0 12px;
}

.product-subcategory {
  color: var(--blue-medium);
  font-weight: 700;
}

.product-brand,
.product-unit {
  color: #7b8aa2;
}

.product-rating {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  color: var(--blue-dark);
}

.product-rating span:last-child {
  color: #73839b;
}

.product-description {
  flex: 1;
  line-height: 1.6;
  margin-bottom: 16px;
}

/* Product Specifications Dropdown */
.product-specs-wrapper {
  margin-bottom: 14px;
  border: 1px solid var(--gray-border);
  border-radius: 10px;
  overflow: hidden;
}

.product-specs-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 10px 14px;
  background: var(--gray-light);
  color: var(--blue-main);
  font-weight: 600;
  font-size: 0.88rem;
  border: none;
  cursor: pointer;
  transition: background 0.2s;
}

.product-specs-toggle:hover {
  background: var(--blue-pale);
}

.specs-arrow {
  transition: transform 0.25s;
  font-size: 0.8rem;
}

.product-specs-wrapper.open .specs-arrow {
  transform: rotate(180deg);
}

.product-specs-list {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.product-specs-wrapper.open .product-specs-list {
  max-height: 600px;
}

.specs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.specs-table tr:nth-child(even) {
  background: var(--gray-light);
}

.specs-table td {
  padding: 8px 14px;
  vertical-align: top;
}

.spec-label {
  color: #7b8aa2;
  width: 45%;
  white-space: nowrap;
}

.spec-value {
  color: var(--blue-dark);
  font-weight: 500;
}

.product-prices {
  display: flex;
  align-items: end;
  gap: 10px;
  margin-bottom: 10px;
}

.current-price {
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--blue-dark);
}

.old-price {
  color: #8f9bb0;
  text-decoration: line-through;
}

.add-to-cart {
  width: 100%;
  margin-top: 0;
}

.product-buy-row {
  display: grid;
  grid-template-columns: 118px 1fr;
  gap: 10px;
  margin-top: 14px;
}

.product-quantity {
  display: grid;
  grid-template-columns: 34px 1fr 34px;
  align-items: center;
  height: 52px;
  border: 1px solid var(--gray-border);
  border-radius: 14px;
  overflow: hidden;
}

.product-quantity button {
  height: 100%;
  background: var(--blue-pale);
  color: var(--blue-dark);
  font-size: 1.1rem;
  font-weight: 700;
}

.product-quantity input {
  width: 100%;
  height: 100%;
  padding: 0;
  border: none;
  text-align: center;
  color: var(--blue-dark);
  font-weight: 700;
  background: transparent;
}

.add-to-cart.in-cart {
  background: var(--green-badge);
  box-shadow: none;
}

.add-to-cart.disabled {
  background: #c3cdd9;
  box-shadow: none;
  cursor: not-allowed;
}

/* --- Відгуки (Reviews) --- */
.product-actions-row {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}

.reviews-toggle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  min-width: 0;
  padding: 5px 0;
  background: none;
  border: 1px dashed var(--gray-border);
  border-radius: 6px;
  color: var(--accent);
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}

.reviews-toggle-btn:hover {
  background: var(--blue-pale);
}

.reviews-section {
  display: none;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--gray-border);
}

.reviews-section.open {
  display: flex;
}

.reviews-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.reviews-empty {
  color: #8a95a3;
  font-size: 13px;
  text-align: center;
  padding: 8px 0;
}

.review-item {
  padding: 10px 12px;
  background: var(--blue-pale);
  border-radius: 10px;
}

.review-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 13px;
}

.review-header strong {
  color: var(--blue-dark);
}

.review-stars {
  color: #f59e0b;
}

.review-date {
  color: #8a95a3;
  margin-left: auto;
  font-size: 12px;
}

.review-text {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.5;
  color: #475569;
}

.reviews-more-btn {
  padding: 6px 14px;
  background: var(--blue-pale);
  border: 1px solid var(--gray-border);
  border-radius: 8px;
  color: var(--accent);
  font-size: 13px;
  cursor: pointer;
  align-self: center;
}

.reviews-more-btn:hover {
  background: #dbeafe;
}

.review-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  background: #f8fafc;
  border-radius: 12px;
  border: 1px solid var(--gray-border);
}

.review-form-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--blue-dark);
}

.review-form .guest-input {
  background: #fff;
  color: var(--blue-dark);
  border-color: var(--gray-border);
}

.review-form .guest-input::placeholder {
  color: #94a3b8;
}

.review-form .guest-input:focus {
  border-color: var(--accent);
}

.review-rating-select {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #475569;
  flex-wrap: wrap;
}

.review-star-label {
  cursor: pointer;
}

.review-star-label input {
  display: none;
}

.review-star-label span {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid var(--gray-border);
  font-size: 13px;
  transition: background 0.15s;
}

.review-star-label input:checked + span {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.review-star-label:hover span {
  background: var(--blue-pale);
}

.review-submit-btn {
  align-self: flex-start;
  padding: 8px 20px;
  font-size: 13px;
}

.empty-box {
  grid-column: 1 / -1;
  padding: 48px 24px;
  border-radius: 24px;
  background: var(--white);
  box-shadow: var(--shadow-soft);
  text-align: center;
}

.load-more-wrap {
  display: flex;
  justify-content: center;
  margin-top: 26px;
}

.load-more-button.hidden {
  display: none;
}

/* Блок переваг */
.reasons-section {
  background: linear-gradient(135deg, var(--blue-main), var(--blue-dark));
}

.reasons-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.reason-card {
  padding: 28px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.82);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.reason-icon {
  width: 60px;
  height: 60px;
  margin-bottom: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.14);
  color: var(--white);
}

.reason-card h3 {
  margin: 0 0 12px;
  font-size: 1.2rem;
  color: var(--white);
}

.reason-card p {
  margin: 0;
  line-height: 1.7;
}

/* Блок акцій */
.promo-banner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding: 34px;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(232, 102, 10, 0.95), rgba(201, 83, 10, 0.94)),
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
  background-size: auto, 34px 34px;
  color: var(--white);
  box-shadow: 0 18px 38px rgba(232, 102, 10, 0.22);
}

.promo-banner h2 {
  margin: 8px 0 12px;
  color: var(--white);
  font-size: clamp(2rem, 4vw, 2.8rem);
}

.promo-banner p {
  margin: 0;
  max-width: 620px;
  line-height: 1.7;
}

.promo-link {
  flex: 0 0 auto;
  background: var(--white);
  color: var(--orange-cta);
  box-shadow: none;
}

.promo-link:hover {
  background: #fff2e8;
}

.promo-products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 24px;
}

.promo-card {
  padding: 20px;
  border-radius: 22px;
  background: var(--white);
  box-shadow: var(--shadow-soft);
}

.promo-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.promo-card-title {
  margin: 0 0 12px;
  color: var(--blue-dark);
  font-size: 1.06rem;
  line-height: 1.45;
}

.promo-card .current-price {
  font-size: 1.5rem;
}

/* ============ Блоки сайту (акції / спецпропозиції) ============ */
.site-blocks-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 20px;
  margin-bottom: 36px;
}

.site-block {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 28px 32px;
  border-radius: 24px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 12px 32px rgba(0,0,0,0.12);
  transition: transform 0.25s, box-shadow 0.25s;
}

.site-block:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 42px rgba(0,0,0,0.18);
}

.site-block-image {
  flex: 0 0 140px;
  height: 140px;
  border-radius: 18px;
  overflow: hidden;
}

.site-block-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.site-block-content {
  flex: 1;
  min-width: 0;
}

.site-block-title {
  margin: 0 0 8px;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.3;
}

.site-block-subtitle {
  margin: 0 0 6px;
  font-size: 1.05rem;
  opacity: 0.88;
  line-height: 1.5;
}

.site-block-text {
  margin: 0 0 14px;
  font-size: 0.95rem;
  opacity: 0.78;
  line-height: 1.6;
}

.site-block-btn {
  display: inline-block;
  padding: 10px 22px;
  border-radius: 12px;
  background: rgba(255,255,255,0.22);
  color: inherit;
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  transition: background 0.2s;
}

.site-block-btn:hover {
  background: rgba(255,255,255,0.38);
}

/* Countdown timer */
.site-block-timer {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 14px;
}

.sb-timer-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 48px;
  padding: 8px 10px 6px;
  border-radius: 10px;
  background: rgba(0,0,0,0.18);
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}

.sb-timer-block small {
  font-size: 0.65rem;
  font-weight: 500;
  text-transform: uppercase;
  opacity: 0.7;
  margin-top: 3px;
}

.sb-timer-sep {
  font-size: 1.3rem;
  font-weight: 700;
  opacity: 0.5;
}

/* Block type variants */
.site-block-countdown {
  background: linear-gradient(135deg, #c62828, #e53935) !important;
}

.site-block-banner {
  min-height: 160px;
}

.site-block-info {
  border: 2px solid rgba(255,255,255,0.15);
}

/* Форма швидкого замовлення */
.quick-order-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 430px;
  gap: 28px;
  align-items: center;
  padding: 34px;
  border-radius: 30px;
  background: linear-gradient(135deg, var(--white), #edf4fe);
  box-shadow: var(--shadow-soft);
}

.quick-order-text h2 {
  margin: 10px 0 14px;
  font-size: clamp(2rem, 3vw, 2.8rem);
  color: var(--blue-dark);
}

.quick-order-text p {
  margin: 0;
  line-height: 1.75;
}

.quick-order-form {
  display: grid;
  gap: 14px;
}

.quick-order-form label {
  display: grid;
  gap: 8px;
}

.quick-order-form span {
  color: var(--blue-dark);
  font-weight: 700;
}

.success-message {
  padding: 22px;
  border-radius: 20px;
  background: rgba(39, 174, 96, 0.12);
  color: #157347;
  font-weight: 700;
}

/* Футер */
.site-footer {
  margin-top: 40px;
  background: var(--blue-dark);
  color: rgba(255, 255, 255, 0.78);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 24px;
  padding: 64px 0 34px;
}

.footer-column {
  display: grid;
  align-content: start;
  gap: 10px;
}

.footer-column h3 {
  margin: 0 0 8px;
  color: var(--white);
}

.footer-column a:hover {
  color: var(--white);
}

.footer-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.5rem;
  color: var(--white);
}

.footer-logo-image {
  display: block;
  width: min(52px, 100%);
  height: auto;
}

.footer-logo-copy .logo-title {
  font-size: 1rem;
}

.footer-logo-copy .logo-subtitle {
  font-size: 0.58rem;
}

.footer-column p {
  margin: 0;
  line-height: 1.7;
}

.socials {
  display: flex;
  gap: 10px;
  margin-top: 8px;
}

.socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
}

.footer-bottom {
  padding: 18px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

/* Кошик */
.cart-overlay,
.filter-overlay,
.account-overlay {
  position: fixed;
  inset: 0;
  z-index: 70;
  background: rgba(10, 22, 40, 0.55);
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
}

.cart-overlay.active,
.filter-overlay.active,
.account-overlay.active {
  opacity: 1;
  visibility: visible;
}

/* Wishlist header button */
.wishlist-header-btn { display: inline-flex; align-items: center; gap: 4px; padding: 0 10px; height: 46px; border-radius: 12px; color: var(--white); background: rgba(255,255,255,0.06); border: 1.5px solid rgba(255,255,255,0.22); font-size: 1.1rem; cursor: pointer; transition: all 0.25s; position: relative; }
.wishlist-header-btn:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.38); }
.wishlist-count { font-size: .7rem; background: var(--orange-accent); color: #fff; border-radius: 50%; min-width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-weight: 700; }

/* Wishlist overlay + panel */
.wishlist-overlay { position: fixed; inset: 0; z-index: 70; background: rgba(10,22,40,0.55); opacity: 0; visibility: hidden; transition: 0.3s; }
.wishlist-overlay.active { opacity: 1; visibility: visible; }
.wishlist-panel { position: fixed; top: 0; right: -400px; width: 380px; max-width: 100vw; height: 100vh; background: var(--bg-primary); z-index: 80; box-shadow: -4px 0 24px rgba(0,0,0,0.15); transition: right 0.3s; display: flex; flex-direction: column; }
.wishlist-panel.open { right: 0; }
.wishlist-panel-header { display: flex; align-items: center; justify-content: space-between; padding: 16px; border-bottom: 1px solid var(--border-color); }
.wishlist-panel-header h3 { font-size: 1.1rem; margin: 0; }
.wishlist-panel-header button { background: none; border: none; font-size: 1.3rem; cursor: pointer; color: var(--text-primary); }
.wishlist-panel-body { flex: 1; overflow-y: auto; padding: 8px; }
.wishlist-bulk-actions { padding: 10px; border-bottom: 1px solid var(--gray-border); }
.wishlist-add-all-btn { width: 100%; font-size: 0.85rem; padding: 10px; }

/* Active filter chips */
.active-filters { display: flex; flex-wrap: wrap; gap: 6px; padding: 0; }
.active-filters:empty { display: none; }
.filter-chip { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; border-radius: 20px; background: var(--blue-pale); color: var(--blue-main); font-size: 0.78rem; font-weight: 500; border: 1px solid rgba(45,111,212,0.2); animation: cardFadeIn 0.2s ease both; }
.filter-chip-remove { background: none; border: none; color: var(--blue-light); cursor: pointer; font-size: 0.85rem; padding: 0 0 0 2px; font-weight: 700; line-height: 1; transition: color 0.15s; }
.filter-chip-remove:hover { color: var(--red-sale); }
.active-filters-clear { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; border-radius: 20px; background: transparent; border: 1px dashed var(--gray-border); color: var(--gray-text); font-size: 0.78rem; cursor: pointer; transition: 0.2s; }
.active-filters-clear:hover { border-color: var(--red-sale); color: var(--red-sale); }
body.dark-theme .filter-chip { background: rgba(59,130,246,0.15); color: var(--primary); border-color: rgba(59,130,246,0.3); }
body.dark-theme .filter-chip-remove { color: var(--primary); }
body.dark-theme .active-filters-clear { border-color: var(--border); color: var(--text2); }

.wishlist-item { display: flex; align-items: center; gap: 10px; padding: 10px; border-bottom: 1px solid var(--border-color); }
.wishlist-item-img { width: 50px; height: 50px; object-fit: cover; border-radius: 6px; }
.wishlist-item-info { flex: 1; min-width: 0; }
.wishlist-item-name { font-weight: 600; font-size: 0.88rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wishlist-item-name:hover { color: var(--blue-primary); }
.wishlist-item-price { font-size: 0.85rem; color: var(--text-secondary); margin-top: 2px; }
.wishlist-item-actions { display: flex; flex-direction: column; gap: 4px; }
.wishlist-item-actions .add-to-cart { font-size: .75rem; padding: 4px 8px; }
.wishlist-remove-btn { background: none; border: none; color: var(--text-secondary); font-size: 1rem; cursor: pointer; }

/* Product Detail Modal */
.product-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: rgba(10, 22, 40, 0.6);
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
}

.product-modal-overlay.active {
  opacity: 1;
  visibility: visible;
}

.product-modal {
  position: fixed;
  inset: 0;
  z-index: 91;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
  padding: 24px;
}

.product-modal.open {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
}

.product-modal-inner {
  position: relative;
  width: 100%;
  max-width: 960px;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  background: var(--white);
  border-radius: 28px;
  box-shadow: 0 24px 64px rgba(10, 22, 40, 0.28);
}

.product-modal-close {
  position: sticky;
  top: 12px;
  float: right;
  margin: 12px 12px 0 0;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(10, 22, 40, 0.08);
  color: var(--blue-dark);
  font-size: 1.1rem;
  z-index: 5;
  transition: background 0.2s;
}

.product-modal-close:hover {
  background: rgba(10, 22, 40, 0.16);
}

.product-modal-content {
  padding: 0 0 32px;
}

.pm-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.pm-image {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 340px;
  padding: 32px;
  background: linear-gradient(180deg, #f8fbff, #eef4fb);
  border-radius: 28px 0 0 0;
  overflow: hidden;
}

.pm-image img {
  max-width: 100%;
  max-height: 380px;
  object-fit: contain;
  border-radius: 8px;
}

.pm-image-placeholder {
  text-align: center;
  color: var(--blue-main);
}

.pm-image-placeholder svg {
  width: 80px;
  height: 80px;
  opacity: 0.5;
}

.pm-image-placeholder p {
  margin: 12px 0 0;
  font-size: 0.95rem;
  color: #7b8aa2;
}

.pm-badges {
  position: absolute;
  top: 18px;
  left: 18px;
  display: flex;
  gap: 8px;
  z-index: 2;
}

.pm-info {
  display: flex;
  flex-direction: column;
  padding: 32px;
}

.pm-category {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue-light);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.pm-title {
  margin: 0 0 12px;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.6rem;
  line-height: 1.3;
  color: var(--blue-dark);
}

.pm-brand {
  margin: 0 0 12px;
  color: #7b8aa2;
  font-size: 0.92rem;
}

.pm-rating {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  font-size: 0.92rem;
}

.pm-rating .stars {
  color: #f59e0b;
}

.pm-rating .meta {
  color: #73839b;
}

.pm-stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 20px;
  font-size: 0.88rem;
  font-weight: 600;
}

.pm-stock.in-stock {
  color: var(--green-badge);
}

.pm-stock.on-order {
  color: var(--blue-light);
}

.pm-stock.out-of-stock {
  color: var(--gray-text);
}

.pm-restock-eta {
  margin-top: 4px;
  font-size: 0.88rem;
  color: var(--blue-light);
  font-weight: 500;
}

.pm-variants { margin: 8px 0 4px; }
.pm-variants-label { font-size: 0.85rem; color: var(--text-secondary); margin-right: 6px; }
.pm-variants-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.pm-variant-btn { padding: 5px 12px; border: 1.5px solid var(--border-color); border-radius: 6px; background: var(--bg-secondary); font-size: 0.85rem; cursor: pointer; transition: all 0.15s; }
.pm-variant-btn:hover { border-color: var(--blue-light); }
.pm-variant-btn.active { border-color: var(--blue-primary); background: var(--blue-primary); color: #fff; }

.pm-stock-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.pm-prices {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 6px;
}

.pm-prices .current-price {
  font-size: 2.2rem;
}

.pm-unit {
  margin: 0 0 20px;
  color: #7b8aa2;
  font-size: 0.88rem;
}

.pm-buy-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 12px;
  margin-bottom: 16px;
}

.pm-buy-row .product-quantity {
  height: 52px;
}

.pm-buy-row .main-button {
  margin-top: 0;
}

.pm-delivery-info {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--gray-border);
}

.pm-delivery-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  background: var(--blue-pale);
  color: var(--blue-main);
  font-size: 0.8rem;
  font-weight: 500;
}

/* Tabs */
.pm-tabs {
  display: flex;
  gap: 0;
  padding: 0 32px;
  border-bottom: 2px solid var(--gray-border);
  margin-top: 8px;
}

.pm-tab {
  padding: 14px 20px;
  background: none;
  color: #7b8aa2;
  font-weight: 600;
  font-size: 0.92rem;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color 0.2s, border-color 0.2s;
}

.pm-tab:hover {
  color: var(--blue-main);
}

.pm-tab.active {
  color: var(--blue-dark);
  border-bottom-color: var(--orange-cta);
}

.pm-tab-content {
  display: none;
  padding: 24px 32px;
}

.pm-tab-content.active {
  display: block;
}

/* Description tab */
.pm-description {
  line-height: 1.7;
  color: var(--gray-text);
  font-size: 0.95rem;
}

.pm-description:empty::after {
  content: attr(data-empty);
  color: #94a3b8;
  font-style: italic;
}

/* Specs tab */
.pm-specs-table {
  width: 100%;
  border-collapse: collapse;
}

.pm-specs-table tr:nth-child(even) {
  background: var(--gray-light);
}

.pm-specs-table td {
  padding: 12px 16px;
  font-size: 0.92rem;
  vertical-align: top;
}

.pm-specs-table .spec-label {
  width: 40%;
  color: #7b8aa2;
}

.pm-specs-table .spec-value {
  color: var(--blue-dark);
  font-weight: 500;
}

/* Reviews tab in modal */
.pm-reviews-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.pm-reviews-empty {
  text-align: center;
  padding: 24px;
  color: #8a95a3;
}

@media (max-width: 768px) {
  .product-modal {
    padding: 0;
    align-items: flex-end;
  }

  .product-modal-inner {
    max-height: 95vh;
    border-radius: 24px 24px 0 0;
  }

  .pm-top {
    grid-template-columns: 1fr;
  }

  .pm-image {
    min-height: 240px;
    border-radius: 24px 24px 0 0;
  }

  .pm-info {
    padding: 20px;
  }

  .pm-tabs {
    padding: 0 20px;
    overflow-x: auto;
  }

  .pm-tab-content {
    padding: 20px;
  }

  .pm-buy-row {
    grid-template-columns: 110px 1fr;
  }

  .pm-title {
    font-size: 1.3rem;
  }
}

.account-sidebar,
.cart-sidebar {
  position: fixed;
  top: 0;
  right: -420px;
  z-index: 80;
  display: flex;
  flex-direction: column;
  width: min(420px, 100%);
  height: 100vh;
  background: var(--blue-dark);
  color: var(--white);
  box-shadow: -12px 0 32px rgba(10, 22, 40, 0.28);
  transition: 0.3s;
}

.cart-sidebar > .cart-header {
  flex-shrink: 0;
  padding: 22px 22px 0;
}

.cart-body {
  flex: 1;
  overflow-y: auto;
  padding: 0 22px;
  min-height: 0;
}

.cart-footer {
  flex-shrink: 0;
  padding: 12px 22px 22px;
  background: var(--blue-dark);
}

.account-sidebar {
  position: fixed;
  top: 0;
  right: -460px;
  z-index: 81;
  display: flex;
  flex-direction: column;
  width: min(460px, 100%);
  height: 100vh;
  padding: 22px;
  background: linear-gradient(180deg, #0a1628, #12233d);
  color: var(--white);
  box-shadow: -12px 0 32px rgba(10, 22, 40, 0.28);
  transition: 0.3s;
  overflow-y: auto;
}

.account-sidebar.open,
.cart-sidebar.open {
  right: 0;
}

.account-header,
.cart-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.account-header h3,
.cart-header h3 {
  margin: 0;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 2rem;
}

.account-header button,
.cart-header button {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.1);
  color: var(--white);
}

.account-content {
  flex: 1;
  overflow-y: auto;
  padding: 18px 4px 18px 0;
}

.account-auth-card,
.account-panel-card,
.account-promo-card,
.account-order-card {
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.account-auth-card {
  padding: 22px;
}

.account-auth-card h4,
.account-section-title {
  margin: 0 0 10px;
  color: var(--white);
}

.account-auth-card p,
.account-note,
.account-order-meta,
.account-order-items,
.account-order-total span,
.account-empty {
  color: rgba(255, 255, 255, 0.72);
}

.account-tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin: 18px 0;
}

.account-tab {
  min-height: 44px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.78);
  font-weight: 700;
}

.account-tab.active {
  background: var(--white);
  color: var(--blue-dark);
}

.account-field {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.account-field span {
  color: var(--white);
  font-weight: 700;
}

.account-field input {
  width: 100%;
  min-height: 50px;
  padding: 0 16px;
  border: none;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.96);
}

.account-actions {
  display: grid;
  gap: 10px;
}

.account-note {
  margin-top: 14px;
  line-height: 1.55;
}

.account-panel-card {
  display: grid;
  gap: 18px;
  padding: 22px;
  margin-bottom: 18px;
}

.account-user-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.account-user-main {
  display: flex;
  align-items: center;
  gap: 14px;
}

.account-avatar {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--blue-main), var(--blue-light));
  color: var(--white);
}

.account-avatar svg {
  width: 24px;
  height: 24px;
}

.account-user-main h4,
.account-promo-card h4,
.account-order-card h4 {
  margin: 0 0 6px;
  color: var(--white);
}

.account-user-main p,
.account-promo-card p,
.account-order-card p {
  margin: 0;
}

.account-logout {
  min-height: 42px;
}

.account-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.account-stat {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.05);
}

.account-stat span {
  display: block;
  margin-bottom: 8px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.82rem;
}

.account-stat strong {
  color: var(--white);
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.55rem;
}

.account-section {
  margin-top: 18px;
}

.account-section-title {
  margin-bottom: 12px;
  font-size: 1.2rem;
}

.account-promo-list,
.account-order-list {
  display: grid;
  gap: 12px;
}

.account-promo-card,
.account-order-card {
  padding: 18px;
}

.account-promo-card strong {
  display: inline-flex;
  margin-top: 10px;
  color: #9fd27b;
}

.account-order-head,
.account-order-total {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.account-order-status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(74, 144, 217, 0.14);
  color: #a9cbff;
  font-size: 0.82rem;
  font-weight: 700;
}

.account-order-meta {
  margin: 10px 0;
  font-size: 0.9rem;
}

.account-order-items {
  display: grid;
  gap: 6px;
  margin: 12px 0 14px;
  font-size: 0.92rem;
}

.account-order-progress {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}

.account-order-step {
  padding: 10px 8px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
  text-align: center;
  font-size: 0.76rem;
  color: rgba(255, 255, 255, 0.56);
}

.account-order-step.done,
.account-order-step.active {
  color: var(--white);
}

.account-order-step.done {
  background: rgba(39, 174, 96, 0.18);
}

.account-order-step.active {
  background: rgba(74, 144, 217, 0.18);
}

.account-order-canceled {
  padding: 10px 8px;
  border-radius: 14px;
  background: rgba(220, 38, 38, 0.18);
  text-align: center;
  font-size: 0.82rem;
  color: #ef4444;
  font-weight: 600;
}

.account-order-total strong {
  color: var(--white);
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.18rem;
}

.account-empty {
  padding: 20px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.05);
}

.cart-items {
  flex: 1;
  overflow-y: auto;
  padding: 18px 4px 18px 0;
}

.cart-empty {
  padding: 28px 18px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.72);
  text-align: center;
}

.cart-item {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.cart-item-preview {
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--blue-main), var(--blue-light));
  color: var(--white);
  overflow: hidden;
}

.cart-item-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cart-item h4 {
  margin: 0 0 8px;
  font-size: 1rem;
}

.cart-item p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
}

.cart-item-meta {
  margin-bottom: 10px;
}

.cart-item-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

.cart-item-total {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.8);
}

.cart-item-total strong {
  color: var(--white);
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.02rem;
}

.cart-item-controls button {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.12);
  color: var(--white);
}

.cart-remove {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--white);
}

.cart-summary {
  padding-top: 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.cart-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  color: rgba(255, 255, 255, 0.78);
}

.cart-discount-line {
  display: none;
}

.cart-discount-line.active {
  display: flex;
}

.cart-total-line {
  margin-bottom: 18px;
  font-size: 1.15rem;
  color: var(--white);
}

.promo-code-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  margin-bottom: 16px;
}

.promo-code-box input {
  background: rgba(255, 255, 255, 0.95);
}

.cart-order-button {
  width: 100%;
}

.payment-methods {
  margin-bottom: 18px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.06);
}

.payment-title {
  margin-bottom: 12px;
  color: var(--white);
  font-weight: 700;
}

.payment-options {
  display: grid;
  gap: 10px;
}

.payment-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.85);
}

.payment-option input {
  margin: 0;
}

.payment-note {
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.6;
}

/* Форма гостьового замовлення */
.guest-checkout-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 16px 0;
  padding: 16px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.guest-checkout-form label {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.65);
  margin-bottom: -4px;
}

/* Секція доставки */
.delivery-section {
  margin-bottom: 18px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.06);
}

.delivery-methods {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.delivery-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.85);
  cursor: pointer;
  transition: 0.2s;
}

.delivery-option:hover {
  background: rgba(255, 255, 255, 0.1);
}

.delivery-option input {
  margin: 0;
}

.delivery-address-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.delivery-select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23ffffff' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

/* Region trigger button */
.region-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
}
.region-trigger svg {
  flex-shrink: 0;
  opacity: 0.7;
}
.region-trigger.has-value #regionLabel {
  color: #fff;
}

/* Region picker modal */
.region-modal-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.5);
  z-index: 100000;
  align-items: flex-end;
  justify-content: center;
}
.region-modal-overlay.open {
  display: flex;
}
.region-modal {
  background: var(--blue-dark, #1a2332);
  border-radius: 16px 16px 0 0;
  width: 100%;
  max-width: 480px;
  max-height: 70vh;
  overflow-y: auto;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.region-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  font-size: 1.05rem;
  font-weight: 600;
  color: #fff;
  position: sticky;
  top: 0;
  background: var(--blue-dark, #1a2332);
}
.region-modal-close {
  background: none;
  border: none;
  color: rgba(255,255,255,0.6);
  font-size: 1.6rem;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.region-modal-options {
  display: flex;
  flex-direction: column;
  padding: 8px 0;
}
.region-modal-options button {
  background: none;
  border: none;
  color: #fff;
  padding: 14px 20px;
  text-align: left;
  font-size: 1rem;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s;
}
.region-modal-options button:hover,
.region-modal-options button:active {
  background: rgba(255,255,255,0.08);
}
.region-modal-options button.selected {
  color: var(--accent, #f97316);
  font-weight: 600;
}

/* Dark theme region picker */
body.dark-theme .region-modal {
  background: var(--bg2);
}
body.dark-theme .region-modal-header {
  background: var(--bg2);
  color: var(--text);
  border-color: var(--border);
}
body.dark-theme .region-modal-close {
  color: var(--text2);
}
body.dark-theme .region-modal-options button {
  color: var(--text);
}
body.dark-theme .region-modal-options button:hover,
body.dark-theme .region-modal-options button:active {
  background: rgba(255,255,255,0.05);
}

/* City search inside modal */
.city-search-wrap {
  padding: 8px 16px;
  position: sticky;
  top: 0;
  background: var(--blue-dark, #1a2332);
  z-index: 1;
}
.city-search-input {
  width: 100%;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.08);
  color: #fff;
  font-size: 15px;
  font-family: inherit;
  outline: none;
  box-sizing: border-box;
}
.city-search-input::placeholder {
  color: rgba(255,255,255,0.45);
}
.city-search-input:focus {
  border-color: var(--accent, #f97316);
}
body.dark-theme .city-search-wrap {
  background: var(--bg2);
}
body.dark-theme .city-search-input {
  background: var(--bg);
  color: var(--text);
  border-color: var(--border);
}

/* Disabled trigger */
.region-trigger:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.delivery-address-block.hidden {
  display: none;
}

/* Pickup address info */
.pickup-address-block{margin-top:10px}
.pickup-address-block.hidden{display:none}
.pickup-info{display:flex;gap:12px;padding:14px 16px;border-radius:12px;background:rgba(59,130,246,0.08);border:1px solid rgba(59,130,246,0.2)}
.pickup-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.pickup-info strong{display:block;font-size:.88rem;color:var(--white);margin-bottom:4px}
.pickup-info p{margin:0;font-size:.84rem;color:rgba(255,255,255,0.8);line-height:1.5}
.pickup-hours{font-size:.78rem!important;color:rgba(255,255,255,0.55)!important;margin-top:4px!important}
body.dark-theme .pickup-info{background:rgba(59,130,246,0.1);border-color:rgba(59,130,246,0.25)}
body.dark-theme .pickup-info strong{color:var(--text)}
body.dark-theme .pickup-info p{color:var(--text2)}

.guest-input {
  width: 100%;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 15px;
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}

.guest-input::placeholder {
  color: rgba(255, 255, 255, 0.35);
}

.guest-input:focus {
  border-color: var(--accent);
}

/* Плашка успішного замовлення */
.order-success-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 36px 24px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(39, 174, 96, 0.18), rgba(16, 185, 129, 0.12));
  border: 1px solid rgba(39, 174, 96, 0.25);
  text-align: center;
}

.order-success-icon {
  font-size: 2.8rem;
}

.order-success-banner h3 {
  margin: 0;
  color: var(--white);
  font-family: "Roboto Condensed", sans-serif;
  font-size: 1.3rem;
  line-height: 1.3;
}

.order-success-banner p {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 1rem;
  line-height: 1.6;
}

/* Сповіщення */
.toast {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 90;
  min-width: 280px;
  max-width: min(360px, calc(100% - 40px));
  padding: 14px 18px;
  border-radius: 16px;
  background: var(--blue-dark);
  color: var(--white);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  transition: 0.3s;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.92rem;
}

.toast.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.toast-icon {
  flex-shrink: 0;
  font-size: 1.15rem;
  line-height: 1;
}

.toast.toast-success { background: #166534; }
.toast.toast-error { background: #991b1b; }
.toast.toast-info { background: var(--blue-dark); }

/* ===== Гамбургер-кнопка ===== */
.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  cursor: pointer;
  transition: 0.3s;
  flex-shrink: 0;
}

.mobile-menu-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: 0.3s;
}

.mobile-menu-toggle.active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.mobile-menu-toggle.active span:nth-child(2) {
  opacity: 0;
}

.mobile-menu-toggle.active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Адаптив для планшетів */
@media (max-width: 1100px) {
  :root {
    --header-height: 140px;
  }

  .header-main {
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    padding: 12px 0;
    min-height: 72px;
  }

  .header-actions {
    gap: 8px;
  }

  .language-switcher {
    display: none;
  }

  .category-nav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    justify-content: flex-start;
    flex-wrap: nowrap;
    padding: 8px 0 10px;
  }

  .category-nav::-webkit-scrollbar {
    display: none;
  }

  .hero-content,
  .quick-order-wrap {
    grid-template-columns: 1fr;
  }

  .hero-panel {
    max-width: 500px;
  }

  .trust-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .popular-categories,
  .reasons-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .promo-products {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .catalog-layout {
    grid-template-columns: 1fr;
  }

  .filter-toggle {
    display: inline-flex;
    width: 100%;
  }

  .filters-panel {
    position: fixed;
    top: 0;
    left: -100%;
    z-index: 75;
    width: min(340px, calc(100% - 20px));
    height: 100vh;
    overflow-y: auto;
    border-radius: 0 20px 20px 0;
    transition: 0.3s;
  }

  .filters-panel.open {
    left: 0;
  }

  .close-filters {
    display: inline-grid;
    place-items: center;
  }

  .products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .account-stats {
    grid-template-columns: 1fr;
  }
}

/* Адаптив для мобільних пристроїв */
@media (max-width: 767px) {
  :root {
    --header-height: 100px;
  }

  .section {
    padding: 48px 0;
  }

  .container {
    width: min(100% - 20px, 1200px);
  }

  /* --- Header mobile --- */
  .header-main {
    grid-template-columns: 1fr auto auto;
    gap: 10px;
    min-height: 56px;
    padding: 8px 0;
  }

  .search-block {
    position: fixed;
    top: 56px;
    left: 0;
    right: 0;
    z-index: 39;
    padding: 6px 10px;
    background: var(--blue-dark);
    box-shadow: 0 4px 12px rgba(10,22,40,.18);
    order: 10;
  }

  .search-block .search-box {
    border-radius: 12px;
  }

  .search-block .search-box input {
    padding: 10px 12px;
    font-size: .9rem;
  }

  .search-block .search-box button {
    width: 42px;
    height: 42px;
  }

  .search-suggestions {
    border-radius: 0 0 12px 12px;
    top: 100%;
    margin-top: 0;
  }

  .header-nav {
    margin-top: 54px;
  }

  .mobile-menu-toggle {
    display: flex;
  }

  .header-actions-inner {
    display: none;
    position: fixed;
    top: 64px;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 60;
    padding: 20px;
    background: var(--blue-dark);
    overflow-y: auto;
    flex-direction: column;
    gap: 12px;
  }

  .header-actions-inner.open {
    display: flex;
  }

  .language-switcher {
    display: inline-flex;
    width: 100%;
    justify-content: center;
  }

  .phone-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .phone-arrow {
    display: inline;
  }

  .phone-dropdown {
    display: none;
    position: static;
    flex-direction: column;
    gap: 8px;
    padding: 0;
    border-radius: 0;
    background: none;
    box-shadow: none;
    border: none;
  }

  .phone-group.open .phone-dropdown {
    display: flex;
  }

  .phone-dropdown-item {
    width: 100%;
    justify-content: center;
    height: 48px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 12px;
  }

  .phone-item {
    width: 100%;
    justify-content: center;
    height: 48px;
  }

  .account-button {
    width: 100%;
    justify-content: center;
    height: 48px;
  }

  .cart-button {
    width: 100%;
    justify-content: center;
    height: 48px;
  }

  .header-actions {
    gap: 8px;
  }

  .logo-image {
    width: min(42px, 100%);
  }

  .logo-title {
    font-size: 1rem;
  }

  .logo-subtitle {
    font-size: 0.55rem;
    letter-spacing: 0.08em;
  }

  .category-nav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 6px;
    padding: 8px 0 10px;
  }

  .category-nav::-webkit-scrollbar {
    display: none;
  }

  .nav-link {
    padding: 6px 10px;
    font-size: 0.76rem;
  }

  /* --- Hero mobile --- */
  .hero {
    padding-top: calc(var(--header-height) + 24px);
    padding-bottom: 48px;
  }

  .hero-text h1 {
    font-size: clamp(1.8rem, 6vw, 2.6rem);
  }

  .hero-text p {
    font-size: 0.95rem;
    margin: 14px 0 20px;
  }

  .hero-badge {
    font-size: 0.78rem;
    padding: 8px 12px;
  }

  .hero-benefits {
    flex-direction: column;
    gap: 10px;
    margin-bottom: 20px;
  }

  .hero-benefit {
    justify-content: flex-start;
    padding: 10px 14px;
  }

  .hero-panel {
    display: none;
  }

  /* --- Trust strip --- */
  .trust-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .trust-card {
    min-height: 60px;
    padding: 12px;
    border-radius: 16px;
    font-size: 0.85rem;
    gap: 8px;
    justify-content: flex-start;
  }

  .trust-card:last-child {
    grid-column: 1 / -1;
    justify-content: center;
    max-width: 60%;
    margin: 0 auto;
  }

  .info-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
  }

  .info-icon svg {
    width: 18px;
    height: 18px;
  }

  /* --- Categories --- */
  .popular-categories {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .category-card {
    padding: 16px;
    border-radius: 18px;
  }

  .category-card-media {
    height: 120px;
    margin: -16px -16px 12px;
  }

  .category-card h3 {
    font-size: 1rem;
    margin: 10px 0 6px;
  }

  .category-card p {
    font-size: 0.85rem;
    padding-top: 10px;
  }

  .category-card-list {
    margin-top: 10px;
    gap: 6px;
  }

  .category-card-list span {
    font-size: 0.72rem;
    min-height: 24px;
    padding: 0 8px;
  }

  /* --- Catalog --- */
  .section-head {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .section-head h2 {
    font-size: 1.6rem;
  }

  .catalog-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 14px;
  }

  .sort-buttons {
    flex-wrap: wrap;
    gap: 8px;
  }

  .sort-button {
    min-height: 36px;
    padding: 0 12px;
    font-size: 0.82rem;
  }

  .found-counter {
    text-align: left;
    font-size: 0.88rem;
  }

  .products-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .product-card {
    border-radius: 16px;
  }

  .product-image {
    height: 180px;
    padding: 12px;
  }

  .product-body {
    padding: 14px 14px 16px;
  }

  .product-title {
    font-size: 0.92rem;
    min-height: 40px;
    margin-bottom: 8px;
  }

  .product-brand,
  .product-unit {
    font-size: 0.8rem;
    margin-bottom: 6px;
  }

  .product-description {
    display: none;
  }

  .product-prices {
    margin-bottom: 6px;
  }

  .current-price {
    font-size: 1.3rem;
  }

  .old-price {
    font-size: 0.82rem;
  }

  .product-buy-row {
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 10px;
  }

  .product-quantity {
    height: 44px;
    grid-template-columns: 30px 1fr 30px;
  }

  .add-to-cart {
    min-height: 44px;
    font-size: 0.88rem;
    margin-top: 0;
  }

  .badge {
    font-size: 0.68rem;
    min-height: 22px;
    padding: 0 7px;
  }

  .product-badges {
    inset: 10px 10px auto 10px;
  }

  .product-image::after {
    inset: 10px;
    border-radius: 14px;
  }

  /* --- Promo --- */
  .promo-banner {
    flex-direction: column;
    text-align: center;
    padding: 24px;
    border-radius: 20px;
  }

  .promo-products {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .promo-link {
    width: 100%;
  }

  /* --- Site Blocks --- */
  .site-blocks-container {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 24px;
  }

  .site-block {
    flex-direction: column;
    text-align: center;
    padding: 22px 18px;
    border-radius: 18px;
    gap: 16px;
  }

  .site-block-image {
    flex: 0 0 auto;
    width: 100%;
    height: 160px;
    border-radius: 14px;
  }

  .site-block-title {
    font-size: 1.2rem;
  }

  .sb-timer-block {
    min-width: 40px;
    font-size: 1.2rem;
    padding: 6px 8px 4px;
  }

  .site-block-timer {
    justify-content: center;
  }

  /* --- Reasons --- */
  .reasons-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .reason-card {
    padding: 20px;
    border-radius: 18px;
  }

  /* --- Quick order --- */
  .quick-order-wrap {
    padding: 24px;
    border-radius: 20px;
  }

  /* --- Footer --- */
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 40px 0 24px;
  }

  /* --- Cart & Account sidebar --- */
  .cart-sidebar,
  .account-sidebar {
    width: 100%;
    right: -100%;
  }

  /* --- Promo code --- */
  .promo-code-box {
    grid-template-columns: 1fr;
  }

  .account-order-progress {
    grid-template-columns: repeat(2, 1fr);
  }

  .account-stats {
    grid-template-columns: 1fr;
  }

  /* ─── Mobile touch & UX optimizations ─── */

  /* Ensure min 44px touch targets for all interactive elements */
  .nav-link {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
  }

  .sort-button {
    min-height: 40px;
  }

  .filter-toggle {
    min-height: 48px;
    font-size: 0.9rem;
  }

  .close-filters {
    width: 44px;
    height: 44px;
  }

  /* Category nav: fade hint for scrollable area */
  .header-nav .container {
    position: relative;
  }
  .category-nav {
    padding-right: 24px;
    -webkit-mask-image: linear-gradient(to right, #000 85%, transparent 100%);
    mask-image: linear-gradient(to right, #000 85%, transparent 100%);
  }

  /* Product cards — content-visibility for scroll perf */
  .product-card {
    content-visibility: auto;
    contain-intrinsic-size: auto 520px;
  }

  /* Larger buy-one-click on mobile */
  .buy-one-click-btn {
    min-height: 44px;
    font-size: 0.88rem;
  }

  /* Bigger action row buttons */
  .product-actions-row {
    gap: 8px;
    margin-top: 10px;
  }

  .compare-btn,
  .reviews-toggle-btn {
    min-height: 40px;
    font-size: 0.8rem;
    padding: 6px 4px;
  }

  /* Product specs toggle — proper touch size */
  .product-specs-toggle {
    min-height: 44px;
    padding: 10px 14px;
    font-size: 0.84rem;
  }

  /* Quantity buttons bigger for touch */
  .product-quantity button {
    font-size: 1.2rem;
  }

  /* Volume badge readable */
  .volume-badge {
    font-size: 0.8rem;
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Review form larger inputs */
  .review-form .guest-input,
  .review-form textarea {
    min-height: 44px;
    font-size: 15px;
  }

  .review-star-label {
    min-width: 40px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Sticky add-to-cart bar for mobile modal */
  .pm-sticky-buy {
    padding: 10px 16px;
    gap: 12px;
  }

  .pm-sticky-buy .main-button {
    min-height: 48px;
    font-size: 0.95rem;
  }

  /* Product modal tabs — larger tap area */
  .pm-tab {
    min-height: 44px;
    padding: 10px 14px;
    font-size: 0.88rem;
  }

  /* Wishlist button bigger touch target */
  .wishlist-btn {
    width: 40px;
    height: 40px;
    font-size: 20px;
  }

  /* Phone links — full-width accessible buttons */
  .phone-item,
  .phone-dropdown-item {
    min-height: 48px;
    font-size: 0.95rem;
  }

  /* Larger search input on mobile */
  .search-box input {
    font-size: 16px; /* prevents iOS zoom on focus */
    padding: 14px 15px;
  }

  /* Quick order form — prevent iOS zoom */
  .quick-order-form input {
    font-size: 16px;
  }

  /* Guest checkout inputs */
  .guest-input {
    font-size: 16px;
    min-height: 48px;
  }

  /* Delivery section mobile */
  .delivery-section {
    padding: 14px;
  }

  .delivery-option {
    padding: 12px;
    font-size: 0.9rem;
    min-height: 44px;
  }

  .delivery-select {
    font-size: 16px;
    min-height: 48px;
  }

  /* Scroll-to-top button */
  .scroll-top-btn {
    width: 48px;
    height: 48px;
  }

  /* Float chat bigger target */
  .float-chat-btn {
    width: 52px;
    height: 52px;
  }

  /* Footer social links — better tap targets */
  .messenger-links a {
    min-height: 40px;
    padding: 8px 14px;
  }
}
@media (min-width: 1101px) {
  .filter-toggle {
    display: none;
  }
}

/* Landscape phone: compact sticky search so it doesn't cover logo */
@media (max-width: 767px) and (orientation: landscape) {
  :root {
    --header-height: 88px;
  }

  .header-main {
    min-height: 44px;
    padding: 4px 0;
  }

  .logo-image {
    width: min(32px, 100%);
  }

  .logo-title {
    font-size: 0.85rem;
  }

  .logo-subtitle {
    display: none;
  }

  .search-block {
    top: 44px;
    padding: 4px 10px;
  }

  .search-block .search-box input {
    padding: 7px 10px;
    font-size: .85rem;
  }

  .search-block .search-box button {
    width: 36px;
    height: 36px;
  }
}

/* Дуже маленькі екрани */
@media (max-width: 420px) {
  :root {
    --header-height: 60px;
  }

  .container {
    width: min(100% - 16px, 1200px);
  }

  .logo-image {
    width: min(36px, 100%);
  }

  .logo-title {
    font-size: 0.88rem;
  }

  .logo-subtitle {
    display: none;
  }

  .popular-categories,
  .products-grid,
  .promo-products {
    grid-template-columns: 1fr;
  }

  .trust-grid {
    grid-template-columns: 1fr;
  }

  .trust-card:last-child {
    max-width: 100%;
  }

  .hero-text h1 {
    font-size: 1.6rem;
  }

  .current-price {
    font-size: 1.2rem;
  }

  .product-image {
    height: 200px;
  }

  .category-card-media {
    height: 100px;
  }

  .search-box button {
    width: 44px;
    height: 44px;
  }

  /* Single column — cards become bigger and more readable */
  .product-card {
    contain-intrinsic-size: auto 480px;
  }

  .product-image {
    height: 220px;
  }

  .product-body {
    padding: 16px;
  }

  .product-title {
    font-size: 1rem;
    min-height: auto;
    -webkit-line-clamp: 3;
    line-clamp: 3;
  }

  .product-buy-row {
    grid-template-columns: 100px 1fr;
  }

  .add-to-cart {
    min-height: 48px;
    font-size: 0.92rem;
  }

  .buy-one-click-btn {
    min-height: 46px;
    font-size: 0.9rem;
  }

  /* Category card single-col */  
  .category-card-media {
    height: 140px;
  }

  .category-card h3 {
    font-size: 1.1rem;
  }
}

/* ═══════════════════════════════════════════════════════════════
   20 IMPROVEMENTS — CSS
   ═══════════════════════════════════════════════════════════════ */

/* 1. Compare products */
.compare-btn{background:none;border:1px solid #cbd5e1;padding:5px 0;border-radius:6px;font-size:.75rem;cursor:pointer;color:#475569;transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:4px;flex:1;min-width:0}
.compare-btn:hover,.compare-btn.active{border-color:#1d4ed8;color:#1d4ed8;background:#eff6ff}
.compare-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:1100;transform:translateY(100%);transition:transform .3s;padding:12px 0}
.compare-panel.visible{transform:translateY(0)}
.compare-panel .container{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}
.compare-chips{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.compare-chip{background:#eff6ff;border:1px solid #93c5fd;border-radius:20px;padding:4px 12px;font-size:.8rem;display:flex;align-items:center;gap:6px}
.compare-chip button{background:none;border:none;cursor:pointer;font-size:1rem;color:#ef4444;line-height:1}
.compare-actions{display:flex;gap:8px}
.compare-overlay{position:fixed;inset:0;z-index:1200;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center}
.compare-overlay.active{display:flex}
.compare-modal{background:#fff;border-radius:12px;max-width:900px;width:95%;max-height:85vh;overflow:auto;padding:24px}
.compare-modal h3{margin:0 0 16px;font-size:1.3rem}
.compare-table{width:100%;border-collapse:collapse}
.compare-table th,.compare-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #e2e8f0;font-size:.85rem}
.compare-table th{background:#f8fafc;font-weight:600;white-space:nowrap;width:150px}
.compare-table td{min-width:180px}
.compare-table .compare-product-name{font-weight:600;font-size:.9rem}
.compare-table .compare-product-price{color:#1d4ed8;font-weight:700}
.compare-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.4rem;cursor:pointer}

/* 2. Skeleton loading */
.skeleton-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.skeleton-image{height:200px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.5s infinite}
.skeleton-line{height:14px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:400% 100%;animation:shimmer 1.5s infinite;border-radius:6px;margin:12px 16px 0}
.skeleton-line.short{width:60%}
.skeleton-line.price{width:40%;height:20px;margin-top:16px}
.skeleton-line.btn{width:100%;height:36px;margin:16px 16px 16px;border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Product cards fade-in animation */
@keyframes cardFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.product-card { animation: cardFadeIn 0.35s ease both; }
.products-grid .product-card:nth-child(1) { animation-delay: 0s; }
.products-grid .product-card:nth-child(2) { animation-delay: 0.04s; }
.products-grid .product-card:nth-child(3) { animation-delay: 0.08s; }
.products-grid .product-card:nth-child(4) { animation-delay: 0.12s; }
.products-grid .product-card:nth-child(5) { animation-delay: 0.16s; }
.products-grid .product-card:nth-child(6) { animation-delay: 0.2s; }

/* 3. Scroll to top button */
.scroll-top-btn{position:fixed;bottom:80px;right:20px;width:48px;height:48px;border-radius:50%;background:#1d4ed8;color:#fff;border:none;font-size:1.4rem;cursor:pointer;box-shadow:0 4px 12px rgba(29,78,216,.3);z-index:1050;opacity:0;visibility:hidden;transition:.3s;display:flex;align-items:center;justify-content:center}
.scroll-top-btn.visible{opacity:1;visibility:visible}
.scroll-top-btn:hover{background:#1e40af;transform:scale(1.1)}

/* 4. Material calculator */
.calc-modal-overlay{position:fixed;inset:0;z-index:1200;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center}
.calc-modal-overlay.active{display:flex}
.calc-modal{background:#fff;border-radius:12px;max-width:480px;width:95%;padding:28px;position:relative}
.calc-modal h3{margin:0 0 8px;font-size:1.2rem}
.calc-modal p{color:#64748b;font-size:.87rem;margin:0 0 20px}
.calc-form label{display:block;margin-bottom:14px;font-size:.9rem;font-weight:500}
.calc-form input,.calc-form select{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:.95rem;margin-top:4px;box-sizing:border-box}
.calc-result{background:#eff6ff;border-radius:8px;padding:16px;margin-top:16px;font-size:.95rem;display:none}
.calc-result.visible{display:block}
.calc-result strong{font-size:1.2rem;color:#1d4ed8}
.calc-formula{margin-top:8px;font-size:.82rem;color:#64748b;font-family:monospace}
.calc-reserve{margin-top:4px;font-size:.85rem;color:#059669;font-weight:500}
.calc-type-info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:8px 12px;margin-bottom:16px;font-size:.85rem;color:#1e40af;display:none}
.calc-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.4rem;cursor:pointer}
.calc-trigger{display:inline-flex;align-items:center;gap:6px;background:#f0fdf4;border:1px solid #86efac;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.85rem;color:#166534;font-weight:500;transition:.2s}
.calc-trigger:hover{background:#dcfce7}

/* 5. Similar products */
.pm-similar{margin-top:24px;border-top:1px solid #e2e8f0;padding-top:20px}
.pm-similar h3{font-size:1rem;margin:0 0 12px;color:#334155}
.pm-similar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.pm-similar-card{background:#f8fafc;border-radius:10px;padding:10px;cursor:pointer;transition:.2s;text-align:center;border:1px solid #e2e8f0}
.pm-similar-card:hover{border-color:#93c5fd;background:#eff6ff}
.pm-similar-card img{width:100%;height:80px;object-fit:cover;border-radius:6px}
.pm-similar-card .sim-placeholder{width:100%;height:80px;background:#e2e8f0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#94a3b8}
.pm-similar-card .sim-name{font-size:.78rem;margin:6px 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:#334155}
.pm-similar-card .sim-price{font-size:.85rem;font-weight:700;color:#1d4ed8}

/* 6. Bundles ("Часто купують разом") */
.pm-bundles{margin-top:24px;border-top:1px solid #e2e8f0;padding-top:20px}
.pm-bundles h3{font-size:1rem;margin:0 0 14px;color:#334155}
.bundle-card{background:linear-gradient(135deg,#f0f9ff 0%,#eff6ff 100%);border:1.5px solid #bfdbfe;border-radius:14px;padding:16px;margin-bottom:14px;transition:.25s}
.bundle-card:hover{border-color:#60a5fa;box-shadow:0 4px 16px rgba(59,130,246,.12)}
.bundle-items{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.bundle-product{display:flex;flex-direction:column;align-items:center;gap:4px;width:100px;text-align:center}
.bundle-product img{width:72px;height:72px;object-fit:cover;border-radius:10px;border:1px solid #e2e8f0;background:#fff}
.bundle-product span{font-size:.75rem;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:#334155}
.bundle-product small{font-size:.72rem;color:#64748b;font-weight:500}
.bundle-noimg{width:72px;height:72px;border-radius:10px;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.bundle-plus{font-size:1.4rem;font-weight:700;color:#3b82f6;flex-shrink:0}
.bundle-price{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px;padding-top:12px;border-top:1px dashed #cbd5e1}
.bundle-old{font-size:.9rem;color:#94a3b8;text-decoration:line-through}
.bundle-new{font-size:1.1rem;font-weight:700;color:#16a34a;background:#dcfce7;padding:3px 10px;border-radius:6px}
.bundle-add-btn{display:block;margin:12px auto 0;padding:10px 28px;border:none;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:.2s;box-shadow:0 2px 8px rgba(37,99,235,.3)}
.bundle-add-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.35)}
.bundle-add-btn:active{transform:translateY(0)}
@media(max-width:500px){.bundle-product{width:80px}.bundle-product img,.bundle-noimg{width:56px;height:56px}.bundle-plus{font-size:1.1rem}}

/* 7. Share product */
.pm-share{display:flex;gap:8px;margin-top:12px}
.pm-share button{padding:6px 12px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;font-size:.78rem;display:flex;align-items:center;gap:4px;transition:.2s;color:#475569}
.pm-share button:hover{border-color:#1d4ed8;color:#1d4ed8;background:#eff6ff}

/* 7. Notify when in stock */
.notify-stock-btn{background:#fef3c7;border:1px solid #fbbf24;color:#92400e;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:.8rem;margin-top:6px;transition:.2s}
.notify-stock-btn:hover{background:#fde68a}
.notify-stock-form{margin-top:8px;display:flex;gap:6px}
.notify-stock-form input{flex:1;padding:6px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:.85rem}
.notify-stock-form button{padding:6px 14px;background:#1d4ed8;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.8rem}

/* 8. Track order by number */
.track-section{background:#f8fafc;border-radius:12px;padding:20px;margin-bottom:20px}
.track-section h4{margin:0 0 10px;font-size:.95rem}
.track-form{display:flex;gap:8px}
.track-form input{flex:1;padding:8px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem}
.track-form button{padding:8px 16px;background:#1d4ed8;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.85rem;white-space:nowrap}
.track-result{margin-top:12px;padding:12px;background:#fff;border-radius:8px;border:1px solid #e2e8f0;font-size:.88rem}
.track-result .track-status{font-weight:600;color:#1d4ed8;font-size:1rem}

/* 9. Sticky mobile buy bar */
.pm-sticky-buy{display:none;position:sticky;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e2e8f0;padding:10px 16px;z-index:10;box-shadow:0 -2px 8px rgba(0,0,0,.08);align-items:center;justify-content:space-between;gap:10px}
.pm-sticky-buy .sticky-price{font-size:1.1rem;font-weight:700;color:#0f172a}
.pm-sticky-buy .main-button{flex:1;max-width:200px}
@media(max-width:768px){.pm-sticky-buy{display:flex}}

/* 10. Search history */
.search-history{padding:8px 0;border-bottom:1px solid #e2e8f0;margin-bottom:4px}
.search-history-title{font-size:.75rem;color:#94a3b8;padding:0 12px 4px;display:flex;justify-content:space-between;align-items:center}
.search-history-title button{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:.72rem}
.search-history-title button:hover{color:#ef4444}
.search-history-item{padding:6px 12px;cursor:pointer;font-size:.87rem;color:#475569;display:flex;align-items:center;gap:6px}
.search-history-item:hover{background:#f1f5f9}
.search-history-item::before{content:"🕐";font-size:.7rem}

/* 11. Image gallery — just zoom overlay */
.image-zoom-overlay{position:fixed;inset:0;z-index:1300;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;cursor:zoom-out}
.image-zoom-overlay.active{display:flex}
.image-zoom-overlay img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.3)}

/* 12. FAQ section */
.faq-section{background:#f8fafc}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{background:#fff;border-radius:10px;margin-bottom:8px;overflow:hidden;border:1px solid #e2e8f0}
.faq-question{width:100%;background:none;border:none;padding:16px 20px;text-align:left;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:#0f172a;transition:.2s}
.faq-question:hover{background:#f1f5f9}
.faq-question .faq-arrow{transition:transform .3s;font-size:.8rem}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 20px}
.faq-item.open .faq-answer{max-height:400px;padding:0 20px 16px}
.faq-answer p{color:#475569;font-size:.9rem;line-height:1.6;margin:0}

/* 13. Buy in 1 click */
.buy-one-click-btn{background:none;border:1px solid #1d4ed8;color:#1d4ed8;padding:6px 0;border-radius:8px;cursor:pointer;font-size:.8rem;transition:.2s;white-space:nowrap;width:100%;text-align:center;margin-top:8px}
.buy-one-click-btn:hover{background:#eff6ff}
.one-click-overlay{position:fixed;inset:0;z-index:1200;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center}
.one-click-overlay.active{display:flex}
.one-click-modal{background:#fff;border-radius:12px;padding:28px;max-width:400px;width:90%;position:relative}
.one-click-modal h3{margin:0 0 4px}
.one-click-modal .oc-product{color:#64748b;font-size:.87rem;margin:0 0 16px}
.one-click-modal label{display:block;font-size:.9rem;font-weight:500;margin-bottom:12px}
.one-click-modal input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:.95rem;margin-top:4px;box-sizing:border-box}
.one-click-modal .main-button{width:100%;margin-top:8px}
.one-click-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.4rem;cursor:pointer}

/* 14. Volume discount badge */
.volume-badge{background:#ecfdf5;color:#065f46;border:1px solid #6ee7b7;padding:3px 8px;border-radius:4px;font-size:.72rem;font-weight:600;display:block;margin-top:6px;text-align:center;width:100%}
.pm-volume-badge{margin:8px 0;background:#ecfdf5;color:#065f46;border:1px solid #6ee7b7;padding:6px 12px;border-radius:6px;font-size:.82rem;font-weight:500}

/* 15. Print order */
.print-order-btn{background:none;border:1px solid #e2e8f0;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:.78rem;color:#475569;transition:.2s}
.print-order-btn:hover{border-color:#1d4ed8;color:#1d4ed8}

/* 16. Promo countdown timer */
.promo-timer{margin-top:18px}
.promo-timer-label{font-size:.85rem;opacity:.85;margin-bottom:8px;display:block}
.promo-timer-digits{display:flex;align-items:center;gap:6px}
.timer-block{display:flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.18);border-radius:8px;padding:6px 10px;min-width:48px}
.timer-block span{font-size:1.5rem;font-weight:700;line-height:1}
.timer-block small{font-size:.65rem;opacity:.8;margin-top:2px}
.timer-sep{font-size:1.4rem;font-weight:700;opacity:.6}

/* 17. Delivery cost calculator */
.delivery-cost-calc{margin-top:12px;padding:10px 14px;background:var(--gray-light);border-radius:10px;border:1px solid var(--gray-border)}
.delivery-cost-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem}
.delivery-cost-note{display:block;margin-top:4px;color:var(--gray-text);font-size:.75rem}



/* 19. Show more button animation */
.load-more-btn{position:relative;overflow:hidden}
.load-more-btn.loading::after{content:"";position:absolute;inset:0;background:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center}

/* Dark theme additions */
body.dark-theme .delivery-cost-calc{background:var(--bg2);border-color:var(--border)}
body.dark-theme .delivery-cost-note{color:var(--text2)}

body.dark-theme .timer-block{background:rgba(255,255,255,.1)}
@media print{body *{display:none!important}.print-order-area,.print-order-area *{display:block!important}.print-order-area{position:fixed;inset:0;z-index:9999;background:#fff;padding:40px;font-size:14px}}

/* 16. Dark theme */
body.dark-theme{--bg:#0f172a;--bg2:#1e293b;--text:#e2e8f0;--text2:#94a3b8;--border:#334155;--card:#1e293b;--primary:#3b82f6;background:var(--bg);color:var(--text)}

/* Header & nav */
body.dark-theme .site-header{background:var(--bg2);border-color:var(--border)}
body.dark-theme .search-block{background:var(--bg2)}
body.dark-theme .header-nav{background:var(--bg2);border-color:var(--border)}
body.dark-theme .search-box{background:var(--bg);box-shadow:inset 0 0 0 1px var(--border)}
body.dark-theme .search-box input{background:transparent;color:var(--text)}
body.dark-theme .search-suggestions{background:var(--card);border-color:var(--border)}
body.dark-theme .search-item{border-color:var(--border)}
body.dark-theme .search-item:hover{background:var(--bg)}
body.dark-theme .search-item strong{color:var(--text)}
body.dark-theme .phone-dropdown{background:var(--bg2);border-color:var(--border)}
body.dark-theme .language-button.active,body.dark-theme .language-button:hover{background:var(--bg);color:var(--text)}

/* Category nav buttons */
body.dark-theme .category-button{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .category-button.active,body.dark-theme .category-button:hover{background:var(--primary);color:#fff}

/* Hero section */
body.dark-theme .hero{background:var(--bg2)}
body.dark-theme .hero h1{color:var(--text)}
body.dark-theme .hero-panel-card,body.dark-theme .mini-card{background:var(--bg);color:var(--text)}

/* Trust & info cards */
body.dark-theme .trust-card{background:var(--card);color:var(--text)}
body.dark-theme .trust-card .info-icon{background:linear-gradient(135deg,rgba(96,165,250,0.22),rgba(59,130,246,0.35));color:#60a5fa}
body.dark-theme .reason-card{background:var(--card);color:var(--text)}
body.dark-theme .reason-card p{color:var(--text2)}

/* Section headings */
body.dark-theme .section-head h2{color:var(--text)}
body.dark-theme .section-label{color:var(--primary)}
body.dark-theme .breadcrumbs a{color:var(--text2)}

/* Category cards */
body.dark-theme .category-card{background:var(--card);border-color:var(--border)}
body.dark-theme .category-card:hover{border-color:var(--primary)}
body.dark-theme .category-card h3{color:var(--text)}
body.dark-theme .category-card p{color:var(--text2)}
body.dark-theme .category-card-icon{background:rgba(59,130,246,0.15);color:var(--primary)}
body.dark-theme .category-card-list span{background:rgba(59,130,246,0.15);color:var(--primary)}
body.dark-theme .category-card-media{background:var(--bg)}

/* Filters panel */
body.dark-theme .filters-panel{background:var(--bg2);color:var(--text);border-color:var(--border)}
body.dark-theme .filters-header h3{color:var(--text)}
body.dark-theme .filter-title{color:var(--text)}
body.dark-theme .filter-list label,body.dark-theme .radio-list label,body.dark-theme .brand-dropdown-list label{color:var(--text2)}
body.dark-theme .brand-search{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .brand-tag{background:var(--bg);color:var(--accent)}
body.dark-theme .brand-dropdown-list label:hover{background:var(--bg)}
body.dark-theme .close-filters{background:var(--bg);color:var(--text)}
body.dark-theme .price-inputs span{color:var(--text)}
body.dark-theme .price-inputs input{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .filter-group{border-color:var(--border)}

/* Catalog bar & sorting */
body.dark-theme .catalog-toolbar{background:var(--card);box-shadow:none}
body.dark-theme .sort-button{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .sort-button.active{background:var(--primary);color:#fff}
body.dark-theme .found-counter{color:var(--text)}

/* Product cards */
body.dark-theme .product-card{background:var(--card);border-color:var(--border);color:var(--text)}
body.dark-theme .product-title{color:var(--text)}
body.dark-theme .product-description,body.dark-theme .product-brand,body.dark-theme .product-unit{color:var(--text2)}
body.dark-theme .product-image{background:var(--bg);color:var(--text)}
body.dark-theme .product-image::after{border-color:var(--border);background:rgba(15,23,42,0.3)}
body.dark-theme .product-image img{background:transparent}
body.dark-theme .product-image-icon{background:rgba(59,130,246,0.15);color:var(--primary)}
body.dark-theme .product-image-caption p{color:var(--text)}
body.dark-theme .product-rating{color:var(--text)}
body.dark-theme .product-rating span:last-child{color:var(--text2)}
body.dark-theme .spec-label{color:var(--text2)}
body.dark-theme .spec-value{color:var(--text)}
body.dark-theme .current-price{color:var(--text)}
body.dark-theme .old-price{color:var(--text2)}
body.dark-theme .badge-out{color:var(--text2)}

/* Product specs dropdown */
body.dark-theme .product-specs-wrapper{border-color:var(--border)}
body.dark-theme .product-specs-toggle{background:var(--bg);color:var(--text)}
body.dark-theme .product-specs-toggle:hover{background:var(--bg2)}
body.dark-theme .specs-table tr:nth-child(even){background:var(--bg)}
body.dark-theme .specs-table td{color:var(--text);border-color:var(--border)}

/* Product quantity & buy */
body.dark-theme .product-quantity{border-color:var(--border)}
body.dark-theme .product-quantity button{background:var(--bg);color:var(--text)}
body.dark-theme .product-quantity input{color:var(--text)}

/* Reviews in cards */
body.dark-theme .review-header strong{color:var(--text)}
body.dark-theme .review-text{color:var(--text2)}
body.dark-theme .review-date{color:var(--text2)}
body.dark-theme .review-form{background:var(--bg);border-color:var(--border)}
body.dark-theme .review-form-title{color:var(--text)}
body.dark-theme .review-form .guest-input{background:var(--bg2);color:var(--text);border-color:var(--border)}
body.dark-theme .reviews-more-btn{background:var(--bg);border-color:var(--border);color:var(--primary)}

/* Cart & account sidebars */
body.dark-theme .cart-sidebar,body.dark-theme .account-sidebar{background:var(--bg2);color:var(--text)}
body.dark-theme .cart-footer{background:var(--bg2)}
body.dark-theme .guest-input,body.dark-theme #promoInput{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .account-tab.active{background:var(--bg);color:var(--text)}
body.dark-theme .secondary-button{background:var(--bg);color:var(--text);border-color:var(--border)}

/* Product modal */
body.dark-theme .product-modal-inner{background:var(--bg2);color:var(--text)}
body.dark-theme .product-modal-close{color:var(--text);background:rgba(255,255,255,0.1)}
body.dark-theme .pm-title{color:var(--text)}
body.dark-theme .pm-brand{color:var(--text2)}
body.dark-theme .pm-description{color:var(--text2)}
body.dark-theme .pm-stock.out-of-stock{color:var(--text2)}
body.dark-theme .pm-tab{color:var(--text2)}
body.dark-theme .pm-tab.active{color:var(--primary);border-color:var(--primary)}
body.dark-theme .pm-specs-table td{color:var(--text);border-color:var(--border)}
body.dark-theme .pm-specs-table tr:nth-child(even){background:var(--bg)}
body.dark-theme .pm-specs-table .spec-label{color:var(--text2)}
body.dark-theme .pm-specs-table .spec-value{color:var(--text)}
body.dark-theme .pm-share button{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .pm-sticky-buy{background:var(--bg2);border-color:var(--border)}
body.dark-theme .close-modal{color:var(--text)}

/* Promo & quick order */
body.dark-theme .promo-banner{background:var(--card);color:var(--text)}
body.dark-theme .promo-card-title{color:var(--text)}

/* Site blocks dark */
body.dark-theme .site-block{box-shadow:0 12px 32px rgba(0,0,0,0.3)}
body.dark-theme .site-block-btn{background:rgba(255,255,255,0.12)}
body.dark-theme .site-block-btn:hover{background:rgba(255,255,255,0.22)}
body.dark-theme .sb-timer-block{background:rgba(0,0,0,0.3)}

body.dark-theme .quick-order-section{background:var(--bg2)}
body.dark-theme .quick-order-wrap{background:var(--card)}
body.dark-theme .quick-order-text h2{color:var(--text)}
body.dark-theme .quick-order-text p{color:var(--text2)}
body.dark-theme .quick-order-form span{color:var(--text)}
body.dark-theme .quick-order-form input{background:var(--bg);color:var(--text);border-color:var(--border)}

/* FAQ */
body.dark-theme .faq-item{background:var(--card);border-color:var(--border)}
body.dark-theme .faq-question{color:var(--text)}
body.dark-theme .faq-answer p{color:var(--text2)}

/* Compare */
body.dark-theme .compare-modal,body.dark-theme .calc-modal,body.dark-theme .one-click-modal{background:var(--bg2);color:var(--text)}
body.dark-theme .calc-type-info{background:var(--bg);border-color:var(--border);color:var(--text-muted)}
body.dark-theme .calc-result{background:var(--bg);color:var(--text)}
body.dark-theme .calc-result strong{color:#60a5fa}
body.dark-theme .calc-formula{color:var(--text-muted)}
body.dark-theme .calc-reserve{color:#34d399}
body.dark-theme .compare-table th,body.dark-theme .compare-table td{border-color:var(--border)}
body.dark-theme .compare-table th{background:var(--bg)}
body.dark-theme .compare-panel{background:var(--bg2)}

/* Footer */
body.dark-theme .site-footer{background:var(--bg2);color:var(--text2)}

/* Misc elements */
body.dark-theme .skeleton-card{background:var(--card)}
body.dark-theme .skeleton-image,body.dark-theme .skeleton-line{background:linear-gradient(90deg,var(--bg) 25%,var(--bg2) 50%,var(--bg) 75%);background-size:400% 100%}
body.dark-theme .app-tag{background:var(--bg);color:var(--text2);border-color:var(--border)}
body.dark-theme .app-tag:hover,body.dark-theme .app-tag.active{background:rgba(59,130,246,0.15);border-color:var(--primary);color:var(--primary)}
body.dark-theme .track-result{background:var(--card);border-color:var(--border);color:var(--text)}

/* Dark toggle button */
.dark-toggle{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;padding:0;border-radius:12px;background:rgba(255,255,255,0.06);border:1.5px solid rgba(255,255,255,0.22);color:var(--white);cursor:pointer;font-size:1.15rem;transition:all .25s ease}
.dark-toggle:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.38)}
body.dark-theme .dark-toggle{background:rgba(255,255,255,0.06);border-color:var(--border);color:var(--text)}
body.dark-theme .dark-toggle:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.3)}

/* 17. Animated trust counters */
.trust-card strong{display:block}

/* 18. Cookie consent */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#1e293b;color:#e2e8f0;padding:16px 0;z-index:1300;transform:translateY(100%);transition:transform .3s}
.cookie-banner.visible{transform:translateY(0)}
.cookie-banner .container{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between}
.cookie-banner p{margin:0;font-size:.87rem;flex:1}
.cookie-banner .cookie-btns{display:flex;gap:8px}
.cookie-banner button{padding:8px 20px;border-radius:8px;border:none;cursor:pointer;font-size:.85rem;font-weight:500}
.cookie-accept{background:#3b82f6;color:#fff}
.cookie-decline{background:#334155;color:#e2e8f0}

/* 19. Application tags filter - reuse filter group styling */
.application-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.app-tag{padding:5px 10px;border-radius:16px;border:1px solid #cbd5e1;background:#fff;font-size:.78rem;cursor:pointer;transition:.2s;color:#475569}
.app-tag:hover,.app-tag.active{background:#eff6ff;border-color:#3b82f6;color:#1d4ed8}

/* 20. Floating chat button */
.float-chat{position:fixed;bottom:20px;right:20px;z-index:1050;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.float-chat-menu{display:none;flex-direction:column;gap:6px;margin-bottom:8px}
.float-chat-menu.open{display:flex}
.float-chat-link{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.15);text-decoration:none;color:#0f172a;font-size:.85rem;font-weight:500;transition:.2s;white-space:nowrap}
.float-chat-link:hover{transform:translateX(-4px);box-shadow:0 4px 16px rgba(0,0,0,.2)}
.float-chat-link .fc-icon{font-size:1.1rem}
.float-chat-btn{width:56px;height:56px;border-radius:50%;background:#1d4ed8;color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px rgba(29,78,216,.35);transition:.3s;display:flex;align-items:center;justify-content:center}
.float-chat-btn:hover{background:#1e40af;transform:scale(1.05)}
.float-chat-btn.open{background:#ef4444}
body.dark-theme .float-chat-link{background:var(--card);color:var(--text);box-shadow:0 2px 10px rgba(0,0,0,.3)}
.scroll-top-btn{bottom:140px}
@media(max-width:768px){.scroll-top-btn{bottom:148px;right:12px}.float-chat{right:12px;bottom:12px}}

/* ═══ Recently Viewed Section ═══ */
.recently-section { padding: 24px 0; }
.recently-title { font-size: 1.2rem; font-weight: 700; margin-bottom: 16px; color: var(--blue-dark); }
.recently-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.recently-item { cursor: pointer; text-align: center; padding: 12px 8px; border-radius: 12px; background: var(--white); border: 1px solid var(--gray-border); transition: box-shadow .2s, transform .15s; }
.recently-item:hover { box-shadow: var(--shadow-soft); transform: translateY(-2px); }
.recently-item img { width: 100%; height: 80px; object-fit: cover; border-radius: 8px; margin-bottom: 8px; }
.recently-item-placeholder { width: 100%; height: 80px; display: flex; align-items: center; justify-content: center; background: var(--gray-light); border-radius: 8px; margin-bottom: 8px; }
.recently-item-placeholder svg { width: 32px; height: 32px; fill: var(--gray-text); }
.recently-item p { font-size: .78rem; line-height: 1.3; color: var(--gray-text); margin: 0 0 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.recently-item span { font-size: .85rem; font-weight: 700; color: var(--blue-dark); }
@media (max-width: 767px) {
  .recently-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 420px) {
  .recently-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══ Install Banner ═══ */
.install-banner { position: fixed; bottom: 0; left: 0; right: 0; z-index: 2000; transform: translateY(100%); transition: transform .35s ease; }
.install-banner.visible { transform: translateY(0); }
.install-banner-inner { display: flex; align-items: center; gap: 16px; padding: 16px 24px; background: var(--blue-main); color: #fff; flex-wrap: wrap; }
.install-title { font-weight: 700; font-size: 1rem; }
.install-text { font-size: .85rem; opacity: .85; flex: 1; }
.install-actions { display: flex; gap: 10px; }
.install-btn.main-button { padding: 8px 20px; font-size: .85rem; }
.install-dismiss { background: transparent; border: 1px solid rgba(255,255,255,.4); color: #fff; padding: 8px 16px; border-radius: 8px; cursor: pointer; font-size: .85rem; }
.install-dismiss:hover { border-color: #fff; }

/* ═══ Checkout Disabled State ═══ */
.cart-order-button.checkout-disabled { opacity: .45; cursor: not-allowed; pointer-events: none; }

/* ═══ Loading State on Buttons ═══ */
.is-loading { position: relative; color: transparent !important; pointer-events: none; }
.is-loading::after { content: ''; position: absolute; top: 50%; left: 50%; width: 18px; height: 18px; margin: -9px 0 0 -9px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: spin .6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ═══ Dark theme additions for new components ═══ */
body.dark-theme .recently-item { background: var(--card); border-color: var(--border); }
body.dark-theme .recently-item:hover { border-color: var(--primary); }
body.dark-theme .recently-item p { color: var(--text2); }
body.dark-theme .recently-item span { color: var(--text); }
body.dark-theme .recently-title { color: var(--text); }
body.dark-theme .recently-item-placeholder { background: var(--border); }
body.dark-theme .install-banner-inner { background: #1e293b; }
body.dark-theme .cart-order-button.checkout-disabled { opacity: .3; }

/* ═══ Extended dark theme coverage ═══ */
/* Buttons & controls */
body.dark-theme .secondary-button:hover{background:var(--bg2);border-color:var(--border)}
body.dark-theme .compare-btn{color:var(--text2);border-color:var(--border)}
body.dark-theme .compare-btn:hover{color:var(--primary);border-color:var(--primary);background:rgba(59,130,246,0.1)}
body.dark-theme .print-order-btn{border-color:var(--border);color:var(--text2)}
body.dark-theme .print-order-btn:hover{border-color:var(--primary);color:var(--primary)}

/* Product modal */
body.dark-theme .pm-image{background:linear-gradient(180deg,var(--bg),var(--bg2))}
body.dark-theme .pm-image-placeholder{color:var(--primary)}
body.dark-theme .pm-image-placeholder p{color:var(--text2)}
body.dark-theme .pm-rating .meta{color:var(--text2)}
body.dark-theme .pm-unit{color:var(--text2)}
body.dark-theme .pm-reviews-empty{color:var(--text2)}
body.dark-theme .pm-similar{border-top-color:var(--border)}
body.dark-theme .pm-similar-card{background:var(--card);border-color:var(--border)}
body.dark-theme .pm-similar-card:hover{border-color:var(--primary)}
body.dark-theme .pm-similar-card .sim-name{color:var(--text2)}
body.dark-theme .pm-similar-card .sim-price{color:var(--primary)}
body.dark-theme .pm-similar-card .sim-placeholder{background:var(--border);color:var(--text2)}

/* Bundles dark theme */
body.dark-theme .pm-bundles{border-top-color:var(--border)}
body.dark-theme .pm-bundles h3{color:var(--text)}
body.dark-theme .bundle-card{background:linear-gradient(135deg,var(--card) 0%,var(--bg2) 100%);border-color:var(--border)}
body.dark-theme .bundle-card:hover{border-color:var(--primary);box-shadow:0 4px 16px rgba(59,130,246,.15)}
body.dark-theme .bundle-product img{border-color:var(--border);background:var(--bg)}
body.dark-theme .bundle-product span{color:var(--text)}
body.dark-theme .bundle-product small{color:var(--text2)}
body.dark-theme .bundle-noimg{background:var(--border)}
body.dark-theme .bundle-price{border-top-color:var(--border)}
body.dark-theme .bundle-old{color:var(--text2)}
body.dark-theme .bundle-new{background:rgba(22,163,74,.15);color:#4ade80}

/* Calculator & forms */
body.dark-theme .calc-modal p{color:var(--text2)}
body.dark-theme .calc-form input,body.dark-theme .calc-form select{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .notify-stock-form input{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .one-click-modal .oc-product{color:var(--text2)}
body.dark-theme .one-click-modal input{background:var(--bg);color:var(--text);border-color:var(--border)}

/* Track & search history */
body.dark-theme .track-section{background:var(--card)}
body.dark-theme .track-form input{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .search-history{border-bottom-color:var(--border)}
body.dark-theme .search-history-title{color:var(--text2)}
body.dark-theme .search-history-title button{color:var(--text2)}
body.dark-theme .search-history-item{color:var(--text2)}
body.dark-theme .search-history-item:hover{background:var(--bg)}

/* FAQ section */
body.dark-theme .faq-section{background:transparent}
body.dark-theme .faq-question:hover{background:var(--bg)}

/* Navigation */
body.dark-theme .breadcrumbs{color:var(--text2)}
body.dark-theme .breadcrumb-separator{color:var(--border)}

/* Sidebar inputs */
body.dark-theme .account-field input{background:var(--bg);color:var(--text);border-color:var(--border)}

/* Payment & checkout in dark */
body.dark-theme .payment-option{background:rgba(255,255,255,0.04);color:var(--text)}
body.dark-theme .payment-title{color:var(--text)}
body.dark-theme .payment-note{color:var(--text2)}

/* Header button borders for dark theme */
body.dark-theme .phone-item,body.dark-theme .account-button,body.dark-theme .cart-button{background:rgba(255,255,255,0.06);border-color:var(--border)}
body.dark-theme .phone-item:hover,body.dark-theme .account-button:hover,body.dark-theme .cart-button:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.3)}
body.dark-theme .language-switcher{background:rgba(255,255,255,0.06);border-color:var(--border)}

/* Cookie consent dark */
body.dark-theme .cookie-banner{background:var(--bg2)}

/* Trust strip dark */
body.dark-theme .trust-strip{background:transparent}

/* Delivery section dark */
body.dark-theme .delivery-section{background:rgba(255,255,255,0.04)}
body.dark-theme .delivery-option{background:rgba(255,255,255,0.04);color:var(--text)}
body.dark-theme .delivery-option:hover{background:rgba(255,255,255,0.08)}
body.dark-theme .delivery-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='2' fill='none'/%3E%3C/svg%3E")}
body.dark-theme .delivery-select option{background:var(--bg2);color:var(--text)}

/* ═══ White areas fix ═══ */
body.dark-theme .catalog-toolbar{background:var(--card);box-shadow:none}
body.dark-theme .secondary-button,body.dark-theme .filter-toggle{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .secondary-button:hover,body.dark-theme .filter-toggle:hover{background:var(--bg2)}
body.dark-theme .promo-link{background:var(--card);color:var(--orange-cta);border:1px solid var(--border)}
body.dark-theme .promo-link:hover{background:var(--bg)}
body.dark-theme .promo-card{background:var(--card);box-shadow:none;border:1px solid var(--border)}
body.dark-theme .promo-card .current-price{color:var(--text)}
body.dark-theme .promo-card .old-price{color:var(--text2)}
body.dark-theme .promo-card .product-unit{color:var(--text2)}
body.dark-theme .empty-box{background:var(--card);box-shadow:none;color:var(--text)}
body.dark-theme .compare-chip{background:var(--bg);border-color:var(--border);color:var(--text)}
body.dark-theme .compare-chip button{color:#f87171}
body.dark-theme .notify-stock-btn{background:rgba(251,191,36,0.15);border-color:rgba(251,191,36,0.4);color:#fbbf24}
body.dark-theme .notify-stock-btn:hover{background:rgba(251,191,36,0.25)}
body.dark-theme .calc-trigger{background:rgba(34,197,94,0.1);border-color:rgba(34,197,94,0.3);color:#4ade80}
body.dark-theme .calc-trigger:hover{background:rgba(34,197,94,0.2)}
body.dark-theme .volume-badge{background:rgba(16,185,129,0.1);border-color:rgba(16,185,129,0.3);color:#34d399}

/* ═══════════════════════════════════════════════════
   20 IMPROVEMENTS — CSS
   ═══════════════════════════════════════════════════ */

/* ─── #2 Mobile bottom navigation ─── */
.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1100;background:var(--white);border-top:1px solid var(--border);padding:6px 0 env(safe-area-inset-bottom,4px);box-shadow:0 -2px 12px rgba(0,0,0,.08)}
.mobile-bottom-nav .nav-items{display:flex;justify-content:space-around;align-items:center}
.mobile-bottom-nav .nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.65rem;color:var(--text2);text-decoration:none;padding:4px 8px;border:none;background:none;cursor:pointer;position:relative;font-family:inherit}
.mobile-bottom-nav .nav-item.active,.mobile-bottom-nav .nav-item:hover{color:var(--primary)}
.mobile-bottom-nav .nav-item svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.mobile-bottom-nav .nav-badge{position:absolute;top:0;right:2px;min-width:16px;height:16px;border-radius:8px;background:var(--orange-cta);color:#fff;font-size:.6rem;display:flex;align-items:center;justify-content:center;padding:0 4px;font-weight:700}
body.dark-theme .mobile-bottom-nav{background:var(--bg2);border-color:var(--border)}
@media(max-width:768px){
  .mobile-bottom-nav{display:block}
  body{padding-bottom:64px}
  .cart-sidebar,.account-sidebar{bottom:64px;height:auto}
  .float-chat{bottom:76px}
  .scroll-top-btn.visible{bottom:76px}
  .compare-panel{bottom:64px}
}

/* ─── #3 Empty states ─── */
.cart-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center;color:var(--text2)}
.cart-empty-state svg{width:64px;height:64px;stroke:var(--text2);fill:none;stroke-width:1.2;opacity:.5}
.cart-empty-state h4{font-size:1.1rem;color:var(--text);margin:0}
.cart-empty-state p{margin:0;font-size:.9rem}
.cart-empty-state .main-button{margin-top:8px;padding:10px 24px;font-size:.85rem}

/* ─── #4 Skeleton loading (already exists, enhance with shimmer) ─── */
@keyframes skeleton-shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton-card{border-radius:24px;background:var(--blue-pale);overflow:hidden;padding:0}
.skeleton-image,.skeleton-line{background:linear-gradient(90deg,rgba(0,0,0,.04) 25%,rgba(0,0,0,.08) 50%,rgba(0,0,0,.04) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.5s ease infinite}
body.dark-theme .skeleton-card{background:var(--card)}
body.dark-theme .skeleton-image,body.dark-theme .skeleton-line{background:linear-gradient(90deg,rgba(255,255,255,.03) 25%,rgba(255,255,255,.07) 50%,rgba(255,255,255,.03) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.5s ease infinite}

/* ─── #5 Review star filter ─── */
.review-star-filter{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.review-star-filter button{padding:4px 10px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:.8rem;cursor:pointer;transition:all .2s}
.review-star-filter button.active{background:var(--primary);color:#fff;border-color:var(--primary)}
body.dark-theme .review-star-filter button{border-color:var(--border);color:var(--text)}
body.dark-theme .review-star-filter button.active{background:var(--primary);color:#fff}

/* ─── #6 Add-to-cart fly animation ─── */
@keyframes fly-to-cart{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(.3) translateY(-80px)}}
.fly-item{position:fixed;width:50px;height:50px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;z-index:9999;pointer-events:none;animation:fly-to-cart .6s ease-in-out forwards}
@keyframes cart-bounce{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}
.cart-count.bounce{animation:cart-bounce .3s ease}

/* ─── #7 Bonus program UI ─── */
.bonus-block{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;padding:16px;margin-bottom:16px}
.bonus-block h4{margin:0 0 4px;font-size:.95rem;color:#92400e}
.bonus-block .bonus-amount{font-size:1.6rem;font-weight:700;color:#d97706}
.bonus-block p{margin:4px 0 0;font-size:.78rem;color:#92400e;opacity:.8}
body.dark-theme .bonus-block{background:linear-gradient(135deg,rgba(251,191,36,.15),rgba(245,158,11,.1));border:1px solid rgba(251,191,36,.25)}
body.dark-theme .bonus-block h4{color:#fbbf24}
body.dark-theme .bonus-block .bonus-amount{color:#fbbf24}
body.dark-theme .bonus-block p{color:#fcd34d}

/* ─── #10 Frequently bought together ─── */
.fbt-section{margin-top:20px;border-top:1px solid var(--border);padding-top:16px}
.fbt-section h4{margin:0 0 10px;font-size:.95rem}
.fbt-items{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px}
.fbt-item{flex:0 0 140px;text-align:center;cursor:pointer;border-radius:12px;border:1px solid var(--border);padding:8px;transition:border-color .2s}
.fbt-item:hover{border-color:var(--primary)}
.fbt-item img{width:100%;height:80px;object-fit:cover;border-radius:8px}
.fbt-item p{margin:6px 0 2px;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fbt-item .fbt-price{font-weight:700;color:var(--primary);font-size:.8rem}
body.dark-theme .fbt-item{border-color:var(--border);background:var(--bg)}

/* ─── #1 Similar products ─── */
.similar-section{margin-top:20px;border-top:1px solid var(--border);padding-top:16px}
.similar-section h4{margin:0 0 10px;font-size:.95rem}
.similar-items{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px}
.similar-item{flex:0 0 150px;text-align:center;cursor:pointer;border-radius:12px;border:1px solid var(--border);padding:8px;transition:border-color .2s}
.similar-item:hover{border-color:var(--primary)}
.similar-item img{width:100%;height:90px;object-fit:cover;border-radius:8px}
.similar-item .similar-no-img{width:100%;height:90px;border-radius:8px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:.7rem}
.similar-item p{margin:6px 0 2px;font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.similar-item .similar-price{font-weight:700;color:var(--primary);font-size:.8rem}
body.dark-theme .similar-item{border-color:var(--border);background:var(--bg)}
body.dark-theme .similar-item .similar-no-img{background:var(--card)}

/* ─── #12 Price history ─── */
.price-history-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text2);font-size:.75rem;cursor:pointer;margin-top:4px}
.price-history-btn:hover{border-color:var(--primary);color:var(--primary)}
.price-chart-wrap{margin-top:8px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--blue-pale)}
.price-chart-wrap canvas{width:100%!important;height:120px!important}
body.dark-theme .price-chart-wrap{background:var(--bg);border-color:var(--border)}

/* ─── #13/#14 Dynamic meta + Schema — no CSS needed ─── */

/* ─── #15 404 page ─── */
.page-404{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px 20px;gap:16px}
.page-404 h1{font-size:5rem;font-weight:900;color:var(--primary);margin:0;line-height:1}
.page-404 h2{font-size:1.4rem;margin:0;color:var(--text)}
.page-404 p{color:var(--text2);max-width:400px;margin:0}
.page-404 .main-button{margin-top:8px}
body.dark-theme .page-404 h1{color:var(--primary)}

/* ─── #17 Blur-up image placeholder ─── */
.product-image img{transition:opacity .3s ease, transform 0.35s ease}
.product-image img.loading{opacity:0}
.product-image .img-placeholder{position:absolute;inset:0;background:var(--blue-pale);display:flex;align-items:center;justify-content:center}
.product-image .img-placeholder::after{content:'';width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
body.dark-theme .product-image .img-placeholder{background:var(--card)}

/* ─── #8 Order status notifications indicator ─── */
.notification-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:600}
.notification-badge.success{background:rgba(34,197,94,.1);color:#22c55e}
.notification-badge.info{background:rgba(59,130,246,.1);color:#3b82f6}

/* ─── #11 Returns/RMA ─── */
.return-form{padding:16px;border:1px solid var(--border);border-radius:16px;margin-top:12px}
.return-form label{display:block;margin-bottom:10px;font-size:.85rem}
.return-form select,.return-form textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:10px;font-size:.85rem;background:var(--white);color:var(--text);font-family:inherit}
.return-form textarea{resize:vertical;min-height:60px}
.return-status{padding:12px;border-radius:12px;background:var(--blue-pale);margin-top:8px}
body.dark-theme .return-form{border-color:var(--border)}
body.dark-theme .return-form select,body.dark-theme .return-form textarea{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .return-status{background:var(--card)}

/* ─── #18 Admin pagination — in admin.css ─── */

/* ─── #19 Low-stock alert badge ─── */
.low-stock-alert{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;background:rgba(239,68,68,.1);color:#ef4444;font-size:.75rem;font-weight:600}

/* ─── #20 Order notes ─── */
.order-notes-section{margin-top:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:rgba(59,130,246,.04)}
.order-notes-section h5{margin:0 0 8px;font-size:.85rem;color:var(--primary)}
.order-note{padding:6px 0;border-bottom:1px solid var(--border);font-size:.82rem}
.order-note:last-child{border-bottom:none}
.order-note .note-meta{font-size:.7rem;color:var(--text2);margin-top:2px}

/* ═══════════════════════════════════════════════════════════
   Phase 22 — Dark theme color fixes, mobile review redesign,
   edge/border alignment
   ═══════════════════════════════════════════════════════════ */

/* ─── Dark theme: Review items ─── */
body.dark-theme .review-item{background:rgba(255,255,255,0.06);border:1px solid var(--border)}
body.dark-theme .review-header strong{color:#f1f5f9}
body.dark-theme .review-text{color:#cbd5e1}
body.dark-theme .review-date{color:#64748b}
body.dark-theme .reviews-empty{color:var(--text2)}
body.dark-theme .reviews-toggle-btn{border-color:var(--border);color:var(--primary);background:transparent}
body.dark-theme .reviews-toggle-btn:hover{background:rgba(59,130,246,0.1)}
body.dark-theme .reviews-more-btn{background:rgba(255,255,255,0.06);border-color:var(--border);color:var(--primary)}
body.dark-theme .reviews-more-btn:hover{background:rgba(255,255,255,0.1)}

/* ─── Dark theme: Review form ─── */
body.dark-theme .review-form{background:rgba(255,255,255,0.04);border-color:var(--border)}
body.dark-theme .review-form-title{color:#f1f5f9}
body.dark-theme .review-form .guest-input{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .review-form .guest-input::placeholder{color:#64748b}
body.dark-theme .review-rating-select{color:var(--text2)}
body.dark-theme .review-star-label span{border-color:var(--border);color:var(--text2)}
body.dark-theme .review-star-label:hover span{background:rgba(59,130,246,0.15)}
body.dark-theme .review-star-label input:checked + span{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ─── Dark theme: Prices & units — brighter ─── */
body.dark-theme .pm-prices .current-price{color:#f8fafc;font-weight:700}
body.dark-theme .pm-unit{color:#94a3b8}
body.dark-theme .pm-sticky-buy{background:var(--bg2);border-color:var(--border)}
body.dark-theme .pm-sticky-buy .sticky-price{color:#f8fafc}

/* ─── Dark theme: Delivery tags ─── */
body.dark-theme .pm-delivery-tag{background:rgba(59,130,246,0.12);color:#93c5fd;border:1px solid rgba(59,130,246,0.2)}
body.dark-theme .pm-delivery-info{border-top-color:var(--border)}

/* ─── Dark theme: Share buttons ─── */
body.dark-theme .pm-share button{background:rgba(255,255,255,0.06);color:var(--text);border-color:var(--border)}
body.dark-theme .pm-share button:hover{background:rgba(59,130,246,0.12);color:var(--primary);border-color:var(--primary)}

/* ─── Dark theme: Calculator trigger ─── */
body.dark-theme .calc-trigger{background:rgba(34,197,94,0.1);border-color:rgba(34,197,94,0.3);color:#4ade80}

/* ─── Dark theme: FBT section ─── */
body.dark-theme .fbt-section{border-top-color:var(--border)}
body.dark-theme .fbt-section h4{color:var(--text)}
body.dark-theme .fbt-item{border-color:var(--border);background:rgba(255,255,255,0.04)}
body.dark-theme .fbt-item:hover{border-color:var(--primary)}
body.dark-theme .fbt-item p{color:var(--text2)}
body.dark-theme .fbt-item .fbt-price{color:#60a5fa}

/* ─── Dark theme: Similar products ─── */
body.dark-theme .similar-section{border-top-color:var(--border)}
body.dark-theme .similar-section h4{color:var(--text)}
body.dark-theme .similar-item p{color:var(--text2)}
body.dark-theme .similar-item .similar-price{color:#60a5fa}

/* ─── Dark theme: Tabs styling ─── */
body.dark-theme .pm-tabs{border-bottom-color:var(--border)}
body.dark-theme .pm-tab{color:var(--text2)}
body.dark-theme .pm-tab:hover{color:var(--text)}
body.dark-theme .pm-tab.active{color:#f8fafc;border-bottom-color:var(--primary)}

/* ─── Dark theme: Reviews section container borders ─── */
body.dark-theme .reviews-section{border-top-color:var(--border)}

/* ─── Dark theme: Product card prices (catalog) ─── */
body.dark-theme .product-prices .current-price{color:#f1f5f9}
body.dark-theme .product-unit{color:#94a3b8}

/* ─── Dark theme: Notify stock button ─── */
body.dark-theme .notify-stock-form input{background:var(--bg);color:var(--text);border-color:var(--border)}
body.dark-theme .notify-stock-form button{background:var(--primary);color:#fff}

/* ─── Dark theme: Price history ─── */
body.dark-theme .price-history-btn{color:var(--text2);border-color:var(--border)}
body.dark-theme .price-history-btn:hover{color:var(--primary);border-color:var(--primary)}

/* ─── Dark theme: Order notes ─── */
body.dark-theme .order-notes-section{background:rgba(59,130,246,0.06);border-color:var(--border)}
body.dark-theme .order-note{border-bottom-color:var(--border);color:var(--text)}

/* ─── Mobile review section redesign ─── */
@media(max-width:768px){
  .reviews-list{gap:12px}

  .review-item{
    padding:14px 16px;
    border-radius:14px;
    border:1px solid var(--gray-border);
    background:#f8fafc;
    box-shadow:0 1px 3px rgba(0,0,0,0.04)
  }

  .review-header{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    font-size:0.85rem;
    margin-bottom:6px
  }

  .review-header strong{
    font-size:0.9rem
  }

  .review-stars{
    font-size:0.85rem;
    letter-spacing:1px
  }

  .review-date{
    font-size:0.75rem;
    color:#8a95a3;
    width:100%;
    margin-left:0;
    margin-top:2px
  }

  .review-text{
    font-size:0.88rem;
    line-height:1.6;
    margin:8px 0 0;
    color:#334155
  }

  .review-star-filter{
    gap:8px;
    margin-bottom:14px;
    padding-bottom:14px;
    border-bottom:1px solid var(--gray-border);
    overflow-x:auto;
    flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch
  }

  .review-star-filter button{
    padding:6px 14px;
    border-radius:16px;
    font-size:0.82rem;
    white-space:nowrap;
    flex-shrink:0
  }

  .review-form{
    padding:16px;
    border-radius:16px;
    margin-top:4px
  }

  .review-form-title{
    font-size:0.92rem;
    margin-bottom:4px
  }

  .review-form .guest-input{
    padding:10px 14px;
    border-radius:10px;
    font-size:0.88rem
  }

  .review-rating-select{
    font-size:0.85rem;
    gap:8px
  }

  .review-star-label span{
    padding:6px 10px;
    border-radius:8px;
    font-size:0.85rem
  }

  .reviews-section{
    gap:14px;
    padding-top:14px
  }

  /* Dark theme mobile review overrides */
  body.dark-theme .review-item{
    background:rgba(255,255,255,0.05);
    border-color:var(--border);
    box-shadow:0 1px 3px rgba(0,0,0,0.2)
  }

  body.dark-theme .review-text{
    color:#cbd5e1
  }

  body.dark-theme .review-date{
    color:#64748b
  }

  body.dark-theme .review-star-filter{
    border-bottom-color:var(--border)
  }
}

/* ─── Edge/border alignment fixes ─── */
/* Modal edge consistency */
.product-modal-inner{
  scrollbar-width:thin;
  scrollbar-color:rgba(0,0,0,0.15) transparent
}

.product-modal-inner::-webkit-scrollbar{width:6px}
.product-modal-inner::-webkit-scrollbar-track{background:transparent}
.product-modal-inner::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.15);border-radius:3px}
body.dark-theme .product-modal-inner::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15)}

/* Ensure tab content has consistent padding */
.pm-tab-content{padding:24px 32px}

/* FBT/Similar sections inside modal — consistent edges */
.fbt-section,.similar-section{margin-left:0;margin-right:0;padding-left:0;padding-right:0}

@media(max-width:768px){
  .pm-tab-content{padding:16px 20px}

  /* Sticky buy bar alignment */
  .pm-sticky-buy{
    padding:10px 20px;
    border-radius:0;
    margin:0 -0px
  }

  /* FBT items scroll properly on mobile */
  .fbt-items,.similar-items{
    margin:0 -4px;
    padding:0 4px 8px
  }

  /* Cart sidebar alignment */
  .cart-sidebar{border-radius:0}
  .account-sidebar{border-radius:0}

  /* Delivery tags wrap nicely */
  .pm-delivery-info{
    gap:8px
  }

  .pm-delivery-tag{
    font-size:0.75rem;
    padding:5px 10px
  }
}

/* ─── Focus-visible keyboard navigation ─── */
:focus-visible {
  outline: 3px solid var(--blue-light);
  outline-offset: 2px;
}
button:focus-visible { outline-offset: 2px; }
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 0;
}
.sort-button:focus-visible { outline-offset: -2px; }
.scroll-top-btn:focus-visible { outline: 2px solid #93c5fd; outline-offset: 2px; }
