/**
 * Chisto — единая система кнопок.
 * Базовый класс: .btn (+ модификаторы через --).
 * Подключать после global.css (токены :root).
 * Отключить подмену Bricks-ленты: не относится к кнопкам.
 */

/* —— База: .btn и все legacy *-btn (кроме счётчиков ± и icon-only фильтров) —— */
.btn,
a.btn,
button.btn,
.chisto-wtc-btn,
.chisto-wkl-btn,
.chisto-sut-btn,
.chisto-twk-btn,
.chisto-tro-btn,
.chisto-thr-btn,
.chisto-sfm-btn,
.chisto-stu-btn,
.chisto-sdv-btn,
.chisto-sch-btn,
.chisto-rrg-btn,
.chisto-vac-btn,
.chisto-urg-btn,
.chisto-rvw-btn,
.chisto-fld-ref .fld-btn,
.chisto-osv-ref .chisto-osv-btn,
.chisto-mtc-ref .chisto-mtc-btn,
.chisto-lfc-ref .chisto-lfc-btn,
.chisto-fir-ref .fir-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 15px 34px;
  border-radius: var(--r-sm);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.2;
  text-decoration: none;
  transition: var(--tr);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  cursor: pointer;
  font-family: var(--font);
  border: 2px solid transparent;
  box-sizing: border-box;
}

.btn::after,
a.btn::after,
button.btn::after,
.chisto-wtc-btn::after,
.chisto-wkl-btn::after,
.chisto-sut-btn::after,
.chisto-twk-btn::after,
.chisto-tro-btn::after,
.chisto-thr-btn::after,
.chisto-sfm-btn::after,
.chisto-stu-btn::after,
.chisto-sdv-btn::after,
.chisto-sch-btn::after,
.chisto-rrg-btn::after,
.chisto-vac-btn::after,
.chisto-urg-btn::after,
.chisto-rvw-btn::after,
.chisto-fld-ref .fld-btn::after,
.chisto-osv-ref .chisto-osv-btn::after,
.chisto-mtc-ref .chisto-mtc-btn::after,
.chisto-lfc-ref .chisto-lfc-btn::after,
.chisto-fir-ref .fir-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.1);
  opacity: 0;
  transition: opacity var(--tr);
  pointer-events: none;
}

.btn:hover::after,
a.btn:hover::after,
button.btn:hover::after,
.chisto-wtc-btn:hover::after,
.chisto-wkl-btn:hover::after,
.chisto-sut-btn:hover::after,
.chisto-twk-btn:hover::after,
.chisto-tro-btn:hover::after,
.chisto-thr-btn:hover::after,
.chisto-sfm-btn:hover::after,
.chisto-stu-btn:hover::after,
.chisto-sdv-btn:hover::after,
.chisto-sch-btn:hover::after,
.chisto-rrg-btn:hover::after,
.chisto-vac-btn:hover::after,
.chisto-urg-btn:hover::after,
.chisto-rvw-btn:hover::after,
.chisto-fld-ref .fld-btn:hover::after,
.chisto-osv-ref .chisto-osv-btn:hover::after,
.chisto-mtc-ref .chisto-mtc-btn:hover::after,
.chisto-lfc-ref .chisto-lfc-btn:hover::after,
.chisto-fir-ref .fir-btn:hover::after {
  opacity: 1;
}

.btn:hover,
a.btn:hover,
button.btn:hover,
.chisto-wtc-btn:hover,
.chisto-wkl-btn:hover,
.chisto-sut-btn:hover,
.chisto-twk-btn:hover,
.chisto-tro-btn:hover,
.chisto-thr-btn:hover,
.chisto-sfm-btn:hover,
.chisto-stu-btn:hover,
.chisto-sdv-btn:hover,
.chisto-sch-btn:hover,
.chisto-rrg-btn:hover,
.chisto-vac-btn:hover,
.chisto-urg-btn:hover,
.chisto-rvw-btn:hover,
.chisto-fld-ref .fld-btn:hover,
.chisto-osv-ref .chisto-osv-btn:hover,
.chisto-mtc-ref .chisto-mtc-btn:hover,
.chisto-lfc-ref .chisto-lfc-btn:hover,
.chisto-fir-ref .fir-btn:hover {
  transform: translateY(-2px);
}

.btn:active,
a.btn:active,
button.btn:active,
.chisto-wtc-btn:active,
.chisto-wkl-btn:active,
.chisto-sut-btn:active,
.chisto-twk-btn:active,
.chisto-tro-btn:active,
.chisto-thr-btn:active,
.chisto-sfm-btn:active,
.chisto-stu-btn:active,
.chisto-sdv-btn:active,
.chisto-sch-btn:active,
.chisto-rrg-btn:active,
.chisto-vac-btn:active,
.chisto-urg-btn:active,
.chisto-rvw-btn:active,
.chisto-fld-ref .fld-btn:active,
.chisto-osv-ref .chisto-osv-btn:active,
.chisto-mtc-ref .chisto-mtc-btn:active,
.chisto-lfc-ref .chisto-lfc-btn:active,
.chisto-fir-ref .fir-btn:active {
  transform: none;
}

.btn:focus-visible,
a.btn:focus-visible,
button.btn:focus-visible,
.chisto-wtc-btn:focus-visible,
.chisto-wkl-btn:focus-visible,
.chisto-sut-btn:focus-visible,
.chisto-twk-btn:focus-visible,
.chisto-tro-btn:focus-visible,
.chisto-thr-btn:focus-visible,
.chisto-sfm-btn:focus-visible,
.chisto-stu-btn:focus-visible,
.chisto-sdv-btn:focus-visible,
.chisto-sch-btn:focus-visible,
.chisto-rrg-btn:focus-visible,
.chisto-vac-btn:focus-visible,
.chisto-urg-btn:focus-visible,
.chisto-rvw-btn:focus-visible,
.chisto-fld-ref .fld-btn:focus-visible,
.chisto-osv-ref .chisto-osv-btn:focus-visible,
.chisto-mtc-ref .chisto-mtc-btn:focus-visible,
.chisto-lfc-ref .chisto-lfc-btn:focus-visible,
.chisto-fir-ref .fir-btn:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

/* Primary (золото) */
.btn--gold,
.chisto-wtc-btn--gold,
.chisto-wkl-btn--gold,
.chisto-sut-btn--gold,
.chisto-twk-btn--gold,
.chisto-tro-btn--gold,
.chisto-thr-btn--gold,
.chisto-sfm-btn--gold,
.chisto-stu-btn--gold,
.chisto-sdv-btn--gold,
.chisto-sch-btn--gold,
.chisto-rrg-btn--gold,
.chisto-vac-btn--gold,
.chisto-rvw-btn--gold,
.chisto-fld-ref .fld-btn--gold,
.chisto-osv-ref .chisto-osv-btn--gold,
.chisto-mtc-ref .chisto-mtc-btn--gold,
.chisto-lfc-ref .chisto-lfc-btn--gold,
.chisto-fir-ref .fir-btn--gold {
  background: linear-gradient(135deg, var(--gold), #d49406);
  color: var(--navy);
  box-shadow: var(--sh-gold);
}

.btn--gold:hover,
.chisto-wtc-btn--gold:hover,
.chisto-wkl-btn--gold:hover,
.chisto-sut-btn--gold:hover,
.chisto-twk-btn--gold:hover,
.chisto-tro-btn--gold:hover,
.chisto-thr-btn--gold:hover,
.chisto-sfm-btn--gold:hover,
.chisto-stu-btn--gold:hover,
.chisto-sdv-btn--gold:hover,
.chisto-sch-btn--gold:hover,
.chisto-rrg-btn--gold:hover,
.chisto-vac-btn--gold:hover,
.chisto-rvw-btn--gold:hover,
.chisto-fld-ref .fld-btn--gold:hover,
.chisto-osv-ref .chisto-osv-btn--gold:hover,
.chisto-mtc-ref .chisto-mtc-btn--gold:hover,
.chisto-lfc-ref .chisto-lfc-btn--gold:hover,
.chisto-fir-ref .fir-btn--gold:hover {
  box-shadow: var(--sh-md);
}

/* Тёмно-синий */
.btn--navy,
.chisto-wtc-btn--navy,
.chisto-tro-btn--navy,
.chisto-thr-btn--navy,
.chisto-stu-btn--navy,
.chisto-rvw-btn--navy,
.chisto-fld-ref .fld-btn--navy,
.chisto-osv-ref .chisto-osv-btn--navy,
.chisto-fir-ref .fir-btn--navy,
.chisto-rrg-btn--navy {
  background: var(--navy);
  color: var(--white);
  box-shadow: var(--sh-md);
}

.btn--navy:hover,
.chisto-wtc-btn--navy:hover,
.chisto-tro-btn--navy:hover,
.chisto-thr-btn--navy:hover,
.chisto-stu-btn--navy:hover,
.chisto-rvw-btn--navy:hover,
.chisto-fld-ref .fld-btn--navy:hover,
.chisto-osv-ref .chisto-osv-btn--navy:hover,
.chisto-fir-ref .fir-btn--navy:hover,
.chisto-rrg-btn--navy:hover {
  background: var(--navy-l);
  color: var(--white);
}

/* Обводка на светлом фоне */
.btn--ol {
  background: transparent;
  color: var(--navy);
  border-color: var(--navy);
}

.btn--ol:hover {
  background: var(--navy);
  color: var(--white);
}

/* Обводка на светлой панели (текст/бордер тёмные) */
.btn--outline-dark {
  background: transparent;
  color: var(--navy);
  border-color: var(--g200);
}

.btn--outline-dark:hover {
  border-color: var(--navy);
  background: rgba(13, 51, 96, 0.04);
  color: var(--navy);
}

/* Контур на тёмном / герой */
.btn--outline-white,
.chisto-wtc-btn--outline-white,
.chisto-wkl-btn--outline-white,
.chisto-sut-btn--outline-white,
.chisto-twk-btn--outline-white,
.chisto-tro-btn--outline-white,
.chisto-thr-btn--outline-white,
.chisto-sfm-btn--outline-white,
.chisto-stu-btn--outline-white,
.chisto-sdv-btn--outline-white,
.chisto-sch-btn--outline-white,
.chisto-vac-btn--outline-white,
.chisto-osv-ref .chisto-osv-btn--outline,
.chisto-mtc-ref .chisto-mtc-btn--outline,
.chisto-lfc-ref .chisto-lfc-btn--outline,
.chisto-fld-ref .fld-btn--outline,
.chisto-fir-ref .fir-btn--outline {
  background: transparent;
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.4);
}

.btn--outline-white:hover,
.chisto-wtc-btn--outline-white:hover,
.chisto-wkl-btn--outline-white:hover,
.chisto-sut-btn--outline-white:hover,
.chisto-twk-btn--outline-white:hover,
.chisto-tro-btn--outline-white:hover,
.chisto-thr-btn--outline-white:hover,
.chisto-sfm-btn--outline-white:hover,
.chisto-stu-btn--outline-white:hover,
.chisto-sdv-btn--outline-white:hover,
.chisto-sch-btn--outline-white:hover,
.chisto-vac-btn--outline-white:hover,
.chisto-osv-ref .chisto-osv-btn--outline:hover,
.chisto-mtc-ref .chisto-mtc-btn--outline:hover,
.chisto-lfc-ref .chisto-lfc-btn--outline:hover,
.chisto-fld-ref .fld-btn--outline:hover,
.chisto-fir-ref .fir-btn--outline:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.75);
  color: var(--white);
}

/* B2B блок на главной: светлая обводка */
.btn--ol-w {
  background: transparent;
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.5);
}

.btn--ol-w:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.9);
  color: var(--white);
}

/* Полупрозрачная на тёмном */
.btn--ghost {
  background: rgba(255, 255, 255, 0.1);
  color: var(--white);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(8px);
}

.btn--ghost:hover {
  background: rgba(255, 255, 255, 0.18);
  color: var(--white);
}

/* Акценты */
.btn--accent-blue,
.chisto-fld-ref .fld-btn--blue {
  background: #0284c7;
  color: var(--white);
  box-shadow: 0 8px 24px rgba(2, 132, 199, 0.35);
}

.btn--accent-blue:hover,
.chisto-fld-ref .fld-btn--blue:hover {
  filter: brightness(1.06);
  color: var(--white);
}

.btn--accent-red,
.chisto-urg-btn--red {
  background: #dc2626;
  color: var(--white);
  box-shadow: 0 8px 28px rgba(220, 38, 38, 0.35);
}

.btn--accent-red:hover,
.chisto-urg-btn--red:hover {
  filter: brightness(1.06);
  color: var(--white);
}

.btn--accent-green,
.chisto-vac-btn--green {
  background: #16a34a;
  color: var(--white);
  box-shadow: 0 8px 24px rgba(22, 163, 74, 0.35);
}

.btn--accent-green:hover,
.chisto-vac-btn--green:hover {
  filter: brightness(1.06);
  color: var(--white);
}

.btn--accent-orange,
.chisto-fir-ref .fir-btn--orange {
  background: #ea580c;
  color: var(--white);
  box-shadow: 0 8px 24px rgba(234, 88, 12, 0.35);
}

.btn--accent-orange:hover,
.chisto-fir-ref .fir-btn--orange:hover {
  filter: brightness(1.06);
  color: var(--white);
}

/* Размеры */
.btn--sm,
.chisto-vac-btn--sm,
.chisto-fld-ref .fld-btn--sm,
.chisto-fir-ref .fir-btn--sm {
  padding: 10px 22px;
  font-size: 13px;
}

.btn--lg {
  padding: 18px 44px;
  font-size: 16px;
}

.btn--block,
.chisto-vac-btn--block,
.chisto-osv-ref .chisto-osv-btn--block {
  width: 100%;
  justify-content: center;
}

.chisto-vac-btn--block {
  margin-top: 16px;
}

/* Плавающие CTA — только тень поверх базового модификатора */
.chisto-urg-btn--floating {
  box-shadow: 0 8px 40px rgba(220, 38, 38, 0.35);
}

.chisto-vac-btn--floating {
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.25);
}

/* Кнопки: chisto-buttons.css (+ .chisto-rrg-sub__body > .chisto-rrg-btn) */
.chisto-rrg-btn--outline {
  background: transparent;
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.35);
}

.chisto-rrg-btn--outline:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--white);
}

.chisto-rrg-btn--block {
  width: 100%;
  justify-content: center;
  font-size: 13px;
  padding: 12px 20px;
}

.chisto-rrg-btn--shrink {
  flex-shrink: 0;
  font-size: 13px;
  padding: 12px 22px;
}

/* Подвал: свой transition-токен */
.chisto-footer-scope .btn,
.chisto-footer-scope a.btn,
.chisto-footer-scope button.btn {
  transition: var(--tr-footer);
}

/* Шапка: на оверлее главной — прежняя полупрозрачная золотая (перекрывает .btn--gold) */
.chisto-header-scope .btn--gold {
  background: rgb(255 255 255 / 0.17);
  color: #ffffff;
  box-shadow: none;
}

.chisto-header-scope .btn--gold:hover {
  background: var(--gold-l);
  color: #ffffff;
}

body:not(.chisto-header-is-overlay) .chisto-header-scope .hdr .btn--gold,
body.chisto-header-is-overlay .chisto-header-scope .hdr.scrolled .btn--gold {
  background: linear-gradient(135deg, var(--gold), #d49406);
  color: var(--navy);
  box-shadow: var(--sh-gold);
}

body:not(.chisto-header-is-overlay) .chisto-header-scope .hdr .btn--gold:hover,
body.chisto-header-is-overlay .chisto-header-scope .hdr.scrolled .btn--gold:hover {
  background: var(--gold-l);
  color: var(--white);
  box-shadow: var(--sh-md);
}

.chisto-header-scope .btn--sm {
  padding: 10px 22px;
  font-size: 13px;
}

@media (max-width: 480px) {
  .btn,
  a.btn,
  button.btn,
  .chisto-wtc-btn,
  .chisto-wkl-btn,
  .chisto-sut-btn,
  .chisto-twk-btn,
  .chisto-tro-btn,
  .chisto-thr-btn,
  .chisto-sfm-btn,
  .chisto-stu-btn,
  .chisto-sdv-btn,
  .chisto-sch-btn,
  .chisto-rrg-btn,
  .chisto-vac-btn,
  .chisto-urg-btn,
  .chisto-rvw-btn,
  .chisto-fld-ref .fld-btn,
  .chisto-osv-ref .chisto-osv-btn,
  .chisto-mtc-ref .chisto-mtc-btn,
  .chisto-lfc-ref .chisto-lfc-btn,
  .chisto-fir-ref .fir-btn {
    padding: 13px 22px;
    font-size: 13px;
  }
}

/* Food concierge: вторичная кнопка на герое */
.chisto-food-scope .btn--outline-white:hover {
  border-color: var(--gold);
  color: var(--white);
}

/**
 * Тёмная заливка (navy и пр.) и контур «на тёмном»: белый текст у ссылок.
 * Перебивает .chisto-*-scope a { color: inherit } и прочие наследования.
 * Не затрагивает .btn--gold, .btn--ol, .btn--outline-dark (светлый фон).
 */
a[class*="btn--navy"],
a[class*="-btn--navy"],
a.btn--accent-blue,
a.btn--accent-red,
a.btn--accent-green,
a.btn--accent-orange,
a[class*="fld-btn--blue"],
a[class*="urg-btn--red"],
a[class*="vac-btn--green"],
a[class*="fir-btn--orange"],
a.btn--outline-white,
a.btn--ol-w,
a.btn--ghost,
a[class*="-btn--outline"]:not([class*="outline-dark"]),
a.chisto-rrg-btn--outline,
a.btn.btn--ol:hover {
  color: #fff !important;
}

a[class*="btn--navy"] svg,
a[class*="-btn--navy"] svg,
a.btn--accent-blue svg,
a.btn--accent-red svg,
a.btn--accent-green svg,
a.btn--accent-orange svg,
a[class*="fld-btn--blue"] svg,
a[class*="urg-btn--red"] svg,
a[class*="vac-btn--green"] svg,
a[class*="fir-btn--orange"] svg,
a.btn--outline-white svg,
a.btn--ol-w svg,
a.btn--ghost svg,
a[class*="-btn--outline"]:not([class*="outline-dark"]) svg,
a.chisto-rrg-btn--outline svg,
a.btn.btn--ol:hover svg {
  fill: currentColor;
}
