/* ==========================================================================
   Трансклик — стили публичной части сайта
   Рерайт 2026-04-20: новый бренд Navy + Teal, облегчённая типографика
   Сохранены все классы для совместимости с index.html и страницами услуг.
   ========================================================================== */

/* Табличный класс для сравнительных таблиц (габариты машин, вагонов, контейнеров).
   На десктопе — чистая Google-Sheets-подобная сетка, зебра, hover.
   На мобильных (<720px) разворачивается в карточки с подписями через data-label. */
.specs-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 12px; }
.specs-table { width: 100%; border-collapse: collapse; background: #fff; font-size: 14px; line-height: 1.4;
  border: 1px solid #dfe3eb; border-radius: 12px; overflow: hidden; }
.specs-table thead th { background: #1a2f4a; color: #fff; text-align: left; padding: 11px 14px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.3px; text-transform: uppercase;
  border-right: 1px solid rgba(255,255,255,0.08); white-space: nowrap; }
.specs-table thead th:last-child { border-right: 0; }
.specs-table tbody td { padding: 11px 14px; border-top: 1px solid #eceef3;
  border-right: 1px solid #eceef3; vertical-align: middle; color: #202733; }
.specs-table tbody td:last-child { border-right: 0; }
.specs-table tbody tr:nth-child(even) { background: #f7f9fc; }
.specs-table tbody tr:hover { background: #eef4fb; }
.specs-table tbody td:first-child { font-weight: 600; color: #1a2f4a; }
.specs-table tbody td strong { color: #1a2f4a; }
.specs-note { margin: 12px 2px 0; color: #5a6778; font-size: 13px; }

@media (max-width: 720px) {
  .specs-table-wrap { overflow: visible; border-radius: 0; }
  .specs-table, .specs-table thead, .specs-table tbody, .specs-table tr, .specs-table td, .specs-table th {
    display: block; border: 0 !important; }
  .specs-table { background: transparent; }
  .specs-table thead { position: absolute; left: -9999px; top: -9999px; }
  .specs-table tbody tr { background: #fff !important; border: 1px solid #dfe3eb !important;
    border-radius: 12px; padding: 10px 14px; margin-bottom: 12px; box-shadow: 0 1px 3px rgba(20,38,66,0.04); }
  .specs-table tbody td { padding: 7px 0 !important; display: flex; justify-content: space-between;
    align-items: baseline; gap: 12px; border-top: 1px dashed #eceef3 !important; }
  .specs-table tbody td:first-child { border-top: 0 !important; padding-top: 2px !important;
    padding-bottom: 10px !important; margin-bottom: 4px; border-bottom: 1px solid #eceef3 !important;
    font-size: 15.5px; display: block; }
  .specs-table tbody td[data-label]::before { content: attr(data-label); color: #5a6778;
    font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px;
    flex-shrink: 0; }
  .specs-table tbody td:first-child[data-label]::before { display: none; }

  /* Блок "О сервисе" (manifest) — ломаем grid в одну колонку */
  .manifest-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .manifest-quote { padding: 22px 18px !important; border-radius: 14px !important; }
  .manifest-quote p[style*="font-size:20px"],
  .manifest-quote p { font-size: 16.5px !important; line-height: 1.5 !important; }
  .manifest-quote div[style*="font-size:56px"] { font-size: 40px !important; margin-bottom: 4px !important; }
  .manifest-cards > div { padding: 14px 16px !important; }
}

/* ---------------------------
   Дизайн-токены (CSS-переменные)
   --------------------------- */
:root{
  /* Палитра бренда */
  --brand-navy:#1a2f4a;           /* основной тёмно-синий */
  --brand-navy-2:#12243b;         /* глубокий акцент */
  --brand-teal:#2aa8b3;            /* бирюзовый акцент */
  --brand-teal-2:#1f8691;          /* насыщенный teal */
  --brand-teal-soft:#e6f5f6;       /* светлый фон под teal */
  --brand-navy-soft:#eef2f8;       /* светлый фон под navy */

  /* Фон и нейтралы */
  --bg:#ffffff;
  --bg-soft:#f7f9fb;
  --bg-subtle:#f1f4f7;

  /* Текст */
  --text:#12243b;
  --text-secondary:#3e526a;
  --muted:#6b7f92;
  --text-subtle:#8b9caf;
  --text-inverse:#ffffff;

  /* Линии, тени */
  --line:#e3e8ee;
  --line-strong:#cfd8e1;
  --shadow-sm:0 1px 2px rgba(18,36,59,.04);
  --shadow:0 6px 18px rgba(18,36,59,.07);
  --shadow-lg:0 14px 36px rgba(18,36,59,.12);

  /* Скруглённость */
  --radius-xs:6px;
  --radius-sm:10px;
  --radius-md:14px;
  --radius-lg:18px;
  --radius-xl:24px;
  --radius-full:999px;

  /* Отступы */
  --space-xs:4px;
  --space-sm:8px;
  --space-md:16px;
  --space-lg:24px;
  --space-xl:40px;
  --space-2xl:64px;

  /* Сохранены старые переменные для совместимости */
  --card:#ffffff;
  --card-solid:#ffffff;
  --primary:var(--brand-teal);
  --primary-soft:var(--brand-teal-2);
  --accent:var(--brand-navy);
  --accent2:var(--brand-teal);
  --radius:var(--radius-xl);

  /* Типографика */
  --font-body:"Inter","Segoe UI","Helvetica Neue",Arial,"Noto Sans",sans-serif;
  --font-display:"Inter","Segoe UI","Helvetica Neue",Arial,sans-serif;
  --font-mono:"JetBrains Mono","SF Mono","Consolas",monospace;

  --fs-xs:12px;
  --fs-sm:13px;
  --fs-base:14.5px;
  --fs-md:15px;
  --fs-lg:16px;
  --fs-xl:18px;
  --fs-h4:18px;
  --fs-h3:20px;
  --fs-h2:26px;
  --fs-h1:34px;
  --fs-hero:44px;

  --lh-tight:1.3;
  --lh-body:1.55;
  --lh-relaxed:1.7;
}

/* ---------------------------
   Reset + базовые элементы
   --------------------------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-base);
  line-height:var(--lh-body);
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
body.mobile-nav-open{overflow:hidden}
body.mobile-nav-open .site-header{z-index:60}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:700;
  color:var(--text);
  line-height:var(--lh-tight);
  letter-spacing:-0.01em;
  margin:0;
}
p{margin:0;line-height:var(--lh-body)}
img{max-width:100%;display:block}
a{text-decoration:none;color:var(--brand-teal-2);transition:color .15s}
a:hover{color:var(--brand-navy)}
button{font:inherit;cursor:pointer}
button,input,textarea,select{-webkit-tap-highlight-color:transparent;font-family:inherit}
hr{border:0;height:1px;background:var(--line);margin:var(--space-lg) 0}

/* ---------------------------
   Layout: контейнеры, секции
   --------------------------- */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.narrow{max-width:1120px}

.section{padding:48px 0}
.section-head{max-width:780px;margin-bottom:28px}
.section-head .eyebrow{color:var(--brand-teal-2)}
.section-head h2{font-size:var(--fs-h2);margin:6px 0 10px;letter-spacing:-0.015em}
.section-head p{color:var(--muted);font-size:var(--fs-md);line-height:var(--lh-relaxed)}

.eyebrow{
  display:inline-block;
  font-size:var(--fs-xs);
  font-weight:600;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--brand-teal-2);
  margin-bottom:6px;
}

/* ---------------------------
   Header / шапка
   --------------------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.header-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:12px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  padding:0;
  text-decoration:none;
}
.brand-logo{
  width:32px;
  height:32px;
  display:block;
  flex-shrink:0;
  border-radius:8px;
}
.brand-stack{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  line-height:1.15;
  min-width:0;
}
.brand-wordmark{
  display:block;
  font-family:var(--font-display);
  font-size:15px;
  line-height:1.15;
  letter-spacing:0.4px;
  font-weight:800;
  color:var(--brand-navy);
}
.brand-tagline{
  display:block;
  font-size:10.5px;
  font-weight:400;
  letter-spacing:0.2px;
  color:var(--muted);
  line-height:1.15;
}
.logo-mark{display:none}
.brand-copy{display:flex;flex-direction:column;min-width:0}
.brand-copy strong{
  display:block;
  font-size:16px;
  line-height:1.1;
  font-weight:700;
  color:var(--brand-navy);
}
.brand-copy small{
  display:block;
  margin-top:2px;
  font-size:11px;
  line-height:1;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.brand-text strong{display:block;font-size:15px;line-height:1.1}
.brand-text span{display:block;font-size:12px;color:var(--muted);margin-top:3px}
.brand-text--single{display:block}
.brand-text--single span{
  display:block;padding:0;border:0;background:transparent;box-shadow:none;
  font-size:0;margin-top:0;line-height:1;color:transparent;white-space:normal;
}
.brand-text--single span::before{
  content:"Сервис логистики";
  display:block;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:2px;
}

.main-nav{display:flex;gap:22px;font-weight:600;font-size:var(--fs-md);color:var(--text-secondary)}
.main-nav a{position:relative;padding:6px 0;color:var(--text-secondary)}
.main-nav a::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--brand-teal);
  transform:scaleX(0);transform-origin:left;
  transition:transform .2s;
}
.main-nav a:hover,.main-nav a.active{color:var(--brand-navy)}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}

.header-actions{display:flex;align-items:center;gap:10px}
.header-cabinet,.phone-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:9px 16px;
  border-radius:var(--radius-sm);
  background:var(--brand-navy);
  color:#fff;
  border:1px solid var(--brand-navy);
  box-shadow:none;
  font-weight:600;
  font-size:var(--fs-sm);
  transition:background .15s,border-color .15s;
}
.header-cabinet:hover,.phone-btn:hover{background:var(--brand-navy-2);color:#fff}

.menu-toggle,.mobile-nav{display:none}
.mobile-note{font-size:13px;color:var(--muted);line-height:1.5}

/* Sticky секции нижняя навигация */
.section-nav-shell{
  position:sticky;
  top:60px;
  z-index:34;
  min-height:48px;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  opacity:0;
  transition:opacity .18s;
}
.section-nav-shell.is-ready{opacity:1}
.section-nav-container{padding-top:8px;padding-bottom:8px}
.section-nav-track{
  display:flex;gap:6px;
  overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;-ms-overflow-style:none;
  padding-bottom:2px;
}
.section-nav-track::-webkit-scrollbar{display:none}
.section-tab{
  flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  min-height:30px;padding:0 12px;
  border-radius:var(--radius-sm);
  border:1px solid var(--line);
  background:#fff;color:var(--text-secondary);
  font-size:var(--fs-xs);font-weight:700;line-height:1;
  transition:background .15s,color .15s,border-color .15s;
  white-space:nowrap;
}
.section-tab:hover{background:var(--bg-soft);border-color:var(--line-strong)}
.section-tab.is-active{
  background:var(--brand-teal-soft);
  color:var(--brand-navy);
  border-color:var(--brand-teal);
}
.section-tab:focus,.section-tab:active{outline:none!important}
.section-tab:focus-visible{box-shadow:0 0 0 2px rgba(42,168,179,.35)}
[data-quick-section]{scroll-margin-top:var(--quick-nav-offset,140px)}

/* ---------------------------
   Hero
   --------------------------- */
.hero{padding:40px 0 28px}
body[data-page="home"]:not(.home-hero-ready) .hero.hero--with-breadcrumbs{
  opacity:0;pointer-events:none;
}
.hero--with-breadcrumbs{padding-top:28px}
.home-hero-breadcrumbs{margin-bottom:4px}
.breadcrumbs{font-size:var(--fs-sm);color:var(--muted);margin-bottom:16px}
.breadcrumbs a{color:var(--brand-teal-2)}
.mobile-breadcrumb-shell{display:none}

.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:36px;
  align-items:start;
}
.hero h1{
  font-size:var(--fs-hero);
  line-height:1.08;
  margin:0 0 16px;
  letter-spacing:-0.02em;
  color:var(--brand-navy);
}
.hero p{
  font-size:var(--fs-lg);
  line-height:var(--lh-relaxed);
  color:var(--text-secondary);
  max-width:640px;
  margin:0 0 14px;
}
.hero p strong{color:var(--brand-navy);font-weight:700}

.home-hero-copy{display:grid;align-content:start;gap:14px}
.hero-copy__support{
  margin:0;
  max-width:640px;
  font-size:var(--fs-md);
  line-height:var(--lh-relaxed);
  color:var(--muted);
}
.hero-cta-note{
  margin:6px 0 0;
  max-width:420px;
  font-size:13px;
  line-height:1.5;
  color:var(--muted);
}

.badges{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-top:20px;
}
.badge{
  display:flex;
  align-items:center;
  min-height:auto;
  text-align:left;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:10px 14px;
  box-shadow:none;
  font-size:13px;
  line-height:1.4;
  color:var(--text);
}

.actions,.cta-row{
  display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;
}

/* ---------------------------
   Кнопки
   --------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:10px 18px;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-size:var(--fs-md);
  border:1px solid transparent;
  cursor:pointer;
  transition:background .15s,border-color .15s,color .15s,transform .1s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:var(--brand-teal);
  color:#fff;
  border-color:var(--brand-teal);
  box-shadow:0 2px 6px rgba(42,168,179,.22);
}
.btn-primary:hover{background:var(--brand-teal-2);border-color:var(--brand-teal-2);color:#fff}
.btn-secondary{
  background:#fff;
  color:var(--brand-navy);
  border-color:var(--line-strong);
}
.btn-secondary:hover{background:var(--bg-soft);border-color:var(--brand-navy)}

.btn,.header-cabinet,.contact-actions a,.contact-actions button,.menu-toggle,
.cookie-btn,.search-form input,.search-result,.doc-card,.card,.link-card,
.badge--action,.keyword-chip--action{outline:none;appearance:none}
.btn:focus,.header-cabinet:focus,.contact-actions a:focus,.contact-actions button:focus,
.menu-toggle:focus,.cookie-btn:focus,.search-form input:focus,.search-result:focus,
.doc-card:focus,.card:focus,.link-card:focus,.badge--action:focus,
.keyword-chip--action:focus{outline:none!important}
.btn:focus-visible,.header-cabinet:focus-visible,.contact-actions a:focus-visible,
.contact-actions button:focus-visible,.menu-toggle:focus-visible,.cookie-btn:focus-visible,
.search-result:focus-visible,.doc-card:focus-visible,.card:focus-visible,
.link-card:focus-visible,.badge--action:focus-visible,.keyword-chip--action:focus-visible{
  box-shadow:0 0 0 3px rgba(42,168,179,.25);
}
button:focus-visible,a:focus-visible{outline:none!important}
.search-form input:focus-visible{
  border-color:var(--brand-teal);
  box-shadow:0 0 0 3px rgba(42,168,179,.18);
}

/* ---------------------------
   Hero Card (справа)
   --------------------------- */
.hero-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-card__head{
  padding:20px 22px 16px;
  background:linear-gradient(135deg,var(--brand-navy-soft) 0%,var(--brand-teal-soft) 100%);
  color:var(--text);
  border-bottom:1px solid var(--line);
}
.hero-card__head h2{margin:6px 0 0;font-size:var(--fs-h3);line-height:1.2;color:var(--brand-navy)}
.hero-card__body{padding:20px 22px}
.hero-card--route .hero-card__body{padding-top:16px}
.hero-card--dashboard .hero-card__body{display:grid;gap:14px}

.hero-road{
  position:relative;
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;margin-bottom:18px;padding:8px 4px 6px;
}
.hero-road__line{
  position:absolute;left:12%;right:12%;top:30px;height:2px;
  background:linear-gradient(90deg,var(--brand-teal) 0%,var(--brand-navy) 100%);
  opacity:.35;
}
.hero-road__stop{position:relative;z-index:1;display:grid;justify-items:center;gap:8px;text-align:center}
.hero-road__stop strong{
  display:grid;place-items:center;
  width:36px;height:36px;
  border-radius:var(--radius-full);
  background:#fff;
  border:1px solid var(--brand-teal);
  box-shadow:var(--shadow-sm);
  color:var(--brand-teal-2);
  font-size:var(--fs-sm);
}
.hero-road__stop span{max-width:160px;font-size:13px;line-height:1.4;color:var(--text-secondary)}

.field-label{font-size:13px;color:var(--muted);margin-bottom:6px}
.fake-field{
  border:1px solid var(--line);background:#fff;
  border-radius:var(--radius-md);
  padding:12px 14px;font-size:var(--fs-md);
}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.price-box{
  background:var(--brand-teal-soft);
  border-radius:var(--radius-lg);
  padding:16px 18px;margin-top:12px;
}
.price-box strong{display:block;font-size:36px;line-height:1.1;margin-top:6px;color:var(--brand-navy);font-weight:700}

.hero-dashboard__summary{
  padding:14px 16px;
  border-radius:var(--radius-md);
  background:var(--bg-soft);
  border:1px solid var(--line);
}
.hero-dashboard__summary strong{display:block;margin-top:4px;font-size:var(--fs-lg);line-height:1.35;color:var(--brand-navy)}
.hero-dashboard__summary span{display:block;margin-top:8px;color:var(--muted);line-height:1.55;font-size:13px}

.hero-status-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.hero-status{
  padding:12px 14px;
  border-radius:var(--radius-md);
  background:#fff;
  border:1px solid var(--line);
}
.hero-status span{
  display:block;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--brand-teal-2);font-weight:600;
}
.hero-status strong{display:block;margin-top:6px;font-size:13.5px;line-height:1.4;color:var(--text);font-weight:600}

.hero-dashboard__list{display:grid;gap:6px}
.hero-dashboard__line{
  display:flex;justify-content:space-between;gap:14px;align-items:center;
  padding:10px 14px;
  border-radius:var(--radius-md);
  background:var(--bg-soft);
  border:1px solid var(--line);
}
.hero-dashboard__line strong{font-size:13.5px;color:var(--brand-navy);font-weight:600}
.hero-dashboard__line span{font-size:13px;color:var(--muted);text-align:right}

/* ---------------------------
   Общие карточки
   --------------------------- */
.cards{display:grid;gap:14px}
.cards-3{grid-template-columns:repeat(3,1fr)}
.card,
.step-card,
.doc-card,
.faq-card,
.link-card,
.home-split__main,
.home-split__side,
.process-card,
.matrix-card,
.matrix-note,
.review-card,
.review-featured-card,
.policy-card,
.tonnage-grid-card,
.tonnage-side-card,
.catalog-group,
.service-aside,
.service-copy{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:20px;
  box-shadow:var(--shadow-sm);
  transition:box-shadow .2s,transform .15s;
}
.card:hover,.step-card:hover,.link-card:hover,.doc-card:hover{
  box-shadow:var(--shadow);
}
.more-link{
  display:inline-block;margin-top:12px;
  font-weight:600;color:var(--brand-teal-2);font-size:var(--fs-sm);
}
.more-link:hover{color:var(--brand-navy)}
.icon{
  width:40px;height:40px;
  border-radius:var(--radius-sm);
  display:grid;place-items:center;
  background:var(--brand-teal);color:#fff;
  margin-bottom:12px;
}
.icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.card h3,.step-card h3,.link-card h3,.doc-card h3,.faq-card h3{
  margin:0 0 8px;
  font-size:var(--fs-h4);
  font-weight:700;
  color:var(--brand-navy);
  letter-spacing:-0.005em;
}
.card p,.step-card p,.faq-card p,.link-card p{
  margin:0;
  color:var(--text-secondary);
  line-height:var(--lh-relaxed);
  font-size:var(--fs-md);
}

/* Trust / Service Grids */
.trust-grid,.docs-grid,.faq-grid,.service-grid{display:grid;gap:14px}
.trust-grid,.service-grid-3{grid-template-columns:repeat(3,1fr)}
.docs-grid{grid-template-columns:repeat(3,1fr)}

.doc-card small{display:block;color:var(--muted);margin-top:4px;font-size:13px}

/* Docs shell */
.docs-shell{
  display:grid;grid-template-columns:1.18fr .82fr;
  overflow:hidden;
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:var(--shadow);
  border:1px solid var(--line);
}
.docs-main{padding:24px}
.docs-side{padding:24px;background:var(--brand-navy);color:#fff}
.docs-side h2,.docs-side h3{color:#fff}
.docs-side p{color:rgba(255,255,255,0.82)}

/* Contact shell */
.contact-shell{
  border-radius:var(--radius-lg);
  padding:24px 28px;
  background:linear-gradient(135deg,var(--brand-teal-soft) 0%,var(--brand-navy-soft) 100%);
  color:var(--text);
  box-shadow:var(--shadow);
  border:1px solid var(--line);
}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:22px;align-items:center}
.contact-shell h2{color:var(--brand-navy);font-size:var(--fs-h2);margin-bottom:8px}
.contact-shell p{color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}
.contact-actions{display:grid;gap:10px}
.contact-actions a,.contact-actions button{
  border-radius:var(--radius-sm);
  padding:14px 18px;
  text-align:center;
  font-weight:600;
  font-size:var(--fs-md);
  border:1px solid transparent;
  cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
}
.contact-actions .primary{background:var(--brand-teal);color:#fff;border-color:var(--brand-teal)}
.contact-actions .primary:hover{background:var(--brand-teal-2);border-color:var(--brand-teal-2);color:#fff}
.contact-actions .ghost{background:#fff;color:var(--brand-navy);border-color:var(--line-strong)}
.contact-actions .ghost:hover{background:var(--bg-soft);border-color:var(--brand-navy)}

/* ---------------------------
   Footer
   --------------------------- */
.site-footer{
  padding:36px 0 22px;
  margin-top:32px;
  background:var(--bg-soft);
  border-top:1px solid var(--line);
}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px}
.footer-grid-wide{grid-template-columns:1.25fr 1fr 0.95fr 1fr}
.footer-brand{
  font-family:var(--font-display);
  font-weight:800;font-size:20px;letter-spacing:0.04em;text-transform:uppercase;
  color:var(--brand-navy);margin-bottom:8px;
}
.site-footer p,.site-footer li,.site-footer a,.footer-bottom{
  color:var(--text-secondary);
  line-height:var(--lh-relaxed);
  font-size:var(--fs-sm);
}
.site-footer a:hover{color:var(--brand-navy)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{padding:2px 0}
.footer-title{font-weight:700;margin-bottom:8px;color:var(--brand-navy);font-size:var(--fs-md)}
.footer-note{font-size:13px;color:var(--muted);margin-top:6px}
.footer-phone{font-weight:700;color:var(--brand-navy)}
.footer-bottom{
  border-top:1px solid var(--line);
  padding-top:14px;margin-top:18px;
  color:var(--muted);font-size:13px;
}

/* ---------------------------
   Service hero & layout
   --------------------------- */
.service-hero{padding:32px 0 10px}
.service-shell{display:grid;grid-template-columns:1.08fr 0.92fr;gap:24px;align-items:start}
.service-aside,.service-copy{
  min-width:0;padding:24px;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);
}
.service-copy h1{
  font-size:var(--fs-hero);
  margin:0 0 14px;letter-spacing:-0.02em;color:var(--brand-navy);
}
.service-copy p{color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}
.service-copy .lead{font-size:var(--fs-lg)}
.service-intro{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.bullet-list{margin:0;padding-left:18px;display:grid;gap:8px;color:var(--text)}
.bullet-list li{line-height:1.6}
.point-list{display:grid;gap:10px;margin-top:18px}
.point{
  display:flex;gap:10px;align-items:flex-start;
  background:var(--bg-soft);
  border-radius:var(--radius-md);
  padding:12px 14px;
}
.dot{
  width:8px;height:8px;border-radius:var(--radius-full);
  background:var(--brand-teal);
  margin-top:6px;flex:0 0 auto;
}
.documents-list{display:grid;gap:14px}
.doc-preview{display:grid;grid-template-columns:200px 1fr;gap:16px;align-items:center}
.doc-preview img,.doc-preview embed{
  width:100%;
  border-radius:var(--radius-md);
  border:1px solid var(--line);
  background:#fff;min-height:200px;
}

/* ---------------------------
   Keywords & chips
   --------------------------- */
.keyword-cloud{display:flex;flex-wrap:wrap;gap:6px}
.keyword-chip{
  display:inline-flex;align-items:center;
  padding:6px 12px;
  border-radius:var(--radius-full);
  background:var(--bg-soft);
  border:1px solid var(--line);
  box-shadow:none;
  font-size:13px;color:var(--text-secondary);
  font-weight:500;
}
.badge--action,.keyword-chip--action{
  cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
}
.badge--action:hover,.keyword-chip--action:hover{
  background:var(--brand-teal-soft);
  border-color:var(--brand-teal);
  color:var(--brand-navy);
}

/* ---------------------------
   FAQ
   --------------------------- */
.faq-card{padding:0;overflow:hidden}
.faq-card summary{
  list-style:none;cursor:pointer;
  padding:16px 20px;
  font-weight:600;font-size:var(--fs-md);
  color:var(--brand-navy);
  position:relative;padding-right:44px;
}
.faq-card summary::-webkit-details-marker{display:none}
.faq-card summary::after{
  content:"+";
  position:absolute;right:20px;top:14px;
  font-size:22px;line-height:1;
  color:var(--brand-teal);
  transition:transform .15s;
}
.faq-card[open] summary::after{content:"−"}
.faq-card p{padding:0 20px 18px;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}

/* ---------------------------
   Таблицы тарифов
   --------------------------- */
.tariff-table{
  display:grid;gap:1px;
  background:var(--line);border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.tariff-row{
  display:grid;grid-template-columns:1.1fr .9fr 1.5fr;gap:16px;
  background:#fff;padding:14px 18px;align-items:start;
  font-size:var(--fs-md);
}
.tariff-head{background:var(--brand-navy);color:#fff;font-weight:700;font-size:var(--fs-sm)}
.tariff-note{color:var(--muted);line-height:var(--lh-relaxed);margin-top:12px;font-size:13px}

.tariff-table-wrap{
  max-width:100%;overflow:auto;-webkit-overflow-scrolling:touch;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:#fff;box-shadow:var(--shadow-sm);
}
.tariff-table-wide{width:100%;min-width:960px;border-collapse:collapse}
.tariff-table-wide th,.tariff-table-wide td{
  padding:14px 16px;text-align:left;vertical-align:top;
  border-bottom:1px solid var(--line);
  font-size:var(--fs-sm);
}
.tariff-table-wide th{
  background:var(--brand-navy);color:#fff;
  font-size:13px;font-weight:700;white-space:nowrap;
}
.tariff-table-wide td{color:var(--text-secondary);line-height:1.55;overflow-wrap:anywhere}
.tariff-table-wide td strong{color:var(--brand-navy)}
.tariff-table-wide td::before{display:none}
.tariff-table-wide tr:last-child td{border-bottom:none}
.tariff-table-wide tr:nth-child(even) td{background:var(--bg-soft)}
.tariff-note--wide{margin-top:14px}

/* ---------------------------
   Home sections (специальные блоки главной)
   --------------------------- */
.home-duo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.home-cabinet-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.home-segment-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.home-segment-card .keyword-cloud{margin-top:14px}

.process-stack{display:grid;gap:12px}
.process-card{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.process-card__num{
  display:grid;place-items:center;
  width:40px;height:40px;
  border-radius:var(--radius-sm);
  background:var(--brand-navy);color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:var(--fs-lg);
}
.process-card__body h3{margin:0 0 6px;font-size:var(--fs-h4)}
.process-card__body p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed)}

.home-price-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.home-price-column{display:grid;gap:12px}
.home-price-card{height:100%}

.home-split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.home-split__main p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed)}
.home-split__main p + p{margin-top:12px}
.home-split__side h3{margin:4px 0 0;font-size:var(--fs-h4)}
.home-split__side .link-cards{grid-template-columns:1fr;gap:12px;margin-top:14px}

/* ---------------------------
   Link cards (мозаика услуг)
   --------------------------- */
.link-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.link-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
}
.link-card h3{margin:0 0 6px;color:var(--brand-navy)}
.link-card p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md);flex:1}
.link-card .btn{margin-top:14px;align-self:flex-start}
.link-card .more-link{margin-top:12px}
.link-card:hover{border-color:var(--brand-teal);box-shadow:var(--shadow)}
.link-card:hover h3{color:var(--brand-teal-2)}

/* ---------------------------
   Caталог и матрица
   --------------------------- */
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.catalog-group h3{margin:4px 0 6px;color:var(--brand-navy)}
.catalog-group>p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed)}
.catalog-branches{display:grid;gap:12px;margin-top:14px}
.catalog-branch{
  padding:14px 16px;border-radius:var(--radius-md);
  background:var(--bg-soft);border:1px solid var(--line);
}
.catalog-branch h4{margin:0 0 10px;font-size:var(--fs-md);color:var(--brand-navy)}
.catalog-links{display:grid;gap:8px}
.catalog-link{
  display:block;padding:10px 12px;
  border-radius:var(--radius-sm);
  background:#fff;border:1px solid var(--line);
  transition:box-shadow .2s,border-color .15s;
}
.catalog-link:hover{border-color:var(--brand-teal);box-shadow:var(--shadow-sm)}
.catalog-link span{display:block;font-weight:600;color:var(--brand-navy);font-size:var(--fs-sm)}
.catalog-link small{display:block;margin-top:3px;color:var(--muted);font-size:12px;word-break:break-word}

.matrix-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.matrix-card h3{margin:6px 0 8px;font-size:var(--fs-h4)}
.matrix-card p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed)}
.matrix-note{margin-top:14px;padding:20px 22px}
.matrix-note h3{margin:0 0 10px;font-size:var(--fs-h4)}
.matrix-list{margin:0;padding-left:18px;display:grid;gap:8px}
.matrix-list li{color:var(--text-secondary);line-height:var(--lh-relaxed)}

.service-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.service-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}

.step-pill{
  display:flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-md);padding:12px 14px;
  box-shadow:var(--shadow-sm);
}
.step-pill strong{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;
  border-radius:var(--radius-full);
  background:var(--brand-navy);color:#fff;
  font-family:var(--font-display);font-size:13px;font-weight:700;
}
.step-pill span{line-height:1.5;color:var(--text-secondary);font-size:var(--fs-sm)}

.mini-note{margin-top:16px;color:var(--muted);line-height:var(--lh-relaxed);font-size:var(--fs-sm)}

/* ---------------------------
   Reviews
   --------------------------- */
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.review-card .platform{
  display:flex;justify-content:space-between;gap:12px;
  align-items:flex-start;margin-bottom:8px;
}
.review-kicker{
  font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--brand-teal-2);font-weight:600;margin-bottom:4px;
}
.review-card h3{margin:0;font-size:var(--fs-h4);color:var(--brand-navy)}
.review-meta{color:var(--muted);line-height:1.55;font-size:13px}
.rating-stars{color:#f59e0b;font-size:16px;letter-spacing:0.04em;margin:8px 0}
.review-card p{margin:8px 0 0;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}
.review-card p strong{color:var(--brand-navy)}
.review-card .btn{margin-top:12px}
.review-card blockquote{
  margin:14px 0 0;padding:12px 14px;
  border-left:3px solid var(--brand-teal);
  border-radius:0 var(--radius-md) var(--radius-md) 0;
  background:var(--bg-soft);
  color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md);font-style:normal;
}
.platform-tag{
  display:inline-flex;padding:3px 8px;
  border-radius:var(--radius-full);
  background:var(--brand-teal-soft);
  color:var(--brand-teal-2);
  font-weight:600;font-size:11px;
}

.review-featured-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.review-featured-card{display:grid;gap:12px}
.review-featured-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.review-type-badge{
  display:inline-flex;padding:3px 8px;border-radius:var(--radius-full);
  background:var(--brand-teal-soft);color:var(--brand-teal-2);
  font-weight:600;font-size:11px;
}
.review-featured-text{margin:0;font-size:var(--fs-md);line-height:var(--lh-relaxed);color:var(--text)}
.review-featured-sign{font-weight:700;color:var(--brand-navy)}
.review-category-cloud{margin:0 0 16px}
.review-story-grid{align-items:start}
.review-story-card{display:grid;gap:12px}
.review-story-card p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed)}
.review-story-meta{display:flex;flex-wrap:wrap;gap:8px 12px;color:var(--muted);font-size:13px}
.review-story-meta span{display:inline-flex;align-items:center;gap:4px}

.home-reviews .review-card p{margin:10px 0 0;color:var(--text-secondary)}
.home-reviews .review-card p strong{color:var(--brand-navy)}

/* ---------------------------
   Прочие блоки
   --------------------------- */
.compact-list{display:grid;gap:8px;margin:0;padding-left:18px}
.compact-list li{line-height:var(--lh-relaxed);color:var(--text-secondary)}

.policy-card h2{margin:20px 0 10px;font-size:var(--fs-h3);color:var(--brand-navy)}
.policy-card h3{margin:14px 0 8px;font-size:var(--fs-h4);color:var(--brand-navy)}
.policy-card p,.policy-card li{line-height:var(--lh-relaxed);color:var(--text-secondary);font-size:var(--fs-md)}
body[data-page="politika-konfidentsialnosti"] .service-copy h1,
body[data-page="politika-konfidentsialnosti"] .service-copy p,
body[data-page="politika-konfidentsialnosti"] .service-aside h2,
body[data-page="politika-konfidentsialnosti"] .service-aside p,
body[data-page="politika-konfidentsialnosti"] .policy-card h2,
body[data-page="politika-konfidentsialnosti"] .policy-card h3,
body[data-page="politika-konfidentsialnosti"] .policy-card p,
body[data-page="politika-konfidentsialnosti"] .policy-card li,
body[data-page="politika-konfidentsialnosti"] .faq-card summary,
body[data-page="politika-konfidentsialnosti"] .faq-card p{
  overflow-wrap:anywhere;word-break:break-word;hyphens:auto;
}
.policy-card ul,.policy-card ol{display:grid;gap:6px;padding-left:20px}

/* Cargo Russia */
.cargo-russia-copy{display:grid;gap:14px}
.cargo-russia-copy p{margin:0}
.cargo-russia-hero-aside h2{margin:6px 0 0;font-size:var(--fs-h3);line-height:1.2}
.cargo-russia-benefits{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
.cargo-russia-benefit{
  min-width:0;padding:12px 14px;
  border-radius:var(--radius-md);background:#fff;
  border:1px solid var(--line);
}
.cargo-russia-benefit strong{display:block;font-size:var(--fs-sm);line-height:1.45;color:var(--brand-navy)}
.cargo-russia-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.cargo-russia-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.cargo-russia-grid-top{margin-top:14px}
.cargo-russia-format-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.cargo-russia-format-card{height:100%}
.cargo-russia-factor-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 24px;margin-top:6px}
.cargo-russia-factor-list li{color:var(--text-secondary)}

/* Tonnage */
.tonnage-hero-shell{align-items:stretch}
.tonnage-hero-copy,.tonnage-section-copy,.tonnage-grid-card,.tonnage-side-card{display:grid;gap:14px}
.tonnage-hero-copy p,.tonnage-section-copy p,.tonnage-grid-card p,.tonnage-side-card p{
  margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed);
}
.tonnage-support{max-width:72ch}
.tonnage-hero-aside h2{margin:6px 0 0;font-size:var(--fs-h3);line-height:1.2}
.tonnage-hero-benefits{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
.tonnage-benefit,.tonnage-summary-item{
  min-width:0;padding:12px 14px;
  border-radius:var(--radius-md);background:#fff;
  border:1px solid var(--line);
  line-height:1.5;
}
.tonnage-benefit{color:var(--brand-navy);font-weight:600;font-size:var(--fs-sm)}
.tonnage-inline-heading{margin:18px 0 10px;font-size:var(--fs-md);font-weight:700;color:var(--brand-navy)}
.tonnage-section-tail{margin-top:0}
.tonnage-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.tonnage-role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.tonnage-grid-card h3,.tonnage-label-card h3,.tonnage-side-card h3{margin:0;font-size:var(--fs-h4);color:var(--brand-navy)}
.tonnage-grid-card .bullet-list,.tonnage-side-card .bullet-list{margin-top:0}
.tonnage-label-card{display:flex;align-items:center;min-height:100px}
.tonnage-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.tonnage-summary-item{font-weight:600;color:var(--brand-navy);font-size:var(--fs-sm)}
.tonnage-process{margin-top:0}

/* Move pages */
.move-page-hero-benefits{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}
.move-page-split{display:grid;grid-template-columns:1.04fr .96fr;gap:14px}
.move-page-side-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}

/* Compare shell */
.compare-shell{
  padding:24px;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--brand-teal-soft) 0%,var(--brand-navy-soft) 100%);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.compare-copy{display:grid;gap:14px}
.compare-copy p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed)}
.compare-side{padding:18px;border-radius:var(--radius-md);background:#fff;border:1px solid var(--line)}
.compare-side .compact-list{margin-top:10px}

/* ---------------------------
   Поиск
   --------------------------- */
.search-container-wide{max-width:1200px}
.search-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow);
}
.search-card--hero{padding:28px;box-shadow:var(--shadow-lg)}
.search-card--hero .section-head h2{font-size:var(--fs-h1);line-height:1.08}

.search-form{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;align-items:stretch}
.search-form input{
  width:100%;padding:14px 18px;
  border-radius:var(--radius-md);
  border:2px solid var(--line-strong);
  background:#fff;font:inherit;font-size:var(--fs-lg);
  color:var(--text);
}
.search-form input::placeholder{color:var(--muted)}
.search-keywords{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 2px}
.search-keywords[hidden]{display:none!important}
.search-keywords .keyword-chip{
  padding:5px 10px;font-size:13px;line-height:1.2;
  box-shadow:none;appearance:none;cursor:pointer;
  border:1px solid var(--line);background:#fff;
}

.search-results:empty{display:none;margin-top:0}
.search-results{display:grid;gap:0;margin-top:6px}
.search-result{
  display:block;padding:12px 0 14px;
  background:transparent;border:0;
  border-bottom:1px solid var(--line);
  border-radius:0;box-shadow:none;
  transition:border-color .15s;
}
.search-result:last-child{padding-bottom:0;border-bottom:none}
.search-result:hover{transform:none;box-shadow:none;border-color:var(--brand-teal)}
.search-result__source{font-size:13px;line-height:1.4;color:var(--muted);margin-bottom:3px}
.search-result__page{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:600;font-size:17px;letter-spacing:-0.01em;
  margin-bottom:3px;color:#1a0dab;line-height:1.25;text-decoration:none;
}
.search-result__page:hover{text-decoration:underline}
.search-result__page:visited{color:#681da8}
.search-result__service{font-size:var(--fs-md);font-weight:600;color:var(--brand-navy);line-height:1.4;margin-bottom:10px}
.search-result__meta{display:flex;flex-wrap:wrap;gap:4px 5px;margin:0 0 6px;line-height:1}
.search-pill{
  display:inline-flex;align-items:center;
  padding:3px 9px;border-radius:var(--radius-full);
  background:var(--brand-teal-soft);color:var(--brand-teal-2);
  font-size:11.5px;font-weight:500;white-space:nowrap;
}
.search-result__description{
  margin:0;color:#202124;line-height:1.5;font-size:13px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.search-result__page mark,.search-result__description mark{
  background:#fff59d;color:inherit;font-weight:700;border-radius:2px;padding:0 1px;
}
.search-result__snippets{display:flex;flex-wrap:wrap;gap:4px 5px;align-items:center;margin-top:8px;line-height:1}
.search-result__snippet{
  display:inline-flex;align-items:center;
  padding:3px 9px;border-radius:var(--radius-full);
  background:var(--brand-teal-soft);border:0;
  color:var(--brand-teal-2);font-weight:500;font-size:11.5px;line-height:1.25;
  white-space:nowrap;
}
.search-result__snippet:hover{background:#c9ecee;text-decoration:none}
.search-empty{
  margin-top:16px;padding:14px 18px;
  border-radius:var(--radius-md);
  border:1px dashed var(--line-strong);
  background:#fff;color:var(--muted);line-height:var(--lh-relaxed);font-size:var(--fs-sm);
}

/* ---------------------------
   Notice strip, модалки
   --------------------------- */
.notice-strip{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.notice-strip .badge{margin-top:0}

.cookie-banner{
  position:fixed;left:20px;bottom:20px;z-index:9999;
  display:none;max-width:560px;
  align-items:flex-start;justify-content:space-between;gap:16px;
  background:var(--brand-navy);color:#fff;
  border-radius:var(--radius-lg);
  padding:14px 16px;
  box-shadow:var(--shadow-lg);
  pointer-events:auto;
  font-size:var(--fs-sm);
}
.cookie-banner.is-visible{display:flex}
.cookie-banner__text{max-width:420px;line-height:1.55;color:#e8edf5}
.cookie-banner__actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.cookie-link{color:var(--brand-teal);font-weight:600}
.cookie-link:hover{color:#fff}
.cookie-btn{
  border:0;background:var(--brand-teal);color:#fff;
  border-radius:var(--radius-sm);padding:9px 14px;
  font-weight:600;font-size:var(--fs-sm);cursor:pointer;pointer-events:auto;
  transition:background .15s;
}
.cookie-btn:hover{background:var(--brand-teal-2)}

.helper-modal{
  position:fixed;inset:0;display:none;
  align-items:center;justify-content:center;
  z-index:80;padding:24px;
}
.helper-modal.is-visible{display:flex}
.helper-modal-open{overflow:hidden}
.helper-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(18,36,59,0.5);
  backdrop-filter:blur(6px);
}
.helper-modal__dialog{
  position:relative;z-index:1;
  width:min(620px,100%);
  padding:26px 24px;
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--line);
}
.helper-modal__dialog h2{margin:6px 0 10px;font-size:var(--fs-h2);line-height:1.1;color:var(--brand-navy)}
.helper-modal__dialog p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}
.helper-modal__link{margin-top:16px}
.helper-modal__close{
  position:absolute;top:12px;right:12px;
  width:36px;height:36px;
  border-radius:var(--radius-full);
  border:1px solid var(--line);background:#fff;color:var(--text);
  font-size:20px;cursor:pointer;transition:background .15s;
}
.helper-modal__close:hover{background:var(--bg-soft)}

/* Calc modal */
.calc-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:90;padding:20px}
.calc-modal.is-visible{display:flex}
.calc-modal-open{overflow:hidden}
.calc-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(18,36,59,0.5);
  backdrop-filter:blur(8px);
}
.calc-modal__dialog{
  position:relative;z-index:1;
  width:min(880px,100%);max-height:min(92vh,960px);
  overflow:auto;
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:var(--shadow-lg);
  padding:24px;
  border:1px solid var(--line);
}
.calc-modal__topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin-bottom:14px}
.calc-modal__brand{display:grid;justify-items:center;gap:2px;text-align:center}
.calc-modal__brand strong{
  font-family:var(--font-display);font-size:18px;line-height:1;
  letter-spacing:0.05em;text-transform:uppercase;color:var(--brand-navy);font-weight:800;
}
.calc-modal__brand span{font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted)}
.calc-modal__backlink{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:36px;padding:0 14px;
  border-radius:var(--radius-sm);
  border:1px solid var(--line);background:#fff;color:var(--text-secondary);
  font-weight:600;font-size:var(--fs-sm);cursor:pointer;
  transition:background .15s;
}
.calc-modal__backlink:hover{background:var(--bg-soft)}
.calc-modal__close{
  position:relative;width:36px;height:36px;
  border:1px solid var(--line);border-radius:var(--radius-full);
  background:#fff;color:var(--text);font-size:20px;cursor:pointer;
  transition:background .15s;
}
.calc-modal__close:hover{background:var(--bg-soft)}
.calc-modal__lead{margin:8px 0 0;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}
.calc-step h2{margin:8px 0 0;font-size:var(--fs-h1);line-height:1.1;color:var(--brand-navy)}
.calc-form{display:grid;gap:14px;margin-top:20px}
.calc-grid{display:grid;gap:12px}
.calc-grid--2{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:end}
.calc-field{display:grid;gap:6px;position:relative;min-width:0}
.calc-field span,.calc-group__title{font-size:var(--fs-sm);font-weight:600;color:var(--brand-navy)}
.calc-field input,.calc-field select,.calc-field textarea{
  width:100%;padding:12px 14px;
  border-radius:var(--radius-md);
  border:1px solid var(--line-strong);background:#fff;color:var(--text);font:inherit;font-size:var(--fs-md);
  transition:border-color .15s,box-shadow .15s;
}
.calc-field textarea{min-height:100px;resize:vertical}
.calc-field input:focus,.calc-field select:focus,.calc-field textarea:focus{
  outline:none;border-color:var(--brand-teal);
  box-shadow:0 0 0 3px rgba(42,168,179,.15);
}
.calc-group{display:grid;gap:10px}
.calc-check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:start}
.calc-check{
  display:flex;align-items:flex-start;gap:8px;
  padding:10px 12px;min-height:60px;
  border:1px solid var(--line);border-radius:var(--radius-md);
  background:#fff;
}
.calc-check input{width:16px;height:16px;margin-top:2px}
.calc-check span{line-height:1.4;color:var(--text);font-size:13px}
.calc-consent{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 14px;
  border-radius:var(--radius-md);
  background:var(--brand-teal-soft);
  border:1px solid var(--brand-teal);
  line-height:1.55;color:var(--text);
  font-size:var(--fs-sm);
}
.calc-consent input{margin-top:3px}
.calc-consent a{color:var(--brand-teal-2);font-weight:600}
.calc-actions{display:flex;gap:12px;flex-wrap:wrap}
.calc-message{
  display:none;padding:12px 14px;
  border-radius:var(--radius-md);
  background:#fef2e8;border:1px solid #f5c69a;
  color:#8a4e1a;line-height:1.5;font-size:var(--fs-sm);
}
.calc-message.is-visible{display:block}
.calc-switcher{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px;border-radius:var(--radius-md);
  background:var(--bg-soft);border:1px solid var(--line);
}
.calc-switcher__btn{
  min-height:36px;padding:0 14px;
  border:none;border-radius:var(--radius-sm);
  background:transparent;color:var(--muted);
  font-weight:600;font-size:var(--fs-sm);cursor:pointer;
  transition:background .15s,color .15s;
}
.calc-switcher__btn.is-active{background:#fff;color:var(--brand-navy);box-shadow:var(--shadow-sm)}
.calc-summary{
  margin-top:14px;padding:14px 16px;
  border-radius:var(--radius-md);
  background:var(--brand-teal-soft);
  border:1px solid var(--brand-teal);
  color:var(--brand-navy);font-weight:600;line-height:1.5;font-size:var(--fs-sm);
}

/* ATI suggestions */
.ati-suggestions{
  position:absolute;z-index:80;
  top:calc(100% + 6px);left:0;right:0;
  max-height:260px;overflow-y:auto;
  background:#f7fbfc;
  border:1px solid #cfe2e6;
  border-radius:12px;
  box-shadow:0 10px 30px rgba(20,38,66,.14), 0 2px 6px rgba(20,38,66,.06);
  padding:6px;
}
.ati-suggestion-item{
  padding:10px 14px;
  border-radius:10px;
  cursor:pointer;
  display:flex;flex-direction:column;gap:2px;
  background:#fff;
  border:1px solid transparent;
  margin-bottom:4px;
  transition:background .15s,border-color .15s,transform .08s;
}
.ati-suggestion-item:last-child{margin-bottom:0}
.ati-suggestion-item:nth-child(even){background:#eef6f7}
.ati-suggestion-item:hover{background:#2aa8b3;color:#fff;border-color:#2aa8b3;transform:translateY(-1px)}

/* ====================================================================
   Главная — стили карточек в духе /tarify/: белые, с тонкой teal-линией
   слева, мягкой тенью, аккуратной типографикой.
   ==================================================================== */
body[data-page="home"] .step-card{
  background:#fff;
  border:1px solid #e3e7ed;
  border-left:3px solid #2aa8b3;
  border-radius:12px;
  padding:18px 20px;
  box-shadow:0 1px 3px rgba(20,38,66,.04);
  transition:border-color .18s, box-shadow .18s, transform .1s;
}
body[data-page="home"] .step-card:hover{
  border-left-color:#1f8691;
  box-shadow:0 6px 18px rgba(20,38,66,.08);
  transform:translateY(-1px);
}
body[data-page="home"] .step-card h3{
  color:#1a2f4a;
  font-size:16px;
  line-height:1.3;
  margin:0 0 8px;
}
body[data-page="home"] .step-card p{
  color:#4a5568;
  font-size:13.5px;
  line-height:1.55;
  margin:0;
}
body[data-page="home"] .section--alt .step-card{
  background:#ffffff;
}
body[data-page="home"] .section-head h2{
  letter-spacing:-0.3px;
}
body[data-page="home"] .section-head .eyebrow{
  color:#1f8691;
  letter-spacing:0.4px;
  text-transform:uppercase;
  font-weight:700;
  font-size:11.5px;
}
body[data-page="home"] .home-duo-grid,
body[data-page="home"] .cargo-russia-grid-3,
body[data-page="home"] .cargo-russia-grid-2{
  gap:14px;
}

/* i-инфо кнопка — круглая, в стиле /tarify/. Ставится после слова-термина. */
.info-btn-inline{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;
  margin-left:4px;
  border-radius:50%;
  border:1px solid #b7c2d0;
  background:#fff;
  color:#5a6778;
  font-size:11px;font-weight:700;font-style:italic;
  font-family:Georgia, serif;
  line-height:1;padding:0;
  cursor:pointer;user-select:none;
  vertical-align:middle;
  transition:background .15s, border-color .15s, color .15s, box-shadow .15s, transform .08s;
}
.info-btn-inline:hover{border-color:var(--brand-teal,#2aa8b3);color:var(--brand-teal,#2aa8b3);background:#eef9fa}
.info-btn-inline:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(42,168,179,.22)}

/* ====================================================================
   i-инфо блок — глобальный паттерн. Открывается кликом, держится 3 сек,
   плавно угасает 2 сек, полностью исчезает через 5 сек. Каждый tooltip
   независим — открытие нового не отменяет таймер старого.
   ==================================================================== */
.info-tip{
  position:fixed;z-index:9999;
  max-width:280px;
  background:#1a2f4a;color:#fff;
  padding:10px 14px;border-radius:10px;
  font-size:12.5px;line-height:1.5;
  box-shadow:0 10px 30px rgba(20,38,66,.28), 0 2px 8px rgba(20,38,66,.18);
  pointer-events:none;
  opacity:0;transform:translateY(6px) scale(.95);
  transition:opacity .28s ease, transform .28s ease;
}
.info-tip.is-visible{opacity:1;transform:translateY(0) scale(1)}
.info-tip.is-fading{opacity:0;transform:translateY(2px) scale(.97);transition:opacity 2s ease, transform 2s ease}
.info-tip::after{
  content:'';position:absolute;
  left:20px;bottom:-6px;
  border:6px solid transparent;border-top-color:#1a2f4a;border-bottom:0;
}
.info-tip.is-below::after{
  top:-6px;bottom:auto;
  border-bottom-color:#1a2f4a;border-top:0;border-bottom:6px solid #1a2f4a;
  border-top-color:transparent;
}
@keyframes infoBtnPulse{0%{transform:scale(1)}50%{transform:scale(1.18)}100%{transform:scale(1)}}
.info-btn-pulse{animation:infoBtnPulse .42s ease}
.ati-suggestion-item:hover .ati-suggestion-item__title,
.ati-suggestion-item:hover .ati-suggestion-item__meta{color:#fff}
.ati-suggestion-item__title{font-size:14px;font-weight:600;color:var(--brand-navy);line-height:1.3}
.ati-suggestion-item__meta{font-size:12px;color:#5a6778;line-height:1.2}

/* Мигание красным при незаполненном обязательном поле */
@keyframes calcFieldFlash {
  0%,100% { box-shadow:0 0 0 0 rgba(215,58,73,0) }
  30% { box-shadow:0 0 0 4px rgba(215,58,73,.25); border-color:#d73a49 }
  60% { box-shadow:0 0 0 2px rgba(215,58,73,.18); border-color:#d73a49 }
}
.calc-field--error input,
.calc-field--error select,
.calc-field--error .calc-unit-toggle {
  border-color:#d73a49 !important;
  animation:calcFieldFlash 1.2s ease-in-out 2;
  background:#fff6f7;
}
.calc-field--error > span {
  color:#d73a49;
}

/* Раскрывающиеся группы «Услуги / Документы» */
.calc-group--collapsible {
  border:1px solid var(--line);
  border-radius:12px;
  padding:0;
  background:#fff;
  margin-top:10px;
  overflow:hidden;
}
.calc-group--collapsible .calc-group__summary {
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-weight:600;color:var(--brand-navy);font-size:15px;
  transition:background .15s;
}
.calc-group--collapsible .calc-group__summary::-webkit-details-marker{display:none}
.calc-group--collapsible .calc-group__summary::after {
  content:"＋";
  font-weight:400;font-size:20px;color:var(--brand-teal);
  transition:transform .2s;
}
.calc-group--collapsible[open] .calc-group__summary::after {
  content:"−";
}
.calc-group--collapsible .calc-group__summary:hover { background:#f7fbfc }
.calc-group--collapsible .calc-group__title { flex:1 }
.calc-group--collapsible .calc-group__hint {
  font-size:12px;font-weight:500;color:#7a8596;
  background:#eef6f7;padding:3px 10px;border-radius:999px;
}
.calc-group--collapsible[open] .calc-check-grid {
  padding:4px 16px 16px;border-top:1px solid var(--line);background:#fafdfd;
}

/* Дизайн формы калькулятора — в стиле результата /calc/ */
.calc-modal__dialog {
  background:linear-gradient(180deg,#ffffff 0%,#f5f9fa 100%);
}
.calc-step--form {
  padding:20px 24px 28px;
}
@media (max-width: 600px) {
  .calc-modal__dialog { padding: 14px; }
  .calc-step--form { padding: 14px 12px 20px; }
}
.calc-step--form .eyebrow {
  color:var(--brand-teal);
  letter-spacing:0.5px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:700;
}
.calc-step--form h2#calc-modal-title {
  font-size:26px;
  color:var(--brand-navy);
  margin:6px 0 8px;
  line-height:1.2;
}
.calc-modal__lead {
  color:#4a5568;font-size:14px;line-height:1.55;
  margin:0 0 18px;
  padding:14px 16px;
  background:#eef6f7;
  border-left:3px solid var(--brand-teal);
  border-radius:8px;
}
.calc-form .calc-field > span {
  display:block;font-size:13px;font-weight:600;color:var(--brand-navy);
  margin-bottom:6px;letter-spacing:0.2px;
}
.calc-form .calc-field input,
.calc-form .calc-field select {
  width:100%;
  padding:11px 14px;
  border:1px solid #d5dde7;
  border-radius:10px;
  background:#fff;
  font-size:15px;
  color:#202733;
  transition:border-color .15s,box-shadow .15s;
}
.calc-form .calc-field input:focus,
.calc-form .calc-field select:focus {
  outline:none;
  border-color:var(--brand-teal);
  box-shadow:0 0 0 3px rgba(42,168,179,.18);
}

.calc-field__input-wrap { position: relative; }
.calc-field__input-wrap input { padding-right: 40px !important; }
.calc-field__clear {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  border: 0;
  background: transparent;
  color: #7a8596;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  padding: 0;
  transition: color .15s;
}
.calc-field__clear:hover { color: #1a2f4a; }
.calc-field__input-wrap.has-value .calc-field__clear { display: inline-flex; }
.calc-form .calc-field__hint {
  display:block;color:#7a8596;font-size:12px;margin-top:5px;
}
.calc-unit-toggle {
  display:inline-flex;gap:0;
  background:#f0f4f7;border:1px solid #d5dde7;border-radius:10px;
  padding:3px;
}
.calc-unit-toggle input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.calc-unit-toggle label {
  padding:8px 18px;cursor:pointer;font-size:14px;font-weight:500;
  color:#4a5568;border-radius:8px;transition:background .15s,color .15s;
}
.calc-unit-toggle input[type="radio"]:checked + label {
  background:var(--brand-navy);color:#fff;
}

.calc-field--with-toggle { display:block; }
.calc-field--with-toggle > span {
  display:block;font-size:13px;font-weight:600;color:var(--brand-navy);
  margin-bottom:8px;letter-spacing:0.2px;
}
.calc-field--with-toggle .calc-unit-toggle {
  margin-bottom:8px;
}
.calc-field--with-toggle input[type="text"] {
  width:100%;
  padding:11px 14px;
  border:1px solid #d5dde7;
  border-radius:10px;
  background:#fff;
  font-size:15px;
  color:#202733;
  transition:border-color .15s,box-shadow .15s;
}
.calc-field--with-toggle input[type="text"]:focus {
  outline:none;
  border-color:var(--brand-teal);
  box-shadow:0 0 0 3px rgba(42,168,179,.18);
}

/* Helper */
.hidden{display:none!important}

/* ---------------------------
   Media queries — адаптив
   --------------------------- */
@media (max-width:1100px){
  .cards-3,.trust-grid,.docs-grid,.service-grid-3,.footer-grid-wide,.reviews-grid,
  .link-cards,.service-benefits,.service-steps,.catalog-grid,.matrix-grid,
  .review-featured-grid,.tonnage-card-grid,.tonnage-role-grid,
  .tonnage-summary-grid,.tonnage-hero-benefits{grid-template-columns:1fr 1fr}
  .hero-grid,.docs-shell,.service-shell,.contact-grid,.footer-grid,.doc-preview{grid-template-columns:1fr}
  .home-cabinet-grid,.home-price-grid,.home-split{grid-template-columns:1fr}
  .cargo-russia-grid-3,.cargo-russia-format-grid{grid-template-columns:1fr 1fr}
  .move-page-split,.move-page-side-grid{grid-template-columns:1fr}
}

@media (max-width:980px){
  :root{
    --fs-base:15px;
    --fs-md:15px;
    --fs-lg:16px;
    --fs-hero:32px;
    --fs-h1:26px;
    --fs-h2:22px;
    --fs-h3:18px;
  }
  body.mobile-nav-open{overflow:hidden}
  body.mobile-nav-open::before{
    content:"";position:fixed;inset:0;
    background:rgba(18,36,59,0.3);
    backdrop-filter:blur(4px);z-index:45;
  }
  .main-nav,.header-actions{display:none}
  .section-nav-shell{top:64px}
  .section-nav-container{padding-top:8px;padding-bottom:8px}
  .section-tab{min-height:28px;padding:0 10px;border-radius:var(--radius-sm);font-size:12px}
  .menu-toggle{
    display:block;position:relative;z-index:61;
    border:1px solid var(--line);background:#fff;
    border-radius:var(--radius-sm);padding:10px 12px;
    box-shadow:var(--shadow-sm);color:var(--brand-navy);
  }
  .mobile-nav{
    display:none;
    position:fixed;top:72px;left:14px;right:14px;z-index:61;
    padding:16px;gap:10px;
    flex-direction:column;
    border-radius:var(--radius-lg);
    background:#fff;
    box-shadow:var(--shadow-lg);
    max-height:calc(100vh - 100px);overflow:auto;
    pointer-events:auto;border:1px solid var(--line);
  }
  .mobile-nav.open{display:flex}
  .mobile-nav a{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 16px;
    border-radius:var(--radius-md);
    background:var(--bg-soft);color:var(--brand-navy);
    font-weight:600;font-size:var(--fs-md);
    border:1px solid var(--line);
  }
  .mobile-nav a.active{background:var(--brand-teal-soft);color:var(--brand-navy);border-color:var(--brand-teal)}
  .mobile-note{padding:4px 8px 0;color:var(--muted);font-size:13px}
  .mobile-breadcrumb-shell{
    display:block;position:sticky;z-index:33;
    background:rgba(255,255,255,0.96);backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
  }
  .mobile-breadcrumbs{padding:6px 0 8px;font-size:13px;color:var(--muted);white-space:nowrap;overflow-x:auto}
  .mobile-breadcrumbs a{color:var(--brand-teal-2)}
  .has-sticky-breadcrumbs .service-hero .breadcrumbs,
  .has-sticky-breadcrumbs .hero--with-breadcrumbs .breadcrumbs{display:none}

  .badges,.grid-2,.cards-3,.trust-grid,.docs-grid,.faq-grid,.service-grid-3,
  .tariff-row,.footer-grid-wide,.reviews-grid,.link-cards,.service-benefits,
  .service-steps,.search-form,.catalog-grid,.matrix-grid,.home-duo-grid,
  .home-cabinet-grid,.home-segment-grid,.home-price-grid,.home-split,
  .hero-status-grid,.cargo-russia-benefits,.cargo-russia-grid-2,
  .cargo-russia-grid-3,.cargo-russia-format-grid,.cargo-russia-factor-list,
  .move-page-hero-benefits,.move-page-split,.move-page-side-grid,
  .review-featured-grid,.tonnage-card-grid,.tonnage-role-grid,
  .tonnage-summary-grid,.tonnage-hero-benefits{grid-template-columns:1fr}

  .hero h1,.service-copy h1{letter-spacing:-0.015em}
  .header-row{gap:10px;padding:10px 0}
  .brand{gap:3px;flex:1 1 auto;min-width:0}
  .brand-wordmark{font-size:18px;letter-spacing:0.04em}
  .brand-copy strong{font-size:14px}
  .brand-copy small{font-size:10px;letter-spacing:0.1em}
  .brand-text--single{display:block}
  .brand-text--single span::before{font-size:10px;letter-spacing:0.12em}
  .badge{min-height:auto}
  .price-box strong{font-size:28px}
  .hero-copy__support,.hero-cta-note{max-width:none}
  .hero-dashboard__line{flex-direction:column;align-items:flex-start}
  .hero-dashboard__line span{text-align:left}
  .process-card{grid-template-columns:1fr;gap:10px}
  .process-card__num{width:36px;height:36px;font-size:var(--fs-md)}
  .home-split__main,.home-split__side{padding:18px}
  .cargo-russia-benefit{padding:12px 14px}
  .tonnage-benefit,.tonnage-summary-item{padding:12px 14px}
  .tonnage-label-card{min-height:auto}
  .compare-shell{padding:18px}
  .compare-side{padding:14px}
  .tariff-table-wide{min-width:760px}
  .tariff-table-wide th,.tariff-table-wide td{padding:12px 14px}
  .search-card{padding:16px}
  .search-card--hero{padding:16px}
  .search-form{grid-template-columns:1fr}
  .search-form input{padding:14px 16px;font-size:var(--fs-md)}
  .search-keywords{gap:5px;margin-top:10px}
  .search-keywords .keyword-chip{padding:5px 10px;font-size:12px}
  .search-results{margin-top:6px}
  .search-result{padding:10px 0 12px}
  .search-result__source{font-size:12px}
  .search-result__page{font-size:15px}
  .search-result__description{font-size:13px;line-height:1.5}
  .search-result__snippets{gap:6px}
  .search-result__snippet{padding:5px 9px;font-size:12px}
  .hero-road{grid-template-columns:1fr;gap:10px;padding-top:4px}
  .hero-road__line{display:none}
  .hero-road__stop{justify-items:start;text-align:left;padding-left:48px;position:relative}
  .hero-road__stop strong{position:absolute;left:0;top:0}
  .hero-road__stop span{max-width:none}
  .cookie-banner{left:12px;right:12px;bottom:12px;max-width:none;flex-direction:column;align-items:flex-start}
  .cookie-banner__text{max-width:none}
  .cookie-banner__actions{width:100%;justify-content:space-between}
  .helper-modal{padding:12px}
  .helper-modal__dialog{padding:22px 20px}
  .helper-modal__dialog h2{font-size:var(--fs-h2)}
  .calc-modal{padding:12px}
  .calc-modal__dialog{padding:20px 18px;border-radius:var(--radius-lg)}
  .calc-modal__topbar{grid-template-columns:1fr auto;grid-template-areas:"back close" "brand brand";gap:8px}
  .calc-modal__backlink{grid-area:back;min-height:36px;padding:0 12px;font-size:13px}
  .calc-modal__brand{grid-area:brand}
  .calc-modal__close{grid-area:close;justify-self:end}
  .calc-modal__brand strong{font-size:16px}
  .calc-modal__brand span{font-size:10px;letter-spacing:0.12em}
  .calc-grid--2,.calc-check-grid{grid-template-columns:1fr}
  .calc-step h2{font-size:var(--fs-h2)}
  .site-footer{padding:28px 0 18px}
}

/* ==========================================================================
   ВИЗУАЛЬНЫЕ МОДИФИКАТОРЫ — акцентные секции, stats, градиенты, CTA-полосы
   ========================================================================== */

/* Тёмная секция (navy фон, белый текст) */
.section--dark{
  background:linear-gradient(135deg,var(--brand-navy) 0%,var(--brand-navy-2) 100%);
  color:#fff;
  margin:48px 0;
  padding:56px 0;
  position:relative;
  overflow:hidden;
}
.section--dark::before{
  content:"";
  position:absolute;top:0;right:0;width:40%;height:100%;
  background:radial-gradient(circle at 80% 50%,rgba(42,168,179,0.15) 0%,transparent 70%);
  pointer-events:none;
}
.section--dark .container{position:relative;z-index:1}
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4{color:#fff}
.section--dark .eyebrow{color:var(--brand-teal);opacity:0.95}
.section--dark p{color:rgba(255,255,255,0.82);line-height:var(--lh-relaxed)}
.section--dark .card,
.section--dark .step-card,
.section--dark .link-card,
.section--dark .process-card,
.section--dark article.step-card{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(10px);
  color:#fff;
}
.section--dark .card h3,
.section--dark .step-card h3,
.section--dark .link-card h3{color:#fff}
.section--dark .card p,
.section--dark .step-card p,
.section--dark .link-card p{color:rgba(255,255,255,0.78)}
.section--dark .btn-primary{background:var(--brand-teal);border-color:var(--brand-teal);color:#fff}
.section--dark .btn-secondary{background:transparent;border-color:rgba(255,255,255,0.35);color:#fff}
.section--dark .btn-secondary:hover{background:rgba(255,255,255,0.08);border-color:#fff}
.section--dark .process-card__num{background:var(--brand-teal);color:#fff}

/* Teal-soft секция */
.section--teal{
  background:linear-gradient(135deg,var(--brand-teal-soft) 0%,#d8eef0 100%);
  margin:32px 0;
  padding:48px 0;
  border-top:3px solid var(--brand-teal);
  border-bottom:3px solid var(--brand-teal);
}
.section--teal .eyebrow{color:var(--brand-teal-2)}
.section--teal h2{color:var(--brand-navy)}

/* Альт фон для чередования */
.section--alt{
  background:var(--bg-soft);
}

/* Stats-strip — полоса метрик с большими цифрами */
.stats-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  margin:0 0 16px;
}
.stats-strip__item{
  padding:28px 20px;
  border-right:1px solid var(--line);
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:6px;
  justify-content:center;
  align-items:center;
  background:#fff;
  transition:background .2s;
}
.stats-strip__item:last-child{border-right:0}
.stats-strip__item:hover{background:var(--brand-teal-soft)}
.big-number{
  font-family:var(--font-display);
  font-size:48px;
  font-weight:800;
  line-height:1;
  letter-spacing:-0.02em;
  color:var(--brand-navy);
  display:block;
}
.big-number--teal{color:var(--brand-teal-2)}
.stats-strip__label{
  font-size:var(--fs-sm);
  color:var(--muted);
  line-height:1.4;
  max-width:180px;
}
.stats-strip__caption{
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--brand-teal-2);
  font-weight:600;
}

/* Feature highlight — карточка с цветным левым бордером */
.feature-highlight{
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--brand-teal);
  border-radius:var(--radius-md);
  padding:18px 22px;
  box-shadow:var(--shadow-sm);
}
.feature-highlight--navy{border-left-color:var(--brand-navy)}
.feature-highlight--warn{border-left-color:#f59e0b;background:#fffbeb}
.feature-highlight h3,
.feature-highlight strong{color:var(--brand-navy);font-size:var(--fs-h4);margin:0 0 6px;display:block}
.feature-highlight p{color:var(--text-secondary);line-height:var(--lh-relaxed);margin:0;font-size:var(--fs-md)}

/* CTA-strip — большая акцентная полоса */
.cta-strip{
  display:grid;
  grid-template-columns:1.4fr auto;
  gap:24px;
  align-items:center;
  padding:32px 36px;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--brand-navy) 0%,var(--brand-navy-2) 55%,var(--brand-teal-2) 100%);
  color:#fff;
  margin:24px 0;
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
}
.cta-strip::before{
  content:"";
  position:absolute;top:-30%;right:-10%;width:50%;height:160%;
  background:radial-gradient(circle,rgba(42,168,179,0.25) 0%,transparent 70%);
  pointer-events:none;
}
.cta-strip__body{position:relative;z-index:1}
.cta-strip h2,
.cta-strip h3{color:#fff;margin:0 0 6px;font-size:var(--fs-h2);line-height:1.15}
.cta-strip p{color:rgba(255,255,255,0.85);margin:0;line-height:var(--lh-relaxed);font-size:var(--fs-md)}
.cta-strip__actions{
  position:relative;z-index:1;
  display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;
}
.cta-strip .btn-primary{background:var(--brand-teal);border-color:var(--brand-teal);color:#fff;font-weight:700}
.cta-strip .btn-primary:hover{background:#26c0cd;border-color:#26c0cd}
.cta-strip .btn-secondary{background:transparent;border-color:rgba(255,255,255,0.45);color:#fff}
.cta-strip .btn-secondary:hover{background:rgba(255,255,255,0.1);border-color:#fff}

/* Градиентный hero */
.gradient-hero{
  background:linear-gradient(135deg,var(--brand-teal-soft) 0%,var(--brand-navy-soft) 50%,#fff 100%);
  padding:56px 0 40px;
  border-bottom:1px solid var(--line);
}

/* Numbered list — BIG */
.numbered-list--big{
  display:grid;
  gap:14px;
  list-style:none;
  padding:0;
  margin:0;
  counter-reset:step;
}
.numbered-list--big li{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:18px;
  align-items:start;
  padding:18px 20px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  transition:border-color .2s,box-shadow .2s;
}
.numbered-list--big li:hover{border-color:var(--brand-teal);box-shadow:var(--shadow-sm)}
.numbered-list--big li::before{
  counter-increment:step;
  content:counter(step);
  font-family:var(--font-display);
  font-size:42px;
  font-weight:800;
  line-height:1;
  color:var(--brand-teal);
  letter-spacing:-0.02em;
  text-align:center;
}
.numbered-list--big h3{margin:0 0 4px;font-size:var(--fs-h4);color:var(--brand-navy)}
.numbered-list--big p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}

/* Acccent tag */
.tag-accent{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;
  border-radius:var(--radius-full);
  background:var(--brand-teal);
  color:#fff;
  font-size:12px;font-weight:600;letter-spacing:0.02em;
}
.tag-accent--navy{background:var(--brand-navy);color:#fff}
.tag-accent--soft{background:var(--brand-teal-soft);color:var(--brand-teal-2);border:1px solid var(--brand-teal)}

/* Price example card — пример расчёта */
.price-example{
  background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow);
}
.price-example__head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:16px;
  padding-bottom:14px;
  margin-bottom:14px;
  border-bottom:2px solid var(--brand-teal);
}
.price-example__title{font-size:var(--fs-h4);font-weight:700;color:var(--brand-navy)}
.price-example__meta{font-size:var(--fs-sm);color:var(--muted)}
.price-example__row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  padding:8px 0;
  font-size:var(--fs-md);
  border-bottom:1px dashed var(--line);
}
.price-example__row:last-child{border-bottom:0;padding-top:14px;border-top:2px solid var(--brand-teal);font-weight:700;font-size:var(--fs-lg);color:var(--brand-navy);margin-top:6px}
.price-example__label{color:var(--text-secondary)}
.price-example__value{color:var(--brand-navy);font-family:var(--font-mono);font-weight:600;text-align:right}

/* Мозаика с крупными карточками */
.mega-card{
  position:relative;
  padding:28px 24px;
  background:linear-gradient(135deg,var(--bg-soft) 0%,#fff 100%);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  transition:box-shadow .2s,transform .15s,border-color .15s;
}
.mega-card:hover{
  box-shadow:var(--shadow);
  border-color:var(--brand-teal);
  transform:translateY(-2px);
}
.mega-card__icon{
  width:48px;height:48px;
  border-radius:var(--radius-md);
  background:var(--brand-teal-soft);
  color:var(--brand-teal-2);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  font-size:24px;
}
.mega-card h3{margin:0 0 8px;color:var(--brand-navy)}
.mega-card p{margin:0;color:var(--text-secondary);line-height:var(--lh-relaxed);font-size:var(--fs-md)}

/* Иконки emoji помогают, но можно стилизовать */
.icon-bubble{
  width:36px;height:36px;
  border-radius:var(--radius-full);
  background:var(--brand-teal-soft);
  color:var(--brand-teal-2);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;
  margin-right:8px;
  flex:0 0 auto;
}

/* Адаптив для новых блоков */
@media (max-width:1100px){
  .stats-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stats-strip__item{border-right:0;border-bottom:1px solid var(--line)}
  .stats-strip__item:nth-child(odd){border-right:1px solid var(--line)}
  .stats-strip__item:nth-last-child(-n+2){border-bottom:0}
  .cta-strip{grid-template-columns:1fr;padding:24px}
  .cta-strip__actions{justify-content:flex-start}
}
@media (max-width:760px){
  .big-number{font-size:36px}
  .stats-strip{grid-template-columns:1fr}
  .stats-strip__item{border-right:0;border-bottom:1px solid var(--line);padding:20px 16px}
  .stats-strip__item:last-child{border-bottom:0}
  .section--dark,.section--teal{padding:36px 0;margin:28px 0}
  .cta-strip{padding:20px;grid-template-columns:1fr}
  .numbered-list--big li{grid-template-columns:44px 1fr;gap:12px;padding:14px 16px}
  .numbered-list--big li::before{font-size:32px}
  .price-example{padding:18px}
  .mega-card{padding:22px 20px}
}

@media (max-width:760px){
  :root{--fs-hero:28px;--fs-h1:22px;--fs-h2:20px}
  .section{padding:32px 0}
  .section-head{margin-bottom:20px}
  .hero{padding:24px 0 20px}
  .hero h1{margin-bottom:12px}

  .tariff-table-wrap{overflow:visible;border:none;border-radius:0;background:transparent;box-shadow:none}
  .tariff-table-wide,
  .tariff-table-wide tbody,
  .tariff-table-wide tr,
  .tariff-table-wide td{display:block;width:100%}
  .tariff-table-wide{min-width:0;border-collapse:separate;border-spacing:0}
  .tariff-table-wide thead{
    position:absolute;width:1px;height:1px;
    padding:0;margin:-1px;overflow:hidden;
    clip:rect(0,0,0,0);clip-path:inset(50%);
    white-space:nowrap;border:0;
  }
  .tariff-table-wide tbody{display:grid;gap:12px}
  .tariff-table-wide tr{
    overflow:hidden;
    border:1px solid var(--line);
    border-radius:var(--radius-md);
    background:#fff;box-shadow:var(--shadow-sm);
  }
  .tariff-table-wide td{padding:10px 14px;border-bottom:1px solid var(--line)}
  .tariff-table-wide td:first-child{padding-top:14px}
  .tariff-table-wide td:last-child{padding-bottom:14px;border-bottom:none}
  .tariff-table-wide td::before{
    content:attr(data-label);
    display:block;margin-bottom:3px;
    color:var(--muted);font-size:11px;font-weight:700;
    letter-spacing:0.08em;line-height:1.3;text-transform:uppercase;
  }
  .tariff-table-wide td strong{display:block;font-size:var(--fs-md);line-height:1.4;color:var(--brand-navy)}
}

/* ============================================================
   МЕНЮ ШАПКИ v4 (2026-04-21) — плоское, без раскрывашек.
   Правило: в шапке только прямые ссылки на хаб-страницы.
   Раскрывающиеся блоки запрещены (директива пользователя).
   ============================================================ */
.top-nav{display:flex;flex:1;justify-content:center}
.top-nav__list{
  list-style:none;padding:0;margin:0;
  display:flex;gap:4px;align-items:center;
  font-weight:600;font-size:var(--fs-md);
}
.top-nav__list > li{position:relative}
.top-nav__list > li > a{
  display:inline-flex;align-items:center;
  padding:10px 14px;
  font-family:inherit;font-size:var(--fs-md);font-weight:600;
  color:var(--text-secondary);
  border-radius:8px;
  transition:background 0.15s,color 0.15s;
  text-decoration:none;
}
.top-nav__list > li > a:hover,
.top-nav__list > li > a.active{
  color:var(--brand-navy);
  background:var(--bg-soft);
}
.mobile-cabinet{
  background:var(--brand-teal) !important;color:#fff !important;
  text-align:center;font-weight:600;
}

@media (max-width: 1100px){
  .top-nav__list{gap:2px;font-size:13.5px}
  .top-nav__list > li > a{padding:9px 10px}
}
@media (max-width: 980px){
  .top-nav{display:none !important}
  .header-actions{display:none !important}
  .menu-toggle{display:block !important}
  .mobile-nav{display:none}
  .mobile-nav.open{display:flex !important;flex-direction:column;gap:8px}
  .mobile-nav > a{
    display:block !important;
    padding:13px 16px !important;
    background:var(--bg-soft) !important;
    color:var(--brand-navy) !important;
    font-weight:600 !important;font-size:15px !important;
    border:1px solid var(--line) !important;border-radius:10px !important;
    text-decoration:none !important;
  }
  .mobile-nav > a:hover{background:var(--brand-teal-soft) !important}
  .mobile-nav > a.mobile-cabinet{
    background:var(--brand-teal) !important;
    color:#fff !important;
    border:none !important;
    text-align:center !important;
    margin-top:8px !important;
  }
  .mobile-nav .mobile-note{color:var(--muted);font-size:13px;text-align:center;padding-top:6px}
}

/* ============================================================
   ФУТЕР v2: тематические пулы, 4 колонки, разная "окраска" 
   через data-атрибут site-footer--<pool>
   ============================================================ */
.site-footer--moves{border-top:3px solid var(--brand-teal)}
.site-footer--vehicles{border-top:3px solid var(--brand-navy)}
.site-footer--specials{border-top:3px solid #c27f30}
.site-footer--universal{border-top:3px solid var(--brand-teal)}
.footer-soon{color:var(--muted) !important}
.footer-soon em{
  display:inline-block;margin-left:4px;padding:1px 6px;
  background:var(--bg-soft);color:var(--muted);
  font-size:9px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;
  border-radius:3px;font-style:normal;vertical-align:middle;
}
.footer-soon:hover{color:var(--brand-navy) !important}
[data-footer-lead]{font-size:var(--fs-md);line-height:1.55;color:var(--text-secondary);margin-bottom:12px}

/* ============================================================
   Калькулятор — маячок единицы измерения (кг/тонн) и подсказки полей
   ============================================================ */
.calc-unit-toggle{
  display:inline-flex;gap:0;
  margin-top:6px;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:10px;padding:3px;
  width:fit-content;
}
.calc-unit-toggle input[type="radio"]{
  position:absolute;opacity:0;pointer-events:none;
}
.calc-unit-toggle label{
  padding:9px 22px;
  font-size:14px;font-weight:500;
  color:var(--muted);
  cursor:pointer;
  border-radius:7px;
  transition:background .15s, color .15s;
  user-select:none;
  margin:0;
}
.calc-unit-toggle input[type="radio"]:checked + label{
  background:var(--brand-teal);
  color:#fff;
  font-weight:600;
}
.calc-unit-toggle input[type="radio"]:focus-visible + label{
  outline:2px solid var(--brand-teal);outline-offset:2px;
}
.calc-field__hint{
  display:block;margin-top:5px;
  font-size:12px;line-height:1.3;
  color:var(--muted);
}

/* ============================================================
   МОБИЛЬНОЕ МЕНЮ v2 — двустрочные пункты (название + описание).
   Высокая специфичность .mobile-nav.open .* — перебивает старые
   правила .mobile-nav > a !important (специфичность 21).
   ============================================================ */
.mobile-nav .mobile-nav__section-title,
.mobile-nav.open .mobile-nav__section-title{
  display:block !important;
  font-size:11px !important;
  font-weight:700 !important;
  text-transform:uppercase !important;
  letter-spacing:0.6px !important;
  color:var(--muted) !important;
  padding:6px 4px 2px !important;
  background:transparent !important;
  border:none !important;
}
.mobile-nav .mobile-nav__item,
.mobile-nav.open .mobile-nav__item{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
  gap:3px !important;
  padding:14px 16px !important;
  border-radius:12px !important;
  background:var(--bg-soft) !important;
  color:var(--brand-navy) !important;
  border:1px solid var(--line) !important;
  text-decoration:none !important;
  font-weight:400 !important;
  text-align:left !important;
  margin:0 !important;
  transition:background 0.15s,border-color 0.15s;
}
.mobile-nav .mobile-nav__item:hover,
.mobile-nav.open .mobile-nav__item:hover,
.mobile-nav .mobile-nav__item:focus-visible,
.mobile-nav.open .mobile-nav__item:focus-visible{
  background:var(--brand-teal-soft) !important;
  border-color:var(--brand-teal) !important;
}
.mobile-nav .mobile-nav__title,
.mobile-nav.open .mobile-nav__title{
  display:block !important;
  font-size:15px !important;
  font-weight:600 !important;
  color:var(--brand-navy) !important;
  line-height:1.3 !important;
}
.mobile-nav .mobile-nav__sub,
.mobile-nav.open .mobile-nav__sub{
  display:block !important;
  font-size:13px !important;
  font-weight:400 !important;
  color:var(--muted) !important;
  line-height:1.4 !important;
}
.mobile-nav .mobile-nav__cta,
.mobile-nav.open .mobile-nav__cta{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:center !important;
  gap:4px !important;
  padding:16px !important;
  border-radius:12px !important;
  background:var(--brand-teal) !important;
  color:#fff !important;
  border:none !important;
  text-decoration:none !important;
  margin-top:8px !important;
  text-align:center !important;
  font-weight:600 !important;
}
.mobile-nav .mobile-nav__cta:hover,
.mobile-nav.open .mobile-nav__cta:hover,
.mobile-nav .mobile-nav__cta:focus-visible,
.mobile-nav.open .mobile-nav__cta:focus-visible{
  background:var(--brand-navy) !important;
  color:#fff !important;
}
.mobile-nav .mobile-nav__cta-title,
.mobile-nav.open .mobile-nav__cta-title{
  display:block !important;
  font-size:16px !important;
  font-weight:700 !important;
  color:#fff !important;
  line-height:1.3 !important;
}
.mobile-nav .mobile-nav__cta-sub,
.mobile-nav.open .mobile-nav__cta-sub{
  display:block !important;
  font-size:13px !important;
  font-weight:400 !important;
  color:rgba(255,255,255,0.85) !important;
  line-height:1.4 !important;
}

/* =========================================================================
   MOBILE GUARDS FOR INLINE-STYLED BLOCKS
   ----------------------------------------------------------------------
   Правила работы с инлайн-вёрсткой на телефоне (≤640px). Когда на странице
   появляются новые блоки с inline `style="display:grid;..."`,
   `grid-column:span 2`, большими паддингами и flex-карточками с gap —
   эти правила автоматически нормализуют их под мобилку. Не удалять.

   Что покрыто:
   1. Любая inline-grid с repeat(auto-fit, minmax(...)) — в одну колонку.
   2. Любой inline `grid-column:span N` — растягивается на всю строку.
   3. Inline-grid с большим min-width (>=300px) принудительно 1fr,
      чтобы карточка не выезжала за экран в 360-390px.
   4. Карточки с большими inline-паддингами (32px/28px/24px) ужимаются.
   5. Inline-flex-карточки с большим gap/min-width дочерних — column-режим.
   6. Inline `flex-shrink:0` у крупных CTA-кнопок сбрасывается, чтобы
      кнопка переносилась на новую строку, а не выталкивала контент.
   ========================================================================= */
@media (max-width:640px){

  main [style*="grid-template-columns"][style*="repeat(auto-fit"],
  main [style*="grid-template-columns"][style*="repeat( auto-fit"]{
    grid-template-columns:1fr !important;
  }

  main [style*="grid-column:span"],
  main [style*="grid-column: span"]{
    grid-column:1 / -1 !important;
  }

  main [style*="padding:32px 28px"],
  main [style*="padding: 32px 28px"]{
    padding:22px 18px !important;
  }
  main [style*="padding:24px 22px"],
  main [style*="padding: 24px 22px"]{
    padding:18px 16px !important;
  }
  main [style*="padding:22px 24px"],
  main [style*="padding: 22px 24px"]{
    padding:18px 16px !important;
  }
  main [style*="padding:20px 18px"],
  main [style*="padding: 20px 18px"]{
    padding:16px 14px !important;
  }

  main [style*="display:flex"][style*="gap:18px"][style*="flex-wrap:wrap"]{
    gap:14px !important;
  }
  main [style*="display:flex"][style*="gap:18px"][style*="flex-wrap:wrap"] > a[style*="flex-shrink:0"]{
    width:100% !important;
    justify-content:center !important;
  }

  main [style*="font-size:56px"]{ font-size:42px !important; }

  main section[id="manifest"] .manifest-grid{ grid-template-columns:1fr !important; }
  main section[id="manifest"] .manifest-quote p[style*="font-size:20px"]{ font-size:17px !important; }

  main [style*="width:56px"][style*="height:56px"]{ width:44px !important; height:44px !important; font-size:22px !important; }

  main section h2[style*="font-size:20px"]{ font-size:18px !important; }
  main section h2[style*="font-size:clamp(22px"]{ font-size:20px !important; }
}

