:root {
    --cms-border: #e2e8f0;
    --cms-radius: 0.75rem;
}
*, *::before, *::after { box-sizing: border-box; }
body {
    margin: 0;
    font-family: var(--cms-font-body);
    color: #1e293b;
    background: #f8fafc;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 { font-family: var(--cms-font-heading); line-height: 1.2; color: #0f172a; margin-top: 0; }
a { color: var(--cms-primary); text-decoration: none; transition: color 150ms; }
a:hover { color: #0f172a; }
img { max-width: 100%; height: auto; }

/* ── Layout ─────────────────────────────── */
.cms-container { max-width: 960px; margin: 0 auto; padding: 0 1.5rem; }

/* ── Header ─────────────────────────────── */
.cms-site-header {
    background: #fff;
    border-bottom: 1px solid var(--cms-border);
    padding: 1rem 0;
    position: sticky; top: 0; z-index: 50;
}
.cms-site-header__inner {
    display: flex; align-items: center;
    justify-content: space-between;
    gap: 1rem; flex-wrap: wrap;
}
.cms-site-header__brand {
    font-weight: 800; font-size: 1.25rem; color: #0f172a;
    text-decoration: none; display: flex; align-items: center;
}
.cms-site-header__brand:hover { color: var(--cms-primary); }
.cms-site-header__nav {
    display: flex; gap: 1.5rem; font-size: 0.9375rem; font-weight: 500; align-items: center;
}
.cms-site-header__nav a { color: #475569; }
.cms-site-header__nav a:hover { color: var(--cms-primary); }
.cms-nav-child { font-size: 0.875rem; padding-left: 0.5rem; }
.cms-nav-toggle {
    display: none; background: none; border: 1px solid var(--cms-border);
    border-radius: 0.375rem; padding: 0.375rem; cursor: pointer; color: #475569;
}

/* ── Nav (recursive multi-level menu) ────────────────
 #
 # Level 0 = horizontal (header/footer).
 # Level ≥ 1 = vertical dropdown shown on hover of the parent `<li>`.
 # The same markup is used for every location — sidebar overrides
 # level ≥ 1 to stay stacked (see `.cms-sidebar-nav` further below). */
.cms-nav__list { list-style: none; padding: 0; margin: 0; }
.cms-nav__list--level-0 { display: flex; gap: 1.5rem; align-items: center; flex-wrap: wrap; }
.cms-nav__item { position: relative; }
.cms-nav__link { display: block; color: #475569; font-weight: 500; font-size: 0.9375rem; }
.cms-nav__link:hover { color: var(--cms-primary); }
.cms-nav__item--has-children > .cms-nav__link::after {
    content: ' ▾'; font-size: 0.75em; color: #94a3b8;
}
.cms-nav__list--level-1,
.cms-nav__list--level-2 {
    position: absolute; top: 100%; left: 0; min-width: 180px;
    background: #fff; border: 1px solid var(--cms-border);
    border-radius: 0.5rem; padding: 0.5rem 0;
    box-shadow: 0 8px 24px -8px rgba(15, 23, 42, 0.15);
    display: none; z-index: 60;
}
.cms-nav__list--level-1 { flex-direction: column; gap: 0; }
.cms-nav__list--level-2 { left: 100%; top: 0; }
.cms-nav__item:hover > .cms-nav__list--level-1,
.cms-nav__item:hover > .cms-nav__list--level-2,
.cms-nav__item:focus-within > .cms-nav__list--level-1,
.cms-nav__item:focus-within > .cms-nav__list--level-2 { display: block; }
.cms-nav__list--level-1 .cms-nav__link,
.cms-nav__list--level-2 .cms-nav__link { padding: 0.5rem 1rem; font-size: 0.875rem; }

/* ── Sidebar (enabled by Theme.showSidebar) ────────── */
.cms-layout { display: block; }
.cms-layout--with-sidebar {
    display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 2rem; align-items: start;
}
.cms-layout__main { min-width: 0; }
.cms-sidebar {
    background: #fff; border: 1px solid var(--cms-border);
    border-radius: var(--cms-radius); padding: 1.25rem;
    position: sticky; top: 5rem;
}
.cms-sidebar__block + .cms-sidebar__block { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--cms-border); }
.cms-sidebar__title {
    font-size: 0.8125rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.08em; color: #0f172a; margin: 0 0 0.75rem;
}
.cms-sidebar__posts { list-style: none; padding: 0; margin: 0; }
.cms-sidebar__posts li { padding: 0.5rem 0; border-bottom: 1px solid #f1f5f9; }
.cms-sidebar__posts li:last-child { border-bottom: none; }
.cms-sidebar__posts a { color: #0f172a; font-size: 0.9375rem; font-weight: 500; display: block; }
.cms-sidebar__posts a:hover { color: var(--cms-primary); }
.cms-sidebar__posts small { display: block; color: #94a3b8; font-size: 0.75rem; margin-top: 0.125rem; }
/* Sidebar nav stays vertical at every depth — no hover dropdowns. */
.cms-sidebar-nav__list { list-style: none; padding: 0; margin: 0; display: block; position: static; box-shadow: none; border: none; background: transparent; }
.cms-sidebar-nav__list--level-1 { padding-left: 1rem; margin-top: 0.25rem; }
.cms-sidebar-nav__list--level-2 { padding-left: 1rem; margin-top: 0.125rem; }
.cms-sidebar-nav__link { display: block; padding: 0.375rem 0; color: #334155; font-weight: 500; font-size: 0.9375rem; }
.cms-sidebar-nav__link:hover { color: var(--cms-primary); }
.cms-sidebar-nav__list--level-1 .cms-sidebar-nav__link,
.cms-sidebar-nav__list--level-2 .cms-sidebar-nav__link { font-size: 0.875rem; color: #475569; }
@media (max-width: 900px) {
    .cms-layout--with-sidebar { grid-template-columns: 1fr; }
    .cms-sidebar { position: static; }
}

/* ── Header variants (from Theme.headerLayout) ─────── */
/* Centered: brand on its own row, nav centered below. */
.cms-site-header--centered .cms-site-header__inner {
    flex-direction: column; justify-content: center; text-align: center; gap: 0.75rem;
}
.cms-site-header--centered .cms-site-header__nav { justify-content: center; flex-wrap: wrap; }
/* Left: brand on the left, nav pinned to the right (browser default space-between). */
.cms-site-header--left .cms-site-header__inner { flex-direction: row; justify-content: space-between; }
/* Transparent: no background, no border, non-sticky — good over a hero. */
.cms-site-header--transparent {
    background: transparent; border-bottom: none; position: absolute;
    top: 0; left: 0; right: 0; box-shadow: none;
}
.cms-site-header--transparent .cms-site-header__brand,
.cms-site-header--transparent .cms-site-header__nav a { color: #fff; }

/* ── Content ────────────────────────────── */
.cms-content { padding: 3rem 0; min-height: 60vh; }
.cms-page-title { font-size: 2.25rem; margin: 0 0 0.75rem; letter-spacing: -0.02em; }
.cms-page-excerpt { font-size: 1.125rem; color: #64748b; margin-bottom: 2rem; }
.cms-featured-image {
    width: 100%; max-height: 420px; object-fit: cover;
    border-radius: var(--cms-radius); margin-bottom: 2rem;
}

/* ── Prose ──────────────────────────────── */
.cms-prose { max-width: 680px; font-size: 1.0625rem; }
.cms-prose p { margin: 0 0 1.25rem; }
.cms-prose h2 { font-size: 1.5rem; margin-top: 2.5rem; }
.cms-prose h3 { font-size: 1.25rem; margin-top: 2rem; }
.cms-prose img { border-radius: 0.5rem; margin: 1.5rem 0; }
.cms-prose a { color: var(--cms-primary); text-decoration: underline; text-underline-offset: 2px; }
.cms-prose blockquote { margin: 1.5rem 0; padding: 1rem 1.5rem; border-left: 4px solid var(--cms-primary); background: #f1f5f9; border-radius: 0 0.5rem 0.5rem 0; }

/* ── Post cards ─────────────────────────── */
.cms-posts-grid {
    display: grid; grid-template-columns: 1fr; gap: 1rem;
}
.cms-post-card {
    display: block; background: #fff;
    border: 1px solid var(--cms-border);
    border-radius: var(--cms-radius); padding: 1.5rem;
    text-decoration: none; color: inherit;
    transition: border-color 150ms, box-shadow 150ms, transform 150ms;
}
.cms-post-card:hover {
    border-color: var(--cms-primary);
    box-shadow: 0 4px 12px -2px rgba(15, 23, 42, 0.08);
    transform: translateY(-1px);
}
.cms-post-card__image {
    width: 100%; height: 180px; object-fit: cover;
    border-radius: 0.5rem; margin-bottom: 1rem;
}
.cms-post-card__title { font-size: 1.25rem; margin: 0 0 0.5rem; color: #0f172a; }
.cms-post-card__meta { font-size: 0.8125rem; color: #64748b; font-weight: 500; }
.cms-post-card__excerpt { margin-top: 0.5rem; color: #475569; font-size: 0.9375rem; }

/* ── Pages list (home) ──────────────────── */
.cms-pages-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem;
}
.cms-page-card {
    display: flex; align-items: center; gap: 0.75rem;
    background: #fff; border: 1px solid var(--cms-border);
    border-radius: var(--cms-radius); padding: 1rem 1.25rem;
    text-decoration: none; color: #0f172a; font-weight: 600;
    transition: border-color 150ms, box-shadow 150ms;
}
.cms-page-card:hover { border-color: var(--cms-primary); box-shadow: 0 2px 8px -2px rgba(15, 23, 42, 0.08); }
.cms-page-card__icon {
    width: 2.25rem; height: 2.25rem; border-radius: 0.5rem;
    background: color-mix(in srgb, var(--cms-primary) 10%, transparent);
    color: var(--cms-primary); display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

/* ── Footer ─────────────────────────────── */
.cms-site-footer {
    background: #0f172a; color: #cbd5e1;
    padding: 2.5rem 0; margin-top: 4rem; font-size: 0.875rem;
}
.cms-site-footer__inner {
    display: flex; justify-content: space-between; align-items: start;
    flex-wrap: wrap; gap: 1.5rem;
}
.cms-site-footer__brand { font-weight: 700; color: #fff; font-size: 1rem; margin-bottom: 0.25rem; }
.cms-site-footer__copy { color: #94a3b8; font-size: 0.8125rem; }
.cms-site-footer__nav { display: flex; gap: 1.25rem; flex-wrap: wrap; }
.cms-site-footer__nav a { color: #cbd5e1; }
.cms-site-footer__nav a:hover { color: #fff; }
/* Recursive footer nav — level 0 inline, nested levels indented below. */
.cms-footer-nav__list { list-style: none; padding: 0; margin: 0; }
.cms-footer-nav__list--level-0 { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.cms-footer-nav__list--level-1,
.cms-footer-nav__list--level-2 { display: block; font-size: 0.8125rem; padding-left: 0.75rem; margin-top: 0.25rem; }
.cms-footer-nav__list--level-1 .cms-footer-nav__item,
.cms-footer-nav__list--level-2 .cms-footer-nav__item { padding: 0.125rem 0; }
.cms-footer-nav__link { color: #cbd5e1; }
.cms-footer-nav__link:hover { color: #fff; }
.cms-site-footer__social { display: flex; gap: 0.75rem; align-items: center; }
.cms-site-footer__social a { color: #94a3b8; transition: color 150ms; }
.cms-site-footer__social a:hover { color: #fff; }

/* ── Footer variants (from Theme.footerLayout) ─────── */
/* Simple: default single-row layout (no overrides needed). */
/* Columns: 4 balanced columns, vertical stack of brand/copy/nav/social. */
.cms-site-footer--columns .cms-site-footer__inner {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    align-items: start; gap: 2rem; text-align: left;
}
.cms-site-footer--columns .cms-site-footer__nav { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
.cms-site-footer--columns .cms-site-footer__social { flex-wrap: wrap; }
/* Minimal: only the brand/copy block, centered. Menu + socials hidden. */
.cms-site-footer--minimal { padding: 1.5rem 0; margin-top: 3rem; }
.cms-site-footer--minimal .cms-site-footer__inner { justify-content: center; text-align: center; }
.cms-site-footer--minimal .cms-site-footer__nav,
.cms-site-footer--minimal .cms-site-footer__social { display: none; }

/* ── Pagination ─────────────────────────── */
.cms-pagination { display: flex; gap: 0.375rem; justify-content: center; margin-top: 2.5rem; flex-wrap: wrap; }
.cms-pagination a, .cms-pagination span {
    padding: 0.5rem 0.875rem; border-radius: 0.375rem;
    background: #fff; border: 1px solid var(--cms-border);
    font-size: 0.875rem; font-weight: 500; color: #475569;
}
.cms-pagination a:hover { border-color: var(--cms-primary); color: var(--cms-primary); }
.cms-pagination .is-current { background: var(--cms-primary); color: #fff; border-color: var(--cms-primary); }

/* ── Badges ──────────────────────────────── */
.cms-badge {
    display: inline-block; padding: 0.125rem 0.625rem;
    background: var(--cms-accent); color: #fff; border-radius: 999px;
    font-size: 0.75rem; font-weight: 600; vertical-align: middle;
}

/* ── Interactions ─────────────────────────── */
.cms-interactions { margin-top: 3rem; border-top: 1px solid var(--cms-border); padding-top: 2rem; }

.cms-reactions { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.cms-reaction-btn {
    display: inline-flex; align-items: center; gap: 0.375rem;
    background: #fff; border: 1px solid var(--cms-border);
    border-radius: 999px; padding: 0.5rem 1rem; cursor: pointer;
    font-size: 0.875rem; color: #475569; font-family: inherit;
    transition: border-color 150ms, color 150ms;
}
.cms-reaction-btn:hover { border-color: var(--cms-primary); color: var(--cms-primary); }

.cms-share { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 2rem; flex-wrap: wrap; }
.cms-share__label { font-weight: 600; margin-right: 0.25rem; color: #0f172a; font-size: 0.875rem; }
.cms-share-btn {
    display: inline-flex; align-items: center; gap: 0.375rem;
    padding: 0.4rem 0.875rem; border-radius: 0.375rem;
    background: #f1f5f9; color: #475569; font-size: 0.8125rem; font-weight: 500;
    transition: background 150ms, color 150ms; text-decoration: none;
}
.cms-share-btn:hover { background: var(--cms-primary); color: #fff; }
.cms-share-btn svg { width: 14px; height: 14px; }

.cms-comments { margin-top: 2rem; }
.cms-comments-heading { font-size: 1.25rem; margin-bottom: 1.25rem; }
.cms-comments-list { list-style: none; padding: 0; margin: 0 0 2rem; }
/* Visual indent cap: the first two nested <ul> levels each push their
 * children 2.5rem right (0 → 40px → 80px). Any deeper <ul> is reset
 * to 0 so N-level threads still live in the DOM but stop shifting. */
.cms-comments-list--nested { margin: 0.75rem 0 0 2.5rem; }
.cms-comments-list--nested .cms-comments-list--nested .cms-comments-list--nested { margin-left: 0; }
.cms-comments__load-more { margin-bottom: 1.25rem; text-align: center; }
.cms-comment {
    display: block; padding: 1rem 0;
    border-bottom: 1px solid #f1f5f9;
}
.cms-comment__inner { display: flex; gap: 0.75rem; }
.cms-comments-list--nested > .cms-comment { border-bottom: 0; padding: 0.75rem 0; }
.cms-comment:last-child { border-bottom: none; }
.cms-comment__avatar {
    width: 2.25rem; height: 2.25rem; border-radius: 999px;
    background: color-mix(in srgb, var(--cms-primary) 12%, transparent);
    color: var(--cms-primary); display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 0.8125rem; flex-shrink: 0;
}
.cms-comment__body { flex: 1; min-width: 0; }
.cms-comment__meta { display: flex; align-items: baseline; flex-wrap: wrap; }
.cms-comment__author { font-weight: 600; font-size: 0.875rem; color: #0f172a; }
.cms-comment__date { font-size: 0.75rem; color: #94a3b8; margin-left: 0.5rem; }
.cms-comment__content { margin-top: 0.25rem; font-size: 0.9375rem; color: #334155; }
.cms-comment__reply-toggle { margin-top: 0.5rem; }
.cms-comment__reply-toggle[open] > .cms-comment__reply-btn { color: var(--cms-primary); }
.cms-comment__reply-btn {
    display: inline-flex; cursor: pointer; list-style: none;
    font-size: 0.8125rem; color: #64748b; font-weight: 500;
    padding: 0.25rem 0;
}
.cms-comment__reply-btn::-webkit-details-marker { display: none; }
.cms-comment__reply-btn:hover { color: var(--cms-primary); }

.cms-comment-form { display: grid; gap: 0.75rem; margin-top: 1.5rem; }
.cms-comment-form--reply { margin-top: 0.75rem; padding: 0.875rem; background: #f8fafc; border-radius: 0.5rem; }
.cms-comment-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.cms-comment-form__identity {
    margin: 0; padding: 0.625rem 0.875rem;
    background: color-mix(in srgb, var(--cms-primary) 8%, transparent);
    border-radius: 0.375rem; color: #0f172a; font-size: 0.875rem;
}
.cms-comment-form input[type="text"],
.cms-comment-form input[type="email"],
.cms-comment-form textarea {
    padding: 0.625rem 0.875rem; border: 1px solid var(--cms-border);
    border-radius: 0.5rem; font-family: inherit; font-size: 0.9375rem;
    color: #1e293b; background: #fff; transition: border-color 150ms;
    width: 100%;
}
.cms-comment-form input:focus,
.cms-comment-form textarea:focus { outline: none; border-color: var(--cms-primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--cms-primary) 15%, transparent); }
.cms-comment-form textarea { resize: vertical; min-height: 100px; }
.cms-comment-form--reply textarea { min-height: 70px; }
.cms-comment-form__actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.cms-btn-primary {
    display: inline-flex; align-items: center; gap: 0.375rem;
    background: var(--cms-primary); color: #fff; border: 0;
    padding: 0.625rem 1.5rem; border-radius: 0.5rem;
    cursor: pointer; font-family: inherit; font-size: 0.9375rem;
    font-weight: 600; transition: opacity 150ms;
}
.cms-btn-primary:hover { opacity: 0.9; }
.cms-btn-secondary {
    display: inline-flex; align-items: center; gap: 0.375rem;
    background: #fff; color: #475569; border: 1px solid var(--cms-border);
    padding: 0.5rem 1.25rem; border-radius: 0.5rem;
    font-family: inherit; font-size: 0.875rem;
    font-weight: 500; text-decoration: none; transition: border-color 150ms, color 150ms;
}
.cms-btn-secondary:hover { border-color: var(--cms-primary); color: var(--cms-primary); }
.cms-form-notice { color: #94a3b8; font-size: 0.8125rem; }

/* ── Back nav ──────────────────────────── */
.cms-back-link {
    display: inline-flex; align-items: center; gap: 0.375rem;
    font-size: 0.875rem; color: #64748b; font-weight: 500;
    margin-bottom: 1.5rem;
}
.cms-back-link:hover { color: var(--cms-primary); }

/* ── Section headings ──────────────────── */
.cms-section-heading {
    font-size: 1.5rem; margin: 0 0 1.25rem;
    display: flex; align-items: center; gap: 0.75rem;
}
.cms-section-heading::after {
    content: ''; flex: 1; height: 1px; background: var(--cms-border);
}

/* ── Empty state ───────────────────────── */
.cms-empty { color: #94a3b8; font-style: italic; text-align: center; padding: 3rem 0; }

/* ── Flash messages ───────────────────── */
.cms-flash { padding: 0.875rem 1.25rem; border-radius: 0.5rem; margin-bottom: 1.5rem; font-size: 0.9375rem; display: flex; align-items: center; gap: 0.5rem; }
.cms-flash--success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.cms-flash--error { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.cms-flash--warning { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; }

/* ── Responsive ─────────────────────────── */
@media (max-width: 768px) {
    .cms-nav-toggle { display: block; }
    .cms-site-header__nav {
        display: none; flex-direction: column; width: 100%;
        gap: 0; padding-top: 0.75rem;
        border-top: 1px solid var(--cms-border);
    }
    .cms-site-header__inner.is-open .cms-site-header__nav { display: flex; }
    .cms-site-header__nav a { padding: 0.625rem 0; border-bottom: 1px solid #f1f5f9; }
    .cms-site-header__nav a:last-child { border-bottom: none; }
    .cms-nav-child { padding-left: 1rem; }

    .cms-page-title { font-size: 1.75rem; }
    .cms-content { padding: 2rem 0; }
    .cms-pages-grid { grid-template-columns: 1fr; }
    .cms-comment-form__row { grid-template-columns: 1fr; }
    .cms-comments-list--nested { margin-left: 1.25rem; }
    .cms-site-footer__inner { flex-direction: column; text-align: center; align-items: center; }
    .cms-site-footer__nav { justify-content: center; }
    .cms-site-footer__social { justify-content: center; }
}

@media (min-width: 640px) {
    .cms-posts-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── Shortcode: menu embed ─────────────── */
.cms-embedded-menu { margin: 1.5rem 0; }
.cms-embedded-menu__list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-wrap: wrap; gap: 0.25rem;
}
.cms-embedded-menu__item a {
    display: block; padding: 0.5rem 1rem; border-radius: 0.375rem;
    background: #f1f5f9; color: #334155; font-weight: 500; font-size: 0.9375rem;
    transition: background 150ms, color 150ms; text-decoration: none;
}
.cms-embedded-menu__item a:hover { background: var(--cms-primary); color: #fff; }
.cms-embedded-menu__sublist {
    list-style: none; padding: 0.25rem 0 0 1rem; margin: 0;
    display: flex; flex-wrap: wrap; gap: 0.25rem;
}
.cms-embedded-menu__sublist a { font-size: 0.875rem; background: transparent; padding: 0.375rem 0.75rem; }

/* ── Shortcode: form embed ─────────────── */
.cms-embedded-form { background: #f8fafc; border: 1px solid var(--cms-border); border-radius: var(--cms-radius); padding: 1.5rem; margin: 1.5rem 0; }
.cms-embedded-form__title { font-size: 1.125rem; margin: 0 0 1rem; font-family: var(--cms-font-heading); }
.cms-embedded-form .cms-form-field { margin-bottom: 0.75rem; }
.cms-embedded-form label { display: block; font-size: 0.875rem; font-weight: 600; color: #374151; margin-bottom: 0.25rem; }
.cms-embedded-form input[type="text"],
.cms-embedded-form input[type="email"],
.cms-embedded-form input[type="number"],
.cms-embedded-form textarea,
.cms-embedded-form select {
    width: 100%; padding: 0.5rem 0.75rem; border: 1px solid var(--cms-border);
    border-radius: 0.375rem; font-family: inherit; font-size: 0.9375rem;
}
.cms-embedded-form textarea { min-height: 80px; resize: vertical; }
