.cms-sections-mount {
 display: flex;
 flex-direction: column;
 gap: 1.5rem;
 width: 100%;
}

.cms-block {
 position: relative;
}

.cms-hero {
 text-align: center;
 padding: 1.5rem 0 0.5rem;
}

.cms-hero h1 {
 margin: 0.35rem 0 0.75rem;
 font-size: clamp(1.6rem, 4vw, 2.4rem);
}

.cms-hero .lede {
 max-width: 40rem;
 margin: 0 auto;
 font-size: 1.05rem;
 line-height: 1.55;
 color: var(--muted);
}

.cms-text {
 max-width: 42rem;
 margin: 0 auto;
 line-height: 1.55;
}

.cms-cta {
 display: flex;
 justify-content: center;
 padding: 0.5rem 0;
}

.cms-cards {
 display: grid;
 gap: 1rem;
 grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
}

.cms-notice {
 max-width: 42rem;
 margin: 0 auto;
 padding: 0.85rem 1rem;
 border-radius: 12px;
 background: color-mix(in srgb, #1565c0 12%, var(--surface, #fff));
 border: 1px solid color-mix(in srgb, #1565c0 25%, transparent);
}

.cms-notice--warning {
 background: color-mix(in srgb, #e65100 10%, var(--surface, #fff));
 border-color: color-mix(in srgb, #e65100 30%, transparent);
}

.cms-image {
 text-align: center;
}

.cms-image img {
 max-width: 100%;
 height: auto;
 border-radius: 12px;
}

.cms-html {
 max-width: 48rem;
 margin: 0 auto;
}

.cms-block-admin {
 display: flex;
 flex-wrap: wrap;
 align-items: center;
 gap: 0.35rem;
 padding: 0.45rem 0.55rem;
 margin-bottom: 0.5rem;
 background: #1a1714;
 color: #fff;
 border-radius: 10px;
 font-size: 0.78rem;
}

.cms-block-admin .cms-block-type {
 font-weight: 700;
 text-transform: uppercase;
 letter-spacing: 0.04em;
 margin-right: 0.35rem;
 color: #ffd6e4;
}

.site-cms-building .cms-block {
 outline: 2px dashed color-mix(in srgb, #c62828 45%, transparent);
 outline-offset: 4px;
 border-radius: 8px;
}

.page-shell {
 max-width: 52rem;
 margin: 0 auto;
 padding: 1.5rem 1.25rem 3rem;
}