/* Компоненты: hero, CTA-форма, карточки блога, фильтры, хлебные крошки */

/* HERO (тёмный, как на живом сайте) */
.hero { padding: 56px 0 40px; background: var(--color-dark); color: var(--color-on-dark); overflow: hidden; }
.hero__grid { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 32px; align-items: center; }
.hero__eyebrow { color: #8fd9c0; font-weight: 600; font-size: 14px; text-transform: uppercase; letter-spacing: .04em; }
.hero__title { color: #fff; font-size: clamp(30px, 4.6vw, 48px); font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; margin: 12px 0 16px; }
.hero__lead { font-size: clamp(16px, 1.8vw, 19px); color: #c4d0dd; max-width: 640px; margin-bottom: 24px; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 12px; }
.hero__actions .btn--ghost { color: #fff; border-color: rgba(255,255,255,0.25); }
.hero__actions .btn--ghost:hover { border-color: var(--color-accent); color: #fff; }
.hero__photo { justify-self: center; max-width: 300px; filter: drop-shadow(0 18px 40px rgba(0,0,0,0.35)); }
.hero__badges { display: flex; flex-wrap: wrap; gap: 14px 28px; margin-top: 32px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.12); }
.hero__badge { display: flex; align-items: center; gap: 8px; font-size: 14px; color: #c4d0dd; }
.hero__badge svg { width: 18px; height: 18px; flex: 0 0 auto; stroke: var(--color-accent); }
@media (max-width: 760px) { .hero__grid { grid-template-columns: 1fr; } .hero__photo { display: none; } }

/* Тёмные секции */
.section--dark { background: var(--color-dark); color: var(--color-on-dark); }
.section--dark .section__head h2 { color: #fff; }
.section--dark .section__head p { color: #b9c6d6; }

/* Сетка проблем (тёмная плашка, 6 иконок) */
.problems-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px 24px; max-width: 960px; margin: 0 auto; }
.problem-item { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.problem-item svg { width: 44px; height: 44px; stroke: #fff; opacity: 0.9; }
.problem-item p { color: #c4d0dd; font-size: 15px; line-height: 1.4; max-width: 240px; }
@media (max-width: 700px) { .problems-grid { grid-template-columns: 1fr 1fr; gap: 28px 16px; } }
@media (max-width: 420px) { .problems-grid { grid-template-columns: 1fr; } }

/* Бейдж и плашка формы */
.form-pill { display: inline-flex; align-items: center; gap: 6px; color: #34d399; font-weight: 600; font-size: 14px; }

/* Картинка-врезка по центру секции (график, воронка) */
.figure-block { margin: 8px auto 0; max-width: 920px; border: 1px solid rgba(15,23,42,0.06); border-radius: var(--radius-lg); overflow: hidden; background: #fff;
  box-shadow: 0 1px 3px rgba(15,23,42,0.04), 0 14px 32px rgba(15,23,42,0.09); }
.figure-block img { width: 100%; display: block; }
.figure-block figcaption { font-size: 13px; color: var(--color-text-muted); padding: 10px 16px; border-top: 1px solid var(--color-border); }
.figure-narrow { max-width: 720px; }

/* Блок «Теряете прибыль» — проблемы с графиками */
.problems { display: grid; gap: 40px; max-width: 920px; }
.problem h3 { font-size: clamp(20px, 2.6vw, 26px); margin-bottom: 8px; }
.problem p { color: var(--color-text-muted); margin-bottom: 16px; max-width: 720px; }
.problem .figure-block { margin: 0; }

/* Сетка «проблемы» */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }
.card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-sm); }
.card h3 { font-size: 18px; margin-bottom: 8px; }
.card p { color: var(--color-text-muted); font-size: 15px; }

/* CTA — премиальный блок «Закажите аудит» (форма слева, декор справа) */
.cta {
  --cta-accent: #12c48b;
  display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 48px; align-items: center;
  background: #0b1d2b; color: #fff; max-width: 1240px; margin: 0 auto; min-height: 540px;
  border-radius: 30px; padding: clamp(28px, 4vw, 68px);
  box-shadow: 0 2px 10px rgba(7, 24, 39, 0.06), 0 28px 64px rgba(7, 24, 39, 0.20); position: relative; overflow: hidden;
}
.cta::before { content: ""; position: absolute; top: -120px; right: -80px; width: 420px; height: 420px;
  background: radial-gradient(circle, rgba(18,196,139,0.16), transparent 70%); pointer-events: none; }
.cta__left { position: relative; z-index: 1; }
.cta h2 { color: #fff; font-size: clamp(32px, 4vw, 50px); font-weight: 800; line-height: 1.05; margin: 16px 0 18px; }
.cta__sub { font-size: clamp(17px, 1.6vw, 22px); color: rgba(255,255,255,0.78); max-width: 620px; line-height: 1.35; margin-bottom: 28px; }

.form-pill { display: inline-flex; align-items: center; gap: 6px; color: var(--cta-accent); font-weight: 600; font-size: 14px; }
.form-pill svg { width: 16px; height: 16px; }

.lead-form { display: grid; gap: 15px; max-width: 560px; }
.lead-form .hp { position: absolute; left: -9999px; opacity: 0; }
.lead-form input { width: 100%; height: 60px; padding: 0 20px; border-radius: 13px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.22); color: #fff; font-size: 16px; }
.lead-form input::placeholder { color: rgba(255,255,255,0.45); }
.lead-form input:focus { outline: none; border-color: var(--cta-accent); box-shadow: 0 0 0 3px rgba(18,196,139,0.12); }
.lead-form__consent { display: flex; gap: 10px; align-items: flex-start; font-size: 12.5px; color: rgba(255,255,255,0.65); line-height: 1.35; max-width: 560px; }
.lead-form__consent input { width: 18px; height: 18px; margin-top: 1px; flex: 0 0 auto; }
.lead-form__consent a { color: rgba(255,255,255,0.9); text-decoration: underline; }
.lead-form__submit { height: 58px; padding: 0 38px; border: 0; border-radius: 13px; background: var(--cta-accent);
  color: #fff; font-weight: 700; font-size: 17px; justify-self: start; margin-top: 4px; cursor: pointer;
  transition: background .2s ease, transform .15s ease; }
.lead-form__submit:hover { background: #10b981; transform: translateY(-2px); }
.lead-form__submit:disabled { opacity: .6; cursor: default; transform: none; }
.form-status { font-size: 14px; min-height: 0; }
.form-status--ok { color: #6ee7b7; }
.form-status--err { color: #fca5a5; }

/* Правая декоративная колонка */
.cta__decor { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 26px; }
.cta__badge-card { background: #fff; color: #0b1d2b; border-radius: 22px; padding: 24px 34px; text-align: center;
  transform: rotate(11deg); box-shadow: 0 24px 50px rgba(0,0,0,0.28); }
.cta__badge-num { font-size: 56px; font-weight: 800; line-height: 1; }
.cta__badge-text { font-size: 14px; color: #64748b; margin-top: 4px; }
.cta__benefits { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; width: 100%; max-width: 280px; }
.cta__benefits li { display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 12px 14px; font-size: 14px; color: #cdd9e6; }
.cta__benefits svg { width: 18px; height: 18px; stroke: var(--cta-accent); flex: 0 0 auto; }

@media (max-width: 860px) {
  .cta { grid-template-columns: 1fr; gap: 30px; min-height: 0; padding: 30px 22px; }
  .cta__sub { font-size: 18px; }
  .cta__decor { flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 16px; }
  .cta__benefits { max-width: none; flex: 1 1 260px; }
  .lead-form { max-width: none; }
  .lead-form__submit { width: 100%; justify-self: stretch; }
}

/* Хлебные крошки */
.breadcrumbs { margin: 18px 0 6px; font-size: 14px; color: var(--color-text-muted); }
.breadcrumbs ol { display: flex; flex-wrap: wrap; align-items: center; gap: 0; padding: 0; margin: 0; list-style: none; }
.breadcrumbs li { display: flex; align-items: center; }
.breadcrumbs li:not(:first-child)::before { content: "›"; margin: 0 8px; color: var(--color-text-faint); }
.breadcrumbs a { color: var(--color-accent); }
.breadcrumbs li[aria-current] { color: var(--color-text); font-weight: 600; }

/* БЛОГ: заголовок, инструменты, сетка карточек */
.blog-head { padding: 28px 0 8px; }
.blog-head h1 { font-size: clamp(28px, 4vw, 40px); font-weight: 800; }
.blog-head p { color: var(--color-text-muted); margin-top: 8px; font-size: 17px; }

.blog-tools { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin: 22px 0 28px; }
.search { display: flex; align-items: center; gap: 8px; border: 1px solid var(--color-border); border-radius: 999px; padding: 8px 14px; flex: 1 1 240px; max-width: 320px; }
.search svg { width: 18px; height: 18px; fill: var(--color-text-faint); flex: 0 0 auto; }
.search input { border: 0; outline: none; width: 100%; font-size: 15px; background: transparent; }
.tag-filter { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-filter__btn { border: 1px solid var(--color-border); background: #fff; color: var(--color-text-muted); border-radius: 999px; padding: 7px 14px; font-size: 14px; }
.tag-filter__btn:hover { border-color: var(--color-accent); color: var(--color-accent-ink); }
.tag-filter__btn--active { background: var(--color-accent); border-color: var(--color-accent); color: #fff; }

.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.post-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.post-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: #cbd5e1; }
.post-card__cover { aspect-ratio: 16 / 9; width: 100%; object-fit: cover; background: var(--color-bg-soft); }
.post-card__body { display: flex; flex-direction: column; gap: 8px; padding: 18px 18px 20px; flex: 1; }
.post-card__tag { align-self: flex-start; background: var(--color-accent-soft); color: var(--color-accent-ink); border-radius: 999px; padding: 3px 10px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.post-card__title { font-size: 18px; font-weight: 700; line-height: 1.3; }
.post-card__title a { color: var(--color-text); }
.post-card__title a:hover { color: var(--color-accent-ink); text-decoration: none; }
.post-card__excerpt { color: var(--color-text-muted); font-size: 14px; flex: 1; }
.post-card__meta { display: flex; align-items: center; gap: 8px; color: var(--color-text-faint); font-size: 13px; margin-top: 4px; }
.blog-empty { color: var(--color-text-muted); padding: 24px 0; }

/* Текстовый блок (страницы услуг) — центрированная колонка, текст слева */
.prose { max-width: 840px; margin: 0 auto; }
.prose h3 { font-size: clamp(20px, 2.4vw, 26px); font-weight: 700; margin: 28px 0 10px; }
.prose p { color: var(--color-text-muted); font-size: 17px; line-height: 1.7; margin: 0 0 14px; }
.prose ul { margin: 0 0 16px; padding-left: 22px; color: var(--color-text-muted); }
.prose li { margin: 6px 0; line-height: 1.6; }
.prose strong { color: var(--color-text); }

/* Тизер блога на других страницах */
.teaser-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }

/* Hero-полоса страницы (блог, услуги) */
.page-hero { background: linear-gradient(180deg, var(--color-bg-soft), var(--color-bg)); padding: 40px 0 24px; border-bottom: 1px solid var(--color-border); }
.page-hero h1 { font-size: clamp(28px, 4vw, 42px); font-weight: 800; letter-spacing: -0.02em; }
.page-hero p { color: var(--color-text-muted); margin-top: 10px; font-size: clamp(16px, 2vw, 18px); max-width: 640px; }

/* Секции с фоном */
.section--soft { background: var(--color-bg-soft); }
.section__head { margin-bottom: 28px; }
.section__head h2 { font-size: clamp(24px, 3.4vw, 36px); font-weight: 800; letter-spacing: -0.01em; }
.section__head p { color: var(--color-text-muted); margin-top: 8px; font-size: 17px; max-width: 680px; }
.lead-paragraph { font-size: clamp(16px, 1.8vw, 19px); color: var(--color-text-muted); max-width: 760px; }
.lead-paragraph strong { color: var(--color-text); }

/* Большая цифра-показатель */
.stat { font-size: clamp(28px, 4vw, 40px); font-weight: 800; color: var(--color-accent-ink); line-height: 1; }
.stat__label { font-size: 14px; color: var(--color-text-muted); margin-top: 4px; }

/* Этапы плана (01–04) — иконка-робот, номер, заголовок, описание */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; }
.step { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 28px 22px; box-shadow: var(--shadow-sm); text-align: center; }
.step__icon { width: 78px; height: 78px; margin: 0 auto 14px; display: block; }
.step__num { font-size: 30px; font-weight: 800; color: var(--color-accent); line-height: 1; }
.step__title { font-size: 19px; font-weight: 700; margin: 4px 0 10px; }
.step p { color: var(--color-text-muted); font-size: 14px; }

/* «Что делаю» — список с акцентом */
.do-list { display: grid; gap: 16px; max-width: 820px; }
.do-list__item { padding-left: 18px; border-left: 3px solid var(--color-accent); }
.do-list__item h3 { font-size: 18px; margin-bottom: 4px; }
.do-list__item p { color: var(--color-text-muted); }

/* Кейсы — карточки-баннеры. Слои: фон → картинка → overlay → текст/метрики */
.cases-grid {
  --card-bg: #0b2034;
  --card-btn: #0f4b73;
  --card-btn-hover: #14597f;
  --card-cta: #e9542c;
  --card-cta-hover: #cf3f1c;
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 44px; max-width: 1100px; margin: 0 auto;
}
.case-card {
  position: relative; overflow: hidden; display: flex;
  min-height: 280px; padding: 24px;
  background: var(--card-bg); border-radius: 22px;
  box-shadow: 0 12px 30px rgba(11, 29, 43, 0.18);
  transition: transform .25s ease, box-shadow .25s ease;
}
.case-card:hover { transform: translateY(-4px); box-shadow: 0 20px 48px rgba(11, 29, 43, 0.30); }

/* фон-декор (z0) → главное фото (z1) → затемнение (z2) → контент (z3) */
.case-card__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.4; z-index: 0; pointer-events: none; user-select: none; }
.case-card__image { position: absolute; right: 24px; bottom: 0; width: 220px; height: auto; object-fit: contain; z-index: 1; pointer-events: none; user-select: none; opacity: 0.92; filter: brightness(0.86); }
.case-card::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(7,24,39,0.78) 0%, rgba(7,24,39,0.40) 45%, rgba(7,24,39,0.12) 100%),
    linear-gradient(180deg, rgba(7,24,39,0.10) 0%, rgba(7,24,39,0.45) 100%);
}
.case-card__content { position: relative; z-index: 3; display: flex; flex-direction: column; flex: 1; }
.case-card__label { color: #9db3c7; font-size: 14px; }
.case-card__title { color: #fff; font-weight: 800; font-size: clamp(21px, 2vw, 26px); line-height: 1.12; margin: 10px 0 0; max-width: 58%; }
.case-card__button { margin-top: auto; align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; background: var(--card-btn); color: #fff; border-radius: 999px; padding: 10px 16px; font-size: 14px; font-weight: 600; text-decoration: none; transition: background .2s ease; }
.case-card__button:hover { background: var(--card-btn-hover); color: #fff; text-decoration: none; }
.case-card__metrics { position: absolute; top: 24px; right: 24px; z-index: 3; display: flex; flex-direction: column; gap: 14px; text-align: right; max-width: 50%; }
.case-card__number { color: #fff; font-weight: 800; font-size: clamp(36px, 3.4vw, 52px); line-height: 0.95; text-shadow: 0 2px 14px rgba(0,0,0,0.55); }
.case-card__caption { color: #e2e9f1; font-size: 16px; line-height: 1.15; text-shadow: 0 1px 8px rgba(0,0,0,0.5); }

/* Позиция и размер картинки — по модификаторам (картинка не влияет на высоту карточки) */
/* Люди — подгонка ПО ВЫСОТЕ (чтобы не обрезало голову), объекты — по ширине */
.case-card--bride       .case-card__image { height: 90%; width: auto; right: 120px; bottom: 0; }
.case-card--car         .case-card__image { width: 250px; right: 24px;  bottom: 26px; }
.case-card--house       .case-card__image { width: 250px; right: 22px;  bottom: 20px; }
.case-card--scooter     .case-card__image { width: 210px; right: 30px;  bottom: 22px; }
.case-card--baby-food   .case-card__image { width: 300px; right: 90px;  bottom: 16px; }
.case-card--red-dress   .case-card__image { height: 96%; width: auto; right: 140px; bottom: 0; }
.case-card--conditioner .case-card__image { width: 290px; right: 90px;  bottom: 18px; }
.case-card--fur-coat    .case-card__image { height: 90%; width: auto; right: 140px; bottom: 0; }
.case-card--window      .case-card__image { width: 195px; right: 175px; bottom: -10px; }
.case-card--cta         .case-card__image { width: 340px; right: 50px;  bottom: 28px; opacity: 0.95; }

/* CTA-карточка */
.case-card--cta::after { background: linear-gradient(90deg, rgba(7,24,39,0.82) 0%, rgba(7,24,39,0.45) 55%, rgba(7,24,39,0.15) 100%); }
.case-card--cta .case-card__title { font-size: clamp(24px, 2.4vw, 32px); max-width: 60%; }
.case-card__button--accent { background: var(--card-cta); }
.case-card__button--accent:hover { background: var(--card-cta-hover); }

@media (max-width: 768px) {
  .cases-grid { grid-template-columns: 1fr; gap: 28px; }
  .case-card { min-height: 300px; }
  .case-card__title { font-size: 22px; max-width: 60%; }
  .case-card__number { font-size: 40px; }
  .case-card__caption { font-size: 15px; }
  .case-card__image { opacity: 0.8; }
  .case-card--baby-food .case-card__image,
  .case-card--conditioner .case-card__image { width: 230px; right: 10px; }
  .case-card--cta .case-card__image { width: 250px; right: 10px; }
}

/* Хабр-врезка */
.habr { display: flex; flex-wrap: wrap; gap: 16px 28px; align-items: center; justify-content: space-between;
  background: var(--color-dark); color: var(--color-on-dark); border-radius: var(--radius-lg); padding: clamp(24px, 4vw, 36px); }
.habr h3 { color: #fff; font-size: clamp(20px, 2.6vw, 28px); max-width: 620px; }
.habr__stats { display: flex; gap: 24px; }
.habr__stats .stat { color: #6ee7b7; }
.habr__stats .stat__label { color: #b9c6d6; }

/* FAQ (общий, вне статьи) */
.faq { display: grid; gap: 10px; max-width: 820px; }
.faq details { border: 1px solid var(--color-border); border-radius: var(--radius); background: #fff; overflow: hidden; }
.faq summary { cursor: pointer; font-weight: 600; padding: 16px 18px; list-style: none; display: flex; justify-content: space-between; gap: 12px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--color-accent); font-weight: 700; }
.faq details[open] summary::after { content: "−"; }
.faq details[open] summary { border-bottom: 1px solid var(--color-border); }
.faq details > div { padding: 14px 18px; color: var(--color-text-muted); }
.faq details > div p { margin: 0 0 8px; }
.faq details > div p:last-child { margin: 0; }
