/* ===========================================================
   ТриАтур — Вариант 3 «Glassmorphism»
   Палитра как в варианте 1: оранжевый + синий/голубой на светлом.
   Матовое стекло, размытия, цветные авроры.
   =========================================================== */

/* ---- Self-hosted Manrope (OFL, Fontsource) — без внешних вызовов ---- */
@font-face{font-family:"Manrope";font-style:normal;font-weight:500;font-display:swap;src:url("fonts/manrope-cyrillic-500.woff2") format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:500;font-display:swap;src:url("fonts/manrope-latin-500.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:600;font-display:swap;src:url("fonts/manrope-cyrillic-600.woff2") format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:600;font-display:swap;src:url("fonts/manrope-latin-600.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:700;font-display:swap;src:url("fonts/manrope-cyrillic-700.woff2") format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:700;font-display:swap;src:url("fonts/manrope-latin-700.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:800;font-display:swap;src:url("fonts/manrope-cyrillic-800.woff2") format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:"Manrope";font-style:normal;font-weight:800;font-display:swap;src:url("fonts/manrope-latin-800.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}

:root {
  --orange: #FF6A00;
  --orange-600: #ED5E00;
  --blue: #1685C8;
  --blue-light: #2AA9E0;
  --blue-900: #0C5C90;
  --ink: #1F2D3D;
  --ink-60: #54657a;
  --ink-40: #8595a6;

  /* стекло */
  --glass: rgba(255,255,255,.46);
  --glass-2: rgba(255,255,255,.66);
  --glass-strong: rgba(255,255,255,.82);
  --glass-brd: rgba(255,255,255,.7);
  --glass-brd-soft: rgba(255,255,255,.45);
  --blur: blur(20px) saturate(160%);
  --blur-lg: blur(36px) saturate(170%);

  --r-xl: 32px;
  --r-lg: 24px;
  --r-md: 18px;
  --r-sm: 12px;

  --sh-soft: 0 10px 30px rgba(31,45,61,.10);
  --sh-card: 0 16px 40px rgba(12,49,80,.14);
  --sh-pop: 0 30px 70px rgba(12,49,80,.22);

  --maxw: 1260px;
  --gut: clamp(18px, 4vw, 56px);

  --font-display: "Manrope", system-ui, sans-serif;
  --font-body: "Manrope", system-ui, sans-serif;
  --ease: cubic-bezier(.22,1,.36,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  background: #e9f3fb;
  overflow-x: hidden;
  position: relative;
}

/* ---------- Фоновые авроры (фикс., за всем) ---------- */
.aurora { position: fixed; inset: 0; z-index: -2; overflow: hidden; pointer-events: none; }
.aurora::before, .aurora::after, .aurora .b1, .aurora .b2, .aurora .b3 { content: ""; position: absolute; border-radius: 50%; filter: blur(70px); opacity: .8; }
.aurora .b1 { width: 52vw; height: 52vw; background: radial-gradient(circle, #FF8A3D, transparent 68%); top: -14vw; right: -8vw; opacity: .55; }
.aurora .b2 { width: 48vw; height: 48vw; background: radial-gradient(circle, #2AA9E0, transparent 68%); top: 22vw; left: -12vw; opacity: .6; }
.aurora .b3 { width: 44vw; height: 44vw; background: radial-gradient(circle, #1685C8, transparent 70%); bottom: -10vw; right: 4vw; opacity: .5; }
.aurora .b4 { content: ""; position: absolute; border-radius: 50%; filter: blur(70px); width: 36vw; height: 36vw; background: radial-gradient(circle, #FFB57A, transparent 70%); top: 120vh; left: 30vw; opacity: .4; }
.grain { position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .4;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 { margin: 0; font-family: var(--font-display); font-weight: 700; line-height: 1.05; letter-spacing: -.02em; }
p { margin: 0; text-wrap: pretty; }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.section { padding-block: clamp(48px, 7vw, 92px); position: relative; }

/* стеклянная карта-утилита */
.glass {
  background: var(--glass);
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft);
  box-shadow: var(--sh-card), inset 0 1px 0 rgba(255,255,255,.55);
}

/* ---------- Типографика заголовков секций ---------- */
.kicker {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--glass-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft);
  padding: 7px 15px; border-radius: 999px;
  font-family: var(--font-body); font-weight: 800; font-size: 12.5px;
  letter-spacing: .12em; text-transform: uppercase; color: var(--orange-600);
}
.kicker .d { width: 7px; height: 7px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 4px rgba(255,106,0,.22); }
.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; margin-bottom: clamp(26px, 4vw, 48px); }
.sec-head .l { max-width: 60%; }
.sec-head h2 { font-size: clamp(30px, 4.6vw, 54px); margin-top: 16px; }
.sec-head h2 .o { color: var(--orange); }
.sec-head p { color: var(--ink-60); margin-top: 12px; font-size: 16.5px; max-width: 44ch; }
.sec-link {
  display: inline-flex; align-items: center; gap: 9px; white-space: nowrap;
  background: var(--glass-2); -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft); padding: 11px 18px; border-radius: 999px;
  font-weight: 800; font-size: 14px; color: var(--blue-900);
  transition: transform .25s var(--ease), box-shadow .25s, background .25s;
}
.sec-link:hover { transform: translateY(-2px); box-shadow: var(--sh-soft); background: var(--glass-strong); }
.sec-link .a { transition: transform .3s var(--ease); }
.sec-link:hover .a { transform: translateX(4px); }

/* ---------- Кнопки ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font-body); font-weight: 800; font-size: 16px;
  border: none; cursor: pointer; border-radius: 999px;
  padding: 15px 28px; transition: transform .25s var(--ease), box-shadow .25s, background .25s;
}
.btn .a { transition: transform .3s var(--ease); }
.btn:hover .a { transform: translateX(4px); }
.btn-primary { background: linear-gradient(135deg, #FF8A3D, var(--orange)); color: #fff; box-shadow: 0 12px 26px rgba(255,106,0,.34); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 18px 34px rgba(255,106,0,.42); }
.btn-glass {
  background: var(--glass-2); color: var(--ink);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd);
}
.btn-glass:hover { background: var(--glass-strong); transform: translateY(-2px); box-shadow: var(--sh-soft); }
.btn-ghost { background: rgba(255,255,255,.16); color: #fff; border: 1px solid rgba(255,255,255,.5); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.btn-ghost:hover { background: rgba(255,255,255,.28); }
.btn-lg { padding: 18px 34px; font-size: 17px; }

/* ===========================================================
   ВЕРХ: контактная плашка + шапка
   =========================================================== */
.topnav { position: sticky; top: 0; z-index: 80; display: flex; flex-direction: column; }
.ribbon {
  background: linear-gradient(120deg, #0C5C90 0%, #1685C8 55%, #2AA9E0 100%);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  color: #fff; font-size: 13.5px; font-weight: 600;
  transition: margin-top .4s var(--ease);
  border-bottom: 1px solid rgba(255,255,255,.18);
}
body.ribbon-hidden .ribbon { margin-top: var(--ribbon-neg, -46px); }
.ribbon .wrap { display: flex; align-items: center; gap: 20px; min-height: 42px; padding-block: 6px; flex-wrap: wrap; }
.ribbon a { color: #fff; }
.ribbon .i { display: inline-flex; align-items: center; gap: 7px; }
.ribbon .i svg { opacity: .9; flex: none; }
.ribbon .p { font-weight: 800; }
.ribbon .p { transition: color .2s; }
.ribbon .p:hover { color: var(--orange); text-decoration: none; }
.ribbon .sep { width: 4px; height: 4px; border-radius: 50%; background: rgba(255,255,255,.7); }
.ribbon .sp { flex: 1; }
.ribbon .soc { display: flex; gap: 7px; }
.ribbon .soc a { width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,.2); transition: background .2s, transform .15s; }
.ribbon .soc a:hover { background: rgba(255,255,255,.36); transform: translateY(-1px); }

.head {
  margin: 12px var(--gut) 0;
  border-radius: 999px;
  background: var(--glass-strong);
  -webkit-backdrop-filter: var(--blur-lg); backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-brd);
  box-shadow: var(--sh-soft);
}
.head .inner { display: flex; align-items: center; gap: 22px; padding: 4px 12px 4px 22px; min-height: 64px; }
.brand { flex: none; display: inline-flex; align-items: center; }
.brand img { height: 56px; width: auto; }
.head nav { display: flex; gap: 2px; margin-left: 6px; }
.head nav a { font-weight: 700; font-size: 15px; padding: 9px 14px; border-radius: 999px; transition: background .2s, color .2s; }
.head nav a:hover { background: rgba(255,255,255,.6); color: #0674ec; }
.head nav a.active { color: var(--orange-600); }

/* выпадающее меню в навигации */
.nav-dd { position: relative; }
.nav-dd .ddbtn {
  font-family: var(--font-body); font-weight: 700; font-size: 15px;
  padding: 9px 14px; border-radius: 999px; border: none; cursor: pointer;
  background: none; color: var(--ink);
  display: inline-flex; align-items: center; gap: 6px;
  transition: background .2s, color .2s;
}
.nav-dd .ddbtn:hover { background: rgba(255,255,255,.6); color: #0674ec; }
.nav-dd .ddbtn.active { color: var(--orange-600); }
.nav-dd .ddbtn .cc { transition: transform .25s var(--ease); }
.nav-dd.open .ddbtn { background: rgba(255,255,255,.6); color: #0674ec; }
.nav-dd.open .ddbtn .cc { transform: rotate(180deg); }
.nav-dd .ddmenu {
  position: absolute; top: calc(100% + 12px); left: 0; min-width: 216px;
  background: var(--glass-strong);
  -webkit-backdrop-filter: var(--blur-lg); backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-brd); border-radius: var(--r-md);
  box-shadow: var(--sh-pop); padding: 8px;
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
  z-index: 90;
}
.nav-dd .ddmenu::before { content: ""; position: absolute; top: -12px; left: 0; right: 0; height: 12px; }
.nav-dd.open .ddmenu { opacity: 1; visibility: visible; transform: none; }
@media (hover: hover) {
  .nav-dd:hover .ddmenu { opacity: 1; visibility: visible; transform: none; }
  .nav-dd:hover .ddbtn { background: rgba(255,255,255,.6); color: #0674ec; }
  .nav-dd:hover .ddbtn .cc { transform: rotate(180deg); }
}
.nav-dd .ddmenu a {
  padding: 11px 14px; border-radius: var(--r-sm);
  font-weight: 700; font-size: 15px; color: var(--ink);
  display: flex; align-items: center; gap: 11px;
  transition: background .18s, color .18s;
}
.nav-dd .ddmenu a:hover { background: rgba(255,255,255,.7); color: #0674ec; }
.nav-dd .ddmenu a svg { color: var(--blue); flex: none; }
.nav-dd .ddmenu-wide { min-width: 500px; display: grid; grid-template-columns: 1fr 1fr; gap: 2px 4px; left: auto; right: 0; }

/* группа «О компании» в мобильном меню */
.msheet .mgroup { margin: 2px 0; }
.msheet .mgroup .mglabel { font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-40); padding: 14px 14px 6px; }
.msheet .mgroup a { font-size: 17px; padding-left: 26px; }
.head .right { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.burger { display: none; margin-left: auto; width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--glass-brd); background: var(--glass-2); cursor: pointer; flex-direction: column; gap: 5px; align-items: center; justify-content: center; }
.burger i { width: 22px; height: 2.4px; border-radius: 3px; background: var(--ink); transition: transform .3s var(--ease), opacity .2s; }
body.menu-open .burger i:nth-child(1) { transform: translateY(7.4px) rotate(45deg); }
body.menu-open .burger i:nth-child(2) { opacity: 0; }
body.menu-open .burger i:nth-child(3) { transform: translateY(-7.4px) rotate(-45deg); }

/* мобильное меню (стекло) */
.msheet {
  position: fixed; inset: 10px 10px 10px auto; width: min(380px, 88vw);
  border-radius: var(--r-xl);
  background: var(--glass-strong);
  -webkit-backdrop-filter: var(--blur-lg); backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-brd);
  box-shadow: var(--sh-pop);
  z-index: 120; transform: translateX(120%); transition: transform .45s var(--ease);
  padding: 22px; display: flex; flex-direction: column; gap: 6px; overflow-y: auto;
}
body.menu-open .msheet { transform: none; }
.msheet .top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.msheet .top img { height: 40px; }
.msheet .close { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--glass-brd); background: var(--glass-2); font-size: 22px; cursor: pointer; color: var(--ink); }
.msheet nav { display: flex; flex-direction: column; gap: 2px; }
.msheet nav a { font-family: var(--font-display); font-weight: 700; font-size: 19px; padding: 12px 14px; border-radius: var(--r-md); transition: background .2s; }
.msheet nav a:hover { background: rgba(255,255,255,.6); }
.msheet .cta { margin-top: 14px; }
.msheet .ph { margin-top: 16px; font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--orange-600); padding-left: 14px; }
.scrim { position: fixed; inset: 0; background: rgba(12,30,50,.4); -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); z-index: 110; opacity: 0; pointer-events: none; transition: opacity .4s; }
body.menu-open .scrim { opacity: 1; pointer-events: auto; }

/* ===========================================================
   ГЕРОЙ
   =========================================================== */
.hero { position: relative; padding-top: clamp(30px, 4vw, 50px); }
.hero .wrap { position: relative; z-index: 2; }
.hero-photo-wrap {
  position: relative; border-radius: var(--r-xl); overflow: hidden;
  min-height: clamp(480px, 56vw, 600px);
  display: flex; align-items: flex-start;
  box-shadow: var(--sh-card);
  border: 1px solid var(--glass-brd-soft);
}
.hero-photo { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.05); }
.hero-photo-wrap::after { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, rgba(11,53,87,.74) 0%, rgba(11,53,87,.36) 52%, rgba(11,53,87,.12) 100%); }
.hero-content { position: relative; z-index: 3; color: #fff; padding: clamp(28px, 4vw, 60px); padding-bottom: clamp(96px, 12vw, 150px); max-width: 680px; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 9px;
  background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.36);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  padding: 8px 16px 8px 11px; border-radius: 999px; font-weight: 600; font-size: 14px; margin-bottom: 20px;
}
.hero-badge .d { width: 8px; height: 8px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 4px rgba(255,106,0,.3); }
.hero h1 { color: #fff; font-size: clamp(36px, 6vw, 68px); font-weight: 800; letter-spacing: -.03em; }
.hero h1 .o { color: var(--orange); }
.hero-sub { margin-top: 18px; font-size: clamp(17px, 1.9vw, 21px); font-weight: 500; max-width: 50ch; color: rgba(255,255,255,.92); }
.hero-actions { margin-top: 26px; display: flex; gap: 14px; flex-wrap: wrap; }
.hero-chips { margin-top: 26px; display: flex; gap: 12px; flex-wrap: wrap; }
.hero-chip { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 700; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.3); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); padding: 8px 14px; border-radius: 999px; }
.hero-chip .st { color: #FFC53D; letter-spacing: 1px; }

/* ---------- Поиск (стеклянная карта, плейсхолдер tourvisor) ---------- */
.search-shell { position: relative; z-index: 10; margin-top: clamp(-58px, -5.5vw, -78px); }
.search-card {
  border-radius: var(--r-xl);
  background: var(--glass-strong);
  -webkit-backdrop-filter: var(--blur-lg); backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-brd);
  box-shadow: var(--sh-pop);
  padding: clamp(18px, 2.4vw, 28px);
}
.search-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.search-tab {
  border: 1px solid transparent; cursor: pointer;
  background: rgba(255,255,255,.5); color: var(--ink-60);
  font-family: var(--font-body); font-weight: 800; font-size: 13.5px;
  padding: 9px 16px; border-radius: 999px; transition: all .2s;
}
.search-tab[aria-selected="true"] { background: linear-gradient(135deg, #FF8A3D, var(--orange)); color: #fff; box-shadow: 0 8px 18px rgba(255,106,0,.3); }
.search-tab:hover:not([aria-selected="true"]) { background: rgba(255,255,255,.8); }
.search-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 10px; align-items: end; }
.f { grid-column: span 2; display: flex; flex-direction: column; gap: 5px; }
.f.from { grid-column: span 2; }
.f.country { grid-column: span 2; }
.f.cls { grid-column: span 2; }
.f-submit { grid-column: span 2; }
.f label { font-size: 12px; font-weight: 800; color: var(--ink-60); padding-left: 14px; letter-spacing: .02em; }
.f .ctl { position: relative; background: rgba(255,255,255,.62); border: 1px solid var(--glass-brd-soft); border-radius: 999px; transition: border-color .2s, background .2s; }
.f .ctl:focus-within { border-color: var(--blue-light); background: #fff; }
.f .ctl svg.lead { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--blue); pointer-events: none; }
.f select, .f input { width: 100%; border: none; background: none; outline: none; font-family: var(--font-body); font-weight: 700; font-size: 15px; color: var(--ink); padding: 13px 14px 13px 38px; border-radius: 999px; appearance: none; }
.f select { cursor: pointer; }
.f .ctl.caret::after { content: ""; position: absolute; right: 17px; top: 50%; width: 8px; height: 8px; border-right: 2px solid var(--ink-40); border-bottom: 2px solid var(--ink-40); transform: translateY(-65%) rotate(45deg); pointer-events: none; }
.f-submit .btn { width: 100%; height: 50px; white-space: nowrap; padding-inline: 14px; gap: 8px; }
.search-note { margin-top: 14px; display: flex; align-items: center; gap: 9px; color: var(--ink-40); font-size: 13px; font-weight: 600; }
.search-note .tag { background: rgba(22,133,200,.12); color: var(--blue-900); padding: 3px 10px; border-radius: 6px; font-size: 11.5px; letter-spacing: .04em; }

/* ===========================================================
   ГОРЯЩИЕ ТУРЫ — стеклянные карточки
   =========================================================== */
.widget-note {
  display: flex; align-items: center; gap: 11px; margin-bottom: 24px;
  border-radius: var(--r-md);
  background: var(--glass);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px dashed rgba(42,169,224,.6);
  color: var(--ink-60); padding: 13px 17px; font-size: 13.5px; font-weight: 700;
}
.widget-note .tag { background: var(--blue); color: #fff; padding: 4px 10px; border-radius: 6px; font-size: 11px; letter-spacing: .06em; }
.widget-note svg { color: var(--orange); flex: none; }

.cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(14px, 1.8vw, 22px); }
.tour {
  border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column;
  background: var(--glass-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft);
  box-shadow: var(--sh-soft);
  transition: transform .3s var(--ease), box-shadow .3s;
}
.tour:hover { transform: translateY(-6px); box-shadow: var(--sh-card); }
.tour .media { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.tour .media img, .tour .media .ph { width: 100%; height: 100%; object-fit: cover; transition: transform .55s var(--ease); }
.tour:hover .media img { transform: scale(1.07); }
.tour .disc { position: absolute; top: 12px; left: 12px; background: linear-gradient(135deg, #FF8A3D, var(--orange)); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 14px; padding: 6px 12px; border-radius: 999px; box-shadow: 0 6px 14px rgba(255,106,0,.4); }
.tour .fav { position: absolute; top: 10px; right: 10px; width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.7); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,.6); cursor: pointer; display: grid; place-items: center; color: var(--ink-60); transition: color .2s, transform .15s; }
.tour .fav:hover { color: var(--orange); transform: scale(1.08); }
.tour .body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.tour .loc { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.tour .loc h3 { font-family: var(--font-display); font-size: 19px; font-weight: 700; }
.tour .st { color: #FFB100; font-size: 13px; letter-spacing: 1px; white-space: nowrap; }
.tour .country { color: var(--ink-60); font-size: 14px; font-weight: 700; }
.tour .dep { color: var(--ink-40); font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 6px; }
.tour .dep svg { color: var(--blue); flex: none; }
.tour .price { margin-top: auto; padding-top: 12px; display: flex; align-items: baseline; gap: 9px; flex-wrap: wrap; }
.tour .price .new { font-family: var(--font-display); font-weight: 800; font-size: 24px; color: var(--orange-600); letter-spacing: -.02em; }
.tour .price .old { color: var(--ink-40); text-decoration: line-through; font-weight: 600; font-size: 15px; }
.tour .price .per { width: 100%; color: var(--ink-40); font-size: 12px; font-weight: 600; }
.tour .more { margin-top: 12px; }
.tour .more .btn { width: 100%; }

/* ===========================================================
   НАПРАВЛЕНИЯ — стеклянные плитки с фото
   =========================================================== */
.dests { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 210px; grid-auto-flow: dense; gap: clamp(13px, 1.6vw, 18px); }
.dest { position: relative; border-radius: var(--r-lg); overflow: hidden; display: flex; align-items: flex-end; color: #fff; box-shadow: var(--sh-soft); border: 1px solid var(--glass-brd-soft); isolation: isolate; }
.dest.wide { grid-column: span 2; }
.dest.tall { grid-row: span 2; }
.dest img, .dest .ph { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); z-index: 0; }
.dest::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(11,40,66,0) 38%, rgba(11,40,66,.8) 100%); }
.dest:hover img { transform: scale(1.08); }
.dest .body { position: relative; z-index: 2; margin: 14px; padding: 12px 16px; width: calc(100% - 28px); border-radius: var(--r-md); background: rgba(255,255,255,.14); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,.28); }
.dest .body h3 { font-size: 20px; }
.dest .body .c { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.88); margin-top: 2px; }

/* ===========================================================
   УСЛУГИ — стеклянные карточки
   =========================================================== */
.services { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(13px, 1.8vw, 20px); }
.svc {
  border-radius: var(--r-lg); padding: 24px;
  background: var(--glass-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft);
  box-shadow: var(--sh-soft);
  display: flex; gap: 16px; align-items: flex-start;
  transition: transform .3s var(--ease), box-shadow .3s;
}
.svc:hover { transform: translateY(-4px); box-shadow: var(--sh-card); }
.svc .ic { flex: none; width: 54px; height: 54px; border-radius: 16px; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg, var(--blue-light), var(--blue)); box-shadow: 0 8px 18px rgba(22,133,200,.3); }
.svc:nth-child(3n-1) .ic { background: linear-gradient(135deg, #FF9A4D, var(--orange)); box-shadow: 0 8px 18px rgba(255,106,0,.3); }
.svc:nth-child(3n) .ic { background: linear-gradient(135deg, #38C0A0, #15998A); box-shadow: 0 8px 18px rgba(21,153,138,.3); }
.svc h3 { font-size: 18px; }
.svc p { color: var(--ink-60); font-size: 14px; margin-top: 5px; }

/* ===========================================================
   СТАТИСТИКА — стекло на синем свечении
   =========================================================== */
.stats-wrap { position: relative; }
.stats {
  border-radius: var(--r-xl); overflow: hidden;
  background: linear-gradient(120deg, rgba(12,92,144,.92), rgba(22,133,200,.86) 55%, rgba(42,169,224,.82));
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid rgba(255,255,255,.28);
  box-shadow: var(--sh-card);
  color: #fff; display: grid; grid-template-columns: repeat(4, 1fr);
  position: relative;
}
.stats::before { content: ""; position: absolute; right: -60px; top: -60px; width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,.2), transparent 70%); }
.stat { padding: clamp(28px, 4vw, 46px) 26px; text-align: center; position: relative; z-index: 2; }
.stat + .stat { border-left: 1px solid rgba(255,255,255,.22); }
.stat b { font-family: var(--font-display); font-weight: 800; font-size: clamp(34px, 4.6vw, 54px); display: block; letter-spacing: -.03em; white-space: nowrap; }
.stat b .o { color: #FFC07A; }
.stat > span { font-weight: 700; font-size: 14.5px; color: rgba(255,255,255,.9); margin-top: 6px; display: block; }

/* ===========================================================
   ОТЗЫВЫ
   =========================================================== */
.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 2vw, 22px); }
.rev {
  border-radius: var(--r-lg); padding: 26px;
  background: var(--glass-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft);
  box-shadow: var(--sh-soft);
  display: flex; flex-direction: column; gap: 13px; position: relative;
}
.rev .mark { position: absolute; top: 16px; right: 22px; font-family: Georgia, serif; font-size: 56px; line-height: .5; color: rgba(255,106,0,.18); }
.rev .st { color: #FFB100; letter-spacing: 2px; }
.rev p { font-size: 16px; color: var(--ink); }
.rev .who { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.rev .av { width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(135deg, var(--blue-light), var(--blue)); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; flex: none; }
.rev .who b { display: block; font-weight: 800; }
.rev .who span { color: var(--ink-40); font-size: 13px; font-weight: 700; }

/* ===========================================================
   НОВОСТИ
   =========================================================== */
.news { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 2vw, 22px); }
.post {
  border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column;
  background: var(--glass-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-soft);
  box-shadow: var(--sh-soft);
  transition: transform .3s var(--ease), box-shadow .3s;
}
.post:hover { transform: translateY(-5px); box-shadow: var(--sh-card); }
.post .media { aspect-ratio: 16/9; overflow: hidden; }
.post .media img, .post .media .ph { width: 100%; height: 100%; object-fit: cover; transition: transform .55s var(--ease); }
.post:hover .media img { transform: scale(1.06); }
.post .body { padding: 18px 20px 22px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.post .date { color: var(--orange-600); font-weight: 800; font-size: 12.5px; letter-spacing: .04em; text-transform: uppercase; }
.post h3 { font-size: 19px; }
.post .read { margin-top: auto; font-weight: 800; color: var(--blue-900); display: inline-flex; align-items: center; gap: 7px; font-size: 14px; }
.post:hover .read .a { transform: translateX(4px); }
.post .read .a { transition: transform .3s var(--ease); }

/* ===========================================================
   CTA — стеклянный оранжевый
   =========================================================== */
.cta-wrap { position: relative; }
.cta {
  border-radius: var(--r-xl); overflow: hidden; position: relative;
  background: linear-gradient(120deg, rgba(255,106,0,.94), rgba(255,138,56,.9));
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid rgba(255,255,255,.3);
  box-shadow: var(--sh-card); color: #fff;
}
.cta::after { content: ""; position: absolute; left: -50px; bottom: -110px; width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,.22), transparent 70%); }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; padding: clamp(34px, 5vw, 60px); position: relative; z-index: 2; }
.cta h2 { color: #fff; font-size: clamp(28px, 4vw, 46px); max-width: 18ch; }
.cta p { color: rgba(255,255,255,.94); margin-top: 10px; font-size: 18px; }
.cta-actions { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.cta-actions .btn-white { background: #fff; color: var(--orange-600); }
.cta-actions .btn-white:hover { transform: translateY(-2px); box-shadow: var(--sh-soft); }
.cta-phone { font-family: var(--font-display); font-weight: 800; font-size: clamp(23px, 3vw, 31px); color: #fff; letter-spacing: -.02em; }
.cta-phone span { display: block; font-family: var(--font-body); font-size: 13px; font-weight: 700; letter-spacing: .04em; opacity: .9; margin-top: 2px; }

/* ===========================================================
   ФУТЕР — стеклянный синий
   =========================================================== */
.foot { margin-top: clamp(40px, 6vw, 70px); position: relative; }
.foot-card {
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  background: linear-gradient(135deg, #2AA9E0 0%, #1685C8 48%, #0C5C90 100%);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.82);
  padding: clamp(40px, 5vw, 64px) var(--gut) 28px;
}
.foot-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.3fr; gap: 36px; max-width: var(--maxw); margin-inline: auto; }
.foot-logo { background: #fff; padding: 10px 14px; border-radius: var(--r-sm); display: inline-block; }
.foot-logo img { height: 42px; }
.foot-slogan { margin-top: 18px; font-size: 16px; color: #fff; max-width: 30ch; font-weight: 600; }
.foot-soc { display: flex; gap: 9px; margin-top: 16px; }
.foot-soc a { width: 40px; height: 40px; border-radius: 12px; background: rgba(255,255,255,.14); display: grid; place-items: center; color: #fff; transition: background .2s, transform .15s; }
.foot-soc a:hover { background: var(--orange); transform: translateY(-2px); }
.foot h4 { color: #fff; font-size: 15px; margin-bottom: 15px; }
.foot ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.foot ul a { color: rgba(255,255,255,.8); font-size: 15px; transition: color .2s, padding-left .2s; }
.foot ul a:hover { color: var(--orange); padding-left: 4px; }
.foot .fc { display: flex; flex-direction: column; gap: 13px; font-size: 14.5px; }
.foot .fc .fp { font-family: var(--font-display); font-weight: 800; font-size: 21px; color: #fff; }
.foot .fc .row { display: flex; gap: 9px; align-items: flex-start; }
.foot .fc .row svg { flex: none; color: var(--blue-light); margin-top: 3px; }
.foot-bottom { margin-top: 40px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.16); display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: 13px; color: rgba(255,255,255,.6); max-width: var(--maxw); margin-inline: auto; }
.foot-bottom a { color: rgba(255,255,255,.72); }
.foot-bottom a:hover { color: #fff; }

/* ===========================================================
   Переключатель вариантов
   =========================================================== */
.variant-switch {
  position: fixed; left: 16px; bottom: 16px; z-index: 200;
  display: flex; align-items: center; gap: 8px;
  background: var(--glass-strong); -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd); border-radius: 999px; padding: 7px 8px 7px 15px;
  box-shadow: var(--sh-card); font-weight: 800; font-size: 11.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--ink);
}
.variant-switch a { background: rgba(255,255,255,.55); color: var(--ink); padding: 8px 12px; border-radius: 999px; border: 1px solid var(--glass-brd-soft); transition: background .2s; }
.variant-switch a:hover { background: #fff; }
.variant-switch a.cur { background: linear-gradient(135deg, #FF8A3D, var(--orange)); color: #fff; border-color: transparent; }

/* ===========================================================
   Плейсхолдеры изображений
   =========================================================== */
.ph { position: relative; background: linear-gradient(135deg, var(--blue-light), var(--blue-900)); display: grid; place-items: center; }
.ph[data-k="beach"] { background: linear-gradient(135deg, #34C6F0, #1685C8); }
.ph[data-k="mount"] { background: linear-gradient(135deg, #6FA8D6, #2C4B66); }
.ph[data-k="city"] { background: linear-gradient(135deg, #FF9A4D, #ED5E00); }
.ph[data-k="exotic"] { background: linear-gradient(135deg, #38C0A0, #15998A); }
.ph[data-k="cruise"] { background: linear-gradient(135deg, #2AA9E0, #0C5C90); }
.ph[data-k="spa"] { background: linear-gradient(135deg, #B79CE0, #6E54B5); }
.ph::after { content: attr(data-l); color: rgba(255,255,255,.9); font-family: var(--font-display); font-weight: 700; font-size: 14px; letter-spacing: .03em; }

/* ===========================================================
   Reveal
   =========================================================== */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
  .reveal.in { opacity: 1; transform: none; }
}

/* ===========================================================
   АДАПТИВ
   =========================================================== */
@media (max-width: 1180px) {
  .head nav, .head .right { display: none; }
  .burger { display: flex; }
}
@media (max-width: 1080px) {
  .head nav, .head .right { display: none; }
  .burger { display: flex; }
  .cards { grid-template-columns: repeat(2, 1fr); }
  .dests { grid-template-columns: repeat(2, 1fr); }
  .services { grid-template-columns: repeat(2, 1fr); }
  .reviews, .news { grid-template-columns: 1fr 1fr; }
  .foot-top { grid-template-columns: 1fr 1fr; gap: 30px; }
}
@media (max-width: 860px) {
  .f, .f.from, .f.country, .f.cls, .f-submit { grid-column: span 6; }
  .stats { grid-template-columns: 1fr 1fr; }
  .stat:nth-child(3) { border-left: none; }
  .stat:nth-child(n+3) { border-top: 1px solid rgba(255,255,255,.22); }
  .sec-head { flex-direction: column; align-items: flex-start; }
  .sec-head .l { max-width: 100%; }
}
@media (max-width: 640px) {
  .cards { grid-template-columns: 1fr; }
  .dests { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .services { grid-template-columns: 1fr; }
  .reviews, .news { grid-template-columns: 1fr; }
  .reviews .rev:nth-child(n+3) { display: none; }
  .news .post:last-child { display: none; }
  .foot-top { grid-template-columns: 1fr; }
  .f, .f.from, .f.country, .f.cls, .f-submit { grid-column: span 12; }
  .hero-content { padding: 22px; }
}

/* ===== Модалка заявки + cookie-баннер (Блок 4/5) ===== */
body.modal-lock { overflow: hidden; }
.modal-scrim { position: fixed; inset: 0; background: rgba(12,49,80,.45); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); z-index: 200; }
.modal-scrim[hidden], .modal[hidden], .cookie[hidden] { display: none; }
.modal { position: fixed; z-index: 201; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: min(440px, calc(100vw - 32px)); max-height: calc(100vh - 32px); overflow: auto;
  background: var(--glass-strong); -webkit-backdrop-filter: var(--blur-lg); backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-brd); border-radius: var(--r-lg); box-shadow: var(--sh-pop); padding: 28px 26px; }
.modal-x { position: absolute; top: 10px; right: 14px; border: none; background: none; font-size: 28px; line-height: 1; color: var(--ink-60); cursor: pointer; }
.modal-x:hover { color: var(--orange-600); }
.modal h3 { font-size: 22px; margin-bottom: 4px; }
.modal-sub { color: var(--ink-60); font-size: 14.5px; margin-bottom: 18px; }
#orderForm { display: flex; flex-direction: column; gap: 13px; }
.fld { display: flex; flex-direction: column; gap: 6px; font-size: 12.5px; font-weight: 800; letter-spacing: .02em; color: var(--ink-60); }
.fld input, .fld textarea { font-family: var(--font-body); font-weight: 600; font-size: 15px; color: var(--ink);
  padding: 12px 14px; border: 1.5px solid rgba(12,49,80,.14); border-radius: var(--r-sm);
  background: rgba(255,255,255,.7); outline: none; transition: border-color .2s; }
.fld textarea { resize: vertical; }
.fld input:focus, .fld textarea:focus { border-color: var(--blue); }
.consent { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--ink-60); font-weight: 600; line-height: 1.45; cursor: pointer; }
.consent input { margin-top: 2px; flex: none; width: 17px; height: 17px; accent-color: var(--orange); }
.consent a { color: var(--blue); text-decoration: underline; }
#orderForm .btn[disabled] { opacity: .5; cursor: not-allowed; }
.form-note { font-size: 14px; font-weight: 700; padding: 10px 12px; border-radius: var(--r-sm); }
.form-note.ok { background: rgba(40,169,224,.15); color: var(--blue-900); }
.form-note.err { background: rgba(255,106,0,.14); color: var(--orange-600); }

.cookie { position: fixed; left: 50%; bottom: 16px; transform: translateX(-50%) translateY(160%);
  width: min(900px, calc(100vw - 24px)); z-index: 150;
  display: flex; gap: 16px; align-items: center; justify-content: space-between; flex-wrap: wrap;
  background: var(--glass-strong); -webkit-backdrop-filter: var(--blur-lg); backdrop-filter: var(--blur-lg);
  border: 1px solid var(--glass-brd); border-radius: var(--r-md); box-shadow: var(--sh-pop); padding: 14px 18px; }
.cookie.show { transform: translateX(-50%) translateY(0); }
.cookie span { font-size: 13.5px; color: var(--ink); font-weight: 600; flex: 1 1 340px; }
.cookie a { color: var(--blue); text-decoration: underline; }
.cookie .btn { white-space: nowrap; }

/* ===== Страница политики + реквизиты в подвале (Блок 5) ===== */
.legal-wrap { max-width: 860px; }
.legal-title { font-size: clamp(28px, 4.4vw, 46px); margin: 16px 0 10px; }
.legal h2 { font-size: 20px; margin: 28px 0 8px; color: var(--ink); }
.legal p { color: var(--ink-60); margin-bottom: 10px; }
.legal ul { color: var(--ink-60); margin: 0 0 12px; padding-left: 22px; }
.legal li { margin-bottom: 5px; }
.legal a { color: var(--blue); text-decoration: underline; }
.legal-note { font-size: 13px; color: var(--ink-40); margin-top: 24px; font-style: italic; }
.foot-req { font-size: 12.5px; color: rgba(255,255,255,.58); line-height: 1.55; padding: 16px 0 4px; border-top: 1px solid rgba(255,255,255,.14); margin-top: 8px; }

/* footer phone hover + requisites readability (dev fix) */
.foot .fc .fp { transition: color .2s; }
.foot .fc .fp:hover { color: var(--orange); }
.foot-req { color: rgba(255,255,255,.66); }

/* footer requisites: align with content grid */
.foot-req { max-width: var(--maxw); margin: 18px auto 0; padding: 0; border-top: none; }

/* Контакты: экстренный телефон + карта Яндекс */
.emergency { display: flex; align-items: center; gap: 18px; margin-bottom: 24px; padding: 18px 24px; border-radius: var(--r-lg); background: linear-gradient(135deg, #FF8A3D, var(--orange)); color: #fff; box-shadow: 0 14px 30px rgba(255,106,0,.34); transition: transform .2s var(--ease), box-shadow .2s; }
.emergency:hover { transform: translateY(-2px); box-shadow: 0 18px 38px rgba(255,106,0,.4); }
.emergency .em-ic { flex: none; width: 52px; height: 52px; border-radius: 50%; background: rgba(255,255,255,.2); display: grid; place-items: center; }
.emergency .em-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.emergency .em-label { font-size: 13.5px; font-weight: 700; opacity: .95; }
.emergency .em-phone { font-family: var(--font-display); font-weight: 800; font-size: clamp(22px, 3vw, 30px); letter-spacing: -.01em; }
.emergency .em-cta { margin-left: auto; white-space: nowrap; font-weight: 800; background: rgba(255,255,255,.18); padding: 11px 18px; border-radius: 999px; transition: background .2s; }
.emergency:hover .em-cta { background: rgba(255,255,255,.32); }
.map .ymap { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
@media (max-width: 560px) { .emergency { flex-wrap: wrap; gap: 12px; } .emergency .em-cta { margin-left: 0; width: 100%; text-align: center; } }

/* emergency: крупнее текст + анимация фона */
.emergency { position: relative; overflow: hidden;
  background: linear-gradient(120deg, #FF9A4D, #FF6A00, #FF8024, #FF6A00);
  background-size: 220% 220%; animation: emGradient 9s ease infinite; }
.emergency::before { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: linear-gradient(100deg, transparent 20%, rgba(255,255,255,.28) 50%, transparent 80%);
  transform: translateX(-120%) skewX(-16deg); animation: emShine 5s ease-in-out infinite; }
.emergency .em-ic, .emergency .em-body, .emergency .em-cta { position: relative; z-index: 1; }
.emergency .em-ic { animation: emPulse 2.2s ease-in-out infinite; }
.emergency .em-label { font-size: clamp(15px, 1.7vw, 18px); font-weight: 800; opacity: 1; letter-spacing: .01em; }
@keyframes emGradient { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
@keyframes emShine { 0% { transform: translateX(-120%) skewX(-16deg); } 55%, 100% { transform: translateX(120%) skewX(-16deg); } }
@keyframes emPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(255,255,255,.4); } 70% { box-shadow: 0 0 0 14px rgba(255,255,255,0); } }
@media (prefers-reduced-motion: reduce) { .emergency, .emergency::before, .emergency .em-ic { animation: none; } .emergency::before { display: none; } }

/* Яндекс-отзывы виджет */
.ya-reviews { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-card); border: 1px solid var(--glass-brd-soft); background: #fff; }
.ya-reviews iframe { width: 100%; height: 560px; border: 0; display: block; }
