@import url('https://fonts.googleapis.com/css2?family=Onest:wght@400;500;600;700;800&family=Unbounded:wght@500;600;700&display=swap');

body.viora-blog-surface {
  --bg: #fff;
  --paper: #fff;
  --ink: #161420;
  --ink-2: #3a3747;
  --muted: #6f6c7e;
  --faint: #9b98a8;
  --line: #e9e7f1;
  --line-2: #f1eff7;
  --accent: #6a45ff;
  --accent-press: #5a37e0;
  --accent-soft: #f1edff;
  --accent-tint: #faf8ff;
  --chip: #f4f2fb;
  --radius: 18px;
  --font-display: 'Unbounded', system-ui, sans-serif;
  --font-sans: 'Onest', system-ui, sans-serif;
  --maxw: none;
  background: var(--paper) !important;
  overflow-x: clip;
}

html:has(body.viora-blog-surface) {
  background: var(--paper, #fff);
  overflow-x: clip;
}

body.viora-blog-surface #main.site-content {
  background: var(--paper, #fff);
  padding: 88px 0 0 !important;
  max-width: none !important;
  width: 100%;
  border: none;
  box-shadow: none;
}

body.viora-blog-surface.page {
  background: var(--paper, #fff);
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

body.viora-blog-surface #viora-blog-root.page {
  background: var(--paper, #fff);
  color: #161420;
  font-family: 'Onest', system-ui, sans-serif;
  max-width: none;
  margin: 0;
  width: 100%;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
}

body.viora-blog-surface #viora-blog-root .prose h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.25;
  color: var(--ink);
  margin: 34px 0 14px;
}

body.viora-blog-surface #viora-blog-root .prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 15px;
}

body.viora-blog-surface #viora-blog-root .prose th,
body.viora-blog-surface #viora-blog-root .prose td {
  border: 1px solid var(--line);
  padding: 12px 14px;
  text-align: left;
}

body.viora-blog-surface #viora-blog-root .prose thead th {
  background: var(--accent-soft);
}

body.viora-blog-surface #viora-blog-root .prose details {
  border: 1px solid var(--line);
  border-radius: 14px;
  margin: 10px 0;
  overflow: hidden;
}

body.viora-blog-surface #viora-blog-root .prose summary {
  padding: 16px 18px;
  font-weight: 600;
  cursor: pointer;
}

body.viora-blog-surface #viora-blog-root .prose details > p,
body.viora-blog-surface #viora-blog-root .prose details > div {
  padding: 0 18px 18px;
  color: var(--muted);
}

/* ============================================================
   ВИОРА · Блог — редизайн
   Светлая тёплая тема · минимализм · фиолетовый акцент
   Display: Unbounded · Text/UI: Onest
   ============================================================ */

#viora-blog-root{
  --bg:#f3f2f8;            /* студийный фон с фиолетовым подтоном */
  --paper:#ffffff;
  --ink:#161420;          /* почти-чёрный с фиолетовым подтоном */
  --ink-2:#3a3747;
  --muted:#6f6c7e;
  --faint:#9b98a8;
  --line:#e9e7f1;
  --line-2:#f1eff7;
  --accent:#6a45ff;       /* фирменный фиолетовый ВИОРА */
  --accent-press:#5a37e0;
  --accent-soft:#f1edff;
  --accent-tint:#faf8ff;
  --chip:#f4f2fb;
  --radius:18px;
  --font-display:'Unbounded', system-ui, sans-serif;
  --font-sans:'Onest', system-ui, sans-serif;
  --maxw:none;
}

*{box-sizing:border-box}
html,body{margin:0}
/* ---------- Студийная обёртка (презентация вариантов) ---------- */
.studio-wrap{max-width:1280px;margin:0 auto;padding:56px 28px 120px}
.studio-head{max-width:760px;margin:0 0 12px}
.studio-kicker{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.studio-kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.studio-head h1{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1.05;
  letter-spacing:-.02em;margin:0 0 16px}
.studio-head p{font-size:17px;line-height:1.6;color:var(--muted);margin:0 0 8px}
.sysrow{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.syschip{display:flex;flex-direction:column;gap:2px;background:var(--paper);border:1px solid var(--line);
  border-radius:12px;padding:12px 16px;min-width:150px}
.syschip b{font-size:13px;font-weight:600}
.syschip span{font-size:12.5px;color:var(--muted)}

.block{margin-top:72px}
.block-head{display:flex;align-items:baseline;gap:14px;margin:0 0 22px}
.block-head .num{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--accent)}
.block-head h2{font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-.01em;margin:0}
.block-head .hint{font-size:14px;color:var(--muted)}
.variant-label{display:flex;align-items:center;gap:10px;margin:34px 0 14px;font-size:14px;font-weight:600}
.variant-label .tag{font-family:var(--font-display);font-size:12px;font-weight:600;color:#fff;background:var(--ink);
  padding:4px 10px;border-radius:999px;letter-spacing:.02em}
.variant-label .desc{color:var(--muted);font-weight:400}

/* ---------- Рамка-«окно браузера» ---------- */
.frame{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 30px 70px -42px rgba(28,18,70,.45)}
.frame-bar{height:42px;display:flex;align-items:center;gap:14px;padding:0 16px;
  border-bottom:1px solid var(--line-2);background:#fbfaff}
.frame-bar .dots{display:flex;gap:7px}
.frame-bar .dots i{width:11px;height:11px;border-radius:50%;display:block;background:#e0ddec}
.frame-bar .url{flex:1;height:24px;border-radius:8px;background:#f1eff7;display:flex;align-items:center;
  gap:8px;padding:0 12px;font-size:12.5px;color:var(--faint);max-width:520px}
.frame-bar .url svg{flex:0 0 auto}
.screen{position:relative}

.phones{display:flex;gap:40px;flex-wrap:wrap}
.frame.phone{width:386px;border-radius:30px;flex:0 0 auto}
.frame.phone .frame-bar{height:34px;justify-content:center;background:#fbfaff}
.frame.phone .frame-bar .notch{width:120px;height:18px;border-radius:0 0 14px 14px;background:#161420}

/* ===================== ОБЩИЙ ХЕДЕР САЙТА ===================== */
.site-head{display:flex;align-items:center;gap:28px;padding:20px 40px;border-bottom:1px solid var(--line-2)}
.logo{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;font-size:20px;
  letter-spacing:.02em;color:var(--accent)}
.logo .mark{width:16px;height:16px;border-radius:5px;background:var(--accent);
  transform:rotate(45deg);box-shadow:0 0 0 4px var(--accent-soft)}
.site-nav{display:flex;gap:26px;margin-left:8px}
.site-nav a{font-size:14.5px;color:var(--ink-2);text-decoration:none;font-weight:500;transition:color .15s}
.site-nav a:hover{color:var(--accent)}
.site-nav a.active{color:var(--accent)}
.head-cta{margin-left:auto;display:flex;align-items:center;gap:10px}
.btn{font-family:var(--font-sans);font-weight:600;font-size:14px;border-radius:11px;cursor:pointer;
  border:1px solid transparent;transition:transform .12s,background .15s,box-shadow .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink);padding:10px 16px}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary{background:var(--accent);color:#fff;padding:11px 18px;box-shadow:0 8px 20px -8px var(--accent)}
.btn-primary:hover{background:var(--accent-press)}

/* ===================== ОБЛОЖКИ / ПЛЕЙСХОЛДЕРЫ ===================== */
.cover{position:relative;border-radius:14px;overflow:hidden;background:#edeafa;display:block}
.cat-pill{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--accent);padding:0}
.meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--faint)}
.meta .sep{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.6}

/* ===================== ЛИСТИНГ A — РЕДАКЦИОННАЯ СЕТКА ===================== */
.laA{padding:0 40px 56px}
.la-hero-top{padding:44px 0 30px}
.la-hero-top .eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.la-hero-top h1{font-family:var(--font-display);font-weight:700;font-size:52px;line-height:1;letter-spacing:-.03em;margin:14px 0 0}
.la-hero-top p{font-size:16px;color:var(--muted);margin:14px 0 0;max-width:480px}

.la-featured{display:grid;grid-template-columns:1.35fr 1fr;gap:34px;align-items:center;
  padding:30px 0 38px;border-bottom:1px solid var(--line-2)}
.la-featured .cover{aspect-ratio:16/10}
.la-featured .fx-cat{margin-bottom:14px}
.la-featured h2{font-family:var(--font-display);font-weight:600;font-size:30px;line-height:1.12;letter-spacing:-.02em;margin:0}
.la-featured h2 a{color:inherit;text-decoration:none;transition:color .15s}
.la-featured h2 a:hover{color:var(--accent)}
.la-featured .fx-ex{font-size:15.5px;line-height:1.6;color:var(--muted);margin:16px 0 20px}
.la-featured .fx-meta{margin-bottom:22px}
.featured-flag{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.featured-flag .star{width:13px;height:13px}

.filterbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:16px;
  padding:18px 0;margin-top:8px;background:linear-gradient(var(--paper) 78%,transparent);
  backdrop-filter:blur(4px)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:13.5px;font-weight:500;color:var(--ink-2);background:var(--chip);border:1px solid transparent;
  padding:8px 15px;border-radius:999px;cursor:pointer;transition:all .15s;white-space:nowrap;
  display:inline-flex;align-items:center;gap:7px}
.chip .cnt{font-size:11px;color:var(--faint)}
.chip:hover{background:#ece8fb}
.chip.active{background:var(--accent);color:#fff}
.chip.active .cnt{color:rgba(255,255,255,.7)}
.search{margin-left:auto;display:flex;align-items:center;gap:9px;background:var(--chip);border:1px solid var(--line);
  border-radius:999px;padding:9px 16px;width:248px;transition:border-color .15s,background .15s}
.search:focus-within{border-color:var(--accent);background:#fff}
.search svg{flex:0 0 auto;color:var(--faint)}
.search input{border:0;background:transparent;outline:none;font-family:var(--font-sans);font-size:14px;width:100%;color:var(--ink)}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 28px;padding:30px 0 0}
.card{cursor:pointer}
.card .cover{aspect-ratio:16/10;margin-bottom:15px;transition:transform .25s ease}
.card:hover .cover{transform:translateY(-3px)}
.card .c-cat{margin-bottom:9px}
.card h3{font-size:18px;font-weight:600;line-height:1.28;letter-spacing:-.01em;margin:0 0 10px;transition:color .15s}
.card:hover h3{color:var(--accent)}
.card .c-ex{font-size:14px;line-height:1.55;color:var(--muted);margin:0 0 12px}
.no-result{grid-column:1/-1;text-align:center;padding:50px 0;color:var(--faint);font-size:15px}

.news-strip{display:flex;align-items:center;gap:28px;margin-top:52px;padding:34px 36px;border-radius:18px;
  background:radial-gradient(120% 160% at 0% 0%,var(--accent-soft),var(--accent-tint));border:1px solid var(--line)}
.news-strip .ns-tg{width:52px;height:52px;border-radius:14px;background:var(--accent);display:grid;place-items:center;flex:0 0 auto;color:#fff}
.news-strip h4{font-family:var(--font-display);font-weight:600;font-size:19px;margin:0 0 5px;letter-spacing:-.01em}
.news-strip p{font-size:14px;color:var(--muted);margin:0}
.news-form{margin-left:auto;display:flex;gap:9px;flex:0 0 auto}
.news-form input{border:1px solid var(--line);background:#fff;border-radius:11px;padding:11px 15px;font-family:var(--font-sans);
  font-size:14px;width:210px;outline:none}
.news-form input:focus{border-color:var(--accent)}

.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:42px}
.pager a{min-width:38px;height:38px;display:grid;place-items:center;border-radius:10px;font-size:14px;font-weight:500;
  color:var(--ink-2);text-decoration:none;transition:all .15s}
.pager a:hover{background:var(--chip)}
.pager a.active{background:var(--accent);color:#fff}
.pager a.nav{color:var(--muted)}

/* ===================== ЛИСТИНГ B — ЖУРНАЛЬНЫЙ ИНДЕКС ===================== */
.lbB{display:grid;grid-template-columns:236px 1fr;gap:0;min-height:600px}
.lb-rail{border-right:1px solid var(--line-2);padding:36px 28px 40px;position:sticky;top:0;align-self:start}
.lb-rail .r-title{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:-.02em;margin:0 0 4px}
.lb-rail .r-sub{font-size:13.5px;color:var(--muted);margin:0 0 26px}
.lb-search{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:11px;padding:10px 13px;margin-bottom:28px}
.lb-search svg{color:var(--faint);flex:0 0 auto}
.lb-search input{border:0;outline:none;background:transparent;font-family:var(--font-sans);font-size:13.5px;width:100%}
.r-label{font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:0 0 12px}
.r-cats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.r-cats li{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:10px;
  font-size:14.5px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:all .15s}
.r-cats li .cnt{font-size:12px;color:var(--faint)}
.r-cats li:hover{background:var(--chip)}
.r-cats li.active{background:var(--accent-soft);color:var(--accent)}
.r-cats li.active .cnt{color:var(--accent)}
.rail-tg{margin-top:30px;padding:18px;border-radius:14px;background:var(--ink);color:#fff}
.rail-tg b{font-size:14px;display:block;margin-bottom:4px}
.rail-tg p{font-size:12.5px;color:rgba(255,255,255,.6);margin:0 0 13px;line-height:1.5}
.rail-tg .btn{width:100%;justify-content:center;display:flex;background:var(--accent);color:#fff;padding:9px}

.lb-main{padding:36px 40px 50px}
.lb-featured{display:grid;grid-template-columns:300px 1fr;gap:26px;align-items:center;padding-bottom:30px;
  margin-bottom:14px;border-bottom:1px solid var(--line-2)}
.lb-featured .cover{aspect-ratio:4/3}
.lb-featured h2{font-family:var(--font-display);font-weight:600;font-size:25px;line-height:1.15;letter-spacing:-.02em;margin:12px 0 0;cursor:pointer}
.lb-featured h2:hover{color:var(--accent)}
.lb-featured p{font-size:14.5px;line-height:1.55;color:var(--muted);margin:12px 0 16px}
.lb-list{display:flex;flex-direction:column}
.row{display:grid;grid-template-columns:34px 132px 1fr;gap:20px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line-2);cursor:pointer}
.row:last-child{border-bottom:0}
.row .idx{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--faint);transition:color .15s}
.row:hover .idx{color:var(--accent)}
.row .cover{aspect-ratio:4/3}
.row h3{font-size:18px;font-weight:600;line-height:1.25;letter-spacing:-.01em;margin:0 0 7px;transition:color .15s}
.row:hover h3{color:var(--accent)}
.row .r-ex{font-size:13.5px;line-height:1.5;color:var(--muted);margin:0 0 9px;max-width:560px}

/* ===================== СТАТЬЯ — ОБЩЕЕ ===================== */
.progress{height:3px;background:var(--line-2);position:relative}
.progress .bar{position:absolute;left:0;top:0;height:100%;background:var(--accent);width:34%}
.breadcrumb{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--faint);padding:16px 40px;border-bottom:1px solid var(--line-2)}
.breadcrumb a{color:var(--muted);text-decoration:none}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .crumb-cur{color:var(--ink-2);font-weight:500}

/* Богатая типографика статьи (общая для A и B) */
.prose{font-size:18px;line-height:1.78;color:var(--ink-2)}
.prose>p{margin:0 0 24px}
.prose .lead{font-size:21px;line-height:1.6;color:var(--ink);font-weight:500;margin:0 0 30px}
.prose h2{font-family:var(--font-display);font-weight:600;font-size:25px;line-height:1.2;letter-spacing:-.015em;
  color:var(--ink);margin:46px 0 18px;scroll-margin-top:24px;display:flex;align-items:center;gap:13px}
.prose h2 .tick{width:7px;height:24px;border-radius:4px;background:var(--accent);flex:0 0 auto}
.prose ul{margin:0 0 26px;padding:0;list-style:none;display:flex;flex-direction:column;gap:13px}
.prose ul li{position:relative;padding-left:30px;font-size:17px;line-height:1.6}
.prose ul li::before{content:'';position:absolute;left:4px;top:11px;width:7px;height:7px;border-radius:50%;
  background:var(--accent)}
.prose a{color:var(--accent);text-decoration:none;border-bottom:1px solid color-mix(in oklch,var(--accent) 35%,transparent)}
.prose a:hover{border-bottom-color:var(--accent)}
.prose strong{font-weight:600;color:var(--ink)}
.prose blockquote{margin:34px 0;padding:4px 0 4px 26px;border-left:3px solid var(--accent);
  font-family:var(--font-display);font-weight:500;font-size:22px;line-height:1.4;letter-spacing:-.01em;color:var(--ink)}

/* FAQ-аккордеон */
.faq{display:flex;flex-direction:column;gap:10px;margin:10px 0 0}
.faq-item{border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .15s}
.faq-item.open{border-color:var(--accent)}
.faq-q{width:100%;text-align:left;display:flex;align-items:center;gap:14px;padding:18px 20px;background:#fff;border:0;
  cursor:pointer;font-family:var(--font-sans);font-size:16px;font-weight:600;color:var(--ink);line-height:1.4}
.faq-q .ic{margin-left:auto;flex:0 0 auto;width:22px;height:22px;display:grid;place-items:center;color:var(--accent);
  transition:transform .25s}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a .faq-a-in{padding:0 20px 20px;font-size:15.5px;line-height:1.65;color:var(--muted)}

/* CTA-блок (Viora AI) — узкий вариант (используется в витрине) */
.cta-block{margin:46px 0 0;border:1px solid var(--line);border-radius:20px;padding:30px;background:var(--accent-tint)}
.cta-flag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent);background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.cta-block h3{font-family:var(--font-display);font-weight:600;font-size:23px;letter-spacing:-.01em;margin:16px 0 6px}
.cta-block>p{font-size:15px;color:var(--muted);margin:0 0 22px;max-width:520px;line-height:1.55}

/* CTA — полноширинный цветной баннер (страница статьи) */
.cta-banner{width:100%;margin:56px 0 0;padding:72px 28px;color:#fff;text-align:center;
  background:
    radial-gradient(120% 130% at 15% 0%, #8a6bff 0%, transparent 55%),
    radial-gradient(120% 130% at 100% 100%, #5a37e0 0%, transparent 60%),
    linear-gradient(135deg, #6a45ff, #5733cf)}
.cta-inner{max-width:720px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.cta-banner .cta-flag{background:rgba(255,255,255,.16);border:0;color:#fff}
.cta-banner h3{font-family:var(--font-display);font-weight:600;font-size:33px;line-height:1.12;letter-spacing:-.02em;
  margin:20px 0 0;text-wrap:balance;color:#fff}
.cta-banner .cta-inner>p{font-size:17px;line-height:1.55;color:rgba(255,255,255,.88);margin:16px 0 0;max-width:540px}
.cta-actions{margin-top:30px;width:100%;display:flex;justify-content:center}
.cta-main{display:flex;align-items:center;gap:16px;background:#fff;color:var(--ink);border-radius:16px;
  padding:16px 20px;min-width:420px;text-align:left;box-shadow:0 18px 40px -18px rgba(0,0,0,.5);transition:transform .14s}
.cta-main:hover{transform:translateY(-2px)}
.cta-main .cm-ic{width:48px;height:48px;border-radius:13px;background:var(--accent-soft);color:var(--accent);
  display:grid;place-items:center;flex:0 0 auto}
.cta-main .cm-ic svg{width:26px;height:26px}
.cta-main .cm-tx{display:flex;flex-direction:column;gap:3px}
.cta-main .cm-tx b{font-family:var(--font-display);font-weight:600;font-size:16px}
.cta-main .cm-tx span{font-size:13px;color:var(--muted);font-weight:400}
.cta-main .cm-arrow{margin-left:auto;font-size:20px;color:var(--accent);font-weight:600}
.cta-banner .cta-links{display:flex;gap:14px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.cta-banner .cta-link{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);border-radius:13px;padding:13px 18px;font-size:14px;font-weight:500;
  color:#fff;cursor:pointer;transition:background .15s,border-color .15s}
.cta-banner .cta-link:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.4)}
.cta-banner .cta-link .em{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.16);color:#fff;
  display:grid;place-items:center;flex:0 0 auto}
.cta-banner .cta-link .em svg{width:17px;height:17px}
.cta-primary{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px}
.cta-primary .av{width:54px;height:54px;border-radius:14px;background:var(--accent);display:grid;place-items:center;color:#fff;flex:0 0 auto}
.cta-primary .av svg{width:26px;height:26px}
.cta-primary .ct-tx b{font-family:var(--font-display);font-weight:600;font-size:17px;display:block;margin-bottom:3px}
.cta-primary .ct-tx span{font-size:13.5px;color:var(--muted)}
.cta-primary .btn{margin-left:auto;flex:0 0 auto}
.cta-links{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.cta-link{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:13px;
  padding:13px 16px;font-size:14px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:border-color .15s,color .15s}
.cta-link:hover{border-color:var(--accent);color:var(--accent)}
.cta-link .em{width:32px;height:32px;border-radius:9px;background:var(--accent-soft);display:grid;place-items:center;flex:0 0 auto;color:var(--accent)}
.cta-link .em svg{width:17px;height:17px}

/* Похожие статьи */
.related{margin:56px 0 0;padding-top:40px;border-top:1px solid var(--line-2)}
.related h3{font-family:var(--font-display);font-weight:600;font-size:20px;letter-spacing:-.01em;margin:0 0 22px}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rel-card{cursor:pointer}
.rel-card .cover{aspect-ratio:16/10;margin-bottom:13px}
.rel-card .c-cat{margin-bottom:8px}
.rel-card h4{font-size:16px;font-weight:600;line-height:1.3;letter-spacing:-.01em;margin:0 0 8px;transition:color .15s}
.rel-card:hover h4{color:var(--accent)}

/* Share */
.share{display:flex;align-items:center;gap:9px}
.share .sh-btn{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);background:#fff;display:grid;
  place-items:center;cursor:pointer;color:var(--muted);transition:all .15s}
.share .sh-btn:hover{border-color:var(--accent);color:var(--accent)}
.share .sh-lbl{font-size:12.5px;color:var(--faint);margin-right:4px}

/* ===================== СТАТЬЯ A — узкая колонка + боковой TOC ===================== */
.artA .a-head{max-width:760px;margin:0 auto;padding:44px 0 0;text-align:left}
.artA .a-cat{margin-bottom:18px}
.artA h1{font-weight:800;font-size:42px;line-height:1.08;letter-spacing:-.025em;margin:0;color:var(--ink)}
.artA .a-meta{display:flex;align-items:center;gap:16px;margin:26px 0 0;flex-wrap:wrap}
.artA .a-author{display:flex;align-items:center;gap:10px}
.artA .a-author .av{width:38px;height:38px;border-radius:50%;background:var(--accent-soft);display:grid;place-items:center;
  color:var(--accent);font-weight:700;font-size:14px}
.artA .a-author b{font-size:14px;font-weight:600;display:block}
.artA .a-author span{font-size:12.5px;color:var(--faint)}
.artA .a-meta .share{margin-left:auto}
.artA .a-cover{max-width:980px;margin:32px auto 0}
.artA .a-cover .cover{aspect-ratio:21/9}
.artA .a-grid{max-width:none;margin:44px auto 0;display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,300px);gap:clamp(32px,4vw,54px);align-items:start;padding-bottom:60px}
.artA .a-body{min-width:0;max-width:none;width:100%}
.artA .a-aside{position:sticky;top:24px;display:flex;flex-direction:column;gap:22px}
.toc .toc-t{font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:0 0 14px}
.toc ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;border-left:2px solid var(--line)}
.toc a{display:block;padding:7px 0 7px 16px;margin-left:-2px;border-left:2px solid transparent;font-size:13.5px;
  line-height:1.4;color:var(--muted);text-decoration:none;transition:all .15s;cursor:pointer;position:relative;z-index:1}
.toc a.toc-h3{padding-left:28px;font-size:13px}
.toc li{list-style:none;margin:0;padding:0}
.prose h2,.prose h3{scroll-margin-top:100px}
.toc a:hover{color:var(--ink)}
.toc a.active{color:var(--accent);border-left-color:var(--accent);font-weight:600}
.aside-cta{background:var(--ink);border-radius:16px;padding:18px;color:#fff}
.aside-cta b{font-size:14px;display:block;margin-bottom:5px;font-family:var(--font-display);font-weight:600}
.aside-cta p{font-size:12.5px;color:rgba(255,255,255,.62);margin:0 0 13px;line-height:1.5}
.aside-cta .btn{width:100%;display:flex;justify-content:center;background:var(--accent);color:#fff;padding:9px}

/* ===================== СТАТЬЯ B — левый рельс мета+TOC, широкая колонка ===================== */
.artB .b-hero{padding:46px 40px 30px;border-bottom:1px solid var(--line-2)}
.artB .b-cat{margin-bottom:16px}
.artB h1{font-family:var(--font-display);font-weight:600;font-size:40px;line-height:1.1;letter-spacing:-.025em;margin:0;max-width:880px}
.artB .b-sub{font-size:17px;color:var(--muted);margin:18px 0 0;max-width:680px;line-height:1.5}
.artB .b-cover{padding:28px 40px 0}
.artB .b-cover .cover{aspect-ratio:24/9}
.artB .b-grid{display:grid;grid-template-columns:230px 1fr;gap:48px;padding:36px 40px 60px}
.artB .b-rail{position:sticky;top:24px;align-self:start;display:flex;flex-direction:column;gap:26px}
.artB .b-rail .rl-block .rl-t{font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:0 0 12px}
.artB .b-rail .rl-meta{display:flex;flex-direction:column;gap:14px}
.artB .b-rail .rl-meta .rm{display:flex;align-items:center;gap:11px}
.artB .b-rail .rl-meta .rm .av{width:36px;height:36px;border-radius:50%;background:var(--accent-soft);display:grid;
  place-items:center;color:var(--accent);font-weight:700;font-size:13px;flex:0 0 auto}
.artB .b-rail .rl-meta .rm b{font-size:13.5px;font-weight:600;display:block}
.artB .b-rail .rl-meta .rm span{font-size:12px;color:var(--faint)}
.artB .b-body{min-width:0;max-width:720px}

/* ===================== МОБАЙЛ ===================== */
.screen.m{font-size:15px}
.m .site-head{padding:15px 18px;gap:14px}
.m .site-head .logo{font-size:17px}
.m .site-nav,.m .head-cta .btn-ghost{display:none}
.m .head-cta{margin-left:auto}
.m .head-cta .btn-primary{padding:9px 13px;font-size:12.5px}
.m .burger{width:24px;height:24px;display:flex;flex-direction:column;justify-content:center;gap:5px;margin-left:auto;cursor:pointer}
.m .burger i{height:2px;background:var(--ink);border-radius:2px;display:block}

.m-list{padding:22px 18px 30px}
.m-list .m-h{font-family:var(--font-display);font-weight:700;font-size:34px;letter-spacing:-.025em;margin:0}
.m-list .m-sub{font-size:14px;color:var(--muted);margin:8px 0 20px}
.m-search{display:flex;align-items:center;gap:9px;background:var(--chip);border:1px solid var(--line);border-radius:12px;
  padding:11px 14px;margin-bottom:16px}
.m-search svg{color:var(--faint)}
.m-search input{border:0;outline:none;background:transparent;font-family:var(--font-sans);font-size:14px;width:100%}
.m-chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:14px;margin-bottom:6px;scrollbar-width:none}
.m-chips::-webkit-scrollbar{display:none}
.m-chips .chip{flex:0 0 auto}
.m-featured{margin:8px 0 24px}
.m-featured .cover{aspect-ratio:16/10;margin-bottom:13px}
.m-featured h2{font-family:var(--font-display);font-weight:600;font-size:21px;line-height:1.18;letter-spacing:-.015em;margin:0}
.m-cards{display:flex;flex-direction:column;gap:24px}
.m-card .cover{aspect-ratio:16/10;margin-bottom:12px}
.m-card .c-cat{margin-bottom:8px}
.m-card h3{font-size:17px;font-weight:600;line-height:1.28;margin:0 0 9px}
.m-card .c-ex{font-size:13.5px;color:var(--muted);line-height:1.5;margin:0}
.m-div{height:1px;background:var(--line-2);margin:24px 0}

.m-art{padding:20px 18px 30px}
.m-art .a-cat{margin-bottom:14px}
.m-art h1{font-weight:800;font-size:28px;line-height:1.14;letter-spacing:-.02em;margin:0}
.m-art .a-meta{display:flex;align-items:center;gap:12px;margin:18px 0 20px;font-size:13px;color:var(--faint)}
.m-art .a-cover{margin:0 -18px 24px}
.m-art .a-cover .cover{aspect-ratio:16/10;border-radius:0}
.m-art .prose{font-size:16.5px;line-height:1.7}
.m-art .prose .lead{font-size:18px}
.m-art .prose h2{font-size:21px;margin:34px 0 14px}
.m-art .prose blockquote{font-size:18px}
.m-cta-bar{position:sticky;bottom:0;display:flex;align-items:center;gap:12px;padding:13px 16px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.m-cta-bar .av{width:38px;height:38px;border-radius:11px;background:var(--accent);display:grid;place-items:center;color:#fff;flex:0 0 auto}
.m-cta-bar b{font-size:13.5px;display:block}
.m-cta-bar span{font-size:11.5px;color:var(--muted)}
.m-cta-bar .btn{margin-left:auto;flex:0 0 auto;padding:9px 14px;font-size:13px}

/* ===================== НАСТОЯЩИЕ СТРАНИЦЫ (standalone A) ===================== */
body.viora-blog-surface.page{background:var(--paper,#fff);color:var(--ink,#161420);font-family:var(--font-sans,'Onest',system-ui,sans-serif);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.viora-blog-surface.page .site-head{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.86);backdrop-filter:blur(10px)}
body.viora-blog-surface.page .site-head .inner,
body.viora-blog-surface.page .laA,
body.viora-blog-surface.page .breadcrumb-wrap{max-width:none;margin:0;width:100%}
body.viora-blog-surface.page .site-head{padding:0}
body.viora-blog-surface.page .site-head .inner{display:flex;align-items:center;gap:28px;padding:18px 28px}
body.viora-blog-surface.page .breadcrumb{max-width:none;margin:0;padding:16px clamp(18px,4vw,48px)}
body.viora-blog-surface.page .laA{padding:0 clamp(18px,4vw,48px) 64px}
body.viora-blog-surface.page .artA .a-head,
body.viora-blog-surface.page .artA .a-cover,
body.viora-blog-surface.page .artA .a-grid,
body.viora-blog-surface.page .artA .art-foot{padding-left:28px;padding-right:28px}
body.viora-blog-surface.page .artA .art-foot{max-width:680px;margin:0 auto;padding-bottom:72px}
/* прогресс-бар поверх всего */
body.viora-blog-surface.page .progress{position:sticky;top:0;z-index:30}
/* подвал */
.site-foot{border-top:1px solid var(--line-2);margin-top:20px}
.site-foot .inner{max-width:var(--maxw);margin:0 auto;padding:40px 28px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.site-foot .logo{font-size:18px}
.site-foot .f-links{display:flex;gap:22px;flex-wrap:wrap}
.site-foot .f-links a{font-size:14px;color:var(--muted);text-decoration:none}
.site-foot .f-links a:hover{color:var(--accent)}
.site-foot .f-copy{margin-left:auto;font-size:13px;color:var(--faint)}

@media (max-width:1080px){
  .la-featured{grid-template-columns:1fr;gap:22px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .artA .a-grid{grid-template-columns:1fr}
  .artA .a-aside{display:none}
  .lbB{grid-template-columns:1fr}
  .lb-rail{position:static;border-right:0;border-bottom:1px solid var(--line-2)}
  .artB .b-grid{grid-template-columns:1fr}
  .artB .b-rail{display:none}
  .rel-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  body.viora-blog-surface.page .site-head .inner{padding:14px 18px;gap:14px}
  body.viora-blog-surface.page .site-nav{display:none}
  body.viora-blog-surface.page .head-cta .btn-ghost{display:none}
  body.viora-blog-surface.page .laA{padding:0 18px 48px}
  .la-hero-top h1{font-size:38px}
  .grid{grid-template-columns:1fr;gap:28px}
  .filterbar{flex-wrap:wrap;gap:12px}
  .search{margin-left:0;width:100%;order:2}
  .news-strip{flex-direction:column;align-items:flex-start;gap:16px;padding:24px}
  .news-form{margin-left:0;width:100%}
  .news-form input{width:100%}
  body.viora-blog-surface.page .breadcrumb{padding:14px 18px;flex-wrap:wrap}
  body.viora-blog-surface.page .artA .a-head,
  body.viora-blog-surface.page .artA .a-cover,
  body.viora-blog-surface.page .artA .a-grid,
  body.viora-blog-surface.page .artA .art-foot{padding-left:18px;padding-right:18px}
  .artA h1{font-size:30px}
  .artA .a-cover .cover{aspect-ratio:16/10}
  .prose{font-size:17px}
  .prose .lead{font-size:19px}
  .prose h2{font-size:22px}
  .rel-grid{grid-template-columns:1fr}
  .site-foot .inner{flex-direction:column;align-items:flex-start;gap:16px}
  .site-foot .f-copy{margin-left:0}
  .cta-banner{padding:48px 18px}
  .cta-banner h3{font-size:26px}
  .cta-main{min-width:0;width:100%;padding:14px 16px;gap:13px}
  .cta-main .cm-ic{width:42px;height:42px}
  .cta-banner .cta-links{flex-direction:column;width:100%}
  .cta-banner .cta-link{justify-content:flex-start}
}

/* CTA-баннер: перебиваем глобальные h3 и nav .btn на блоге */
body.viora-blog-surface #viora-blog-root .cta-banner .cta-inner h3 {
  color: #fff;
}

body.viora-blog-surface #viora-blog-root .cta-banner .cta-inner > p {
  color: rgba(255, 255, 255, 0.88);
}

body.viora-blog-surface #viora-blog-root .cta-banner .cta-main.btn {
  background: #fff;
  color: var(--ink);
  border: none;
  box-shadow: 0 18px 40px -18px rgba(0, 0, 0, 0.45);
  text-decoration: none;
}

body.viora-blog-surface #viora-blog-root .cta-banner .cta-main.btn:hover {
  background: #fff;
  color: var(--ink);
  transform: translateY(-2px);
  box-shadow: 0 22px 44px -18px rgba(0, 0, 0, 0.5);
}

body.viora-blog-surface #viora-blog-root .cta-banner .cta-main .cm-tx b {
  color: var(--ink);
}

body.viora-blog-surface #viora-blog-root .cta-banner .cta-main .cm-tx span {
  color: var(--ink-2);
}

body.viora-blog-surface #viora-blog-root .cta-banner .cta-main .cm-arrow {
  color: var(--accent);
}

/* Full-bleed blog shell — no side “frame” from theme container */
body.viora-blog-surface .site-wrapper {
  max-width: none !important;
  width: 100%;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  overflow-x: clip;
}

body.viora-blog-surface #main.site-content.blog-page,
body.viora-blog-surface #main.site-content {
  margin: 0 !important;
  overflow-x: clip;
}

body.viora-blog-surface #viora-blog-root .laA {
  max-width: none;
  width: 100%;
  padding-left: clamp(18px, 4vw, 56px);
  padding-right: clamp(18px, 4vw, 56px);
}

body.viora-blog-surface #viora-blog-root .la-hero-top,
body.viora-blog-surface #viora-blog-root .la-featured,
body.viora-blog-surface #viora-blog-root .filterbar,
body.viora-blog-surface #viora-blog-root .grid {
  width: 100%;
  max-width: none;
}

body.viora-blog-surface #viora-blog-root .artA .a-head,
body.viora-blog-surface #viora-blog-root .artA .a-cover,
body.viora-blog-surface #viora-blog-root .artA .a-grid,
body.viora-blog-surface #viora-blog-root .artA .art-foot {
  max-width: none;
  padding-left: clamp(18px, 4vw, 56px);
  padding-right: clamp(18px, 4vw, 56px);
}

body.viora-blog-surface #viora-blog-root .artA .a-grid {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
}

@media (max-width: 1080px) {
  body.viora-blog-surface #viora-blog-root .artA .a-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  body.viora-blog-surface #main.site-content {
    padding-top: 76px !important;
  }

  body.viora-blog-surface #viora-blog-root .laA,
  body.viora-blog-surface #viora-blog-root .artA .a-head,
  body.viora-blog-surface #viora-blog-root .artA .a-cover,
  body.viora-blog-surface #viora-blog-root .artA .a-grid,
  body.viora-blog-surface #viora-blog-root .artA .art-foot {
    padding-left: clamp(16px, 5vw, 24px);
    padding-right: clamp(16px, 5vw, 24px);
  }
}

body.viora-blog-surface #viora-blog-root .artA .a-meta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  flex-wrap: nowrap;
  width: 100%;
}

body.viora-blog-surface #viora-blog-root .artA .a-author {
  flex: 0 1 auto;
  min-width: 0;
}

body.viora-blog-surface #viora-blog-root .artA .a-meta .share {
  display: flex !important;
  align-items: center;
  gap: 9px;
  margin-left: auto;
  flex: 0 0 auto;
  visibility: visible !important;
  opacity: 1 !important;
}

body.viora-blog-surface #viora-blog-root .share .sh-lbl {
  font-size: 12.5px;
  color: var(--faint);
  margin-right: 4px;
  white-space: nowrap;
}

body.viora-blog-surface #viora-blog-root .share .sh-btn {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 1px solid var(--line) !important;
  border-radius: 11px !important;
  background: #fff !important;
  color: var(--muted) !important;
  display: grid !important;
  place-items: center !important;
  box-shadow: none !important;
  transform: none !important;
  font-size: 0 !important;
  line-height: 0 !important;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  appearance: none;
  -webkit-appearance: none;
}

body.viora-blog-surface #viora-blog-root .share .sh-btn svg {
  width: 16px;
  height: 16px;
  display: block;
}

body.viora-blog-surface #viora-blog-root .share .sh-btn:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  background: #fff !important;
  transform: none !important;
  box-shadow: none !important;
}

body.viora-blog-surface #viora-blog-root .share .sh-btn.is-copied {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

@media (max-width: 720px) {
  body.viora-blog-surface #viora-blog-root .artA .a-meta {
    flex-wrap: wrap;
  }

  body.viora-blog-surface #viora-blog-root .artA .a-meta .share {
    margin-left: 0;
    width: 100%;
  }
}

/* Подвал на всю ширину экрана — без белого хвоста снизу (без 100vw hack) */
body.viora-blog-surface .site-footer-unified {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  flex-shrink: 0;
}

body.viora-blog-surface .footer-container-unified {
  width: 100% !important;
  max-width: min(95vw, 1440px) !important;
  margin: 0 auto !important;
  padding-left: clamp(1.5rem, 4vw, 4rem) !important;
  padding-right: clamp(1.5rem, 4vw, 4rem) !important;
  box-sizing: border-box !important;
}

body.viora-blog-surface,
html:has(body.viora-blog-surface) {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
