:root {
  --card-surface: rgba(26, 26, 26, 0.94);
  --accent-heading: #FF8C42;
  --space-unit: 8px;
  --space-sm: 16px;
  --space-md: 32px;
  --space-lg: 64px;
  --space-xl: 100px;
  --leading-body: 1.6;
  --section-y: var(--space-lg);
  --section-head-gap: var(--space-md);
  --card-padding: var(--space-md);
  --card-inner-gap: var(--space-sm);
  --grid-gap: var(--space-md);
  --text-to-cta-gap: var(--space-md);
  --container-padding-x: var(--space-sm);
}
@media (min-width: 768px) {
  :root {
    --section-y: var(--space-xl);
    --container-padding-x: calc(var(--space-unit) * 3);
  }
}
.py-home-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}
.py-home-section-services {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}
.gap-home {
  gap: var(--grid-gap);
}
.p-home-card {
  padding: var(--card-padding);
  box-sizing: border-box;
}
.p-home-card-no-top {
  padding-left: var(--card-padding);
  padding-right: var(--card-padding);
  padding-bottom: var(--card-padding);
  padding-top: 0;
  box-sizing: border-box;
}
.mb-home-head {
  margin-bottom: var(--section-head-gap);
}
.mt-home-after-h2 {
  margin-top: var(--card-inner-gap);
}
.mb-home-after-h2 {
  margin-bottom: var(--card-inner-gap);
}
.mt-home-stack {
  margin-top: var(--grid-gap);
}
.pt-home-section {
  padding-top: var(--section-y);
}
.pb-home-section {
  padding-bottom: var(--section-y);
}
.pt-home-card-edge {
  padding-top: var(--card-padding);
}
.section-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--section-head-gap);
}
.section-head.section-head--left {
  align-items: flex-start;
  text-align: left;
}
.section-head > * {
  margin: 0;
}
.section-body-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.section-body-stack > .btn {
  align-self: flex-start;
  flex-shrink: 0;
}
.hero__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.hero__text > * {
  margin: 0;
}
.hero__text .hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
main p {
  line-height: var(--leading-body);
  margin: 0;
}
main h1, main h2, main h3, main h4 {
  margin: 0;
}
.stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-unit);
  text-align: center;
}
.stat > * {
  margin: 0;
}
#preimushchestva .gosti-benefits-grid {
  align-items: start;
}

#uslugi #services-text.services__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-md);
  padding-top: 0;
  box-sizing: border-box;
}
#uslugi #services-text.services__text .services__title,
#uslugi #services-text.services__text .services__price {
  margin: 0;
}

#uslugi #services-text .services__desc-wrap {
  margin: 0;
  min-height: calc(4 * var(--space-md));
  width: 100%;
}
#uslugi #services-text .services__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin: 0;
}
.pb-home-hero-gosti {
  padding-bottom: var(--space-md);
}

main {
  padding: 0;
  margin: 0;
  display: block;
}

main > .site-hero:first-child {
  margin-top: 0;
}

.site-hero {
  margin: 0;
  padding-top: 0;
  background-color: #0C0D0E !important;
  isolation: isolate;
}

.site-hero > video {
  z-index: 0;
}

#uslugi.py-home-section-services {
  padding-top: var(--space-lg);
  padding-bottom: var(--section-y);
}
.card__inner {
  display: flex;
  flex-direction: column;
  gap: var(--card-inner-gap);
  height: 100%;
  box-sizing: border-box;
}
.card__inner > * {
  margin: 0;
}
.card__inner .card__title {
  min-height: 2lh;
  line-height: 1.35;
}
.card__inner .card__body {
  line-height: var(--leading-body);
  flex-grow: 1;
}
.owner__contacts {
  display: flex;
  flex-direction: column;
  gap: var(--card-inner-gap);
}
ul.messenger__list {
  display: flex;
  gap: 5px;
}
#booking-support .page-card {
  padding: 24px;
  gap: 15px;
}
.faq__item .faq__content p {
  line-height: var(--leading-body);
}
.faq__accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-unit);
}
/* РћС‚РєСЂС‹С‚С‹Р№ FAQ: Р»РµРІР°СЏ РѕСЂР°РЅР¶РµРІР°СЏ РїРѕР»РѕСЃР° */
.faq__item--open {
  box-shadow: inset 3px 0 0 var(--accent-heading), inset 0 1px 0 rgba(255,255,255,0.10), 0 16px 48px rgba(0,0,0,0.55) !important;
  border-color: rgba(255,140,66,0.25) !important;
}
/* + в†’ Г— РїСЂРё РѕС‚РєСЂС‹С‚РёРё */
.faq__item--open .faq__icon--plus { display: none; }
.faq__item--open .faq__icon--close { display: block; }
.faq__item--open .faq__icon-wrap { border-color: var(--accent-heading); color: var(--accent-heading); }
/** @section РЎРµРєС†РёСЏ СЃ РєР°СЂС‚РѕР№, С‚РµР»РµС„РѕРЅРѕРј Рё РјРµСЃСЃРµРЅРґР¶РµСЂР°РјРё */
.owner__title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  line-height: 0.9;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0;
}
.owner__subtitle {
  font-family: Georgia, 'Times New Roman', serif;
  font-style: italic;
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  color: var(--accent-heading);
  margin-top: 0.5rem;
  line-height: 1.2;
}
.owner__phone {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  transition: color 0.2s;
}
.owner__phone:hover { color: var(--accent-heading); }
/** @section РЎРµРєС†РёСЏ CTA СЃ С€Р°РіР°РјРё РѕС„РѕСЂРјР»РµРЅРёСЏ Р·Р°РєР°Р·Р° */
.contacts__title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0;
}
.contacts__subtitle {
  font-family: Georgia, 'Times New Roman', serif;
  font-style: italic;
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  color: var(--accent-heading);
  margin-top: 0.5rem;
  line-height: 1.2;
}
/* CSS 3D Phone Mockup */
.phone__wrap {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: -50px;
  padding-top: 10px;
}
.phone__body {
  position: relative;
  width: 270px;
  background: linear-gradient(155deg, #ff4040 0%, #d40000 30%, #a00000 65%, #700000 100%);
  border-radius: 46px;
  padding: 6px;
  box-shadow:
    0 0 0 1px rgba(255,80,80,0.3),
    10px 30px 70px rgba(0,0,0,0.9),
    -3px -3px 10px rgba(255,100,100,0.1) inset,
    3px 3px 10px rgba(0,0,0,0.5) inset;
  transform: perspective(1100px) rotateZ(-10deg) rotateY(8deg) rotateX(4deg);
  transition: transform 0.5s cubic-bezier(0.23, 1, 0.32, 1);
}
.phone__body:hover {
  transform: perspective(1100px) rotateZ(-3deg) rotateY(2deg) rotateX(1deg);
}
.phone__body::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 46px;
  background: linear-gradient(145deg, rgba(255,255,255,0.22) 0%, transparent 40%);
  pointer-events: none;
  z-index: 2;
}
.phone__bezel {
  position: relative;
  background: linear-gradient(160deg, #2a2a2a 0%, #1a1a1a 100%);
  border-radius: 42px;
  padding: 14px 10px 12px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.05) inset,
    0 2px 12px rgba(0,0,0,0.6) inset;
  overflow: hidden;
}
.phone__btn {
  position: absolute;
  background: linear-gradient(90deg, #b00000, #800000);
  border-radius: 2px 0 0 2px;
  z-index: 3;
}
.phone__btn--vol-up  { left:-3px; top:88px;  width:4px; height:28px; border-radius:2px 0 0 2px; }
.phone__btn--vol-down{ left:-3px; top:126px; width:4px; height:28px; border-radius:2px 0 0 2px; }
.phone__btn--power   { right:-3px; top:108px; width:4px; height:42px; border-radius:0 2px 2px 0; }
.phone__notch {
  width: 80px;
  height: 20px;
  background: #111;
  border-radius: 0 0 18px 18px;
  margin: -14px auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  position: relative;
  z-index: 2;
}
.phone__notch-cam {
  width: 7px; height: 7px;
  background: radial-gradient(circle, #2a2a2a, #111);
  border-radius: 50%;
  border: 1px solid #333;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05) inset;
}
.phone__notch-speaker {
  width: 28px; height: 4px;
  background: #222;
  border-radius: 2px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.04),
    inset 0 1px 2px rgba(0,0,0,0.8);
}
.phone__screen {
  background: #ffffff;
  border-radius: 6px;
  overflow: hidden;
  padding: 8px 10px 10px;
}
.phone__status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  padding: 0 2px;
}
.phone__time {
  font-family: -apple-system, 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 600; color: #111;
}
.phone__status-icons { display: flex; gap: 3px; align-items: center; }
.phone__dialer {
  display: flex; flex-direction: column;
  align-items: center; gap: 7px;
}
.phone__brand {
  font-family: 'Montserrat', sans-serif;
  font-size: 7px; font-weight: 700;
  color: #cc0000;
  letter-spacing: 0.12em; text-transform: uppercase; text-align: center;
}
.phone__number {
  font-family: -apple-system, 'Montserrat', sans-serif;
  font-size: 18px; font-weight: 400;
  color: #111; text-decoration: none;
  letter-spacing: -0.02em; text-align: center;
  display: block; line-height: 1;
  transition: color 0.2s;
}
.phone__number:hover { color: #cc0000; }
.phone__keypad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px; width: 100%;
}
.phone__key {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  background: #e8e8e8;
  border: none; border-radius: 50%;
  aspect-ratio: 1; cursor: pointer;
  transition: background 0.12s, transform 0.1s;
  gap: 0; padding: 0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.18), 0 0 0 0.5px rgba(0,0,0,0.06);
}
.phone__key:hover  { background: #d0d0d0; transform: scale(1.05); }
.phone__key:active { background: #bababa; transform: scale(0.95); }
.phone__key-digit {
  font-family: -apple-system, 'Montserrat', sans-serif;
  font-size: 17px; font-weight: 300; color: #111; line-height: 1.1;
}
.phone__key-sub {
  font-family: -apple-system, 'Montserrat', sans-serif;
  font-size: 5px; font-weight: 500;
  color: #555; letter-spacing: 0.05em; line-height: 1;
}
.phone__actions {
  display: flex; justify-content: center; margin-top: 2px;
}
.phone__call {
  display: flex; align-items: center; justify-content: center;
  width: 48px; height: 48px;
  background: linear-gradient(145deg, #4cd964, #28a745);
  border-radius: 50%;
  box-shadow: 0 4px 16px rgba(40,167,69,0.5);
  transition: transform 0.15s, box-shadow 0.15s;
}
.phone__call:hover {
  transform: scale(1.1);
  box-shadow: 0 8px 24px rgba(40,167,69,0.7);
}
.phone__home-bar {
  width: 55px; height: 3px;
  background: rgba(0,0,0,0.15);
  border-radius: 2px; margin: 10px auto 0;
}
@media (max-width: 1024px) {
  .phone__wrap { margin-bottom: 0; }
}
@media (max-width: 640px) {
  .phone__body { width: 210px; border-radius: 36px;
    transform: perspective(1100px) rotateZ(-5deg) rotateY(3deg) rotateX(2deg); }
  .phone__number { font-size: 14px; }
  .phone__key-digit { font-size: 13px; }
  .phone__call { width: 40px; height: 40px; }
}
/* РЁР°РіРё Р·Р°РєР°Р·Р° РІ Р±Р»РѕРєРµ РєРѕРЅС‚Р°РєС‚РѕРІ */
.order-step {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.order-step__num {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  font-weight: 900;
  color: var(--accent-heading);
  line-height: 1;
  min-width: 36px;
  padding-top: 2px;
}
.order-step__title {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 4px;
}
.order-step__desc {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.5;
}
/* Р”РµРєРѕСЂР°С‚РёРІРЅС‹Р№ Р·Р°РіРѕР»РѕРІРѕРє FAQ */
.faq__decorative-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: #fff;
  text-transform: uppercase;
  overflow-wrap: break-word;
}
.faq__decorative-subtitle {
  font-family: Georgia, 'Times New Roman', serif;
  font-style: italic;
  font-size: 1.5rem;
  color: var(--accent-heading);
  line-height: 1.2;
}
.card__inner > .btn:last-child {
  margin-top: calc(var(--text-to-cta-gap) - var(--card-inner-gap));
}
.card__inner > ul:last-child {
  margin-top: calc(var(--text-to-cta-gap) - var(--card-inner-gap));
}

/* Р•РґРёРЅР°СЏ СЃРёСЃС‚РµРјР° СЃРµРєС†РёР№ Рё РєР°СЂС‚РѕС‡РµРє */
.page-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}
#preimushchestva.page-section,
#preimushchestva.py-home-section {
  padding-top: var(--space-lg);
  padding-bottom: var(--space-lg);
}
#preimushchestva .page-card {
  gap: 0;
}
#preimushchestva .page-card__num {
  margin-bottom: 24px;
}
#preimushchestva .page-card__title {
  margin-bottom: 15px;
}
.page-section__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-sm);
  margin-bottom: var(--section-head-gap);
}
.page-section__head > * { margin: 0; }
.page-section__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.page-section__body > * { margin: 0; }
.page-section__body > .btn {
  align-self: flex-start;
  flex-shrink: 0;
}
.page-card {
  padding: var(--card-padding);
  display: flex;
  flex-direction: column;
  gap: var(--card-inner-gap);
  box-sizing: border-box;
  height: 100%;
}
.page-card > * { margin: 0; }
.page-card__num {
  display: block;
  line-height: 1;
}
.page-card__title {
  min-height: 2lh;
  line-height: 1.35;
}
.page-card__body {
  line-height: var(--leading-body);
  flex-grow: 1;
}
@media (max-width: 767px) {
  .page-card__body { flex-grow: 0; }
  .page-card__title { min-height: 0; }
  .page-card { height: auto; }
}

html, body { background-color: #0C0D0E; width: 100%; max-width: 100%; }
body { overflow-x: hidden; }
main { color: rgba(255, 255, 255, 0.88); width: 100%; min-width: 0; flex: 1 1 auto; }
.heading-accent { color: var(--accent-heading) !important; }
.text-body-readable { color: rgba(255, 255, 255, 0.82); }
.container {
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-padding-x);
  padding-right: var(--container-padding-x);
  box-sizing: border-box;
}
.site-footer {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}
.footer-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}
.footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-md);
}
.footer-copy {
  margin: 0;
  text-align: center;
  line-height: var(--leading-body);
}
/* fixed-фон давал полосу между шапкой и hero — оставляем scroll */
html { scrollbar-width: none; -ms-overflow-style: none; }
body::-webkit-scrollbar, html::-webkit-scrollbar { width: 0; display: none; }
body { -ms-overflow-style: none; scrollbar-width: none; }
.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }
/* FAQ accordion smooth expand */
.faq__item .faq__content { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.5s cubic-bezier(0.32, 0.72, 0, 1); }
.faq__item--open .faq__content { grid-template-rows: 1fr; }
.faq__item .faq__content > div { overflow: hidden; min-height: 0; }
.faq__item--open .faq__icon { transform: rotate(180deg); }
/* Section fade-in on scroll */
.animate-on-scroll { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s ease; }
.animate-on-scroll.visible { opacity: 1; transform: translateY(0); }
@keyframes carousel-slide-in-next { from { opacity: 0; transform: translateX(60px); } to { opacity: 1; transform: translateX(0); } }
@keyframes carousel-slide-in-prev { from { opacity: 0; transform: translateX(-60px); } to { opacity: 1; transform: translateX(0); } }
.carousel__main .carousel__card { animation: carousel-slide-in-next 0.45s cubic-bezier(0.34, 1.56, 0.64, 1) both; }
.carousel__main[data-direction="prev"] .carousel__card { animation: carousel-slide-in-prev 0.45s cubic-bezier(0.34, 1.56, 0.64, 1) both; }
@keyframes orbit-fade { from { opacity: 0.5; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
.carousel__orbit-item--anim { animation: orbit-fade 0.35s ease-out; }
.nav-link-underline::after { content:''; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:currentColor; transition:width 0.3s ease-out; }
.nav-link-underline:hover::after { width:100%; }
.messenger__btn:hover { transform: scale(1.05); opacity: 0.95; }
.block-title { font-family: 'Montserrat', sans-serif !important; font-weight: 700; }
@keyframes btn-cta-glow {
  0%, 100% { box-shadow: 0 4px 28px rgba(234, 88, 12, 0.42), 0 0 0 1px rgba(255,255,255,0.2); }
  50% { box-shadow: 0 6px 36px rgba(234, 88, 12, 0.62), 0 0 0 1px rgba(255,255,255,0.28); }
}
/* РЎРёСЃС‚РµРјР° РєРЅРѕРїРѕРє: РєР°РїСЃСѓР»Р° + uppercase-РїРѕРґРїРёСЃРё */
.btn {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  color: #fff !important;
  border-radius: 9999px !important;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}
.btn::before,
.btn::after { display: none !important; }
.btn:hover {
  color: #fff !important;
  filter: brightness(1.08);
  transform: translateY(-2px);
}
.btn--primary {
  border: 2px solid rgba(255,255,255,0.4) !important;
  background: linear-gradient(180deg, #FFA04A 0%, #EA580C 55%, #C2410C 100%) !important;
  box-shadow: 0 4px 20px rgba(234, 88, 12, 0.45);
}
.btn--primary:hover {
  box-shadow: 0 6px 28px rgba(234, 88, 12, 0.55);
}
.btn--secondary {
  border: 1px solid rgba(255,255,255,0.28) !important;
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 4px 18px rgba(0,0,0,0.35);
}
.btn--secondary:hover {
  background: rgba(255,255,255,0.14) !important;
  border-color: rgba(255,255,255,0.4) !important;
  box-shadow: 0 6px 22px rgba(0,0,0,0.4);
}
.btn--helper {
  border: 1px dashed rgba(255,255,255,0.25) !important;
  background: rgba(20,22,24,0.65) !important;
  color: rgba(255,255,255,0.88) !important;
  box-shadow: none;
}
.btn--helper:hover {
  background: rgba(255,255,255,0.1) !important;
  border-color: rgba(255,255,255,0.35) !important;
}
@keyframes btn-ghost-contour-glow {
  0%, 100% {
    border-color: rgba(255, 255, 255, 0.82);
    box-shadow:
      0 2px 12px rgba(0, 0, 0, 0.42),
      0 0 0 1px rgba(0, 0, 0, 0.28),
      0 0 6px 0 rgba(255, 255, 255, 0.1);
  }
  50% {
    border-color: rgba(255, 255, 255, 0.98);
    box-shadow:
      0 2px 12px rgba(0, 0, 0, 0.42),
      0 0 0 1px rgba(0, 0, 0, 0.28),
      0 0 12px 2px rgba(255, 255, 255, 0.22),
      0 0 24px 0 rgba(255, 245, 235, 0.07);
  }
}
/* РљРѕРЅС‚СѓСЂРЅР°СЏ РєР°РїСЃСѓР»Р°: Р±РµР»Р°СЏ РѕР±РІРѕРґРєР° СЃ РїСѓР»СЊСЃРёСЂСѓСЋС‰РёРј СЃРІРµС‡РµРЅРёРµРј */
.btn--ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px !important;
  border: 1px solid rgba(255, 255, 255, 0.9);
  background: #060606;
  background: linear-gradient(180deg, #101010 0%, #050505 100%);
  color: #fff !important;
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  /* РЎРёРјРјРµС‚СЂРёС‡РЅС‹Рµ РѕС‚СЃС‚СѓРїС‹ + С‡СѓС‚СЊ Р±РѕР»СЊС€Рµ СЃРЅРёР·Сѓ вЂ” РІРёР·СѓР°Р»СЊРЅРѕРµ С†РµРЅС‚СЂРёСЂРѕРІР°РЅРёРµ РєР°РїСЃ-С‚РµРєСЃС‚Р° (Inter) */
  padding: 0.65rem 1.65rem 0.72rem;
  line-height: 1.15;
  text-decoration: none;
  animation: btn-ghost-contour-glow 2.8s ease-in-out infinite;
  transition:
    background-color 0.2s ease,
    transform 0.2s ease;
}
.btn--ghost:hover {
  color: #fff !important;
  animation: none;
  background: #141414;
  background: linear-gradient(180deg, #1a1a1a 0%, #0c0c0c 100%);
  border-color: #fff;
  transform: translateY(-1px);
  box-shadow:
    0 4px 20px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(0, 0, 0, 0.35),
    0 0 16px 2px rgba(255, 255, 255, 0.18);
}
/* РЎРІРµС‡РµРЅРёРµ С‚РѕР»СЊРєРѕ Сѓ РѕСЃРЅРѕРІРЅРѕРіРѕ CTA (РЅРµ Сѓ btn--secondary) */
.btn--primary.btn--cta {
  animation: btn-cta-glow 2.6s ease-in-out infinite;
}
/* mix-blend-mode: lighten РЅРµР№С‚СЂР°Р»РёР·СѓРµС‚ С‡С‘СЂРЅС‹Р№ С„РѕРЅ PNG-Р»РѕРіРѕС‚РёРїР° РЅР° С‚С‘РјРЅРѕР№ С€Р°РїРєРµ */
.logo-header-img {
  mix-blend-mode: lighten;
}
@keyframes faq__glint-sweep {
  0% { transform: translateX(-220%) skewX(-22deg); opacity: 0; }
  12% { opacity: 0.35; }
  34% { transform: translateX(320%) skewX(-22deg); opacity: 0; }
  100% { transform: translateX(320%) skewX(-22deg); opacity: 0; }
}
.faq__glint {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.faq__glint::after {
  content: '';
  position: absolute;
  top: -35%;
  bottom: -35%;
  left: -50%;
  width: 42%;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.45) 50%, rgba(255,255,255,0) 100%);
  filter: blur(0.6px);
  animation: faq__glint-sweep 4.2s ease-in-out infinite;
  z-index: 2;
}
.glass-hover {
  background: var(--card-surface) !important;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 16px 48px rgba(0,0,0,0.55);
  transition: border-color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease;
}
.glass-hover:hover {
  border-color: rgba(255,255,255,0.22) !important;
  outline: 1px solid rgba(255,255,255,0.08);
  outline-offset: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 0 0 1px rgba(255,255,255,0.12),
    0 18px 40px rgba(0,0,0,0.5),
    0 0 20px rgba(255,140,66,0.12) !important;
  transform: translateY(-1px);
}
