:root {
    --paper: #fff7f0;
    --surface: #ffede0;
    --ink: #3a2a24;
    --muted: #8a7870;
    --muted-soft: #bbaea6;
    --terracotta: color-mix(in srgb, var(--cms-primary) 100%, transparent);
    --border: #f0d8c6;
    --cms-border: #f0d8c6;
    --cms-radius: 24px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
    background: var(--paper); color: var(--ink);
    font-family: var(--cms-font-body); font-size: 16px; line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    background-image: radial-gradient(ellipse 80% 60% at top left, color-mix(in srgb, var(--cms-secondary) 15%, transparent), transparent 60%),
                      radial-gradient(ellipse 60% 40% at bottom right, color-mix(in srgb, var(--cms-accent) 10%, transparent), transparent 50%);
    background-attachment: fixed;
}
h1, h2, h3, h4, h5, h6 { font-family: var(--cms-font-heading); color: var(--ink); font-weight: 500; letter-spacing: -0.015em; line-height: 1.2; }
a { color: var(--ink); text-decoration: none; transition: color 150ms; }
a:hover { color: var(--cms-primary); }
img { max-width: 100%; height: auto; display: block; }

.cms-container { max-width: 1120px; margin: 0 auto; padding: 0 2rem; }

/* Header — floating pill */
.cms-site-header { padding: 1.5rem 0; }
.cms-site-header__inner {
    display: flex; align-items: center; justify-content: space-between;
    background: rgba(255,255,255,0.7); backdrop-filter: blur(12px);
    border: 1px solid var(--border); border-radius: 999px;
    padding: 0.75rem 1.5rem;
    box-shadow: 0 12px 32px -16px rgba(58,42,36,0.12);
    gap: 1rem; flex-wrap: wrap;
}
.cms-site-header__brand {
    font-family: var(--cms-font-heading); font-size: 1.375rem; font-weight: 500;
    color: var(--ink); letter-spacing: -0.01em; display: flex; align-items: center; gap: 0.5rem;
}
.cms-soft-brand-dot { width: 1.5rem; height: 1.5rem; border-radius: 50%; background: linear-gradient(135deg, var(--cms-secondary), var(--cms-primary)); }
.cms-site-header__nav { display: flex; gap: 1.75rem; font-size: 0.875rem; align-items: center; }
.cms-site-header__nav a { color: var(--ink); font-weight: 500; }
.cms-site-header__nav a:hover { color: var(--cms-primary); }
.cms-nav-toggle { display: none; background: none; border: none; padding: 0.25rem; cursor: pointer; color: var(--ink); }

/* Nav */
.cms-nav__list { list-style: none; padding: 0; margin: 0; }
.cms-nav__list--level-0 { display: flex; gap: 1.75rem; align-items: center; flex-wrap: wrap; }
.cms-nav__item { position: relative; }
.cms-nav__link { display: block; color: var(--ink); font-weight: 500; font-size: 0.875rem; }
.cms-nav__link:hover { color: var(--cms-primary); }
.cms-nav__item--has-children > .cms-nav__link::after { content: ' ✦'; color: var(--muted); font-size: 0.8em; }
.cms-nav__list--level-1, .cms-nav__list--level-2 {
    position: absolute; top: 100%; left: 0; min-width: 200px;
    background: #fff; border: 1px solid var(--border); border-radius: 16px;
    padding: 0.75rem 0; display: none; z-index: 60;
    box-shadow: 0 20px 40px -16px rgba(58,42,36,0.15);
}
.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 1.25rem; }

/* Sidebar */
.cms-layout { display: block; }
.cms-layout--with-sidebar { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 3rem; align-items: start; }
.cms-layout__main { min-width: 0; }
.cms-sidebar { background: #fff; border-radius: 24px; padding: 1.5rem; position: sticky; top: 6rem; box-shadow: 0 8px 24px -16px rgba(58,42,36,0.1); }
.cms-sidebar__block + .cms-sidebar__block { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.cms-sidebar__title { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--cms-primary); margin: 0 0 1rem; }
.cms-sidebar__posts { list-style: none; padding: 0; margin: 0; }
.cms-sidebar__posts li { padding: 0.5rem 0; }
.cms-sidebar__posts a { color: var(--ink); font-size: 0.9375rem; font-weight: 500; display: block; font-family: var(--cms-font-heading); }
.cms-sidebar__posts a:hover { color: var(--cms-primary); }
.cms-sidebar__posts small { display: block; color: var(--muted); font-size: 0.7rem; margin-top: 0.125rem; }
.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: 0.875rem; margin-top: 0.25rem; }
.cms-sidebar-nav__list--level-2 { padding-left: 0.875rem; margin-top: 0.125rem; }
.cms-sidebar-nav__link { display: block; padding: 0.4rem 0; color: var(--ink); font-weight: 500; font-size: 0.9375rem; }
.cms-sidebar-nav__link:hover { color: var(--cms-primary); }
@media (max-width: 960px) { .cms-layout--with-sidebar { grid-template-columns: 1fr; gap: 2rem; } .cms-sidebar { position: static; } }

/* Header variants */
.cms-site-header--centered .cms-site-header__inner { flex-direction: column; text-align: center; gap: 1rem; border-radius: 32px; }
.cms-site-header--centered .cms-site-header__nav { justify-content: center; }
.cms-site-header--transparent .cms-site-header__inner { background: transparent; backdrop-filter: none; border: none; box-shadow: none; }

main { padding-bottom: 4rem; }

/* Kicker */
.cms-soft-kicker {
    display: inline-flex; align-items: center; gap: 0.5rem;
    background: var(--surface); padding: 0.375rem 0.875rem; border-radius: 999px;
    font-size: 0.75rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--cms-primary); margin-bottom: 1.25rem; font-family: var(--cms-font-body);
}
.cms-soft-kicker::before { content: '●'; color: var(--cms-primary); font-size: 0.6em; }

/* Hero */
.cms-soft-hero { display: grid; grid-template-columns: 1.2fr 1fr; gap: 3rem; align-items: center; margin: 3rem 0 5rem; }
.cms-soft-hero__body { display: flex; flex-direction: column; align-items: flex-start; }
.cms-soft-hero__title { font-size: clamp(2.5rem, 5vw, 4.25rem); font-weight: 500; margin: 0 0 1.25rem; line-height: 1.05; letter-spacing: -0.025em; color: var(--ink); }
.cms-soft-hero__title em { font-style: italic; color: var(--cms-primary); }
.cms-soft-hero__lede { font-size: 1.125rem; color: var(--muted); max-width: 480px; margin: 0 0 2rem; line-height: 1.6; }
.cms-soft-hero__media { aspect-ratio: 4 / 5; border-radius: 40px; overflow: hidden; background: linear-gradient(160deg, color-mix(in srgb, var(--cms-secondary) 70%, var(--paper)) 0%, var(--cms-primary) 100%); box-shadow: 0 30px 60px -30px rgba(58,42,36,0.35); position: relative; }
.cms-soft-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.cms-soft-cta {
    display: inline-flex; align-items: center; gap: 0.5rem;
    background: var(--ink); color: var(--paper); padding: 0.875rem 1.75rem;
    border-radius: 999px; font-weight: 600; font-size: 0.9375rem; text-decoration: none;
    transition: transform 200ms, background 200ms; font-family: var(--cms-font-body);
}
.cms-soft-cta:hover { transform: translateY(-2px); background: var(--cms-primary); color: var(--paper); }
.cms-soft-cta::after { content: '→'; transition: transform 200ms; }
.cms-soft-cta:hover::after { transform: translateX(3px); }

/* Section head */
.cms-soft-sec-head { text-align: center; margin: 4.5rem 0 2.5rem; }
.cms-soft-sec-head__title { font-size: 2.25rem; font-weight: 500; letter-spacing: -0.02em; margin: 0.5rem 0 0; color: var(--ink); }
.cms-soft-sec-head .cms-soft-kicker { margin-bottom: 0; }

.cms-section-heading { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--cms-primary); margin: 4rem 0 2rem; font-family: var(--cms-font-body); }

/* Cards */
.cms-soft-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.75rem; }
.cms-soft-card {
    background: #fff; border-radius: 24px; overflow: hidden;
    text-decoration: none; color: var(--ink);
    box-shadow: 0 8px 24px -12px rgba(58,42,36,0.1);
    transition: transform 250ms, box-shadow 250ms;
    display: flex; flex-direction: column;
}
.cms-soft-card:hover { transform: translateY(-4px); box-shadow: 0 20px 40px -16px rgba(58,42,36,0.18); }
.cms-soft-card__media { aspect-ratio: 5 / 3; background: linear-gradient(135deg, color-mix(in srgb, var(--cms-primary) 60%, var(--paper)) 0%, var(--cms-primary) 100%); overflow: hidden; }
.cms-soft-card:nth-child(even) .cms-soft-card__media { background: linear-gradient(135deg, color-mix(in srgb, var(--cms-secondary) 60%, var(--paper)) 0%, var(--cms-secondary) 100%); }
.cms-soft-card:nth-child(3n) .cms-soft-card__media { background: linear-gradient(135deg, color-mix(in srgb, var(--cms-accent) 60%, var(--paper)) 0%, var(--cms-accent) 100%); }
.cms-soft-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms; }
.cms-soft-card:hover .cms-soft-card__media img { transform: scale(1.04); }
.cms-soft-card__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.cms-soft-card__cat { font-size: 0.75rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cms-primary); font-weight: 600; margin-bottom: 0.5rem; display: block; }
.cms-soft-card__title { font-size: 1.375rem; font-weight: 500; line-height: 1.25; letter-spacing: -0.01em; margin: 0 0 0.5rem; color: var(--ink); }
.cms-soft-card:hover .cms-soft-card__title { color: var(--cms-primary); }
.cms-soft-card__excerpt { font-size: 0.9375rem; color: var(--muted); flex: 1; margin-bottom: 1rem; line-height: 1.55; }
.cms-soft-card__meta { font-size: 0.8125rem; color: var(--muted-soft); }

/* Pages grid */
.cms-pages-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1rem; }
.cms-page-card { display: flex; align-items: center; gap: 0.875rem; background: #fff; border-radius: 16px; padding: 1rem 1.25rem; color: var(--ink); font-weight: 500; box-shadow: 0 4px 12px -6px rgba(58,42,36,0.08); transition: transform 200ms, box-shadow 200ms; }
.cms-page-card:hover { transform: translateY(-2px); box-shadow: 0 10px 24px -10px rgba(58,42,36,0.15); color: var(--cms-primary); }
.cms-page-card__icon { width: 2rem; height: 2rem; border-radius: 50%; background: var(--surface); color: var(--cms-primary); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 0.875rem; }

/* Article */
.cms-soft-article { max-width: 760px; margin: 3rem auto; background: #fff; border-radius: 32px; padding: 3rem 3rem; box-shadow: 0 12px 40px -20px rgba(58,42,36,0.12); }
.cms-soft-article__header { margin-bottom: 2rem; }
.cms-soft-article__title { font-size: clamp(1.875rem, 3.5vw, 2.75rem); font-weight: 500; letter-spacing: -0.02em; line-height: 1.1; margin: 0 0 1rem; }
.cms-soft-article__lede { font-size: 1.25rem; color: var(--muted); line-height: 1.55; margin: 0 0 1.5rem; }
.cms-soft-article__byline { display: flex; align-items: center; gap: 0.875rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--border); }
.cms-soft-article__avatar { width: 2.5rem; height: 2.5rem; border-radius: 50%; background: linear-gradient(135deg, var(--cms-secondary), var(--cms-primary)); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 600; font-family: var(--cms-font-heading); }
.cms-soft-article__byline-name { font-weight: 600; font-size: 0.9375rem; }
.cms-soft-article__byline-date { font-size: 0.8125rem; color: var(--muted); }

/* Blog index head */
.cms-soft-index-head { text-align: center; padding: 3rem 0 3rem; }
.cms-soft-index-title { font-size: clamp(2.5rem, 5vw, 3.75rem); font-weight: 500; letter-spacing: -0.025em; margin: 0.5rem 0 0.75rem; }
.cms-soft-index-sub { color: var(--muted); font-size: 1.125rem; margin: 0; }

.cms-featured-image { width: 100%; max-height: 500px; object-fit: cover; border-radius: 24px; margin: 2rem 0; }
.cms-page-title { font-size: 2.5rem; font-weight: 500; margin: 0 0 1rem; letter-spacing: -0.02em; line-height: 1.1; }
.cms-page-excerpt { font-size: 1.125rem; color: var(--muted); margin-bottom: 2rem; line-height: 1.55; }

/* Prose */
.cms-prose { font-family: var(--cms-font-heading); font-size: 1.125rem; line-height: 1.8; color: #4a3a30; }
.cms-prose p { margin: 0 0 1.25rem; }
.cms-prose h2 { font-size: 1.625rem; margin: 2.75rem 0 1rem; font-weight: 500; color: var(--ink); }
.cms-prose h3 { font-size: 1.25rem; margin: 2rem 0 0.75rem; font-weight: 500; color: var(--ink); }
.cms-prose img { margin: 2rem 0; border-radius: 16px; }
.cms-prose a { color: var(--cms-primary); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.cms-prose ul, .cms-prose ol { margin: 0 0 1.5rem 1.25rem; }
.cms-prose li { margin-bottom: 0.5rem; }
.cms-prose blockquote { font-style: italic; font-size: 1.25rem; color: var(--cms-primary); border: none; padding: 1rem 0 1rem 1.5rem; border-left: 3px solid var(--cms-secondary); margin: 2rem 0; }

/* Footer */
.cms-site-footer { margin-top: 5rem; padding: 3rem 0 1.5rem; border-top: 1px solid var(--border); text-align: center; }
.cms-site-footer__inner { display: flex; justify-content: center; align-items: baseline; flex-wrap: wrap; gap: 2rem; }
.cms-site-footer__brand { font-family: var(--cms-font-heading); font-size: 1.5rem; font-weight: 500; color: var(--ink); margin: 0 0 0.25rem; }
.cms-site-footer__copy { font-size: 0.8125rem; color: var(--muted); margin: 0; }
.cms-site-footer__nav { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.cms-site-footer__nav a { color: var(--ink); font-size: 0.875rem; font-weight: 500; }
.cms-site-footer__nav a:hover { color: var(--cms-primary); }
.cms-footer-nav__list { list-style: none; padding: 0; margin: 0; }
.cms-footer-nav__list--level-0 { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.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__link { color: var(--ink); font-size: 0.875rem; font-weight: 500; }
.cms-footer-nav__link:hover { color: var(--cms-primary); }
.cms-site-footer__social { display: flex; gap: 1rem; }
.cms-site-footer__social a { color: var(--muted); }
.cms-site-footer__social a:hover { color: var(--cms-primary); }
.cms-site-footer--columns .cms-site-footer__inner { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); 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--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: 3rem; flex-wrap: wrap; }
.cms-pagination a, .cms-pagination span { padding: 0.5rem 0.875rem; background: #fff; border: 1px solid var(--border); border-radius: 999px; font-size: 0.8125rem; font-weight: 500; color: var(--ink); font-variant-numeric: tabular-nums; transition: border-color 150ms, background 150ms; }
.cms-pagination a:hover { border-color: var(--cms-primary); }
.cms-pagination .is-current { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* Badge */
.cms-badge { display: inline-block; padding: 0.15rem 0.625rem; background: var(--cms-primary); color: #fff; border-radius: 999px; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; vertical-align: middle; }

/* Back link */
.cms-back-link { display: inline-flex; align-items: center; gap: 0.375rem; font-size: 0.8125rem; color: var(--muted); margin-bottom: 1.5rem; transition: color 150ms, transform 200ms; }
.cms-back-link:hover { color: var(--cms-primary); }
.cms-back-link svg { transition: transform 200ms; }
.cms-back-link:hover svg { transform: translateX(-2px); }

/* Interactions */
.cms-interactions { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); display: grid; gap: 1.25rem; }
.cms-reactions { display: flex; gap: 0.5rem; flex-wrap: wrap; margin: 0; }
.cms-reaction-btn { display: inline-flex; align-items: center; gap: 0.375rem; background: #fff; border: 1px solid var(--border); padding: 0.5rem 1.125rem; border-radius: 999px; cursor: pointer; font-family: inherit; font-size: 0.8125rem; color: var(--ink); font-weight: 500; transition: transform 150ms, border-color 150ms, color 150ms; }
.cms-reaction-btn:hover { transform: translateY(-1px); border-color: var(--cms-primary); color: var(--cms-primary); }
.cms-share { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; margin: 0; }
.cms-share__label { font-size: 0.75rem; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; margin-right: 0.25rem; }
.cms-share-btn { display: inline-flex; align-items: center; gap: 0.375rem; padding: 0.4rem 0.875rem; background: #fff; border: 1px solid var(--border); border-radius: 999px; color: var(--ink); font-size: 0.8125rem; cursor: pointer; font-family: inherit; text-decoration: none; transition: border-color 150ms; }
.cms-share-btn:hover { border-color: var(--cms-primary); color: var(--cms-primary); }
.cms-share-btn svg { width: 14px; height: 14px; }

.cms-comments { margin-top: 2rem; }
.cms-comments-heading { font-family: var(--cms-font-heading); font-size: 1.5rem; font-weight: 500; margin-bottom: 1.5rem; }
.cms-comments-list { list-style: none; padding: 0; margin: 0 0 2rem; }
.cms-comments-list--nested { margin: 0.75rem 0 0 2rem; }
.cms-comments-list--nested .cms-comments-list--nested .cms-comments-list--nested { margin-left: 0; }
.cms-comment { padding: 1.25rem 0; border-bottom: 1px solid var(--border); }
.cms-comment__inner { display: flex; gap: 1rem; }
.cms-comment:last-child { border-bottom: none; }
.cms-comment__avatar { width: 2.5rem; height: 2.5rem; border-radius: 50%; background: linear-gradient(135deg, var(--cms-secondary), var(--cms-primary)); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--cms-font-heading); font-weight: 600; font-size: 0.9375rem; flex-shrink: 0; }
.cms-comment__body { flex: 1; min-width: 0; }
.cms-comment__author { font-weight: 600; font-size: 0.9375rem; color: var(--ink); }
.cms-comment__date { font-size: 0.75rem; color: var(--muted-soft); margin-left: 0.5rem; }
.cms-comment__content { margin-top: 0.375rem; font-size: 0.9375rem; line-height: 1.7; }
.cms-comment__reply-btn { display: inline-flex; cursor: pointer; list-style: none; font-size: 0.8125rem; color: var(--cms-primary); font-weight: 500; padding: 0.25rem 0; }
.cms-comment__reply-btn::-webkit-details-marker { display: none; }

/* Comment form */
.cms-comment-form { display: grid; gap: 0.75rem; margin-top: 1.5rem; }
.cms-comment-form--reply { margin-top: 0.75rem; padding: 1.25rem; background: #fff; border-radius: 16px; box-shadow: 0 4px 12px -6px rgba(58,42,36,0.08); }
.cms-comment-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.cms-comment-form__identity { margin: 0; padding: 0.75rem 1.125rem; background: var(--surface); border-radius: 999px; font-size: 0.9rem; }
.cms-comment-form input[type="text"], .cms-comment-form input[type="email"], .cms-comment-form textarea { padding: 0.75rem 1rem; border: 1px solid var(--border); border-radius: 12px; font-family: inherit; font-size: 0.9375rem; color: var(--ink); background: #fff; width: 100%; }
.cms-comment-form input:focus, .cms-comment-form textarea:focus { outline: none; border-color: var(--cms-primary); }
.cms-comment-form textarea { resize: vertical; min-height: 110px; border-radius: 16px; }
.cms-comment-form__actions { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }
.cms-btn-primary { display: inline-flex; align-items: center; gap: 0.5rem; background: var(--ink); color: var(--paper); border: 0; padding: 0.75rem 1.75rem; border-radius: 999px; cursor: pointer; font-family: inherit; font-size: 0.9rem; font-weight: 600; transition: transform 150ms, background 150ms; }
.cms-btn-primary:hover { transform: translateY(-1px); background: var(--cms-primary); }
.cms-btn-secondary { display: inline-flex; gap: 0.375rem; background: #fff; color: var(--ink); border: 1px solid var(--border); padding: 0.625rem 1.25rem; border-radius: 999px; font-family: inherit; font-size: 0.875rem; text-decoration: none; transition: border-color 150ms; }
.cms-btn-secondary:hover { border-color: var(--cms-primary); }
.cms-form-notice { color: var(--muted); font-size: 0.8125rem; }

.cms-empty { color: var(--muted); text-align: center; padding: 3rem 0; font-style: italic; }
.cms-flash { padding: 0.875rem 1.25rem; margin-bottom: 1.5rem; font-size: 0.9rem; border-radius: 16px; border: 1px solid; }
.cms-flash--success { background: #f0f9f4; border-color: #86e0a9; color: #14532d; }
.cms-flash--error { background: #fef2f2; border-color: #fca5a5; color: #7f1d1d; }
.cms-flash--warning { background: #fffbeb; border-color: #fde68a; color: #78350f; }

/* Shortcodes */
.cms-embedded-menu { margin: 1.75rem 0; }
.cms-embedded-menu__list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.cms-embedded-menu__item a { display: block; padding: 0.5rem 1.125rem; background: #fff; border: 1px solid var(--border); border-radius: 999px; color: var(--ink); font-size: 0.875rem; font-weight: 500; text-decoration: none; transition: border-color 150ms; }
.cms-embedded-menu__item a:hover { border-color: var(--cms-primary); color: var(--cms-primary); }
.cms-embedded-menu__sublist { list-style: none; padding: 0.25rem 0 0 1rem; margin: 0; display: flex; flex-wrap: wrap; gap: 0.375rem; }
.cms-embedded-menu__sublist a { font-size: 0.8125rem; background: transparent; color: var(--muted); padding: 0.375rem 0.75rem; border: none; }
.cms-embedded-form { background: #fff; border: 1px solid var(--border); border-radius: 24px; padding: 2rem; margin: 2rem 0; box-shadow: 0 8px 24px -12px rgba(58,42,36,0.08); }
.cms-embedded-form__title { font-family: var(--cms-font-heading); font-size: 1.375rem; margin: 0 0 1.25rem; font-weight: 500; }
.cms-embedded-form label { display: block; font-size: 0.8125rem; font-weight: 600; color: var(--ink); margin-bottom: 0.375rem; }
.cms-embedded-form input, .cms-embedded-form textarea, .cms-embedded-form select { width: 100%; padding: 0.625rem 1rem; border: 1px solid var(--border); border-radius: 12px; font-family: inherit; font-size: 0.9375rem; background: #fff; }
.cms-embedded-form textarea { min-height: 90px; resize: vertical; border-radius: 16px; }

@media (max-width: 768px) {
    .cms-nav-toggle { display: block; }
    .cms-site-header__inner { border-radius: 24px; }
    .cms-site-header__nav { display: none; flex-direction: column; width: 100%; gap: 0; padding-top: 0.75rem; border-top: 1px solid var(--border); }
    .cms-site-header__inner.is-open .cms-site-header__nav { display: flex; }
    .cms-site-header__nav a { padding: 0.75rem 0; }
    .cms-soft-hero { grid-template-columns: 1fr; }
    .cms-soft-hero__media { aspect-ratio: 3 / 2; }
    .cms-soft-cards { 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; }
    .cms-soft-article { padding: 2rem 1.5rem; }
}
