/* =========================================================
   StaticPress – blocks.css
   All page builder block styles
   ========================================================= */

/* ── Block wrapper ──────────────────────────────────────── */
.sp-block {
    padding-block: var(--sp-block-pt, var(--sp-space-12)) var(--sp-block-pb, var(--sp-space-12));
}
.sp-block:first-child { padding-top: 0; }

/* ── Hero ────────────────────────────────────────────────── */
.sp-hero {
    position:   relative;
    background-size:     cover;
    background-position: center;
    background-repeat:   no-repeat;
    display:    flex;
    align-items: center;
    overflow:   hidden;
    padding-block: 0;
}
.sp-hero__overlay {
    position:   absolute;
    inset:      0;
    pointer-events: none;
}
.sp-hero__video {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    z-index:    -1;
}
.sp-hero .sp-container { position: relative; z-index: 1; padding-block: var(--sp-space-20); width: 100%; }
.sp-hero__content  { max-width: 800px; }
.sp-hero--centered .sp-container { display: flex; justify-content: center; }
.sp-hero--centered .sp-hero__content { text-align: center; }
.sp-hero--right .sp-hero__content { margin-left: auto; }

.sp-hero__eyebrow {
    display:    inline-block;
    font-size:  var(--sp-font-size-sm);
    font-weight: var(--sp-font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: .1em;
    color:      var(--sp-color-primary);
    margin-bottom: var(--sp-space-4);
}
.sp-hero__heading { color: inherit; margin-bottom: var(--sp-space-6); }
.sp-hero__sub     { font-size: var(--sp-font-size-xl); opacity: .85; margin-bottom: var(--sp-space-8); line-height: var(--sp-line-height-relaxed); }
.sp-hero__buttons { display: flex; gap: var(--sp-space-4); flex-wrap: wrap; }
.sp-hero--centered .sp-hero__buttons { justify-content: center; }

.sp-hero__scroll  { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; text-decoration: none; animation: sp-bounce 2s infinite; }
.sp-hero__scroll-icon { width: 24px; height: 40px; border: 2px solid currentColor; border-radius: 12px; display: flex; align-items: flex-start; justify-content: center; padding: 5px; }
.sp-hero__scroll-icon::after { content: ''; width: 4px; height: 8px; background: currentColor; border-radius: 2px; animation: sp-scroll-dot 2s infinite; }
@keyframes sp-bounce { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(-10px); } }
@keyframes sp-scroll-dot { 0%,100% { transform: translateY(0); opacity: 1; } 50% { transform: translateY(8px); opacity: 0; } }

/* ── Section ─────────────────────────────────────────────── */
.sp-section {
    position:   relative;
    background-size:     cover;
    background-position: center;
    overflow:   hidden;
}
.sp-section__overlay { position: absolute; inset: 0; pointer-events: none; }
.sp-section .sp-container { position: relative; z-index: 1; }

/* ── Columns ─────────────────────────────────────────────── */
.sp-columns {
    display:    flex;
    flex-wrap:  wrap;
    gap:        var(--sp-space-8);
}
.sp-columns--align-center  { align-items: center; }
.sp-columns--align-bottom  { align-items: flex-end; }
.sp-columns--align-stretch { align-items: stretch; }
.sp-column { flex: 1; min-width: min(100%, 280px); }

/* ── Heading block ───────────────────────────────────────── */
.sp-heading-block { margin-bottom: var(--sp-space-8); }
.sp-heading-block--center { text-align: center; }
.sp-heading-block--right  { text-align: right; }
.sp-eyebrow {
    display:    inline-block;
    font-size:  var(--sp-font-size-sm);
    font-weight: var(--sp-font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: .1em;
    color:      var(--sp-color-primary);
    margin-bottom: var(--sp-space-3);
}
.sp-subheading { font-size: var(--sp-font-size-lg); color: var(--sp-color-text-muted); margin-top: var(--sp-space-4); }

/* ── Image block ─────────────────────────────────────────── */
.sp-image { margin: 0; }
.sp-image--center { text-align: center; }
.sp-image--right  { text-align: right; }
.sp-image__img    { border-radius: var(--sp-radius-lg); max-width: 100%; }
.sp-image figcaption { font-size: var(--sp-font-size-sm); color: var(--sp-color-text-muted); margin-top: var(--sp-space-2); text-align: center; }

/* ── Button block ────────────────────────────────────────── */
.sp-button-wrap         { display: flex; }
.sp-button-wrap--center { justify-content: center; }
.sp-button-wrap--right  { justify-content: flex-end; }

/* ── Toggle / Accordion ──────────────────────────────────── */
.sp-toggle { border-radius: var(--sp-radius-lg); overflow: hidden; }
.sp-toggle--bordered .sp-toggle__item  { border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-md); margin-bottom: var(--sp-space-2); overflow: hidden; }
.sp-toggle--filled   .sp-toggle__item  { background: var(--sp-color-bg-alt); border-radius: var(--sp-radius-md); margin-bottom: var(--sp-space-2); }
.sp-toggle--default  .sp-toggle__item  { border-bottom: 1px solid var(--sp-color-border); }
.sp-toggle--default  .sp-toggle__item:last-child { border-bottom: none; }
.sp-toggle--minimal  .sp-toggle__item  { border-bottom: 1px solid var(--sp-color-border); }

.sp-toggle__btn {
    width:      100%;
    display:    flex;
    align-items: center;
    justify-content: space-between;
    gap:        var(--sp-space-4);
    padding:    var(--sp-space-5) var(--sp-space-6);
    background: none;
    border:     none;
    cursor:     pointer;
    text-align: left;
    font-weight: var(--sp-font-weight-semibold);
    font-size:  1rem;
    color:      var(--sp-color-text);
    font-family: var(--sp-font-body);
    transition: all var(--sp-transition-fast);
}
.sp-toggle__btn:hover { color: var(--sp-color-primary); background: var(--sp-color-bg-alt); }
.sp-toggle__btn[aria-expanded="true"] { color: var(--sp-color-primary); }

.sp-toggle__icon {
    flex-shrink: 0;
    width:  20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid var(--sp-color-border);
    position: relative;
    transition: all var(--sp-transition-fast);
}
.sp-toggle__icon::before,
.sp-toggle__icon::after { content: ''; position: absolute; top: 50%; left: 50%; background: var(--sp-color-text); border-radius: 2px; }
.sp-toggle__icon::before { width: 8px; height: 2px; transform: translate(-50%,-50%); }
.sp-toggle__icon::after  { width: 2px; height: 8px; transform: translate(-50%,-50%); transition: transform var(--sp-transition-fast), opacity var(--sp-transition-fast); }
.sp-toggle__btn[aria-expanded="true"] .sp-toggle__icon { border-color: var(--sp-color-primary); background: var(--sp-color-primary); }
.sp-toggle__btn[aria-expanded="true"] .sp-toggle__icon::before,
.sp-toggle__btn[aria-expanded="true"] .sp-toggle__icon::after { background: #fff; }
.sp-toggle__btn[aria-expanded="true"] .sp-toggle__icon::after { transform: translate(-50%,-50%) rotate(90deg); opacity: 0; }

.sp-toggle__body { overflow: hidden; }
.sp-toggle__body[hidden] { display: none; }
.sp-toggle__content { padding: 0 var(--sp-space-6) var(--sp-space-5); color: var(--sp-color-text-muted); line-height: var(--sp-line-height-relaxed); }

/* ── Tabs ────────────────────────────────────────────────── */
.sp-tabs { overflow: hidden; }
.sp-tabs__nav { display: flex; border-bottom: 2px solid var(--sp-color-border); overflow-x: auto; scrollbar-width: none; gap: 0; }
.sp-tabs__nav::-webkit-scrollbar { display: none; }

.sp-tab__btn {
    padding:    var(--sp-space-3) var(--sp-space-6);
    background: none;
    border:     none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor:     pointer;
    font-weight: var(--sp-font-weight-medium);
    font-size:  var(--sp-font-size-sm);
    color:      var(--sp-color-text-muted);
    white-space: nowrap;
    font-family: var(--sp-font-body);
    transition: all var(--sp-transition-fast);
}
.sp-tab__btn:hover { color: var(--sp-color-primary); }
.sp-tab__btn--active,
.sp-tab__btn[aria-selected="true"] { color: var(--sp-color-primary); border-bottom-color: var(--sp-color-primary); }

/* Pills */
.sp-tabs--pills .sp-tabs__nav { border-bottom: none; gap: var(--sp-space-2); margin-bottom: var(--sp-space-6); }
.sp-tabs--pills .sp-tab__btn { border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-full); margin-bottom: 0; }
.sp-tabs--pills .sp-tab__btn--active { background: var(--sp-color-primary); color: #fff; border-color: var(--sp-color-primary); }

/* Underline */
.sp-tabs--underline .sp-tabs__nav { gap: var(--sp-space-4); }

/* Vertical */
.sp-tabs--vertical { display: flex; gap: var(--sp-space-8); }
.sp-tabs--vertical .sp-tabs__nav { flex-direction: column; border-bottom: none; border-right: 2px solid var(--sp-color-border); min-width: 180px; }
.sp-tabs--vertical .sp-tab__btn { border-bottom: none; border-right: 2px solid transparent; margin-right: -2px; text-align: left; }
.sp-tabs--vertical .sp-tab__btn--active { border-right-color: var(--sp-color-primary); }
.sp-tabs--vertical .sp-tabs__panels { flex: 1; }

.sp-tab__panel { padding-top: var(--sp-space-6); }
.sp-tab__panel[hidden] { display: none; }

/* ── Slider ──────────────────────────────────────────────── */
.sp-slider {
    position:   relative;
    overflow:   hidden;
    border-radius: var(--sp-radius-xl);
    user-select: none;
}
.sp-slider__track { display: flex; transition: transform var(--sp-transition-slow); }
.sp-slider__slide {
    flex:       0 0 100%;
    position:   relative;
    overflow:   hidden;
}
.sp-slider__img   { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.sp-slider__caption {
    position:   absolute;
    bottom:     0;
    left:       0;
    right:      0;
    background: linear-gradient(transparent, rgba(0,0,0,.7));
    padding:    var(--sp-space-8) var(--sp-space-8) var(--sp-space-6);
    color:      #fff;
}
.sp-slider__heading { font-size: var(--sp-font-size-2xl); font-weight: var(--sp-font-weight-bold); margin-bottom: var(--sp-space-2); }
.sp-slider__text    { opacity: .85; margin-bottom: var(--sp-space-4); }

.sp-slider__prev, .sp-slider__next {
    position:   absolute;
    top:        50%;
    transform:  translateY(-50%);
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(4px);
    border:     none;
    width:      48px;
    height:     48px;
    border-radius: var(--sp-radius-full);
    cursor:     pointer;
    font-size:  1.5rem;
    display:    flex;
    align-items: center;
    justify-content: center;
    color:      var(--sp-color-text);
    box-shadow: var(--sp-shadow-md);
    transition: all var(--sp-transition-fast);
    z-index:    10;
}
.sp-slider__prev  { left:  1rem; }
.sp-slider__next  { right: 1rem; }
.sp-slider__prev:hover, .sp-slider__next:hover { background: var(--sp-color-primary); color: #fff; }

.sp-slider__dots { position: absolute; bottom: 1rem; left: 50%; transform: translateX(-50%); display: flex; gap: var(--sp-space-2); z-index: 10; }
.sp-slider__dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.5); border: none; cursor: pointer; padding: 0; transition: all var(--sp-transition-fast); }
.sp-slider__dot--active { background: #fff; width: 24px; border-radius: 4px; }

/* Cards slider */
.sp-slider--cards .sp-slider__track { gap: var(--sp-space-4); }
.sp-slider--cards .sp-slider__slide { flex: 0 0 280px; border-radius: var(--sp-radius-lg); background: var(--sp-color-surface); border: 1px solid var(--sp-color-border); padding: var(--sp-space-6); }

/* ── Features ────────────────────────────────────────────── */
.sp-features { display: grid; gap: var(--sp-space-8); }
.sp-features--cols-2 { grid-template-columns: repeat(2, 1fr); }
.sp-features--cols-3 { grid-template-columns: repeat(3, 1fr); }
.sp-features--cols-4 { grid-template-columns: repeat(4, 1fr); }
.sp-features--cols-6 { grid-template-columns: repeat(6, 1fr); }

.sp-feature { display: flex; flex-direction: column; gap: var(--sp-space-4); }
.sp-feature--icon-left { flex-direction: row; align-items: flex-start; }
.sp-features--icon-left .sp-feature { flex-direction: row; align-items: flex-start; }

.sp-feature__icon {
    width:      56px;
    height:     56px;
    flex-shrink: 0;
    display:    flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,87,255,.1);
    color:      var(--sp-color-primary);
    border-radius: var(--sp-radius-lg);
    font-size:  1.5rem;
}
.sp-feature__img    { width: 56px; height: 56px; object-fit: cover; border-radius: var(--sp-radius-lg); }
.sp-feature__title  { font-size: var(--sp-font-size-lg); font-weight: var(--sp-font-weight-bold); margin-bottom: 0; }
.sp-feature__text   { color: var(--sp-color-text-muted); font-size: var(--sp-font-size-sm); line-height: var(--sp-line-height-relaxed); }
.sp-feature__link   { font-size: var(--sp-font-size-sm); font-weight: var(--sp-font-weight-semibold); color: var(--sp-color-primary); text-decoration: none; }
.sp-feature__link:hover { text-decoration: underline; }

/* Cards style */
.sp-features--card .sp-feature { background: var(--sp-color-surface); border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-xl); padding: var(--sp-space-8); transition: box-shadow var(--sp-transition-fast); }
.sp-features--card .sp-feature:hover { box-shadow: var(--sp-shadow-lg); }

@media (max-width: 768px) {
    .sp-features--cols-3,.sp-features--cols-4,.sp-features--cols-6 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .sp-features--cols-2,.sp-features--cols-3,.sp-features--cols-4,.sp-features--cols-6 { grid-template-columns: 1fr; }
}

/* ── Testimonials ────────────────────────────────────────── */
.sp-testimonials { display: grid; gap: var(--sp-space-8); grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.sp-testimonial {
    background:   var(--sp-color-surface);
    border:       1px solid var(--sp-color-border);
    border-radius: var(--sp-radius-xl);
    padding:      var(--sp-space-8);
    display:      flex;
    flex-direction: column;
    gap:          var(--sp-space-4);
}
.sp-testimonial__avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; }
.sp-testimonial__quote  { font-size: var(--sp-font-size-lg); line-height: var(--sp-line-height-relaxed); color: var(--sp-color-text); font-style: italic; flex: 1; }
.sp-testimonial__quote::before { content: '"'; font-size: 3em; line-height: .5; color: var(--sp-color-primary); opacity: .3; margin-bottom: var(--sp-space-2); display: block; }
.sp-stars { font-size: 1.1rem; color: #F59E0B; letter-spacing: 2px; }
.sp-testimonial__author { display: flex; align-items: center; gap: var(--sp-space-3); }
.sp-testimonial__name   { font-weight: var(--sp-font-weight-semibold); font-size: var(--sp-font-size-sm); }
.sp-testimonial__role   { font-size: var(--sp-font-size-xs); color: var(--sp-color-text-muted); display: block; }

/* ── Team ────────────────────────────────────────────────── */
.sp-team { display: grid; gap: var(--sp-space-8); }
.sp-team--cols-2 { grid-template-columns: repeat(2, 1fr); }
.sp-team--cols-3 { grid-template-columns: repeat(3, 1fr); }
.sp-team--cols-4 { grid-template-columns: repeat(4, 1fr); }

.sp-team-member { text-align: center; }
.sp-team-member__photo { width: 100%; aspect-ratio: 3/4; object-fit: cover; border-radius: var(--sp-radius-xl); margin-bottom: var(--sp-space-4); }
.sp-team-member__name  { font-size: var(--sp-font-size-lg); margin-bottom: var(--sp-space-1); }
.sp-team-member__role  { font-size: var(--sp-font-size-sm); color: var(--sp-color-primary); font-weight: var(--sp-font-weight-semibold); margin-bottom: var(--sp-space-3); }
.sp-team-member__bio   { font-size: var(--sp-font-size-sm); color: var(--sp-color-text-muted); }
.sp-team-member__social { display: flex; justify-content: center; gap: var(--sp-space-3); margin-top: var(--sp-space-4); }

/* ── Pricing ─────────────────────────────────────────────── */
.sp-pricing { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--sp-space-8); align-items: start; }
.sp-pricing-card {
    border:       1px solid var(--sp-color-border);
    border-radius: var(--sp-radius-2xl);
    padding:      var(--sp-space-8);
    display:      flex;
    flex-direction: column;
    gap:          var(--sp-space-6);
    position:     relative;
    background:   var(--sp-color-surface);
    transition:   box-shadow var(--sp-transition-base);
}
.sp-pricing-card--featured {
    border-color: var(--sp-color-primary);
    box-shadow:   0 0 0 3px rgba(0,87,255,.1);
    transform:    scale(1.03);
}
.sp-pricing-card__header { text-align: center; }
.sp-pricing-card__name   { font-size: var(--sp-font-size-xl); font-weight: var(--sp-font-weight-bold); margin-bottom: var(--sp-space-2); }
.sp-pricing-card__badge  { display: inline-block; padding: 4px 12px; background: var(--sp-color-primary); color: #fff; border-radius: var(--sp-radius-full); font-size: var(--sp-font-size-xs); font-weight: var(--sp-font-weight-bold); margin-bottom: var(--sp-space-4); }
.sp-pricing-card__price  { display: flex; align-items: baseline; justify-content: center; gap: var(--sp-space-2); }
.sp-pricing-card__amount { font-size: var(--sp-font-size-5xl); font-weight: var(--sp-font-weight-black); color: var(--sp-color-heading); }
.sp-pricing-card__period { font-size: var(--sp-font-size-sm); color: var(--sp-color-text-muted); }
.sp-pricing-card__features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--sp-space-3); flex: 1; }
.sp-pricing-card__features li { display: flex; align-items: center; gap: var(--sp-space-2); font-size: var(--sp-font-size-sm); }
.sp-pricing-card__features li::before { content: '✓'; color: var(--sp-color-success); font-weight: bold; flex-shrink: 0; }
.sp-pricing-card .sp-btn { width: 100%; justify-content: center; }

/* ── Counter ─────────────────────────────────────────────── */
.sp-counters { display: flex; flex-wrap: wrap; gap: var(--sp-space-10); justify-content: center; }
.sp-counter  { text-align: center; min-width: 150px; }
.sp-counter__number { display: block; font-size: var(--sp-font-size-5xl); font-weight: var(--sp-font-weight-black); color: var(--sp-color-primary); line-height: 1; }
.sp-counter__label  { display: block; font-size: var(--sp-font-size-sm); color: var(--sp-color-text-muted); margin-top: var(--sp-space-2); }

/* ── CTA ─────────────────────────────────────────────────── */
.sp-cta { padding-block: var(--sp-space-16); text-align: center; }
.sp-cta--gradient { background: linear-gradient(135deg, var(--sp-color-primary), var(--sp-color-accent)); color: #fff; }
.sp-cta--boxed .sp-container { background: var(--sp-color-bg-alt); border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-2xl); padding: var(--sp-space-16); }
.sp-cta__heading { margin-bottom: var(--sp-space-4); }
.sp-cta__text    { font-size: var(--sp-font-size-lg); color: var(--sp-color-text-muted); margin-bottom: var(--sp-space-8); max-width: 60ch; margin-inline: auto; }
.sp-cta--gradient .sp-cta__text { color: rgba(255,255,255,.85); }
.sp-cta__buttons { display: flex; gap: var(--sp-space-4); justify-content: center; flex-wrap: wrap; }

/* ── Map ─────────────────────────────────────────────────── */
.sp-map { border-radius: var(--sp-radius-xl); overflow: hidden; border: 1px solid var(--sp-color-border); }

/* ── Video ───────────────────────────────────────────────── */
.sp-video { border-radius: var(--sp-radius-xl); overflow: hidden; }
.sp-video iframe, .sp-video video { width: 100%; height: 100%; display: block; }

/* ── Icon box ────────────────────────────────────────────── */
.sp-icon-box { display: flex; gap: var(--sp-space-5); }
.sp-icon-box--boxed { background: var(--sp-color-bg-alt); border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-xl); padding: var(--sp-space-8); }
.sp-icon-box--circle .sp-icon-box__icon { border-radius: 50%; }
.sp-icon-box--filled .sp-icon-box__icon { background: var(--sp-color-primary); color: #fff; }
.sp-icon-box__icon  { width: 56px; height: 56px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,87,255,.1); color: var(--sp-color-primary); border-radius: var(--sp-radius-lg); font-size: 1.5rem; }
.sp-icon-box__title { font-size: var(--sp-font-size-lg); margin-bottom: var(--sp-space-2); }
.sp-icon-box__text  { color: var(--sp-color-text-muted); font-size: var(--sp-font-size-sm); }

/* ── Divider ─────────────────────────────────────────────── */
.sp-divider { border: none; border-top: 1px solid var(--sp-color-border); margin: var(--sp-space-8) auto; }

/* ── Blog filter ─────────────────────────────────────────── */
.sp-blog-filter__toolbar { display: flex; gap: var(--sp-space-4); flex-wrap: wrap; align-items: center; margin-bottom: var(--sp-space-8); }
.sp-blog-filter__search  { flex: 1; min-width: 200px; padding: var(--sp-space-3) var(--sp-space-5); border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-full); font-size: var(--sp-font-size-sm); background: var(--sp-color-bg); color: var(--sp-color-text); outline: none; transition: border-color var(--sp-transition-fast); }
.sp-blog-filter__search:focus { border-color: var(--sp-color-primary); }
.sp-blog-filter__cats    { display: flex; gap: var(--sp-space-2); flex-wrap: wrap; }
.sp-filter-btn {
    padding:    var(--sp-space-2) var(--sp-space-4);
    border:     1px solid var(--sp-color-border);
    border-radius: var(--sp-radius-full);
    background: transparent;
    cursor:     pointer;
    font-size:  var(--sp-font-size-sm);
    font-weight: var(--sp-font-weight-medium);
    font-family: var(--sp-font-body);
    color:      var(--sp-color-text-muted);
    transition: all var(--sp-transition-fast);
}
.sp-filter-btn:hover, .sp-filter-btn--active { background: var(--sp-color-primary); color: #fff; border-color: var(--sp-color-primary); }
.sp-blog-filter__pagination { display: flex; justify-content: space-between; align-items: center; margin-top: var(--sp-space-8); }
.sp-blog-filter__info { font-size: var(--sp-font-size-sm); color: var(--sp-color-text-muted); }

/* ── Social links ────────────────────────────────────────── */
.sp-social-link {
    display:     flex;
    align-items: center;
    justify-content: center;
    width:       36px;
    height:      36px;
    border-radius: 50%;
    background:  var(--sp-color-bg-alt);
    color:       var(--sp-color-text-muted);
    text-decoration: none;
    font-size:   .9rem;
    transition:  all var(--sp-transition-fast);
    border:      1px solid var(--sp-color-border);
}
.sp-social-link:hover { background: var(--sp-color-primary); color: #fff; border-color: var(--sp-color-primary); }

/* ── Block spacing ───────────────────────────────────────── */
.sp-spacer { display: block; }
