.hero-gradient {
    background: linear-gradient(90deg, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.7) 50%, rgba(255,255,255,0) 100%);
}
.card-hover {
    transition: all 0.3s ease;
}
.card-hover:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px -15px rgba(0,0,0,0.1);
}
.testimonial-card {
    scroll-snap-align: start;
}
.testimonials-track {
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.mobile-nav-open {
    display: block !important;
}
.alert-success {
    background-color: #dcfce7;
    border: 1px solid #86efac;
    color: #166534;
}
.alert-error {
    background-color: #fee2e2;
    border: 1px solid #fca5a5;
    color: #991b1b;
}
.page-content a { color: #15803d; text-decoration: underline; }
.page-content a:hover { color: #166534; }
.page-content h2, .page-content h3 { color: #111827; font-family: 'Playfair Display', serif; margin-top: 1.5em; margin-bottom: 0.5em; }
.nav-dropdown-menu { pointer-events: none; }
.group:hover .nav-dropdown-menu { display: block; pointer-events: auto; }

/* Mobile nav accordion */
details > summary::-webkit-details-marker { display: none; }
details > summary::marker { display: none; }

/* ── Page builder block styles ─────────────────────────────────── */
.block-text { margin-bottom: 1.5rem; }
.block-text p { margin-bottom: 0.75em; color: #4b5563; }
.block-text h2 { font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 600; color: #111827; margin: 1.5em 0 0.5em; }
.block-text h3 { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 600; color: #111827; margin: 1.25em 0 0.4em; }

.block-image-text { display: grid; grid-template-columns: 1fr; gap: 2rem; margin-bottom: 2rem; }
@media (min-width: 768px) {
    .block-image-text { grid-template-columns: 1fr 1fr; }
    .block-image-text.right .blk-img { order: 2; }
    .block-image-text.right .blk-txt { order: 1; }
}
.blk-txt { align-self: center; }
.blk-txt p { margin-bottom: 0.75em; color: #4b5563; }
.blk-txt h2 { font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 600; color: #111827; margin: 0 0 0.75em; }
.blk-txt h3 { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 600; color: #111827; margin: 0 0 0.5em; }

.block-cta { background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 0.75rem; padding: 2rem; text-align: center; margin-bottom: 2rem; }
.block-cta-title { font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 600; color: #14532d; margin-bottom: 0.5rem; }
.block-cta-body { color: #166534; margin-bottom: 1.25rem; }
.block-cta-btn { display: inline-block; background: #166534; color: #fff; padding: 0.65rem 1.75rem; border-radius: 0.4rem; font-weight: 500; text-decoration: none; transition: background 0.2s; }
.block-cta-btn:hover { background: #14532d; }

.block-callout { display: flex; gap: 1rem; background: #eff6ff; border: 1px solid #bfdbfe; border-radius: 0.75rem; padding: 1.25rem 1.5rem; margin-bottom: 1.5rem; }
.block-callout-icon { flex-shrink: 0; color: #2563eb; margin-top: 0.1rem; }
.block-callout strong { display: block; color: #1e3a5f; margin-bottom: 0.25rem; font-weight: 600; }
.block-callout p { color: #374151; margin: 0; font-size: 0.95em; }
.alert-success {
    background-color: #dcfce7;
    border: 1px solid #86efac;
    color: #166534;
}
.alert-error {
    background-color: #fee2e2;
    border: 1px solid #fca5a5;
    color: #991b1b;
}
