/*
Theme Name: Kadence Child (Sunalizer)
Template: kadence
Version: 0.1.0
Description: Child theme for Sunalizer reviewer site.
*/

@font-face {
    font-family: 'Geist';
    src: url('./assets/fonts/Geist-VariableFont_wght.woff2') format('woff2-variations'),
         url('./assets/fonts/Geist-VariableFont_wght.woff2') format('woff2');
    font-weight: 100 900;
    font-display: swap;
    font-style: normal;
}

:root {
    /* Surfaces */
    --color-bg:            #FAF7F2;
    --color-surface:       #FFFFFF;
    --color-surface-sand:  #F4ECDC;
    --color-surface-dark:  #0E1525;

    /* Primary */
    --color-primary:       #0891B2;
    --color-primary-hover: #0E7490;
    --color-primary-soft:  #E0F7FA;

    /* Semantic */
    --color-star:          #F59E0B;
    --color-pros-bg:       #ECFDF5;
    --color-pros-border:   #A7F3D0;
    --color-pros-icon:     #10B981;
    --color-cons-bg:       #FEF2F2;
    --color-cons-border:   #FECACA;
    --color-cons-icon:     #EF4444;
    --color-best-overall:  #10B981;

    /* Text */
    --color-text:          #0F172A;
    --color-text-muted:    #64748B;
    --color-text-on-dark:  #F1F5F9;

    /* Borders */
    --color-border:        #E2E8F0;
    --color-border-strong: #94A3B8;
    --color-border-hover:  var(--color-primary);

    /* Typography */
    --font-sans: 'Geist', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

    /* Spacing — 4px grid */
    --space-1:  4px;  --space-2:  8px;  --space-3: 12px;
    --space-4: 16px;  --space-6: 24px;  --space-8: 32px;
    --space-12: 48px; --space-16: 64px; --space-24: 96px;

    /* Radii */
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --radius-pill: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
    --shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08);
    --shadow-lg: 0 12px 32px rgba(15, 23, 42, 0.12);

    /* Layout */
    --container-max: 1200px;
    --content-max:   760px;
    --sidebar-w:     300px;
    --gutter:        32px;

    /* Motion */
    --transition: 150ms ease-out;
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.65;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

img, svg { max-width: 100%; display: block; }
a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-hover); }
button, input, select, textarea { font: inherit; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-sans);
    color: var(--color-text);
    margin: 0 0 var(--space-4);
    line-height: 1.25;
}
h1 { font-size: 56px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.15; }
h2 { font-size: 32px; font-weight: 600; letter-spacing: -0.01em; }
h3 { font-size: 22px; font-weight: 600; letter-spacing: -0.005em; }
h4 { font-size: 18px; font-weight: 600; }
p  { margin: 0 0 var(--space-3); }
strong { font-weight: 600; }
small { font-size: 14px; color: var(--color-text-muted); }

/* ===== Layout utilities ===== */

.sunalizer-container {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--space-6);
}

.sunalizer-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--sidebar-w);
    gap: var(--gutter);
    align-items: start;
}

.sunalizer-layout > .sunalizer-main { min-width: 0; }

.sunalizer-layout > .sunalizer-sidebar {
    position: sticky;
    top: calc(72px + var(--space-6));
    align-self: start;
}

.sunalizer-section {
    padding-block: var(--space-16);
}

.sunalizer-section + .sunalizer-section {
    border-top: 1px solid var(--color-border);
}

/* ====================================================
   Hero
   ==================================================== */

.sunalizer-hero {
    padding-block: var(--space-24) var(--space-16);
}

.sunalizer-hero h1 {
    margin-top: var(--space-3);
    max-width: 18ch;
}

.sunalizer-hero > p {
    font-size: 17px;
    color: var(--color-text-muted);
    max-width: 60ch;
    margin-bottom: var(--space-6);
}

.sunalizer-hero-checks {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-4);
}

.sunalizer-hero-checks li {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-surface);
    box-shadow: var(--shadow-sm);
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
}

.sunalizer-hero-checks li::before {
    content: "";
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    background-color: var(--color-primary);
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='%23000' d='M13.485 3.515a1 1 0 010 1.414l-7 7a1 1 0 01-1.414 0l-3-3a1 1 0 011.414-1.414L6 9.586l6.293-6.293a1 1 0 011.192.222z'/></svg>") no-repeat center / contain;
            mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='%23000' d='M13.485 3.515a1 1 0 010 1.414l-7 7a1 1 0 01-1.414 0l-3-3a1 1 0 011.414-1.414L6 9.586l6.293-6.293a1 1 0 011.192.222z'/></svg>") no-repeat center / contain;
}

/* Disclaimer (HTML: .sunalizer-disclaimer на p) */
.sunalizer-disclaimer {
    font-size: 14px;
    color: var(--color-text-muted);
    font-style: italic;
    margin-bottom: var(--space-4);
}

/* CTA button — overrides WP block */
.sunalizer-hero .wp-block-button .wp-block-button__link {
    background: var(--color-primary);
    color: #fff;
    padding: 14px 28px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 16px;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    transition: background var(--transition), box-shadow var(--transition);
}

.sunalizer-hero .wp-block-button .wp-block-button__link::after {
    content: "→";
    font-weight: 400;
}

.sunalizer-hero .wp-block-button .wp-block-button__link:hover {
    background: var(--color-primary-hover);
    box-shadow: var(--shadow-md);
    color: #fff;
}

/* ====================================================
   Top Picks Table
   ==================================================== */

.sunalizer-top-picks {
    background: var(--color-surface);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin: 0 0 var(--space-8);
}

.sunalizer-top-picks table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
}

.sunalizer-top-picks tbody tr:last-child td {
    border-bottom: 1px solid var(--color-border-strong);
}

.sunalizer-top-picks thead {
    background: var(--color-surface-sand);
}

.sunalizer-top-picks thead th {
    text-align: left;
    padding: 14px 20px;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.sunalizer-top-picks tbody td {
    padding: 8px 20px;
    border-top: 1px solid var(--color-border-strong);
    vertical-align: middle;
    font-size: 15px;
    color: var(--color-text);
}

.sunalizer-top-picks tbody tr {
    transition: background var(--transition);
}

.sunalizer-top-picks tbody tr:hover {
    background: rgba(8, 145, 178, 0.04);
}

/* App cell layout: chip + name */
.sunalizer-top-picks tbody td:first-child {
    font-weight: 700;
    font-size: 17px;
}

.sunalizer-top-picks tbody td:first-child::before {
    content: attr(data-initials);
    display: inline-flex;
    width: 28px;
    height: 28px;
    margin-right: 12px;
    border-radius: var(--radius-sm);
    background: var(--color-primary);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
    letter-spacing: 0;
    text-transform: uppercase;
}

/* Rating column */
.sunalizer-top-picks .sunalizer-stars {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 600;
    color: var(--color-text);
}

.sunalizer-top-picks .sunalizer-stars-icon {
    display: inline-flex;
    color: var(--color-star);
    font-size: 14px;
    letter-spacing: 1px;
}

/* "Full review" — button */
.sunalizer-top-picks tbody td:last-child a {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    padding: 8px 16px;
    border-radius: var(--radius-md);
    text-decoration: none;
    line-height: 1;
    transition: background var(--transition), transform var(--transition);
    white-space: nowrap;
}

.sunalizer-top-picks tbody td:last-child a:hover {
    background: var(--color-primary-hover);
    color: #fff;
    transform: translateY(-1px);
}

.sunalizer-top-picks tbody td:last-child a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 3px;
}

.sunalizer-top-picks tbody td:last-child a::after {
    content: "→";
    font-weight: 700;
}

/* ====================================================
   Comparison Table
   ==================================================== */

.sunalizer-comparison {
    background: var(--color-surface);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin: 0 0 var(--space-8);
}

.sunalizer-comparison tbody tr:last-child td {
    border-bottom: 1px solid var(--color-border-strong);
}

.sunalizer-comparison table {
    width: 100%;
    border-collapse: collapse;
    min-width: 600px;
    margin: 0;
}

.sunalizer-comparison thead {
    background: var(--color-surface-sand);
}

.sunalizer-comparison thead th {
    text-align: left;
    padding: 14px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.sunalizer-comparison tbody td {
    padding: 14px 16px;
    border-top: 1px solid var(--color-border-strong);
    font-size: 15px;
    color: var(--color-text);
    vertical-align: middle;
}

.sunalizer-comparison tbody td:first-child {
    font-weight: 600;
}

/* ✓ / × icons rendered through char content — color via class */
.sunalizer-comparison .check { color: var(--color-pros-icon); font-weight: 700; }
.sunalizer-comparison .cross { color: var(--color-cons-icon); font-weight: 700; }

/* ====================================================
   Methodology
   ==================================================== */

.sunalizer-methodology {
    background: var(--color-surface-sand);
    border-radius: var(--radius-lg);
    padding: var(--space-12);
    margin: var(--space-8) 0;
}

.sunalizer-methodology__intro {
    max-width: 80ch;
    margin-bottom: var(--space-8);
}

.sunalizer-methodology__intro h2 {
    margin: 0 0 var(--space-3);
}

.sunalizer-methodology__intro p {
    color: var(--color-text);
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
}

/* Grid: 4 cols desktop, 2 tablet, 1 mobile */
.sunalizer-methodology__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
}

.sunalizer-methodology__card {
    position: relative;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-6) var(--space-5, 20px) var(--space-5, 20px);
    box-shadow: var(--shadow-sm);
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    overflow: hidden;
}

/* Тонкая cyan-линия слева — editorial accent */
.sunalizer-methodology__card::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: var(--color-primary);
    opacity: 0;
    transition: opacity var(--transition);
}

.sunalizer-methodology__card:hover {
    border-color: var(--color-primary);
    box-shadow: 0 8px 24px rgba(8, 145, 178, 0.08);
    transform: translateY(-2px);
}

.sunalizer-methodology__card:hover::before {
    opacity: 1;
}

/* Numbered badge — 01 / 02 / … в верхнем правом углу */
.sunalizer-methodology__num {
    position: absolute;
    top: var(--space-4);
    right: var(--space-5, 20px);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--color-primary);
    opacity: 0.5;
    font-variant-numeric: tabular-nums;
}

/* Icon — Lucide-style line-svg, primary stroke, без chip-фона */
.sunalizer-methodology__icon {
    display: block;
    width: 32px;
    height: 32px;
    margin-bottom: var(--space-4);
    color: var(--color-primary);
}

.sunalizer-methodology__icon > svg {
    width: 100%;
    height: 100%;
    display: block;
}

.sunalizer-methodology__card h3 {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 var(--space-2);
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.sunalizer-methodology__card p {
    font-size: 14px;
    line-height: 1.55;
    color: var(--color-text-muted);
    margin: 0;
}

/* Tablet 2 cols, small 1 col */
@media (max-width: 1024px) {
    .sunalizer-methodology__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .sunalizer-methodology__grid { grid-template-columns: 1fr; }
    .sunalizer-methodology { padding: var(--space-6); }
}

/* ====================================================
   Header branding — скрываем дубль site-title (логотип
   с wordmark уже содержит «Sunalizer»). Header Builder
   в Customizer не правился, поэтому фиксим CSS-ом.
   ==================================================== */

.site-branding .site-title-wrap { display: none; }

.site-branding .brand { display: inline-flex; align-items: center; }

/* Размер логотипа в шапке — desktop & mobile */
.site-branding .custom-logo {
    height: auto;
    max-height: 44px;
    width: auto;
}

@media (max-width: 768px) {
    .site-branding .custom-logo { max-height: 36px; }
}

/* ====================================================
   Key facts (✓ inline-список — About Us, методология hero)
   ==================================================== */

.sunalizer-key-facts {
    list-style: none;
    margin: var(--space-6) 0 var(--space-8);
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3) var(--space-6);
    justify-content: flex-start;
}

.sunalizer-key-facts > li {
    position: relative;
    padding-left: 1.6em;
    font-size: 15px;
    line-height: 1.4;
    color: var(--color-text);
    font-weight: 500;
}

.sunalizer-key-facts > li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 0;
    width: 1.2em;
    height: 1.2em;
    color: var(--color-primary);
    font-weight: 700;
    font-size: 1.05em;
    line-height: 1.2;
}

/* ====================================================
   Authors
   ==================================================== */

.sunalizer-authors {
    text-align: center;
    padding-block: var(--space-16);
}

.sunalizer-authors > p {
    max-width: 60ch;
    margin: 0 auto var(--space-8);
    color: var(--color-text-muted);
    font-size: 17px;
}

.sunalizer-authors__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    max-width: 960px;
    margin: 0 auto;
}

@media (max-width: 1024px) {
    .sunalizer-authors__grid { grid-template-columns: repeat(2, 1fr); }
}

.sunalizer-author {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    text-align: center;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}

.sunalizer-author:hover {
    border-color: var(--color-border-hover);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

/* Avatar: круглый chip с инициалами + cyan gradient */
.sunalizer-author__avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    margin: 0 auto var(--space-4);
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
    color: #fff;
    font-size: 28px;
    font-weight: 700;
    letter-spacing: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
    box-shadow: 0 4px 12px rgba(8, 145, 178, 0.25);
}

/* Photo: круглое фото на месте chip-инициалов, та же диаметр + cyan ободок */
.sunalizer-author__photo {
    display: block;
    width: 96px;
    height: 96px;
    object-fit: cover;
    border-radius: 50%;
    margin: 0 auto var(--space-4);
    border: 2px solid var(--color-primary-soft);
    box-shadow: 0 4px 12px rgba(8, 145, 178, 0.18);
    transition: border-color var(--transition);
}

.sunalizer-author:hover .sunalizer-author__photo {
    border-color: var(--color-primary);
}

.sunalizer-author__name {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 var(--space-1);
    color: var(--color-text);
}

.sunalizer-author__title {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-primary-hover);
    font-weight: 600;
    margin: 0 0 var(--space-3);
}

.sunalizer-author__bio {
    font-size: 14px;
    line-height: 1.55;
    color: var(--color-text-muted);
    margin: 0;
}

/* ====================================================
   Trust badges
   ==================================================== */

.sunalizer-trust-badges {
    margin: var(--space-12) 0;
    text-align: center;
}

.sunalizer-trust-badges__label {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-muted);
    margin-bottom: var(--space-4);
}

.sunalizer-trust-badges__grid {
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--space-8);
}

.sunalizer-trust-badges__grid .wp-block-image,
.sunalizer-trust-badges__grid figure {
    margin: 0;
}

.sunalizer-trust-badges__grid img {
    max-height: 36px;
    width: auto;
    opacity: 0.75;
    filter: grayscale(80%);
    transition: opacity var(--transition), filter var(--transition);
}

.sunalizer-trust-badges__grid img:hover {
    opacity: 1;
    filter: grayscale(0);
}

/* Footer variant — invert logos for dark background */
.sunalizer-trust-badges--on-dark .sunalizer-trust-badges__grid img {
    filter: brightness(0) invert(1) opacity(0.7);
}

.sunalizer-trust-badges--on-dark .sunalizer-trust-badges__grid img:hover {
    filter: brightness(0) invert(1) opacity(1);
}

/* ====================================================
   FAQ — native <details> accordion
   ==================================================== */

.sunalizer-faq {
    margin: var(--space-12) 0;
}

.sunalizer-faq > h2 {
    font-size: 28px;
    font-weight: 700;
    margin: 0 0 var(--space-6);
}

.sunalizer-faq__list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.sunalizer-faq__item {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

.sunalizer-faq__item:hover {
    border-color: var(--color-border-hover);
    box-shadow: var(--shadow-md);
}

.sunalizer-faq__item[open] {
    border-color: var(--color-primary);
    background: var(--color-primary-soft);
    box-shadow: 0 4px 16px rgba(8, 145, 178, 0.08);
}

/* Скрываем дефолтный triangle */
.sunalizer-faq__question::-webkit-details-marker { display: none; }
.sunalizer-faq__question::marker { content: ''; }

.sunalizer-faq__question {
    list-style: none;
    cursor: pointer;
    padding: var(--space-5, 20px) var(--space-6);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-4);
    font-size: 17px;
    font-weight: 600;
    color: var(--color-text);
    user-select: none;
}

.sunalizer-faq__question > span {
    flex: 1;
}

.sunalizer-faq__chevron {
    color: var(--color-primary);
    transition: transform 0.25s ease;
    flex-shrink: 0;
}

.sunalizer-faq__item[open] .sunalizer-faq__chevron {
    transform: rotate(180deg);
}

.sunalizer-faq__answer {
    padding: 0 var(--space-6) var(--space-5, 20px);
    color: var(--color-text);
    font-size: 16px;
    line-height: 1.65;
    /* Smooth open animation через max-height fallback */
    animation: sunalizerFaqOpen 0.25s ease;
}

.sunalizer-faq__answer p {
    margin: 0;
}

.sunalizer-faq__item[open] .sunalizer-faq__question {
    color: var(--color-primary-hover);
}

@keyframes sunalizerFaqOpen {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
    .sunalizer-faq__chevron,
    .sunalizer-faq__answer {
        animation: none;
        transition: none;
    }
}

/* ====================================================
   Review Card
   ==================================================== */

.sunalizer-review-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-8);
    margin: var(--space-6) 0;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.sunalizer-review-card:hover {
    border-color: var(--color-border-hover);
    box-shadow: var(--shadow-md);
}

/* Header */
.sunalizer-review-card__header {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--space-4);
    align-items: center;
    margin-bottom: var(--space-4);
}

.sunalizer-app-chip {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md);
    background: var(--color-primary);
    color: #fff;
    font-size: 22px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
    flex-shrink: 0;
}

.sunalizer-review-card__title h2 {
    margin: 0 0 var(--space-2);
    font-size: 24px;
}

.sunalizer-review-card__subtitle {
    margin: 0 0 var(--space-2);
    font-size: 14px;
    color: var(--color-text-muted);
    font-weight: 500;
}

.sunalizer-rating-line {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    font-size: 15px;
    color: var(--color-text);
}

.sunalizer-rating-line .sunalizer-stars-icon {
    color: var(--color-star);
    letter-spacing: 1px;
}

.sunalizer-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--radius-pill);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sunalizer-badge--best {
    background: var(--color-best-overall);
    color: #fff;
}

.sunalizer-review-card__meta {
    text-align: right;
    color: var(--color-text-muted);
    font-size: 14px;
}

.sunalizer-price {
    font-weight: 600;
    color: var(--color-text);
}

/* Intro */
.sunalizer-review-card__intro {
    color: var(--color-text);
    margin-bottom: var(--space-6);
    max-width: var(--content-max);
}

/* Pros / Cons grid */
.sunalizer-pros-cons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.sunalizer-pros, .sunalizer-cons {
    border-radius: var(--radius-md);
    padding: var(--space-5, 20px);
    border-width: 1px;
    border-style: solid;
}

.sunalizer-pros {
    background: var(--color-pros-bg);
    border-color: var(--color-pros-border);
}

.sunalizer-cons {
    background: var(--color-cons-bg);
    border-color: var(--color-cons-border);
}

.sunalizer-pros h3,
.sunalizer-cons h3 {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0 0 var(--space-3);
    color: var(--color-text);
}

.sunalizer-pros ul,
.sunalizer-cons ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sunalizer-pros li,
.sunalizer-cons li {
    display: flex;
    gap: var(--space-2);
    align-items: flex-start;
    padding: var(--space-1) 0;
    font-size: 15px;
    color: var(--color-text);
}

.sunalizer-pros li::before {
    content: "✓";
    flex-shrink: 0;
    color: var(--color-pros-icon);
    font-weight: 700;
    width: 18px;
}

.sunalizer-cons li::before {
    content: "×";
    flex-shrink: 0;
    color: var(--color-cons-icon);
    font-weight: 700;
    width: 18px;
}

/* Footer (breakdown + verdict) */
.sunalizer-review-card__footer {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--space-6);
    align-items: start;
}

.sunalizer-rating-breakdown h3 {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--space-4);
}

.sunalizer-bar {
    display: grid;
    grid-template-columns: 140px 1fr 36px;
    gap: var(--space-3);
    align-items: center;
    margin-bottom: var(--space-2);
}

.sunalizer-bar__label {
    font-size: 14px;
    color: var(--color-text-muted);
}

.sunalizer-bar__track {
    background: var(--color-border);
    height: 8px;
    border-radius: var(--radius-pill);
    overflow: hidden;
}

.sunalizer-bar__fill {
    background: var(--color-primary);
    height: 100%;
    border-radius: var(--radius-pill);
}

.sunalizer-bar__value {
    font-weight: 600;
    font-size: 14px;
    color: var(--color-text);
    text-align: right;
}

/* Verdict box */
.sunalizer-verdict {
    background: var(--color-primary-soft);
    border-radius: var(--radius-md);
    padding: var(--space-5, 20px);
    text-align: center;
}

.sunalizer-verdict__label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-primary-hover);
    margin-bottom: var(--space-1);
}

.sunalizer-verdict__score {
    display: block;
    font-size: 36px;
    font-weight: 700;
    color: var(--color-primary-hover);
    line-height: 1.1;
    margin-bottom: var(--space-2);
}

.sunalizer-verdict p {
    font-size: 14px;
    color: var(--color-text);
    margin-bottom: var(--space-3);
}

/* Verdict callout с HTML-телом (полная md-секция: параграфы, ### Rating, ul lists) */
.sunalizer-verdict__body {
    text-align: left;
    margin: var(--space-3) auto var(--space-5, 20px);
    max-width: 60ch;
}
.sunalizer-verdict__body p {
    font-size: 15px;
    line-height: 1.65;
    margin: 0 0 var(--space-3);
}
.sunalizer-verdict__body h3 {
    font-size: 18px;
    font-weight: 700;
    margin: var(--space-4) 0 var(--space-2);
    color: var(--color-primary-hover);
}
.sunalizer-verdict__body ul {
    padding-left: var(--space-5, 20px);
    margin: 0 0 var(--space-3);
}
.sunalizer-verdict__body li {
    font-size: 15px;
    line-height: 1.6;
    margin: 0 0 var(--space-2);
}
.sunalizer-verdict__body strong {
    color: var(--color-text);
    font-weight: 700;
}

.sunalizer-verdict .wp-block-button__link,
.sunalizer-verdict a.wp-block-button__link {
    background: var(--color-primary);
    color: #fff;
    padding: 10px 20px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 14px;
    display: inline-block;
    transition: background var(--transition);
}

.sunalizer-verdict .wp-block-button__link:hover {
    background: var(--color-primary-hover);
    color: #fff;
}

/* ====================================================
   Tablet — sidebar drops below main
   ==================================================== */

@media (max-width: 980px) {
    .sunalizer-layout {
        grid-template-columns: 1fr;
    }
    .sunalizer-layout > .sunalizer-sidebar {
        position: static;
        margin-top: var(--space-8);
    }
    .sunalizer-review-card__footer {
        grid-template-columns: 1fr;
    }
    .sunalizer-review-card {
        padding: var(--space-6);
    }
}

/* ====================================================
   Mobile — typography scale + stack tables/cards
   ==================================================== */

@media (max-width: 768px) {
    body { font-size: 16px; line-height: 1.6; }
    h1 { font-size: 32px; line-height: 1.25; }
    h2 { font-size: 24px; line-height: 1.3; }
    h3 { font-size: 20px; }

    .sunalizer-container { padding-inline: var(--space-4); }
    .sunalizer-section, .sunalizer-hero { padding-block: var(--space-12); }

    /* Hero */
    .sunalizer-hero h1 { max-width: 100%; }
    .sunalizer-hero-checks li { font-size: 13px; padding: 5px 12px; }

    /* Top picks — collapse to card-stack */
    .sunalizer-top-picks thead { display: none; }
    .sunalizer-top-picks table,
    .sunalizer-top-picks tbody,
    .sunalizer-top-picks tr,
    .sunalizer-top-picks td { display: block; width: 100%; }
    .sunalizer-top-picks tbody tr {
        border-top: 1px solid var(--color-border);
        padding: var(--space-4);
    }
    .sunalizer-top-picks tbody tr:first-child {
        border-top: 0;
    }
    .sunalizer-top-picks tbody td {
        border: 0;
        padding: var(--space-1) 0;
        text-align: center;
    }
    .sunalizer-top-picks tbody td:first-child {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-2);
        padding-top: var(--space-2);
    }
    .sunalizer-top-picks tbody td:first-child::before {
        margin-right: 0;
    }
    /* Stars + rating + Full review центрируются */
    .sunalizer-top-picks .sunalizer-stars {
        justify-content: center;
    }
    .sunalizer-top-picks tbody td:last-child a {
        justify-content: center;
    }

    /* Review card */
    .sunalizer-review-card { padding: var(--space-4); }
    .sunalizer-review-card__header {
        grid-template-columns: auto 1fr;
    }
    .sunalizer-review-card__meta {
        grid-column: 1 / -1;
        text-align: left;
        padding-top: var(--space-2);
    }
    .sunalizer-pros-cons { grid-template-columns: 1fr; }
    .sunalizer-bar { grid-template-columns: 110px 1fr 32px; gap: var(--space-2); }
    .sunalizer-bar__label { font-size: 13px; }

    /* Methodology */
    .sunalizer-methodology { padding: var(--space-6); }

    /* Authors — на mobile одной колонкой */
    .sunalizer-authors__grid {
        grid-template-columns: 1fr;
    }

    /* Authors — tablet 1024px → 2 cols handled below in same query if hit */

    /* Trust badges */
    .sunalizer-trust-badges__grid { gap: var(--space-4); }
    .sunalizer-trust-badges__grid img { max-height: 28px; }
}

/* ====================================================
   Review Page (single CPT — /reviews/<slug>/)
   ==================================================== */

.sunalizer-review-page {
    max-width: 1080px;
    margin: 0 auto;
}

/* Hero — chip + title + tagline + rating + sticky-ish CTA aside */
.sunalizer-review-page__hero {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-8);
    align-items: center;
    padding: var(--space-8);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-8);
}

.sunalizer-review-page__hero-main {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-5, 20px);
    align-items: center;
}

.sunalizer-app-chip--xl {
    width: 96px;
    height: 96px;
    border-radius: var(--radius-md);
    background: var(--color-primary);
    color: #fff;
    font-size: 32px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
    flex-shrink: 0;
}

.sunalizer-review-page__tagline {
    color: var(--color-text-muted);
    font-size: 16px;
    margin: 0 0 var(--space-3);
    max-width: 50ch;
}

.sunalizer-review-page__rating {
    margin: 0;
}

.sunalizer-review-page__hero-cta {
    text-align: center;
    padding: var(--space-5, 20px);
    background: var(--color-primary-soft);
    border-radius: var(--radius-md);
    min-width: 200px;
}

.sunalizer-review-page__price-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-primary-hover);
    font-weight: 600;
    margin-bottom: 4px;
}

.sunalizer-review-page__price {
    font-size: 26px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-3);
}

.sunalizer-review-page__cta-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    padding: 10px 20px;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: background var(--transition), transform var(--transition);
    white-space: nowrap;
}

.sunalizer-review-page__cta-btn:hover {
    background: var(--color-primary-hover);
    color: #fff;
    transform: translateY(-1px);
}

/* Section spacing */
.sunalizer-review-page__section {
    margin-bottom: var(--space-12);
}

.sunalizer-review-page__section h2 {
    font-size: 26px;
    font-weight: 700;
    margin: 0 0 var(--space-5, 20px);
}

/* Extra blocks: Features Breakdown / How Works / Pricing & Conditions / User Reviews / Testing Process */
.sunalizer-review-page__features-breakdown,
.sunalizer-review-page__how-works,
.sunalizer-review-page__pricing-conditions,
.sunalizer-review-page__user-reviews,
.sunalizer-review-page__testing-process {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-6, 24px) var(--space-7, 28px);
    box-shadow: var(--shadow-sm);
}

.sunalizer-review-page__features-breakdown h2,
.sunalizer-review-page__how-works h2,
.sunalizer-review-page__pricing-conditions h2,
.sunalizer-review-page__user-reviews h2,
.sunalizer-review-page__testing-process h2 {
    margin-top: 0;
}

.sunalizer-review-page__features-breakdown h3,
.sunalizer-review-page__how-works h3,
.sunalizer-review-page__pricing-conditions h3,
.sunalizer-review-page__user-reviews h3,
.sunalizer-review-page__testing-process h3 {
    font-size: 18px;
    font-weight: 700;
    margin: var(--space-6, 24px) 0 var(--space-3);
    color: var(--color-text);
}

.sunalizer-review-page__features-breakdown p,
.sunalizer-review-page__how-works p,
.sunalizer-review-page__pricing-conditions p,
.sunalizer-review-page__user-reviews p,
.sunalizer-review-page__testing-process p {
    color: var(--color-text);
    font-size: 15px;
    line-height: 1.65;
    margin: 0 0 var(--space-3);
}

.sunalizer-review-page__features-breakdown ul,
.sunalizer-review-page__how-works ul,
.sunalizer-review-page__pricing-conditions ul,
.sunalizer-review-page__user-reviews ul,
.sunalizer-review-page__testing-process ul,
.sunalizer-review-page__features-breakdown ol,
.sunalizer-review-page__how-works ol,
.sunalizer-review-page__pricing-conditions ol,
.sunalizer-review-page__user-reviews ol,
.sunalizer-review-page__testing-process ol {
    padding-left: var(--space-5, 20px);
    color: var(--color-text);
    line-height: 1.6;
}

.sunalizer-review-page__features-breakdown li,
.sunalizer-review-page__how-works li,
.sunalizer-review-page__pricing-conditions li,
.sunalizer-review-page__user-reviews li,
.sunalizer-review-page__testing-process li {
    margin: 0 0 var(--space-2);
}

.sunalizer-review-page__features-breakdown img,
.sunalizer-review-page__how-works img,
.sunalizer-review-page__pricing-conditions img,
.sunalizer-review-page__user-reviews img,
.sunalizer-review-page__testing-process img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    margin: var(--space-4) 0;
    box-shadow: var(--shadow-sm);
}

.sunalizer-review-page__features-breakdown .app-screenshots,
.sunalizer-review-page__how-works .app-screenshots,
.sunalizer-review-page__pricing-conditions .app-screenshots,
.sunalizer-review-page__user-reviews .app-screenshots,
.sunalizer-review-page__testing-process .app-screenshots {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
    margin: var(--space-5, 20px) 0;
}

.sunalizer-review-page__features-breakdown .app-screenshots img,
.sunalizer-review-page__how-works .app-screenshots img,
.sunalizer-review-page__pricing-conditions .app-screenshots img,
.sunalizer-review-page__user-reviews .app-screenshots img,
.sunalizer-review-page__testing-process .app-screenshots img {
    margin: 0;
    aspect-ratio: 1 / 2;
    object-fit: cover;
}

.sunalizer-review-page__features-breakdown table,
.sunalizer-review-page__how-works table,
.sunalizer-review-page__pricing-conditions table,
.sunalizer-review-page__user-reviews table,
.sunalizer-review-page__testing-process table,
.sunalizer-review-page .wp-block-table table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
    font-size: 14px;
}

.sunalizer-review-page__features-breakdown th,
.sunalizer-review-page__how-works th,
.sunalizer-review-page__pricing-conditions th,
.sunalizer-review-page__user-reviews th,
.sunalizer-review-page__testing-process th,
.sunalizer-review-page__features-breakdown td,
.sunalizer-review-page__how-works td,
.sunalizer-review-page__pricing-conditions td,
.sunalizer-review-page__user-reviews td,
.sunalizer-review-page__testing-process td {
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--color-border-strong);
    text-align: left;
}

.sunalizer-review-page tr:last-child td {
    border-bottom: 1px solid var(--color-border-strong);
}

.sunalizer-review-page__features-breakdown th,
.sunalizer-review-page__how-works th,
.sunalizer-review-page__pricing-conditions th,
.sunalizer-review-page__user-reviews th,
.sunalizer-review-page__testing-process th {
    background: var(--color-bg-soft, #f4ede1);
    font-weight: 700;
}

@media (max-width: 768px) {
    .sunalizer-review-page__features-breakdown,
    .sunalizer-review-page__how-works,
    .sunalizer-review-page__pricing-conditions,
    .sunalizer-review-page__user-reviews,
    .sunalizer-review-page__testing-process {
        padding: var(--space-5, 20px) var(--space-4, 16px);
    }
    .sunalizer-review-page__features-breakdown .app-screenshots,
    .sunalizer-review-page__how-works .app-screenshots,
    .sunalizer-review-page__pricing-conditions .app-screenshots,
    .sunalizer-review-page__user-reviews .app-screenshots,
    .sunalizer-review-page__testing-process .app-screenshots {
        grid-template-columns: 1fr;
    }
}

/* Verdict уже стилизован .sunalizer-verdict в Review Card; здесь только spacing */
.sunalizer-review-page__verdict {
    padding: var(--space-8);
    margin-bottom: var(--space-12);
}

/* Reviewed-by italic строка под tagline в hero */
.sunalizer-review-page__reviewed-by {
    font-size: 13px;
    font-style: italic;
    color: var(--color-text-muted);
    margin: 0 0 var(--space-3);
    line-height: 1.5;
}

/* Hero intro: 2 параграфа из md между cover и First Look */
.sunalizer-review-page__intro-paragraphs {
    margin-bottom: var(--space-12);
}
.sunalizer-review-page__intro-paragraphs p {
    color: var(--color-text);
    font-size: 16px;
    line-height: 1.7;
    margin: 0 0 var(--space-4);
}

/* First Look — те же card-стили что у других extra-blocks секций */
.sunalizer-review-page__first-look {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-6, 24px) var(--space-7, 28px);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-12);
}
.sunalizer-review-page__first-look h2 { margin-top: 0; }
.sunalizer-review-page__first-look p {
    color: var(--color-text);
    font-size: 15px;
    line-height: 1.65;
    margin: 0 0 var(--space-3);
}
@media (max-width: 768px) {
    .sunalizer-review-page__first-look {
        padding: var(--space-5, 20px) var(--space-4, 16px);
    }
}

/* Testing Process использует sunalizer-methodology__ классы (см. блок methodology выше) —
   автоматически наследует cyan accent, hover-эффект, numbered badges.
   Здесь повышаем specificity, чтобы перебить общие .sunalizer-review-page__testing-process h3/p правила. */
.sunalizer-review-page__methodology {
    margin: var(--space-5, 20px) 0 var(--space-6, 24px);
}
.sunalizer-review-page__methodology .sunalizer-methodology__card h3 {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 var(--space-2);
    color: var(--color-text);
    letter-spacing: -0.01em;
}
.sunalizer-review-page__methodology .sunalizer-methodology__card p {
    font-size: 14px;
    line-height: 1.55;
    color: var(--color-text-muted);
    margin: 0;
}

/* Disclaimer italic — в конце страницы */
.sunalizer-review-page__disclaimer,
.sunalizer-article-page__disclaimer {
    text-align: center;
    font-size: 12px;
    color: var(--color-text-muted);
    margin: var(--space-8) 0 var(--space-4);
    line-height: 1.5;
}

/* ====================================================
   Article / Listicle страницы (best-N-apps-for-X)
   ==================================================== */

.sunalizer-article-page {
    max-width: 1080px;
    margin: 0 auto;
}

/* TL;DR callout под H1 */
.sunalizer-article-page__tldr {
    background: var(--color-primary-soft);
    border-left: 4px solid var(--color-primary);
    padding: var(--space-4) var(--space-5, 20px);
    border-radius: var(--radius-sm, 6px);
    font-size: 16px;
    line-height: 1.65;
    color: var(--color-text);
    margin: var(--space-5, 20px) 0 var(--space-6, 24px);
}
.sunalizer-article-page__tldr strong {
    color: var(--color-primary-hover);
    font-weight: 700;
    letter-spacing: 0.02em;
}

/* Table of Contents — нативный <details>, закрыт по умолчанию.
   Summary всегда в cyan-soft фоне — когда TOC закрыт, виден только цветной summary. */
.sunalizer-article-page__toc {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin: var(--space-6, 24px) 0;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
.sunalizer-article-page__toc > summary {
    cursor: pointer;
    padding: var(--space-4) var(--space-5, 20px);
    font-size: 16px;
    font-weight: 700;
    color: var(--color-primary-hover);
    letter-spacing: -0.01em;
    list-style: none;
    position: relative;
    user-select: none;
    background: var(--color-primary-soft);
    transition: background var(--transition);
}
.sunalizer-article-page__toc > summary::-webkit-details-marker { display: none; }
.sunalizer-article-page__toc > summary::after {
    content: '';
    position: absolute;
    right: var(--space-5, 20px);
    top: 50%;
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--color-primary);
    border-bottom: 2px solid var(--color-primary);
    transform: translateY(-70%) rotate(45deg);
    transition: transform var(--transition);
}
.sunalizer-article-page__toc[open] > summary::after {
    transform: translateY(-30%) rotate(-135deg);
}
.sunalizer-article-page__toc > summary:hover {
    background: var(--color-primary);
    color: #fff;
}
.sunalizer-article-page__toc > summary:hover::after {
    border-color: #fff;
}
.sunalizer-article-page__toc-list {
    list-style: none;
    margin: 0;
    padding: 0 var(--space-5, 20px) var(--space-4);
    border-top: 1px solid var(--color-border);
}
.sunalizer-article-page__toc-list li {
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-border);
    margin: 0;
}
.sunalizer-article-page__toc-list li:last-child { border-bottom: none; }
.sunalizer-article-page__toc-list a {
    color: var(--color-text);
    text-decoration: none;
    font-size: 15px;
    display: block;
    padding: var(--space-1) 0;
    transition: color var(--transition);
}
.sunalizer-article-page__toc-list a:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

/* Cover image */
.sunalizer-article-page__cover {
    margin: 0 0 var(--space-6, 24px);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.sunalizer-article-page__cover img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--radius-md);
}

/* Typography для всего body */
.sunalizer-article-page h2 {
    font-size: 26px;
    font-weight: 700;
    margin: var(--space-10) 0 var(--space-4);
    color: var(--color-text);
    letter-spacing: -0.01em;
}
.sunalizer-article-page h3 {
    font-size: 19px;
    font-weight: 700;
    margin: var(--space-6) 0 var(--space-3);
    color: var(--color-text);
}
.sunalizer-article-page h4 {
    font-size: 16px;
    font-weight: 700;
    margin: var(--space-5, 20px) 0 var(--space-2);
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.sunalizer-article-page p {
    font-size: 16px;
    line-height: 1.7;
    color: var(--color-text);
    margin: 0 0 var(--space-4);
}
.sunalizer-article-page ul,
.sunalizer-article-page ol {
    padding-left: var(--space-5, 20px);
    margin: 0 0 var(--space-4);
    color: var(--color-text);
    line-height: 1.65;
}
.sunalizer-article-page li {
    margin: 0 0 var(--space-2);
}

/* Tables — обёртка <figure class="wp-block-table"> получает chrome (border/radius/shadow),
   <table> остаётся flush в обёртке. Margin на table убран — он создавал внутренний пробел
   между tbody и нижней рамкой figure. */
.sunalizer-article-page .wp-block-table:not(.sunalizer-top-picks):not(.sunalizer-comparison),
.sunalizer-review-page .wp-block-table:not(.sunalizer-top-picks):not(.sunalizer-comparison) {
    background: var(--color-surface);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin: 0 0 var(--space-8);
}
.sunalizer-article-page table,
.sunalizer-article-page .wp-block-table table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
    font-size: 14px;
}
.sunalizer-article-page th,
.sunalizer-article-page td {
    padding: var(--space-3) var(--space-3);
    border-bottom: 1px solid var(--color-border-strong);
    text-align: left;
    vertical-align: top;
}
.sunalizer-article-page th {
    background: var(--color-surface-sand, #f4ede1);
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.sunalizer-article-page tr:last-child td {
    border-bottom: 1px solid var(--color-border-strong);
}

/* HR разделитель между mini-reviews */
.sunalizer-article-page hr,
.sunalizer-article-page .wp-block-separator {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--space-8) 0;
    opacity: 0.6;
}

/* Inline картинки внутри секций */
.sunalizer-article-page img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    margin: var(--space-4) 0;
}

/* Ссылки — :not() исключает CTA-кнопки внутри embedded patterns (silo-card / review-card /
   top-picks / verdict — у всех белый текст на cyan фоне; общий primary color сделал бы текст
   невидимым). */
.sunalizer-article-page a:not(.sunalizer-silo-card__cta):not(.sunalizer-top-picks__cta):not(.wp-block-button__link):not(.sunalizer-review-page__cta-btn):not(.sunalizer-homepage-hero__cta-primary):not(.sunalizer-homepage-hero__cta-secondary) {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: color var(--transition);
}
.sunalizer-article-page a:not(.sunalizer-silo-card__cta):not(.sunalizer-top-picks__cta):not(.wp-block-button__link):not(.sunalizer-review-page__cta-btn):not(.sunalizer-homepage-hero__cta-primary):not(.sunalizer-homepage-hero__cta-secondary):hover {
    color: var(--color-primary-hover);
}

@media (max-width: 768px) {
    .sunalizer-article-page h2 { font-size: 22px; }
    .sunalizer-article-page h3 { font-size: 17px; }
    .sunalizer-article-page p,
    .sunalizer-article-page li { font-size: 15px; }
    .sunalizer-article-page table { font-size: 13px; }
    .sunalizer-article-page th,
    .sunalizer-article-page td { padding: var(--space-2); }
}

/* Responsive */
@media (max-width: 980px) {
    .sunalizer-review-page__hero {
        grid-template-columns: 1fr;
    }
    .sunalizer-review-page__hero-cta {
        text-align: left;
    }
}

@media (max-width: 540px) {
    .sunalizer-review-page__hero-main {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .sunalizer-app-chip--xl {
        margin: 0 auto;
    }
    .sunalizer-review-page__tagline {
        margin-left: auto;
        margin-right: auto;
    }
}

/* ====================================================
   Silo Archive (hub page) — child cards grid
   ==================================================== */

.sunalizer-silo-intro {
    margin-bottom: var(--space-12);
}

/* ====================================================
   Review Byline (author / date / fact-checker + disclaimer)
   ==================================================== */

.sunalizer-review-byline {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: var(--space-6);
    align-items: center;
    background: var(--color-surface);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    padding: 14px 18px;
    margin: var(--space-4) 0 var(--space-3);
}

.sunalizer-review-byline__col {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.sunalizer-review-byline__col--date {
    justify-content: center;
    padding: 0 var(--space-6);
    border-left: 1px solid var(--color-border-strong);
    border-right: 1px solid var(--color-border-strong);
    white-space: nowrap;
}

.sunalizer-review-byline__col--fc {
    justify-content: flex-end;
}

.sunalizer-review-byline__avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    background: var(--color-surface-sand);
}

.sunalizer-review-byline__text {
    display: flex;
    flex-direction: column;
    line-height: 1.35;
    min-width: 0;
}

.sunalizer-review-byline__line {
    font-size: 14px;
    color: var(--color-text);
}

.sunalizer-review-byline__name {
    font-weight: 700;
    color: var(--color-primary);
    text-decoration: none;
}

.sunalizer-review-byline__name:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

.sunalizer-review-byline__name--plain {
    color: var(--color-text);
    font-weight: 700;
}

.sunalizer-review-byline__title {
    font-size: 13px;
    color: var(--color-text-muted);
}

.sunalizer-review-byline__date {
    font-size: 14px;
    color: var(--color-text);
    font-weight: 500;
}

.sunalizer-review-byline__fc-label {
    font-size: 13px;
    color: var(--color-text-muted);
    white-space: nowrap;
    margin-right: 4px;
}

.sunalizer-review-byline__disclaimer {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--color-surface-sand);
    border: 1px solid #E8DEC5;
    border-radius: var(--radius-md);
    padding: 12px 16px;
    margin: 0 0 var(--space-3);
}

.sunalizer-review-byline__breadcrumbs {
    font-size: 13px;
    line-height: 1.5;
    color: var(--color-text-muted);
    margin: 0 0 var(--space-8);
}

.sunalizer-review-byline__breadcrumbs a {
    color: var(--color-primary);
    text-decoration: none;
}

.sunalizer-review-byline__breadcrumbs a:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

.sunalizer-review-byline__bc-sep {
    color: var(--color-text-muted);
    margin: 0 4px;
}

.sunalizer-review-byline__bc-current {
    color: var(--color-text);
    font-weight: 500;
}

/* ====================================================
   Review page — Comments section
   ==================================================== */

.sunalizer-review-comments {
    margin: var(--space-12) 0;
}

.sunalizer-comments__title,
.sunalizer-comments__form-title {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 var(--space-5, 20px);
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.sunalizer-comments__list {
    list-style: none;
    margin: 0 0 var(--space-8);
    padding: 0;
}

.sunalizer-comments__list .comment {
    padding: var(--space-5, 20px) 0;
    border-bottom: 1px solid var(--color-border-strong);
}

.sunalizer-comments__list .comment:first-child {
    padding-top: 0;
}

.sunalizer-comments__list .comment:last-child {
    border-bottom: 0;
}

.sunalizer-comments__list .comment-author .avatar {
    border-radius: 50%;
    margin-right: 12px;
    vertical-align: middle;
}

.sunalizer-comments__list .comment-meta {
    font-size: 13px;
    color: var(--color-text-muted);
    margin-bottom: var(--space-3);
}

.sunalizer-comments__list .comment-meta a {
    color: var(--color-text-muted);
    text-decoration: none;
}

.sunalizer-comments__list .children {
    list-style: none;
    padding-left: var(--space-6);
    margin: var(--space-4) 0 0;
    border-left: 2px solid var(--color-primary-soft);
}

.sunalizer-comments__form {
    background: var(--color-surface);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    padding: var(--space-6);
}

.sunalizer-comments__form p {
    margin: 0 0 var(--space-4);
}

.sunalizer-comments__form label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sunalizer-comments__form input[type="text"],
.sunalizer-comments__form input[type="email"],
.sunalizer-comments__form input[type="url"],
.sunalizer-comments__form textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    font: inherit;
    font-size: 15px;
    color: var(--color-text);
    transition: border-color var(--transition), box-shadow var(--transition);
}

.sunalizer-comments__form input[type="text"]:focus,
.sunalizer-comments__form input[type="email"]:focus,
.sunalizer-comments__form input[type="url"]:focus,
.sunalizer-comments__form textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-soft);
}

.sunalizer-comments__form textarea {
    min-height: 120px;
    resize: vertical;
    font-family: inherit;
}

.sunalizer-comments__form .required {
    color: var(--color-cons-icon);
}

.sunalizer-comments__form .comment-form-cookies-consent label,
.sunalizer-comments__form .comment-form-cookies-consent {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-transform: none;
    font-weight: 400;
    font-size: 13px;
    color: var(--color-text-muted);
    letter-spacing: 0;
}

.sunalizer-comments__form .comment-form-cookies-consent input {
    width: auto;
}

.sunalizer-comments__submit,
.sunalizer-comments__form input[type="submit"],
.sunalizer-comments__form button[type="submit"] {
    background: var(--color-primary);
    color: #fff !important;
    border: 0;
    padding: 12px 24px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    transition: background var(--transition);
}

.sunalizer-comments__submit:hover,
.sunalizer-comments__form input[type="submit"]:hover,
.sunalizer-comments__form button[type="submit"]:hover {
    background: var(--color-primary-hover);
}

.comments-area .comment-respond { margin: 0; }

/* ====================================================
   Review page — Related Reviews (3-card grid внизу)
   ==================================================== */

.sunalizer-review-related {
    margin: var(--space-12) 0 var(--space-8);
}

.sunalizer-review-related__title {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 var(--space-6);
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.sunalizer-review-byline__disclaimer p {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    color: var(--color-text);
}

.sunalizer-review-byline__disclaimer strong {
    font-weight: 700;
}

.sunalizer-review-byline__disclaimer-icon {
    flex: 0 0 22px;
    width: 22px;
    height: 22px;
    color: var(--color-star);
    margin-top: 1px;
    display: inline-flex;
}

.sunalizer-review-byline__disclaimer-icon svg {
    width: 100%;
    height: 100%;
}

@media (max-width: 800px) {
    .sunalizer-review-byline {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }
    .sunalizer-review-byline__col--date {
        justify-content: flex-start;
        padding: 0;
        border-left: 0;
        border-right: 0;
        border-top: 1px solid var(--color-border-strong);
        border-bottom: 1px solid var(--color-border-strong);
        padding: 10px 0;
    }
    .sunalizer-review-byline__col--fc {
        justify-content: flex-start;
    }
}

/* ====================================================
   Archive pages (silo / reviews) — единая ширина hero + симметричные отступы H1
   ==================================================== */

.sunalizer-container.sunalizer-archive {
    max-width: 1080px;
}

.sunalizer-archive > .entry-title,
.sunalizer-archive .sunalizer-silo-intro > .entry-title {
    margin: 0 0 var(--space-12);
    padding-top: var(--space-12);
}

@media (max-width: 768px) {
    .sunalizer-archive > .entry-title,
    .sunalizer-archive .sunalizer-silo-intro > .entry-title {
        margin-bottom: var(--space-8);
        padding-top: var(--space-8);
    }
}

.sunalizer-silo-children__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-bottom: var(--space-12);
}

.sunalizer-silo-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}

.sunalizer-silo-card:hover {
    border-color: var(--color-border-hover);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.sunalizer-silo-card__cover {
    display: block;
    aspect-ratio: 5 / 3;
    overflow: hidden;
    background: var(--color-surface-sand);
}

.sunalizer-silo-card__cover > svg,
.sunalizer-silo-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.sunalizer-silo-card__body {
    padding: var(--space-5, 20px);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    flex: 1;
}

.sunalizer-silo-card__title {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
}

.sunalizer-silo-card__title a {
    color: var(--color-text);
    text-decoration: none;
    transition: color var(--transition);
}

.sunalizer-silo-card__title a:hover {
    color: var(--color-primary);
}

.sunalizer-silo-card__excerpt {
    font-size: 14px;
    line-height: 1.55;
    color: var(--color-text-muted);
    margin: 0;
    flex: 1;
}

.sunalizer-silo-card__cta {
    align-self: flex-start;
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    padding: 8px 16px;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: background var(--transition);
    margin-top: auto;
}

.sunalizer-silo-card__cta:hover {
    background: var(--color-primary-hover);
    color: #fff;
}

.sunalizer-silo-children__pagination ul {
    display: flex;
    justify-content: center;
    gap: var(--space-2);
    list-style: none;
    padding: 0;
    margin: 0;
}

.sunalizer-silo-children__pagination a,
.sunalizer-silo-children__pagination span {
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    text-decoration: none;
    font-size: 14px;
}

.sunalizer-silo-children__pagination .current {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

@media (max-width: 1024px) {
    .sunalizer-silo-children__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
    .sunalizer-silo-children__grid { grid-template-columns: 1fr; }
}

/* ====================================================
   Accessibility
   ==================================================== */

:focus { outline: none; }

:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

a:focus-visible,
button:focus-visible,
.wp-block-button__link:focus-visible,
summary:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* Skip-to-content link (если site-header добавит) */
.skip-link {
    position: absolute;
    left: -9999px;
    background: var(--color-primary);
    color: #fff;
    padding: var(--space-3) var(--space-4);
    z-index: 1000;
}
.skip-link:focus {
    left: var(--space-4);
    top: var(--space-4);
}

/* ====================================================
   Site Header (Kadence override)
   ==================================================== */

.site-header,
.kadence-header-section {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.site-header .site-title,
.site-header .site-branding a {
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: 22px;
    color: var(--color-text);
    text-decoration: none;
}

.site-header .site-title::before,
.site-header .site-branding a::before {
    content: "●";
    color: var(--color-primary);
    margin-right: 4px;
    font-size: 16px;
}

.main-navigation a {
    font-size: 15px;
    font-weight: 500;
    color: var(--color-text);
    transition: color var(--transition);
}

.main-navigation a:hover {
    color: var(--color-primary);
}

/* ====================================================
   Site Footer
   ==================================================== */

.site-footer,
.kadence-footer-section {
    background: var(--color-surface-dark);
    color: var(--color-text-on-dark);
    padding: var(--space-16) 0 var(--space-8);
    margin-top: var(--space-24);
}

.site-footer h2, .site-footer h3, .site-footer h4 {
    color: var(--color-text-on-dark);
}

.site-footer .footer-widget-title,
.site-footer .widget-title {
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 13px;
    font-weight: 600;
    color: #94A3B8; /* slate-400 */
    margin-bottom: var(--space-4);
}

.site-footer a {
    color: #CBD5E1; /* slate-300 */
    font-size: 14px;
    transition: color var(--transition);
}

.site-footer a:hover {
    color: var(--color-primary-soft);
}

.site-footer .footer-bottom {
    margin-top: var(--space-8);
    padding-top: var(--space-6);
    border-top: 1px solid #1E293B; /* slate-800 */
    font-size: 13px;
    color: #94A3B8;
    text-align: center;
}

/* Newsletter input in footer */
.site-footer input[type="email"], .site-footer input[type="text"] {
    background: #1E293B;
    border: 1px solid #334155;
    color: var(--color-text-on-dark);
    padding: 10px 14px;
    border-radius: var(--radius-md);
    font-size: 14px;
}

/* Trust badges in footer (on-dark variant injected via class on wrapper) */
.site-footer .sunalizer-trust-badges {
    /* Auto-injected variant on dark — use --on-dark modifier */
}

.site-footer .sunalizer-trust-badges__grid img {
    filter: brightness(0) invert(1) opacity(0.7);
}

.site-footer .sunalizer-trust-badges__grid img:hover {
    filter: brightness(0) invert(1) opacity(1);
}

/* ====================================================
   Sidebar widgets
   ==================================================== */

.sunalizer-sidebar .widget,
.sunalizer-sidebar .sunalizer-widget {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: var(--space-5, 20px);
    margin-bottom: var(--space-6);
}

.sunalizer-sidebar .widget-title,
.sunalizer-sidebar .sunalizer-widget__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: var(--space-3);
    margin-bottom: var(--space-4);
}

/* Top 3 widget */
.sunalizer-widget--top3 ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sunalizer-widget--top3 li {
    display: grid;
    grid-template-columns: 32px 1fr;
    gap: var(--space-3);
    align-items: center;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-border);
}

.sunalizer-widget--top3 li:last-child { border-bottom: 0; }

.sunalizer-widget--top3 .sunalizer-app-chip {
    width: 32px;
    height: 32px;
    font-size: 12px;
    border-radius: var(--radius-sm);
}

.sunalizer-widget--top3 .name {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
}

.sunalizer-widget--top3 .rating {
    font-size: 12px;
    color: var(--color-text-muted);
}

/* Latest reviews widget */
.sunalizer-widget--latest ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sunalizer-widget--latest li {
    display: grid;
    grid-template-columns: 60px 1fr;
    gap: var(--space-3);
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-border);
}

.sunalizer-widget--latest li:last-child { border-bottom: 0; }

.sunalizer-widget--latest .thumb {
    width: 60px;
    height: 60px;
    background: var(--color-surface-sand);
    border-radius: var(--radius-sm);
}

.sunalizer-widget--latest .title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sunalizer-widget--latest .date {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-top: 4px;
}

/* ====================================================
   Homepage Hero (2-col, after TL;DR)
   ==================================================== */

.sunalizer-homepage-hero {
    margin: var(--space-8) 0 var(--space-12);
}

.sunalizer-homepage-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: var(--space-12);
    align-items: center;
}

@media (max-width: 900px) {
    .sunalizer-homepage-hero__grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }
}

.sunalizer-homepage-hero__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.sunalizer-homepage-hero__badge {
    display: inline-flex;
    align-self: flex-start;
    background: var(--color-primary-soft);
    color: var(--color-primary-hover);
    font-size: 13px;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    letter-spacing: 0.01em;
}

.sunalizer-homepage-hero__title {
    font-size: clamp(28px, 3.4vw, 40px);
    font-weight: 800;
    line-height: 1.18;
    margin: 0;
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.sunalizer-homepage-hero__lede {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-text-muted);
    margin: 0;
    max-width: 56ch;
}

.sunalizer-homepage-hero__features {
    list-style: none;
    margin: var(--space-2) 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
}

@media (max-width: 700px) {
    .sunalizer-homepage-hero__features {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.sunalizer-homepage-hero__feature {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 10px 12px;
    font-size: 13px;
    line-height: 1.3;
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
}

.sunalizer-homepage-hero__feature-icon {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    background: var(--color-primary-soft);
    border-radius: var(--radius-sm);
}

.sunalizer-homepage-hero__feature-icon svg {
    width: 18px;
    height: 18px;
}

.sunalizer-homepage-hero__feature-text strong {
    display: block;
    font-weight: 600;
    color: var(--color-text);
}

.sunalizer-homepage-hero__disclaimer {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--color-surface-sand);
    border: 1px solid #E8DEC5;
    border-radius: var(--radius-md);
    padding: 12px 14px;
    margin: var(--space-2) 0 0;
    font-size: 13px;
    line-height: 1.5;
    color: var(--color-text-muted);
}

.sunalizer-homepage-hero__disclaimer p {
    margin: 0;
}

.sunalizer-homepage-hero__disclaimer strong {
    color: var(--color-text);
    font-weight: 600;
}

.sunalizer-homepage-hero__disclaimer-icon {
    flex: 0 0 20px;
    width: 20px;
    height: 20px;
    color: var(--color-star);
    margin-top: 1px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.sunalizer-homepage-hero__disclaimer-icon svg {
    width: 100%;
    height: 100%;
}

.sunalizer-homepage-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-3);
}

.sunalizer-homepage-hero__cta-primary,
.sunalizer-homepage-hero__cta-secondary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 15px;
    text-decoration: none;
    line-height: 1;
    transition: background var(--transition, .2s), border-color var(--transition, .2s), box-shadow var(--transition, .2s), color var(--transition, .2s);
}

.sunalizer-homepage-hero__cta-primary {
    background: var(--color-primary);
    color: #fff;
    border: 1px solid var(--color-primary);
}

.sunalizer-homepage-hero__cta-primary:hover,
.sunalizer-homepage-hero__cta-primary:focus {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: #fff;
    box-shadow: var(--shadow-md);
}

.sunalizer-homepage-hero__cta-secondary {
    background: var(--color-surface);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}

.sunalizer-homepage-hero__cta-secondary:hover,
.sunalizer-homepage-hero__cta-secondary:focus {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: var(--color-surface);
}

.sunalizer-homepage-hero__media {
    margin: 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    aspect-ratio: 5 / 4;
    background: var(--color-surface-sand);
    box-shadow: var(--shadow-md, 0 10px 30px -10px rgba(15, 23, 42, 0.18));
}

.sunalizer-homepage-hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ====================================================
   Site Footer — 4-column custom layout (footer.php)
   Цвета захардкожены: Kadence parent ставит низко-контрастные
   override'ы на .site-footer h3/a/p — нужно ВЫИГРАТЬ каскад.
   ==================================================== */

.sunalizer-footer {
    background: #FFFFFF;
    border-top: 1px solid #E2E8F0;
    color: #0F172A;
    padding: 56px 0 0;
    font-size: 15px;
    line-height: 1.6;
}

/* Жёсткий ресет цветов внутри футера — Kadence parent ставит свои */
.sunalizer-footer,
.sunalizer-footer h1, .sunalizer-footer h2, .sunalizer-footer h3,
.sunalizer-footer h4, .sunalizer-footer h5, .sunalizer-footer h6,
.sunalizer-footer p, .sunalizer-footer span, .sunalizer-footer li {
    color: #0F172A;
}

.sunalizer-footer__inner {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
    gap: var(--space-10, 40px);
    padding-bottom: var(--space-10, 40px);
}

.sunalizer-footer__col { min-width: 0; }

.sunalizer-footer .sunalizer-footer__heading {
    font-size: 13px;
    font-weight: 800;
    color: #0F172A;
    margin: 0 0 18px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1.3;
}

.sunalizer-footer .sunalizer-footer__sub-heading {
    font-size: 13px;
    font-weight: 800;
    color: #0F172A;
    margin: 24px 0 10px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.sunalizer-footer__logo {
    display: inline-flex;
    align-items: center;
    margin-bottom: var(--space-4, 16px);
}

.sunalizer-footer__logo img {
    height: auto;
    max-height: 36px;
    width: auto;
}

.sunalizer-footer__brand-text {
    font-size: 22px;
    font-weight: 700;
    color: var(--color-text);
}

.sunalizer-footer .sunalizer-footer__tagline {
    color: #475569;
    margin: 0 0 20px;
    max-width: 36ch;
    font-size: 15px;
}

.sunalizer-footer__social {
    display: flex;
    gap: var(--space-3, 12px);
    list-style: none;
    margin: 0 0 var(--space-2, 8px);
    padding: 0;
}

.sunalizer-footer__social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #0891B2;
    color: #FFFFFF;
    transition: background 150ms, transform 150ms;
    text-decoration: none;
}

.sunalizer-footer__social a:hover {
    background: #0E7490;
    transform: translateY(-2px);
    color: #FFFFFF;
}

.sunalizer-footer__social svg { width: 18px; height: 18px; display: block; fill: #FFFFFF; }

.sunalizer-footer .sunalizer-footer__email {
    color: #0891B2;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
    word-break: break-word;
    font-size: 15px;
}

.sunalizer-footer .sunalizer-footer__email:hover { color: #0E7490; }

.sunalizer-footer__links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.sunalizer-footer .sunalizer-footer__links a {
    color: #1E293B;
    text-decoration: none;
    position: relative;
    padding-left: 18px;
    transition: color 150ms;
    display: inline-block;
    font-size: 15px;
    font-weight: 500;
}

.sunalizer-footer .sunalizer-footer__links a::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 6px;
    height: 6px;
    border-right: 2px solid #0891B2;
    border-top: 2px solid #0891B2;
    transform: rotate(45deg);
    transition: border-color 150ms;
}

.sunalizer-footer .sunalizer-footer__links a:hover {
    color: #0891B2;
}

.sunalizer-footer .sunalizer-footer__links a:hover::before {
    border-color: #0E7490;
}

.sunalizer-footer__col--trust .sunalizer-footer__tagline { margin-bottom: 20px; }

.sunalizer-footer__trust-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.sunalizer-footer__trust {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    padding: 12px 14px;
    transition: border-color 150ms, box-shadow 150ms, transform 150ms;
    min-height: 60px;
}

.sunalizer-footer__trust:hover {
    border-color: #0891B2;
    box-shadow: 0 4px 12px rgba(8, 145, 178, 0.10);
    transform: translateY(-1px);
}

.sunalizer-footer__trust img {
    max-height: 28px;
    max-width: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

.sunalizer-footer__bottom {
    border-top: 1px solid #E2E8F0;
    margin-top: 24px;
    padding: 22px 0;
    color: #475569;
    font-size: 14px;
    text-align: center;
}

@media (max-width: 1024px) {
    .sunalizer-footer__inner {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-8, 32px);
    }
    .sunalizer-footer__col--brand { grid-column: 1 / -1; }
}

@media (max-width: 600px) {
    .sunalizer-footer__inner { grid-template-columns: 1fr; }
}
