/**
 * inner-ru-2027.css — общий premium shell внутренних RU-страниц.
 * Подключать после home-ru-unified.css; body: class="wm-2027-home wm-2027-inner".
 */

body.wm-2027-inner {
  background: var(--wm-bg-deep);
  color: var(--wm-text);
}

.wm-inner-orbit {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
  opacity: 0.55;
}
.wm-inner-orbit::before,
.wm-inner-orbit::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(62, 232, 200, 0.12);
  animation: wm-inner-orbit-spin 120s linear infinite;
}
.wm-inner-orbit::before {
  width: min(140vw, 900px);
  height: min(140vw, 900px);
  top: -40%;
  right: -35%;
  box-shadow: 0 0 80px rgba(91, 140, 255, 0.06);
}
.wm-inner-orbit::after {
  width: min(100vw, 640px);
  height: min(100vw, 640px);
  bottom: -25%;
  left: -20%;
  animation-duration: 90s;
  animation-direction: reverse;
  border-color: rgba(91, 140, 255, 0.1);
}
@keyframes wm-inner-orbit-spin {
  to {
    transform: rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .wm-inner-orbit::before,
  .wm-inner-orbit::after {
    animation: none;
  }
}

.wm-inner-main {
  position: relative;
  z-index: 1;
  padding-bottom: var(--wm-space-2xl);
}

/* --- Inner hero (без particles) --- */
.wm-inner-hero {
  position: relative;
  min-height: clamp(300px, 38vh, 480px);
  padding: clamp(4.75rem, 11vw, 6rem) clamp(1.25rem, 4vw, 3rem) clamp(2rem, 5vw, 3rem);
  overflow: hidden;
  isolation: isolate;
}
.wm-inner-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 70% 45% at 15% 25%, rgba(91, 140, 255, 0.16), transparent 55%),
    radial-gradient(ellipse 55% 40% at 90% 20%, rgba(62, 232, 200, 0.07), transparent 48%),
    linear-gradient(180deg, var(--wm-bg-deep) 0%, var(--wm-bg) 50%, var(--wm-bg-deep) 100%);
}
.wm-inner-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1100px;
  margin: 0 auto;
}
.wm-inner-hero__eyebrow {
  font-family: var(--wm-font-mono);
  font-size: var(--wm-text-small);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wm-mint);
  margin: 0 0 var(--wm-space-md);
}
.wm-inner-hero__title {
  font-family: var(--wm-font-display);
  font-size: clamp(1.85rem, 4vw, 2.85rem);
  font-weight: 700;
  line-height: var(--wm-leading-tight);
  letter-spacing: -0.03em;
  margin: 0 0 var(--wm-space-md);
}
.wm-inner-hero__title em {
  font-style: normal;
  color: var(--wm-accent);
  text-shadow: 0 0 36px var(--wm-accent-soft);
}
.wm-inner-hero__lead {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  line-height: var(--wm-leading-body);
  color: rgba(210, 218, 232, 0.9);
  max-width: 40rem;
  margin: 0 0 var(--wm-space-lg);
}
.wm-inner-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--wm-space-md);
}

/* --- Sections --- */
.wm-inner-section {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(2.5rem, 6vw, 4rem) clamp(1.25rem, 4vw, 3rem);
}
.wm-inner-section--tight {
  padding-top: clamp(1.5rem, 4vw, 2.5rem);
}
.wm-inner-section__head {
  margin-bottom: var(--wm-space-xl);
}
.wm-inner-section__kicker {
  font-family: var(--wm-font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wm-mint);
  margin: 0 0 var(--wm-space-sm);
}
.wm-inner-section__title {
  font-family: var(--wm-font-display);
  font-size: var(--wm-text-h2);
  font-weight: 700;
  margin: 0 0 var(--wm-space-sm);
}
.wm-inner-section__lead {
  color: var(--wm-text-muted);
  font-size: 1.05rem;
  line-height: var(--wm-leading-body);
  max-width: 42rem;
  margin: 0;
}

/* Согласование прайса: главная #prices ↔ эта страница */
p.wm-pricing-sync-note {
  text-align: center;
  max-width: 46rem;
  margin: 1.25rem auto 0;
  padding: 0 clamp(0.5rem, 2vw, 1rem);
  font-size: 0.92rem;
  line-height: 1.58;
  color: rgba(175, 186, 210, 0.92);
}
p.wm-pricing-sync-note a {
  color: var(--wm-accent);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}
p.wm-pricing-sync-note a:hover {
  color: #8ab4ff;
}

/* --- Glass cards --- */
.wm-inner-card {
  background: var(--wm-surface-glass);
  backdrop-filter: blur(var(--wm-blur-glass)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--wm-blur-glass)) saturate(140%);
  border: 1px solid var(--wm-border);
  border-radius: var(--wm-radius-lg);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  box-shadow: var(--wm-shadow-soft);
  transition:
    border-color var(--wm-duration) var(--wm-ease-out),
    box-shadow var(--wm-duration) var(--wm-ease-out),
    transform var(--wm-duration) var(--wm-ease-out);
}
a.wm-inner-card {
  display: block;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.wm-inner-card:hover {
  border-color: rgba(62, 232, 200, 0.22);
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(91, 140, 255, 0.12);
  transform: translateY(-2px);
}
@media (prefers-reduced-motion: reduce) {
  .wm-inner-card:hover {
    transform: none;
  }
}

.wm-inner-grid {
  display: grid;
  gap: var(--wm-space-lg);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .wm-inner-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .wm-inner-grid--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 960px) {
  .wm-inner-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.wm-inner-list {
  margin: 0;
  padding-left: 1.15rem;
  color: var(--wm-text-muted);
  line-height: 1.65;
}
.wm-inner-list li {
  margin-bottom: 0.35rem;
}

.wm-inner-pill {
  display: inline-block;
  font-family: var(--wm-font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  background: var(--wm-mint-soft);
  color: var(--wm-mint);
  border: 1px solid rgba(62, 232, 200, 0.25);
  margin-bottom: var(--wm-space-sm);
}
.wm-inner-pill--muted {
  background: rgba(255, 255, 255, 0.04);
  color: var(--wm-text-muted);
  border-color: var(--wm-border);
}

/* --- Portfolio filters --- */
.wm-inner-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: var(--wm-space-xl);
  max-width: 100%;
}
.wm-inner-filter {
  font-family: var(--wm-font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.5rem 0.85rem;
  min-height: 44px;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  border-radius: 999px;
  border: 1px solid var(--wm-border);
  background: rgba(255, 255, 255, 0.03);
  color: var(--wm-text-muted);
  cursor: pointer;
  transition: background var(--wm-duration), border-color var(--wm-duration), color var(--wm-duration);
}
.wm-inner-filter:hover,
.wm-inner-filter.is-active {
  color: var(--wm-text);
  border-color: rgba(62, 232, 200, 0.35);
  background: rgba(62, 232, 200, 0.08);
}

.wm-portfolio-card[data-type] {
  transition: opacity var(--wm-duration), transform var(--wm-duration);
}
.wm-portfolio-card.is-hidden {
  display: none;
}

.wm-inner-card__title {
  font-family: var(--wm-font-display);
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0 0 var(--wm-space-sm);
}
.wm-inner-card__meta {
  font-size: 0.85rem;
  color: rgba(220, 228, 240, 0.88);
  margin-bottom: var(--wm-space-md);
}
.wm-inner-card__body {
  font-size: 0.95rem;
  color: var(--wm-text-muted);
  line-height: 1.6;
  margin: 0 0 var(--wm-space-md);
}
.wm-inner-card__stack {
  font-family: var(--wm-font-mono);
  font-size: 0.78rem;
  color: var(--wm-text-faint);
  margin: 0 0 var(--wm-space-md);
}
.wm-inner-card__foot {
  display: flex;
  flex-wrap: wrap;
  gap: var(--wm-space-sm);
  align-items: center;
  justify-content: space-between;
}

/* --- Pricing calculator --- */
.wm-calc {
  display: grid;
  gap: var(--wm-space-xl);
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .wm-calc {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}
.wm-calc__form .wm-inner-card {
  margin-bottom: var(--wm-space-md);
}
.wm-calc__row {
  margin-bottom: var(--wm-space-lg);
}
.wm-calc__row:last-child {
  margin-bottom: 0;
}
.wm-calc__label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--wm-text-muted);
  margin-bottom: var(--wm-space-sm);
}
.wm-calc__options {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.wm-calc__options label {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.95rem;
  color: var(--wm-text-muted);
  padding: 0.4rem 0.5rem;
  border-radius: var(--wm-radius-sm);
  border: 1px solid transparent;
  transition: background var(--wm-duration), border-color var(--wm-duration);
}
.wm-calc__options label:hover {
  background: rgba(255, 255, 255, 0.04);
}
.wm-calc__options input {
  margin-top: 0.2rem;
  accent-color: var(--wm-mint);
}
.wm-calc__options input:checked + span {
  color: var(--wm-text);
}
.wm-calc__result .wm-inner-card {
  position: sticky;
  top: 96px;
}
@media (max-width: 1023px) {
  .wm-calc__result .wm-inner-card {
    position: relative;
    top: auto;
  }
}
.wm-calc__result-value {
  font-family: var(--wm-font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  margin: 0 0 var(--wm-space-sm);
  color: var(--wm-mint);
  transition: opacity 0.2s ease;
  word-break: break-word;
  hyphens: auto;
}
.wm-calc__result-meta {
  font-size: 0.95rem;
  color: var(--wm-text-muted);
  line-height: 1.55;
  margin: 0 0 var(--wm-space-md);
}
.wm-calc__disclaimer {
  font-size: 0.8rem;
  color: var(--wm-text-faint);
  line-height: 1.5;
  margin: var(--wm-space-lg) 0 0;
  padding-top: var(--wm-space-md);
  border-top: 1px solid var(--wm-border);
}

/* --- Contacts command center --- */
.wm-contact-cc {
  display: grid;
  gap: var(--wm-space-lg);
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .wm-contact-cc {
    grid-template-columns: 1.1fr 0.9fr;
  }
}
.wm-contact-cc__panel {
  min-height: 200px;
}
.wm-contact-cc__channels a {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  min-height: 48px;
  box-sizing: border-box;
  border-radius: var(--wm-radius-md);
  border: 1px solid var(--wm-border);
  text-decoration: none;
  color: var(--wm-text);
  margin-bottom: 0.5rem;
  word-break: break-word;
  transition: border-color var(--wm-duration), background var(--wm-duration);
}
.wm-contact-cc__channels a:hover {
  border-color: rgba(91, 140, 255, 0.35);
  background: rgba(91, 140, 255, 0.06);
}

/* --- Brief forms --- */
.wm-brief fieldset {
  border: 1px solid var(--wm-border);
  border-radius: var(--wm-radius-md);
  padding: clamp(1rem, 4vw, var(--wm-space-lg));
  margin: 0 0 var(--wm-space-lg);
  background: rgba(0, 0, 0, 0.15);
  max-width: 100%;
  box-sizing: border-box;
}
.wm-brief legend {
  font-family: var(--wm-font-display);
  font-weight: 600;
  padding: 0 0.5rem;
}
.wm-brief label {
  display: block;
  font-size: 0.85rem;
  color: var(--wm-text-muted);
  margin-bottom: 0.35rem;
}
.wm-brief input[type="text"],
.wm-brief input[type="email"],
.wm-brief textarea,
.wm-brief select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-bottom: var(--wm-space-md);
  padding: 0.65rem 0.85rem;
  border-radius: var(--wm-radius-sm);
  border: 1px solid var(--wm-border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--wm-text);
  font-family: var(--wm-font-sans);
  font-size: 1rem;
}
.wm-brief textarea {
  min-height: 100px;
  resize: vertical;
}

/* --- Reveal: inner extends home unified when both classes on body --- */
body.wm-2027-inner .wm-inner-reveal {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 0.55s var(--wm-ease-out),
    transform 0.55s var(--wm-ease-out);
}
body.wm-2027-inner .wm-inner-reveal.is-visible {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  body.wm-2027-inner .wm-inner-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* P0 mobile fallback: portfolio cards always visible regardless of IO/scroll state.
 * IntersectionObserver+reveal on mobile is fragile (async header reflow, iOS cold-load
 * quirks, scroll-into-rootMargin not firing). На mobile карточки портфолио показываем
 * сразу; reveal-анимация — только bonus на desktop. Не ломает desktop reveal на других
 * элементах (.wm-inner-section, .wm-inner-card и т.п.). */
@media (max-width: 768px) {
  body.wm-2027-inner .wm-pp-card.wm-inner-reveal,
  body.wm-2027-inner .wm-portfolio-card.wm-inner-reveal {
    opacity: 1;
    transform: none;
  }
}

/* ============================================================
   Inner hero visuals (per-page backgrounds)
   ============================================================ */
.wm-inner-hero--visual {
  min-height: clamp(380px, 46vh, 560px);
}

/* Картинка на ::before + transform (Ken Burns) — стабильнее анимации background-position по нескольким слоям */
.wm-inner-hero--visual .wm-inner-hero__bg {
  background: linear-gradient(180deg, var(--wm-bg-deep) 0%, var(--wm-bg) 50%, var(--wm-bg-deep) 100%);
  overflow: hidden;
}

.wm-inner-hero--visual .wm-inner-hero__bg::before {
  content: "";
  position: absolute;
  inset: -5%;
  z-index: 0;
  background-image: var(--wm-inner-hero-image, none);
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  transform-origin: 70% 45%;
  animation: wm-inner-hero-kenburns 22s ease-in-out infinite alternate;
  will-change: transform;
}

.wm-inner-hero--visual .wm-inner-hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(7, 8, 12, 0.92) 0%, rgba(7, 8, 12, 0.78) 42%, rgba(7, 8, 12, 0.25) 72%, rgba(7, 8, 12, 0.05) 100%),
    radial-gradient(ellipse 70% 45% at 15% 25%, rgba(91, 140, 255, 0.16), transparent 55%);
}

@media (max-width: 720px) {
  .wm-inner-hero--visual .wm-inner-hero__bg::after {
    background:
      linear-gradient(180deg, rgba(7, 8, 12, 0.9) 0%, rgba(7, 8, 12, 0.55) 55%, rgba(7, 8, 12, 0.95) 100%),
      radial-gradient(ellipse 70% 45% at 15% 25%, rgba(91, 140, 255, 0.12), transparent 55%);
  }
}

@keyframes wm-inner-hero-kenburns {
  0% {
    transform: scale(1) translate(0, 0);
  }
  100% {
    transform: scale(1.08) translate(-1.5%, 0.5%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .wm-inner-hero--visual .wm-inner-hero__bg::before {
    animation: none;
  }
}

/* glow pulse on hero eyebrow */
.wm-inner-hero--visual .wm-inner-hero__eyebrow {
  position: relative;
  display: inline-block;
  padding: 0.25rem 0.7rem;
  border-radius: 999px;
  background: rgba(62, 232, 200, 0.08);
  border: 1px solid rgba(62, 232, 200, 0.25);
  animation: wm-inner-eyebrow-pulse 4.5s ease-in-out infinite;
}
@keyframes wm-inner-eyebrow-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(62, 232, 200, 0.0); }
  50%      { box-shadow: 0 0 22px 0 rgba(62, 232, 200, 0.22); }
}
@media (prefers-reduced-motion: reduce) {
  .wm-inner-hero--visual .wm-inner-hero__eyebrow { animation: none; }
}

/* Per-page hero image bindings */
.wm-inner-hero--visual[data-inner-page="portfolio"]          { --wm-inner-hero-image: url("../../images/inner/portfolio-hero.png"); }
.wm-inner-hero--visual[data-inner-page="services"]           { --wm-inner-hero-image: url("../../images/inner/services-hero.png"); }
.wm-inner-hero--visual[data-inner-page="pricing"]            { --wm-inner-hero-image: url("../../images/inner/pricing-hero.png"); }
.wm-inner-hero--visual[data-inner-page="mobile-app"]         { --wm-inner-hero-image: url("../../images/inner/mobile-app-hero.png"); }
.wm-inner-hero--visual[data-inner-page="web-platform"]       { --wm-inner-hero-image: url("../../images/inner/web-platform-hero.png"); }
.wm-inner-hero--visual[data-inner-page="telegram-bot"]       { --wm-inner-hero-image: url("../../images/inner/telegram-bot-hero.png"); }
.wm-inner-hero--visual[data-inner-page="ai-automation"]      { --wm-inner-hero-image: url("../../images/inner/ai-automation-hero.png"); }
.wm-inner-hero--visual[data-inner-page="ux-ui"]              { --wm-inner-hero-image: url("../../images/inner/ux-ui-hero.png"); }
.wm-inner-hero--visual[data-inner-page="landing"]            { --wm-inner-hero-image: url("../../images/inner/landing-hero.png"); }
.wm-inner-hero--visual[data-inner-page="contact"]            { --wm-inner-hero-image: url("../../images/inner/contact-hero.png"); }
.wm-inner-hero--visual[data-inner-page="brief-product"]      { --wm-inner-hero-image: url("../../images/inner/brief-product-hero.png"); }
.wm-inner-hero--visual[data-inner-page="brief-automation"]   { --wm-inner-hero-image: url("../../images/inner/brief-automation-hero.png"); }

/* ============================================================
   Pricing estimator — compact premium layout
   ============================================================ */
.wm-estimator {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--wm-space-xl);
  align-items: start;
}
@media (min-width: 1024px) {
  .wm-estimator {
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 1fr);
    gap: var(--wm-space-2xl);
  }
}

/* Form wrapper as single premium glass panel */
.wm-estimator__form {
  position: relative;
  padding: clamp(1.25rem, 2.4vw, 1.9rem);
  border-radius: var(--wm-radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(ellipse 100% 60% at 0% 0%, rgba(62, 232, 200, 0.05), transparent 60%),
    radial-gradient(ellipse 90% 50% at 100% 100%, rgba(91, 140, 255, 0.05), transparent 60%),
    rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 18px 50px -20px rgba(0, 0, 0, 0.55);
  overflow: hidden;
}
.wm-estimator__form::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(62, 232, 200, 0.18), transparent 18%),
    linear-gradient(0deg, rgba(91, 140, 255, 0.12), transparent 24%);
  opacity: 0.45;
  pointer-events: none;
  mix-blend-mode: screen;
}

/* Progress track */
.wm-estimator__progress {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.35rem;
}
.wm-estimator__progress-track {
  flex: 1;
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
  position: relative;
}
.wm-estimator__progress-fill {
  display: block;
  height: 100%;
  width: 25%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(62, 232, 200, 0.9) 0%, rgba(91, 140, 255, 0.9) 100%);
  box-shadow: 0 0 18px rgba(62, 232, 200, 0.35);
  transition: width 0.45s var(--wm-ease-out);
}
.wm-estimator__progress-label {
  font-family: var(--wm-font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wm-text-faint);
}
@media (prefers-reduced-motion: reduce) {
  .wm-estimator__progress-fill { transition: none; }
}

/* Groups */
.wm-estimator__group + .wm-estimator__group,
.wm-estimator__grid {
  margin-top: 1.25rem;
}
.wm-estimator__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem 1.25rem;
}
@media (min-width: 768px) {
  .wm-estimator__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1024px) {
  .wm-estimator__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.wm-estimator__group {
  position: relative;
}
.wm-estimator__grid .wm-estimator__group + .wm-estimator__group {
  margin-top: 0;
}
.wm-estimator__group-head {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.55rem;
}
.wm-estimator__group-num {
  font-family: var(--wm-font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  color: var(--wm-mint);
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  background: rgba(62, 232, 200, 0.08);
  border: 1px solid rgba(62, 232, 200, 0.22);
}
.wm-estimator__group-label {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--wm-text);
}

/* Segmented chip control */
.wm-seg {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.wm-seg__chip {
  position: relative;
  cursor: pointer;
  user-select: none;
}
.wm-seg__chip input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.wm-seg__chip > span {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.8rem;
  font-family: var(--wm-font-sans);
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--wm-text-muted);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  transition:
    color 0.2s var(--wm-ease-out),
    background 0.25s var(--wm-ease-out),
    border-color 0.25s var(--wm-ease-out),
    box-shadow 0.3s var(--wm-ease-out),
    transform 0.2s var(--wm-ease-out);
}
.wm-seg__chip > span i {
  font-size: 0.82rem;
  color: var(--wm-mint);
  opacity: 0.8;
}
.wm-seg__chip:hover > span {
  color: var(--wm-text);
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(62, 232, 200, 0.25);
}
.wm-seg__chip input:focus-visible + span {
  outline: 2px solid rgba(62, 232, 200, 0.6);
  outline-offset: 2px;
}
.wm-seg__chip input:checked + span {
  color: #071014;
  background: linear-gradient(135deg, rgba(62, 232, 200, 0.95) 0%, rgba(91, 180, 255, 0.92) 100%);
  border-color: rgba(62, 232, 200, 0.7);
  box-shadow:
    0 0 0 1px rgba(62, 232, 200, 0.25),
    0 8px 24px -8px rgba(62, 232, 200, 0.55),
    0 0 22px rgba(91, 140, 255, 0.28);
  transform: translateY(-1px);
}
.wm-seg__chip input:checked + span i {
  color: #071014;
  opacity: 1;
}
.wm-seg--compact .wm-seg__chip > span {
  padding: 0.4rem 0.7rem;
  font-size: 0.82rem;
}
@media (prefers-reduced-motion: reduce) {
  .wm-seg__chip > span { transition: none; }
  .wm-seg__chip input:checked + span { transform: none; }
}

/* Result card */
.wm-estimator__result {
  position: relative;
}
@media (min-width: 1024px) {
  .wm-estimator__result {
    position: sticky;
    top: 96px;
  }
}
.wm-estimator__result-card {
  position: relative;
  padding: clamp(1.3rem, 2vw, 1.75rem);
  border-radius: var(--wm-radius-lg);
  border: 1px solid rgba(62, 232, 200, 0.22);
  background:
    radial-gradient(ellipse 80% 50% at 100% 0%, rgba(91, 140, 255, 0.12), transparent 60%),
    radial-gradient(ellipse 80% 50% at 0% 100%, rgba(62, 232, 200, 0.1), transparent 60%),
    linear-gradient(160deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.015) 100%);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  box-shadow:
    0 24px 60px -24px rgba(0, 0, 0, 0.7),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  overflow: hidden;
}
.wm-estimator__result-card::after {
  content: "";
  position: absolute;
  inset: -40% -40% auto auto;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle, rgba(62, 232, 200, 0.2) 0%, transparent 60%);
  filter: blur(16px);
  pointer-events: none;
  animation: wm-estimator-glow 8s ease-in-out infinite;
}
@keyframes wm-estimator-glow {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.8; }
  50%      { transform: translate(-10px, 10px) scale(1.1); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .wm-estimator__result-card::after { animation: none; }
}
.wm-estimator__result-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.wm-estimator__result-kicker {
  font-family: var(--wm-font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wm-mint);
}
.wm-estimator__result-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--wm-mint);
  box-shadow: 0 0 12px rgba(62, 232, 200, 0.7);
  animation: wm-estimator-dot 2.4s ease-in-out infinite;
}
@keyframes wm-estimator-dot {
  0%, 100% { opacity: 0.6; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.2); }
}
@media (prefers-reduced-motion: reduce) {
  .wm-estimator__result-dot { animation: none; }
}
.wm-estimator__result-stat-label {
  font-family: var(--wm-font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wm-text-faint);
  margin: 0 0 0.35rem;
}
.wm-estimator__result-value {
  font-family: var(--wm-font-display);
  font-size: clamp(1.6rem, 2.6vw, 2.15rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--wm-text);
  background: linear-gradient(135deg, #ffffff 0%, rgba(62, 232, 200, 0.92) 55%, rgba(91, 180, 255, 0.9) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin: 0 0 1.1rem;
  word-break: break-word;
  transition: opacity 0.25s var(--wm-ease-out);
}
.wm-estimator__result-value.is-pulse {
  animation: wm-estimator-pulse 0.5s var(--wm-ease-out);
}
@keyframes wm-estimator-pulse {
  0%   { opacity: 0.35; transform: translateY(4px); }
  100% { opacity: 1;    transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .wm-estimator__result-value.is-pulse { animation: none; }
}
.wm-estimator__result-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding-top: 0.9rem;
  margin-bottom: 1.2rem;
  border-top: 1px dashed rgba(255, 255, 255, 0.08);
}
@media (max-width: 520px) {
  .wm-estimator__result-row {
    grid-template-columns: 1fr;
  }
}
.wm-estimator__result-meta {
  font-family: var(--wm-font-sans);
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--wm-text);
  line-height: 1.35;
  margin: 0;
}
.wm-estimator__result-cta {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.1rem;
}
.wm-estimator__result-cta .wm-2027-btn {
  width: 100%;
  justify-content: center;
}
.wm-estimator__disclaimer {
  font-size: 0.74rem;
  line-height: 1.5;
  color: var(--wm-text-faint);
  margin: 0;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

/* =============================================================================
 * RU inner — Responsive Emergency Pass (mobile / tablet)
 * Scope: body.wm-2027-inner. Desktop-safe overrides below breakpoints.
 * ============================================================================= */

body.wm-2027-inner {
  overflow-x: clip;
}

.wm-inner-main,
.wm-inner-section,
.wm-inner-hero__inner {
  max-width: 100%;
}

@media (max-width: 1023px) {
  .wm-inner-section {
    padding-left: clamp(0.9rem, 4vw, 1.5rem);
    padding-right: clamp(0.9rem, 4vw, 1.5rem);
  }

  .wm-inner-hero {
    min-height: clamp(240px, 32vh, 400px);
    padding-left: clamp(1.25rem, 5vw, 1.85rem);
    padding-right: clamp(1.25rem, 5vw, 1.85rem);
  }

  .wm-inner-section {
    padding-inline: clamp(1.25rem, 5vw, 1.85rem);
  }

  .wm-inner-hero__title {
    font-size: clamp(1.45rem, 5.2vw, 2.4rem);
  }

  .wm-inner-hero__actions {
    gap: 0.65rem;
  }

  .wm-inner-hero__actions .wm-2027-btn {
    flex: 1 1 auto;
    min-width: min(100%, 12rem);
    justify-content: center;
  }

  .wm-inner-card {
    min-width: 0;
  }

  .wm-inner-grid {
    gap: clamp(0.85rem, 3vw, var(--wm-space-lg));
  }

  .wm-estimator {
    gap: var(--wm-space-lg);
  }

  .wm-estimator__form {
    padding: clamp(1rem, 3.5vw, 1.5rem);
  }
}

@media (max-width: 768px) {
  .wm-inner-hero--visual {
    min-height: clamp(220px, 36vh, 380px);
  }

  .wm-inner-hero--visual .wm-inner-hero__bg {
    opacity: 0.92;
  }

  .wm-inner-section__title {
    font-size: clamp(1.2rem, 4.5vw, 1.5rem);
  }

  .wm-inner-section__lead {
    font-size: 0.98rem;
  }

  .wm-seg__chip > span {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    min-height: 44px;
    box-sizing: border-box;
  }

  .wm-seg--compact .wm-seg__chip > span {
    padding: 0.5rem 0.65rem;
    font-size: 0.78rem;
  }
}

@media (max-width: 430px) {
  .wm-inner-hero--visual[data-inner-page="contact"] .wm-inner-hero__bg::before,
  .wm-inner-hero--visual[data-inner-page="brief-product"] .wm-inner-hero__bg::before,
  .wm-inner-hero--visual[data-inner-page="brief-automation"] .wm-inner-hero__bg::before {
    display: none !important;
  }

  .wm-inner-hero--visual[data-inner-page="contact"] .wm-inner-hero__bg::after,
  .wm-inner-hero--visual[data-inner-page="brief-product"] .wm-inner-hero__bg::after,
  .wm-inner-hero--visual[data-inner-page="brief-automation"] .wm-inner-hero__bg::after {
    background: linear-gradient(180deg, rgba(7, 8, 12, 0.94) 0%, rgba(7, 8, 12, 0.88) 100%);
  }

  .wm-inner-filters {
    gap: 0.4rem;
  }

  .wm-inner-filter {
    flex: 1 1 calc(50% - 0.25rem);
    min-width: calc(50% - 0.25rem);
    font-size: 0.8125rem;
  }
}

@media (max-width: 360px) {
  .wm-inner-filter {
    flex: 1 1 100%;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  body.wm-2027-inner .wm-inner-hero {
    min-height: clamp(210px, 30vh, 320px);
    padding: clamp(3.5rem, 12vw, 4.75rem) clamp(1.25rem, 5.5vw, 1.65rem) 1.25rem;
  }

  body.wm-2027-inner .wm-inner-section {
    padding-inline: clamp(1.25rem, 5.5vw, 1.65rem);
  }

  body.wm-2027-inner .wm-inner-card {
    padding: clamp(1.05rem, 4.5vw, 1.5rem);
    box-sizing: border-box;
    max-width: 100%;
  }

  body.wm-2027-inner .wm-inner-hero--visual {
    min-height: clamp(240px, 34vh, 380px);
  }

  body.wm-2027-inner .wm-inner-hero__title {
    font-size: clamp(1.35rem, 6.2vw, 2rem);
    margin-bottom: var(--wm-space-sm);
  }

  body.wm-2027-inner .wm-inner-hero__lead {
    font-size: clamp(0.88rem, 3.5vw, 1.02rem);
    margin-bottom: var(--wm-space-md);
  }

  body.wm-2027-inner .wm-inner-hero__eyebrow {
    margin-bottom: var(--wm-space-sm);
  }

  .wm-inner-hero__actions {
    flex-direction: column;
    align-items: center;
    gap: 0.55rem;
    width: 100%;
  }

  .wm-inner-hero__actions .wm-2027-btn {
    width: 100%;
    max-width: 340px;
    margin-inline: auto;
    justify-content: center;
    min-height: 44px;
    padding: 0.7rem 1.15rem;
    font-size: 0.95rem;
    border-radius: 12px;
  }
}

@media (max-width: 1000px) {
  html:has(body.wm-2027-home #menu.menu-open-open) {
    overflow: hidden;
  }
}

@media (max-width: 430px) {
  .wm-seg {
    gap: 0.35rem;
  }

  .wm-seg__chip {
    flex: 1 1 calc(50% - 0.2rem);
    min-width: 0;
  }

  .wm-seg__chip > span {
    width: 100%;
    justify-content: center;
    text-align: center;
    flex-wrap: wrap;
  }
}

@media (max-width: 380px) {
  .wm-seg__chip {
    flex: 1 1 100%;
  }
}

/* --- Estimator: solid mint value on narrow screens (gradient text contrast) --- */
@media (max-width: 520px) {
  .wm-estimator__result-value {
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
    -webkit-text-fill-color: var(--wm-mint);
    color: var(--wm-mint);
  }
}
