/* ═══════════════════════════════════════════════════════════
   СибНэт 1С — Design System
   Вставить в: Настройки сайта → Ещё → Дополнительный CSS
   Шрифт: Onest (подключён через Google Fonts в Тильде)
═══════════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  /* Brand */
  --c-navy:       #09498C;
  --c-blue:       #2789CA;
  --c-blue-pale:  #EBF5FF;
  --c-blue-light: #D6EEFF;
  --c-pink:       #FE69B7;
  --c-pink-pale:  #FFF0F8;

  /* Neutrals — tinted toward brand */
  --c-bg:         #F6F9FC;
  --c-surface:    #FFFFFF;
  --c-dark:       #0B1929;
  --c-dark2:      #142236;
  --c-ink:        #1A2E42;
  --c-muted:      #5C7A9A;
  --c-subtle:     #8EA8C3;
  --c-border:     rgba(9,73,140,.10);
  --c-border-mid: rgba(39,137,202,.20);

  /* Status */
  --c-ok:   #22C55E;
  --c-warn: #F59E0B;

  /* Typography */
  --ff: 'Onest', system-ui, sans-serif;
  --fm: 'JetBrains Mono', monospace;

  /* Spacing scale (8-base) */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-8: 32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-20: 80px;

  /* Radii */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-2xl: 28px;

  /* Shadows */
  --sh-sm:  0 1px 3px rgba(9,73,140,.08), 0 1px 2px rgba(9,73,140,.04);
  --sh-md:  0 4px 16px rgba(9,73,140,.10), 0 1px 4px rgba(9,73,140,.06);
  --sh-lg:  0 12px 40px rgba(9,73,140,.12), 0 4px 12px rgba(9,73,140,.06);

  /* Layout */
  --w-content: 1140px;
  --px: 5%;
  --py-section: var(--sp-20);
}

/* ── BASE RESET (scoped — не ломает Тильду) ── */
.sn-hero *, .sn-stats *, .sn-section *,
.sn-deploy *, .sn-its *, .sn-cta *, .sn-geo * {
  box-sizing: border-box;
}
.sn-hero, .sn-stats, .sn-section,
.sn-deploy-section, .sn-its-section,
.sn-cta, .sn-geo {
  font-family: var(--ff);
  color: var(--c-ink);
  -webkit-font-smoothing: antialiased;
}

/* ── КНОПКИ — белый текст, принудительно ── */
a.sn-btn,
a.sn-btn:link,
a.sn-btn:visited,
a.sn-btn:hover,
a.sn-btn:active,
button.sn-btn { color: #ffffff !important; }

.sn-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--ff);
  font-size: 15px;
  font-weight: 700;
  padding: 13px 26px;
  border-radius: var(--r-md);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: transform .18s cubic-bezier(.4,0,.2,1), box-shadow .18s cubic-bezier(.4,0,.2,1), background .15s;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.sn-btn--primary {
  background: var(--c-navy);
  color: #fff !important;
}
.sn-btn--primary:hover { background: #0B5FAF; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(9,73,140,.28); }
.sn-btn--primary:active { transform: translateY(0); box-shadow: none; }

.sn-btn--ghost {
  background: var(--c-blue);
  color: #fff !important;
}
.sn-btn--ghost:hover { background: #3A99DC; transform: translateY(-2px); }
.sn-btn--ghost:active { transform: translateY(0); }

/* ── СЕКЦИИ ── */
.sn-section { padding: var(--py-section) var(--px); }
.sn-section__inner { max-width: var(--w-content); margin: 0 auto; }
.sn-section--light { background: var(--c-bg); }
.sn-section--white { background: var(--c-surface); }
.sn-section--dark  { background: var(--c-dark); }
.sn-section--tinted { background: var(--c-blue-pale); }

.sn-section__hd { margin-bottom: var(--sp-12); }
.sn-section__hd h2 {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 800;
  letter-spacing: -.8px;
  color: var(--c-dark);
  line-height: 1.2;
}
.sn-section--dark .sn-section__hd h2 { color: #fff; }
.sn-section__sub {
  font-size: 16px;
  color: var(--c-muted);
  margin-top: var(--sp-3);
  max-width: 580px;
  line-height: 1.7;
}
.sn-section--dark .sn-section__sub { color: rgba(255,255,255,.5); }


/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.sn-hero {
  background: var(--c-surface);
  overflow: hidden;
}
.sn-hero__inner {
  max-width: var(--w-content);
  margin: 0 auto;
  padding: 72px var(--px) 64px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}

/* Eyebrow */
.sn-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: var(--c-blue-pale);
  border: 1px solid var(--c-border-mid);
  border-radius: 100px;
  padding: 5px 14px 5px 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--c-blue);
  margin-bottom: var(--sp-5);
}
.sn-eyebrow__dot {
  width: 7px; height: 7px;
  background: var(--c-pink);
  border-radius: 50%;
  animation: snBlink 2.4s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes snBlink {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:.5; transform:scale(1.35); }
}

/* H1 */
.sn-hero__h1 {
  font-size: clamp(32px, 4vw, 50px);
  font-weight: 800;
  letter-spacing: -1.5px;
  color: var(--c-dark);
  line-height: 1.12;
  margin-bottom: var(--sp-5);
}
.sn-accent { color: var(--c-blue); }
.sn-pink   { color: var(--c-pink); }

.sn-hero__lead {
  font-size: 17px;
  color: var(--c-muted);
  line-height: 1.7;
  margin-bottom: var(--sp-8);
  max-width: 460px;
}
.sn-hero__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; margin-bottom: var(--sp-8); }

/* Trust */
.sn-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.sn-trust__item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--c-muted);
}
.sn-trust__icon { color: var(--c-blue); flex-shrink: 0; }


/* ── 1С APP MOCKUP ── */
.sn-hero__visual { position: relative; }

.sn-app {
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid rgba(9,73,140,.13);
  box-shadow: var(--sh-lg);
  background: #EEF2F7;
  font-size: 13px;
  user-select: none;
}

/* Titlebar */
.sn-app__bar {
  background: #E2E8F0;
  border-bottom: 1px solid rgba(9,73,140,.1);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.sn-app__title { font-size: 12px; font-weight: 600; color: #4A6080; flex: 1; text-align: left; }
.sn-app__live  { display: flex; align-items: center; gap: 5px; font-size: 10px; font-weight: 700; color: var(--c-ok); font-family: var(--fm); }
.sn-app__live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--c-ok); animation: snBlink 2s infinite; }

/* Body */
.sn-app__body { display: grid; grid-template-columns: 144px 1fr; min-height: 268px; }

/* Nav */
.sn-app__nav {
  background: #E4EAF2;
  border-right: 1px solid rgba(9,73,140,.09);
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sn-nav-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 9px;
  border-radius: var(--r-sm);
  font-size: 12px;
  font-weight: 500;
  color: #4A6080;
  cursor: pointer;
  border: none;
  background: transparent;
  text-align: left;
  width: 100%;
  transition: background .15s, color .15s;
  touch-action: manipulation;
  position: relative;
}
.sn-nav-item:hover { background: rgba(39,137,202,.12); color: var(--c-navy); }
.sn-nav-item--active { background: var(--c-navy) !important; color: #fff !important; }
.sn-badge {
  margin-left: auto;
  background: var(--c-pink);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  width: 16px; height: 16px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* Pane */
.sn-app__pane { background: #fff; padding: 14px; overflow: hidden; }
.sn-tab { display: none; animation: snFadeIn .2s ease; }
.sn-tab--active { display: block; }
@keyframes snFadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
.sn-pane__title { font-size: 13px; font-weight: 700; color: var(--c-dark); margin: 0 0 12px; }

/* Metrics */
.sn-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 12px; }
.sn-metric { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-sm); padding: 10px 12px; }
.sn-metric__lbl { display: block; font-size: 10px; color: var(--c-muted); font-weight: 600; margin-bottom: 3px; }
.sn-metric__val { display: block; font-size: 14px; font-weight: 800; color: var(--c-dark); margin-bottom: 2px; font-family: var(--fm); }
.sn-metric__delta { display: inline-flex; align-items: center; gap: 2px; font-size: 10px; font-weight: 700; }
.sn-metric__delta--up { color: var(--c-ok); }
.sn-metric__delta--dn { color: #EF4444; }

/* Tasks */
.sn-tasks { background: var(--c-bg); border-radius: var(--r-sm); padding: 10px; }
.sn-tasks__lbl { display: block; font-size: 10px; font-weight: 700; color: var(--c-subtle); text-transform: uppercase; letter-spacing: .6px; margin-bottom: 7px; }
.sn-task {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 4px;
  font-size: 12px; color: var(--c-ink);
  border-bottom: 1px solid var(--c-border);
  cursor: pointer;
  border-radius: 5px;
  transition: background .15s;
}
.sn-task:last-child { border-bottom: none; }
.sn-task:hover { background: var(--c-blue-pale); }
.sn-task--done { color: var(--c-muted); }
.sn-task--done span:nth-child(2) { text-decoration: line-through; }
.sn-task__chk { flex-shrink: 0; }
.sn-task__chk svg { display: block; }
.sn-task__time { margin-left: auto; font-size: 10px; color: var(--c-subtle); font-family: var(--fm); flex-shrink: 0; }

/* Bank */
.sn-bank-card { background: var(--c-navy); border-radius: var(--r-md); padding: 13px 15px; margin-bottom: 10px; }
.sn-bank-card__lbl  { display: block; font-size: 10px; color: rgba(255,255,255,.6); font-weight: 600; margin-bottom: 3px; }
.sn-bank-card__sum  { display: block; font-size: 20px; font-weight: 800; color: #fff; font-family: var(--fm); margin-bottom: 3px; }
.sn-bank-card__sync { display: flex; align-items: center; gap: 4px; font-size: 10px; color: rgba(255,255,255,.45); font-family: var(--fm); }

.sn-ops { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.sn-op { display: flex; align-items: center; gap: 8px; padding: 5px 0; border-bottom: 1px solid var(--c-border); }
.sn-op:last-child { border-bottom: none; }
.sn-op__ic { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; }
.sn-op__ic--in  { background: rgba(34,197,94,.12); color: var(--c-ok); }
.sn-op__ic--out { background: rgba(239,68,68,.10); color: #EF4444; }
.sn-op__name { font-size: 11px; font-weight: 600; color: var(--c-dark); margin: 0; }
.sn-op__date { font-size: 10px; color: var(--c-muted); margin: 0; }
.sn-op__sum { margin-left: auto; font-size: 11px; font-weight: 700; flex-shrink: 0; font-family: var(--fm); }
.sn-op__sum--in  { color: var(--c-ok); }
.sn-op__sum--out { color: #EF4444; }

/* Salary */
.sn-sal-period { font-size: 11px; color: var(--c-muted); margin: 0 0 10px; }
.sn-sal-period strong { color: var(--c-dark); }
.sn-sals { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.sn-sal { display: flex; align-items: center; gap: 8px; padding: 7px 10px; background: var(--c-bg); border-radius: var(--r-sm); border: 1px solid var(--c-border); }
.sn-sal__name { font-size: 11px; color: var(--c-ink); flex: 1; }
.sn-sal__sum  { font-size: 12px; font-weight: 700; color: var(--c-dark); flex-shrink: 0; font-family: var(--fm); }

/* Reports */
.sn-reps { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 7px; }
.sn-rep { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: var(--r-sm); border: 1px solid var(--c-border); }
.sn-rep--ok   { background: rgba(34,197,94,.06); border-color: rgba(34,197,94,.15); }
.sn-rep--warn { background: rgba(245,158,11,.06); border-color: rgba(245,158,11,.15); }
.sn-rep svg { flex-shrink: 0; color: var(--c-muted); }
.sn-rep__name { font-size: 11px; font-weight: 600; color: var(--c-dark); margin: 0; }
.sn-rep__meta { font-size: 10px; color: var(--c-muted); margin: 0; }

/* Status pills (shared) */
.sn-status {
  font-size: 10px; font-weight: 700;
  padding: 2px 9px;
  border-radius: 100px;
  flex-shrink: 0;
  white-space: nowrap;
}
.sn-status--ok   { background: rgba(34,197,94,.12); color: #16A34A; }
.sn-status--in   { background: rgba(39,137,202,.15); color: #1D6FA4; }
.sn-status--warn { background: rgba(245,158,11,.12); color: #B45309; }


/* ══════════════════════════════════════
   STATS
══════════════════════════════════════ */
.sn-stats { background: var(--c-navy); padding: 44px var(--px); }
.sn-stats__inner {
  max-width: var(--w-content);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
}
.sn-stat { padding: 0 16px; }
.sn-stat + .sn-stat { border-left: 1px solid rgba(255,255,255,.15); }
.sn-stat__val {
  display: block;
  font-size: clamp(30px,3vw,38px);
  font-weight: 800;
  color: #fff;
  letter-spacing: -1px;
  line-height: 1;
  font-family: var(--fm);
}
.sn-stat__sup { color: var(--c-pink); }
.sn-stat__lbl { display: block; font-size: 13px; color: rgba(255,255,255,.6); margin-top: 5px; font-weight: 500; }


/* ══════════════════════════════════════
   PRODUCT CARDS
══════════════════════════════════════ */
/* Filter nav */
.sn-tabs-nav {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: var(--sp-8);
}
.sn-filter {
  font-family: var(--ff);
  font-size: 13px;
  font-weight: 600;
  color: var(--c-muted);
  padding: 8px 18px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--c-border);
  background: transparent;
  cursor: pointer;
  transition: all .18s;
  touch-action: manipulation;
  min-height: 44px;
}
a.sn-filter, a.sn-filter:link, a.sn-filter:visited { color: var(--c-muted) !important; }
.sn-filter--active,
.sn-filter:hover { background: var(--c-navy); color: #fff !important; border-color: var(--c-navy); }

/* Card grid */
.sn-cards {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 20px;
}

.sn-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition: transform .22s cubic-bezier(.4,0,.2,1), box-shadow .22s cubic-bezier(.4,0,.2,1), border-color .2s;
  position: relative;
  overflow: hidden;
}
.sn-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--c-blue);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s cubic-bezier(.4,0,.2,1);
}
.sn-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-border-mid); }
.sn-card:hover::before { transform: scaleX(1); }

.sn-card__top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 14px; }
.sn-card__badge {
  background: var(--c-pink);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 100px;
}
.sn-card__icon { width: 40px; height: 40px; border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; background: var(--c-blue-pale); color: var(--c-navy); flex-shrink: 0; }
.sn-card__icon--pink { background: var(--c-pink-pale); color: var(--c-pink); }
.sn-card__icon--blue { background: var(--c-blue-light); color: var(--c-blue); }

.sn-card h3 { font-size: 15px; font-weight: 700; color: var(--c-dark); margin: 0 0 8px; }
.sn-card > p { font-size: 13px; color: var(--c-muted); line-height: 1.6; margin: 0 0 12px; }

/* Price display */
.sn-price { margin: 0 0 14px; display: flex; flex-direction: column; gap: 4px; }
.sn-price__row { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; }
.sn-price__mode {
  font-size: 10px; font-weight: 700;
  color: var(--c-subtle);
  text-transform: uppercase;
  letter-spacing: .7px;
  flex-shrink: 0;
  min-width: 44px;
}
.sn-price__mode--cloud { color: var(--c-pink); }
.sn-price__val { font-size: 12px; font-weight: 700; color: var(--c-navy); background: var(--c-blue-pale); padding: 2px 8px; border-radius: 100px; }
.sn-price__val--cloud { background: var(--c-pink-pale); color: var(--c-pink); }

/* Features list */
.sn-features { list-style: none; padding: 0; margin: 0 0 18px; flex: 1; }
.sn-features li {
  font-size: 12px; color: var(--c-muted);
  padding: 3px 0 3px 16px;
  position: relative;
  line-height: 1.55;
}
.sn-features li::before {
  content: '';
  position: absolute; left: 0; top: 9px;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--c-blue);
}

/* Card link */
.sn-card__link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 700;
  color: var(--c-blue) !important;
  text-decoration: none;
  margin-top: auto;
  transition: color .15s, gap .2s;
}
.sn-card__link:hover { color: var(--c-navy) !important; gap: 8px; }


/* ══════════════════════════════════════
   DEPLOYMENT
══════════════════════════════════════ */
.sn-deploy {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px;
}
.sn-deploy__card {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-2xl);
  padding: 32px;
  transition: border-color .25s;
}
.sn-deploy__card:hover { border-color: rgba(39,137,202,.35); }
.sn-deploy__card--cloud { background: rgba(39,137,202,.07); }
.sn-deploy__card--box   { background: rgba(9,73,140,.14); }

.sn-deploy__icon {
  width: 52px; height: 52px;
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.sn-deploy__card--cloud .sn-deploy__icon { background: rgba(39,137,202,.2); color: #7EC8F5; }
.sn-deploy__card--box   .sn-deploy__icon { background: rgba(254,105,183,.15); color: var(--c-pink); }

.sn-deploy__card h3 { font-size: 19px; font-weight: 800; color: #fff; margin: 0 0 8px; }
.sn-deploy__sub { font-size: 13px; color: rgba(255,255,255,.5); margin: 0 0 20px; line-height: 1.65; }

.sn-deploy__list { list-style: none; padding: 0; margin: 0 0 24px; }
.sn-deploy__list li {
  display: flex; align-items: flex-start; gap: 9px;
  font-size: 13px; color: rgba(255,255,255,.78);
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.sn-deploy__list li:last-child { border-bottom: none; }

.sn-deploy__chk {
  width: 16px; height: 16px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 2px;
  font-size: 8px; font-weight: 900;
  background: rgba(39,137,202,.3); color: #7EC8F5;
}
.sn-deploy__chk::before { content: '✓'; }
.sn-deploy__chk--pink { background: rgba(254,105,183,.2); color: var(--c-pink); }

.sn-deploy__cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff); font-size: 14px; font-weight: 700;
  padding: 11px 22px;
  border-radius: var(--r-md);
  cursor: pointer; text-decoration: none;
  border: none; transition: all .2s;
  touch-action: manipulation;
}
.sn-deploy__cta--cloud { background: var(--c-blue); color: #fff !important; }
.sn-deploy__cta--cloud:hover { background: #3A99DC; transform: translateY(-2px); }
.sn-deploy__cta--box { background: rgba(254,105,183,.18); color: var(--c-pink) !important; border: 1px solid rgba(254,105,183,.28); }
.sn-deploy__cta--box:hover { background: rgba(254,105,183,.28); transform: translateY(-2px); }


/* ══════════════════════════════════════
   ITS
══════════════════════════════════════ */
.sn-its {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.sn-its__copy h2 {
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 800;
  letter-spacing: -.8px;
  color: var(--c-dark);
  line-height: 1.2;
  margin: 0 0 14px;
}
.sn-its__copy > p {
  font-size: 15px; color: var(--c-muted);
  line-height: 1.7; margin: 0 0 24px;
}

.sn-its__tariffs { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; gap: 10px; }
.sn-tariff {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 14px 18px;
  transition: all .2s;
  gap: var(--sp-3);
}
.sn-tariff:hover { border-color: var(--c-blue); box-shadow: var(--sh-sm); }
.sn-tariff--pop { border-color: var(--c-blue); background: var(--c-blue-pale); }

.sn-tariff__left { display: flex; align-items: center; gap: 11px; min-width: 0; }
.sn-tariff__right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.sn-tariff__ico {
  width: 34px; height: 34px;
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.sn-tariff__ico--std  { background: var(--c-blue-light); color: var(--c-blue); }
.sn-tariff__ico--pro  { background: var(--c-navy); color: #fff; }
.sn-tariff__ico--corp { background: var(--c-dark); color: rgba(255,255,255,.7); }

.sn-tariff__name { font-size: 13px; font-weight: 700; color: var(--c-dark); margin: 0; }
.sn-tariff__desc { font-size: 11px; color: var(--c-muted); margin: 2px 0 0; }
.sn-tariff__price { font-size: 15px; font-weight: 800; color: var(--c-navy); flex-shrink: 0; white-space: nowrap; }
.sn-tariff__tag { background: var(--c-pink); color: #fff; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 100px; white-space: nowrap; }

/* ITS visual panel */
.sn-its__visual { background: var(--c-dark); border-radius: var(--r-2xl); padding: 26px; }
.sn-its__visual-hd { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.sn-its__logo {
  width: 38px; height: 38px;
  background: var(--c-blue);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 900;
  color: #fff; font-family: var(--fm);
}
.sn-its__visual-title { font-size: 15px; font-weight: 700; color: #fff; margin: 0; }
.sn-its__visual-sub   { font-size: 11px; color: rgba(255,255,255,.45); margin: 2px 0 0; }

.sn-svcs { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.sn-svc {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-md);
  padding: 11px 14px;
}
.sn-svc svg { flex-shrink: 0; color: rgba(255,255,255,.5); }
.sn-svc__name { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.9); margin: 0; }
.sn-svc__note { font-size: 10px; color: rgba(255,255,255,.4); margin: 1px 0 0; }
.sn-svc__status { margin-left: auto; }


/* ══════════════════════════════════════
   PROCESS STEPS
══════════════════════════════════════ */
.sn-steps { list-style: none; padding: 0; margin: 0; max-width: 860px; display: flex; flex-direction: column; }
.sn-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  align-items: flex-start;
  padding: 22px 0;
  border-bottom: 1px solid var(--c-border);
}
.sn-step:last-child { border-bottom: none; }
.sn-step__num {
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 2px solid var(--c-border-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800;
  color: var(--c-blue);
  font-family: var(--fm);
  flex-shrink: 0;
}
.sn-step__body h3 { font-size: 15px; font-weight: 700; color: var(--c-dark); margin: 0 0 5px; }
.sn-step__body p  { font-size: 13px; color: var(--c-muted); line-height: 1.65; margin: 0; }
.sn-step__dur {
  display: inline-block;
  font-size: 11px; font-weight: 600;
  color: var(--c-blue);
  background: var(--c-blue-pale);
  border-radius: 100px;
  padding: 2px 9px;
  margin-top: 7px;
  font-family: var(--fm);
}


/* ══════════════════════════════════════
   WHY GRID
══════════════════════════════════════ */
.sn-why {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 20px;
}
.sn-why__card {
  padding: 22px 18px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  transition: border-color .22s, transform .22s;
}
.sn-why__card:hover { border-color: var(--c-blue); transform: translateY(-3px); }
.sn-why__num { display: block; font-size: 30px; font-weight: 800; color: var(--c-navy); opacity: .18; line-height: 1; margin-bottom: 10px; font-family: var(--fm); }
.sn-why__card h3 { font-size: 14px; font-weight: 700; color: var(--c-dark); margin: 0 0 7px; }
.sn-why__card p  { font-size: 13px; color: var(--c-muted); line-height: 1.65; margin: 0; }


/* ══════════════════════════════════════
   FAQ
══════════════════════════════════════ */
.sn-faq { max-width: 780px; margin: 0; padding: 0; }
.sn-faq__item { border-bottom: 1px solid var(--c-border); }
.sn-faq__q {
  width: 100%;
  background: transparent; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0;
  font-family: var(--ff); font-size: 15px; font-weight: 600;
  color: var(--c-dark); text-align: left;
  gap: 16px;
  transition: color .15s;
  touch-action: manipulation;
  min-height: 44px;
}
.sn-faq__q:hover { color: var(--c-blue); }
.sn-faq__q--open { color: var(--c-blue); }
.sn-faq__arr {
  flex-shrink: 0;
  color: var(--c-subtle);
  transition: transform .25s cubic-bezier(.4,0,.2,1), color .15s;
}
.sn-faq__q--open .sn-faq__arr { transform: rotate(180deg); color: var(--c-blue); }
.sn-faq__a {
  font-size: 14px; color: var(--c-muted);
  line-height: 1.7;
  padding: 0 0 18px;
  max-width: 680px;
  margin: 0;
  animation: snFadeIn .2s ease;
}
/* hidden attribute override */
.sn-faq__a[hidden] { display: none; }


/* ══════════════════════════════════════
   CTA
══════════════════════════════════════ */
.sn-cta {
  background: var(--c-navy);
  padding: 64px var(--px);
}
.sn-cta__inner {
  max-width: var(--w-content);
  margin: 0 auto;
}
.sn-cta h2 {
  font-size: clamp(26px, 3.5vw, 40px);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.8px;
  margin: 0 0 12px;
}
.sn-cta p {
  font-size: 16px;
  color: rgba(255,255,255,.65);
  line-height: 1.65;
  margin: 0;
  max-width: 560px;
}


/* ══════════════════════════════════════
   GEO REGIONS
══════════════════════════════════════ */
.sn-geo {
  background: var(--c-surface);
  padding: 36px var(--px);
  border-top: 1px solid var(--c-border);
}
.sn-geo__inner { max-width: var(--w-content); margin: 0 auto; }
.sn-geo__title { font-size: 13px; font-weight: 600; color: var(--c-muted); margin: 0 0 12px; }
.sn-geo__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.sn-geo__tag {
  font-size: 12px; color: var(--c-muted) !important;
  background: var(--c-blue-pale);
  border: 1px solid var(--c-border);
  border-radius: 6px;
  padding: 4px 10px;
  text-decoration: none;
  transition: color .15s, border-color .15s;
  min-height: 30px; display: inline-flex; align-items: center;
}
.sn-geo__tag:hover { color: var(--c-blue) !important; border-color: var(--c-border-mid); }


/* ══════════════════════════════════════
   SCROLL ANIMATIONS
══════════════════════════════════════ */
.sn-anim {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .55s cubic-bezier(.4,0,.2,1), transform .55s cubic-bezier(.4,0,.2,1);
}
.sn-anim--in {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger for card grids */
.sn-cards .sn-anim:nth-child(2) { transition-delay: .08s; }
.sn-cards .sn-anim:nth-child(3) { transition-delay: .14s; }
.sn-cards .sn-anim:nth-child(4) { transition-delay: .20s; }
.sn-cards .sn-anim:nth-child(5) { transition-delay: .26s; }
.sn-cards .sn-anim:nth-child(6) { transition-delay: .32s; }
.sn-why .sn-anim:nth-child(2) { transition-delay: .08s; }
.sn-why .sn-anim:nth-child(3) { transition-delay: .16s; }
.sn-why .sn-anim:nth-child(4) { transition-delay: .24s; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .sn-anim { opacity: 1; transform: none; transition: none; }
  * { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}


/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 960px) {
  .sn-hero__inner { grid-template-columns: 1fr; padding: 56px var(--px); }
  .sn-hero__visual { display: none; }
  .sn-cards  { grid-template-columns: 1fr 1fr; }
  .sn-deploy { grid-template-columns: 1fr; }
  .sn-its    { grid-template-columns: 1fr; }
  .sn-why    { grid-template-columns: repeat(2,1fr); }
  .sn-stats__inner { grid-template-columns: repeat(2,1fr); }
  .sn-stat + .sn-stat { border-left: none; border-top: 1px solid rgba(255,255,255,.1); }
}

@media (max-width: 600px) {
  :root { --py-section: 56px; }
  .sn-cards { grid-template-columns: 1fr; }
  .sn-why   { grid-template-columns: 1fr; }
  .sn-hero__actions { flex-direction: column; }
  .sn-hero__actions .sn-btn { justify-content: center; }
  .sn-stats__inner { grid-template-columns: repeat(2,1fr); }
  .sn-its { gap: var(--sp-8); }
}

/* ═══════════════════════════════════════════════════════════
   HERO VISUAL — ANIMATED MOCKUP v2
═══════════════════════════════════════════════════════════ */

/* Контейнер визуала — позиционирование бейджей */
.sn-hero__visual {
  position: relative;
  padding: 20px 0 20px;
}

/* ── Плавающие уведомления ── */
.sn-notif {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 9px 14px;
  box-shadow: var(--sh-md);
  z-index: 10;
  min-width: 210px;
  animation: snFloat 3.5s ease-in-out infinite;
}
.sn-notif--top    { top: 0; right: -10px; animation-delay: 0s; }
.sn-notif--bottom { bottom: 0; left: -10px; animation-delay: 1.8s; }

@keyframes snFloat {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

.sn-notif__dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: snBlink 2s ease-in-out infinite;
}
.sn-notif__dot--green { background: var(--c-ok); box-shadow: 0 0 0 3px rgba(34,197,94,.15); }
.sn-notif__dot--blue  { background: var(--c-blue); box-shadow: 0 0 0 3px rgba(39,137,202,.15); }

.sn-notif__title { font-size: 12px; font-weight: 700; color: var(--c-dark); margin: 0; line-height: 1.2; }
.sn-notif__sub   { font-size: 10px; color: var(--c-muted); margin: 2px 0 0; line-height: 1.2; }

/* ── Логотип в сайдбаре ── */
/* .sn-app__nav-logo — управляется inline-стилями для совместимости с Тильдой */

/* ── Прогресс-бар автопереключения в сайдбаре ── */
.sn-app__autoprogress {
  margin-top: auto;
  height: 2px;
  background: rgba(39,137,202,.15);
  border-radius: 2px;
  overflow: hidden;
  position: absolute;
  bottom: 0; left: 8px; right: 8px;
}
.sn-app__autoprogress-fill {
  height: 100%;
  background: var(--c-blue);
  border-radius: 2px;
  width: 0%;
  transition: width linear;
}

/* Nav flex fix для absolute progress */
.sn-app__nav {
  position: relative;
  padding-bottom: 12px !important;
}

/* ── Sparkline-график ── */
.sn-sparkwrap {
  margin-bottom: 10px;
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--c-bg);
  padding: 8px 10px 6px;
  border: 1px solid var(--c-border);
}
.sn-spark {
  display: block;
  width: 100%;
  height: 40px;
}
.sn-spark__line {
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: snDrawLine 1.4s cubic-bezier(.4,0,.2,1) forwards;
  animation-delay: .3s;
}
.sn-spark__area {
  opacity: 0;
  animation: snFadeIn .8s ease forwards;
  animation-delay: .9s;
}
.sn-spark__dot {
  opacity: 0;
  transform-origin: center;
  animation: snPopIn .3s cubic-bezier(.34,1.56,.64,1) forwards;
  animation-delay: 1.4s;
}
@keyframes snDrawLine {
  to { stroke-dashoffset: 0; }
}
@keyframes snPopIn {
  from { opacity: 0; transform: scale(0); }
  to   { opacity: 1; transform: scale(1); }
}
.sn-spark__label {
  display: block;
  font-size: 9px;
  color: var(--c-subtle);
  font-family: var(--fm);
  margin-top: 3px;
  font-weight: 600;
  letter-spacing: .3px;
}

/* ── Итог по зарплате ── */
.sn-sal-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  padding: 9px 12px;
  background: var(--c-navy);
  border-radius: var(--r-sm);
}
.sn-sal-total__lbl { font-size: 11px; font-weight: 600; color: rgba(255,255,255,.6); }
.sn-sal-total__val { font-size: 14px; font-weight: 800; color: #fff; font-family: var(--fm); }

/* ── Stagger-анимации для строк при появлении вкладки ── */
.sn-op--anim,
.sn-sal--anim,
.sn-rep--anim {
  opacity: 0;
  transform: translateY(8px);
  animation: snRowIn .3s cubic-bezier(.4,0,.2,1) forwards;
  animation-delay: var(--d, 0s);
}
/* Сбрасываем когда таб не активен */
.sn-tab:not(.sn-tab--active) .sn-op--anim,
.sn-tab:not(.sn-tab--active) .sn-sal--anim,
.sn-tab:not(.sn-tab--active) .sn-rep--anim {
  animation: none;
  opacity: 0;
  transform: translateY(8px);
}
@keyframes snRowIn {
  to { opacity: 1; transform: translateY(0); }
}

/* ── Счётчик анимация (цифры нарастают) ── */
.sn-count {
  display: block;
  transition: opacity .15s;
}

/* ── Улучшенный fade для смены вкладок ── */
.sn-tab {
  animation: snTabIn .25s cubic-bezier(.4,0,.2,1);
}
@keyframes snTabIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .sn-notif,
  .sn-spark__line,
  .sn-spark__area,
  .sn-spark__dot,
  .sn-op--anim,
  .sn-sal--anim,
  .sn-rep--anim,
  .sn-count {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    stroke-dashoffset: 0 !important;
  }
}

.sn-app__nav-logo{background:transparent!important;border:none!important;border-radius:0!important;margin:0 0 12px 8px!important;justify-content:flex-start!important;width:auto!important;height:auto!important;}
