/* ============================================================
   soboleznovaniya.ru — РЕДИЗАЙН 2026 · главная
   Источник: dis/Соболезнования.dc.html
   ВАЖНО: контентные зоны (H1, лид, готовые тексты, «как выразить»,
   разделы, CTA) при интеграции выводятся из редактора WordPress —
   здесь демо-наполнение из макета (плейсхолдер).
   ============================================================ */

/* ---------- HERO ---------- */
.hero{ padding:48px 0 44px; }
.hero__grid{ display:grid; grid-template-columns:1fr 360px; gap:40px; align-items:center; }
.hero__title{ margin:0; }
.hero__kicker{
  display:block; font-size:clamp(24px,3vw,40px); font-weight:var(--fw-bold);
  letter-spacing:-0.02em; line-height:1.05; color:var(--ink); margin-bottom:18px;
}
.hero__display{ display:block; }   /* использует .display из base.css */
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:42px; }
.hero__lead{ margin:44px 0 0; max-width:52ch; }

/* Плавающие пилюли-теги */
.hero__pills{ position:relative; height:300px; }
.pill{
  position:absolute; display:flex; align-items:center; gap:16px;
  background:var(--pill-bg); border-radius:var(--r-pill);
  padding:14px 14px 14px 26px; box-shadow:var(--sh-pill);
  transition:transform .14s, box-shadow .14s;
}
.pill:hover{ transform:translateY(-3px); box-shadow:var(--sh-pill-hover); }
.pill__label{ font-size:18px; font-weight:var(--fw-bold); }
.pill__dot{ width:40px; height:40px; border-radius:50%; background:#C8C8CC; }
.pill--1{ top:6px; right:0; }
.pill--2{ top:118px; left:6px; }
.pill--3{ top:232px; right:14px; }

/* ---------- ГОТОВЫЕ ТЕКСТЫ ---------- */
.rtexts{ padding:56px 0; border-top:1px solid var(--line); }
.rtexts__head{ display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:32px; }
.rtexts__more{ font-size:16px; font-weight:var(--fw-semibold); color:var(--ink); }
.rtexts__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:16px; }
.rtext{ background:var(--cloud); border-radius:var(--r-card); padding:30px 30px 24px; display:flex; flex-direction:column; gap:20px; }
.rtext__tag{ align-self:flex-start; font-size:12px; font-weight:var(--fw-semibold); letter-spacing:0.04em; text-transform:uppercase; color:var(--ink); background:#fff; padding:7px 12px; border-radius:var(--r-xs); }
.rtext__text{ margin:0; font-size:19px; line-height:1.55; color:var(--ink-2); flex:1; }
.rtext__copy{
  align-self:flex-start; font-family:inherit; font-weight:var(--fw-semibold); font-size:15px;
  padding:12px 20px; border-radius:11px; cursor:pointer;
  border:1px solid var(--border); background:#fff; color:var(--ink);
  transition:all .14s;
}
.rtext__copy.is-copied{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* ---------- КАК ВЫРАЗИТЬ ---------- */
.how{ padding:56px 0; border-top:1px solid var(--line); }
.how__grid{ display:grid; grid-template-columns:0.55fr 1fr; gap:48px; }
.how__list{ margin:0; padding:0; list-style:none; font-size:19px; line-height:1.6; color:var(--slate); }
.how__item{ padding:22px 0; border-top:1px solid var(--line-2); display:flex; gap:20px; }
.how__item:last-child{ border-bottom:1px solid var(--line-2); }
.how__num{ font-weight:var(--fw-bold); color:var(--mute); }
.how__item b{ font-weight:var(--fw-semibold); }

/* ---------- КОМУ ВЫРАЗИТЬ (плитки-роутер) ---------- */
.podbor{ padding:48px 0; border-top:1px solid var(--line); }
.podbor__head{ display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:22px; }
.podbor__title{ margin:0; font-size:var(--h2-sm); line-height:1.0; letter-spacing:var(--track-tight); font-weight:var(--fw-extrabold); }
.podbor__note{ font-size:14px; color:var(--muted); }
.podbor__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(168px,1fr)); gap:10px; }
.tile{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:var(--cloud); border-radius:var(--r-chip); padding:15px 18px;
  font-size:16px; font-weight:var(--fw-semibold);
  transition:background .14s, color .14s, transform .14s;
}
.tile:hover{ background:var(--ink); color:#fff; transform:translateY(-2px); }
.tile__ar{ color:var(--mute); font-size:14px; }
.tile:hover .tile__ar{ color:#fff; }

/* ---------- РАЗДЕЛЫ ---------- */
.seclinks{ padding:56px 0; border-top:1px solid var(--line); }
.seclinks__title{ margin:0 0 32px; }
.seclinks__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:16px; }
.lcard{
  background:var(--cloud); border-radius:var(--r-card-lg); padding:40px; min-height:240px;
  display:flex; flex-direction:column; justify-content:space-between;
  transition:transform .14s, box-shadow .14s;
}
.lcard:hover{ transform:translateY(-3px); }
.lcard--dark{ background:var(--ink); color:#fff; }
.lcard__eyebrow{ font-size:13px; font-weight:var(--fw-semibold); color:var(--muted); }
.lcard--dark .lcard__eyebrow{ color:var(--on-dark-faint); }
.lcard__title{ font-size:30px; font-weight:var(--fw-extrabold); letter-spacing:var(--track-tight); line-height:1.05; }
.lcard__sub{ font-size:16px; color:#6B6C72; margin-top:12px; }
.lcard--dark .lcard__sub{ color:var(--on-dark-mute); }

/* ---------- CTA ---------- */
.home-cta{ padding:84px 0; border-top:1px solid var(--line); text-align:center; }
.home-cta__title{ margin:0 auto; font-size:clamp(38px,5.4vw,80px); line-height:0.96; letter-spacing:-0.045em; font-weight:var(--fw-extrabold); max-width:16ch; }
.home-cta__text{ margin:26px auto 38px; max-width:50ch; font-size:19px; line-height:1.55; color:var(--graphite); }

/* ---------- Адаптив ---------- */
@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__pills{ display:none; }
}
@media (max-width:760px){
  .how__grid{ grid-template-columns:1fr; gap:22px; }
}
@media (max-width:640px){
  .hero{ padding:28px 0 26px; }
  .hero__display{ font-size:44px; line-height:1.0; }
  .hero__kicker{ margin-bottom:18px; }
  .hero__cta .btn{ font-size:16px; padding:17px 26px; }
  .hero__lead{ font-size:17px; margin-top:30px; }
  .rtexts, .how, .podbor, .seclinks{ padding-top:36px; padding-bottom:36px; }
  .home-cta{ padding:56px 0; }
}
