/* ФОРПОСТ · vitvetved.ru · forpost.css v1.0 */

/* ─── ФОРПОСТ · vitvetved.ru · MAIN CSS ──────────────────────── */
:root {
  --dk:  #131926;       /* основной фон */
  --dk2: #1A2338;       /* фон карточек */
  --dk3: #0E1520;       /* глубокий фон */
  --dk4: #212D45;       /* карточки hover */
  --am:  #F0A020;       /* amber акцент */
  --aml: rgba(240,160,32,.10);
  --amm: rgba(240,160,32,.22);
  --amh: rgba(240,160,32,.35);
  --tx:  #F2EDE8;       /* основной текст */
  --txm: rgba(242,237,232,.55);
  --txd: rgba(242,237,232,.25);
  --txf: rgba(242,237,232,.10);
  --br:  rgba(242,237,232,.08);
  --bra: rgba(240,160,32,.18);
  --re:  #E24B4A;
  --fs-d: 'Epilogue', sans-serif;
  --fs-b: 'Manrope', sans-serif;
  --fs-m: 'DM Mono', monospace;
  --mw: 1340px;
  --px: 48px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--fs-b);
  font-size: 16px;
  line-height: 1.6;
  background: var(--dk);
  color: var(--tx);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
.wrap { max-width: var(--mw); margin: 0 auto; padding: 0 var(--px); }

/* ─── TOP BAR ───────────────────────────────────────────────── */
.topbar {
  background: var(--dk3);
  border-bottom: 1px solid var(--br);
  padding: 8px 0;
  font-size: 12px;
  color: var(--txm);
}
.topbar-inner {
  display: flex; justify-content: space-between; align-items: center;
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--px);
}
.topbar a { color: var(--txm); }
.topbar a:hover { color: var(--am); }
.top-contacts, .top-social { display: flex; gap: 16px; align-items: center; }
.tg-dot { display: inline-block; width: 7px; height: 7px; background: var(--am); border-radius: 50%; margin-right: 4px; }

/* ─── HEADER ─────────────────────────────────────────────────── */
.site-header {
  background: var(--dk);
  border-bottom: 1px solid var(--br);
  padding: 18px 0;
  position: sticky; top: 0; z-index: 100;
}
.header-inner {
  display: flex; justify-content: space-between; align-items: center;
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--px);
}
.logo {
  font-family: var(--fs-d);
  font-size: 26px; font-weight: 900;
  color: var(--tx); letter-spacing: -.04em;
}
.logo span { color: var(--am); }
.logo-sub {
  font-family: var(--fs-m);
  font-size: 9px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--txd);
  margin-top: 2px;
}
.header-cta {
  background: var(--am); color: var(--dk); border: none;
  font-family: var(--fs-b); font-size: 13px; font-weight: 700;
  padding: 10px 24px; cursor: pointer; letter-spacing: .02em;
  transition: opacity .15s;
}
.header-cta:hover { opacity: .88; }

/* ─── NAV ────────────────────────────────────────────────────── */
.site-nav {
  background: var(--dk2);
  border-bottom: 1px solid var(--br);
}
.nav-inner {
  display: flex; gap: 0;
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--px);
}
.nav-inner a {
  font-size: 13px; font-weight: 500;
  color: var(--txm); padding: 12px 16px;
  border-bottom: 2px solid transparent;
  transition: all .15s;
  white-space: nowrap;
}
.nav-inner a:hover, .nav-inner a.active { color: var(--tx); border-bottom-color: var(--am); }

/* ─── TICKER ─────────────────────────────────────────────────── */
.ticker {
  background: var(--am); color: var(--dk);
  font-family: var(--fs-m); font-size: 11px; font-weight: 500;
  padding: 7px 0; text-align: center; letter-spacing: .06em;
}

/* ─── HERO ───────────────────────────────────────────────────── */
.hero {
  background: var(--dk3);
  padding: 72px 0 64px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; top: 0; right: 0;
  width: 600px; height: 600px;
  background: radial-gradient(circle at center, rgba(240,160,32,.06) 0%, transparent 70%);
  pointer-events: none;
}
.hero-inner {
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--px);
  display: grid; grid-template-columns: 1fr 400px; gap: 64px; align-items: start;
}
.hero-kicker {
  font-family: var(--fs-m); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(240,160,32,.5);
  margin-bottom: 18px;
}
.hero-h1 {
  font-family: var(--fs-d);
  font-size: clamp(36px,4vw,60px);
  font-weight: 900; letter-spacing: -.04em; line-height: 1.0;
  color: var(--tx); margin-bottom: 18px;
}
.hero-h1 em { font-style: normal; color: var(--am); }
.hero-p {
  font-size: 16px; color: var(--txm); line-height: 1.65;
  max-width: 520px; margin-bottom: 28px;
}
.hero-btns { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.btn-primary {
  background: var(--am); color: var(--dk);
  font-family: var(--fs-b); font-size: 14px; font-weight: 700;
  padding: 13px 28px; border: none; cursor: pointer;
  transition: opacity .15s; white-space: nowrap;
}
.btn-primary:hover { opacity: .88; }
.btn-outline {
  border: 1px solid var(--amm); color: var(--txm);
  font-family: var(--fs-b); font-size: 14px;
  padding: 12px 28px; background: transparent; cursor: pointer;
  transition: all .15s; white-space: nowrap;
}
.btn-outline:hover { border-color: var(--am); color: var(--tx); }
.hero-stats {
  display: flex; gap: 0; margin-top: 40px;
  padding-top: 32px; border-top: 1px solid var(--br);
}
.hero-stat {
  flex: 1; padding-right: 28px;
  border-right: 1px solid var(--br);
}
.hero-stat:last-child { border-right: none; padding-left: 28px; padding-right: 0; }
.hero-stat:first-child { padding-left: 0; }
.hero-stat dt {
  font-family: var(--fs-d); font-size: 30px; font-weight: 900;
  color: var(--am); letter-spacing: -.03em; line-height: 1;
}
.hero-stat dd {
  font-family: var(--fs-m); font-size: 10px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--txd); margin-top: 4px;
}

/* ─── HERO WIDGET: risk check ────────────────────────────────── */
.risk-widget {
  background: var(--dk2); border: 1px solid var(--bra);
  padding: 24px;
}
.rw-title {
  font-family: var(--fs-d); font-size: 14px; font-weight: 900;
  letter-spacing: -.01em; margin-bottom: 16px;
  color: var(--tx);
}
.rw-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; margin-bottom: 8px;
  border: 1px solid var(--br);
  font-size: 13px;
}
.rw-row .rw-icon { font-size: 16px; flex-shrink: 0; }
.rw-row.ok { border-color: rgba(26,122,74,.3); }
.rw-row.warn { border-color: rgba(240,160,32,.25); }
.rw-row.fail { border-color: rgba(226,75,74,.3); }
.rw-row .rw-label { flex: 1; color: var(--txm); }
.rw-row .rw-status { font-family: var(--fs-m); font-size: 11px; font-weight: 500; }
.rw-row.ok .rw-status { color: #4caf7d; }
.rw-row.warn .rw-status { color: var(--am); }
.rw-row.fail .rw-status { color: var(--re); }
.rw-cta {
  display: block; text-align: center; margin-top: 14px;
  background: var(--aml); border: 1px solid var(--amm);
  color: var(--am); font-size: 12px; font-weight: 700;
  padding: 10px; letter-spacing: .04em; cursor: pointer;
  transition: background .15s;
}
.rw-cta:hover { background: var(--amm); }

/* ─── PROOF STRIP ────────────────────────────────────────────── */
.proof {
  background: var(--dk2);
  border-top: 1px solid var(--bra);
  border-bottom: 1px solid var(--br);
  padding: 20px 0;
}
.proof-inner {
  display: flex; gap: 0;
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--px);
}
.proof-item {
  flex: 1; display: flex; align-items: center; gap: 12px;
  padding: 0 24px; border-right: 1px solid var(--br);
}
.proof-item:first-child { padding-left: 0; }
.proof-item:last-child { border-right: none; }
.proof-icon { font-size: 18px; }
.proof-text strong { display: block; font-size: 13px; font-weight: 600; color: var(--tx); }
.proof-text span { font-size: 11px; color: var(--txd); }

/* ─── SECTION COMMON ─────────────────────────────────────────── */
.section { padding: 80px 0; }
.section-kicker {
  font-family: var(--fs-m); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(240,160,32,.5); margin-bottom: 10px;
}
.section-title {
  font-family: var(--fs-d); font-size: clamp(26px,3vw,40px);
  font-weight: 900; letter-spacing: -.03em; line-height: 1.05;
  color: var(--tx); margin-bottom: 10px;
}
.section-sub {
  font-size: 14px; color: var(--txm); line-height: 1.6;
  max-width: 560px; margin-bottom: 40px;
}

/* ─── SERVICES ───────────────────────────────────────────────── */
.services { background: var(--dk); }
.svc-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--br);
}
.svc-card {
  background: var(--dk);
  padding: 24px 20px;
  display: flex; flex-direction: column;
  transition: background .18s;
}
.svc-card:hover { background: var(--dk2); }
.svc-card.featured { background: var(--dk2); border: 1px solid var(--bra); margin: -1px; }
.svc-num {
  font-family: var(--fs-m); font-size: 11px; color: var(--txd);
  margin-bottom: 10px; letter-spacing: .12em;
}
.svc-name {
  font-family: var(--fs-d); font-size: 17px; font-weight: 700;
  color: var(--tx); margin-bottom: 8px; letter-spacing: -.01em; line-height: 1.2;
}
.svc-desc { font-size: 12px; color: var(--txm); line-height: 1.55; flex: 1; margin-bottom: 16px; }
.svc-price {
  font-family: var(--fs-m); font-size: 18px; font-weight: 500; color: var(--am);
}
.svc-price span { font-size: 11px; color: var(--txd); display: block; margin-top: 2px; }
.svc-badge {
  display: inline-block; font-family: var(--fs-m); font-size: 10px;
  background: var(--aml); color: var(--am); border: 1px solid var(--amm);
  padding: 2px 8px; margin-bottom: 8px; letter-spacing: .1em;
}

/* ─── WHY ────────────────────────────────────────────────────── */
.why { background: var(--dk2); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--br); margin-bottom: 40px; }
.why-card { background: var(--dk2); padding: 28px; }
.why-num {
  font-family: var(--fs-d); font-size: 40px; font-weight: 900;
  color: var(--aml); letter-spacing: -.04em; line-height: 1; margin-bottom: 12px;
}
.why-card h3 { font-family: var(--fs-d); font-size: 16px; font-weight: 700; color: var(--tx); margin-bottom: 8px; letter-spacing: -.01em; }
.why-card p { font-size: 13px; color: var(--txm); line-height: 1.6; }

.vs-table { width: 100%; border-collapse: collapse; }
.vs-table th {
  padding: 12px 20px; text-align: left;
  font-family: var(--fs-m); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--txd);
  border-bottom: 1px solid var(--br);
}
.vs-table td { padding: 14px 20px; font-size: 13px; border-bottom: 1px solid var(--br); }
.vs-table td:first-child { color: var(--txm); }
.vs-table td:nth-child(2) { color: var(--re); }
.vs-table td:last-child { color: #4caf7d; font-weight: 600; }
.vs-table th:first-child { width: 30%; }
.vs-table th:nth-child(2) { width: 35%; }

/* ─── TOOLS ──────────────────────────────────────────────────── */
.tools { background: var(--dk3); }
.tools-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--br); }
.tool-card {
  background: var(--dk3); padding: 24px 20px;
  transition: background .18s;
}
.tool-card:hover { background: var(--dk2); }
.tool-icon {
  width: 40px; height: 40px;
  background: var(--aml); border: 1px solid var(--amm);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; margin-bottom: 14px;
}
.tool-name { font-family: var(--fs-d); font-size: 15px; font-weight: 700; color: var(--tx); margin-bottom: 6px; }
.tool-desc { font-size: 12px; color: var(--txm); line-height: 1.55; margin-bottom: 14px; }
.tool-link {
  font-family: var(--fs-m); font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--am); border-bottom: 1px solid var(--amm);
  padding-bottom: 2px; display: inline-block; cursor: pointer;
}

/* ─── TEAM ───────────────────────────────────────────────────── */
.team { background: var(--dk); }
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--br); }
.team-card { background: var(--dk); padding: 20px; }
.team-card.lead { background: var(--dk2); border-top: 2px solid var(--am); margin-top: -1px; }
.t-ava {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--dk2); border: 1px solid var(--bra);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fs-m); font-size: 13px; font-weight: 500;
  color: var(--am); margin-bottom: 12px;
}
.lead .t-ava { background: var(--aml); }
.t-role {
  font-family: var(--fs-m); font-size: 9px; letter-spacing: .15em;
  text-transform: uppercase; color: var(--txd); margin-bottom: 4px;
}
.t-name { font-family: var(--fs-d); font-size: 15px; font-weight: 700; color: var(--tx); margin-bottom: 6px; }
.t-spec { font-size: 12px; color: var(--txm); line-height: 1.5; margin-bottom: 8px; }
.t-badge {
  display: inline-block; font-family: var(--fs-m); font-size: 10px;
  padding: 2px 8px; background: var(--aml); color: var(--am);
  border: 1px solid var(--amm); letter-spacing: .08em;
}

/* ─── FAQ ────────────────────────────────────────────────────── */
.faq { background: var(--dk2); }
.faq-list { max-width: 720px; }
.faq-item { border-bottom: 1px solid var(--br); }
.faq-q {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 0; cursor: pointer;
  font-size: 15px; font-weight: 600; color: var(--tx);
  gap: 12px;
}
.faq-q span { font-size: 20px; color: var(--txd); transition: transform .2s; flex-shrink: 0; }
.faq-a { display: none; padding-bottom: 18px; font-size: 14px; color: var(--txm); line-height: 1.65; }
.faq-item.open .faq-q span { transform: rotate(45deg); color: var(--am); }
.faq-item.open .faq-a { display: block; }

/* ─── CTA FORM ───────────────────────────────────────────────── */
.cta-section { background: var(--dk3); padding: 80px 0; }
.cta-inner {
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--px);
  display: grid; grid-template-columns: 1fr 460px; gap: 64px; align-items: start;
}
.cta-left p { font-size: 14px; color: var(--txm); line-height: 1.65; max-width: 420px; margin-bottom: 24px; }
.cta-contacts { display: flex; flex-direction: column; gap: 10px; }
.cta-contact-item {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; color: var(--txm);
}
.cta-contact-item a { color: var(--am); }

.cta-form { background: var(--dk2); border: 1px solid var(--bra); padding: 28px; position: relative; }
.cta-form-title {
  font-family: var(--fs-d); font-size: 18px; font-weight: 900;
  color: var(--tx); letter-spacing: -.02em; margin-bottom: 20px;
}

.form-row { margin-bottom: 14px; }
.form-row label { display: block; font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--txd); margin-bottom: 6px; }
.form-row input,
.form-row select {
  width: 100%; background: var(--dk); border: 1px solid var(--br);
  color: var(--tx); font-family: var(--fs-b); font-size: 14px;
  padding: 10px 14px; outline: none;
  transition: border-color .15s;
}
.form-row input:focus, .form-row select:focus { border-color: var(--am); }
.form-row select { appearance: none; cursor: pointer; }
.form-row select option { background: var(--dk2); }

#main-form-error, #svc-form-error {
  display: none; background: rgba(226,75,74,.12);
  border-left: 3px solid var(--re);
  padding: 10px 14px; font-size: 13px; color: #f5a0a0; margin-bottom: 12px;
}
#main-form-success, #svc-form-success {
  display: none; text-align: center; padding: 40px 20px;
}

.form-submit {
  width: 100%; background: var(--am); color: var(--dk);
  font-family: var(--fs-b); font-size: 14px; font-weight: 700;
  padding: 13px; border: none; cursor: pointer;
  transition: opacity .15s; letter-spacing: .02em;
}
.form-submit:hover { opacity: .88; }
.form-submit:disabled { opacity: .5; cursor: not-allowed; }
.form-note {
  font-size: 11px; color: var(--txd); line-height: 1.5;
  margin-top: 12px; text-align: center;
}
.form-note a { color: var(--txd); border-bottom: 1px solid var(--txf); }

/* ─── FOOTER ─────────────────────────────────────────────────── */
.site-footer { background: var(--dk3); border-top: 1px solid var(--br); padding: 48px 0 0; }
.footer-inner {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 40px; max-width: var(--mw); margin: 0 auto; padding: 0 var(--px) 40px;
}
.f-logo { font-family: var(--fs-d); font-size: 22px; font-weight: 900; color: var(--tx); letter-spacing: -.03em; margin-bottom: 6px; }
.f-logo span { color: var(--am); }
.f-tagline { font-family: var(--fs-m); font-size: 9px; letter-spacing: .18em; text-transform: uppercase; color: var(--txd); margin-bottom: 12px; }
.f-desc { font-size: 12px; color: var(--txm); line-height: 1.6; margin-bottom: 12px; max-width: 280px; }
.f-network { font-size: 11px; color: var(--txd); line-height: 1.5; }
.f-network a { color: var(--txd); border-bottom: 1px solid var(--txf); }
.f-col-title {
  font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--txd); margin-bottom: 14px;
}
.f-col ul { list-style: none; }
.f-col ul li { margin-bottom: 8px; }
.f-col ul li a { font-size: 13px; color: var(--txm); transition: color .15s; }
.f-col ul li a:hover { color: var(--am); }
.footer-bottom {
  border-top: 1px solid var(--br); padding: 16px var(--px);
  max-width: var(--mw); margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; color: var(--txd);
}
.footer-bottom a { color: var(--txd); transition: color .15s; }
.footer-bottom a:hover { color: var(--am); }

/* ─── ARTICLE ─────────────────────────────────────── */
.art-bc-wrap { background: var(--dk2); border-bottom: 1px solid var(--br); padding: 10px 0; }
.art-bc { display: flex; gap: 8px; align-items: center; font-size: 13px; color: var(--txd); }
.art-bc a { color: var(--txm); } .art-bc a:hover { color: var(--am); }
.bc-sep { color: var(--txd); }
.bc-current { color: var(--txm); }

.art-layout { display: grid; grid-template-columns: 1fr 300px; gap: 48px; padding-top: 40px; padding-bottom: 80px; }
.art-h1 { font-family: var(--fs-d); font-size: clamp(24px,3vw,36px); font-weight: 900; letter-spacing: -.03em; line-height: 1.08; color: var(--tx); margin-bottom: 16px; }
.art-meta { display: flex; justify-content: space-between; align-items: center; padding: 14px 0; border-top: 1px solid var(--br); border-bottom: 1px solid var(--br); margin-bottom: 24px; }
.art-author { display: flex; align-items: center; gap: 10px; }
.art-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--aml); border: 1px solid var(--amm); display: flex; align-items: center; justify-content: center; font-family: var(--fs-m); font-size: 13px; color: var(--am); }
.art-author-name { font-size: 13px; font-weight: 600; color: var(--tx); display: block; }
.art-author-role { font-size: 11px; color: var(--txd); display: block; }
.art-dates { font-family: var(--fs-m); font-size: 11px; color: var(--txd); }
.art-bluf { background: var(--dk2); border-left: 3px solid var(--am); padding: 16px 20px; margin-bottom: 28px; font-size: 15px; line-height: 1.65; color: var(--txm); }
.art-content h2 { font-family: var(--fs-d); font-size: 22px; font-weight: 700; color: var(--tx); margin: 32px 0 12px; letter-spacing: -.02em; }
.art-content p { font-size: 15px; line-height: 1.7; color: var(--txm); margin-bottom: 16px; }
.art-content ul, .art-content ol { padding-left: 20px; margin-bottom: 16px; }
.art-content li { font-size: 15px; line-height: 1.65; color: var(--txm); margin-bottom: 6px; }
.art-content a { color: var(--am); border-bottom: 1px solid var(--amm); }
.art-content strong { color: var(--tx); font-weight: 600; }
.art-content blockquote { border-left: 3px solid var(--am); padding: 12px 16px; background: var(--dk2); margin: 20px 0; color: var(--txm); }
.art-cta-inline { background: var(--dk2); border: 1px solid var(--bra); padding: 20px; display: flex; justify-content: space-between; align-items: center; gap: 16px; margin: 32px 0; }
.art-cta-text strong { display: block; font-size: 15px; font-weight: 600; color: var(--tx); margin-bottom: 4px; }
.art-cta-text span { font-size: 13px; color: var(--txm); }
.art-cta-btn { background: var(--am); color: var(--dk); font-size: 13px; font-weight: 700; padding: 10px 20px; white-space: nowrap; }
.art-faq-title, .art-related-title { font-family: var(--fs-d); font-size: 20px; font-weight: 700; color: var(--tx); margin-bottom: 16px; letter-spacing: -.02em; }
.art-related-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--br); }
.art-related-card { background: var(--dk2); padding: 16px; display: flex; flex-direction: column; gap: 8px; transition: background .15s; }
.art-related-card:hover { background: var(--dk4); }
.art-related-cat { font-family: var(--fs-m); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txd); }
.art-related-name { font-size: 13px; font-weight: 500; color: var(--tx); line-height: 1.4; }

/* ─── SIDEBAR ─────────────────────────────────────── */
.art-sidebar { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 80px; align-self: start; }
.sidebar-card { background: var(--dk2); border: 1px solid var(--br); padding: 18px; }
.sidebar-card-title { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--txd); margin-bottom: 12px; }
.sidebar-cta { border-color: var(--bra); }
.sidebar-cta-title { font-family: var(--fs-d); font-size: 18px; font-weight: 700; color: var(--tx); margin-bottom: 4px; }
.sidebar-cta-sub { font-size: 12px; color: var(--txm); margin-bottom: 14px; }
.sidebar-cta-btn { display: block; background: var(--am); color: var(--dk); font-size: 13px; font-weight: 700; padding: 10px; text-align: center; margin-bottom: 12px; }
.sidebar-cta-contacts { display: flex; gap: 12px; }
.sidebar-cta-contacts a { font-size: 12px; color: var(--am); }
.sidebar-tools { display: flex; flex-direction: column; gap: 8px; }
.sidebar-tool { font-size: 13px; color: var(--txm); padding: 8px 0; border-bottom: 1px solid var(--br); display: block; transition: color .15s; }
.sidebar-tool:hover { color: var(--am); }

/* ─── SERVICE PAGE ─────────────────────────────────── */
.svc-hero { background: var(--dk3); padding: 40px 0 48px; }
.svc-hero-inner { display: grid; grid-template-columns: 1fr 340px; gap: 48px; align-items: start; margin-top: 20px; }
.svc-h1 { font-family: var(--fs-d); font-size: clamp(26px,3vw,40px); font-weight: 900; letter-spacing: -.03em; line-height: 1.05; color: var(--tx); margin-bottom: 14px; }
.svc-bluf { font-size: 15px; color: var(--txm); line-height: 1.65; margin-bottom: 20px; }
.svc-price-row { display: flex; align-items: baseline; gap: 12px; margin-bottom: 20px; }
.svc-price-label { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--txd); }
.svc-price { font-family: var(--fs-m); font-size: 24px; font-weight: 500; color: var(--am); }
.svc-term { font-size: 12px; color: var(--txd); }
.svc-hero-btns { display: flex; gap: 12px; }
.svc-jurist-card { background: var(--dk2); border: 1px solid var(--bra); padding: 20px; }
.svc-jurist-title { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--txd); margin-bottom: 12px; }
.svc-section { padding: 56px 0; }
.svc-alt { background: var(--dk2); }
.svc-section-title { font-family: var(--fs-d); font-size: 24px; font-weight: 700; color: var(--tx); letter-spacing: -.02em; margin-bottom: 24px; }
.svc-deliverables { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.svc-deliverables li { display: flex; align-items: flex-start; gap: 12px; font-size: 14px; color: var(--txm); line-height: 1.55; padding: 12px 16px; background: var(--dk2); border: 1px solid var(--br); }
.svc-deliverables li::before { content: '→'; color: var(--am); flex-shrink: 0; font-weight: 700; }
.svc-for-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--br); }
.svc-for-card { background: var(--dk); padding: 20px; }
.svc-for-icon { font-family: var(--fs-d); font-size: 28px; font-weight: 900; color: var(--aml); margin-bottom: 8px; }
.svc-for-text { font-size: 13px; color: var(--txm); line-height: 1.6; }
.svc-steps { display: flex; flex-direction: column; gap: 0; }
.svc-step { display: flex; gap: 20px; padding: 20px 0; border-bottom: 1px solid var(--br); }
.svc-step:last-child { border-bottom: none; }
.svc-step-num { font-family: var(--fs-d); font-size: 28px; font-weight: 900; color: var(--aml); min-width: 48px; }
.svc-step-body strong { display: block; font-size: 15px; font-weight: 600; color: var(--tx); margin-bottom: 4px; }
.svc-step-body p { font-size: 13px; color: var(--txm); line-height: 1.6; }
.svc-cases { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--br); }
.svc-case { background: var(--dk2); padding: 20px; }
.svc-case::before { content: 'Кейс'; font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--am); display: block; margin-bottom: 10px; }
.svc-case-body { font-size: 13px; color: var(--txm); line-height: 1.65; font-style: italic; }
.svc-law-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
.svc-law-item { background: var(--dk2); border: 1px solid var(--br); padding: 14px; font-size: 13px; color: var(--txm); line-height: 1.55; }
.svc-law-tag { display: block; font-family: var(--fs-m); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--am); margin-bottom: 6px; }
.svc-price-block { display: grid; grid-template-columns: auto 1fr; gap: 32px; align-items: start; }
.svc-price-big { font-family: var(--fs-m); font-size: 32px; color: var(--am); font-weight: 500; margin: 8px 0; }
.svc-price-note { font-size: 13px; color: var(--txd); }
.svc-pi-title { font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--txd); margin-bottom: 8px; }
.svc-price-includes ul { list-style: none; }
.svc-price-includes li { font-size: 13px; color: var(--txm); padding: 4px 0; border-bottom: 1px solid var(--br); }
.svc-related-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--br); }
.svc-related-card { background: var(--dk); padding: 20px; transition: background .15s; }
.svc-related-card:hover { background: var(--dk2); }
.svc-related-name { font-size: 15px; font-weight: 600; color: var(--tx); margin-bottom: 8px; }
.svc-related-price { font-family: var(--fs-m); font-size: 14px; color: var(--am); }
.svc-guarantees { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--br); }
.svc-guarantee { background: var(--dk2); padding: 20px; text-align: center; }
.svc-g-icon { font-size: 28px; margin-bottom: 10px; }
.svc-guarantee strong { display: block; font-size: 14px; font-weight: 600; color: var(--tx); margin-bottom: 4px; }
.svc-guarantee span { font-size: 12px; color: var(--txd); }
.svc-form-section { background: var(--dk3); padding: 80px 0; }
.svc-form-inner { display: grid; grid-template-columns: 1fr 440px; gap: 64px; align-items: start; }
.svc-form-title { font-family: var(--fs-d); font-size: clamp(24px,2.5vw,34px); font-weight: 900; letter-spacing: -.03em; color: var(--tx); margin-bottom: 14px; }
.svc-form-sub { font-size: 14px; color: var(--txm); line-height: 1.65; margin-bottom: 20px; }
.svc-form-contacts { display: flex; flex-direction: column; gap: 8px; }
.svc-form-contacts a { font-size: 14px; color: var(--am); }


/* ─── КВИЗ ──────────────────────────────────────────────────────── */
.quiz-progress{display:flex;gap:0;margin-bottom:24px}
.quiz-step-dot{flex:1;height:3px;background:var(--br);transition:background .3s}
.quiz-step-dot.done{background:var(--am)}
.quiz-step-dot.active{background:var(--amm)}
.quiz-step{display:none}
.quiz-step.active{display:block}
.quiz-label{font-family:var(--fs-m);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--txd);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.quiz-label span{color:rgba(240,160,32,.4)}
.quiz-q{font-family:var(--fs-d);font-size:18px;font-weight:700;color:var(--tx);letter-spacing:-.02em;margin-bottom:16px;line-height:1.2}
.quiz-options{display:flex;flex-direction:column;gap:8px}
.quiz-opt{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--dk);border:1px solid var(--br);cursor:pointer;font-size:14px;color:var(--txm);transition:all .15s;text-align:left;width:100%;font-family:var(--fs-b)}
.quiz-opt:hover{border-color:var(--amm);color:var(--tx);background:rgba(240,160,32,.04)}
.quiz-opt.selected{border-color:var(--am);color:var(--tx);background:var(--aml)}
.quiz-opt .opt-icon{font-size:18px;flex-shrink:0}
.quiz-opt .opt-tag{margin-left:auto;font-family:var(--fs-m);font-size:10px;color:var(--txd);white-space:nowrap}
.quiz-opt.selected .opt-tag{color:var(--am)}
.quiz-nav{display:flex;gap:8px;margin-top:16px}
.quiz-back{border:1px solid var(--br);color:var(--txd);background:transparent;font-size:13px;padding:10px 16px;cursor:pointer;transition:all .15s;font-family:var(--fs-b)}
.quiz-back:hover{border-color:var(--amm);color:var(--txm)}
.quiz-next{flex:1;background:var(--am);color:var(--dk);font-size:13px;font-weight:700;padding:10px;border:none;cursor:pointer;transition:opacity .15s;font-family:var(--fs-b)}
.quiz-next:disabled{opacity:.35;cursor:not-allowed}
.quiz-next:not(:disabled):hover{opacity:.88}
.quiz-summary{background:var(--dk);border:1px solid var(--br);padding:12px 14px;margin-bottom:16px;font-size:12px;color:var(--txm);line-height:1.7}
.quiz-summary span{color:var(--am);font-weight:600}

/* ─── UTILITIES ─────────────────────────────────────── */
.visually-hidden { position: absolute; left: -9999px; visibility: hidden; }

/* ═══════════════════════════════════════════════════════
   Стили специфичных компонент, ранее inline в страницах.
   Перенесены сюда B1 для соответствия CLAUDE.md правилу 6.
   ═══════════════════════════════════════════════════════ */

/* ─── КАЛЬКУЛЯТОРЫ (instrumenty/*) ──────────────────────────── */
.calc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; padding: 32px 0 64px; }
.calc-form { background: var(--dk2); border: 1px solid var(--bra); padding: 28px; }
.calc-result { background: var(--dk3); border: 1px solid var(--br); padding: 28px; position: sticky; top: 80px; align-self: start; }
.calc-result-title { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--txd); margin-bottom: 14px; }
.calc-row { display: flex; justify-content: space-between; align-items: baseline; padding: 12px 0; border-bottom: 1px solid var(--br); font-size: 14px; }
.calc-row .lbl { color: var(--txm); }
.calc-row .val { font-family: var(--fs-m); color: var(--tx); font-weight: 500; }
.calc-total { display: flex; justify-content: space-between; align-items: baseline; padding: 18px 0 0; margin-top: 8px; border-top: 2px solid var(--am); }
.calc-total .lbl { font-family: var(--fs-d); font-size: 14px; font-weight: 700; color: var(--tx); letter-spacing: -.01em; text-transform: uppercase; }
.calc-total .val { font-family: var(--fs-d); font-size: 28px; font-weight: 900; color: var(--am); letter-spacing: -.02em; }
.calc-warn { margin-top: 18px; padding: 12px 14px; background: var(--aml); border-left: 3px solid var(--am); font-size: 12px; color: var(--txm); line-height: 1.5; }
.radio-row { display: flex; gap: 0; background: var(--dk); border: 1px solid var(--br); margin-bottom: 16px; }
.radio-row label { flex: 1; padding: 10px 14px; text-align: center; font-size: 13px; color: var(--txm); cursor: pointer; border-right: 1px solid var(--br); transition: all .15s; }
.radio-row label:last-child { border-right: none; }
.radio-row input { display: none; }
.radio-row input:checked + label { background: var(--am); color: var(--dk); font-weight: 700; }
@media (max-width: 900px) {
  .calc-grid { grid-template-columns: 1fr; }
  .calc-result { position: static; }
}

/* ─── ПРОФИЛИ КОМАНДЫ (komanda/*) ──────────────────────────── */
.prof-hero { padding: 48px 0 32px; background: var(--dk3); }
.prof-hero-inner { display: grid; grid-template-columns: auto 1fr; gap: 32px; align-items: center; }
.prof-ava { width: 120px; height: 120px; border-radius: 50%; background: var(--aml); border: 1px solid var(--amm); display: flex; align-items: center; justify-content: center; font-family: var(--fs-d); font-size: 48px; font-weight: 900; color: var(--am); letter-spacing: -.05em; }
.prof-role { font-family: var(--fs-m); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--txd); margin-bottom: 8px; }
.prof-name { font-family: var(--fs-d); font-size: clamp(28px, 3vw, 40px); font-weight: 900; letter-spacing: -.03em; color: var(--tx); margin-bottom: 12px; line-height: 1.05; }
.prof-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 18px; }
.prof-tag { font-family: var(--fs-m); font-size: 11px; background: var(--aml); color: var(--am); border: 1px solid var(--amm); padding: 4px 10px; letter-spacing: .06em; }
.prof-bio { font-size: 15px; color: var(--txm); line-height: 1.65; max-width: 720px; }
.prof-section { padding: 48px 0; border-bottom: 1px solid var(--br); }
.prof-section-title { font-family: var(--fs-d); font-size: 22px; font-weight: 700; color: var(--tx); letter-spacing: -.02em; margin-bottom: 18px; }
.prof-cluster-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--br); }
.prof-cluster { background: var(--dk2); padding: 18px; }
.prof-cluster-axis { font-family: var(--fs-m); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--am); margin-bottom: 6px; }
.prof-cluster-name { font-size: 14px; font-weight: 600; color: var(--tx); margin-bottom: 6px; }
.prof-cluster-desc { font-size: 12px; color: var(--txm); line-height: 1.5; }
.prof-svc { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--br); }
.prof-svc-card { background: var(--dk2); padding: 20px; transition: background .15s; }
.prof-svc-card:hover { background: var(--dk4); }
.prof-svc-name { font-family: var(--fs-d); font-size: 16px; font-weight: 700; color: var(--tx); margin-bottom: 8px; letter-spacing: -.01em; }
.prof-svc-price { font-family: var(--fs-m); font-size: 14px; color: var(--am); }
.prof-materials { list-style: none; }
.prof-materials li { list-style: none; padding: 14px 0; border-bottom: 1px solid var(--br); font-size: 14px; }
.prof-materials li a { color: var(--tx); font-weight: 500; }
.prof-materials li a:hover { color: var(--am); }
.prof-materials li .meta { font-family: var(--fs-m); font-size: 11px; color: var(--txd); display: block; margin-top: 4px; letter-spacing: .08em; text-transform: uppercase; }
@media (max-width: 700px) {
  .prof-hero-inner { grid-template-columns: 1fr; text-align: center; }
  .prof-ava { margin: 0 auto; }
  .prof-cluster-list, .prof-svc { grid-template-columns: 1fr; }
}

/* ─── ХАБЫ РАЗДЕЛОВ (kts/, tn-ved/, etc.) ──────────────────── */
.hub-filters { display: flex; gap: 8px; flex-wrap: wrap; margin: 24px 0 32px; }
.hub-filter { padding: 8px 14px; background: var(--dk2); border: 1px solid var(--br); font-family: var(--fs-m); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--txm); cursor: pointer; transition: all .15s; }
.hub-filter:hover { border-color: var(--amm); color: var(--tx); }
.hub-filter.active { background: var(--aml); border-color: var(--am); color: var(--am); }
.hub-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--br); }
.hub-card { background: var(--dk2); padding: 24px; display: flex; flex-direction: column; gap: 8px; transition: background .15s; }
.hub-card:hover { background: var(--dk4); }
.hub-cat { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--am); }
.hub-title { font-family: var(--fs-d); font-size: 17px; font-weight: 700; color: var(--tx); line-height: 1.25; letter-spacing: -.01em; }
.hub-desc { font-size: 13px; color: var(--txm); line-height: 1.55; flex: 1; }
.hub-meta { font-family: var(--fs-m); font-size: 11px; color: var(--txd); display: flex; gap: 12px; }
.hub-search { width: 100%; background: var(--dk); border: 1px solid var(--br); color: var(--tx); font-family: var(--fs-b); font-size: 14px; padding: 12px 16px; outline: none; margin-bottom: 16px; }
.hub-search:focus { border-color: var(--am); }
@media (max-width: 700px) { .hub-cards { grid-template-columns: 1fr; } }

/* ─── ШАБЛОНЫ — ХАБ (/shablony/) ──────────────────── */
.sh-filters { display: flex; gap: 8px; flex-wrap: wrap; margin: 24px 0 24px; }
.sh-filter { padding: 8px 14px; background: var(--dk2); border: 1px solid var(--br); font-family: var(--fs-m); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--txm); cursor: pointer; transition: all .15s; }
.sh-filter:hover { border-color: var(--amm); color: var(--tx); }
.sh-filter.active { background: var(--aml); border-color: var(--am); color: var(--am); }
.sh-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--br); }
.sh-card { background: var(--dk2); padding: 20px; display: flex; gap: 14px; align-items: flex-start; transition: background .15s; }
.sh-card:hover { background: var(--dk4); }
.sh-icon { width: 44px; height: 44px; background: var(--aml); border: 1px solid var(--amm); display: flex; align-items: center; justify-content: center; font-family: var(--fs-d); font-size: 11px; font-weight: 900; color: var(--am); letter-spacing: .04em; flex-shrink: 0; }
.sh-cat { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--am); margin-bottom: 4px; }
.sh-name { font-size: 14px; font-weight: 600; color: var(--tx); line-height: 1.35; }
@media (max-width: 700px) { .sh-cards { grid-template-columns: 1fr; } }

/* ─── ШАБЛОН — СТРАНИЦА (/shablony/*) ──────────────────── */
.tpl-download { background: var(--dk2); border: 1px solid var(--bra); padding: 28px; display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: center; margin: 24px 0 32px; }
.tpl-icon { width: 64px; height: 64px; background: var(--aml); border: 1px solid var(--amm); display: flex; align-items: center; justify-content: center; font-family: var(--fs-d); font-size: 14px; font-weight: 900; color: var(--am); letter-spacing: .04em; }
.tpl-meta-name { font-family: var(--fs-d); font-size: 18px; font-weight: 700; color: var(--tx); margin-bottom: 4px; letter-spacing: -.01em; }
.tpl-meta-sub { font-size: 13px; color: var(--txm); }
.tpl-dl-btn { background: var(--am); color: var(--dk); border: none; font-size: 14px; font-weight: 700; padding: 12px 22px; cursor: pointer; white-space: nowrap; font-family: var(--fs-b); }
.tpl-form { background: var(--dk2); border: 1px solid var(--bra); padding: 22px; margin: 0 0 32px; display: none; }
.tpl-form.open { display: block; }
.tpl-structure { background: var(--dk3); border-left: 3px solid var(--am); padding: 18px 22px; margin: 24px 0; }
.tpl-structure h3 { font-family: var(--fs-d); font-size: 14px; font-weight: 700; color: var(--tx); margin-bottom: 12px; text-transform: uppercase; letter-spacing: .06em; }
.tpl-structure ol { padding-left: 24px; font-size: 14px; color: var(--txm); line-height: 1.7; }
.tpl-laws { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; margin: 24px 0; }
.tpl-law { background: var(--dk2); border: 1px solid var(--br); padding: 14px 16px; font-size: 13px; color: var(--txm); line-height: 1.5; }
.tpl-law strong { display: block; font-family: var(--fs-m); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--am); margin-bottom: 6px; }
@media (max-width: 700px) { .tpl-download { grid-template-columns: 1fr; text-align: center; } }

/* ─── КОНТАКТЫ (/kontakty/) ──────────────────── */
.contacts-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 32px; }
.ct-card { background: var(--dk2); border: 1px solid var(--br); padding: 24px; }
.ct-card.amber { border-color: var(--bra); }
.ct-label { font-family: var(--fs-m); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--txd); margin-bottom: 10px; }
.ct-value { font-family: var(--fs-d); font-size: 22px; font-weight: 900; color: var(--am); letter-spacing: -.01em; margin-bottom: 6px; }
.ct-value a { color: var(--am); border-bottom: 1px solid var(--amm); }
.ct-sub { font-size: 13px; color: var(--txm); line-height: 1.5; }
@media (max-width: 700px) { .contacts-grid { grid-template-columns: 1fr; } }

/* ─── ХАБ ИНСТРУМЕНТОВ (/instrumenty/) ──────────────────── */
.tools-hub-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--br); margin-top: 24px; }
.tools-hub-card { background: var(--dk2); padding: 24px; display: flex; flex-direction: column; gap: 10px; transition: background .15s; }
.tools-hub-card:hover { background: var(--dk4); }
.tools-hub-card.featured { border: 1px solid var(--bra); margin: -1px; grid-column: span 3; background: var(--dk3); }
.tools-hub-card.featured .tool-icon { width: 56px; height: 56px; font-size: 24px; }
.tools-hub-card.featured .tool-name { font-size: 22px; }
.tools-hub-card.featured .tool-desc { font-size: 14px; }
@media (max-width: 900px) {
  .tools-hub-grid { grid-template-columns: repeat(2, 1fr); }
  .tools-hub-card.featured { grid-column: span 2; }
}
@media (max-width: 600px) {
  .tools-hub-grid { grid-template-columns: 1fr; }
  .tools-hub-card.featured { grid-column: span 1; }
}

/* ─── PDn/COOKIE CONSENT BANNER (152-ФЗ) ──────────────────────
   Показывается при первом заходе на сайт.
   Скрывается JS-кодом после клика на «Принять» или «Отклонить».
   Хранит выбор в localStorage:
     forpost_pdn_consent = 'accepted' | 'declined'
   ──────────────────────────────────────────────────────────── */
.pdn-banner {
  display: none;  /* показывается JS-ом, если нет согласия */
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 200;  /* выше mobile-cta-bar (90) и header (100) */
  max-width: 720px;
  margin: 0 auto;
  background: var(--dk2);
  border: 1px solid var(--bra);
  box-shadow: 0 12px 40px rgba(0,0,0,.55), 0 0 0 4px rgba(240,160,32,.06);
  padding: 18px 22px;
  font-size: 13px;
  color: var(--txm);
  line-height: 1.55;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .25s ease, transform .25s ease;
}
.pdn-banner.show { display: block; opacity: 1; transform: translateY(0); }
.pdn-banner-title {
  font-family: var(--fs-d);
  font-size: 14px; font-weight: 700;
  color: var(--tx); letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 8px;
}
.pdn-banner-title::before {
  content: '🍪';
  font-size: 18px;
}
.pdn-banner p { margin-bottom: 12px; }
.pdn-banner a {
  color: var(--am);
  border-bottom: 1px solid var(--amm);
}
.pdn-banner a:hover { border-bottom-color: var(--am); }
.pdn-banner-actions {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-top: 12px;
}
.pdn-banner-actions button {
  font-family: var(--fs-b);
  font-size: 13px; font-weight: 700;
  padding: 10px 20px;
  cursor: pointer;
  border: none;
  transition: opacity .15s, border-color .15s, background .15s;
  letter-spacing: .02em;
  min-height: 40px;
}
.pdn-accept {
  background: var(--am); color: var(--dk);
  flex: 1; min-width: 140px;
}
.pdn-accept:hover { opacity: .88; }
.pdn-decline {
  background: transparent;
  border: 1px solid var(--br) !important;
  color: var(--txm);
  flex: 0 0 auto;
}
.pdn-decline:hover { border-color: var(--amm) !important; color: var(--tx); }
.pdn-settings-link {
  display: block;
  margin-top: 10px;
  font-size: 11px;
  color: var(--txd);
  text-align: center;
  border-bottom: none;
}
.pdn-settings-link:hover { color: var(--am); }

/* Мобильная адаптация */
@media (max-width: 600px) {
  .pdn-banner {
    left: 8px; right: 8px; bottom: 8px;
    padding: 14px 16px;
    font-size: 12px;
  }
  .pdn-banner-title { font-size: 13px; }
  .pdn-banner-actions { flex-direction: column; }
  .pdn-banner-actions button { width: 100%; min-width: 0; }
  /* Когда баннер виден на мобильном, поднимаем mobile-cta-bar */
  body.pdn-shown .mobile-cta-bar { bottom: 0; opacity: .4; pointer-events: none; }
}

/* ─── STICKY MOBILE CTA-BAR (B4) ──────────────────── */
.mobile-cta-bar {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
  background: var(--dk2);
  border-top: 1px solid var(--bra);
  padding: 8px 12px;
  box-shadow: 0 -8px 24px rgba(0,0,0,.35);
}
.mobile-cta-bar-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.mobile-cta-bar a {
  display: flex; flex-direction: column; align-items: center;
  padding: 8px 4px;
  font-size: 11px; font-weight: 600;
  color: var(--txm);
  background: var(--dk);
  border: 1px solid var(--br);
  transition: all .15s;
  text-align: center;
  line-height: 1.2;
  text-decoration: none;
}
.mobile-cta-bar a:hover, .mobile-cta-bar a:active {
  border-color: var(--am); color: var(--am);
}
.mobile-cta-bar a .ic {
  font-size: 18px;
  margin-bottom: 2px;
  color: var(--am);
}
.mobile-cta-bar a.primary {
  background: var(--am);
  color: var(--dk);
  border-color: var(--am);
}
.mobile-cta-bar a.primary .ic { color: var(--dk); }
@media (max-width: 760px) {
  .mobile-cta-bar { display: block; }
  body { padding-bottom: 72px; }  /* чтобы контент не залезал под бар */
}

/* ─── PAGINATION ХАБОВ (C1) ──────────────────── */
.hub-pagination {
  display: flex; justify-content: center; align-items: center; gap: 8px;
  margin: 32px 0 0;
}
.hub-pagination button, .hub-pagination span.current {
  background: var(--dk2);
  border: 1px solid var(--br);
  color: var(--txm);
  font-family: var(--fs-m); font-size: 13px;
  padding: 8px 14px;
  cursor: pointer;
  transition: all .15s;
}
.hub-pagination button:hover { border-color: var(--am); color: var(--tx); }
.hub-pagination span.current {
  background: var(--aml);
  border-color: var(--am);
  color: var(--am);
  font-weight: 700;
}
.hub-pagination button:disabled {
  opacity: .35;
  cursor: not-allowed;
}

/* ─── INTERNAL RELATED-LINKS (C2) ──────────────────── */
.also-see {
  background: var(--dk2);
  border: 1px solid var(--br);
  padding: 24px;
  margin: 32px 0;
}
.also-see-title {
  font-family: var(--fs-d); font-size: 14px; font-weight: 700;
  color: var(--tx); letter-spacing: .04em;
  text-transform: uppercase; margin-bottom: 16px;
}
.also-see-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.also-see-item {
  display: block;
  padding: 12px 14px;
  background: var(--dk);
  border: 1px solid var(--br);
  font-size: 13px;
  color: var(--tx);
  line-height: 1.45;
  transition: all .15s;
  text-decoration: none;
}
.also-see-item:hover { border-color: var(--am); color: var(--am); }
.also-see-item .cat {
  display: block;
  font-family: var(--fs-m); font-size: 10px;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--am);
  margin-bottom: 4px;
}

/* ═══════════════════════════════════════════════════════
   ОТЗЫВЧИВЫЙ ДИЗАЙН (RESPONSIVE)
   Breakpoints:
     ≤ 1024px — планшеты в портретной ориентации
     ≤  768px — большие телефоны, планшеты-фаблеты
     ≤  600px — обычные смартфоны
     ≤  380px — узкие смартфоны (iPhone SE 1st gen и т.п.)
   ═══════════════════════════════════════════════════════ */

/* ─── ≤ 1024px (планшеты, узкие лэптопы) ──────────────────── */
@media (max-width: 1024px) {
  :root { --px: 32px; }

  /* Hero: уменьшаем правую колонку */
  .hero-inner { grid-template-columns: 1fr 360px; gap: 40px; }

  /* Сетки 4-колоночные → 3 */
  .svc-grid, .tools-grid, .team-grid { grid-template-columns: repeat(3, 1fr); }

  /* WHY 3 → 2 */
  .why-grid { grid-template-columns: repeat(2, 1fr); }

  /* CTA */
  .cta-inner { grid-template-columns: 1fr 400px; gap: 40px; }

  /* Article layout */
  .art-layout { grid-template-columns: 1fr 280px; gap: 32px; }

  /* Service hero */
  .svc-hero-inner { grid-template-columns: 1fr 300px; gap: 32px; }
  .svc-form-inner { grid-template-columns: 1fr 400px; gap: 40px; }

  /* Footer 5 → 4 (объединяя последнюю с контактами) */
  .footer-inner { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 32px; }
  .footer-inner > .f-col:nth-child(5) {
    grid-column: 2 / 5;
    display: flex; flex-wrap: wrap; gap: 0 24px;
  }
  .footer-inner > .f-col:nth-child(5) ul {
    display: flex; flex-wrap: wrap; gap: 4px 16px;
  }

  /* Сравнительная таблица — overflow-x */
  .vs-table { display: block; overflow-x: auto; white-space: nowrap; }
}

/* ─── ≤ 768px (большие телефоны, планшеты-фаблеты в portrait) ──── */
@media (max-width: 768px) {
  :root { --px: 20px; }

  /* TopBar — компактнее или скрыть второстепенное */
  .topbar { padding: 6px 0; font-size: 11px; }
  .topbar-inner {
    flex-direction: column; gap: 4px; align-items: flex-start;
  }
  .top-contacts, .top-social {
    gap: 10px; flex-wrap: wrap;
  }
  .top-social { display: none; } /* WhatsApp / TG / Канал — уже в mobile CTA */

  /* Header */
  .header-inner { padding: 12px var(--px); }
  .logo { font-size: 22px; }
  .header-cta { padding: 8px 16px; font-size: 12px; }

  /* Nav — горизонтальный скролл вместо переноса */
  .site-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .nav-inner { padding: 0 var(--px); }
  .nav-inner a { padding: 10px 12px; font-size: 12px; flex-shrink: 0; }
  .nav-inner::-webkit-scrollbar { display: none; }
  .site-nav { scrollbar-width: none; }

  /* Hero — стек */
  .hero { padding: 48px 0 40px; }
  .hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .risk-widget { padding: 18px; }
  .hero-stats {
    margin-top: 28px; padding-top: 20px;
    flex-wrap: wrap; gap: 16px 0;
  }
  .hero-stat {
    flex: 0 0 50%; padding: 0;
    border-right: none;
  }
  .hero-stat:first-child, .hero-stat:last-child { padding: 0; }
  .hero-stat dt { font-size: 24px; }
  .hero-btns { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-btns .btn-primary, .hero-btns .btn-outline { width: 100%; text-align: center; }

  /* Hero ::before декоратив — убираем чтобы не отрисовывал */
  .hero::before { display: none; }

  /* Proof strip — на 2 колонки или скролл */
  .proof { padding: 14px 0; overflow-x: auto; }
  .proof-inner {
    flex-wrap: nowrap; min-width: max-content; gap: 24px;
  }
  .proof-item {
    flex: 0 0 auto; padding: 0 12px;
    border-right: 1px solid var(--br);
  }
  .proof-item:last-child { border-right: none; }

  /* Section padding */
  .section { padding: 48px 0; }
  .section-sub { font-size: 13px; margin-bottom: 24px; }

  /* Service grid → 2 колонки */
  .svc-grid, .tools-grid, .team-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-card.featured { margin: 0; }  /* убираем negative margin */
  .svc-card { padding: 18px 16px; }

  /* WHY → 1 колонка */
  .why-grid { grid-template-columns: 1fr; }
  .why-card { padding: 20px; }
  .why-num { font-size: 32px; }

  /* CTA — стек */
  .cta-section { padding: 56px 0; }
  .cta-inner { grid-template-columns: 1fr; gap: 32px; }
  .cta-form { padding: 20px; }
  .cta-form-title { font-size: 16px; }

  /* Article layout — стек, sidebar внизу */
  .art-layout {
    grid-template-columns: 1fr; gap: 32px;
    padding-top: 24px; padding-bottom: 56px;
  }
  .art-sidebar {
    position: static;
    order: 2;
  }
  .art-related-grid { grid-template-columns: 1fr; }

  /* Service page */
  .svc-hero { padding: 28px 0 36px; }
  .svc-hero-inner { grid-template-columns: 1fr; gap: 24px; margin-top: 12px; }
  .svc-section { padding: 40px 0; }
  .svc-for-grid { grid-template-columns: 1fr; }
  .svc-cases { grid-template-columns: 1fr; }
  .svc-law-grid { grid-template-columns: 1fr 1fr; }
  .svc-guarantees { grid-template-columns: 1fr 1fr; }
  .svc-related-grid { grid-template-columns: 1fr; }
  .svc-price-block { grid-template-columns: 1fr; gap: 24px; }
  .svc-form-section { padding: 48px 0; }
  .svc-form-inner { grid-template-columns: 1fr; gap: 32px; }
  .svc-hero-btns { flex-direction: column; align-items: stretch; }
  .svc-hero-btns .btn-primary, .svc-hero-btns .btn-outline {
    width: 100%; text-align: center;
  }

  /* Article CTA inline */
  .art-cta-inline {
    flex-direction: column; align-items: flex-start; gap: 12px;
  }
  .art-cta-btn { width: 100%; text-align: center; }

  /* Footer */
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding: 0 var(--px) 28px;
  }
  .footer-inner > div:first-child { grid-column: 1 / 3; }
  .footer-inner > .f-col:nth-child(5) {
    grid-column: 1 / 3; display: block;
  }
  .footer-inner > .f-col:nth-child(5) ul {
    display: block;
  }
  .footer-bottom {
    flex-direction: column; gap: 8px; padding: 14px var(--px);
    text-align: center;
  }

  /* Ticker — меньше padding */
  .ticker { padding: 6px var(--px); font-size: 10px; }

  /* FAQ — больше padding tap-targets */
  .faq-q { padding: 16px 0; min-height: 48px; font-size: 14px; }

  /* Forms — большие тап-таргеты */
  .form-row input, .form-row select {
    font-size: 16px; /* iOS не зумит при focus, если ≥ 16px */
    padding: 12px 14px;
    min-height: 44px;
  }
  .form-submit { padding: 16px; min-height: 48px; }
  .header-cta, .btn-primary, .btn-outline { min-height: 44px; }

  /* TPL download block */
  .tpl-download {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 20px;
  }

  /* Profile hero — стек */
  .prof-hero-inner { grid-template-columns: 1fr; text-align: center; gap: 20px; }
  .prof-ava { margin: 0 auto; width: 96px; height: 96px; font-size: 36px; }
  .prof-cluster-list, .prof-svc { grid-template-columns: 1fr; }

  /* Hub cards single column */
  .hub-cards, .sh-cards { grid-template-columns: 1fr; }
  .hub-card { padding: 18px; }

  /* Tools hub */
  .tools-hub-grid { grid-template-columns: 1fr; }
  .tools-hub-card.featured { grid-column: span 1; }

  /* Calculators (calc-grid уже 1fr на 900px) */

  /* Mobile CTA bar — даём контенту место */
  body { padding-bottom: 76px; }
}

/* ─── ≤ 600px (типичные смартфоны) ──────────────────── */
@media (max-width: 600px) {
  :root { --px: 16px; }

  /* Service / Team / Tools — single column */
  .svc-grid, .tools-grid, .team-grid { grid-template-columns: 1fr; }

  /* Footer — 1 колонка */
  .footer-inner { grid-template-columns: 1fr; }
  .footer-inner > div:first-child,
  .footer-inner > .f-col:nth-child(5) { grid-column: 1 / 2; }

  /* H1 hero — компактнее */
  .hero-h1 { font-size: clamp(28px, 7vw, 36px); }
  .section-title { font-size: clamp(22px, 5.5vw, 30px); }

  /* Service grid — отступы поменьше */
  .svc-card { padding: 16px; }

  /* Hero btns — стек */
  .hero-btns { flex-direction: column; align-items: stretch; }

  /* svc-law-grid и svc-guarantees → 1 col */
  .svc-law-grid { grid-template-columns: 1fr; }
  .svc-guarantees { grid-template-columns: 1fr 1fr; }

  /* Quiz options — узкий tag */
  .quiz-opt .opt-tag { display: none; }
  .quiz-opt { padding: 10px 12px; font-size: 13px; }
  .quiz-q { font-size: 16px; }

  /* Hero stats */
  .hero-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .hero-stat { border: none; padding: 0; }

  /* Breadcrumb — обернуть в скролл */
  .art-bc {
    overflow-x: auto; white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-right: 12px;
  }
  .art-bc::-webkit-scrollbar { display: none; }

  /* Mobile CTA bar — компактные кнопки */
  .mobile-cta-bar a { padding: 8px 2px; font-size: 10px; }
  .mobile-cta-bar a .ic { font-size: 16px; }
}

/* ─── ≤ 380px (узкие смартфоны: iPhone SE 1st gen, mini, старые Android) ─── */
@media (max-width: 380px) {
  :root { --px: 12px; }

  /* Hero stats — 1 col */
  .hero-stats { grid-template-columns: 1fr; gap: 8px; }
  .hero-stat { display: flex; align-items: baseline; gap: 12px; }
  .hero-stat dt { font-size: 20px; }
  .hero-stat dd { margin: 0; }

  /* Service guarantees */
  .svc-guarantees { grid-template-columns: 1fr; }

  /* Logo */
  .logo { font-size: 18px; }
  .logo-sub { font-size: 8px; }

  /* H1 — ещё меньше */
  .hero-h1 { font-size: clamp(24px, 8vw, 30px); }

  /* Topbar — скрыть городской телефон */
  .top-contacts a:nth-child(3),
  .top-contacts span:nth-child(2),
  .top-contacts span:nth-child(4) { display: none; }
}

/* ─── PRINT — для распечатки страниц ──────────────────── */
@media print {
  .topbar, .site-nav, .ticker, .mobile-cta-bar,
  .header-cta, .cta-section, .svc-form-section,
  .hub-pagination, .mobile-cta-bar { display: none !important; }
  body { background: white; color: black; padding: 0; }
  a { color: black; text-decoration: underline; }
  .art-layout { grid-template-columns: 1fr; }
  .art-sidebar { display: none; }
}

/* ─── REDUCED MOTION — для пользователей с особыми настройками ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

