/*
Theme Name: GeneratePress Child
Template: generatepress
Description: Дочерняя тема ATresulting.ru
Version: 1.0
*/
/* ============ BASE ============ */
:root{
  --blue:#2F8DFB;
  --blue-2:#4FA3FF;
  --blue-dark:#1E5BB8;
  --blue-deep:#142B5C;
  --blue-bg:#3A95FC;
  --blue-bg-2:#1E7AE8;
  --blue-soft:#EAF2FF;
  --orange:#FFA940;
  --orange-dark:#FF8A00;
  --orange-soft:#FFF1DC;
  --green:#22C55E;
  --pink:#FF6B9C;
  --purple:#A56BFF;
  --ink:#0F1B3D;
  --ink-2:#2B3A5C;
  --muted:#7a89a8;
  --line:#E6ECF7;
  --bg-soft:#F4F8FF;
  --bg-deep:#0E1A40;
  --white:#fff;
  --shadow-sm:0 4px 12px rgba(30,91,184,.06);
  --shadow:0 12px 32px rgba(30,91,184,.10);
  --shadow-lg:0 22px 50px rgba(30,91,184,.18);
  --shadow-orange:0 12px 28px rgba(255,138,0,.35);
  --radius:18px;
  --radius-lg:24px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.container{max-width:1240px;margin:0 auto;padding:0 24px}

/* ============ TYPO ============ */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:99px;
  background:var(--orange-soft);color:var(--orange-dark);
  font-size:13px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;
  margin-bottom:18px;
}
.eyebrow.blue{background:var(--blue-soft);color:var(--blue-dark)}
.eyebrow::before{content:'';width:6px;height:6px;background:currentColor;border-radius:50%}
.section-title{
  font-size:42px;font-weight:800;line-height:1.15;
  margin-bottom:16px;color:var(--ink);
  letter-spacing:-.5px;
}
.section-sub{
  font-size:17px;color:var(--muted);max-width:680px;
  margin-bottom:48px;
}
.section{padding:100px 0;position:relative}
.section.bg-soft{background:var(--bg-soft)}
.section-head{margin-bottom:56px}
.section-head.center{text-align:center;display:flex;flex-direction:column;align-items:center}
.section-head.center .section-sub{margin-left:auto;margin-right:auto}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 30px;border-radius:14px;
  font-weight:700;font-size:16px;
  cursor:pointer;border:none;
  transition:all .25s ease;
  white-space:nowrap;
  font-family:inherit;
}
.btn-sm{padding:12px 22px;font-size:14px;border-radius:12px}
.btn-primary{background:var(--orange);color:#fff;box-shadow:var(--shadow-orange)}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 16px 34px rgba(255,138,0,.45)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.5);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.18);border-color:#fff}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 12px 28px rgba(47,141,251,.35)}
.btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px)}
.btn-outline{background:#fff;color:var(--blue-dark);border:2px solid var(--line)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}

/* ============ HIGHLIGHTER ============ */
.hl{
  background:linear-gradient(180deg, transparent 55%, var(--orange) 55%, var(--orange) 92%, transparent 92%);
  padding:0 6px;
  white-space:nowrap;
}
.hl-blue{
  background:linear-gradient(180deg, transparent 55%, rgba(47,141,251,.25) 55%, rgba(47,141,251,.25) 92%, transparent 92%);
  padding:0 4px;
}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;gap:24px;
}
.logo{font-size:24px;letter-spacing:-.5px;display:flex;align-items:center;gap:8px}
.logo-mark{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:900;font-size:18px;
  box-shadow:0 6px 14px rgba(47,141,251,.35);
}
.logo-bold{font-weight:900;color:var(--blue-dark)}
.logo-light{font-weight:500;color:var(--ink)}
.main-nav{display:flex;gap:32px;flex:1;justify-content:center}
.main-nav a{font-weight:600;color:var(--ink-2);font-size:15px;transition:color .2s;position:relative}
.main-nav a:hover{color:var(--blue)}
.header-phone{font-weight:700;color:var(--ink);font-size:15px;display:flex;align-items:center;gap:6px}
.header-cta{display:flex;align-items:center;gap:16px}
.burger{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:26px;height:3px;background:var(--blue-dark);border-radius:2px}

/* ============ HERO ============ */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(circle at 85% 15%, rgba(255,169,64,.18) 0, transparent 35%),
    radial-gradient(circle at 10% 90%, rgba(165,107,255,.18) 0, transparent 30%),
    linear-gradient(135deg,#3A95FC 0%, #1E5BB8 100%);
  color:#fff;
  padding:90px 0 130px;
}
.hero-bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  pointer-events:none;
}
.hero-bg-rings::before,
.hero-bg-rings::after{
  content:'';position:absolute;
  border:1.5px solid rgba(255,255,255,.10);
  border-radius:50%;pointer-events:none;
}
.hero-bg-rings::before{width:700px;height:700px;left:-260px;top:-220px}
.hero-bg-rings::after{width:480px;height:480px;right:-140px;bottom:-180px}

.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 8px;border-radius:99px;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);
  font-size:13px;font-weight:600;
  margin-bottom:24px;
}
.hero-badge .dot{
  width:24px;height:24px;border-radius:50%;
  background:var(--orange);display:flex;align-items:center;justify-content:center;
  font-size:14px;
}
.hero-title{
  font-size:54px;font-weight:900;line-height:1.1;
  text-transform:uppercase;letter-spacing:-1px;
  margin-bottom:28px;
}
.hero-sub{
  font-size:19px;line-height:1.6;
  opacity:.92;max-width:540px;
  margin-bottom:32px;font-weight:500;
}
.hero-list{display:flex;flex-direction:column;gap:12px;margin-bottom:40px}
.hero-list li{
  position:relative;padding-left:32px;
  font-size:16px;font-weight:500;
}
.hero-list li::before{
  content:'';position:absolute;left:0;top:6px;
  width:18px;height:18px;background:var(--orange);
  border-radius:5px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z'/></svg>");
  background-size:14px;background-position:center;background-repeat:no-repeat;
}
.hero-cta-row{display:flex;gap:16px;margin-bottom:50px;flex-wrap:wrap}
.hero-trust{
  display:flex;gap:36px;padding-top:30px;
  border-top:1px solid rgba(255,255,255,.18);
}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-size:32px;font-weight:800;color:var(--orange);line-height:1}
.hero-trust span{font-size:13px;opacity:.85;margin-top:6px;font-weight:500}

/* ===== HERO ILLUSTRATION (composed) ===== */
.hero-illustration{position:relative;display:flex;justify-content:center;align-items:center;min-height:520px}
.hero-art-bg{
  position:absolute;width:480px;height:480px;
  background:radial-gradient(circle, rgba(255,255,255,.12) 0%, transparent 70%);
  border-radius:50%;
}
.hero-art-main{
  position:relative;width:100%;max-width:520px;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.25));
}
.float-card{
  position:absolute;background:#fff;color:var(--ink);
  border-radius:14px;padding:14px 18px;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
  display:flex;align-items:center;gap:12px;
  font-weight:600;font-size:14px;
  animation:float 6s ease-in-out infinite;
}
.float-card .ic{
  width:38px;height:38px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.float-card.fc1{top:8%;left:-20px;animation-delay:0s}
.float-card.fc1 .ic{background:var(--orange-soft);color:var(--orange-dark)}
.float-card.fc2{top:42%;right:-30px;animation-delay:1.5s}
.float-card.fc2 .ic{background:#E6FBEE;color:var(--green)}
.float-card.fc3{bottom:8%;left:10%;animation-delay:3s}
.float-card.fc3 .ic{background:var(--blue-soft);color:var(--blue-dark)}
.float-card small{display:block;color:var(--muted);font-weight:500;font-size:11px;margin-top:2px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ============ STRIP (логотипы/доверие) ============ */
.strip{background:#fff;padding:30px 0;border-bottom:1px solid var(--line)}
.strip-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.strip-label{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.strip-tags{display:flex;gap:14px;flex-wrap:wrap}
.strip-tag{
  padding:8px 16px;border-radius:99px;
  background:var(--bg-soft);color:var(--ink-2);
  font-size:13px;font-weight:600;
  border:1px solid var(--line);
}

/* ============ BENEFITS ============ */
.benefits{padding:80px 0 60px;background:#fff}
.benefits-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.benefit-card{
  background:#fff;border-radius:var(--radius);
  padding:30px 24px 28px;
  border:1px solid var(--line);
  transition:all .25s ease;
  position:relative;overflow:hidden;
}
.benefit-card::before{
  content:'';position:absolute;left:0;top:0;width:4px;height:0;
  background:var(--orange);transition:height .3s ease;
}
.benefit-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.benefit-card:hover::before{height:100%}
.benefit-icon{
  width:54px;height:54px;border-radius:14px;
  background:var(--blue-soft);display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.benefit-icon svg{width:30px;height:30px}
.benefit-card h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--ink)}
.benefit-card p{font-size:14px;color:var(--muted);line-height:1.55}

/* ============ SERVICES ============ */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.service-card{
  background:#fff;border-radius:var(--radius-lg);
  padding:32px 28px;
  border:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:all .3s ease;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card .sv-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px}
.service-card .sv-icon{
  width:64px;height:64px;border-radius:16px;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 24px rgba(47,141,251,.30);
}
.service-card .sv-icon svg{width:32px;height:32px;color:#fff}
.service-card.sc-orange .sv-icon{background:linear-gradient(135deg,var(--orange),var(--orange-dark));box-shadow:0 12px 24px rgba(255,138,0,.30)}
.service-card.sc-purple .sv-icon{background:linear-gradient(135deg,var(--purple),#7a3df7);box-shadow:0 12px 24px rgba(165,107,255,.30)}
.service-card.sc-green .sv-icon{background:linear-gradient(135deg,var(--green),#16a34a);box-shadow:0 12px 24px rgba(34,197,94,.30)}
.service-card.sc-pink .sv-icon{background:linear-gradient(135deg,var(--pink),#e63b78);box-shadow:0 12px 24px rgba(255,107,156,.30)}
.service-card .sv-tag{
  font-size:11px;font-weight:700;letter-spacing:.5px;
  padding:5px 10px;border-radius:99px;
  background:var(--orange-soft);color:var(--orange-dark);
  text-transform:uppercase;
}
.service-card h3{font-size:20px;font-weight:700;margin-bottom:10px;color:var(--ink)}
.service-card p{font-size:14.5px;color:var(--muted);line-height:1.6;margin-bottom:20px;flex:1}
.service-card .sv-meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:18px;border-top:1px dashed var(--line);
  font-size:13px;color:var(--ink-2);font-weight:600;
}
.service-card .sv-price{color:var(--blue-dark);font-weight:800}
.service-card ul{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.service-card ul li{position:relative;padding-left:22px;font-size:13.5px;color:var(--ink-2)}
.service-card ul li::before{
  content:'';position:absolute;left:0;top:6px;width:12px;height:12px;
  background:var(--orange);border-radius:3px;
}

/* ============ PAINS ============ */
.pains{
  background:linear-gradient(180deg, var(--bg-soft) 0%, #fff 100%);
}
.pains-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pain-card{
  background:#fff;border-radius:var(--radius);padding:28px 26px;
  border:1px solid var(--line);position:relative;
  transition:all .25s ease;
}
.pain-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#FFD2B0}
.pain-num{
  position:absolute;top:-18px;right:24px;
  width:48px;height:48px;border-radius:50%;
  background:#fff;border:3px solid var(--orange);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:var(--orange-dark);font-size:16px;
}
.pain-card .pain-emoji{font-size:32px;margin-bottom:14px;display:block}
.pain-card h3{font-size:17px;font-weight:700;margin-bottom:10px;color:var(--ink);padding-right:50px}
.pain-card p{font-size:14px;color:var(--muted);line-height:1.6}
.pain-arrow{
  display:flex;align-items:center;gap:10px;
  margin-top:16px;padding-top:14px;border-top:1px dashed var(--line);
  font-size:13px;font-weight:600;color:var(--blue-dark);
}
.pain-arrow b{color:var(--green)}

/* ============ SEGMENTS ============ */
.segments{background:var(--bg-deep);color:#fff;border-radius:32px;padding:80px 60px;margin:0 24px;position:relative;overflow:hidden}
.segments-wrap{padding:0;background:#fff}
.segments::before{
  content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  background:radial-gradient(circle, rgba(255,169,64,.20) 0%, transparent 70%);
}
.segments::after{
  content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;
  background:radial-gradient(circle, rgba(47,141,251,.20) 0%, transparent 70%);
}
.segments .section-title{color:#fff}
.segments .section-sub{color:rgba(255,255,255,.7)}
.segments-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:1}
.segment-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:28px;
  backdrop-filter:blur(10px);
  transition:all .25s ease;
}
.segment-card:hover{background:rgba(255,255,255,.12);transform:translateY(-4px);border-color:var(--orange)}
.segment-emoji{font-size:36px;margin-bottom:14px}
.segment-card h3{font-size:18px;font-weight:700;margin-bottom:10px;color:#fff}
.segment-card p{font-size:14px;color:rgba(255,255,255,.7);line-height:1.6}
.segment-card .seg-result{
  margin-top:16px;padding:10px 14px;border-radius:10px;
  background:rgba(255,169,64,.15);color:var(--orange);
  font-size:13px;font-weight:700;display:inline-block;
}

/* ============ PROCESS ============ */
.process-steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.process-steps::before{
  content:'';position:absolute;top:36px;left:8%;right:8%;height:2px;
  background:repeating-linear-gradient(90deg,var(--blue) 0,var(--blue) 6px,transparent 6px,transparent 12px);
  z-index:0;
}
.process-step{position:relative;text-align:center;padding-top:0}
.process-num{
  width:72px;height:72px;border-radius:50%;
  background:#fff;border:3px solid var(--blue);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:24px;color:var(--blue-dark);
  margin:0 auto 20px;position:relative;z-index:1;
  box-shadow:0 10px 24px rgba(47,141,251,.20);
}
.process-step.done .process-num{background:var(--blue);color:#fff}
.process-step h3{font-size:17px;font-weight:700;margin-bottom:8px;color:var(--ink)}
.process-step p{font-size:14px;color:var(--muted);line-height:1.55}
.process-step .step-time{
  display:inline-block;margin-top:10px;padding:4px 12px;
  border-radius:99px;background:var(--blue-soft);color:var(--blue-dark);
  font-size:12px;font-weight:700;
}

/* ============ CASES ============ */
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case-card{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--line);overflow:hidden;
  transition:all .3s ease;display:flex;flex-direction:column;
}
.case-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.case-cover{
  height:170px;
  background:linear-gradient(135deg,var(--blue) 0%, var(--blue-dark) 100%);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.case-cover.cv-2{background:linear-gradient(135deg,var(--orange) 0%, var(--orange-dark) 100%)}
.case-cover.cv-3{background:linear-gradient(135deg,var(--purple) 0%, #7a3df7 100%)}
.case-cover .cv-emoji{font-size:64px;filter:drop-shadow(0 6px 12px rgba(0,0,0,.2))}
.case-cover::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.15) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.1) 0%, transparent 40%);
}
.case-body{padding:26px 26px 28px;flex:1;display:flex;flex-direction:column}
.case-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.case-tag{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:5px 10px;border-radius:99px;
  background:var(--blue-soft);color:var(--blue-dark);
}
.case-card h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--ink);line-height:1.35}
.case-card .case-desc{font-size:14px;color:var(--muted);margin-bottom:20px;line-height:1.55}
.case-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px 0;border-top:1px solid var(--line);margin-bottom:18px}
.case-meta div{font-size:12px;color:var(--muted)}
.case-meta b{display:block;color:var(--ink);font-size:14px;margin-top:2px}
.case-metrics{display:flex;flex-direction:column;gap:14px}
.metric{display:flex;flex-direction:column;gap:6px}
.metric-label{font-size:13px;font-weight:700;color:var(--ink-2);display:flex;justify-content:space-between}
.metric-bars{display:grid;grid-template-columns:1fr 1fr;gap:6px;align-items:center}
.metric-bar{
  height:30px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;
  position:relative;
}
.metric-bar.was{background:#F1F4FA;color:var(--muted)}
.metric-bar.now{background:var(--blue);color:#fff;clip-path:polygon(0 0, calc(100% - 14px) 0, 100% 50%, calc(100% - 14px) 100%, 0 100%);padding-right:14px}
.metric-bar.now.green{background:var(--green)}
.metric-bar.now.orange{background:var(--orange)}
.metric-cap{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);font-weight:600}

/* ============ PRICING ============ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-card{
  background:#fff;border-radius:var(--radius-lg);
  padding:36px 32px 32px;
  border:2px solid var(--line);
  display:flex;flex-direction:column;
  position:relative;transition:all .3s ease;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.price-card.featured{
  border-color:var(--orange);
  background:linear-gradient(180deg,#fff 0%,#FFF8EC 100%);
  transform:scale(1.04);
  box-shadow:var(--shadow-lg);
}
.price-card.featured:hover{transform:scale(1.04) translateY(-6px)}
.price-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--orange);color:#fff;
  padding:6px 18px;border-radius:99px;
  font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  box-shadow:0 8px 18px rgba(255,138,0,.4);
}
.price-name{font-size:14px;font-weight:700;color:var(--blue-dark);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.price-amount{font-size:42px;font-weight:900;color:var(--ink);line-height:1;margin-bottom:4px}
.price-amount small{font-size:18px;color:var(--muted);font-weight:600}
.price-period{font-size:13px;color:var(--muted);margin-bottom:24px}
.price-desc{font-size:14px;color:var(--ink-2);margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.price-features{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;flex:1}
.price-features li{position:relative;padding-left:28px;font-size:14px;color:var(--ink-2);line-height:1.5}
.price-features li::before{
  content:'';position:absolute;left:0;top:4px;width:18px;height:18px;
  background:var(--blue-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232F8DFB'><path d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z'/></svg>") center/12px no-repeat;
  border-radius:5px;
}
.price-features li.muted{color:var(--muted);text-decoration:line-through}
.price-features li.muted::before{background:#F1F4FA url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23ccc'><path d='M19 13H5v-2h14v2z'/></svg>") center/12px no-repeat}
.price-features li.featured-line::before{background:var(--orange-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23FF8A00'><path d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z'/></svg>") center/12px no-repeat}
.price-card .btn{width:100%;justify-content:center}

/* ============ TESTIMONIALS ============ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{
  background:#fff;border-radius:var(--radius-lg);
  padding:32px 28px;border:1px solid var(--line);
  position:relative;transition:all .25s ease;
}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.testi-card::before{
  content:'"';position:absolute;top:14px;right:24px;
  font-size:80px;color:var(--blue-soft);font-family:Georgia,serif;
  line-height:1;font-weight:900;
}
.testi-stars{color:var(--orange);margin-bottom:14px;font-size:16px;letter-spacing:2px}
.testi-text{font-size:15px;color:var(--ink-2);line-height:1.65;margin-bottom:24px;position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line)}
.testi-avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:18px;flex-shrink:0;
}
.testi-avatar.av-2{background:linear-gradient(135deg,var(--orange),var(--orange-dark))}
.testi-avatar.av-3{background:linear-gradient(135deg,var(--purple),#7a3df7)}
.testi-info b{display:block;font-size:15px;color:var(--ink)}
.testi-info span{font-size:13px;color:var(--muted)}

/* ============ BLOG ============ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--line);overflow:hidden;
  transition:all .3s ease;display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.blog-cover{
  height:200px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blue) 0%, var(--blue-dark) 100%);
}
.blog-cover.bc-2{background:linear-gradient(135deg,var(--orange) 0%, var(--orange-dark) 100%)}
.blog-cover.bc-3{background:linear-gradient(135deg,var(--purple) 0%, #7a3df7 100%)}
.blog-cover::after{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 70% 30%, rgba(255,255,255,.18) 0%, transparent 40%),
    radial-gradient(circle at 20% 80%, rgba(0,0,0,.12) 0%, transparent 40%);
}
.blog-cover .bc-icon{font-size:70px;filter:drop-shadow(0 6px 12px rgba(0,0,0,.2));position:relative;z-index:1}
.blog-body{padding:24px 26px 28px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;gap:14px;font-size:12px;color:var(--muted);margin-bottom:12px;font-weight:600}
.blog-meta .blog-cat{
  padding:4px 10px;border-radius:99px;background:var(--blue-soft);color:var(--blue-dark);
  text-transform:uppercase;letter-spacing:.5px;
}
.blog-card h3{font-size:18px;font-weight:700;color:var(--ink);line-height:1.35;margin-bottom:10px;flex:1}
.blog-excerpt{font-size:14px;color:var(--muted);line-height:1.55;margin-bottom:18px}
.blog-link{
  font-size:14px;font-weight:700;color:var(--blue-dark);
  display:inline-flex;align-items:center;gap:6px;
  transition:gap .2s;
}
.blog-link:hover{gap:12px;color:var(--orange-dark)}

/* ============ FAQ ============ */
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:#fff;border-radius:14px;
  border:1px solid var(--line);
  overflow:hidden;transition:all .25s;
}
.faq-item[open]{border-color:var(--blue);box-shadow:var(--shadow-sm)}
.faq-item summary{
  padding:22px 26px;cursor:pointer;list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-weight:700;font-size:16px;color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';width:32px;height:32px;border-radius:50%;
  background:var(--blue-soft);color:var(--blue-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:600;flex-shrink:0;
  transition:all .25s;
}
.faq-item[open] summary::after{content:'−';background:var(--orange);color:#fff}
.faq-item .faq-body{padding:0 26px 24px;color:var(--ink-2);font-size:15px;line-height:1.65}

/* ============ CTA-FORM ============ */
.cta-form-section{
  background:linear-gradient(135deg,var(--blue) 0%, var(--blue-dark) 100%);
  position:relative;overflow:hidden;color:#fff;
}
.cta-form-section::before{
  content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;
  background:radial-gradient(circle, rgba(255,169,64,.15) 0%, transparent 70%);
}
.cta-form-section::after{
  content:'';position:absolute;bottom:-150px;left:-150px;width:500px;height:500px;
  background:radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 70%);
}
.cta-form-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.cta-form-content h2{font-size:38px;font-weight:800;line-height:1.2;margin-bottom:18px}
.cta-form-content p{font-size:17px;opacity:.92;margin-bottom:28px;line-height:1.6}
.cta-form-bullets{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.cta-form-bullets li{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500}
.cta-form-bullets li::before{
  content:'';width:24px;height:24px;border-radius:50%;
  background:var(--orange);flex-shrink:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z'/></svg>");
  background-size:16px;background-position:center;background-repeat:no-repeat;
}
.cta-form-card{
  background:#fff;color:var(--ink);
  border-radius:24px;padding:40px;
  box-shadow:0 30px 60px rgba(0,0,0,.25);
}
.cta-form-card h3{font-size:22px;font-weight:800;margin-bottom:8px}
.cta-form-card .cta-sub{font-size:14px;color:var(--muted);margin-bottom:24px}
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-field label{font-size:13px;font-weight:600;color:var(--ink-2)}
.form-field input,.form-field select,.form-field textarea{
  padding:14px 16px;border-radius:10px;
  border:1.5px solid var(--line);
  font-size:15px;font-family:inherit;color:var(--ink);
  transition:border-color .2s;
  background:#fff;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--blue);
}
.form-policy{font-size:12px;color:var(--muted);margin-top:14px;line-height:1.5;text-align:center}
.form-policy a{color:var(--blue-dark);text-decoration:underline}

/* ===== Мессенджеры (мини-CTA) ===== */
.msg-cta{
  background:linear-gradient(135deg,var(--blue) 0%, var(--blue-dark) 100%);
  color:#fff;padding:60px 0;position:relative;overflow:hidden;
}
.msg-cta::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 80% 20%, rgba(255,169,64,.18) 0%, transparent 40%),
    radial-gradient(circle at 20% 80%, rgba(255,255,255,.08) 0%, transparent 40%);
}
.msg-cta-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.msg-cta-text h3{font-size:26px;font-weight:800;margin-bottom:6px}
.msg-cta-text p{opacity:.85;font-size:15px}
.msg-buttons{display:flex;gap:14px;flex-wrap:wrap}
.msg-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;color:var(--ink);
  padding:14px 24px;border-radius:12px;
  font-weight:700;font-size:15px;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 8px 20px rgba(0,0,0,.15);
}
.msg-btn:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.22)}
.msg-btn-icon{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:14px;
}
.msg-btn-icon.tg{background:#229ED9}
.msg-btn-icon.wa{background:#25D366}
.msg-btn-icon.em{background:var(--orange)}

/* ============ FOOTER ============ */
.site-footer{
  background:var(--bg-deep);color:#fff;
  padding:70px 0 30px;
  position:relative;overflow:hidden;
}
.site-footer::before{
  content:'';position:absolute;top:-50px;right:-50px;width:300px;height:300px;
  background:radial-gradient(circle,rgba(47,141,251,.15) 0%, transparent 70%);
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;
  position:relative;z-index:1;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-brand .logo-light{color:#fff}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.6);margin:18px 0 24px;line-height:1.6;max-width:320px}
.footer-socials{display:flex;gap:10px}
.footer-soc{
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  color:#fff;transition:all .2s;
  font-size:14px;
}
.footer-soc:hover{background:var(--orange);transform:translateY(-3px)}
.footer-col h4{font-size:14px;font-weight:800;margin-bottom:18px;color:#fff;text-transform:uppercase;letter-spacing:1px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:14px;color:rgba(255,255,255,.65);transition:color .2s}
.footer-col ul a:hover{color:var(--orange)}
.footer-contacts li{font-size:14px;color:rgba(255,255,255,.7);display:flex;align-items:flex-start;gap:8px}
.footer-contacts li b{display:block;color:#fff;margin-bottom:2px;font-weight:700}
.footer-bottom{
  padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  position:relative;z-index:1;
  font-size:13px;color:rgba(255,255,255,.5);
}
.footer-bottom a{color:rgba(255,255,255,.7);text-decoration:underline}

/* ============ RESPONSIVE ============ */
@media (max-width:1080px){
  .services-grid,.pains-grid,.cases-grid,.segments-grid,.pricing-grid,.testi-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:40px}
  .process-steps::before{display:none}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .price-card.featured{transform:none}
  .price-card.featured:hover{transform:translateY(-6px)}
  .cta-form-inner{grid-template-columns:1fr;gap:40px}
}
@media (max-width:860px){
  .main-nav,.header-cta{display:none}
  .burger{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-illustration{order:1;min-height:320px;margin-top:8px}
  .hero-title{font-size:34px}
  .hero-sub{font-size:16px}
  .section{padding:70px 0}
  .section-title{font-size:30px}
  .float-card{font-size:12px;padding:10px 12px}
  .float-card .ic{width:32px;height:32px}
  .segments{padding:60px 24px;border-radius:20px}
}
@media (max-width:560px){
  .services-grid,.pains-grid,.cases-grid,.segments-grid,.benefits-grid,.process-steps,.pricing-grid,.testi-grid,.blog-grid,.footer-grid{grid-template-columns:1fr}
  .cta-form-card{padding:28px 22px}
  .cta-form-content h2{font-size:26px}
  .msg-cta-inner{flex-direction:column;text-align:center;align-items:center}
  .hero{padding:60px 0 80px}
  .hero-title{font-size:28px}
  .hero-trust{gap:18px;flex-wrap:wrap}
  .hero-trust b{font-size:22px}
  .btn{padding:14px 22px;font-size:14px}
}

/* ===== Telegram-link в footer ===== */
.footer-tg{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:10px;
  background:#229ED9;color:#fff;text-decoration:none;font-weight:600;font-size:14px;
  transition:background .15s ease, transform .15s ease;
}
.footer-tg:hover{background:#1d8bbf;transform:translateY(-1px)}
.footer-vk{background:#0077FF}
.footer-vk:hover{background:#0066DD}
.footer-tg svg{flex-shrink:0}

/* ===== intl-tel-input оверрайды ===== */
.iti{width:100%}
.iti--separate-dial-code .iti__selected-flag{
  background:#F4F8FF;border-radius:10px 0 0 10px;border-right:1px solid #E6ECF7;
}
.cta-form-card .iti input[type=tel]{
  width:100%;padding:14px 16px;border:1px solid #E6ECF7;border-radius:10px;
  font-family:inherit;font-size:15px;background:#F4F8FF;
}
.cta-form-card .iti input[type=tel]:focus{outline:none;border-color:#2F8DFB;background:#fff}
.field-error{
  display:block;margin-top:6px;color:#dc2626;font-size:13px;font-weight:500;min-height:18px;
}

/* ===== Popup ===== */
.popup-overlay{
  position:fixed;inset:0;background:rgba(15,27,61,.55);
  display:flex;align-items:center;justify-content:center;
  z-index:1000;padding:20px;
  opacity:0;transition:opacity .22s ease;
  backdrop-filter:blur(4px);
}
.popup-overlay.show{opacity:1}
.popup-card{
  background:#fff;border-radius:20px;padding:40px 36px 32px;
  max-width:420px;width:100%;text-align:center;position:relative;
  box-shadow:0 30px 80px rgba(15,27,61,.3);
  transform:translateY(20px) scale(.96);transition:transform .22s ease;
}
.popup-overlay.show .popup-card{transform:translateY(0) scale(1)}
.popup-icon{margin-bottom:16px}
.popup-card h3{font-size:22px;margin:0 0 10px;color:#0F1B3D;font-weight:700}
.popup-card p{margin:0 0 24px;color:#5A6B91;font-size:15px;line-height:1.5}
.popup-ok{min-width:140px;justify-content:center}
.popup-close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;
  border:none;background:#F4F8FF;color:#5A6B91;
  font-size:22px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s ease,color .15s ease;
}
.popup-close:hover{background:#E6ECF7;color:#0F1B3D}

/* ===== CF7 form overrides ===== */
.wpcf7-form .cta-form-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.wpcf7-form .form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.wpcf7-form .form-field label {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-2);
}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="tel"],
.wpcf7-form select {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid #E6ECF7;
  border-radius: 10px;
  font-family: inherit;
  font-size: 15px;
  background: #F4F8FF;
  color: var(--ink);
  transition: border-color .2s, background .2s;
  -webkit-appearance: none;
  appearance: none;
}
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form select:focus {
  outline: none;
  border-color: #2F8DFB;
  background: #fff;
}
.wpcf7-form input::placeholder {
  color: #a0aec0;
}
.wpcf7-form .wpcf7-submit {
  width: 100%;
  justify-content: center;
  padding: 16px 24px;
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-dark) 100%);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-family: inherit;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
  box-shadow: var(--shadow-orange);
}
.wpcf7-form .wpcf7-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(255,138,0,.45);
}
.wpcf7-form .wpcf7-not-valid-tip {
  color: #dc2626;
  font-size: 13px;
  font-weight: 500;
  margin-top: 4px;
}
.wpcf7-form .wpcf7-response-output {
  display: none !important;
}
/* intl-tel-input inside CF7 */
.wpcf7-form .iti { width: 100%; }
.wpcf7-form .iti--separate-dial-code .iti__selected-flag {
  background: #F4F8FF;
  border-radius: 10px 0 0 10px;
  border-right: 1px solid #E6ECF7;
}
.wpcf7-form .wpcf7-form-control-wrap[data-name="phone"] input[type="tel"] {
  padding-left: 80px;
}

/* === FIXES === */
#cta-form, #contacts {
  scroll-margin-top: 90px;
}
.cta-form-card {
  position: relative;
  z-index: 2;
}
.wpcf7-form input[type=text],
.wpcf7-form input[type=tel],
.wpcf7-form select {
  background: #ffffff !important;
  border: 1.5px solid #CBD5E1 !important;
  color: #0F1B3D !important;
  pointer-events: auto !important;
}
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form select:focus {
  border-color: #2F8DFB !important;
  box-shadow: 0 0 0 3px rgba(47,141,251,.15) !important;
  outline: none !important;
}
.cta-form-card .form-field label,
.cta-form-card label {
  color: #2B3A5C !important;
}

/* Fix: popup overlay must not block page when hidden */
.popup-overlay[hidden] {
  display: none !important;
}
/* Fix: allow text selection globally */
*, *::before, *::after {
  user-select: auto;
  -webkit-user-select: auto;
}

/* ======================================================
   BLOG — archive (home.php) & single (single.php)
   ====================================================== */

/* --- Blog Hero --- */
.blog-hero {
  background: linear-gradient(135deg, var(--blue-deep) 0%, var(--blue-dark) 100%);
  color: #fff;
  padding: 80px 0 64px;
  position: relative;
  overflow: hidden;
}
.blog-hero-bg {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}
.blog-hero .eyebrow {
  display: inline-block;
  background: rgba(255,169,64,.18);
  color: #FFD08A;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 99px;
  margin-bottom: 18px;
}
.blog-hero-title {
  font-size: 44px;
  font-weight: 900;
  line-height: 1.15;
  margin-bottom: 16px;
  position: relative;
}
.blog-hero-sub {
  font-size: 17px;
  opacity: .88;
  max-width: 560px;
  line-height: 1.6;
  position: relative;
}

/* --- Blog Grid --- */
.blog-archive { background: var(--bg-soft); }
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.blog-card {
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s;
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}
.blog-card-img-wrap { display: block; overflow: hidden; aspect-ratio: 16/9; }
.blog-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.blog-card:hover .blog-card-img { transform: scale(1.04); }
.blog-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; gap: 10px; }
.blog-card-meta { display: flex; align-items: center; gap: 12px; }
.blog-tag {
  font-size: 12px; font-weight: 700;
  color: var(--blue);
  background: var(--blue-soft);
  padding: 3px 10px; border-radius: 99px;
  text-transform: uppercase; letter-spacing: .04em;
}
.blog-date { font-size: 13px; color: var(--muted); }
.blog-card-title { font-size: 17px; font-weight: 700; line-height: 1.35; }
.blog-card-title a { color: var(--ink); }
.blog-card-title a:hover { color: var(--blue); }
.blog-card-excerpt { font-size: 14px; color: var(--ink-2); line-height: 1.6; flex: 1; }
.blog-read-more {
  font-size: 14px; font-weight: 700;
  color: var(--blue);
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 4px;
}
.blog-read-more:hover { color: var(--blue-dark); }

/* Empty state */
.blog-empty {
  text-align: center; padding: 80px 24px;
  font-size: 17px; color: var(--ink-2);
}
.blog-empty a { color: var(--blue); font-weight: 600; }

/* Pagination */
.blog-pagination { margin-top: 48px; display: flex; justify-content: center; }
.blog-pagination .nav-links { display: flex; gap: 8px; align-items: center; }
.blog-pagination .page-numbers {
  padding: 8px 16px; border-radius: 8px;
  font-size: 15px; font-weight: 600;
  color: var(--ink-2); background: #fff;
  border: 1px solid var(--line);
  transition: all .15s;
}
.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current {
  background: var(--blue); color: #fff; border-color: var(--blue);
}

/* --- Blog CTA strip --- */
.blog-cta-strip {
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color: #fff; padding: 60px 0;
}
.blog-cta-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap;
}
.blog-cta-inner h2 { font-size: 26px; font-weight: 800; margin-bottom: 6px; }
.blog-cta-inner p { font-size: 16px; opacity: .88; }

/* ======================================================
   SINGLE POST
   ====================================================== */

/* Post Hero */
.post-hero {
  background: linear-gradient(135deg, var(--blue-deep) 0%, var(--blue-dark) 100%);
  color: #fff; padding: 56px 0 48px;
}
.post-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; opacity: .75; margin-bottom: 20px;
}
.post-breadcrumb a { color: #fff; }
.post-breadcrumb a:hover { opacity: 1; }
.post-meta-top {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 20px;
}
.post-meta-top time,
.post-read-time { font-size: 14px; opacity: .8; }
.post-title {
  font-size: 40px; font-weight: 900; line-height: 1.15;
  max-width: 820px; margin-bottom: 20px;
}
.post-lead {
  font-size: 18px; line-height: 1.65; opacity: .9;
  max-width: 700px; margin-bottom: 32px;
}
.post-cover {
  margin-top: 40px; border-radius: 20px 20px 0 0; overflow: hidden;
  max-height: 440px;
}
.post-cover-img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Post Layout */
.post-body-wrap { background: #fff; padding: 60px 0; }
.post-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 56px;
  align-items: start;
}

/* Post Content Typography */
.post-content { font-size: 17px; line-height: 1.75; color: var(--ink); }
.post-content h2 {
  font-size: 26px; font-weight: 800; margin: 40px 0 16px;
  color: var(--ink); line-height: 1.3;
}
.post-content h3 {
  font-size: 20px; font-weight: 700; margin: 32px 0 12px; color: var(--ink);
}
.post-content p { margin-bottom: 20px; }
.post-content ul, .post-content ol {
  margin: 0 0 20px 24px;
}
.post-content li { margin-bottom: 8px; }
.post-content a { color: var(--blue); text-decoration: underline; }
.post-content a:hover { color: var(--blue-dark); }
.post-content blockquote {
  border-left: 4px solid var(--blue);
  background: var(--bg-soft);
  padding: 20px 24px; margin: 28px 0;
  border-radius: 0 12px 12px 0;
  font-size: 18px; font-style: italic; color: var(--ink-2);
}
.post-content img {
  border-radius: 12px; margin: 28px 0; max-width: 100%;
}
.post-content pre {
  background: var(--bg-deep); color: #e2e8f0;
  padding: 20px 24px; border-radius: 12px;
  overflow-x: auto; font-size: 14px; margin: 24px 0;
}
.post-content code {
  background: var(--bg-soft); padding: 2px 6px;
  border-radius: 4px; font-size: 14px; color: var(--blue-dark);
}
.post-content pre code { background: none; color: inherit; padding: 0; }
.post-content table {
  width: 100%; border-collapse: collapse; margin: 24px 0;
}
.post-content th, .post-content td {
  padding: 12px 16px; border: 1px solid var(--line);
  text-align: left; font-size: 15px;
}
.post-content th { background: var(--bg-soft); font-weight: 700; }

/* Post Tags */
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 40px 0 0; }
.post-tag {
  font-size: 13px; font-weight: 600;
  padding: 5px 12px; border-radius: 99px;
  border: 1px solid var(--line);
  color: var(--ink-2);
  transition: all .15s;
}
.post-tag:hover { background: var(--blue); color: #fff; border-color: var(--blue); }

/* Post Nav */
.post-nav {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; margin-top: 48px; padding-top: 32px;
  border-top: 1px solid var(--line);
}
.post-nav-item {
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 20px; border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  transition: all .15s;
}
.post-nav-item:hover { border-color: var(--blue); background: var(--blue-soft); }
.post-nav-next { text-align: right; }
.post-nav-label { font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
.post-nav-title { font-size: 15px; font-weight: 600; color: var(--ink); line-height: 1.4; }

/* Sidebar */
.post-sidebar { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 20px; }
.sidebar-card {
  background: var(--bg-soft); border-radius: var(--radius);
  padding: 24px; border: 1px solid var(--line);
}
.sidebar-author { display: flex; gap: 14px; align-items: flex-start; }
.sidebar-author-avatar {
  width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--blue), var(--blue-dark));
  color: #fff; font-size: 14px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
}
.sidebar-author strong { display: block; font-size: 15px; margin-bottom: 4px; color: var(--ink); }
.sidebar-author p { font-size: 13px; color: var(--muted); line-height: 1.5; }
.sidebar-cta { background: linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%); color: #fff; border: none; }
.sidebar-cta-title { font-size: 17px; font-weight: 800; margin-bottom: 8px; }
.sidebar-cta p { font-size: 14px; opacity: .88; line-height: 1.5; }
.sidebar-heading { font-size: 15px; font-weight: 700; margin-bottom: 14px; color: var(--ink); }
.sidebar-related { display: flex; flex-direction: column; gap: 12px; }
.sidebar-related li { display: flex; flex-direction: column; gap: 2px; }
.sidebar-related a { font-size: 14px; font-weight: 600; color: var(--ink); line-height: 1.4; }
.sidebar-related a:hover { color: var(--blue); }
.sidebar-related time { font-size: 12px; color: var(--muted); }

/* ======================================================
   RESPONSIVE
   ====================================================== */
@media (max-width: 1024px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .post-layout { grid-template-columns: 1fr; }
  .post-sidebar { position: static; }
  .post-title { font-size: 30px; }
  .blog-hero-title { font-size: 34px; }
}
@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
  .blog-hero-title { font-size: 26px; }
  .blog-cta-inner { flex-direction: column; text-align: center; }
  .post-nav { grid-template-columns: 1fr; }
  .post-title { font-size: 24px; }
  .post-hero { padding: 40px 0 36px; }
}

/* ======================================================
   AUDIT POPUP
   ====================================================== */
.popup-audit-card {
  max-width: 520px;
  padding: 44px 44px 36px;
}
.popup-audit-card h3 {
  font-size: 24px; font-weight: 800; color: var(--ink);
  margin-bottom: 8px;
}
.popup-audit-card .cta-sub {
  font-size: 15px; color: var(--ink-2); margin-bottom: 4px; line-height: 1.55;
}

/* CTA section teaser card */
.cta-form-card--teaser {
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.22);
  border-radius: 20px;
  padding: 44px 36px;
  display: flex; flex-direction: column;
  align-items: center; text-align: center; gap: 22px;
  color: #fff;
}
.cta-teaser-icon { display: flex; justify-content: center; }
.cta-form-card--teaser h3 {
  font-size: 26px; font-weight: 800; color: #fff; line-height: 1.25;
}
.cta-teaser-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 11px;
  width: 100%; text-align: left;
}
.cta-teaser-list li {
  padding-left: 26px; position: relative;
  font-size: 15px; color: rgba(255,255,255,.9);
}
.cta-teaser-list li::before {
  content: '✓'; position: absolute; left: 0;
  color: #FFA940; font-weight: 700;
}
.btn-white {
  background: #fff; color: var(--blue);
  font-weight: 700; border-radius: 10px;
  padding: 14px 28px; font-size: 15px;
  display: inline-block; transition: background .18s, color .18s;
  border: none; text-decoration: none;
}
.btn-white:hover { background: #E6F1FF; color: var(--blue-dark); }

/* ======================================================
   POLICY PAGE
   ====================================================== */
.policy-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 16px 0 60px;
}
.policy-content h1 { display: none; } /* заголовок уже в hero */
.policy-content .policy-meta {
  font-size: 14px; color: var(--muted); margin-bottom: 32px;
}

/* ======================================================
   MOBILE NAV DROPDOWN
   ====================================================== */
@media (max-width: 860px) {
  .main-nav.open {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: #fff;
    border-top: 1px solid var(--line);
    box-shadow: 0 12px 32px rgba(15,27,61,.12);
    z-index: 99;
    padding: 8px 0 16px;
  }
  .main-nav.open a {
    padding: 14px 24px;
    font-size: 16px;
    border-bottom: 1px solid var(--line);
    display: block;
  }
  .main-nav.open a:last-child { border-bottom: none; }
}
