/* ═══════════════════════════════════
   MARQA · Shared Stylesheet
   Concept C — SIGNAL
═══════════════════════════════════ */
:root {
  --black:#141414; --red:#C23B2A; --red-dk:#8C2219;
  --bone:#F0EDE8; --warm:#E5E0D8; --grey:#3A3A3A;
  --mid:#797672; --rule:rgba(20,20,20,.08); --inv:rgba(240,237,232,.08);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bone);color:var(--black);font-family:'IBM Plex Mono',monospace;font-size:12px;}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:200;
  background:rgba(20,20,20,.97);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--inv);
  height:52px;display:flex;align-items:center;
  justify-content:space-between;padding:0 56px;
}
.nav-logo{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:900;
  text-transform:uppercase;color:var(--bone);letter-spacing:-.01em;text-decoration:none;}
.nav-logo .q{color:var(--red);}
.nav-links{display:flex;gap:0;list-style:none;}
.nav-links li a{
  display:block;padding:0 14px;height:52px;line-height:52px;
  font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(240,237,232,.4);text-decoration:none;
  border-bottom:2px solid transparent;
  transition:color .15s,border-color .15s;
}
.nav-links li a:hover{color:rgba(240,237,232,.8);}
.nav-links li a.active{color:var(--bone);border-bottom-color:var(--red);}
.nav-cta{
  background:var(--red);color:var(--bone);padding:8px 18px;
  border:none;cursor:pointer;font-family:'IBM Plex Mono',monospace;
  font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;display:inline-block;line-height:1;
  transition:background .15s;
}
.nav-cta:hover{background:var(--red-dk);}

/* ── SECTIONS ── */
.sec{padding:64px 56px;border-bottom:1px solid var(--rule);}
.sec.dark{background:var(--black);color:var(--bone);}
.sec.warm{background:var(--warm);}
.sec-hd{display:flex;align-items:baseline;gap:16px;margin-bottom:48px;
  padding-bottom:14px;border-bottom:2px solid currentColor;}
.sec-n{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);flex-shrink:0;}
.sec-h{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--mid);}
.dark .sec-h{color:rgba(240,237,232,.3);}
.dark .sec-hd{border-color:rgba(240,237,232,.12);}

/* ── BUTTONS ── */
.btn-primary{background:var(--bone);color:var(--red);padding:14px 28px;border:none;cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;
  text-decoration:none;display:inline-block;transition:all .2s;}
.btn-primary:hover{background:var(--black);color:var(--bone);}
.btn-primary.dark-btn{background:var(--black);color:var(--bone);}
.btn-primary.dark-btn:hover{background:var(--red);}
.btn-primary.red-btn{background:var(--red);color:var(--bone);}
.btn-primary.red-btn:hover{background:var(--red-dk);}
.btn-ghost{background:transparent;border:1.5px solid rgba(240,237,232,.4);
  color:rgba(240,237,232,.7);padding:12px 28px;cursor:pointer;
  font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;white-space:nowrap;text-decoration:none;
  display:inline-block;transition:all .2s;}
.btn-ghost:hover{border-color:rgba(240,237,232,.8);color:var(--bone);}

/* ── HERO SHARED ── */
.hero-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--red);
  margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.hero-label::before{content:'';width:28px;height:1px;background:var(--red);flex-shrink:0;}

/* ── RATING PILLS ── */
.rpill{background:rgba(194,59,42,.15);border:1px solid rgba(194,59,42,.25);
  padding:3px 9px;font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(194,59,42,.75);}
.pills-row{display:flex;gap:6px;flex-wrap:wrap;}

/* ── CTA FULL ── */
.cta-full{background:var(--red);padding:72px 56px;
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:40px;}
.cta-title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(36px,5vw,56px);
  font-weight:900;text-transform:uppercase;line-height:.95;color:var(--bone);}
.cta-sub{font-family:'Source Serif 4',serif;font-size:14px;line-height:1.65;
  color:rgba(240,237,232,.7);margin-top:14px;max-width:480px;}
.cta-btns{display:flex;flex-direction:column;gap:10px;align-items:flex-end;flex-shrink:0;}

/* ── FOOTER ── */
.site-footer{background:var(--black);padding:28px 56px;
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--inv);}
.sf-logo{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:900;
  text-transform:uppercase;color:var(--bone);text-decoration:none;}
.sf-logo .q{color:var(--red);}
.sf-end{display:flex;align-items:center;gap:14px;}
.sf-bar{width:2px;height:28px;background:var(--red);}
.sf-txt{font-size:12px;letter-spacing:.05em;color:rgba(240,237,232,.75);line-height:1.7;}
.sf-meta{font-size:12px;letter-spacing:.05em;color:rgba(240,237,232,.85);
  text-align:right;line-height:1.8;}

/* ── INDEX: HERO ── */
.hero{background:var(--black);padding:80px 56px 72px;position:relative;
  overflow:hidden;border-bottom:3px solid var(--red);}
.hero-bg-grid{position:absolute;inset:0;
  background-image:linear-gradient(var(--inv) 1px,transparent 1px),
    linear-gradient(90deg,var(--inv) 1px,transparent 1px);
  background-size:60px 60px;pointer-events:none;}
.hero-inner{position:relative;display:grid;grid-template-columns:1fr auto;
  align-items:end;gap:40px;}
.hero-h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(56px,8vw,96px);
  font-weight:900;text-transform:uppercase;line-height:.9;letter-spacing:-.01em;color:var(--bone);}
.hero-h1 .acc{color:var(--red);}
.hero-sub{margin-top:24px;font-family:'Source Serif 4',serif;font-size:15px;
  line-height:1.7;color:rgba(240,237,232,.5);max-width:520px;}
.hero-sub strong{color:rgba(240,237,232,.8);}
.hero-right{text-align:right;display:flex;flex-direction:column;
  align-items:flex-end;gap:8px;padding-bottom:4px;}
.hero-end-lbl{font-size:8px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(240,237,232,.28);margin-bottom:5px;}
.hero-end-nm{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:rgba(240,237,232,.5);}
.hero-btns{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;}

/* ── INDEX: STATS ── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--black);}
.stat-card{background:rgba(240,237,232,.04);border:1px solid rgba(240,237,232,.06);
  padding:28px 24px;transition:background .2s;}
.stat-card:hover{background:rgba(240,237,232,.07);}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-size:48px;font-weight:900;
  color:var(--red);line-height:1;}
.stat-txt{font-family:'Source Serif 4',serif;font-size:12.5px;
  color:rgba(240,237,232,.45);line-height:1.5;margin-top:8px;}
.stat-txt strong{color:rgba(240,237,232,.75);}

/* ── INDEX: SERVICES ── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);}
.svc-card{background:var(--bone);padding:32px 28px;
  border-left:3px solid transparent;transition:border-color .2s,background .2s;}
.svc-card:hover{border-left-color:var(--red);background:#E8E3DB;}
.svc-ic{font-size:24px;margin-bottom:14px;}
.svc-name{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;color:var(--black);margin-bottom:8px;}
.svc-desc{font-family:'Source Serif 4',serif;font-size:12.5px;color:var(--grey);line-height:1.55;}

/* ── INDEX: CASES ── */
.cases-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);}
.case-card{background:var(--bone);padding:28px 24px;}
.case-tag{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:10px;}
.case-title{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:var(--black);margin-bottom:8px;line-height:1.2;}
.case-desc{font-family:'Source Serif 4',serif;font-size:12px;color:var(--grey);line-height:1.55;margin-bottom:12px;}
.case-result{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:900;color:var(--red);}

/* ── TEAM ── */
.team-hero{background:var(--black);padding:64px 56px;border-bottom:3px solid var(--red);}
.team-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;}
.team-h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(52px,7vw,80px);
  font-weight:900;text-transform:uppercase;line-height:.92;color:var(--bone);}
.team-h1 .acc{color:var(--red);}
.team-sub{font-family:'Source Serif 4',serif;font-size:14px;line-height:1.7;
  color:rgba(240,237,232,.5);}
.team-sub strong{color:rgba(240,237,232,.75);}
.partner-card{display:grid;grid-template-columns:280px 1fr;gap:0;background:var(--rule);}
.pc-left{background:var(--black);padding:48px 40px;
  display:flex;flex-direction:column;justify-content:space-between;}
.pc-avatar{width:200px;height:200px;background:var(--grey);margin-bottom:24px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;font-size:64px;font-weight:900;
  color:rgba(240,237,232,.15);border-left:4px solid var(--red);}
.pc-tag{font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:6px;}
.pc-name{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;
  text-transform:uppercase;color:var(--bone);letter-spacing:.02em;}
.pc-role{font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(240,237,232,.35);margin-top:4px;}
.pc-ratings{margin-top:20px;display:flex;flex-direction:column;gap:7px;}
.pc-rating{font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(194,59,42,.7);display:flex;align-items:center;gap:6px;}
.pc-rating::before{content:'·';color:var(--red);}
.pc-right{background:var(--bone);padding:48px 44px;display:flex;flex-direction:column;gap:24px;}
.pc-spec{border-top:2px solid var(--black);padding-top:20px;}
.pc-spec-lbl{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);margin-bottom:10px;}
.pc-spec-val{font-family:'Source Serif 4',serif;font-size:13.5px;color:var(--grey);line-height:1.65;}
.pc-spec-val strong{color:var(--black);}
.pc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.pc-tag-item{background:rgba(20,20,20,.06);padding:3px 9px;font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);}
.pc-quote{font-family:'Source Serif 4',serif;font-style:italic;font-size:14px;color:var(--grey);line-height:1.65;border-left:3px solid var(--red);padding-left:16px;}
.pc-contact{display:flex;gap:12px;flex-wrap:wrap;}
.pc-contact-item{font-size:9px;letter-spacing:.08em;color:var(--mid);}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--rule);}
.tm-card{background:var(--bone);padding:36px 32px;display:flex;gap:24px;
  align-items:flex-start;border-left:3px solid transparent;transition:border-color .2s;}
.tm-card:hover{border-left-color:var(--red);}
.tm-avatar{width:80px;height:80px;background:var(--warm);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;color:var(--mid);}
.tm-tag2{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:5px;}
.tm-name{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;
  text-transform:uppercase;letter-spacing:.03em;color:var(--black);margin-bottom:2px;}
.tm-role{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:10px;}
.tm-bio{font-family:'Source Serif 4',serif;font-size:12px;color:var(--grey);line-height:1.55;margin-bottom:10px;}
.tm-specs{display:flex;flex-wrap:wrap;gap:5px;}
.tm-spec{background:rgba(20,20,20,.05);padding:2px 8px;font-size:7.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);}
.analysts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--rule);}
.an-card{background:var(--bone);padding:28px 24px;}
.an-ic{font-size:28px;margin-bottom:12px;}
.an-tag-sm{font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:6px;}
.an-name{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;
  text-transform:uppercase;letter-spacing:.03em;color:var(--black);margin-bottom:8px;}
.an-role2{font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);margin-bottom:10px;}
.an-bio{font-family:'Source Serif 4',serif;font-size:11.5px;color:var(--grey);line-height:1.55;}

/* ── ANALYTICS ── */
.analytics-hero{background:var(--black);padding:64px 56px;border-bottom:3px solid var(--red);}
.an-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;}
.an-h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(52px,7vw,80px);
  font-weight:900;text-transform:uppercase;line-height:.92;color:var(--bone);}
.an-h1 .acc{color:var(--red);}
.an-sub{font-family:'Source Serif 4',serif;font-size:14px;line-height:1.75;
  color:rgba(240,237,232,.5);margin-top:16px;}
.categories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);}
.cat-card{background:var(--bone);padding:32px 28px;border-top:3px solid var(--rule);
  cursor:default;transition:background .2s;}
.cat-card:nth-child(1){border-top-color:var(--red);}
.cat-card:nth-child(2){border-top-color:var(--black);}
.cat-card:nth-child(3){border-top-color:var(--mid);}
.cat-card:nth-child(4){border-top-color:var(--red);}
.cat-card:nth-child(5){border-top-color:var(--black);}
.cat-card:nth-child(6){border-top-color:var(--mid);}
.cat-card:hover{background:#E8E3DB;}
.cat-ic{font-size:24px;margin-bottom:12px;}
.cat-title{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:var(--black);margin-bottom:5px;}
.cat-url{font-family:'IBM Plex Mono',monospace;font-size:8.5px;color:var(--red);
  letter-spacing:.06em;margin-bottom:10px;}
.cat-desc{font-family:'Source Serif 4',serif;font-size:12px;color:var(--grey);
  line-height:1.55;margin-bottom:12px;}
.cat-count{font-family:'Barlow Condensed',sans-serif;font-size:32px;font-weight:900;color:var(--mid);}
.cat-count-lbl{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);}
.articles-grid{display:grid;grid-template-columns:2fr 1fr;gap:2px;background:var(--rule);}
.article-main{background:var(--bone);padding:40px 36px;}
.article-side{display:flex;flex-direction:column;gap:2px;background:var(--rule);}
.article-sm{background:var(--bone);padding:24px 24px;flex:1;}
.art-cat{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:8px;}
.art-title-big{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;
  text-transform:uppercase;letter-spacing:.02em;color:var(--black);margin-bottom:12px;line-height:1.1;}
.art-title-sm{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;
  text-transform:uppercase;letter-spacing:.02em;color:var(--black);margin-bottom:8px;line-height:1.15;}
.art-excerpt{font-family:'Source Serif 4',serif;font-size:13px;color:var(--grey);
  line-height:1.65;margin-bottom:16px;}
.art-meta{font-size:8.5px;letter-spacing:.08em;color:var(--mid);}
.art-link{display:inline-flex;align-items:center;gap:6px;font-size:9px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-top:16px;cursor:pointer;}
.sub-strip{background:var(--black);padding:32px 56px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;}
.sub-txt{font-family:'Source Serif 4',serif;font-size:14px;color:rgba(240,237,232,.6);}
.sub-txt strong{color:var(--bone);}
.sub-form{display:flex;gap:0;}
.sub-input{background:rgba(240,237,232,.08);border:1px solid rgba(240,237,232,.15);
  padding:10px 16px;color:var(--bone);font-family:'IBM Plex Mono',monospace;
  font-size:11px;width:260px;outline:none;}
.sub-input::placeholder{color:rgba(240,237,232,.3);}
.sub-btn{background:var(--red);color:var(--bone);border:none;padding:10px 20px;
  font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;cursor:pointer;}

/* ── ABOUT ── */
.about-hero{background:var(--black);padding:80px 56px;border-bottom:3px solid var(--red);}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.ab-h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(52px,7vw,80px);
  font-weight:900;text-transform:uppercase;line-height:.92;color:var(--bone);}
.ab-h1 .acc{color:var(--red);}
.ab-text{font-family:'Source Serif 4',serif;font-size:15px;line-height:1.75;
  color:rgba(240,237,232,.55);}
.ab-text strong{color:rgba(240,237,232,.85);}
.timeline{display:flex;flex-direction:column;gap:0;border-left:2px solid var(--rule);}
.tl-item{padding:28px 0 28px 32px;border-bottom:1px solid var(--rule);position:relative;}
.tl-item::before{content:'';position:absolute;left:-6px;top:34px;
  width:10px;height:10px;border-radius:50%;background:var(--bone);border:2px solid var(--red);}
.tl-year{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;
  color:var(--red);line-height:1;margin-bottom:6px;}
.tl-event{font-family:'Source Serif 4',serif;font-size:13.5px;color:var(--grey);line-height:1.6;}
.awards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);}
.award-card{background:var(--bone);padding:28px 24px;}
.aw-year{font-family:'Barlow Condensed',sans-serif;font-size:40px;font-weight:900;
  color:rgba(20,20,20,.07);line-height:1;margin-bottom:8px;}
.aw-name{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:var(--black);margin-bottom:6px;}
.aw-desc{font-family:'Source Serif 4',serif;font-size:12px;color:var(--grey);line-height:1.55;}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--rule);}
.val-card{background:var(--bone);padding:36px 28px;}
.val-n{font-family:'Barlow Condensed',sans-serif;font-size:64px;font-weight:900;
  color:rgba(20,20,20,.05);line-height:1;margin-bottom:12px;}
.val-title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:var(--black);margin-bottom:10px;}
.val-desc{font-family:'Source Serif 4',serif;font-size:13px;color:var(--grey);line-height:1.65;}
.net-strip{background:var(--black);padding:40px 56px;
  display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;}
.net-bar{width:3px;height:60px;background:var(--red);flex-shrink:0;}
.net-title{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--bone);margin-bottom:8px;}
.net-desc{font-family:'Source Serif 4',serif;font-size:13.5px;
  color:rgba(240,237,232,.5);line-height:1.65;max-width:700px;}
.net-desc strong{color:rgba(240,237,232,.8);}
.net-pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}

/* ── CONTACTS ── */
.contacts-hero{background:var(--black);padding:72px 56px;border-bottom:3px solid var(--red);}
.contacts-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.ct-h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(48px,7vw,72px);
  font-weight:900;text-transform:uppercase;line-height:.92;color:var(--bone);}
.ct-h1 .acc{color:var(--red);}
.ct-promise{font-family:'Source Serif 4',serif;font-size:14px;line-height:1.7;
  color:rgba(240,237,232,.5);margin-top:16px;}
.ct-promise strong{color:var(--red);}
.ct-channels{display:flex;flex-direction:column;gap:14px;}
.ct-ch{display:flex;align-items:center;gap:14px;}
.ct-ch-icon{width:40px;height:40px;background:rgba(240,237,232,.08);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;}
.ct-ch-lbl{font-size:8px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(240,237,232,.3);margin-bottom:3px;}
.ct-ch-val{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;
  color:var(--bone);letter-spacing:.02em;}
.form-section{background:var(--warm);padding:64px 56px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.form-block-lbl{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);
  margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--rule);}
.form-wrap{display:flex;flex-direction:column;gap:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-field{display:flex;flex-direction:column;gap:5px;}
.form-field label{font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);}
.form-field input,.form-field select,.form-field textarea{
  background:var(--bone);border:1px solid rgba(20,20,20,.15);
  padding:11px 14px;color:var(--black);font-family:'Source Serif 4',serif;
  font-size:13px;outline:none;transition:border-color .15s;width:100%;}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--red);}
.form-field textarea{resize:vertical;min-height:100px;}
.form-submit{background:var(--black);color:var(--bone);padding:14px 28px;border:none;
  cursor:pointer;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;width:100%;margin-top:8px;
  transition:background .15s;}
.form-submit:hover{background:var(--red);}
.form-info{display:flex;flex-direction:column;gap:28px;}
.fi-block{border-top:2px solid var(--rule);padding-top:20px;}
.fi-lbl{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);margin-bottom:8px;}
.fi-val{font-family:'Source Serif 4',serif;font-size:13.5px;color:var(--grey);line-height:1.65;}
.fi-val strong{color:var(--black);}
.map-ph{background:var(--black);height:240px;display:flex;align-items:center;
  justify-content:center;flex-direction:column;gap:12px;}
.map-ph-text{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;color:rgba(240,237,232,.3);}
.map-address{font-family:'IBM Plex Mono',monospace;font-size:9px;
  letter-spacing:.08em;color:rgba(240,237,232,.2);}

/* ── CHECK ── */
.check-hero{background:var(--black);padding:80px 56px;border-bottom:3px solid var(--red);}
.check-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.ch-h1{font-family:'Barlow Condensed',sans-serif;font-size:clamp(52px,7vw,80px);
  font-weight:900;text-transform:uppercase;line-height:.92;color:var(--bone);}
.ch-h1 .acc{color:var(--red);}
.ch-sub{font-family:'Source Serif 4',serif;font-size:15px;line-height:1.75;
  color:rgba(240,237,232,.5);margin-top:20px;}
.ch-sub strong{color:rgba(240,237,232,.8);}
.ch-form-hero{background:rgba(240,237,232,.05);border:1px solid rgba(240,237,232,.1);padding:32px;}
.ch-form-lbl{font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(240,237,232,.4);margin-bottom:16px;}
.ch-input{width:100%;background:rgba(240,237,232,.08);border:1px solid rgba(240,237,232,.2);
  padding:16px 18px;color:var(--bone);font-family:'Source Serif 4',serif;
  font-size:15px;outline:none;transition:border-color .15s;}
.ch-input:focus{border-color:var(--red);}
.ch-input::placeholder{color:rgba(240,237,232,.3);}
.ch-btn{width:100%;background:var(--red);color:var(--bone);border:none;padding:14px;
  font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:800;
  text-transform:uppercase;letter-spacing:.1em;cursor:pointer;margin-top:10px;
  transition:background .15s;}
.ch-btn:hover{background:var(--red-dk);}
.ch-disclaimer{font-size:8.5px;letter-spacing:.06em;
  color:rgba(240,237,232,.25);margin-top:12px;line-height:1.6;}
.check-result{padding:48px 56px;display:none;}
.check-result.visible{display:block;}
.result-box{background:var(--black);padding:40px 44px;}
.rb-label{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:16px;}
.rb-query{font-family:'Barlow Condensed',sans-serif;font-size:36px;font-weight:900;
  text-transform:uppercase;color:var(--bone);margin-bottom:20px;}
.rb-status{display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.rb-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:#FFC107;}
.rb-status-text{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;
  text-transform:uppercase;color:var(--bone);}
.rb-desc{font-family:'Source Serif 4',serif;font-size:13.5px;
  color:rgba(240,237,232,.55);line-height:1.7;margin-bottom:28px;}
.rb-cta{background:var(--red);color:var(--bone);border:none;padding:12px 24px;
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;cursor:pointer;text-decoration:none;
  display:inline-block;}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--rule);}
.how-card{background:var(--bone);padding:28px 24px;}
.how-n{font-family:'Barlow Condensed',sans-serif;font-size:48px;font-weight:900;
  color:rgba(20,20,20,.07);line-height:1;margin-bottom:10px;}
.how-title{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:var(--black);margin-bottom:8px;}
.how-desc{font-family:'Source Serif 4',serif;font-size:12px;color:var(--grey);line-height:1.55;}
.faq-list{display:flex;flex-direction:column;gap:0;}
.faq-item{border-bottom:1px solid var(--rule);}
.faq-q{display:flex;justify-content:space-between;align-items:center;
  padding:18px 0;cursor:pointer;}
.faq-q-text{font-family:'Source Serif 4',serif;font-size:14px;color:var(--black);line-height:1.4;}
.faq-toggle{font-family:'IBM Plex Mono',monospace;font-size:16px;color:var(--red);
  flex-shrink:0;margin-left:16px;user-select:none;}
.faq-a{display:none;padding-bottom:18px;}
.faq-a.open{display:block;}
.faq-a-text{font-family:'Source Serif 4',serif;font-size:13px;color:var(--grey);line-height:1.7;}

/* ══════════════════════════════════
   ARTICLE PAGES · /analytics/
══════════════════════════════════ */

/* ── HERO СТАТЬИ ── */
.article-hero {
  background: var(--black);
  padding: 56px 56px 48px;
  border-bottom: 3px solid var(--red);
}
.article-breadcrumb {
  font-size: 8px; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(240,237,232,.3); margin-bottom: 20px;
  display: flex; align-items: center; gap: 8px;
}
.article-breadcrumb a { color: rgba(240,237,232,.3); text-decoration: none; }
.article-breadcrumb a:hover { color: rgba(240,237,232,.6); }
.article-breadcrumb span { color: rgba(240,237,232,.15); }
.article-cluster {
  font-size: 9px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--red); margin-bottom: 16px;
  display: flex; align-items: center; gap: 10px;
}
.article-cluster::before { content:''; width:28px; height:1px; background:var(--red); flex-shrink:0; }
.article-h1 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 900; text-transform: uppercase;
  line-height: .94; letter-spacing: -.01em;
  color: var(--bone); max-width: 760px;
}
.article-lead {
  font-family: 'Source Serif 4', serif;
  font-size: 15px; line-height: 1.75;
  color: rgba(240,237,232,.55);
  max-width: 640px; margin-top: 20px;
}
.article-lead strong { color: rgba(240,237,232,.85); }

/* ── РАННИЙ CTA ── */
.article-early-cta {
  background: rgba(194,59,42,.12);
  border-left: 3px solid var(--red);
  padding: 14px 20px; margin: 24px 0 0;
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
}
.article-early-cta p {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10px; letter-spacing: .08em;
  color: rgba(240,237,232,.65); flex: 1;
}
.article-early-cta .btn-red {
  background: var(--red); color: var(--bone);
  padding: 9px 18px; font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; text-decoration: none; white-space: nowrap;
  transition: background .15s;
}
.article-early-cta .btn-red:hover { background: var(--red-dk); }
.article-early-cta .btn-tg {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px;
  letter-spacing: .08em; color: rgba(240,237,232,.5);
  text-decoration: none; white-space: nowrap;
}

/* ── БЛОК АВТОРА ── */
.article-author {
  background: var(--warm); padding: 56px;
  border-bottom: 1px solid var(--rule);
  display: flex; align-items: center; gap: 24px;
}
.article-author-photo {
  width: 64px; height: 64px; flex-shrink: 0;
  background: var(--mid); object-fit: cover;
}
.article-author-meta { display: flex; flex-direction: column; gap: 3px; }
.article-author-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black); text-decoration: none;
}
.article-author-name:hover { color: var(--red); }
.article-author-role {
  font-size: 8px; letter-spacing: .12em; text-transform: uppercase; color: var(--mid);
}
.article-author-dates {
  font-size: 8.5px; letter-spacing: .06em; color: var(--mid); margin-top: 2px;
}

/* ── LAYOUT: СЕТКА СТАТЬЯ + SIDEBAR ── */
.article-layout {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 0;
  align-items: start;
  background: var(--rule);
}
.article-main { background: var(--bone); padding: 56px; }
.article-sidebar {
  background: var(--warm);
  padding: 32px 28px;
  position: sticky; top: 52px;
  border-left: 1px solid var(--rule);
}

/* ── ОГЛАВЛЕНИЕ ── */
.article-toc-title {
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--mid); margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 2px solid var(--rule);
}
.article-toc ol { padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: 2px; }
.article-toc li a {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .04em;
  color: var(--mid); text-decoration: none; padding: 4px 0;
  display: block; border-left: 2px solid transparent;
  padding-left: 10px; transition: all .15s;
}
.article-toc li a:hover { color: var(--red); border-left-color: var(--red); }

/* ── ТЕЛО СТАТЬИ ── */
.article-content h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black);
  margin: 40px 0 14px; padding-top: 40px;
  border-top: 1px solid var(--rule);
}
.article-content h2:first-child { border-top: none; padding-top: 0; margin-top: 0; }
.article-content h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--red); margin: 24px 0 8px;
}
.article-content p {
  font-family: 'Source Serif 4', serif;
  font-size: 14px; color: var(--grey); line-height: 1.75; margin-bottom: 14px;
}
.article-content strong { color: var(--black); }
.article-content a { color: var(--red); text-decoration: underline; text-decoration-color: rgba(194,59,42,.3); }
.article-content a:hover { text-decoration-color: var(--red); }
.article-content ul, .article-content ol {
  font-family: 'Source Serif 4', serif; font-size: 14px;
  color: var(--grey); line-height: 1.7;
  padding-left: 20px; margin-bottom: 14px;
}
.article-content li { margin-bottom: 5px; }
.article-content table {
  width: 100%; border-collapse: collapse; margin: 20px 0;
  font-family: 'IBM Plex Mono', monospace; font-size: 11px;
}
.article-content th {
  background: var(--black); color: var(--bone);
  padding: 10px 14px; text-align: left;
  letter-spacing: .08em; text-transform: uppercase; font-size: 8.5px;
}
.article-content td { border: 1px solid var(--rule); padding: 9px 14px; vertical-align: top; }
.article-content tr:nth-child(even) td { background: var(--warm); }

/* ── КЕЙС ── */
.article-case {
  background: var(--black); padding: 28px 32px; margin: 32px 0;
  border-left: 4px solid var(--red);
}
.article-case-label {
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--red); margin-bottom: 10px;
}
.article-case p {
  font-family: 'Source Serif 4', serif; font-size: 13px;
  color: rgba(240,237,232,.65); line-height: 1.7; margin: 0;
}
.article-case strong { color: rgba(240,237,232,.9) !important; }

/* ── ЛИДМАГНЕТ ── */
.article-lead-magnet {
  background: var(--warm); border: 1px solid rgba(20,20,20,.1);
  border-top: 3px solid var(--black);
  padding: 28px 32px; margin: 32px 0;
}
.article-lead-magnet-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black); margin-bottom: 8px;
}
.article-lead-magnet p {
  font-family: 'Source Serif 4', serif; font-size: 13px;
  color: var(--grey); line-height: 1.65; margin-bottom: 12px;
}
.article-lead-magnet .lm-cta {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px;
  letter-spacing: .06em; color: var(--mid);
}
.article-lead-magnet .lm-cta strong { color: var(--red); }

/* ── ФИНАЛЬНЫЙ CTA ── */
.article-cta-block {
  background: var(--black); padding: 48px 56px;
  border-top: 3px solid var(--red);
}
.article-cta-block .cta-label {
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(194,59,42,.6); margin-bottom: 12px;
}
.article-cta-block .cta-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(28px, 4vw, 44px); font-weight: 900;
  text-transform: uppercase; line-height: .95; color: var(--bone);
  margin-bottom: 14px;
}
.article-cta-block .cta-offer {
  font-family: 'Source Serif 4', serif; font-size: 14px;
  color: rgba(240,237,232,.5); line-height: 1.65;
  max-width: 560px; margin-bottom: 28px;
}
.article-cta-block .cta-offer strong { color: rgba(240,237,232,.8); }
.article-cta-btns { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.article-cta-btns .btn-cta-main {
  background: var(--red); color: var(--bone);
  padding: 14px 28px; font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .08em; text-decoration: none; display: inline-block;
  transition: background .15s;
}
.article-cta-btns .btn-cta-main:hover { background: var(--red-dk); }
.article-cta-btns .btn-cta-tg {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px;
  letter-spacing: .08em; color: rgba(240,237,232,.5);
  text-decoration: none;
}
.article-cta-btns .btn-cta-tg:hover { color: var(--bone); }
.article-cta-phone {
  font-family: 'IBM Plex Mono', monospace; font-size: 9px;
  letter-spacing: .1em; color: rgba(240,237,232,.3);
  margin-top: 16px;
}
.article-cta-phone a { color: rgba(240,237,232,.4); text-decoration: none; }
.article-trust {
  font-size: 8px; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(194,59,42,.5); margin-top: 10px;
}

/* ── FAQ (article) ── */
.article-faq { padding: 56px; background: var(--warm); }
.article-faq-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--mid);
  margin-bottom: 28px; padding-bottom: 14px;
  border-bottom: 2px solid var(--rule);
  display: flex; align-items: baseline; gap: 16px;
}
.article-faq-title::before { content: '05 ·'; font-size: 9px; color: var(--red); }

/* ── СВЯЗАННЫЕ МАТЕРИАЛЫ ── */
.article-related { padding: 48px 56px; background: var(--bone); border-top: 1px solid var(--rule); }
.article-related-title {
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--mid); margin-bottom: 24px;
}
.article-related-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; background: var(--rule); }
.article-related-card {
  background: var(--bone); padding: 24px;
  border-left: 3px solid transparent; transition: border-color .2s;
}
.article-related-card:hover { border-left-color: var(--red); }
.article-related-card a {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .02em; color: var(--black); text-decoration: none;
  display: block; margin-bottom: 6px; line-height: 1.2;
}
.article-related-card a:hover { color: var(--red); }
.article-related-card p {
  font-family: 'Source Serif 4', serif; font-size: 11.5px;
  color: var(--mid); line-height: 1.5;
}

/* ── MOBILE STICKY ── */
.article-mobile-sticky {
  display: none; position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--black); border-top: 2px solid var(--red);
  padding: 10px 16px; gap: 8px; z-index: 100; align-items: center;
}
@media (max-width: 768px) { .article-mobile-sticky { display: flex; } }
.article-mobile-sticky .ms-main {
  flex: 1; background: var(--red); color: var(--bone);
  padding: 10px; text-align: center; font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; text-decoration: none;
}
.article-mobile-sticky .ms-icon {
  width: 40px; height: 40px; background: rgba(240,237,232,.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; text-decoration: none; flex-shrink: 0;
}

/* ── АДАПТИВ ── */
@media (max-width: 900px) {
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { display: none; }
  .article-main { padding: 32px 24px; }
  .article-hero { padding: 40px 24px 32px; }
  .article-author { padding: 32px 24px; }
  .article-faq { padding: 32px 24px; }
  .article-cta-block { padding: 40px 24px; }
  .article-related { padding: 32px 24px; }
  .article-related-grid { grid-template-columns: 1fr; }
}


/* ══════════════════════════════════
   ARTICLE v2 · /analytics/[slug]
   Новые компоненты — добавлено 2026-04-26
══════════════════════════════════ */

/* ── READING PROGRESS ── */
.rp {
  position: fixed; top: 52px; left: 0; right: 0;
  height: 2px; background: rgba(20,20,20,.08);
  z-index: 300; pointer-events: none;
}
.rp-bar {
  height: 100%; background: var(--red); width: 0%;
  transition: width .08s linear;
}

/* ── HERO УЛУЧШЕННЫЙ ── */
.art-hero {
  background: var(--black);
  padding: 48px 56px 44px;
  border-bottom: 3px solid var(--red);
  position: relative; overflow: hidden;
}
.art-hero-bg {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(240,237,232,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(240,237,232,.02) 1px, transparent 1px);
  background-size: 56px 56px; pointer-events: none;
}
.art-hero-inner { position: relative; }
.art-breadcrumb {
  font-size: 8px; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(240,237,232,.25); margin-bottom: 20px;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.art-breadcrumb a { color: rgba(240,237,232,.25); text-decoration: none; transition: color .15s; }
.art-breadcrumb a:hover { color: rgba(240,237,232,.55); }
.art-breadcrumb span { color: rgba(240,237,232,.12); }
.art-meta-row {
  display: flex; align-items: center; gap: 10px; margin-bottom: 20px; flex-wrap: wrap;
}
.art-cat-pill {
  background: rgba(194,59,42,.2); border: 1px solid rgba(194,59,42,.3);
  padding: 3px 10px; font-size: 8px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--red);
  font-family: 'IBM Plex Mono', monospace;
}
.art-type-pill {
  background: rgba(240,237,232,.06); border: 1px solid rgba(240,237,232,.1);
  padding: 3px 10px; font-size: 8px; letter-spacing: .1em;
  text-transform: uppercase; color: rgba(240,237,232,.35);
  font-family: 'IBM Plex Mono', monospace;
}
.art-h1 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(32px, 5.5vw, 60px);
  font-weight: 900; text-transform: uppercase;
  line-height: .92; letter-spacing: -.01em;
  color: var(--bone); max-width: 820px;
  margin-bottom: 22px;
}
.art-lead {
  font-family: 'Source Serif 4', serif;
  font-size: 15px; line-height: 1.78;
  color: rgba(240,237,232,.5); max-width: 660px;
}
.art-lead strong { color: rgba(240,237,232,.82); }

/* РАННИЙ CTA УЛУЧШЕННЫЙ */
.art-early-cta {
  margin-top: 28px;
  background: rgba(194,59,42,.1);
  border: 1px solid rgba(194,59,42,.2);
  border-left: 3px solid var(--red);
  padding: 14px 20px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.art-early-text {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10px; letter-spacing: .07em;
  color: rgba(240,237,232,.55); flex: 1; min-width: 200px;
}
.art-early-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-red {
  background: var(--red); color: var(--bone);
  padding: 9px 18px; font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; text-decoration: none; white-space: nowrap;
  transition: background .15s; display: inline-block;
}
.btn-red:hover { background: var(--red-dk); }
.btn-tg {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px;
  letter-spacing: .06em; color: rgba(240,237,232,.45);
  text-decoration: none; white-space: nowrap;
  padding: 9px 0; display: inline-block;
}
.btn-tg:hover { color: rgba(240,237,232,.75); }

/* ── АВТОР ── */
.art-author-bar {
  background: var(--warm);
  padding: 20px 56px;
  border-bottom: 1px solid var(--rule);
  display: flex; align-items: center;
  justify-content: space-between; gap: 20px; flex-wrap: wrap;
}
.art-author-left { display: flex; align-items: center; gap: 16px; }
.art-author-avatar {
  width: 48px; height: 48px; flex-shrink: 0;
  background: var(--mid); object-fit: cover;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Barlow Condensed', sans-serif; font-size: 18px;
  font-weight: 900; color: rgba(240,237,232,.3);
}
.art-author-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black);
  text-decoration: none; display: block;
}
.art-author-name:hover { color: var(--red); }
.art-author-role {
  font-size: 8px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--mid); margin-top: 2px;
}
.art-author-right { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.art-date {
  font-size: 8.5px; letter-spacing: .08em;
  color: var(--mid); font-family: 'IBM Plex Mono', monospace;
}
.art-readtime {
  background: var(--rule); padding: 4px 10px;
  font-size: 8px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--mid); font-family: 'IBM Plex Mono', monospace;
  display: flex; align-items: center; gap: 5px;
}
.art-readtime-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--red); }

/* ── LAYOUT: КОНТЕНТ + САЙДБАР ── */
.art-layout {
  display: grid;
  grid-template-columns: 272px 1fr;
  align-items: start;
  background: var(--rule);
  gap: 2px;
}

/* ── ОСНОВНОЙ КОНТЕНТ ── */
.art-main {
  background: var(--bone);
  padding: 52px 56px 64px;
  min-width: 0;
}

/* H2 с автонумерацией — корректно до 99 секций */
.art-body { counter-reset: h2c; }
.art-body h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .06em; color: var(--black);
  margin: 48px 0 16px; padding-top: 44px;
  border-top: 2px solid var(--rule);
  display: flex; align-items: baseline; gap: 12px;
  counter-increment: h2c;
}
.art-body h2::before {
  content: counter(h2c, decimal-leading-zero) ' ·';
  font-size: 10px; letter-spacing: .2em;
  color: var(--red); font-weight: 400;
  font-family: 'IBM Plex Mono', monospace;
  flex-shrink: 0;
}
.art-body h2:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
.art-body h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--red);
  margin: 24px 0 8px;
}
.art-body p {
  font-family: 'Source Serif 4', serif;
  font-size: 14px; color: var(--grey); line-height: 1.78;
  margin-bottom: 14px;
}
.art-body strong { color: var(--black); }
.art-body a { color: var(--red); text-decoration: underline; text-decoration-color: rgba(194,59,42,.3); }
.art-body a:hover { text-decoration-color: var(--red); }
.art-body ul, .art-body ol {
  font-family: 'Source Serif 4', serif; font-size: 14px;
  color: var(--grey); line-height: 1.72; padding-left: 20px; margin-bottom: 14px;
}
.art-body li { margin-bottom: 6px; }

/* ── КЛЮЧЕВЫЕ МЕТРИКИ ── */
.art-metrics {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 2px; background: var(--rule); margin: 28px 0;
}
.art-metric {
  background: var(--bone); padding: 20px 18px;
  border-top: 2px solid transparent;
  transition: border-color .2s;
}
.art-metric:hover { border-top-color: var(--red); }
.art-metric-n {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 36px; font-weight: 900; color: var(--red); line-height: 1;
}
.art-metric-unit {
  font-size: 12px; color: var(--mid); font-weight: 400;
}
.art-metric-lbl {
  font-size: 8px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--mid); margin-top: 5px; line-height: 1.4;
  font-family: 'IBM Plex Mono', monospace;
}

/* ── БЛОКИ ШАГОВ ── */
.art-step {
  display: grid; grid-template-columns: 56px 1fr;
  margin: 14px 0; background: var(--rule); gap: 2px;
}
.art-step-n {
  background: var(--black);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 28px; font-weight: 900; color: var(--red);
  display: flex; align-items: center; justify-content: center;
  min-height: 80px; flex-shrink: 0;
}
.art-step-body {
  background: var(--bone); padding: 18px 22px;
}
.art-step-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black); margin-bottom: 7px;
}
.art-step-body p {
  font-family: 'Source Serif 4', serif; font-size: 13px;
  color: var(--grey); line-height: 1.65; margin-bottom: 6px;
}
.art-step-body p:last-child { margin-bottom: 0; }
.art-step-body strong { color: var(--black); }

/* ── CALLOUT БОКСЫ ── */
.art-tip, .art-warning, .art-note {
  margin: 24px 0; padding: 16px 20px;
  display: flex; flex-direction: column; gap: 7px;
}
.art-tip {
  background: rgba(194,59,42,.05);
  border-left: 3px solid var(--red);
}
.art-warning {
  background: rgba(20,20,20,.04);
  border-left: 3px solid var(--black);
}
.art-note {
  background: var(--warm);
  border-left: 3px solid var(--mid);
}
.art-callout-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  font-weight: 500;
}
.art-tip .art-callout-label { color: var(--red); }
.art-warning .art-callout-label { color: var(--black); }
.art-note .art-callout-label { color: var(--mid); }
.art-callout-text {
  font-family: 'Source Serif 4', serif;
  font-size: 13px; color: var(--grey); line-height: 1.65;
}
.art-callout-text strong { color: var(--black); }

/* ── ТАБЛИЦЫ УЛУЧШЕННЫЕ ── */
.art-table-wrap { margin: 24px 0; overflow-x: auto; }
.art-table {
  width: 100%; border-collapse: collapse;
  font-size: 12px; min-width: 420px;
}
.art-table th {
  background: var(--black); color: var(--bone);
  padding: 10px 14px; text-align: left;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .12em; text-transform: uppercase;
  font-weight: 500; white-space: nowrap;
  border-right: 1px solid rgba(240,237,232,.06);
}
.art-table th:last-child { border-right: none; }
.art-table td {
  border: 1px solid var(--rule);
  padding: 10px 14px; vertical-align: top;
  font-family: 'Source Serif 4', serif;
  font-size: 13px; color: var(--grey); line-height: 1.5;
}
.art-table tr:nth-child(even) td { background: var(--warm); }
.art-table td:first-child {
  font-family: 'IBM Plex Mono', monospace; font-size: 11px;
  color: var(--black);
}
.art-table td strong { color: var(--black); }
.art-table .td-red { color: var(--red); font-weight: 600; }

/* ── КЕЙС ── */
.art-case {
  background: var(--black); padding: 28px 32px;
  margin: 32px 0; border-left: 4px solid var(--red);
}
.art-case-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--red); margin-bottom: 12px;
  display: flex; align-items: center; gap: 8px;
}
.art-case-label::before {
  content: ''; width: 20px; height: 1px; background: var(--red);
}
.art-case p {
  font-family: 'Source Serif 4', serif; font-size: 13.5px;
  color: rgba(240,237,232,.6); line-height: 1.72; margin-bottom: 8px;
}
.art-case p:last-child { margin-bottom: 0; }
.art-case strong { color: rgba(240,237,232,.88) !important; }

/* ── ЛИДМАГНЕТ ── */
.art-magnet {
  background: var(--warm);
  border: 1px solid rgba(20,20,20,.1);
  border-top: 3px solid var(--black);
  padding: 26px 30px; margin: 32px 0;
  display: grid; grid-template-columns: 1fr auto;
  gap: 20px; align-items: start;
}
.art-magnet-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black); margin-bottom: 8px;
}
.art-magnet p {
  font-family: 'Source Serif 4', serif; font-size: 13px;
  color: var(--grey); line-height: 1.62; margin-bottom: 8px;
}
.art-magnet p:last-child { margin-bottom: 0; }
.art-magnet .lm-cta {
  font-family: 'IBM Plex Mono', monospace; font-size: 9.5px;
  letter-spacing: .06em; color: var(--mid);
}
.art-magnet .lm-cta strong { color: var(--red); }
.art-magnet-icon {
  font-size: 36px; flex-shrink: 0; opacity: .7;
}

/* ── САЙДБАР ── */
.art-sidebar {
  background: var(--warm);
  padding: 28px 24px;
  position: sticky; top: 54px;
  border-left: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 0;
  max-height: calc(100vh - 56px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--rule) transparent;
}

/* TOC */
.toc-hd {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--mid); margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 2px solid var(--rule);
}
.toc-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1px; }
.toc-list a {
  display: flex; align-items: baseline; gap: 8px;
  font-family: 'IBM Plex Mono', monospace; font-size: 9.5px;
  letter-spacing: .03em; color: var(--mid); text-decoration: none;
  padding: 5px 10px 5px 12px;
  border-left: 2px solid transparent;
  transition: all .15s; line-height: 1.4;
}
.toc-list a:hover { color: var(--black); border-left-color: rgba(20,20,20,.2); }
.toc-list a.toc-active { color: var(--red); border-left-color: var(--red); }
.toc-list .toc-n {
  font-size: 8px; color: var(--red); opacity: .6;
  flex-shrink: 0;
}
.toc-list a.toc-active .toc-n { opacity: 1; }

/* Sidebar CTA */
.sb-cta {
  background: var(--black); padding: 22px;
  margin-top: 20px; flex-shrink: 0;
}
.sb-cta-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7.5px; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(194,59,42,.5); margin-bottom: 8px;
}
.sb-cta-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px; font-weight: 900; text-transform: uppercase;
  color: var(--bone); line-height: .95; margin-bottom: 10px;
}
.sb-cta-desc {
  font-family: 'Source Serif 4', serif; font-size: 11.5px;
  color: rgba(240,237,232,.38); line-height: 1.6; margin-bottom: 14px;
}
.sb-cta-btn {
  display: block; background: var(--red); color: var(--bone);
  padding: 10px 14px; text-align: center; text-decoration: none;
  font-family: 'IBM Plex Mono', monospace; font-size: 8.5px;
  letter-spacing: .12em; text-transform: uppercase;
  transition: background .15s;
}
.sb-cta-btn:hover { background: var(--red-dk); }
.sb-cta-links {
  display: flex; gap: 12px; margin-top: 8px;
  justify-content: center;
}
.sb-cta-link {
  font-family: 'IBM Plex Mono', monospace; font-size: 8.5px;
  letter-spacing: .06em; color: rgba(240,237,232,.3);
  text-decoration: none;
}
.sb-cta-link:hover { color: rgba(240,237,232,.6); }

/* Sidebar author */
.sb-author {
  margin-top: 20px; padding-top: 16px;
  border-top: 1px solid var(--rule);
  flex-shrink: 0;
}
.sb-author-lbl {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7.5px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--mid); margin-bottom: 10px;
}
.sb-author-card {
  display: flex; align-items: center; gap: 10px;
}
.sb-author-av {
  width: 36px; height: 36px; flex-shrink: 0;
  background: var(--mid);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Barlow Condensed', sans-serif; font-size: 14px;
  font-weight: 900; color: rgba(240,237,232,.3);
}
.sb-author-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; color: var(--black); text-decoration: none;
  display: block;
}
.sb-author-name:hover { color: var(--red); }
.sb-author-role {
  font-size: 7.5px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--mid); margin-top: 2px;
  font-family: 'IBM Plex Mono', monospace;
}

/* ── ФИНАЛЬНЫЙ CTA ── */
.art-final-cta {
  background: var(--black); padding: 52px 56px;
  border-top: 3px solid var(--red);
}
.art-final-cta .cta-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(194,59,42,.5); margin-bottom: 12px;
}
.art-final-cta .cta-h {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(32px, 4.5vw, 52px); font-weight: 900;
  text-transform: uppercase; line-height: .93;
  color: var(--bone); margin-bottom: 16px;
}
.art-final-cta .cta-offer {
  font-family: 'Source Serif 4', serif; font-size: 14px;
  color: rgba(240,237,232,.45); line-height: 1.7;
  max-width: 560px; margin-bottom: 28px;
}
.art-final-cta .cta-offer strong { color: rgba(240,237,232,.75); }
.art-final-cta .cta-btns { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.btn-cta-main {
  background: var(--red); color: var(--bone);
  padding: 14px 28px; font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .08em; text-decoration: none; display: inline-block;
  transition: background .15s;
}
.btn-cta-main:hover { background: var(--red-dk); }
.btn-cta-tg {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px;
  letter-spacing: .06em; color: rgba(240,237,232,.4); text-decoration: none;
}
.btn-cta-tg:hover { color: rgba(240,237,232,.7); }
.art-final-cta .cta-phone {
  font-family: 'IBM Plex Mono', monospace; font-size: 8.5px;
  letter-spacing: .1em; color: rgba(240,237,232,.25); margin-top: 16px;
}
.art-final-cta .cta-phone a { color: rgba(240,237,232,.35); text-decoration: none; }
.art-final-cta .cta-trust {
  font-size: 8px; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(194,59,42,.4); margin-top: 8px;
}

/* ── FAQ ── */
.art-faq { padding: 52px 56px; background: var(--warm); }
.art-faq-hd {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--mid);
  margin-bottom: 28px; padding-bottom: 14px;
  border-bottom: 2px solid var(--rule);
  display: flex; align-items: baseline; gap: 14px;
}
.art-faq-hd .faq-n {
  font-size: 9px; color: var(--red);
  font-family: 'IBM Plex Mono', monospace; font-weight: 400;
}

/* ── СВЯЗАННЫЕ СТАТЬИ ── */
.art-related { padding: 48px 56px; background: var(--bone); border-top: 1px solid var(--rule); }
.art-related-hd {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--mid); margin-bottom: 20px;
}
.art-related-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 2px; background: var(--rule);
}
.art-related-card {
  background: var(--bone); padding: 22px 20px;
  border-left: 3px solid transparent;
  transition: border-color .18s, background .15s;
  text-decoration: none; display: flex; flex-direction: column;
}
.art-related-card:hover { border-left-color: var(--red); background: #eae5df; }
.art-related-cat {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--red); margin-bottom: 8px;
}
.art-related-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .02em; color: var(--black);
  line-height: 1.12; margin-bottom: 8px; flex: 1;
}
.art-related-meta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7.5px; letter-spacing: .07em; color: var(--mid);
  margin-top: auto;
}

/* ── MOBILE STICKY ── */
.art-mobile-sticky {
  display: none; position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--black); border-top: 2px solid var(--red);
  padding: 10px 16px; gap: 8px; z-index: 200; align-items: center;
}
@media (max-width: 860px) {
  .art-mobile-sticky { display: flex; }
  .art-layout { grid-template-columns: 1fr; }
  .art-sidebar { display: none; }
  .art-main { padding: 36px 24px; }
  .art-hero { padding: 40px 24px 36px; }
  .art-author-bar { padding: 16px 24px; }
  .art-faq { padding: 36px 24px; }
  .art-final-cta { padding: 40px 24px; }
  .art-related { padding: 36px 24px; }
  .art-related-grid { grid-template-columns: 1fr; }
  .art-metrics { grid-template-columns: repeat(2, 1fr); }
  .art-magnet { grid-template-columns: 1fr; }
  .art-magnet-icon { display: none; }
}
.ms-main {
  flex: 1; background: var(--red); color: var(--bone);
  padding: 11px; text-align: center;
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  text-decoration: none;
}
.ms-icon {
  width: 42px; height: 42px; background: rgba(240,237,232,.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; text-decoration: none; flex-shrink: 0;
}


/* ══════════════════════════════════════════════════
   MOBILE & TABLET RESPONSIVE · добавлено 2026-04-26
   Breakpoints:
   768px  — телефон (portrait)
   1024px — планшет / телефон landscape
══════════════════════════════════════════════════ */

/* ── БУРГЕР-КНОПКА ── */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px; height: 36px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px;
  flex-shrink: 0;
}
.nav-burger span {
  display: block;
  width: 100%; height: 1.5px;
  background: rgba(240,237,232,.6);
  transition: all .25s;
}
.nav-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── МОБИЛЬНОЕ МЕНЮ (drawer) ── */
.nav-drawer {
  display: none;
  position: fixed;
  top: 52px; left: 0; right: 0; bottom: 0;
  background: rgba(20,20,20,.98);
  z-index: 199;
  flex-direction: column;
  padding: 32px 24px;
  gap: 0;
  overflow-y: auto;
}
.nav-drawer.open { display: flex; }
.nav-drawer li { list-style: none; border-bottom: 1px solid rgba(240,237,232,.06); }
.nav-drawer li a {
  display: block;
  padding: 16px 0;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  color: rgba(240,237,232,.5);
  text-decoration: none;
  transition: color .15s;
}
.nav-drawer li a:hover,
.nav-drawer li a.active { color: var(--bone); }
.nav-drawer li a.active { color: var(--red); }
.nav-drawer-cta {
  margin-top: 24px;
  background: var(--red); color: var(--bone);
  padding: 16px; text-align: center;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; text-decoration: none;
  display: block;
}

/* ════════════════════════
   TABLET: max-width 1024px
════════════════════════ */
@media (max-width: 1024px) {

  /* Nav */
  nav { padding: 0 32px; }
  .nav-links li a { padding: 0 10px; }

  /* Sections */
  .sec { padding: 48px 32px; }
  .cta-full { padding: 48px 32px; }
  .form-section { padding: 48px 32px; }

  /* Hub analytics */
  .hub-hero { padding: 40px 32px 0; }
  .hub-hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .hub-right { display: none; }
  .hub-ticker { padding: 0 32px; }
  .filter-bar { padding: 0 32px; }
  .featured-wrap { padding: 0 32px; }
  .sec-label { padding: 16px 32px; }
  .art-section { padding: 0 32px 40px; }
  .art-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .load-more-wrap { padding: 24px 32px; }
  .sub-strip { padding: 32px; flex-direction: column; gap: 16px; }
  .cta-full { padding: 48px 32px; }
  .site-footer { padding: 20px 32px; }

  /* Featured card */
  .featured-card { grid-template-columns: 1fr; }
  .featured-side { display: none; }
  .featured-main { min-height: 240px; padding: 32px; }

  /* Article v2 */
  .art-hero { padding: 40px 32px 0; }
  .art-author-bar { padding: 16px 32px; }
  .art-main { padding: 40px 32px 48px; }
  .art-faq { padding: 40px 32px; }
  .art-final-cta { padding: 40px 32px; }
  .art-related { padding: 36px 32px; }
  .load-more-wrap { padding: 24px 32px; }

  /* Contacts & Check */
  .contacts-inner { padding: 40px 32px; flex-direction: column; gap: 32px; }
  .check-inner { padding: 40px 32px; flex-direction: column; gap: 32px; }
  .form-grid { grid-template-columns: 1fr; }
  .form-info { border-left: none; padding-left: 0; border-top: 1px solid var(--rule); padding-top: 32px; }
}

/* ════════════════════════
   MOBILE: max-width 768px
════════════════════════ */
@media (max-width: 768px) {

  /* NAV */
  nav { padding: 0 20px; height: 52px; }
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .nav-burger { display: flex; }

  /* Sections */
  .sec { padding: 36px 20px; }
  .cta-full { padding: 36px 20px; flex-direction: column; gap: 24px; }
  .cta-title { font-size: 36px; }
  .site-footer { padding: 20px; flex-direction: column; gap: 16px; text-align: center; }
  .sf-end { flex-direction: column; align-items: center; }
  .sf-meta { text-align: center; }

  /* Hub analytics */
  .hub-masthead { padding: 0 20px; }
  .hub-hero { padding: 36px 20px 0; }
  .hub-h1 { font-size: 56px; }
  .hub-ticker { padding: 0 20px; gap: 0; }
  .hub-tick-sep { margin-right: 16px; }
  .filter-bar { padding: 0 20px; }
  .search-wrap { padding: 0 20px; }
  .featured-wrap { padding: 0 20px; }
  .sec-label { padding: 14px 20px; }
  .art-section { padding: 0 20px 36px; }
  .art-grid-3 { grid-template-columns: 1fr; }
  .load-more-wrap { padding: 20px; flex-direction: column; gap: 12px; }
  .sub-strip { padding: 24px 20px; }

  /* Featured */
  .featured-main { padding: 24px 20px; border-left-width: 3px; }
  .featured-title { font-size: 26px; }

  /* Art card */
  .art-card { padding: 22px 16px; }

  /* Article v2 */
  .art-hero { padding: 32px 20px 0; }
  .art-h1 { font-size: 32px; }
  .art-lead { font-size: 14px; }
  .art-early-cta { flex-direction: column; gap: 12px; }
  .art-early-btns { flex-direction: column; gap: 8px; }
  .btn-red { text-align: center; }
  .art-author-bar { padding: 14px 20px; flex-direction: column; align-items: flex-start; gap: 8px; }
  .art-main { padding: 32px 20px 48px; }
  .art-body h2 { font-size: 17px; }
  .art-step { grid-template-columns: 44px 1fr; }
  .art-step-n { font-size: 22px; }
  .art-metrics { grid-template-columns: 1fr 1fr; }
  .art-metric-n { font-size: 28px; }
  .art-case { padding: 22px 20px; }
  .art-magnet { padding: 20px; }
  .art-faq { padding: 32px 20px; }
  .art-final-cta { padding: 36px 20px; }
  .art-final-cta .cta-h { font-size: 32px; }
  .art-final-cta .cta-btns { flex-direction: column; gap: 12px; }
  .btn-cta-main { text-align: center; }
  .art-related { padding: 32px 20px; }
  .art-related-grid { grid-template-columns: 1fr; }

  /* Form rows → single column */
  .form-row { flex-direction: column; }
  .form-section { padding: 36px 20px; }
  .contacts-inner { padding: 32px 20px; }
  .contacts-hero { padding: 0; }
  .ct-channels { grid-template-columns: 1fr; }

  /* Check hero */
  .check-inner { padding: 32px 20px; }
  .check-hero { padding: 0; }
  .ch-form-hero { padding: 20px; }

  /* How grid → 2 колонки */
  .how-grid { grid-template-columns: 1fr 1fr; }

  /* Addresses */
  .addr-grid { grid-template-columns: 1fr !important; }

  /* 404 */
  .e404-inner { grid-template-columns: 1fr; }
  .e404-left { padding: 48px 20px; }
  .e404-right { display: none; }
  .e404-strip { padding: 14px 20px; flex-direction: column; gap: 8px; text-align: center; }
  .e404-code { font-size: 100px; }
}

/* ════════════════════════
   SMALL: max-width 400px
════════════════════════ */
@media (max-width: 400px) {
  .hub-h1 { font-size: 44px; }
  .art-h1 { font-size: 28px; }
  .how-grid { grid-template-columns: 1fr; }
  .art-metrics { grid-template-columns: 1fr; }
  .hub-tick-item:nth-child(5),
  .hub-tick-sep:nth-child(4) { display: none; }
}

/* ══════════════════════════════════
   SERVICE PAGES · /services/{slug}/
   Добавлено 2026-04-27
══════════════════════════════════ */

/* ── HERO ── */
.svc-hero {
  background: var(--black); border-bottom: 3px solid var(--red);
  padding: 0; position: relative; overflow: hidden;
}
.svc-hero-bg {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(240,237,232,.02) 1px, transparent 1px), linear-gradient(90deg, rgba(240,237,232,.02) 1px, transparent 1px);
  background-size: 56px 56px; pointer-events: none;
}
.svc-hero-inner { position: relative; padding: 48px 56px 52px; }
.svc-breadcrumb {
  font-size: 8px; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(240,237,232,.25); margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.svc-breadcrumb a { color: rgba(240,237,232,.25); text-decoration: none; }
.svc-breadcrumb a:hover { color: rgba(240,237,232,.5); }
.svc-breadcrumb span { color: rgba(240,237,232,.12); }
.svc-meta-row { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.svc-cat-pill {
  background: rgba(194,59,42,.15); border: 1px solid rgba(194,59,42,.25);
  padding: 3px 10px; font-size: 8px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--red); font-family: 'IBM Plex Mono', monospace;
}
.svc-update { font-size: 8px; letter-spacing: .1em; color: rgba(240,237,232,.2); font-family: 'IBM Plex Mono', monospace; }
.svc-h1 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(36px, 5.5vw, 64px); font-weight: 900;
  text-transform: uppercase; line-height: .92; letter-spacing: -.01em;
  color: var(--bone); max-width: 780px; margin-bottom: 18px;
}
.svc-lead {
  font-family: 'Source Serif 4', serif; font-size: 15px;
  color: rgba(240,237,232,.5); line-height: 1.72; max-width: 600px; margin-bottom: 26px;
}
.svc-lead strong { color: rgba(240,237,232,.8); }
.svc-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.svc-hero-phone {
  font-family: 'IBM Plex Mono', monospace; font-size: 9.5px;
  letter-spacing: .08em; color: rgba(240,237,232,.25); display: flex; gap: 12px; flex-wrap: wrap;
}
.svc-hero-phone a { color: rgba(240,237,232,.35); text-decoration: none; }
.svc-hero-phone a:hover { color: rgba(240,237,232,.65); }

/* ── TRUST BAR ── */
.svc-trust-bar { background: var(--warm); border-bottom: 2px solid var(--rule); }
.svc-trust-inner {
  padding: 20px 56px; display: flex; align-items: center;
  gap: 0; flex-wrap: wrap;
}
.svc-trust-stat { padding: 0 28px; flex-shrink: 0; }
.svc-trust-stat:first-child { padding-left: 0; }
.svc-trust-n {
  font-family: 'Barlow Condensed', sans-serif; font-size: 28px;
  font-weight: 900; color: var(--black); line-height: 1;
}
.svc-trust-lbl { font-size: 8px; letter-spacing: .1em; text-transform: uppercase; color: var(--mid); margin-top: 2px; }
.svc-trust-sep { width: 1px; height: 32px; background: var(--rule); flex-shrink: 0; }
.svc-trust-sep--pills { margin: 0 12px; }
.svc-trust-pills { display: flex; gap: 6px; flex-wrap: wrap; padding: 0 12px; }

/* ── BRIDGE ── */
.svc-bridge { padding: 52px 56px; background: var(--bone); border-top: 1px solid var(--rule); }
.svc-bridge-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 2px; background: var(--rule); margin-top: 28px; }
.svc-bridge-item { background: var(--bone); padding: 22px 20px; display: flex; gap: 14px; align-items: flex-start; }
.svc-bridge-ic { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.svc-bridge-txt { font-family: 'Source Serif 4', serif; font-size: 13.5px; color: var(--grey); line-height: 1.65; }

/* ── CTA-A ── */
.svc-cta-a {
  background: rgba(194,59,42,.06); border-left: 4px solid var(--red);
  padding: 24px 56px; display: flex; align-items: center;
  justify-content: space-between; gap: 24px; flex-wrap: wrap;
}
.svc-cta-a-txt { font-family: 'Source Serif 4', serif; font-size: 14px; color: var(--grey); line-height: 1.6; flex: 1; min-width: 260px; }
.svc-cta-a-btns { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; flex-shrink: 0; }
.svc-tel-link { font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .06em; color: var(--mid); text-decoration: none; white-space: nowrap; }
.svc-tel-link:hover { color: var(--red); }

/* ── STEPS ── */
.svc-steps { padding: 52px 56px; background: var(--bone); }
.svc-steps-list { display: flex; flex-direction: column; gap: 2px; background: var(--rule); margin-top: 28px; }
.svc-step-result { font-family: 'IBM Plex Mono', monospace; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--red); margin-top: 6px; }

/* ── PRICING ── */
.svc-pricing { padding: 52px 56px; background: var(--warm); }
.svc-price-grid { display: grid; grid-template-columns: 280px 1fr; gap: 2px; background: var(--rule); margin-top: 28px; }
.svc-price-card { background: var(--black); padding: 32px 28px; display: flex; flex-direction: column; gap: 8px; }
.svc-price-card--main {}
.svc-price-label { font-size: 8px; letter-spacing: .18em; text-transform: uppercase; color: rgba(194,59,42,.6); }
.svc-price-num { font-family: 'Barlow Condensed', sans-serif; font-size: 40px; font-weight: 900; color: var(--bone); line-height: 1; }
.svc-price-desc { font-family: 'Source Serif 4', serif; font-size: 13px; color: rgba(240,237,232,.45); line-height: 1.6; }
.svc-price-guarantee { font-size: 8px; letter-spacing: .08em; color: rgba(240,237,232,.2); margin-top: 4px; }
.svc-price-details { background: var(--bone); padding: 24px; }

/* ── PARTNER ── */
.svc-partner { padding: 52px 56px; background: var(--bone); border-top: 1px solid var(--rule); }
.svc-partner-card { display: flex; gap: 28px; align-items: flex-start; margin-top: 28px; background: var(--warm); padding: 28px; }
.svc-partner-av {
  width: 72px; height: 72px; background: var(--mid); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Barlow Condensed', sans-serif; font-size: 24px;
  font-weight: 900; color: rgba(240,237,232,.3);
}
.svc-partner-name { font-family: 'Barlow Condensed', sans-serif; font-size: 18px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--black); text-decoration: none; display: block; }
.svc-partner-name:hover { color: var(--red); }
.svc-partner-role { font-size: 8px; letter-spacing: .12em; text-transform: uppercase; color: var(--red); margin: 4px 0; font-family: 'IBM Plex Mono', monospace; }
.svc-partner-tags { font-size: 9px; letter-spacing: .06em; color: var(--mid); margin-bottom: 10px; font-family: 'IBM Plex Mono', monospace; }
.svc-partner-bio { font-family: 'Source Serif 4', serif; font-size: 13px; color: var(--grey); line-height: 1.65; }

/* ── CASES (warm bg) ── */
.svc-cases { padding: 52px 56px; background: var(--warm); }
.svc-cases-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2px; background: var(--rule); margin-top: 28px; }

/* ── REVIEWS ── */
.svc-reviews { padding: 52px 56px; background: var(--bone); }
.svc-reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; margin-top: 28px; }
.svc-review-card { background: var(--warm); padding: 24px; border-left: 3px solid var(--rule); }
.svc-review-quote { font-family: 'Source Serif 4', serif; font-size: 14px; color: var(--grey); line-height: 1.72; font-style: italic; margin-bottom: 12px; }
.svc-review-attr { font-size: 8.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--mid); font-family: 'IBM Plex Mono', monospace; }
.svc-reviews-disclaimer { font-size: 8px; letter-spacing: .08em; color: var(--mid); margin-top: 16px; font-family: 'IBM Plex Mono', monospace; }

/* ── MICRO-CTA ── */
.svc-micro-cta {
  padding: 24px 56px; background: var(--bone); border-top: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
}
.svc-micro-cta p { font-family: 'Source Serif 4', serif; font-size: 14px; color: var(--grey); }

/* ── CTA-Б ── */
.svc-cta-b { background: var(--black); padding: 36px 56px; border-top: 1px solid rgba(240,237,232,.06); }
.svc-cta-b-inner { display: flex; align-items: center; gap: 32px; flex-wrap: wrap; }
.svc-cta-b-txt { flex: 1; min-width: 260px; }
.svc-cta-b-txt strong { font-family: 'Barlow Condensed', sans-serif; font-size: 20px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--bone); display: block; margin-bottom: 6px; }
.svc-cta-b-txt p { font-family: 'Source Serif 4', serif; font-size: 13px; color: rgba(240,237,232,.4); line-height: 1.6; }
.svc-cta-b-btns { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; flex-shrink: 0; }

/* ── RELATED ── */
.svc-related { padding: 52px 56px; background: var(--bone); border-top: 1px solid var(--rule); }

/* ── FINAL CTA ── */
.svc-final-cta { background: var(--black); padding: 64px 56px; border-top: 3px solid var(--red); }
.svc-final-inner { display: grid; grid-template-columns: 1fr 400px; gap: 56px; align-items: start; }
.svc-final-eyebrow { font-size: 8px; letter-spacing: .2em; text-transform: uppercase; color: rgba(194,59,42,.5); margin-bottom: 10px; }
.svc-final-h { font-family: 'Barlow Condensed', sans-serif; font-size: clamp(36px, 4.5vw, 52px); font-weight: 900; text-transform: uppercase; line-height: .92; color: var(--bone); margin-bottom: 14px; }
.svc-final-sub { font-family: 'Source Serif 4', serif; font-size: 14px; color: rgba(240,237,232,.45); line-height: 1.7; max-width: 420px; margin-bottom: 20px; }
.svc-final-sub strong { color: rgba(240,237,232,.75); }
.svc-final-trust { font-size: 8px; letter-spacing: .1em; text-transform: uppercase; color: rgba(194,59,42,.4); margin-bottom: 20px; font-family: 'IBM Plex Mono', monospace; }
.svc-final-channels { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.svc-ch-link { font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .07em; color: rgba(240,237,232,.35); text-decoration: none; }
.svc-ch-link:hover { color: rgba(240,237,232,.7); }
.svc-final-addr { font-size: 8px; letter-spacing: .07em; color: rgba(240,237,232,.18); font-family: 'IBM Plex Mono', monospace; line-height: 1.6; }
.svc-form { display: flex; flex-direction: column; gap: 12px; background: rgba(240,237,232,.04); padding: 28px; border: 1px solid rgba(240,237,232,.08); }
.svc-form .form-field label { font-size: 8px; letter-spacing: .14em; text-transform: uppercase; color: rgba(240,237,232,.3); display: block; margin-bottom: 5px; font-family: 'IBM Plex Mono', monospace; }
.svc-form input, .svc-form textarea { width: 100%; background: rgba(240,237,232,.06); border: 1px solid rgba(240,237,232,.12); padding: 11px 14px; color: var(--bone); font-family: 'IBM Plex Mono', monospace; font-size: 11px; outline: none; transition: border-color .15s; }
.svc-form input:focus, .svc-form textarea:focus { border-color: rgba(194,59,42,.4); }
.svc-form input::placeholder, .svc-form textarea::placeholder { color: rgba(240,237,232,.2); }
.svc-form textarea { min-height: 80px; resize: vertical; }
.svc-form-disclaimer { font-size: 7.5px; letter-spacing: .06em; color: rgba(240,237,232,.18); line-height: 1.6; font-family: 'IBM Plex Mono', monospace; }

/* ── DISCLAIMER ── */
.svc-disclaimer { padding: 20px 56px; background: var(--black); font-size: 8px; letter-spacing: .06em; color: rgba(240,237,232,.15); line-height: 1.7; font-family: 'IBM Plex Mono', monospace; border-top: 1px solid rgba(240,237,232,.04); }

/* ── MOBILE SERVICES ── */
@media (max-width: 1024px) {
  .svc-hero-inner { padding: 40px 32px 48px; }
  .svc-trust-inner { padding: 16px 32px; }
  .svc-bridge, .svc-steps, .svc-pricing, .svc-partner, .svc-cases,
  .svc-reviews, .svc-related, .svc-final-cta, .svc-disclaimer { padding-left: 32px; padding-right: 32px; }
  .svc-cta-a, .svc-micro-cta, .svc-cta-b { padding-left: 32px; padding-right: 32px; }
  .svc-final-inner { grid-template-columns: 1fr; }
  .svc-price-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .svc-hero-inner { padding: 32px 20px 40px; }
  .svc-trust-inner { padding: 14px 20px; gap: 0; flex-wrap: wrap; }
  .svc-trust-stat { padding: 8px 14px; }
  .svc-trust-sep { display: none; }
  .svc-trust-pills { padding: 8px 0; width: 100%; }
  .svc-bridge, .svc-steps, .svc-pricing, .svc-partner, .svc-cases,
  .svc-reviews, .svc-related, .svc-final-cta, .svc-disclaimer { padding-left: 20px; padding-right: 20px; }
  .svc-cta-a, .svc-micro-cta, .svc-cta-b { padding: 20px; flex-direction: column; }
  .svc-partner-card { flex-direction: column; }
  .svc-final-inner { grid-template-columns: 1fr; }
  .svc-price-grid { grid-template-columns: 1fr; }
}

/* ── PRICING HUB · /pricing.html ── */
.pricing-svc-card {
  background: var(--bone);
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 10px;
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: border-color .2s, background .15s;
  position: relative;
}
.pricing-svc-card:hover { border-left-color: var(--red); }
.pricing-svc-cta-card { cursor: default; }
.psc-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 9px; letter-spacing: .18em;
  color: var(--red); opacity: .6;
}
.psc-icon { font-size: 26px; }
.psc-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--black); line-height: 1.05;
}
.psc-desc {
  font-family: 'Source Serif 4', serif;
  font-size: 13px; color: var(--grey); line-height: 1.65; flex: 1;
}
.psc-price {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 28px; font-weight: 900; color: var(--black);
  margin-top: 8px; line-height: 1;
}
.psc-price-note {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8px; letter-spacing: .08em; color: var(--mid);
}
.psc-cta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 9px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--red);
  margin-top: 4px; transition: letter-spacing .15s;
}
.pricing-svc-card:hover .psc-cta { letter-spacing: .18em; }
@media (max-width: 768px) {
  .pricing-svc-card { padding: 24px 20px; }
}

/* ── HERO MOBILE (pricing.html использует .hero) ── */
@media (max-width: 1024px) {
  .hero { padding: 48px 32px 44px; }
  .hero-inner { grid-template-columns: 1fr; gap: 24px; }
  .hero-right { display: none; }
}
@media (max-width: 768px) {
  .hero { padding: 36px 20px 36px; }
  .hero-h1 { font-size: 52px; }
}

/* ── PRICING CARD VARIANTS ── */
.pricing-svc-card.psc-dark { background: var(--black); }
.pricing-svc-card.psc-dark .psc-name { color: var(--bone); }
.pricing-svc-card.psc-dark .psc-num { color: var(--red); opacity: 1; }
.pricing-svc-card.psc-dark .psc-desc { color: rgba(240,237,232,.5); }
.pricing-svc-card.psc-dark .psc-price { color: var(--bone); }
.pricing-svc-card.psc-dark .psc-price-note { color: rgba(240,237,232,.3); }
.pricing-svc-card.psc-warm { background: var(--warm); }
/* ══════════════════════════════════════════════════
   MARQA · MOBILE FIX · 2026-05-22
   Доадаптация главной и командной страниц под телефон
   Добавлено в конец style.css
══════════════════════════════════════════════════ */

/* ── ГЛОБАЛЬНО: страховка от горизонтального переполнения ── */
html, body { overflow-x: hidden; max-width: 100%; }

/* ── TABLET: 1024px (планшет и узкие десктопы) ── */
@media (max-width: 1024px) {

  /* INDEX: 4-колоночные блоки → 2 колонки */
  .stats-row  { grid-template-columns: repeat(2, 1fr); }
  .svc-grid   { grid-template-columns: repeat(2, 1fr); }
  .cases-row  { grid-template-columns: repeat(2, 1fr); }

  /* INDEX: блок команды (HTML с inline-стилем 3-х колонок) */
  .sec > div[style*="grid-template-columns:repeat(3,1fr)"],
  .sec > div[style*="grid-template-columns: repeat(3, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* CTA: переключаем grid в 1 колонку (предыдущее правило flex-direction
     не работает, потому что .cta-full объявлен как display:grid) */
  .cta-full   { grid-template-columns: 1fr; gap: 28px; }
  .cta-btns   { align-items: stretch; flex-direction: row; flex-wrap: wrap; gap: 12px; }
  .cta-btns > * { flex: 1 1 200px; text-align: center; }

  /* TEAM: hero и карточка партнёра */
  .team-hero       { padding: 48px 32px; }
  .team-hero-inner { grid-template-columns: 1fr; gap: 24px; }
  .partner-card    { grid-template-columns: 240px 1fr; }
  .pc-left         { padding: 36px 28px; }
  .pc-avatar       { width: 160px; height: 160px; font-size: 56px; }
}

/* ── MOBILE: 768px (телефон portrait) ── */
@media (max-width: 768px) {

  /* Базовый размер шрифта читаемее (12px → 13px) */
  body { font-size: 13px; }

  /* HERO: кнопки во всю ширину, в столбик */
  .hero-btns                  { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-btns .btn-primary,
  .hero-btns .btn-ghost       { text-align: center; width: 100%; padding-left: 0; padding-right: 0; }

  /* STATS: одна колонка, компактнее */
  .stats-row   { grid-template-columns: 1fr; }
  .stat-card   { padding: 22px 20px; }
  .stat-num    { font-size: 38px; }
  .stat-txt    { font-size: 13px; }

  /* SERVICES: одна колонка */
  .svc-grid    { grid-template-columns: 1fr; }
  .svc-card    { padding: 24px 22px; }
  .svc-ic      { font-size: 22px; margin-bottom: 12px; }
  .svc-name    { font-size: 16px; }
  .svc-desc    { font-size: 13px; }

  /* CASES: одна колонка */
  .cases-row   { grid-template-columns: 1fr; }
  .case-card   { padding: 22px 20px; }
  .case-title  { font-size: 15px; }
  .case-desc   { font-size: 13px; }
  .case-result { font-size: 22px; }

  /* TEAM preview на главной (инлайн-сетка): одна колонка */
  .sec > div[style*="grid-template-columns:repeat(3,1fr)"],
  .sec > div[style*="grid-template-columns: repeat(3, 1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* CTA: одна колонка, кнопки на всю ширину */
  .cta-full     { grid-template-columns: 1fr; gap: 20px; }
  .cta-btns     { align-items: stretch; flex-direction: column; gap: 10px; }
  .cta-btns > * { width: 100%; text-align: center; flex: none; }
  .cta-sub      { font-size: 13px; }

  /* TEAM page: карточка партнёра в столбик */
  .team-hero    { padding: 36px 20px; }
  .partner-card { grid-template-columns: 1fr; }
  .pc-left      { padding: 28px 22px; }
  .pc-avatar    { width: 120px; height: 120px; font-size: 44px; margin-bottom: 18px; }
  .pc-name      { font-size: 22px; }

  /* Section header: компактнее, переносим, если длинный */
  .sec-hd       { margin-bottom: 28px; gap: 12px; flex-wrap: wrap; }

  /* Защита от горизонтального переполнения медиа */
  img, video, iframe { max-width: 100%; height: auto; }
}

/* ── EXTRA SMALL: 380px (узкие телефоны, iPhone SE и т.п.) ── */
@media (max-width: 380px) {
  .sec        { padding: 30px 16px; }
  .hero       { padding: 32px 16px 32px; }
  .cta-full   { padding: 30px 16px; }
  .stat-num   { font-size: 34px; }
  .case-result{ font-size: 20px; }
  .pc-name    { font-size: 20px; }
}
