/* ===== PearCMS — внутренние страницы | LIGHT =====
 * Парный к pages.css. Большинство стилей опирается на CSS-переменные из
 * pearcms-light.css (--space-*, --fg-*, --line, --pear*, --leaf*), поэтому
 * структура и значения практически идентичны dark-версии. Отличия:
 *   - sticky-плашка кабинета (cab-top) — бумажный полупрозрачный фон вместо тёмного
 *   - alert-баннеры — насыщенные текстовые цвета для контраста на бумаге
 *   - cookie-banner — светлая подложка вместо тёмной
 *   - prev-a..prev-f (превьюшки шаблонов) — оставлены тёмными: это «скриншоты»
 *     демо-сайтов, их вид должен быть постоянным, не зависеть от темы Aurora.
 */

/* подшапка / хлебные крошки */
.subhead{ padding:48px 0 8px }
.crumbs{ font-family:var(--f-mono); font-size:12px; color:var(--fg-mute); letter-spacing:.04em; display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:18px }
.crumbs a:hover{ color:var(--accent) }
.crumbs .sep{ opacity:.5 }
.crumbs .cur{ color:var(--fg-dim) }
.subhead h1{ font-family:var(--f-display); font-weight:600; font-size:clamp(30px,4.4vw,46px); letter-spacing:-.02em; line-height:1.08; margin:0 0 12px }
.subhead p{ color:var(--fg-dim); font-size:16px; margin:0; max-width:680px }

/* фильтр-чипы */
.chips{ display:flex; gap:8px; flex-wrap:wrap; margin:28px 0 6px }
.chip{ padding:9px 16px; border-radius:999px; font-size:14px; font-weight:500; border:1px solid var(--line-2); color:var(--fg-dim); transition:all .15s; white-space:nowrap }
.chip:hover{ color:var(--fg); border-color:var(--fg-mute) }
.chip.active{ background:var(--pear); color:#1c1d17; border-color:var(--pear) }

/* каталог (темы / модули) */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
@media (max-width:920px){ .cat-grid{ grid-template-columns:1fr 1fr } }
@media (max-width:600px){ .cat-grid{ grid-template-columns:1fr } }
.cat-card{ background:var(--space-1); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .2s, border-color .2s, box-shadow .2s }
.cat-card:hover{ transform:translateY(-4px); border-color:var(--line-2); box-shadow:var(--shadow-md) }
.cat-prev{ height:170px; position:relative; overflow:hidden; border-bottom:1px solid var(--line); display:grid; place-items:center }
.cat-prev .tag{ position:absolute; top:12px; left:12px; font-family:var(--f-mono); font-size:10px; text-transform:uppercase; letter-spacing:.08em; background:rgba(253,250,240,.85); border:1px solid var(--line-2); color:var(--fg-dim); padding:4px 9px; border-radius:6px; backdrop-filter:blur(4px) }
.cat-prev .badge{ position:absolute; top:12px; right:12px; font-family:var(--f-mono); font-size:10px; font-weight:600; background:var(--leaf-deep); color:#fff; padding:4px 9px; border-radius:6px }
.cat-prev .pvic{ color:#fff; opacity:.92 }
.cat-body{ padding:18px 18px 20px; display:flex; flex-direction:column; flex:1 }
.cat-body h3{ font-family:var(--f-display); font-weight:600; font-size:18px; margin:0 0 6px; letter-spacing:-.01em }
.cat-body p{ color:var(--fg-dim); font-size:14px; margin:0 0 16px; flex:1 }
.cat-meta{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding-top:14px; border-top:1px solid var(--line) }
.cat-meta .price{ font-family:var(--f-display); font-weight:600; font-size:18px }
.cat-meta .free{ color:var(--leaf-deep) }
.cat-meta .rate{ font-size:13px; color:var(--fg-mute); display:inline-flex; align-items:center; gap:5px }
.cat-meta .rate .star{ color:var(--pear-deep) }
/* превью-плашки шаблонов: оставляем тёмными — это «скриншоты» */
.prev-a{ background:linear-gradient(135deg,#1a2740,#0e1119) }
.prev-b{ background:linear-gradient(135deg,#2a2415,#0e1119) }
.prev-c{ background:linear-gradient(135deg,#15281c,#0e1119) }
.prev-d{ background:linear-gradient(135deg,#2a1530,#0e1119) }
.prev-e{ background:linear-gradient(135deg,#102a2a,#0e1119) }
.prev-f{ background:linear-gradient(135deg,#2a1018,#0e1119) }
.prev-a::after,.prev-b::after,.prev-c::after,.prev-d::after,.prev-e::after,.prev-f::after{ content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%; background:radial-gradient(circle,rgba(230,210,74,.3),transparent 70%) }

/* статья / деталь */
.article{ display:grid; grid-template-columns:1fr 300px; gap:44px; align-items:start; padding-top:8px }
@media (max-width:980px){ .article{ grid-template-columns:1fr } }
.article-body{ max-width:760px; min-width:0 }
.article-cover{ height:300px; border-radius:var(--radius); border:1px solid var(--line-2); overflow:hidden; position:relative; margin-bottom:28px }
.article-cover::after{ content:""; position:absolute; right:-60px; top:-60px; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle,rgba(168,134,28,.22),transparent 70%) }
.article-body h2{ font-family:var(--f-display); font-weight:600; font-size:26px; letter-spacing:-.015em; margin:40px 0 14px }
.article-body h3{ font-family:var(--f-display); font-weight:600; font-size:20px; margin:28px 0 10px }
.article-body p{ color:var(--fg-dim); font-size:16px; line-height:1.75; margin:0 0 16px }
.article-body ul{ margin:0 0 18px; padding-left:0; list-style:none }
.article-body ul li{ position:relative; padding-left:24px; margin-bottom:10px; color:var(--fg-dim) }
.article-body ul li::before{ content:""; position:absolute; left:3px; top:10px; width:6px; height:6px; border-radius:50%; background:var(--pear-deep) }
.article-body blockquote{ margin:24px 0; padding:6px 0 6px 20px; border-left:2px solid var(--pear-deep); font-family:var(--f-display); font-style:italic; font-size:18px; color:var(--fg) }
.article-meta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; font-family:var(--f-mono); font-size:12px; color:var(--fg-mute); margin-bottom:24px; padding-bottom:22px; border-bottom:1px solid var(--line) }
.article-meta .cat{ color:var(--accent) }
.aside-card{ background:var(--space-1); border:1px solid var(--line); border-radius:var(--radius); padding:22px; position:sticky; top:88px }
.aside-card h4{ font-family:var(--f-mono); font-size:11px; text-transform:uppercase; letter-spacing:.14em; color:var(--fg-mute); margin:0 0 14px }
.aside-card .row{ display:flex; justify-content:space-between; gap:12px; padding:10px 0; border-bottom:1px solid var(--line); font-size:14px }
.aside-card .row:last-of-type{ border-bottom:0 }
.aside-card .row span{ color:var(--fg-mute) }
.aside-card .row b{ font-weight:500 }
.aside-card .btn{ width:100%; justify-content:center; margin-top:16px }
.gallery{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:6px 0 22px }
.gallery div{ height:120px; border-radius:11px; border:1px solid var(--line) }

/* поддержка */
.sup-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:42px }
@media (max-width:820px){ .sup-grid{ grid-template-columns:1fr } }
.sup-card{ background:var(--space-1); border:1px solid var(--line); border-radius:var(--radius); padding:26px; transition:border-color .2s, transform .2s }
.sup-card:hover{ border-color:var(--line-2); transform:translateY(-3px) }
.sup-card .ic{ width:50px; height:50px; border-radius:13px; background:var(--space-3); border:1px solid var(--line-2); display:grid; place-items:center; color:var(--accent); margin-bottom:16px }
.sup-card h3{ font-family:var(--f-display); font-weight:600; font-size:19px; margin:0 0 8px }
.sup-card p{ color:var(--fg-dim); font-size:14px; margin:0 0 14px }
.sup-card a.more{ font-family:var(--f-mono); font-size:12px; color:var(--accent); display:inline-flex; gap:7px; align-items:center }
.faq{ max-width:820px }
details.faq-item{ background:var(--space-1); border:1px solid var(--line); border-radius:12px; padding:2px 20px; margin-bottom:12px }
details.faq-item[open]{ border-color:var(--line-2) }
details.faq-item summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; padding:18px 0; font-family:var(--f-display); font-size:17px; font-weight:500 }
details.faq-item summary::-webkit-details-marker{ display:none }
details.faq-item summary .ic{ width:26px; height:26px; border-radius:50%; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--fg-mute); flex-shrink:0; transition:transform .25s }
details.faq-item[open] summary .ic{ transform:rotate(45deg); color:var(--accent); border-color:var(--pear-deep) }
details.faq-item .ans{ padding:0 0 18px; color:var(--fg-dim); font-size:15px; line-height:1.65 }

/* ===== Кабинет ===== */
.cab{ display:grid; grid-template-columns:260px 1fr; min-height:100vh }
@media (max-width:900px){ .cab{ grid-template-columns:1fr } }
.cab-side{ border-right:1px solid var(--line); background:var(--space-1); display:flex; flex-direction:column; position:sticky; top:0; height:100vh; overflow-y:auto }
@media (max-width:900px){ .cab-side{ position:static; height:auto } }
.cab-brand{ display:flex; align-items:center; gap:11px; padding:18px 20px; border-bottom:1px solid var(--line) }
.cab-brand .mark{ width:38px; height:38px; border-radius:11px; background:radial-gradient(circle at 35% 30%, #fdfaf0, #ece5cd); border:1px solid var(--line-2); display:grid; place-items:center; overflow:hidden }
.cab-brand .mark img{ width:28px; height:28px; object-fit:contain }
.cab-brand b{ font-family:var(--f-display); font-size:17px }
.cab-brand span{ font-family:var(--f-mono); font-size:10px; color:var(--fg-mute); text-transform:uppercase; letter-spacing:.14em; display:block }
.cab-nav{ padding:14px 12px; display:flex; flex-direction:column; gap:3px; flex:1 }
.cab-nav .lbl{ font-family:var(--f-mono); font-size:10px; text-transform:uppercase; letter-spacing:.14em; color:var(--fg-mute); padding:14px 12px 6px }
.cab-nav a{ display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:10px; font-size:14.5px; color:var(--fg-dim); transition:background .15s, color .15s }
.cab-nav a:hover{ background:var(--space-2); color:var(--fg) }
.cab-nav a.active{ background:var(--pear); color:#1c1d17; font-weight:500 }
.cab-nav a.active svg{ color:#1c1d17 }
.cab-nav a svg{ color:var(--fg-mute); flex-shrink:0 }
.cab-nav a .tail{ margin-left:auto; font-family:var(--f-mono); font-size:11px; color:var(--accent) }
.cab-nav a.active .tail{ color:#1c1d17 }
.cab-user{ border-top:1px solid var(--line); padding:14px; display:flex; align-items:center; gap:11px }
.cab-user .av{ width:38px; height:38px; border-radius:50%; background:var(--space-3); border:1px solid var(--line-2); display:grid; place-items:center; color:var(--accent); font-family:var(--f-display); font-weight:600 }
.cab-user .nm{ flex:1; min-width:0 }
.cab-user .nm b{ font-size:14px; display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.cab-user .nm span{ font-size:12px; color:var(--fg-mute) }
.cab-user a{ color:var(--fg-mute) }
.cab-user a:hover{ color:var(--accent) }

.cab-main{ min-width:0; display:flex; flex-direction:column }
/* sticky-плашка кабинета — бумажная полупрозрачная */
.cab-top{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:16px 28px; border-bottom:1px solid var(--line); position:sticky; top:0; background:rgba(253,250,240,.85); backdrop-filter:blur(14px); z-index:20 }
.cab-top h1{ font-family:var(--f-display); font-weight:600; font-size:20px; margin:0 }
.cab-top .acts{ display:flex; align-items:center; gap:10px }
.cab-burger{ display:none; width:40px; height:40px; border-radius:10px; border:1px solid var(--line-2); align-items:center; justify-content:center }
@media (max-width:900px){ .cab-burger{ display:inline-flex } .cab-side{ display:none } body.cab-open .cab-side{ display:flex; position:fixed; inset:0 auto 0 0; width:280px; z-index:60 } body.cab-open::after{ content:""; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:55 } }
.cab-content{ padding:28px; display:flex; flex-direction:column; gap:22px }

.kpis{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px }
@media (max-width:820px){ .kpis{ grid-template-columns:1fr 1fr } }
@media (max-width:460px){ .kpis{ grid-template-columns:1fr } }
.kpi{ background:var(--space-1); border:1px solid var(--line); border-radius:14px; padding:20px }
.kpi .k-ic{ width:40px; height:40px; border-radius:11px; background:var(--space-3); border:1px solid var(--line-2); display:grid; place-items:center; color:var(--accent); margin-bottom:14px }
.kpi b{ font-family:var(--f-display); font-weight:600; font-size:28px; letter-spacing:-.01em; display:block; line-height:1 }
.kpi span{ font-size:13px; color:var(--fg-mute); margin-top:6px; display:block }
.kpi .trend{ font-size:12px; color:var(--leaf-deep); margin-top:8px; display:inline-flex; gap:5px; align-items:center }

.panel{ background:var(--space-1); border:1px solid var(--line); border-radius:16px; overflow:hidden }
.panel-h{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:18px 22px; border-bottom:1px solid var(--line) }
.panel-h h2{ font-family:var(--f-display); font-weight:600; font-size:18px; margin:0 }
.panel-h a{ font-size:13px; color:var(--accent) }
.panel-b{ padding:22px }
.cols2{ display:grid; grid-template-columns:1fr 1fr; gap:22px }
@media (max-width:980px){ .cols2{ grid-template-columns:1fr } }

table.tbl{ width:100%; border-collapse:collapse; font-size:14px }
table.tbl th{ text-align:left; padding:12px 22px; background:var(--space-2); border-bottom:1px solid var(--line); font-family:var(--f-mono); font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--fg-mute); font-weight:500 }
table.tbl td{ padding:13px 22px; border-bottom:1px solid var(--line); color:var(--fg-dim) }
table.tbl tr:last-child td{ border-bottom:0 }
.pill{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:500; padding:3px 10px; border-radius:999px }
.pill.ok{ background:rgba(67,107,31,.14); color:var(--leaf-deep) }
.pill.warn{ background:rgba(168,134,28,.18); color:var(--accent) }
.pill.err{ background:rgba(166,64,42,.14); color:#a6402a }

/* settings form */
.set-row{ display:grid; grid-template-columns:240px 1fr; gap:24px; padding:22px; border-bottom:1px solid var(--line) }
@media (max-width:760px){ .set-row{ grid-template-columns:1fr; gap:12px } }
.set-row:last-child{ border-bottom:0 }
.set-row .lab b{ font-size:15px; display:block; margin-bottom:4px }
.set-row .lab span{ font-size:13px; color:var(--fg-mute) }
.set-field input, .set-field select, .set-field textarea{ width:100%; background:var(--space-2); border:1px solid var(--line-2); border-radius:10px; padding:12px 14px; color:var(--fg); font:inherit; font-size:14px; transition:border-color .15s }
.set-field input:focus, .set-field select:focus, .set-field textarea:focus{ outline:none; border-color:var(--pear-deep) }
.set-field .hintx{ font-size:12px; color:var(--fg-mute); margin-top:7px }
.switch{ position:relative; width:46px; height:26px; border-radius:999px; background:var(--space-3); border:1px solid var(--line-2); cursor:pointer; transition:background .2s }
.switch.on{ background:var(--pear-deep); border-color:var(--pear-deep) }
.switch i{ position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%; background:var(--fg); transition:transform .2s }
.switch.on i{ transform:translateX(20px); background:var(--space) }
.set-toggles{ display:flex; flex-direction:column; gap:16px }
.set-toggle{ display:flex; align-items:center; justify-content:space-between; gap:16px }
.set-toggle .tt b{ font-size:14px; display:block }
.set-toggle .tt span{ font-size:12.5px; color:var(--fg-mute) }
.tabs{ display:flex; gap:6px; border-bottom:1px solid var(--line); padding:0 22px; overflow-x:auto }
.tabs button{ padding:14px 6px; margin-right:14px; font-size:14px; color:var(--fg-dim); border-bottom:2px solid transparent; white-space:nowrap }
.tabs button.active{ color:var(--fg); border-bottom-color:var(--pear-deep) }

/* kassa */
.balance{ background:linear-gradient(150deg,var(--space-2),var(--space-1)); border:1px solid var(--line-2); border-radius:18px; padding:26px; position:relative; overflow:hidden }
.balance::after{ content:""; position:absolute; right:-50px; top:-50px; width:200px; height:200px; border-radius:50%; background:radial-gradient(circle,rgba(168,134,28,.14),transparent 70%) }
.balance .lbl{ font-family:var(--f-mono); font-size:11px; text-transform:uppercase; letter-spacing:.14em; color:var(--fg-mute) }
.balance .amt{ font-family:var(--f-display); font-weight:600; font-size:44px; letter-spacing:-.02em; margin:8px 0 4px }
.balance .sub{ font-size:13px; color:var(--fg-mute) }
.amounts{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin:4px 0 18px }
@media (max-width:560px){ .amounts{ grid-template-columns:1fr 1fr } }
.amt-btn{ padding:14px; border-radius:12px; border:1px solid var(--line-2); font-family:var(--f-display); font-weight:600; font-size:18px; color:var(--fg); transition:all .15s }
.amt-btn:hover{ border-color:var(--fg-mute) }
.amt-btn.active{ border-color:var(--pear-deep); background:rgba(230,210,74,.18); color:var(--accent) }
.amt-input{ display:flex; gap:10px; align-items:center; margin-bottom:20px }
.amt-input input{ flex:1; background:var(--space-2); border:1px solid var(--line-2); border-radius:11px; padding:14px 16px; color:var(--fg); font:inherit; font-size:18px; font-family:var(--f-display); font-weight:600 }
.amt-input input:focus{ outline:none; border-color:var(--pear-deep) }
.pay-methods{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:8px }
@media (max-width:560px){ .pay-methods{ grid-template-columns:1fr } }
.pay-m{ display:flex; align-items:center; gap:10px; padding:13px 15px; border:1px solid var(--line-2); border-radius:12px; cursor:pointer; font-size:14px; color:var(--fg-dim); transition:all .15s }
.pay-m:hover{ border-color:var(--fg-mute) }
.pay-m.active{ border-color:var(--pear-deep); background:rgba(230,210,74,.14); color:var(--fg) }
.pay-m svg{ color:var(--accent) }

/* ============================================================
 * Fallback-стили для классов, которые используют PHP-шаблоны
 * темы. Светлые варианты алёртов и cookie-баннера.
 * ============================================================ */

/* ── Алёрты (flash/error/success баннеры) ── */
.alert-soft, .alert-ok, .alert-warn, .alert-error{
    padding:12px 16px;
    border-radius:10px;
    font-size:14px;
    border:1px solid var(--line-2);
    background:var(--space-1);
    color:var(--fg-dim);
    margin-bottom:16px;
}
.alert-ok   { border-color:rgba(67,107,31,.45); background:rgba(67,107,31,.08); color:var(--leaf-deep) }
.alert-warn { border-color:rgba(168,134,28,.45); background:rgba(230,210,74,.18); color:var(--accent) }
.alert-error{ border-color:rgba(166,64,42,.45); background:rgba(166,64,42,.08); color:#8a3621 }

/* ── Auth-wrap (общая обёртка login/register/forgot/2fa/reset) ── */
.auth-wrap{
    max-width:520px;
    margin:60px auto;
    padding:36px 30px;
    background:var(--space-1);
    border:1px solid var(--line);
    border-radius:18px;
}
.auth-wrap h1{
    font-family:var(--f-display);
    font-weight:600;
    font-size:28px;
    margin:0 0 12px;
}
.auth-wrap > p{ color:var(--fg-dim); margin:0 0 24px }
.auth-wrap .field, .auth-wrap .auth-field{ margin-bottom:16px }
.auth-wrap label{
    display:block;
    font-size:13px;
    color:var(--fg-mute);
    margin-bottom:6px;
    font-weight:500;
}
.auth-wrap input, .auth-wrap select, .auth-wrap textarea{
    width:100%;
    padding:12px 14px;
    background:var(--space-2);
    color:var(--fg);
    border:1px solid var(--line-2);
    border-radius:10px;
    font-size:15px;
    transition:border-color .15s;
}
.auth-wrap input:focus, .auth-wrap select:focus, .auth-wrap textarea:focus{
    outline:none;
    border-color:var(--pear-deep);
}

/* ── Avatar-drop (drag-drop загрузка аватара в профиле) ── */
.avatar-drop{
    display:flex;
    align-items:center;
    gap:14px;
    padding:16px;
    border:1px dashed var(--line-2);
    border-radius:12px;
    background:var(--space-1);
    cursor:pointer;
    transition:border-color .15s, background .15s;
}
.avatar-drop:hover{ border-color:var(--pear-deep); background:rgba(230,210,74,.10) }
.avatar-drop__icon{
    width:48px; height:48px;
    border-radius:12px;
    background:var(--space-2);
    display:grid; place-items:center;
    color:var(--fg-dim);
    flex-shrink:0;
}
.avatar-drop__text{
    font-size:14px;
    color:var(--fg);
    flex:1;
}
.avatar-drop__hint{
    font-size:12px;
    color:var(--fg-mute);
    margin-top:4px;
}
.avatar-drop__filename{
    font-size:12px;
    color:var(--accent);
    margin-top:6px;
}

/* ── Buy-action (CmsBoard покупка) ── */
.buy-action{
    margin-top:32px;
    padding:24px;
    background:var(--space-1);
    border:1px solid var(--line);
    border-radius:16px;
    text-align:center;
}
.buy-action .field{
    max-width:420px;
    margin:0 auto 16px;
}

/* ── Cab-stars (звёзды в кабинете) ── */
.cab-stars{
    display:inline-flex;
    gap:2px;
    color:var(--pear-deep);
    font-size:14px;
}

/* ── .contact (контакты в футере темы) ── */
.contact{ margin-bottom:8px; font-size:14px }
.contact a{ color:var(--fg-dim) }
.contact a:hover{ color:var(--accent) }

/* ── Cookie banner (нижняя плашка GDPR) — бумажная подложка ── */
.cookie-banner{
    position:fixed;
    left:20px; bottom:20px;
    max-width:420px;
    padding:18px 20px;
    background:linear-gradient(135deg, rgba(253,250,240,.96), rgba(246,241,224,.96));
    border:1px solid var(--line-2);
    border-radius:14px;
    backdrop-filter:blur(10px);
    z-index:50;
    box-shadow:0 14px 40px rgba(90,80,30,.18);
}
.cookie-banner__msg{
    color:var(--fg-dim);
    font-size:13px;
    line-height:1.5;
    margin-bottom:12px;
}
.cookie-banner__links{ font-size:12px; margin-bottom:12px }
.cookie-banner__links a{
    color:var(--accent);
    border-bottom:1px dashed currentColor;
    margin-right:10px;
}
.cookie-banner__btn{
    background:var(--pear);
    color:#1c1d17;
    border:0;
    padding:9px 18px;
    border-radius:10px;
    font-weight:500;
    font-size:13px;
    cursor:pointer;
    transition:opacity .15s;
}
.cookie-banner__btn:hover{ opacity:.85 }

/* ── MNews rating (звёзды-рейтинг внутри новости) ── */
.mn-rate{
    margin-top:40px;
    padding:24px;
    background:var(--space-1);
    border:1px solid var(--line);
    border-radius:14px;
    text-align:center;
}
.mn-rate__title{
    font-family:var(--f-display);
    font-weight:600;
    font-size:18px;
    margin-bottom:12px;
}
.mn-rate__stars{
    display:inline-flex;
    gap:6px;
    margin:8px 0;
}
.mn-rate__stars .mn-star{
    background:none;
    border:0;
    color:var(--fg-mute);
    font-size:28px;
    cursor:pointer;
    transition:color .15s, transform .15s;
}
.mn-rate__stars .mn-star:hover,
.mn-rate__stars .mn-star.is-active{
    color:var(--pear-deep);
    transform:scale(1.1);
}
.mn-rate__info{
    color:var(--fg-dim);
    font-size:13px;
    margin-top:8px;
}

/* ── Pricing-card / tariff highlighting на cmsboard/buy ── */
.tariff-card{
    padding:24px;
    background:var(--space-1);
    border:1px solid var(--line);
    border-radius:16px;
    transition:border-color .15s, transform .15s;
}
.tariff-card:hover{ border-color:var(--line-2); transform:translateY(-2px) }
.tariff-card.featured{
    border-color:var(--pear-deep);
    background:linear-gradient(180deg, rgba(230,210,74,.10), var(--space-1));
}
.tariff-card h3{
    font-family:var(--f-display);
    font-weight:600;
    font-size:22px;
    margin:0 0 8px;
}
.tariff-card .price{
    font-family:var(--f-display);
    font-weight:600;
    font-size:36px;
    color:var(--accent);
    margin:14px 0;
}
.tariff-card ul{
    list-style:none;
    padding:0;
    margin:18px 0;
}
.tariff-card ul li{
    color:var(--fg-dim);
    font-size:14px;
    padding:6px 0;
    display:flex;
    gap:8px;
    align-items:flex-start;
}

/* ── Panel accent (балансная плашка) ──
 * Светлая тема: солнечный pear-градиент. На тёмном тексте читается лучше,
 * чем тёмный градиент из dark-версии.
 */
.panel.panel-accent{
    background:linear-gradient(135deg, #f4e88a, #e6d24a 55%, #c8a934);
    border-color:var(--pear-deep);
    box-shadow:0 14px 34px -16px rgba(168,134,28,.45);
}
.panel.panel-accent .panel-h{
    border-bottom-color:rgba(28,29,23,.16);
}
.panel.panel-accent .panel-h h2{ color:#1c1d17 }
.panel.panel-accent .panel-h a{ color:rgba(28,29,23,.75) }
.panel.panel-accent .panel-h a:hover{ color:#1c1d17 }
.panel-accent__amount{
    font-family:var(--f-display);
    font-weight:600;
    font-size:48px;
    line-height:1;
    color:#1c1d17;
}
.panel-accent__amount .cur{
    color:rgba(28,29,23,.78);
    font-size:28px;
    margin-left:6px;
}
.panel-accent__sub{
    color:rgba(28,29,23,.72);
    font-size:14px;
    margin:14px 0 18px;
}
/* кнопка-призрак внутри панели — на жёлтом фоне нужен тёмный контур */
.panel.panel-accent .btn-ghost{
    border-color:rgba(28,29,23,.32);
    color:#1c1d17;
}
.panel.panel-accent .btn-ghost:hover{
    border-color:#1c1d17;
    color:#1c1d17;
}
.panel.panel-accent .btn-primary{
    background:#1c1d17;
    color:var(--pear);
}
.panel.panel-accent .btn-primary:hover{
    background:#2c2d27;
}

/* ── Footer: юридические ссылки ── */
.foot-legal{
    margin-top:32px;
    padding-top:20px;
    border-top:1px solid var(--line);
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    align-items:center;
    justify-content:center;
    font-size:13px;
}
.foot-legal a{
    color:var(--fg-dim);
    text-decoration:none;
    transition:color .15s;
    border-bottom:1px dashed transparent;
}
.foot-legal a:hover{
    color:var(--accent);
    border-bottom-color:currentColor;
}
.foot-legal .dot-sep{
    color:var(--fg-mute);
    user-select:none;
}
@media (max-width:560px){
    .foot-legal{ gap:10px; font-size:12px }
    .foot-legal .dot-sep{ display:none }
    .foot-legal a{ display:block }
}
