@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500;600&family=Inter:wght@300;400;500;600&display=swap');

.sp-block {
    width: 100%;
    background: #ffffff;
    color: #1f2937;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;
    font-size: 16px;
    line-height: 1.65;
    font-weight: 400;
    letter-spacing: 0.005em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
}
.sp-block *, .sp-block *::before, .sp-block *::after { box-sizing: border-box; }
.sp-block p { margin: 0 0 1em 0; color: #4b5563; }
.sp-block p:last-child { margin-bottom: 0; }
.sp-block a { color: #059669; text-decoration: none; transition: color .2s ease; }
.sp-block a:hover { color: #1f2937; }

.sp-block .sp-container { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 768px) { .sp-block .sp-container { padding: 0 20px; } }

.sp-block .sp-section { padding: 90px 0; }
@media (max-width: 768px) { .sp-block .sp-section { padding: 56px 0; } }

.sp-block .sp-hero { background: #ffffff; }
.sp-block .sp-pillars { background: #fbfaf6; }
.sp-block .sp-editorial { background: #ffffff; }
.sp-block .sp-universes { background: #fbfaf6; }
.sp-block .sp-services { background: #ffffff; }
.sp-block .sp-quote { background: #f5f3ec; }

.sp-block .sp-eyebrow {
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #059669;
    margin-bottom: 18px;
}

.sp-block .sp-title, .sp-block .sp-h2, .sp-block .sp-h3 {
    font-family: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
    font-weight: 500;
    color: #1f2937;
    line-height: 1.18;
    letter-spacing: -0.01em;
    margin: 0 0 24px 0;
}
.sp-block .sp-title { font-size: clamp(32px, 4.2vw, 52px); }
.sp-block .sp-h2 { font-size: clamp(26px, 3vw, 38px); }
.sp-block .sp-h3 { font-size: clamp(22px, 2.2vw, 28px); }

.sp-block .sp-lead {
    font-family: 'Inter', sans-serif;
    font-size: clamp(16px, 1.25vw, 18px);
    line-height: 1.7;
    color: #4b5563;
    font-weight: 300;
    max-width: 760px;
}

.sp-block .sp-grid { display: grid; gap: 48px; }
@media (max-width: 768px) { .sp-block .sp-grid { gap: 36px; } }
.sp-block .sp-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sp-block .sp-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.sp-block .sp-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 1024px) {
    .sp-block .sp-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .sp-block .sp-grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
    .sp-block .sp-grid-4, .sp-block .sp-grid-3, .sp-block .sp-grid-2 { grid-template-columns: 1fr; }
}

.sp-block .sp-hero { text-align: center; }
.sp-block .sp-hero .sp-container { max-width: 920px; }
.sp-block .sp-hero .sp-eyebrow { margin-bottom: 20px; }
.sp-block .sp-hero .sp-title { margin-bottom: 28px; }
.sp-block .sp-hero .sp-lead { margin: 0 auto; text-align: center; }
.sp-block .sp-divider { width: 64px; height: 1px; background: #10b981; margin: 48px auto 0 auto; position: relative; }
.sp-block .sp-divider::before, .sp-block .sp-divider::after { content: ''; position: absolute; top: 50%; width: 4px; height: 4px; border-radius: 50%; background: #10b981; transform: translateY(-50%); }
.sp-block .sp-divider::before { left: -14px; }
.sp-block .sp-divider::after { right: -14px; }

.sp-block .sp-pillar { text-align: center; padding: 16px 8px; }
.sp-block .sp-icon { display: inline-flex; align-items: center; justify-content: center; width: 68px; height: 68px; border-radius: 50%; background: rgba(16, 185, 129, 0.08); color: #059669; margin-bottom: 22px; }
.sp-block .sp-icon svg { width: 34px; height: 34px; }
.sp-block .sp-pillar-title { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 22px; font-weight: 500; color: #1f2937; margin: 0 0 12px 0; line-height: 1.3; }
.sp-block .sp-pillar-text { font-size: 15px; line-height: 1.65; color: #6b7280; max-width: 260px; margin: 0 auto; }

.sp-block .sp-editorial-grid { gap: 80px; }
@media (max-width: 1024px) { .sp-block .sp-editorial-grid { gap: 48px; } }
.sp-block .sp-editorial-col .sp-h3 { margin-bottom: 20px; position: relative; padding-bottom: 18px; }
.sp-block .sp-editorial-col .sp-h3::after { content: ''; position: absolute; bottom: 0; left: 0; width: 40px; height: 1px; background: #10b981; }
.sp-block .sp-editorial-col p { font-size: 15.5px; line-height: 1.75; }

.sp-block .sp-section-header { text-align: center; margin-bottom: 64px; }
@media (max-width: 768px) { .sp-block .sp-section-header { margin-bottom: 44px; } }
.sp-block .sp-universe { background: #ffffff; padding: 38px 32px; border: 1px solid #e5e7eb; position: relative; transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.sp-block .sp-universe:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(31, 41, 55, 0.07); border-color: #10b981; }
@media (max-width: 768px) { .sp-block .sp-universe { padding: 32px 26px; } }
.sp-block .sp-universe-number { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 14px; font-weight: 500; letter-spacing: 0.1em; color: #10b981; margin-bottom: 18px; }
.sp-block .sp-universe-title { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 22px; font-weight: 500; color: #1f2937; margin: 0 0 16px 0; line-height: 1.3; }
.sp-block .sp-universe p { font-size: 14.5px; line-height: 1.65; color: #6b7280; margin-bottom: 22px; }
.sp-block .sp-universe-link { display: inline-flex; align-items: center; font-size: 13px; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: #059669; border-bottom: 1px solid currentColor; padding-bottom: 4px; transition: color .2s ease; }
.sp-block .sp-universe-link::after { content: '\2192'; margin-left: 8px; transition: transform .25s ease; }
.sp-block .sp-universe-link:hover { color: #1f2937; }
.sp-block .sp-universe-link:hover::after { transform: translateX(4px); }

.sp-block .sp-services .sp-section-header { margin-bottom: 56px; }
@media (max-width: 768px) { .sp-block .sp-services .sp-section-header { margin-bottom: 40px; } }
.sp-block .sp-service { text-align: center; padding: 32px 20px; position: relative; }
.sp-block .sp-service + .sp-service::before { content: ''; position: absolute; left: 0; top: 20%; bottom: 20%; width: 1px; background: #e5e7eb; }
@media (max-width: 1024px) { .sp-block .sp-service + .sp-service::before { display: none; } }
.sp-block .sp-service-title { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 22px; font-weight: 500; color: #1f2937; margin: 0 0 16px 0; position: relative; display: inline-block; }
.sp-block .sp-service-title::after { content: ''; display: block; width: 28px; height: 1px; background: #10b981; margin: 12px auto 0 auto; }
.sp-block .sp-service p { font-size: 15px; line-height: 1.7; color: #6b7280; max-width: 320px; margin: 0 auto; }

.sp-block .sp-quote { text-align: center; }
.sp-block .sp-quote .sp-container { max-width: 820px; }
.sp-block .sp-quote-mark { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 96px; line-height: 1; color: #10b981; margin-bottom: 8px; font-weight: 500; }
.sp-block .sp-quote-text { font-family: 'Cormorant Garamond', Georgia, serif; font-size: clamp(22px, 2.2vw, 28px); font-weight: 400; line-height: 1.45; color: #1f2937; font-style: italic; margin: 0 auto 28px auto; max-width: 720px; }
.sp-block .sp-quote-signature { font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500; letter-spacing: 0.22em; text-transform: uppercase; color: #6b7280; }
