/**
 * Светлая премиум-стилистика (huly.io): воздух, bento, glow, glass.
 * Класс .site-premium на body.
 */

.site-premium {
  --bg-color: #f4f6f9;
  --surface: #ffffff;
  --surface-muted: #f8fafc;
  --text-color: #182e3d;
  --text-muted: #565f67;
  --border-color: rgba(24, 46, 61, 0.08);
  --shadow-soft: 0 8px 30px rgba(15, 35, 55, 0.06);
  --shadow-card: 0 20px 50px rgba(45, 128, 194, 0.1);
  --font: "Inter", "Manrope", system-ui, sans-serif;
  color-scheme: light;
}

body.site-premium {
  background: var(--bg-color);
  color: var(--text-color);
}

/* Header — светлый glass-pill */
.site-premium .site-header {
  padding: 14px 16px 0;
}
.site-premium .site-header__inner {
  max-width: 1180px;
  margin-inline: auto;
  width: 100%;
  padding: 10px 20px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.9);
  border-radius: 999px;
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.site-premium .site-header.is-scrolled .site-header__inner {
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 12px 40px rgba(15, 35, 55, 0.08);
}
.site-premium .logo__mark {
  height: 36px;
  filter: none;
}
.site-premium .nav a {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
}
.site-premium .nav a:hover {
  color: var(--primary-color);
}
.site-premium .btn {
  border-radius: 999px;
}
.site-premium .btn--primary {
  background: linear-gradient(135deg, var(--primary-color), var(--info-color));
  color: #fff;
  box-shadow: 0 8px 28px rgba(45, 128, 194, 0.35);
}

/* Hero — светлый с лучом и glow-витриной */
.site-premium .hero.hero--light {
  background: linear-gradient(180deg, #fafbfd 0%, #f4f6f9 55%, #eef2f7 100%);
  color: var(--text-color);
  padding: clamp(28px, 5vw, 48px) 0 0;
  overflow: clip;
}
.hero__stack {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(40px, 6vw, 64px);
  max-width: 920px;
  margin-inline: auto;
}
.hero.hero--light .hero__bg {
  z-index: 0;
}
.site-premium .hero.hero--light .hero__mesh {
  background:
    radial-gradient(ellipse 80% 55% at 50% -5%, rgba(45, 128, 194, 0.14), transparent 58%),
    radial-gradient(ellipse 45% 40% at 85% 25%, rgba(15, 136, 147, 0.08), transparent 50%),
    linear-gradient(180deg, #fafbfd 0%, #f4f6f9 100%);
  animation: hero-mesh-breathe 14s ease-in-out infinite alternate;
}
.site-premium .hero.hero--light .hero__bokeh {
  background:
    radial-gradient(circle at 50% 0%, rgba(45, 128, 194, 0.12) 0%, transparent 48%),
    radial-gradient(circle at 15% 50%, rgba(74, 155, 212, 0.08) 0%, transparent 42%);
}
.site-premium .hero.hero--light .hero__aurora--a {
  opacity: 0.35;
  background: conic-gradient(from 200deg, rgba(45, 128, 194, 0.35), rgba(15, 136, 147, 0.15), rgba(74, 155, 212, 0.25), rgba(45, 128, 194, 0.35));
}
.site-premium .hero.hero--light .hero__aurora--b {
  opacity: 0.25;
}
.site-premium .hero.hero--light .hero__gridlines {
  background-image:
    linear-gradient(rgba(45, 128, 194, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45, 128, 194, 0.04) 1px, transparent 1px);
  mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, black, transparent 72%);
}
.site-premium .hero.hero--light .hero__vignette {
  background: radial-gradient(ellipse 90% 70% at 50% 20%, transparent, rgba(244, 246, 249, 0.9));
}
.site-premium .hero.hero--light .hero__beam {
  position: absolute;
  top: -5%;
  left: 50%;
  width: 2px;
  height: 55%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, transparent, rgba(45, 128, 194, 0.5), rgba(74, 155, 212, 0.2), transparent);
  filter: blur(0.5px);
  animation: hero-beam-pulse 4s ease-in-out infinite;
}
.site-premium .hero.hero--light .hero__beam-glow {
  position: absolute;
  top: 8%;
  left: 50%;
  width: min(420px, 60vw);
  height: 45%;
  transform: translateX(-50%);
  background: radial-gradient(ellipse closest-side, rgba(45, 128, 194, 0.18), transparent 70%);
  animation: hero-beam-pulse 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes hero-beam-pulse {
  0%, 100% { opacity: 0.7; }
  50% { opacity: 1; }
}
/* hero light typography — в main.css; здесь только усиление кнопок */
.site-premium .hero.hero--light .btn--primary {
  background: linear-gradient(135deg, var(--primary-color), var(--info-color));
  color: #fff;
  box-shadow: 0 10px 32px rgba(45, 128, 194, 0.4);
}
.site-premium .hero-showcase__shell {
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.9);
  box-shadow:
    0 0 0 1px rgba(45, 128, 194, 0.08),
    -20px -20px 60px rgba(45, 128, 194, 0.15),
    20px 24px 70px rgba(178, 105, 20, 0.08),
    0 32px 80px rgba(15, 35, 55, 0.12);
}
.site-premium .hero-showcase__caption {
  color: var(--text-muted);
  text-align: center;
}
.site-premium .hero-showcase__tag {
  color: var(--primary-color);
  font-weight: 600;
}

/* Marquee — layout обязателен (без него теги слипаются в одну строку) */
.marquee-section {
  padding: clamp(32px, 4vw, 48px) 0 clamp(40px, 5vw, 56px);
  background: #fff;
  border-bottom: 1px solid var(--border-color);
}
.marquee-section__lead {
  text-align: center;
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  color: var(--text-muted);
  margin-bottom: 24px;
  padding-inline: 16px;
}
.marquee {
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee__track {
  display: flex;
  width: max-content;
  animation: huly-marquee 42s linear infinite;
}
.marquee--static .marquee__track {
  animation: none;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
  max-width: 960px;
  margin-inline: auto;
  gap: 10px;
  padding-inline: 16px;
}
.marquee--static .marquee__group:last-child {
  display: none;
}
@keyframes huly-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.marquee__group {
  display: flex;
  flex-shrink: 0;
  gap: 10px;
  padding-right: 10px;
}
.marquee__pill {
  flex-shrink: 0;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  color: var(--text-color);
  background: var(--surface-muted, #f8fafc);
  border: 1px solid var(--border-color);
}

/* Bento */
.bento-section {
  padding: clamp(72px, 9vw, 108px) 0;
  background: linear-gradient(180deg, #fff 0%, var(--bg-color) 100%);
}
.section__head--left {
  text-align: left;
  max-width: 560px;
  margin: 0 0 40px;
}
.bento-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .bento-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto auto;
  }
  .bento-card--tall { grid-row: span 2; }
  .bento-card--wide { grid-column: span 1; }
}
@media (min-width: 1024px) {
  .bento-grid {
    grid-template-columns: 1.1fr 1.4fr 1fr;
    /* Фиксированные строки — иначе анимации внутри карточек «растягивают» панель */
    grid-template-rows: repeat(2, 272px);
    align-items: stretch;
  }
  .bento-card--tall { grid-row: 1 / 3; grid-column: 1; }
  .bento-card--wide { grid-column: 2; grid-row: 1 / 3; }
  .bento-card--normal:nth-of-type(3) { grid-column: 3; grid-row: 1; }
  .bento-card--normal:nth-of-type(4) { grid-column: 3; grid-row: 2; }

  /* Двухрядные карточки: визуал заполняет высоту, текст внизу (не «взлетает») */
  .bento-card--tall,
  .bento-card--wide {
    height: 100%;
    min-height: 0;
  }
  .bento-card--tall .bento-card__visual,
  .bento-card--wide .bento-card__visual {
    flex: 1 1 auto;
    height: auto;
    max-height: none;
    min-height: 168px;
  }
  .bento-card--tall .bento-card__visual {
    min-height: 0;
    overflow: visible;
    align-items: flex-start;
    justify-content: center;
    padding-top: 2px;
  }
  .bento-card--wide .bento-card__visual {
    overflow: hidden;
    align-items: center;
  }
  .bento-card--tall .bento-card__copy,
  .bento-card--wide .bento-card__copy {
    margin-top: auto;
    flex-shrink: 0;
  }
}
.bento-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 220px;
  padding: 20px;
  border-radius: 24px;
  background: #0f1419;
  color: #e8eef4;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.06);
}
.bento-card--glow-amber::before,
.bento-card--glow-blue::before,
.bento-card--glow-cyan::before,
.bento-card--glow-violet::before {
  content: "";
  position: absolute;
  width: 70%;
  height: 55%;
  border-radius: 50%;
  filter: blur(48px);
  opacity: 0.55;
  pointer-events: none;
}
.bento-card--glow-amber::before {
  top: -15%;
  left: -10%;
  background: rgba(251, 191, 36, 0.45);
}
.bento-card--glow-blue::before {
  top: 20%;
  left: 30%;
  background: rgba(45, 128, 194, 0.5);
}
.bento-card--glow-cyan::before {
  bottom: -10%;
  left: 20%;
  background: rgba(15, 136, 147, 0.45);
}
.bento-card--glow-violet::before {
  top: 10%;
  right: -15%;
  background: rgba(99, 102, 241, 0.4);
}
.bento-card__visual {
  position: relative;
  z-index: 1;
  flex: 0 0 168px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 168px;
  min-height: 168px;
  max-height: 168px;
  margin-bottom: 16px;
  overflow: hidden;
}
@media (max-width: 1023px) {
  .bento-card--tall .bento-card__visual {
    flex: 0 0 auto;
    height: auto;
    min-height: 200px;
    max-height: none;
    overflow: visible;
    align-items: flex-start;
  }
}
.bento-card__copy {
  position: relative;
  z-index: 1;
}
.bento-card__copy h3 {
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 6px;
  color: #fff;
}
.bento-card__copy p {
  font-size: 13px;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
}

/* Mock UI */
.mock-ui--glass {
  width: min(100%, 260px);
  padding: 14px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(12px);
}
.bento-card--tall .bento-card__visual .mock-ui--glass {
  width: 100%;
  max-width: 260px;
}
.mock-cmd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.35);
  margin-bottom: 10px;
  font-size: 12px;
}
.mock-cmd__hint { color: rgba(255, 255, 255, 0.5); }
.mock-cmd kbd {
  padding: 3px 8px;
  border-radius: 6px;
  background: rgba(45, 128, 194, 0.35);
  font-size: 11px;
  font-weight: 700;
}
.mock-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 12px;
}
.mock-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  color: rgba(255, 255, 255, 0.75);
}
.mock-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.mock-dot--ok { background: #4ade80; box-shadow: 0 0 8px #4ade80; }
.mock-dot--wait { background: #fbbf24; }
.mock-tasks {
  position: relative;
  width: min(100%, 280px);
  height: 160px;
  max-height: 160px;
  perspective: 920px;
  contain: layout style;
}
.mock-task {
  position: absolute;
  top: 0;
  left: 0;
  width: 88%;
  padding: 14px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.95);
  color: var(--text-color);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
  transform-origin: 50% 50%;
  will-change: transform, opacity, box-shadow;
  z-index: 1;
}
.mock-tasks:not(.mock-tasks--swapped) .mock-task--back {
  transform: translate(0, 0) rotate(-7deg) scale(0.86);
  opacity: 0.8;
  z-index: 1;
}
.mock-tasks:not(.mock-tasks--swapped) .mock-task--front {
  transform: translate(13%, 46%) rotate(4deg) scale(1);
  opacity: 1;
  z-index: 2;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.3);
}
.mock-tasks--swapped .mock-task--back {
  transform: translate(13%, 46%) rotate(4deg) scale(1);
  opacity: 1;
  z-index: 2;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.3);
}
.mock-tasks--swapped .mock-task--front {
  transform: translate(0, 0) rotate(-7deg) scale(0.86);
  opacity: 0.8;
  z-index: 1;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
}
@keyframes mock-task-swap-to-front {
  0% {
    transform: translate(0, 0) rotate(-7deg) scale(0.86);
    opacity: 0.8;
    z-index: 1;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
  }
  42% {
    transform: translate(46%, 14%) rotate(10deg) scale(1.12);
    opacity: 1;
    z-index: 12;
    box-shadow: 0 28px 56px rgba(45, 128, 194, 0.38);
  }
  72% {
    transform: translate(22%, 34%) rotate(6deg) scale(1.04);
    z-index: 8;
  }
  100% {
    transform: translate(13%, 46%) rotate(4deg) scale(1);
    opacity: 1;
    z-index: 2;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.3);
  }
}
@keyframes mock-task-swap-to-back {
  0% {
    transform: translate(13%, 46%) rotate(4deg) scale(1);
    opacity: 1;
    z-index: 2;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.3);
  }
  42% {
    transform: translate(6%, 22%) rotate(-14deg) scale(0.9);
    opacity: 0.88;
    z-index: 11;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.2);
  }
  72% {
    transform: translate(2%, 8%) rotate(-9deg) scale(0.88);
    z-index: 6;
  }
  100% {
    transform: translate(0, 0) rotate(-7deg) scale(0.86);
    opacity: 0.8;
    z-index: 1;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
  }
}
.mock-tasks--animating:not(.mock-tasks--swapped) .mock-task--back {
  animation: mock-task-swap-to-front 0.95s cubic-bezier(0.34, 1.15, 0.64, 1) forwards;
}
.mock-tasks--animating:not(.mock-tasks--swapped) .mock-task--front {
  animation: mock-task-swap-to-back 0.95s cubic-bezier(0.34, 1.15, 0.64, 1) forwards;
}
.mock-tasks--animating.mock-tasks--swapped .mock-task--back {
  animation: mock-task-swap-to-back 0.95s cubic-bezier(0.34, 1.15, 0.64, 1) forwards;
}
.mock-tasks--animating.mock-tasks--swapped .mock-task--front {
  animation: mock-task-swap-to-front 0.95s cubic-bezier(0.34, 1.15, 0.64, 1) forwards;
}
@media (prefers-reduced-motion: reduce) {
  .mock-task {
    will-change: auto;
  }
  .mock-tasks--animating .mock-task {
    animation: none !important;
  }
}
.mock-task strong { display: block; font-size: 13px; margin: 6px 0 4px; }
.mock-meta { font-size: 11px; color: var(--text-muted); }
.mock-pill {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
}
.mock-pill--med { background: #fef3c7; color: #b45309; }
.mock-pill--high { background: #fee2e2; color: #b91c1c; }
.mock-pill--blue {
  background: rgba(45, 128, 194, 0.14);
  color: var(--primary-dark);
  border: 1px solid rgba(45, 128, 194, 0.28);
}
.mock-avatars {
  display: flex;
  margin-top: 8px;
}
.mock-avatars span {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid #fff;
  margin-left: -6px;
  background: linear-gradient(135deg, var(--primary-light), var(--info-color));
}
.mock-avatars span:first-child { margin-left: 0; }
.mock-registry {
  position: relative;
  width: min(100%, 240px);
  padding: 16px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--text-color);
  overflow: hidden;
  isolation: isolate;
}
.mock-registry__scan {
  position: absolute;
  left: -8%;
  right: -8%;
  top: -20%;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(45, 128, 194, 0.15) 18%,
    var(--primary-color) 50%,
    var(--accent-color) 72%,
    transparent 100%
  );
  box-shadow:
    0 0 14px rgba(45, 128, 194, 0.55),
    0 0 28px rgba(15, 136, 147, 0.25);
  opacity: 0;
  pointer-events: none;
  z-index: 3;
}
.mock-registry--scanning .mock-registry__scan {
  opacity: 1;
  animation: mock-registry-scan 1.05s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
@keyframes mock-registry-scan {
  0% {
    transform: translateY(0);
    opacity: 0;
  }
  12% {
    opacity: 1;
  }
  88% {
    opacity: 1;
  }
  100% {
    transform: translateY(220px);
    opacity: 0;
  }
}
.mock-registry__head {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 8px;
}
.mock-registry p {
  position: relative;
  z-index: 2;
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 12px;
  min-height: 2.8em;
  max-height: 2.8em;
  overflow: hidden;
  transition: color 0.25s ease, opacity 0.25s ease;
}
.mock-registry--checking p {
  color: var(--primary-color);
  opacity: 0.92;
}
.mock-registry [data-mock-registry-pill] {
  position: relative;
  overflow: hidden;
  background: rgba(45, 128, 194, 0.12);
  color: var(--primary-dark);
  border: 1px solid rgba(45, 128, 194, 0.32);
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    background 0.35s ease,
    color 0.35s ease;
}
.mock-registry--checking [data-mock-registry-pill],
.mock-registry--verified [data-mock-registry-pill] {
  animation: mock-registry-pill-pulse 0.55s ease-in-out 2;
}
.mock-registry--scanning [data-mock-registry-pill] {
  background: var(--primary-color);
  color: #fff;
  box-shadow: 0 0 0 3px rgba(45, 128, 194, 0.22), 0 0 18px rgba(45, 128, 194, 0.45);
  transform: scale(1.06);
}
.mock-registry [data-mock-registry-pill]::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 30%,
    rgba(255, 255, 255, 0.65) 48%,
    transparent 66%
  );
  transform: translateX(-120%);
  pointer-events: none;
}
.mock-registry--checking [data-mock-registry-pill]::after,
.mock-registry--verified [data-mock-registry-pill]::after {
  animation: mock-registry-pill-shine 0.7s ease-out 1;
}
@keyframes mock-registry-pill-pulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(45, 128, 194, 0);
  }
  50% {
    transform: scale(1.05);
    box-shadow: 0 0 0 4px rgba(45, 128, 194, 0.2);
  }
}
@keyframes mock-registry-pill-shine {
  to {
    transform: translateX(120%);
  }
}
.mock-btn {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 8px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--primary-color), var(--info-color));
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  cursor: default;
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease,
    filter 0.28s ease;
}
.mock-registry--verified .mock-btn {
  transform: scale(1.02);
  filter: brightness(1.08);
  box-shadow: 0 8px 22px rgba(45, 128, 194, 0.45);
}
@media (prefers-reduced-motion: reduce) {
  .mock-registry--scanning .mock-registry__scan {
    animation: none;
    opacity: 0;
  }
  .mock-registry--checking [data-mock-registry-pill],
  .mock-registry--verified [data-mock-registry-pill] {
    animation: none;
  }
}
.mock-notify {
  position: relative;
  width: 100px;
  height: 100px;
  min-height: 100px;
  max-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  contain: layout style;
}
.mock-notify__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(45, 128, 194, 0.4);
  transform-origin: center center;
}
.mock-notify__ring--1 {
  animation: mock-notify-ring-a 4.5s ease-in-out infinite;
}
.mock-notify__ring--2 {
  inset: -12px;
  border-color: rgba(251, 191, 36, 0.35);
  animation: mock-notify-ring-b 4.5s ease-in-out infinite;
  animation-delay: 0.6s;
}
@keyframes mock-notify-ring-a {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.35;
  }
  50% {
    transform: scale(1.06);
    opacity: 0.15;
  }
}
@keyframes mock-notify-ring-b {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.25;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.1;
  }
}
.mock-import .mock-cmd--import {
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  padding: 12px 14px;
}

.mock-cmd__label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}

.mock-cmd__field {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 8px 12px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(255, 255, 255, 0.12);
  overflow: hidden;
}

.mock-cmd__field-icon {
  flex-shrink: 0;
  color: rgba(125, 211, 252, 0.9);
}

.mock-cmd__filename {
  flex: 1;
  min-width: 0;
  font-size: 12px;
  font-weight: 600;
  color: #e8f4fc;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mock-cmd__cursor {
  width: 2px;
  height: 16px;
  border-radius: 1px;
  background: rgba(125, 211, 252, 0.9);
  flex-shrink: 0;
}

.mock-list--picker {
  margin-top: 10px;
}

.mock-list--picker li {
  margin-bottom: 6px;
}

.mock-list__pick {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.75);
  font-size: 12px;
  text-align: left;
  cursor: pointer;
  transition: background 0.25s, border-color 0.25s, color 0.25s;
}

.mock-list__pick:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.mock-list__pick.is-active {
  background: rgba(45, 128, 194, 0.22);
  border-color: rgba(125, 211, 252, 0.35);
  color: #fff;
  box-shadow: 0 4px 16px rgba(45, 128, 194, 0.2);
}

.mock-list__name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mock-list__check {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #7dd3fc;
}

.mock-notify__icon {
  position: relative;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: linear-gradient(145deg, #1f5a8a, #0f8893);
  box-shadow: 0 10px 28px rgba(45, 128, 194, 0.45);
  transform-origin: top center;
}

.mock-notify__icon--shake {
  animation: mock-notify-bell-shake 0.65s cubic-bezier(0.36, 0, 0.2, 1);
}

@keyframes mock-notify-bell-shake {
  0% {
    transform: rotate(0deg) scale(1);
  }
  18% {
    transform: rotate(-14deg) scale(1.08);
  }
  36% {
    transform: rotate(12deg) scale(1.02);
  }
  52% {
    transform: rotate(-9deg) scale(1.06);
  }
  68% {
    transform: rotate(7deg) scale(1.04);
  }
  84% {
    transform: rotate(-4deg) scale(1.02);
  }
  100% {
    transform: rotate(0deg) scale(1);
  }
}

.mock-notify__badge {
  position: absolute;
  top: -7px;
  right: -9px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ef4444, #dc2626);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #fff;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.45);
  transform-origin: center bottom;
}

.mock-notify__badge--pop {
  animation: mock-notify-badge-pop 0.45s cubic-bezier(0.34, 1.4, 0.64, 1);
}

@keyframes mock-notify-badge-pop {
  0% {
    transform: scale(0.5) translateY(4px);
    opacity: 0;
  }
  100% {
    transform: scale(1) translateY(0);
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mock-notify__ring--1,
  .mock-notify__ring--2 {
    animation: none;
  }
  .mock-notify__icon--shake,
  .mock-notify__badge--pop {
    animation: none;
  }
}

/* Capabilities grid */
.cap-grid-section {
  padding: clamp(64px, 8vw, 96px) 0;
  background: #fff;
}
.cap-grid {
  display: grid;
  gap: 20px;
}
@media (min-width: 640px) { .cap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .cap-grid { grid-template-columns: repeat(3, 1fr); } }
.cap-card {
  padding: 28px 24px;
  border-radius: 20px;
  background: var(--surface-muted);
  border: 1px solid var(--border-color);
  transition: box-shadow 0.28s, border-color 0.28s;
}
.cap-card:hover {
  border-color: rgba(45, 128, 194, 0.25);
  box-shadow: var(--shadow-soft);
}
.cap-card h3 {
  font-size: 1.05rem;
  margin: 16px 0 8px;
  font-weight: 600;
}
.cap-card p {
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
}
.gradient-icon {
  position: relative;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  color: #fff;
}
.gradient-icon__glow {
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  filter: blur(14px);
  opacity: 0.55;
  z-index: 0;
}
.gradient-icon svg { position: relative; z-index: 1; }
.gradient-icon--blue {
  background: linear-gradient(135deg, var(--primary-color), var(--primary-light));
}
.gradient-icon--blue .gradient-icon__glow { background: var(--primary-color); }
.gradient-icon--cyan {
  background: linear-gradient(135deg, var(--info-color), #38bdf8);
}
.gradient-icon--cyan .gradient-icon__glow { background: var(--info-color); }
.gradient-icon--violet {
  background: linear-gradient(135deg, #6366f1, #a78bfa);
}
.gradient-icon--violet .gradient-icon__glow { background: #6366f1; }
.gradient-icon--amber {
  background: linear-gradient(135deg, var(--accent-color), var(--accent-light));
}
.gradient-icon--amber .gradient-icon__glow { background: var(--accent-color); }

/* Compare glow frame */
.compare-wrap {
  position: relative;
  padding: 8px;
  border-radius: 24px;
}
.compare-wrap::before,
.compare-wrap::after {
  content: "";
  position: absolute;
  width: 40%;
  height: 40%;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}
.compare-wrap::before {
  top: -5%;
  left: -5%;
  background: var(--primary-color);
}
.compare-wrap::after {
  bottom: -5%;
  right: -5%;
  background: var(--accent-light);
}
.compare-wrap .compare {
  position: relative;
  z-index: 1;
}

/* Секции на светлом */
.site-premium .section--alt {
  background: var(--surface-muted);
}
.site-premium .section__head h2 {
  font-size: clamp(1.85rem, 3.8vw, 2.65rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text-color);
}
.site-premium .ladder-card,
.site-premium .price-card,
.site-premium .case,
.site-premium .press-card {
  background: var(--surface);
  border-color: var(--border-color);
  box-shadow: var(--shadow-soft);
}
.site-premium .ladder-card--featured,
.site-premium .price-card--featured {
  background: linear-gradient(165deg, #fff 0%, #f0f7fd 100%);
  border-color: rgba(45, 128, 194, 0.35);
  box-shadow: var(--shadow-card);
}
.site-premium .section-scene__orb {
  opacity: 0.4;
}
/* CTA: светлый блок с читаемым текстом (не белый на белом) */
.site-premium .cta,
.site-premium .cta.cta--scene {
  margin: 0 16px 80px;
  padding: clamp(48px, 6vw, 64px) 32px;
  border-radius: var(--border-radius-lg);
  border: 1px solid rgba(45, 128, 194, 0.15);
  background:
    radial-gradient(ellipse 80% 70% at 50% 0%, rgba(45, 128, 194, 0.14), transparent 55%),
    linear-gradient(180deg, #fff 0%, #f0f7fd 100%);
  color: var(--text-color);
  box-shadow: 0 20px 50px rgba(45, 128, 194, 0.1);
}
.site-premium .cta::before {
  opacity: 0.35;
}
.site-premium .cta h2 {
  color: var(--text-color);
}
.site-premium .cta p {
  color: var(--text-muted);
  opacity: 1;
}
.site-premium .cta__trial {
  color: var(--text-muted);
  opacity: 1;
}
.site-premium .site-footer {
  background: var(--hero-bg);
}

@media (prefers-reduced-motion: reduce) {
  .site-premium .hero.hero--light .hero__beam,
  .site-premium .hero.hero--light .hero__beam-glow,
  .marquee__track {
    animation: none;
  }
}
