/* ============================================================
   soboleznovaniya.ru — РЕДИЗАЙН 2026 · КАТАЛОГ ОДНОЙ ФРАЗЫ
   Эталон: «Царствие небесное». Текст канона + сетка картинок-открыток
   с этой фразой + копирование. WP: H1/лид/тело — из редактора,
   карточки — из медиатеки/постов-открыток одной фразы.
   ============================================================ */

/* ---------- HERO ---------- */
.pcat-hero{ padding:44px 0 6px; }
.pcat-hero .pmeta{ margin-bottom:24px; }
.pcat-h1{ margin:0; overflow-wrap:break-word; word-break:normal; hyphens:auto; -webkit-hyphens:auto; text-wrap:balance; }
.pcat-lead{ margin:24px 0 0; max-width:60ch; font-size:20px; line-height:1.55; color:var(--slate); }

/* ---------- Сетка картинок-открыток ---------- */
.pcat-sub{ display:flex; align-items:baseline; justify-content:space-between; gap:18px; flex-wrap:wrap; padding:34px 0 0; }
.pcat-sub__h{ font-size:22px; font-weight:var(--fw-bold); letter-spacing:-0.02em; }
.pcat-sub__hint{ font-size:14px; color:var(--muted); }

.pcat-grid{ padding:18px 0 8px; display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }
.ocard{ margin:0; display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-card-lg); overflow:hidden; }
.ocard__img{ aspect-ratio:1/1; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; background:var(--ink); }
.ocard__img img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block; }

/* плейсхолдер-эскиз (туда пойдёт сгенерированная открытка «матовое масло») */
.ocard__ph{ padding:26px; }
.ocard__ph .pcard__brace{ position:absolute; top:14px; left:16px; }
.ocard__phtext{ font-size:23px; font-weight:var(--fw-bold); color:#fff; text-align:center; line-height:1.2; letter-spacing:-0.02em; }
.ocard__sketch{ position:absolute; top:13px; right:13px; font-size:11px; font-weight:var(--fw-semibold); letter-spacing:0.05em; text-transform:uppercase; color:#fff; background:rgba(255,255,255,.16); padding:5px 9px; border-radius:var(--r-pill); }

/* подпись + действия */
.ocard__bar{ padding:15px 17px 17px; display:flex; flex-direction:column; gap:13px; }
.ocard__phrase{ margin:0; font-size:16px; line-height:1.45; color:var(--ink-2); flex:1; }
.ocard__actions{ display:flex; gap:8px; }
.ocard__btn{ font-family:inherit; font-weight:var(--fw-semibold); font-size:14px; cursor:pointer; padding:10px 14px; border-radius:var(--r-chip); border:1px solid var(--border); background:var(--paper); color:var(--ink); transition:background .14s,color .14s,border-color .14s; display:inline-flex; align-items:center; gap:7px; text-decoration:none; }
.ocard__btn:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.ocard__btn--primary{ background:var(--ink); color:#fff; border-color:var(--ink); }
.ocard__btn--primary:hover{ background:var(--graphite); border-color:var(--graphite); }

/* ---------- Канон-текст (статья под сеткой) ---------- */
.pcat-article{ padding:52px 0 8px; margin-top:30px; display:flex; justify-content:center; border-top:1px solid var(--line); }
.pcat-article .art-body{ max-width:760px; width:100%; font-size:19px; line-height:1.75; color:#2E2F34; }
.pcat-article .art-body p{ margin:0 0 22px; }
.pcat-article .art-lead{ margin:0 0 34px; font-size:23px; line-height:1.5; letter-spacing:-0.01em; color:var(--ink); font-weight:var(--fw-medium); }
.pcat-article .art-body h2{ margin:40px 0 16px; font-size:clamp(28px,3vw,38px); line-height:1.1; letter-spacing:-0.025em; font-weight:var(--fw-extrabold); }
.pcat-article .art-body h3{ margin:32px 0 12px; font-size:23px; line-height:1.2; letter-spacing:-0.02em; font-weight:var(--fw-bold); }
.pcat-article .art-body ul{ margin:0 0 22px; padding:0; list-style:none; }
.pcat-article .art-body li{ padding:14px 0; border-top:1px solid var(--line-2); padding-left:26px; position:relative; }
.pcat-article .art-body li:last-child{ border-bottom:1px solid var(--line-2); }
.pcat-article .art-body li::before{ content:""; position:absolute; left:4px; top:23px; width:7px; height:7px; border-radius:50%; background:var(--mute); }
.pcat-article .art-body blockquote{ margin:26px 0; padding:20px 26px; border-left:3px solid var(--ink); background:var(--cloud); border-radius:0 var(--r-card-sm) var(--r-card-sm) 0; }
.pcat-article .art-body blockquote p{ margin:0; font-size:18px; }
.pcat-article .art-body b, .pcat-article .art-body strong{ font-weight:var(--fw-semibold); }

/* ---------- Тост «скопировано» ---------- */
.toast{ position:fixed; left:50%; bottom:34px; transform:translateX(-50%) translateY(20px); background:var(--ink); color:#fff; padding:13px 22px; border-radius:var(--r-pill); font-weight:var(--fw-semibold); font-size:15px; opacity:0; pointer-events:none; transition:opacity .25s,transform .25s; z-index:140; box-shadow:var(--sh-menu); }
.toast.is-on{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ---------- Адаптив ---------- */
@media (max-width:640px){
  .pcat-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .ocard__phtext{ font-size:16px; }
  .ocard__bar{ padding:12px; gap:10px; }
  .ocard__phrase{ font-size:14px; }
  .ocard__btn{ font-size:13px; padding:9px 11px; }
  .pcat-article .art-body{ font-size:17px; }
  .pcat-hero, .pcat-article{ padding-top:30px; }
}
