/* =========================
   BADGE GENERAL
========================= */

.section-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    padding: 9px 20px;

    border-radius: 999px;

    background: var(--gold-soft);
    color: var(--text-soft);

    font-size: 0.9rem;
    font-weight: 800;
}

/* =========================
   ABOUT POSTER SECTION
========================= */

.about-poster-section {
    width: min(900px, calc(100% - 34px));
    margin: 42px auto 76px;
}

.about-poster-card {
    position: relative;
    overflow: hidden;

    padding: 0;

    border-radius: 34px;
    border: 1px solid rgba(214, 177, 97, 0.34);

    background:
        radial-gradient(circle at 78% 12%, rgba(255, 235, 176, 0.42), transparent 34%),
        radial-gradient(circle at 20% 22%, rgba(255, 255, 255, 0.94), transparent 38%),
        linear-gradient(180deg, #fffaf0 0%, #f6ead4 100%);

    box-shadow: 0 26px 72px rgba(39, 25, 7, 0.13);
}

.about-poster-body {
    min-height: 520px;

    padding: 54px 44px 42px;

    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    align-items: center;
    gap: 24px;
}

.about-poster-photo {
    height: 100%;

    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.about-poster-photo img {
    width: min(370px, 100%);
    height: auto;

    display: block;

    object-fit: contain;
    object-position: bottom center;

    border: none;
    border-radius: 0;

    filter: drop-shadow(0 18px 30px rgba(8, 47, 95, 0.16));

    -webkit-mask-image:
        radial-gradient(
            ellipse at center,
            rgba(0, 0, 0, 1) 58%,
            rgba(0, 0, 0, 0.88) 72%,
            rgba(0, 0, 0, 0.35) 88%,
            transparent 100%
        );

    mask-image:
        radial-gradient(
            ellipse at center,
            rgba(0, 0, 0, 1) 58%,
            rgba(0, 0, 0, 0.88) 72%,
            rgba(0, 0, 0, 0.35) 88%,
            transparent 100%
        );
}

.about-poster-text {
    height: 100%;

    padding: 8px 0 0;

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;

    text-align: center;
}

.about-poster-text p {
    width: 100%;
    max-width: 465px;

    margin: 0 auto;

    color: #082f5f;

    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(0.98rem, 1.05vw, 1.1rem);
    line-height: 1.88;
    text-align: center;
    text-wrap: balance;
}

.about-poster-text strong {
    color: #082f5f;
    font-weight: 850;
}

/* =========================
   ORNAMENTO TRIGO
========================= */

.poster-wheat {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    color: #d6b161;
}

.poster-wheat--top {
    margin: 0 auto 18px;
}

.poster-wheat--bottom {
    margin: 22px auto 0;
}

.poster-wheat span {
    width: 86px;
    height: 1px;

    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(214, 177, 97, 0.9),
            transparent
        );
}

.poster-wheat i {
    color: #d6b161;
    font-size: 1rem;
}

.poster-wheat--bottom i:nth-child(3) {
    transform: translateY(-4px);
}

.poster-divider {
    width: 150px;
    height: 18px;

    margin: 22px auto;

    position: relative;

    background:
        radial-gradient(
            circle,
            #d6b161 0 4px,
            transparent 5px
        );
    background-repeat: no-repeat;
    background-position: center;
}

.poster-divider::before,
.poster-divider::after {
    content: "";

    position: absolute;
    top: 50%;

    width: 62px;
    height: 1px;

    background: rgba(214, 177, 97, 0.72);
}

.poster-divider::before {
    left: 0;
}

.poster-divider::after {
    right: 0;
}

/* =========================
   CARDS DENTRO DE ABOUT
========================= */

.about-poster-section .cards-section,
.about-home-section .cards-section {
    margin-top: 34px;
    padding: 0;

    background: transparent;
}

.about-poster-section .cards-wrapper,
.about-home-section .cards-wrapper {
    width: 100%;
    max-width: none;

    padding: 0;
    margin: 0;
}

.about-poster-section .cards-grid,
.about-home-section .cards-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    align-items: stretch;
}

.about-poster-section .card-box,
.about-home-section .card-box {
    min-width: 0;

    padding: 20px;

    border-radius: 22px;

    background: rgba(255, 253, 247, 0.94);
    border: 1px solid rgba(214, 177, 97, 0.34);

    box-shadow:
        0 14px 36px rgba(44, 27, 6, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);

    transition:
        transform 0.25s ease,
        box-shadow 0.25s ease,
        border-color 0.25s ease;
}

.about-poster-section .card-box:hover,
.about-home-section .card-box:hover {
    transform: translateY(-4px);

    border-color: rgba(214, 177, 97, 0.58);

    box-shadow:
        0 22px 46px rgba(44, 27, 6, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.about-poster-section .card-box h2,
.about-home-section .card-box h2 {
    margin: 0 0 16px;

    color: var(--primary);

    font-size: 1.18rem;
    line-height: 1.15;
}

/* =========================
   CAROUSEL CARDS
========================= */

.about-poster-section .card-carousel,
.about-home-section .card-carousel {
    position: relative;

    width: 100%;
    aspect-ratio: 16 / 10;

    overflow: hidden;

    border-radius: 18px;
    background: #efe3cc;
}

.about-poster-section .carousel-track,
.about-home-section .carousel-track {
    position: relative;

    width: 100%;
    height: 100%;
}

.about-poster-section .carousel-image,
.about-poster-section .home-activity-image,
.about-home-section .carousel-image,
.about-home-section .home-activity-image {
    position: absolute;
    inset: 0;

    display: none;

    width: 100%;
    height: 100%;

    object-fit: cover;
    object-position: center;
}

.about-poster-section .carousel-image.active,
.about-poster-section .home-activity-image.active,
.about-home-section .carousel-image.active,
.about-home-section .home-activity-image.active {
    display: block;
}

.about-poster-section .carousel-btn,
.about-home-section .carousel-btn {
    position: absolute;
    top: 50%;
    z-index: 5;

    width: 36px;
    height: 36px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;
    border: 1px solid rgba(214, 177, 97, 0.38);

    transform: translateY(-50%);

    background: rgba(255, 253, 247, 0.94);
    color: var(--primary);

    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.12);

    cursor: pointer;
}

.about-poster-section .carousel-btn.prev,
.about-home-section .carousel-btn.prev {
    left: 10px;
}

.about-poster-section .carousel-btn.next,
.about-home-section .carousel-btn.next {
    right: 10px;
}

.about-poster-section .carousel-dots,
.about-home-section .carousel-dots {
    position: static;

    display: flex;
    justify-content: center;
    gap: 7px;

    margin-top: 12px;
}

.about-poster-section .dot,
.about-home-section .dot {
    width: 8px;
    height: 8px;

    border: none;
    border-radius: 999px;

    background: rgba(214, 177, 97, 0.45);

    cursor: pointer;
}

.about-poster-section .dot.active,
.about-home-section .dot.active {
    width: 22px;

    background: #d6b161;
}

/* =========================
   CONTENIDO CARDS
========================= */

.card-quote {
    margin: 16px 0 0;

    color: rgba(129, 91, 34, 0.92);

    font-size: 0.92rem;
    line-height: 1.6;
    font-style: italic;
}

.card-quote-author,
.biblioteca-quote-author {
    display: block;

    margin-top: 8px;

    color: #b08442;

    font-size: 0.8rem;
    font-style: italic;
    letter-spacing: 0.04em;
}

.card-description {
    margin: 16px 0 0;

    color: rgba(7, 48, 94, 0.82);

    font-size: 0.9rem;
    line-height: 1.75;
    text-align: justify;
    text-justify: inter-word;
}

.card-download-btn {
    width: fit-content;
    max-width: 100%;

    min-height: 40px;

    margin-top: 16px;
    padding: 0 16px;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    border-radius: 999px;

    background: linear-gradient(180deg, #f2dfad, #e7c97d);
    color: var(--primary);

    font-size: 0.86rem;
    font-weight: 800;
    text-align: center;
    text-decoration: none;

    box-shadow: 0 10px 22px rgba(128, 88, 23, 0.14);
}

/* =========================
   ACCORDION LANDING
========================= */

.landing-accordion {
    width: min(1050px, calc(100% - 32px));
    margin: 34px auto 80px;

    display: grid;
    gap: 18px;
}

.accordion-card {
    overflow: hidden;

    border-radius: 30px;
    border: 1px solid var(--border);

    background: rgba(255, 250, 240, 0.94);

    box-shadow: var(--shadow);

    transition:
        transform 0.25s ease,
        box-shadow 0.25s ease,
        border-color 0.25s ease,
        background 0.25s ease;
}

.accordion-card:hover {
    transform: translateY(-2px);
}

.accordion-card.active {
    border-color: rgba(214, 177, 97, 0.46);

    box-shadow: 0 24px 58px rgba(72, 48, 20, 0.14);
}

.accordion-header {
    width: 100%;
    padding: 26px 34px;

    display: grid;
    grid-template-columns: 70px 1fr auto;
    align-items: center;
    gap: 22px;

    border: none;
    background: transparent;

    text-align: left;
    cursor: pointer;
}

.accordion-icon {
    width: 70px;
    height: 70px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 999px;

    background: var(--gold-soft);
    color: var(--gold);

    font-size: 1.85rem;
    flex-shrink: 0;

    transition:
        transform 0.25s ease,
        background 0.25s ease,
        color 0.25s ease;
}

.accordion-card.active .accordion-icon {
    transform: scale(1.04);
}

.accordion-title {
    min-width: 0;
}

.accordion-title h2 {
    margin: 0;

    color: var(--text);

    font-size: clamp(1.65rem, 2.7vw, 2.45rem);
    font-weight: 850;
    line-height: 1.08;
}

.accordion-title p {
    display: none;
}

.accordion-arrow {
    color: var(--gold);
    font-size: 1.25rem;

    transition: transform 0.3s ease;
}

.accordion-card.active .accordion-arrow {
    transform: rotate(180deg);
}

.accordion-content {
    display: grid;
    grid-template-rows: 0fr;

    transition:
        grid-template-rows 0.38s ease,
        padding 0.38s ease;
}

.accordion-content > * {
    overflow: hidden;
}

.accordion-card.active .accordion-content {
    grid-template-rows: 1fr;

    padding: 0 24px 26px;
}

.accordion-content .about-grid {
    width: 100%;
    margin: 0 auto;

    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

/* =========================
   ABOUT CARDS INTERNAS
========================= */

.about-card {
    margin: 0;

    padding: 24px 28px;

    border-radius: 22px;
    border: 1px solid var(--border);

    background: rgba(255, 250, 240, 0.88);

    box-shadow: var(--shadow);
}

.about-card--closing {
    background: rgba(255, 248, 234, 0.96);
}

.about-card h2,
.about-card h3 {
    margin: 0 0 13px;

    display: flex;
    align-items: center;
    gap: 12px;

    color: var(--text);

    font-size: clamp(1.18rem, 1.7vw, 1.52rem);
    font-weight: 850;
    line-height: 1.2;
}

.about-card h2 i,
.about-card h3 i {
    color: var(--gold);

    font-size: 1rem;
}

.about-card p,
.about-card blockquote,
.espiritismo-main-text {
    margin: 0 0 14px;

    color: var(--text-soft);

    font-size: 0.96rem;
    line-height: 1.78;
    font-style: normal;
    text-align: justify;
    text-justify: inter-word;
}

.about-card p:last-child,
.about-card blockquote:last-child,
.espiritismo-main-text:last-child {
    margin-bottom: 0;
}

.about-card blockquote {
    padding-left: 0;
    border-left: none;
}

/* =========================
   LINKS / BUTTONS
========================= */

.espiritismo-link-btn,
.espiritismo-btn {
    width: fit-content;
    max-width: 100%;

    min-height: 44px;

    margin-top: 16px;
    padding: 0 18px;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    border: none;
    border-radius: 999px;

    background: #ead28e;
    color: #0f376d;

    font-size: 0.9rem;
    font-weight: 850;
    text-decoration: none;

    cursor: pointer;

    transition:
        transform 0.22s ease,
        background 0.22s ease,
        box-shadow 0.22s ease;
}

.espiritismo-link-btn:hover,
.espiritismo-btn:hover {
    transform: translateY(-2px);

    background: #d6b161;

    box-shadow: 0 10px 24px rgba(214, 177, 97, 0.28);
}

/* =========================
   CONTACTO SIMPLE
========================= */

.contact-links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;

    margin-top: 18px;
}

.contact-link {
    min-height: 42px;

    padding: 0 18px;

    display: inline-flex;
    align-items: center;
    gap: 10px;

    border-radius: 999px;

    background: rgba(214, 177, 97, 0.14);

    color: var(--primary);

    font-weight: 800;
    text-decoration: none;

    transition:
        transform 0.2s ease,
        background 0.2s ease;
}

.contact-link:hover {
    transform: translateY(-2px);

    background: rgba(214, 177, 97, 0.22);
}

/* =========================
   RADIO
========================= */

.radio-accordion {
    width: 100%;

    overflow: hidden;

    border-radius: 30px;
    border: 1px solid var(--border);

    background: rgba(255, 250, 240, 0.94);

    box-shadow: var(--shadow);
}

.radio-inner {
    width: calc(100% - 52px);

    margin: 0 auto;
    padding-bottom: 28px;
}

.radio-player-wrapper {
    padding: 14px;

    border-radius: 24px;
    border: 1px solid rgba(214, 166, 74, 0.24);

    background: rgba(255, 250, 240, 0.98);

    box-shadow: 0 12px 30px rgba(61, 42, 12, 0.1);
}

.radio-player-wrapper iframe {
    width: 100%;
    height: 135px;

    display: block;

    border: none;
    border-radius: 18px;

    background: #fffaf0;
}

/* =========================
   MODAL OBRAS
========================= */

.obras-modal {
    position: fixed;
    inset: 0;

    display: flex;
    align-items: center;
    justify-content: center;

    padding: 20px;

    opacity: 0;
    visibility: hidden;
    pointer-events: none;

    z-index: 99999;

    transition:
        opacity 0.3s ease,
        visibility 0.3s ease;
}

.obras-modal.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.obras-modal-backdrop {
    position: absolute;
    inset: 0;

    background: rgba(7, 15, 28, 0.62);

    backdrop-filter: blur(8px);
}

.obras-modal-content {
    position: relative;
    z-index: 2;

    width: min(540px, 100%);
    max-height: 92vh;

    overflow: auto;

    padding: 26px;

    border-radius: 30px;

    background: rgba(248, 243, 232, 0.98);

    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.28);

    animation: modalIn 0.35s ease;
}

@keyframes modalIn {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.96);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.obras-modal-content h3 {
    margin: 0 0 20px;

    color: #0f376d;

    font-size: 1.8rem;
    text-align: center;
}

.obras-modal-image {
    width: 100%;

    display: block;

    border-radius: 22px;

    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
}

.obras-modal-close {
    position: absolute;
    top: 18px;
    right: 18px;

    width: 42px;
    height: 42px;

    border: none;
    border-radius: 50%;

    background: #0f376d;
    color: white;

    cursor: pointer;

    transition:
        transform 0.2s ease,
        background 0.2s ease;
}

.obras-modal-close:hover {
    transform: rotate(90deg);

    background: #173f77;
}

/* =========================
   CONTACTO CARDS
========================= */

.contact-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.9fr 0.9fr;
    gap: 18px;
}

.contact-card {
    min-height: 245px;

    padding: 26px;

    border-radius: 26px;
    border: 1px solid rgba(214, 177, 97, 0.26);

    background:
        linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.96),
            rgba(255, 248, 235, 0.96)
        );

    box-shadow: 0 18px 42px rgba(44, 27, 6, 0.08);
}

.contact-card--main {
    background:
        radial-gradient(
            circle at top right,
            rgba(214, 177, 97, 0.24),
            transparent 38%
        ),
        linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.98),
            rgba(255, 248, 235, 0.96)
        );
}

.contact-tag {
    display: inline-flex;

    margin-bottom: 14px;
    padding: 7px 14px;

    border-radius: 999px;

    background: rgba(214, 177, 97, 0.14);
    color: #9b7132;

    font-size: 0.72rem;
    font-weight: 850;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.contact-icon {
    width: 54px;
    height: 54px;

    margin-bottom: 16px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 18px;

    background: rgba(214, 177, 97, 0.16);
    color: #c89c42;

    font-size: 1.25rem;
}

.contact-card h3 {
    margin: 0 0 12px;

    color: #082f5f;

    font-size: 1.25rem;
    font-weight: 850;
    line-height: 1.15;
}

.contact-card p {
    margin: 0;

    color: rgba(7, 48, 94, 0.82);

    font-size: 0.94rem;
    line-height: 1.7;
}

.contact-action {
    width: fit-content;
    min-height: 42px;

    margin-top: 20px;
    padding: 0 16px;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;

    border-radius: 999px;

    background: #ead28e;
    color: #0f376d;

    font-size: 0.86rem;
    font-weight: 850;
    text-decoration: none;

    transition:
        transform 0.22s ease,
        background 0.22s ease,
        box-shadow 0.22s ease;
}

.contact-action:hover {
    transform: translateY(-2px);
    background: #d6b161;
    box-shadow: 0 12px 26px rgba(214, 177, 97, 0.24);
}

.contact-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

/* =========================
   FOOTER
========================= */

.site-footer {
    margin-top: 72px;
    padding: 48px 20px;
    background: var(--card);
    border-top: 1px solid var(--border);
}

/* =========================
   DARK MODE
========================= */

html[data-theme="dark"] .about-poster-card,
html[data-theme="dark"] .accordion-card,
html[data-theme="dark"] .about-card,
html[data-theme="dark"] .radio-accordion,
html[data-theme="dark"] .contact-card {
    background:
        linear-gradient(
            180deg,
            rgba(17, 27, 43, 0.96),
            rgba(12, 21, 35, 0.98)
        ) !important;

    border-color: rgba(214, 177, 97, 0.16) !important;

    box-shadow: 0 22px 54px rgba(0, 0, 0, 0.38);
}

html[data-theme="dark"] .section-badge {
    background: rgba(214, 177, 97, 0.12);
    color: #f0d28d;
}

html[data-theme="dark"] .about-poster-text p,
html[data-theme="dark"] .about-poster-text strong,
html[data-theme="dark"] .accordion-title h2,
html[data-theme="dark"] .about-card h2,
html[data-theme="dark"] .about-card h3,
html[data-theme="dark"] .contact-card h3 {
    color: #f8f1df !important;
}

html[data-theme="dark"] .about-card p,
html[data-theme="dark"] .about-card blockquote,
html[data-theme="dark"] .espiritismo-main-text,
html[data-theme="dark"] .card-description,
html[data-theme="dark"] .contact-card p {
    color: rgba(245, 236, 214, 0.86) !important;
}

html[data-theme="dark"] .about-card h3 i,
html[data-theme="dark"] .about-card h2 i,
html[data-theme="dark"] .accordion-arrow,
html[data-theme="dark"] .accordion-icon {
    color: #e5bf6d !important;
}

html[data-theme="dark"] .accordion-icon,
html[data-theme="dark"] .contact-tag,
html[data-theme="dark"] .contact-icon {
    background: rgba(214, 177, 97, 0.12);
    color: #f0d28d;
}

html[data-theme="dark"] .card-box {
    background:
        linear-gradient(
            180deg,
            rgba(24, 36, 56, 0.98),
            rgba(18, 28, 44, 0.98)
        ) !important;

    border-color: rgba(214, 177, 97, 0.16) !important;
}

html[data-theme="dark"] .card-quote,
html[data-theme="dark"] .card-quote-author,
html[data-theme="dark"] .biblioteca-quote-author {
    color: #d8b56b !important;
}

html[data-theme="dark"] .espiritismo-link-btn,
html[data-theme="dark"] .espiritismo-btn,
html[data-theme="dark"] .card-download-btn,
html[data-theme="dark"] .contact-link,
html[data-theme="dark"] .contact-action {
    background:
        linear-gradient(
            180deg,
            #d6b161,
            #c89c42
        ) !important;

    color: #0f1b2c !important;
}

html[data-theme="dark"] .obras-modal-content {
    background: rgba(15, 24, 38, 0.98);
}

html[data-theme="dark"] .obras-modal-content h3 {
    color: #f7ead6;
}

/* =========================
   RESPONSIVE TABLET
========================= */

@media (max-width: 850px) {
    .about-poster-section {
        width: calc(100% - 28px);
        margin: 34px auto 66px;
    }

    .about-poster-card {
        border-radius: 30px;
    }

    .about-poster-body {
        min-height: auto;

        padding: 42px 24px 36px;

        grid-template-columns: 1fr;
        gap: 26px;
    }

    .about-poster-photo img {
        width: min(310px, 82vw);
    }

    .about-poster-text p {
        max-width: 560px;

        font-size: 1rem;
        line-height: 1.74;
    }

    .about-poster-section .cards-grid,
    .about-home-section .cards-grid {
        grid-template-columns: 1fr;
    }

    .landing-accordion {
        width: min(100% - 24px, 1050px);
        margin: 30px auto 64px;
    }

    .contact-grid {
        grid-template-columns: 1fr;
    }

    .contact-card {
        min-height: auto;
    }
}

/* =========================
   RESPONSIVE MOBILE
========================= */

@media (max-width: 640px) {
    .section-badge {
        padding: 8px 16px;

        font-size: 0.8rem;
    }

    .about-poster-section {
        width: calc(100% - 18px);
        margin: 28px auto 56px;
    }

    .about-poster-card {
        border-radius: 26px;
    }

    .about-poster-body {
        padding: 34px 18px 30px;
        gap: 22px;
    }

    .about-poster-photo img {
        width: min(280px, 88vw);
    }

    .about-poster-text p {
        font-size: 0.96rem;
        line-height: 1.68;
    }

    .poster-wheat span {
        width: 48px;
    }

    .poster-divider {
        margin: 16px auto;
    }

    .accordion-card {
        border-radius: 24px;
    }

    .accordion-header {
        grid-template-columns: 52px 1fr auto;
        gap: 14px;

        padding: 20px 18px;
    }

    .accordion-icon {
        width: 52px;
        height: 52px;

        font-size: 1.35rem;
    }

    .accordion-title h2 {
        font-size: 1.38rem;
    }

    .accordion-card.active .accordion-content {
        padding: 0 14px 20px;
    }

    .about-card {
        padding: 20px 18px;

        border-radius: 20px;
    }

    .about-card p,
    .about-card blockquote,
    .espiritismo-main-text,
    .card-description {
        font-size: 0.94rem;
        line-height: 1.72;
        text-align: left;
    }

    .espiritismo-link-btn,
    .espiritismo-btn,
    .card-download-btn {
        width: 100%;
        justify-content: center;
    }

    .radio-inner {
        width: calc(100% - 28px);
        padding-bottom: 22px;
    }

    .radio-player-wrapper iframe {
        height: 145px;
    }

    .obras-modal-content {
        padding: 20px;
        border-radius: 24px;
    }

    .obras-modal-content h3 {
        font-size: 1.45rem;
    }

    .contact-card {
        padding: 22px 18px;
        border-radius: 24px;
    }

    .contact-card h3 {
        font-size: 1.18rem;
    }

    .contact-card p {
        font-size: 0.92rem;
        line-height: 1.68;
    }

    .contact-action {
        width: 100%;
    }

    .contact-socials {
        width: 100%;
    }
}
