/*
Theme Name: ПФ-НА.РФ
Theme URI: https://пф-на.рф/
Author: ПФ-НА.РФ
Author URI: https://пф-на.рф/
Description: Современная тема WordPress для сервиса улучшения поведенческих факторов Яндекс. Тема включает в себя стильный дизайн, адаптивную верстку, поддержку Elementor и функциональные формы обратной связи.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pf-na
Tags: elementor, custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ══════════════════════════════════════════
   RESET
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:#ffffff;
  color:#0f0f0f;
  font-family:'Montserrat',sans-serif;
  font-size:16px;
  line-height:1.5;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ══════════════════════════════════════════
   VARS
══════════════════════════════════════════ */
:root{
  --bg:#ffffff;
  --bg2:#f7f8fa;
  --bg3:#eef0f4;
  --white:#0f0f0f;
  --offwhite:#1a1a1a;
  --muted:#6b7280;
  --muted2:#9ca3af;
  --border:#e5e7eb;
  --border2:#d1d5db;
  --accent:#1d4ed8;
  --accent2:#2563eb;
  --green:#16a34a;
  --red:#dc2626;
}

/* ══════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════ */
.wrap{max-width:1320px;margin:0 auto;padding:0 40px}
@media(max-width:900px){.wrap{padding:0 20px}}

/* ══════════════════════════════════════════
   HEADER / NAV
══════════════════════════════════════════ */
header{
  position:fixed;top:0;left:0;right:0;z-index:500;
  background:rgba(255,255,255,.97);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(8px);
}
.nav{
  display:flex;align-items:center;
  height:72px;gap:0;
}
.nav-logo{
  font-size:20px;font-weight:900;letter-spacing:-.03em;
  color:var(--white);white-space:nowrap;
  padding-right:40px;border-right:1px solid var(--border);
  height:100%;display:flex;align-items:center;flex-shrink:0;
}
.nav-logo span{color:var(--accent)}
.nav-menu{
  display:flex;align-items:center;flex:1;height:100%;
}
.nav-menu a{
  height:100%;display:flex;align-items:center;
  padding:0 20px;font-size:13px;font-weight:600;
  color:var(--muted);border-right:1px solid var(--border);
  transition:color .2s,background .2s;white-space:nowrap;
}
.nav-menu a:hover{color:var(--accent);background:rgba(29,78,216,.05)}
.nav-contact{
  display:flex;align-items:center;margin-left:auto;height:100%;
  border-left:1px solid var(--border);
}
.nav-phone{
  padding:0 28px;display:flex;flex-direction:column;justify-content:center;
  border-right:1px solid var(--border);height:100%;gap:3px;
}
.nav-phone a{font-size:15px;font-weight:800;color:var(--white);letter-spacing:-.01em}
.nav-phone span{font-size:10px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.08em}
.nav-email{
  padding:0 24px;height:100%;display:flex;align-items:center;
  border-right:1px solid var(--border);
}
.nav-email a{font-size:12px;color:var(--muted);font-weight:500}
.nav-email a:hover{color:#0f0f0f}
.nav-cta{
  height:100%;padding:0 32px;
  background:var(--accent);
  font-size:13px;font-weight:800;color:#fff;
  display:flex;align-items:center;letter-spacing:.01em;
  transition:background .2s;white-space:nowrap;
}
.nav-cta:hover{background:var(--accent2)}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero{
  padding-top:72px;
  border-bottom:1px solid var(--border);
}

/* top stripe — заголовок + фото */
.hero-main{
  display:grid;
  grid-template-columns:1fr 520px;
  border-bottom:1px solid var(--border);
  min-height:500px;
}
.hero-left{
  padding:64px 56px 56px 0;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;justify-content:space-between;
}
.hero-pre{
  font-size:11px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-bottom:28px;
}
.hero h1{
  font-size:clamp(36px,5.2vw,72px);
  font-weight:900;line-height:1.04;
  letter-spacing:-.04em;
  margin-bottom:32px;
}
.hero h1 em{
  font-style:italic;color:var(--accent);
}
.hero-sub{
  font-size:clamp(22px,2.8vw,38px);
  font-weight:800;line-height:1.15;
  letter-spacing:-.025em;
  color:var(--white);
  margin-bottom:40px;
}
.hero-tezisy{
  display:flex;flex-direction:column;gap:10px;
  margin-bottom:44px;
}
.hero-tezis{
  font-size:10px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:10px;
}
.hero-tezis::before{
  content:'';width:4px;height:4px;border-radius:50%;
  background:var(--accent);flex-shrink:0;
}
.hero-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:#0f0f0f;color:#ffffff;
  font-size:13px;font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;padding:18px 36px;
  transition:background .2s,color .2s;width:fit-content;
  border:none;cursor:pointer;
}
.hero-btn:hover{background:var(--accent);color:#ffffff}
.hero-btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:var(--muted);
  font-size:13px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;padding:18px 36px;
  border:1px solid var(--border2);
  transition:color .2s,border-color .2s;
  cursor:pointer;
}
.hero-btn-ghost:hover{color:#0f0f0f;border-color:#6b7280}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* hero right — фото + badges */
.hero-right{
  background:var(--bg2);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.hero-photo-wrap{
  flex:1;
  background:var(--bg3);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.hero-photo-placeholder{
  width:100%;height:100%;color:#6b7280;
  background:linear-gradient(135deg,#dbeafe 0%,#eff6ff 50%,#dbeafe 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted2);
  flex-direction:column;gap:12px;
}
.hero-photo-placeholder .big-num{
  font-size:clamp(64px,9vw,120px);font-weight:900;
  color:rgba(29,78,216,.18);letter-spacing:-.06em;line-height:1;
}
.hero-photo-stats{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--border);
}
.hero-stat{
  padding:24px 28px;border-right:1px solid var(--border);
}
.hero-stat:last-child{border-right:none}
.hero-stat-val{
  font-size:clamp(22px,2.5vw,32px);font-weight:900;
  letter-spacing:-.03em;color:var(--white);line-height:1;margin-bottom:4px;
}
.hero-stat-lbl{
  font-size:10px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
}

/* hero bottom stripe — 3 колонки */
.hero-bottom{
  display:grid;grid-template-columns:repeat(3,1fr);
}
.hero-bottom-item{
  padding:28px 40px;border-right:1px solid var(--border);
  font-size:10px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);
  line-height:1.7;
}
.hero-bottom-item:last-child{border-right:none}
.hero-bottom-item strong{
  display:block;font-size:13px;color:var(--white);
  margin-bottom:6px;letter-spacing:-.01em;text-transform:none;
  font-weight:800;
}

/* ══════════════════════════════════════════
   MARQUEE
══════════════════════════════════════════ */
.marquee-wrap{
  overflow:hidden;border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.marquee-inner{
  display:flex;white-space:nowrap;
  animation:mq 32s linear infinite;
}
@keyframes mq{to{transform:translateX(-50%)}}
.marquee-inner:hover{animation-play-state:paused}
.mq-item{
  display:inline-flex;align-items:center;gap:20px;
  padding:14px 36px;font-size:11px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  border-right:1px solid var(--border);flex-shrink:0;
}
.mq-dot{color:var(--accent);font-size:18px;line-height:0}

/* ══════════════════════════════════════════
   SECTIONS — общие стили
══════════════════════════════════════════ */
.sec{
  padding:96px 0;
  border-bottom:1px solid var(--border);
}
.sec-dark{background:var(--bg2)}
.sec-label{
  font-size:10px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:20px;display:block;
}
.sec-title{
  font-size:clamp(26px,3.8vw,52px);
  font-weight:900;line-height:1.1;
  letter-spacing:-.035em;margin-bottom:16px;
}
.sec-title em{font-style:italic;color:var(--accent)}
.sec-title strong{color:var(--white)}
.sec-head{
  display:grid;grid-template-columns:1fr 1fr;
  gap:48px;margin-bottom:64px;align-items:start;
}
.sec-head-desc{
  font-size:15px;color:var(--muted);line-height:1.75;
  padding-top:8px;
}

/* ══════════════════════════════════════════
   SECTION: ЧТО РЕШАЕМ (4 колонки)
══════════════════════════════════════════ */
.tasks-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.task-card{
  padding:40px 32px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background .25s;
}
.task-card:hover{background:rgba(29,78,216,.04)}
.task-n{
  font-size:10px;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted2);margin-bottom:20px;
}
.task-title{
  font-size:17px;font-weight:800;line-height:1.3;
  letter-spacing:-.02em;margin-bottom:14px;
}
.task-desc{
  font-size:13px;color:var(--muted);line-height:1.7;
  margin-bottom:20px;
}
.task-result{
  font-size:11px;font-weight:800;color:var(--green);
  letter-spacing:.06em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.task-result::before{content:'↑';font-size:14px}

/* ══════════════════════════════════════════
   SECTION: КАК РАБОТАЕМ (5 шагов)
══════════════════════════════════════════ */
.steps-row{
  display:grid;grid-template-columns:repeat(5,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.step-item{
  padding:40px 28px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;
}
.step-num{
  font-size:48px;font-weight:900;color:rgba(0,0,0,.06);
  line-height:1;letter-spacing:-.04em;
  margin-bottom:16px;
}
.step-title{
  font-size:14px;font-weight:800;letter-spacing:-.01em;
  margin-bottom:10px;
}
.step-desc{font-size:12px;color:var(--muted);line-height:1.7}
.step-time{
  margin-top:16px;font-size:10px;font-weight:800;
  color:var(--accent);letter-spacing:.08em;text-transform:uppercase;
}

/* ══════════════════════════════════════════
   SECTION: РЕЗУЛЬТАТЫ (numbered rows)
══════════════════════════════════════════ */
.results-list{}
.res-row{
  display:grid;grid-template-columns:72px 1fr 220px;
  gap:0;border-top:1px solid var(--border);
  transition:background .2s;
}
.res-row:last-child{border-bottom:1px solid var(--border)}
.res-row:hover{background:rgba(0,0,0,.02)}
.res-n{
  padding:40px 28px;
  font-size:11px;font-weight:800;color:var(--muted2);
  letter-spacing:.12em;text-transform:uppercase;
  border-right:1px solid var(--border);
  display:flex;align-items:flex-start;padding-top:44px;
}
.res-body{
  padding:40px 48px;border-right:1px solid var(--border);
}
.res-title{
  font-size:20px;font-weight:800;letter-spacing:-.025em;
  margin-bottom:10px;
}
.res-desc{font-size:13px;color:var(--muted);line-height:1.7;max-width:560px}
.res-tag{
  padding:40px 32px;display:flex;align-items:flex-start;padding-top:44px;
}
.res-badge{
  display:inline-block;
  background:rgba(29,78,216,.08);
  border:1px solid rgba(29,78,216,.2);
  color:var(--accent2);
  font-size:12px;font-weight:800;letter-spacing:.04em;
  padding:10px 20px;
}

/* ══════════════════════════════════════════
   CTA-БАННЕР
══════════════════════════════════════════ */
.cta-banner{
  background:#eff6ff;border:1px solid #bfdbfe;
  padding:48px 56px;
  display:flex;align-items:center;justify-content:space-between;
  gap:32px;flex-wrap:wrap;
  margin-top:56px;
}
.cta-b-text h3{
  font-size:clamp(20px,2.5vw,30px);font-weight:900;
  letter-spacing:-.025em;margin-bottom:8px;
}
.cta-b-text p{font-size:14px;color:var(--muted);max-width:480px}
.cta-b-right{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.discount-pill{
  background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.25);
  color:var(--green);font-size:13px;font-weight:800;
  padding:12px 24px;letter-spacing:.04em;
}

/* ══════════════════════════════════════════
   SECTION: ПРОБЛЕМЫ (3 кол)
══════════════════════════════════════════ */
.problems-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.prob-card{
  padding:40px 36px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background .25s;
}
.prob-card:hover{background:rgba(0,0,0,.02)}
.prob-title{
  font-size:16px;font-weight:800;letter-spacing:-.015em;
  margin-bottom:14px;
}
.prob-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:20px}
.prob-solve{
  font-size:11px;font-weight:800;color:var(--green);
  text-transform:uppercase;letter-spacing:.08em;
  display:flex;gap:8px;
}
.prob-solve::before{content:'✓'}

/* ══════════════════════════════════════════
   SECTION: ПРЕИМУЩЕСТВА (список строк)
══════════════════════════════════════════ */
.adv-table{border-top:1px solid var(--border)}
.adv-tr{
  display:grid;grid-template-columns:64px 280px 1fr 180px;
  border-bottom:1px solid var(--border);
  transition:background .2s;
}
.adv-tr:hover{background:rgba(0,0,0,.02)}
.adv-td{padding:36px 32px;border-right:1px solid var(--border)}
.adv-td:last-child{border-right:none;display:flex;align-items:center}
.adv-num{
  font-size:12px;font-weight:800;color:var(--muted2);
  letter-spacing:.12em;text-transform:uppercase;
  display:flex;align-items:center;
}
.adv-title{
  font-size:16px;font-weight:800;letter-spacing:-.01em;
  display:flex;align-items:center;
}
.adv-desc{font-size:13px;color:var(--muted);line-height:1.7;display:flex;align-items:center}
.adv-cta-link{
  font-size:11px;font-weight:800;color:var(--accent);
  letter-spacing:.08em;text-transform:uppercase;
  transition:color .2s;
}
.adv-cta-link:hover{color:#0f0f0f}

/* ══════════════════════════════════════════
   SECTION: КЕЙСЫ
══════════════════════════════════════════ */
.cases-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.case-card{
  padding:36px 32px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background .25s;
}
.case-card:hover{background:rgba(0,0,0,.02)}
.case-niche{
  font-size:10px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted2);margin-bottom:6px;
}
.case-name{
  font-size:22px;font-weight:900;letter-spacing:-.03em;margin-bottom:4px;
}
.case-period{font-size:12px;color:var(--muted);margin-bottom:24px}
.case-task{margin-bottom:16px}
.case-task strong{
  font-size:10px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted2);display:block;margin-bottom:6px;
}
.case-task p{font-size:13px;color:var(--muted);line-height:1.6}
.case-result{}
.case-result em{
  font-size:10px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent2);font-style:normal;
  display:block;margin-bottom:8px;
}
.case-result p{
  font-size:13px;font-weight:700;line-height:1.6;color:var(--white);
}
.case-metrics{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.case-metric{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:8px;border-top:1px solid var(--border);
}
.case-metric-lbl{font-size:12px;color:var(--muted)}
.case-metric-val{font-size:14px;font-weight:900;color:var(--green);letter-spacing:-.01em}

/* ══════════════════════════════════════════
   SECTION: ОПАСЕНИЯ / FAQ
══════════════════════════════════════════ */
.fears-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.fear-card{
  padding:44px 40px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.fear-q{
  font-size:18px;font-weight:800;letter-spacing:-.02em;
  line-height:1.3;margin-bottom:16px;
}
.fear-a{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:20px}
.fear-verdict{
  font-size:11px;font-weight:800;color:var(--green);
  letter-spacing:.08em;text-transform:uppercase;
  display:flex;gap:8px;align-items:center;
}
.fear-verdict::before{content:'✓';opacity:.7}

/* ══════════════════════════════════════════
   SECTION: ЧТО ПОЛУЧИТЕ ЗА 7 ДНЕЙ
══════════════════════════════════════════ */
.get-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.get-card{
  padding:40px 36px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.get-num{
  font-size:10px;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted2);margin-bottom:16px;
}
.get-title{font-size:16px;font-weight:800;letter-spacing:-.015em;margin-bottom:10px}
.get-desc{font-size:13px;color:var(--muted);line-height:1.7}

/* ══════════════════════════════════════════
   SECTION: ПАКЕТЫ
══════════════════════════════════════════ */
.packages-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.pkg{
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;
}
.pkg-head{padding:36px 36px 28px;border-bottom:1px solid var(--border)}
.pkg.featured .pkg-head{background:rgba(29,78,216,.05)}
.pkg-badge{
  display:inline-block;
  background:var(--accent);color:#fff;
  font-size:9px;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;padding:5px 12px;
  margin-bottom:16px;
}
.pkg-name{font-size:22px;font-weight:900;letter-spacing:-.02em;margin-bottom:6px}
.pkg-sub{font-size:12px;color:var(--muted);margin-bottom:20px}
.pkg-price{
  font-size:clamp(28px,3vw,42px);font-weight:900;
  letter-spacing:-.04em;line-height:1;
}
.pkg-price span{font-size:14px;color:var(--muted);font-weight:500;letter-spacing:0}
.pkg-body{padding:28px 36px;flex:1;border-bottom:1px solid var(--border)}
.pkg-features{display:flex;flex-direction:column;gap:10px}
.pkg-feature{
  font-size:13px;color:var(--muted);
  display:flex;gap:10px;line-height:1.5;
}
.pkg-feature::before{content:'—';color:var(--accent);flex-shrink:0}
.pkg-foot{padding:24px 36px}
.pkg-cta{
  display:block;width:100%;padding:16px;
  font-size:12px;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;text-align:center;
  border:none;cursor:pointer;transition:all .2s;
}
.pkg-cta-white{background:#0f0f0f;color:#ffffff}
.pkg-cta-white:hover{background:var(--accent);color:#ffffff}
.pkg-cta-outline{
  background:transparent;color:var(--muted);
  border:1px solid var(--border2);
}
.pkg-cta-outline:hover{color:var(--white);border-color:var(--muted)}

/* ══════════════════════════════════════════
   CONTACT FORM
══════════════════════════════════════════ */
.contact-sec{
  padding:96px 0;border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}
.contact-left h2{
  font-size:clamp(28px,4vw,52px);font-weight:900;
  letter-spacing:-.04em;line-height:1.1;margin-bottom:20px;
}
.contact-left h2 em{font-style:italic;color:var(--accent)}
.contact-left p{
  font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:32px;
}
.contact-promises{display:flex;flex-direction:column;gap:14px}
.contact-promise{
  display:flex;gap:14px;font-size:14px;color:var(--muted);line-height:1.5;
}
.contact-promise::before{
  content:'→';color:var(--accent2);flex-shrink:0;font-weight:800;
}
.contact-promise strong{color:var(--white)}

.form-box{
  background:#f7f8fa;
  border:1px solid var(--border2);
  padding:44px;
}
.form-box-title{font-size:20px;font-weight:900;letter-spacing:-.02em;margin-bottom:6px}
.form-box-sub{font-size:13px;color:var(--muted);margin-bottom:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.form-group label{
  font-size:9px;font-weight:800;text-transform:uppercase;
  letter-spacing:.16em;color:var(--muted2);
}
.form-group input,
.form-group select,
.form-group textarea{
  background:#ffffff;
  border:1px solid var(--border2);color:var(--white);
  padding:14px 16px;font-size:14px;font-family:'Montserrat',sans-serif;
  outline:none;width:100%;border-radius:0;transition:border-color .2s;
  -webkit-appearance:none;
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--muted2)}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--accent)}
.form-group textarea{min-height:90px;resize:vertical}
.form-group select{cursor:pointer}
.form-group select option{background:#ffffff;color:#0f0f0f}
.form-submit{
  width:100%;padding:20px;
  background:#0f0f0f;color:#ffffff;
  font-size:12px;font-weight:900;letter-spacing:.1em;
  text-transform:uppercase;border:none;cursor:pointer;
  font-family:'Montserrat',sans-serif;
  transition:background .2s,color .2s;margin-top:4px;
}
.form-submit:hover{background:var(--accent);color:#fff}
.form-note{
  font-size:11px;color:var(--muted2);margin-top:14px;
  text-align:center;line-height:1.5;
}
.form-note a{color:var(--muted2);border-bottom:1px solid var(--border2)}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
footer{background:#f7f8fa;border-top:1px solid var(--border)}
.footer-main{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  border-bottom:1px solid var(--border);
}
.footer-col{
  padding:48px 36px;border-right:1px solid var(--border);
}
.footer-col:last-child{border-right:none}
.footer-logo{
  font-size:22px;font-weight:900;letter-spacing:-.03em;margin-bottom:14px;
}
.footer-logo span{color:var(--accent)}
.footer-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:24px}
.footer-contacts a{
  display:block;font-size:13px;color:var(--muted);
  margin-bottom:7px;transition:color .2s;
}
.footer-contacts a:hover{color:#0f0f0f}
.footer-col h4{
  font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.14em;color:var(--muted2);margin-bottom:20px;
}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:13px;color:var(--muted);transition:color .2s}
.footer-col ul a:hover{color:#0f0f0f}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 36px;flex-wrap:wrap;gap:10px;
  font-size:11px;color:var(--muted2);
}
.footer-bottom a{color:var(--muted2);transition:color .2s}
.footer-bottom a:hover{color:#374151}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1100px){
  .tasks-grid{grid-template-columns:repeat(2,1fr)}
  .steps-row{grid-template-columns:repeat(3,1fr)}
  .adv-tr{grid-template-columns:52px 220px 1fr}
  .adv-tr .adv-td:last-child{display:none}
  .footer-main{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .nav-menu{display:none}
  .hero-main{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:56px 0 44px}
  .hero-bottom{grid-template-columns:1fr}
  .hero-bottom-item{border-right:none;border-bottom:1px solid var(--border)}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .fears-grid{grid-template-columns:1fr}
  .fear-card{border-right:none}
  .packages-grid{grid-template-columns:1fr}
  .pkg{border-right:none}
  .res-row{grid-template-columns:52px 1fr}
  .res-tag{display:none}
}
@media(max-width:700px){
  .tasks-grid,.problems-grid,.get-grid,.cases-grid{grid-template-columns:1fr}
  .task-card,.prob-card,.get-card,.case-card{border-right:none}
  .steps-row{grid-template-columns:1fr 1fr}
  .step-item{border-right:none}
  .step-item:nth-child(odd){border-right:1px solid var(--border)}
  .adv-tr{grid-template-columns:1fr}
  .adv-td{border-right:none;padding:20px 24px}
  .adv-num,.adv-cta-link{display:none}
  .form-row{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr}
  .footer-col{border-right:none}
  .sec-head{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideInUp {
  from {
    transform: translateY(30px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes slideInLeft {
  from {
    transform: translateX(-30px);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(30px);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

/* Применение анимаций */
.hero h1, .hero-sub, .sec-title {
  animation: slideInUp 0.8s ease-out forwards;
}

.hero-tezisy, .hero-actions {
  animation: fadeIn 1s ease-out 0.3s forwards;
  opacity: 0;
  animation-fill-mode: forwards;
}

.task-card, .step-item, .prob-card, .fear-card, .get-card, .case-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.task-card:hover, .prob-card:hover, .get-card:hover, .case-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}

.hero-btn, .nav-cta, .pkg-cta-white {
  transition: all 0.3s ease;
}

.hero-btn:hover, .nav-cta:hover, .pkg-cta-white:hover {
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(29,78,216,0.2);
}

/* Анимация для элементов при прокрутке */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.animate-on-scroll.animated {
  opacity: 1;
  transform: translateY(0);
}

/* Elementor совместимые стили */
.elementor-section {
  position: relative;
}

.elementor-widget {
  margin-bottom: 20px;
}

.elementor-column {
  position: relative;
  min-height: 1px;
  display: flex;
}

/* Inner templates */
.site-main-inner {
  padding-top: 72px;
}

.inner-hero {
  padding: 64px 0 36px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(239,246,255,.8) 0%, rgba(255,255,255,1) 100%);
}

.inner-meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}

.inner-meta span {
  padding: 8px 12px;
  border: 1px solid var(--border);
  background: #fff;
}

.posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
}

.post-card {
  padding: 36px 32px;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: #fff;
  transition: background .25s, transform .25s, box-shadow .25s;
}

.post-card:hover {
  background: rgba(29,78,216,.03);
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(15,15,15,.05);
}

.post-card .hero-btn-ghost {
  margin-top: 18px;
}

.content-shell {
  max-width: 920px;
  margin: 0 auto;
  padding: 40px 48px;
  border: 1px solid var(--border);
  background: #fff;
}

.content-shell-empty {
  text-align: center;
}

.content-thumbnail {
  margin-bottom: 32px;
  border: 1px solid var(--border);
  overflow: hidden;
}

.content-thumbnail img {
  width: 100%;
  height: auto;
}

.content-prose {
  font-size: 16px;
  line-height: 1.85;
  color: var(--offwhite);
}

.content-prose > * + * {
  margin-top: 1.2em;
}

.content-prose h2,
.content-prose h3,
.content-prose h4 {
  line-height: 1.2;
  letter-spacing: -.02em;
  color: var(--white);
}

.content-prose h2 {
  font-size: 30px;
}

.content-prose h3 {
  font-size: 24px;
}

.content-prose ul,
.content-prose ol {
  padding-left: 1.4em;
}

.content-prose ul {
  list-style: disc;
}

.content-prose ol {
  list-style: decimal;
}

.content-prose a {
  color: var(--accent);
}

.content-prose blockquote {
  padding: 20px 24px;
  border-left: 3px solid var(--accent);
  background: var(--bg2);
}

.content-prose table {
  width: 100%;
  border-collapse: collapse;
}

.content-prose th,
.content-prose td {
  padding: 12px 14px;
  border: 1px solid var(--border);
  text-align: left;
}

.entry-footer-meta {
  display: flex;
  gap: 12px 20px;
  flex-wrap: wrap;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  color: var(--muted);
}

.entry-footer-meta a {
  color: var(--accent);
}

.post-navigation,
.posts-pagination,
.comments-shell {
  max-width: 920px;
  margin: 28px auto 0;
}

.post-navigation .nav-links,
.posts-pagination .nav-links {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.post-navigation a,
.posts-pagination a,
.posts-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 10px 18px;
  border: 1px solid var(--border);
  color: var(--muted);
  background: #fff;
}

.posts-pagination .current {
  border-color: var(--accent);
  color: var(--accent);
}

.search-form {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: 20px;
}

.search-field {
  min-width: 280px;
  padding: 14px 16px;
  border: 1px solid var(--border2);
}

.search-submit {
  padding: 14px 20px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-weight: 800;
  text-transform: uppercase;
  cursor: pointer;
}

input.error,
textarea.error,
select.error {
  border-color: var(--red);
}

@media(max-width:1100px) {
  .posts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media(max-width:900px) {
  .content-shell {
    padding: 28px 24px;
  }

  .post-navigation .nav-links,
  .posts-pagination .nav-links,
  .search-form {
    flex-direction: column;
  }
}

@media(max-width:700px) {
  .posts-grid {
    grid-template-columns: 1fr;
  }

  .post-card {
    border-right: none;
  }

  .search-field {
    min-width: 0;
    width: 100%;
  }
}

/* Typography tuning: improve readability, especially on mobile */
.hero-sub {
  font-size: clamp(24px, 3vw, 42px);
}

.hero-tezis,
.sec-label,
.task-n,
.get-num,
.case-niche,
.footer-col h4 {
  font-size: 11px;
}

.sec-title {
  font-size: clamp(30px, 4.2vw, 58px);
}

.sec-head-desc,
.contact-left p,
.footer-desc,
.footer-contacts a,
.footer-col ul a {
  font-size: 16px;
}

.task-title,
.prob-title,
.get-title,
.adv-title {
  font-size: 18px;
}

.task-desc,
.prob-desc,
.get-desc,
.adv-desc,
.case-task p,
.case-result p,
.fear-a,
.pkg-feature,
.form-box-sub {
  font-size: 15px;
}

.fear-q,
.form-box-title {
  font-size: 22px;
}

.pkg-name,
.case-name,
.res-title {
  font-size: 24px;
}

.pkg-sub,
.case-period,
.case-metric-lbl,
.form-note,
.form-submit,
.footer-bottom,
.contact-promise {
  font-size: 13px;
}

.form-group label {
  font-size: 10px;
}

.form-group input,
.form-group select,
.form-group textarea {
  font-size: 15px;
}

@media(max-width:900px) {
  .hero h1 {
    font-size: clamp(42px, 9vw, 64px);
  }

  .hero-sub {
    font-size: clamp(26px, 5.8vw, 36px);
  }

  .sec-title,
  .contact-left h2 {
    font-size: clamp(32px, 7vw, 46px);
  }

  .sec-head-desc,
  .contact-left p,
  .task-desc,
  .prob-desc,
  .fear-a,
  .get-desc,
  .adv-desc,
  .pkg-feature,
  .case-task p,
  .case-result p,
  .footer-desc,
  .footer-contacts a,
  .footer-col ul a,
  .content-prose {
    font-size: 16px;
    line-height: 1.8;
  }

  .task-title,
  .prob-title,
  .get-title,
  .adv-title,
  .fear-q,
  .form-box-title {
    font-size: 20px;
  }

  .pkg-name,
  .case-name,
  .res-title {
    font-size: 26px;
  }

  .form-group input,
  .form-group select,
  .form-group textarea,
  .search-field {
    font-size: 16px;
  }
}

@media(max-width:700px) {
  body {
    font-size: 17px;
  }

  .hero-left {
    padding: 44px 0 36px;
  }

  .hero h1 {
    font-size: clamp(44px, 11vw, 56px);
    line-height: 1.05;
  }

  .hero-sub {
    font-size: 28px;
    line-height: 1.2;
  }

  .hero-tezis,
  .sec-label,
  .task-n,
  .get-num,
  .case-niche,
  .footer-col h4 {
    font-size: 12px;
  }

  .sec-title,
  .contact-left h2 {
    font-size: 34px;
    line-height: 1.12;
  }

  .sec-head-desc,
  .contact-left p,
  .task-desc,
  .prob-desc,
  .fear-a,
  .get-desc,
  .adv-desc,
  .pkg-feature,
  .case-task p,
  .case-result p,
  .footer-desc,
  .footer-contacts a,
  .footer-col ul a,
  .content-prose,
  .form-box-sub,
  .contact-promise {
    font-size: 17px;
    line-height: 1.8;
  }

  .task-title,
  .prob-title,
  .get-title,
  .adv-title,
  .fear-q,
  .form-box-title {
    font-size: 22px;
    line-height: 1.35;
  }

  .pkg-name,
  .case-name,
  .res-title {
    font-size: 28px;
  }

  .pkg-sub,
  .case-period,
  .case-metric-lbl,
  .form-note,
  .form-submit,
  .footer-bottom {
    font-size: 14px;
  }

  .hero-btn,
  .hero-btn-ghost,
  .pkg-cta,
  .nav-cta {
    font-size: 14px;
  }

  .form-box,
  .task-card,
  .prob-card,
  .get-card,
  .case-card,
  .fear-card,
  .pkg-head,
  .pkg-body,
  .pkg-foot,
  .res-body,
  .hero-bottom-item,
  .footer-col {
    padding-left: 24px;
    padding-right: 24px;
  }

  .form-group input,
  .form-group select,
  .form-group textarea,
  .search-field {
    font-size: 16px;
    padding: 16px;
  }
}

/* Logo dot accent */
.nav-logo span,
.footer-logo span {
  color: var(--accent) !important;
  display: inline-block;
  animation: pfLogoDotBlink 1s linear infinite !important;
}

@keyframes pfLogoDotBlink {
  0%, 42%, 100% {
    opacity: 1;
    text-shadow: 0 0 12px rgba(37,99,235,.4);
  }
  50%, 92% {
    opacity: 0;
    text-shadow: none;
  }
}

/* Contact Form 7 styling */
.pf-na-cf7 .wpcf7-form {
  display: block;
}

.pf-na-cf7 .wpcf7-form p {
  margin: 0;
}

.pf-na-cf7 .wpcf7-form br {
  display: none;
}

.pf-na-cf7 .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.pf-na-cf7 .form-group {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 14px;
}

.pf-na-cf7 .form-group label {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--muted2);
}

.pf-na-cf7 .wpcf7-form-control-wrap {
  display: block;
}

.pf-na-cf7 .wpcf7-text,
.pf-na-cf7 .wpcf7-tel,
.pf-na-cf7 .wpcf7-textarea,
.pf-na-cf7 .wpcf7-select {
  width: 100%;
  background: #ffffff;
  border: 1px solid var(--border2);
  color: var(--white);
  padding: 14px 16px;
  font-size: 15px;
  font-family: 'Montserrat', sans-serif;
  outline: none;
  border-radius: 0;
  transition: border-color .2s;
  -webkit-appearance: none;
}

.pf-na-cf7 .wpcf7-text:focus,
.pf-na-cf7 .wpcf7-tel:focus,
.pf-na-cf7 .wpcf7-textarea:focus,
.pf-na-cf7 .wpcf7-select:focus {
  border-color: var(--accent);
}

.pf-na-cf7 .wpcf7-textarea {
  min-height: 90px;
  resize: vertical;
}

.pf-na-cf7 .wpcf7-submit {
  width: 100%;
  padding: 20px;
  background: #0f0f0f;
  color: #ffffff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  font-family: 'Montserrat', sans-serif;
  transition: background .2s, color .2s;
  margin-top: 4px;
}

.pf-na-cf7 .wpcf7-submit:hover {
  background: var(--accent);
  color: #fff;
}

.pf-na-cf7 .wpcf7-spinner {
  margin: 12px 0 0;
}

.pf-na-cf7 .wpcf7-response-output,
.pf-na-cf7 .wpcf7-not-valid-tip {
  margin: 12px 0 0;
  font-size: 13px;
}

.pf-na-cf7 .wpcf7-response-output {
  border: none;
  padding: 0;
}

@media(max-width:700px) {
  .pf-na-cf7 .form-row {
    grid-template-columns: 1fr;
  }

  .pf-na-cf7 .wpcf7-text,
  .pf-na-cf7 .wpcf7-tel,
  .pf-na-cf7 .wpcf7-textarea,
  .pf-na-cf7 .wpcf7-select {
    font-size: 16px;
    padding: 16px;
  }
}
