@font-face {
    font-family: "Weddingday";
    src: url("../fonts/Weddingday.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Citadel";
    src: url("../fonts/citadel.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    background: #f5f2ee;
    color: #2d2520;
    font-family: Georgia, "Times New Roman", serif;
    padding-bottom: 110px;
}

.site-casamento {
    width: 100%;
    margin: 0 auto;
    background: #ffffff;
}

.bloco-foto {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: #f8f5f0;
}

.foto-cover {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center center;
}

.bloco-capa {
    height: 89vh;
    min-height: 750px;
    margin-bottom: 0;
}

.bloco-contagem,
.bloco-frase,
.bloco-info,
.bloco-final {
    height: 780px;
}

.bloco-texto-grande {
    max-width: 1540px;
    height: 680px;
    margin: 0 auto 42px;
}

.primeira-dupla {
    margin-top: 0;
}

.bloco-capa {
    margin-bottom: 0;
}

.grid-duplo {
    max-width: 1500px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 34px;
}

.texto-sobre-foto {
    position: absolute;
    inset: 0;
    z-index: 3;
    padding: 28px;
    color: #ffffff;
    text-align: center;
}

.texto-sobre-foto.centro {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.texto-sobre-foto.esquerda {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    text-align: left;
}

.texto-sobre-foto h1 {
    margin: 0;
    font-size: 64px;
    font-weight: 400;
    font-style: normal;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.35);
}

.texto-sobre-foto h1.nome-noivos-capa {
    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 72px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.05;
    letter-spacing: 0;
}

.texto-sobre-foto h2 {
    margin: 0 0 18px;
    font-size: 42px;
    font-weight: 400;
    font-style: italic;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.35);
}

.texto-sobre-foto p {
    margin: 0;
    font-size: 30px;
    line-height: 1.45;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.35);
}

.texto-sobre-foto small {
    margin-top: 18px;
    font-size: 15px;
}

.texto-sobre-foto ul {
    margin: 16px 0 0;
    padding-left: 24px;
    font-size: 25px;
    line-height: 1.45;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.35);
}

.nome-noivos-capa {
    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 72px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.05;
    letter-spacing: 0;
}

.texto-escuro {
    color: #111111;
}

.texto-escuro p,
.texto-escuro span,
.texto-escuro small {
    text-shadow: none;
}

.subtitulo-script {
    margin: 0 0 10px;
    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 42px !important;
    font-weight: 400;
    font-style: normal;
    line-height: 1.05;
    color: rgb(26, 26, 27);
    font-kerning: normal;
    letter-spacing: 0;
    text-decoration-line: none;
    text-decoration-thickness: initial;
    text-decoration-style: initial;
    text-shadow: none !important;
}

.bloco-contagem .texto-sobre-foto.centro {
    justify-content: center;
    transform: translateY(-8px);
}

.contador {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 62px;
    font-weight: 400;
    letter-spacing: 6px;
    margin-top: 20px;
    color: #111111;
}

.contador span {
    display: inline-flex;
    align-items: center;
}

.contador span:not(:last-child)::after {
    content: ":";
    margin: 0 14px;
    font-weight: 400;
}

.contador-labels {
    display: flex;
    justify-content: center;
    gap: 54px;
    margin-top: 16px;
    text-transform: uppercase;
    color: #111111;
}

.contador-labels small {
    font-size: 16px;
    letter-spacing: 0;
    text-shadow: none !important;
}

.overlay-escuro {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: rgba(0, 0, 0, 0.30);
}

.overlay-claro {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: rgba(255, 255, 255, 0.35);
}

.bloco-convite {
    max-width: 1000px;
    margin: 64px auto;
    padding: 0 24px;
}

.convite-card {
    padding: 52px 64px;
    border: 1px solid rgba(0, 0, 0, 0.20);
    background: #fbfaf7;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.06);
}

.convite-card h2 {
    margin: 24px 0;
    font-size: 54px;
    font-weight: 400;
    font-style: italic;
}

.convite-card p {
    margin: 10px 0;
    font-size: 19px;
    line-height: 1.5;
}

.convite-pais {
    font-size: 18px;
}

.botao-mapa {
    display: inline-block;
    margin-top: 22px;
    padding: 13px 24px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.90);
    color: #3d312b;
    text-decoration: none;
    font-weight: 700;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
}

.baloes-fixos {
    position: fixed;
    left: 50%;
    bottom: calc(14px + env(safe-area-inset-bottom));
    transform: translateX(-50%);
    width: calc(100% - 24px);
    max-width: 430px;
    z-index: 9999;

    display: none;
    gap: 8px;
    justify-content: space-between;

    padding: 9px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 12px 35px rgba(0, 0, 0, 0.22);
}

.baloes-fixos button {
    flex: 1;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.95);
    color: #4a3024;
    padding: 8px 4px 7px;
    font-family: inherit;
    box-shadow: 0 5px 16px rgba(0, 0, 0, 0.10);
    cursor: pointer;
}

.baloes-fixos button span {
    display: block;
    font-size: 20px;
    line-height: 1;
    margin-bottom: 4px;
}

.baloes-fixos button small {
    display: block;
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
}

.baloes-fixos button:active {
    transform: scale(0.96);
}

.foto-capa {
    object-position: center 12%;
    transform: scale(1.20);
    transform-origin: center 12%;
}

.foto-noiva {
    object-position: 54% center;
}

.foto-frase {
    object-position: center 38%;
}

.foto-jardim {
    object-position: center center;
}

.foto-cerimonia {
    object-position: center center;
}

.foto-recepcao {
    object-position: center center;
}

.foto-info {
    object-position: 48% center;
}

.foto-final {
    object-position: center center;
}

.texto-biblico {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    color: #ffffff;
    padding-left: 82px;
    padding-right: 40px;
}

.texto-biblico p {
    max-width: 280px;
    margin: 0;
    font-size: 22px;
    line-height: 1.38;
    font-weight: 400;
    text-shadow: 0 2px 18px rgba(0, 0, 0, 0.38);
}

.texto-biblico small {
    width: 280px;
    margin-top: 18px;
    font-size: 13px;
    text-align: center;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.38);
}

/* =========================================================
   AJUSTE ESPECIAL - PRIMEIRA DUPLA ESTILO CANVA
   ========================================================= */

.primeira-dupla {
    max-width: 1540px;
    margin: 0 auto 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}

.primeira-contagem,
.primeira-frase {
    height: 830px;
    margin: 0;
}

.primeira-contagem .foto-cover,
.primeira-frase .foto-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.primeira-contagem .foto-cover {
    object-position: center center;
}

.primeira-frase .foto-cover {
    object-position: center 1%;
}

/* Contagem regressiva mais parecida com Canva */

.primeira-contagem .texto-sobre-foto.centro {
    justify-content: center;
    transform: translateY(-8px);
}

.primeira-contagem .subtitulo-script {
    margin: 0 0 14px;
    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 58px !important;
    font-weight: 400;
    font-style: normal;
    line-height: 1;
    color: rgb(26, 26, 27);
    text-shadow: none !important;
}

.contador-grid {
    display: grid;
    grid-template-columns: repeat(4, max-content);
    align-items: start;
    justify-content: center;
    column-gap: 28px;
    width: auto;
    margin: 18px auto 0;
    color: #111111;
}

.contador-item {
    position: relative;
    text-align: center;
    min-width: 0;
}

.contador-item span {
    display: block;
    font-family: "Alumni Sans", Arial, sans-serif;
    font-size: 86px;
    font-weight: 700;
    line-height: 0.92;
    letter-spacing: 3px;
}

.contador-item:not(:last-child)::after {
    content: ":";
    position: absolute;
    top: -3px;
    right: -19px;
    font-family: "Alumni Sans", Arial, sans-serif;
    font-size: 86px;
    font-weight: 700;
    line-height: 0.92;
}

.contador-item small {
    display: block;
    margin-top: 14px;
    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.6px;
    color: #111111;
    text-shadow: none !important;
}

/* Texto bíblico mais fino e estreito */

.primeira-frase .texto-biblico {
    position: absolute;
    top: 0;
    left: 54px;
    right: auto;
    bottom: 0;
    z-index: 3;

    width: 250px;
    padding: 0;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    text-align: center;
    color: #ffffff;
    transform: translateY(-6px);
}

.primeira-frase .texto-biblico p {
    max-width: 250px;
    margin: 0;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 18px;
    line-height: 1.36;
    font-weight: 400;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.36);
}

.primeira-frase .texto-biblico small {
    width: 250px;
    margin-top: 16px;
    font-size: 11px;
    text-align: center;
    font-weight: 400;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.36);
}

.texto-convite-historia p {
    max-width: 520px;
    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif !important;
    font-size: 38px;
    line-height: 1.22;
    font-weight: 300 !important;
    text-align: center;
    letter-spacing: 0;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.24) !important;
}

.bloco-convite-imagem {
    width: 100%;
    max-width: 1540px;
    margin: 0 auto;
    padding: 42px 24px;
    box-sizing: border-box;
    background: #ffffff;
    text-align: center;
}

.imagem-convite {
    display: block;
    width: 100%;
    max-width: 980px;
    height: auto;
    margin: 0 auto;
    object-fit: contain;
}

/* =========================================================
   BLOCO CERIMÔNIA - FOTO FUNDO + IGREJA NA FRENTE
   ========================================================= */

.bloco-cerimonia-local {
    position: relative;
    overflow: hidden;
    background: #ffffff;
}

.foto-cerimonia-fundo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

.efeito-branco-cerimonia {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: rgba(255, 255, 255, 0.58);
}

.conteudo-cerimonia-local {
    position: absolute;
    inset: 0;
    z-index: 3;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    padding: 34px;
    box-sizing: border-box;
    text-align: center;
}

.texto-cerimonia-local {
    margin: 0 0 34px;
    max-width: 620px;

    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 28px;
    line-height: 1.25;
    font-weight: 400;
    letter-spacing: 0.4px;

    color: #ffffff;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.26);
}

.imagem-igreja {
    display: block;
    width: 68%;
    max-width: 480px;
    height: auto;

    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.10);
}

/* =========================================================
   BLOCO RECEPÇÃO - FOTO + TEXTO SUPERIOR
   ========================================================= */

.bloco-recepcao-local {
    position: relative;
    overflow: hidden;
    background: #ffffff;
}

.foto-recepcao-local {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

.conteudo-recepcao-local {
    position: absolute;
    inset: 0;
    z-index: 3;

    display: flex;
    align-items: flex-start;
    justify-content: center;

    padding: 70px 32px 32px;
    box-sizing: border-box;
    text-align: center;
}

.conteudo-recepcao-local p {
    margin: 0;
    max-width: 640px;

    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 24px;
    line-height: 1.25;
    font-weight: 400;
    letter-spacing: 0.3px;

    color: #ffffff;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.35);
}

/* =========================================================
   MAPA DE SANTA ROSA
   ========================================================= */

.bloco-mapa-santa-rosa {
    position: relative;
    width: 100%;
    max-width: 1540px;
    height: 760px;
    margin: 0 auto 42px;
    overflow: hidden;
    background: #d8d2cc;
}

.foto-mapa-fundo {
    position: absolute;
    inset: 0;
    z-index: 1;

    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.conteudo-mapa-santa-rosa {
    position: absolute;
    inset: 0;
    z-index: 3;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    padding: 56px 24px;
    box-sizing: border-box;
    text-align: center;
}

.conteudo-mapa-santa-rosa h2 {
    margin: 0 0 28px;

    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 58px;
    font-weight: 400;
    line-height: 1;
    color: #ffffff;

    text-shadow: 0 2px 18px rgba(0, 0, 0, 0.32);
}

.caixa-google-maps {
    width: min(760px, 82%);
    height: 360px;

    background: #ffffff;
    overflow: hidden;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.16);
}

.caixa-google-maps iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
}

@media (max-width: 768px) {

    .subtitulo-script {
        font-size: 42px !important;
    }

    body {
        padding-bottom: 105px;
    }

    .site-casamento {
        width: 100%;
        max-width: 100%;
    }

    .grid-duplo {
        display: block;
        margin: 0;
    }

    .bloco-capa,
    .bloco-contagem,
    .bloco-frase,
    .bloco-texto-grande,
    .bloco-info,
    .bloco-final {
        height: 100svh;
        min-height: 680px;
        margin: 0 0 22px;
    }

    .texto-sobre-foto {
        padding: 26px;
    }

    .texto-sobre-foto h1.nome-noivos-capa {
        font-size: 70px;
        white-space: nowrap;
        max-width: 96vw;
    }

    .texto-sobre-foto h2 {
        font-size: 34px;
    }

    .texto-sobre-foto p {
        font-size: 25px;
        line-height: 1.45;
    }

    .texto-sobre-foto ul {
        font-size: 21px;
        line-height: 1.45;
    }

    .contador-grid {
        grid-template-columns: repeat(4, max-content);
        column-gap: 18px;
        width: auto;
        margin-top: 16px;
    }

    .contador-item span {
        font-size: 56px;
        font-weight: 700;
        letter-spacing: 1px;
    }

    .contador-item:not(:last-child)::after {
        top: -2px;
        right: -13px;
        font-size: 56px;
        font-weight: 700;
    }

    .contador-item small {
        margin-top: 10px;
        font-size: 12px;
        letter-spacing: 0.3px;
    }

    .primeira-contagem .subtitulo-script {
        font-size: 30px !important;
    }

    .convite-card {
        padding: 34px 22px;
    }

    .convite-card h2 {
        font-size: 40px;
    }

    .convite-card p {
        font-size: 16px;
    }

    .baloes-fixos {
        display: flex;
    }

    .grid-duplo {
        margin: 0;
        gap: 0;
    }

    .bloco-contagem,
    .bloco-frase,
    .bloco-info,
    .bloco-final {
        height: 100svh;
        min-height: 680px;
    }

    .subtitulo-script {
        font-size: 38px !important;
    }

    .texto-biblico {
        align-items: center;
        padding: 26px;
    }

    .texto-biblico p {
        max-width: 300px;
        font-size: 24px;
        line-height: 1.42;
    }

    .texto-biblico small {
        width: 300px;
    }

    .primeira-dupla {
        display: block;
        max-width: 100%;
        margin: 0;
        gap: 0;
    }

    .primeira-contagem,
    .primeira-frase {
        height: 100svh;
        min-height: 680px;
        margin-bottom: 22px;
    }

    .primeira-contagem .subtitulo-script {
        font-size: 38px !important;
    }

    .primeira-contagem .contador {
        font-size: 38px;
        letter-spacing: 3px;
    }

    .primeira-contagem .contador span:not(:last-child)::after {
        margin: 0 7px;
    }

    .primeira-contagem .contador-labels {
        gap: 22px;
    }

    .primeira-contagem .contador-labels small {
        font-size: 12px;
    }

    .primeira-frase .texto-biblico {
        align-items: center;
        padding: 26px;
        transform: none;
    }

    .primeira-frase .texto-biblico p {
        max-width: 300px;
        font-size: 24px;
        line-height: 1.42;
    }

    .primeira-frase .texto-biblico small {
        width: 300px;
    }

    .bloco-recepcao-local {
        height: 100svh;
        min-height: 680px;
        margin-bottom: 22px;
    }

    .foto-recepcao-local {
        object-position: center center;
    }

    .conteudo-recepcao-local {
        align-items: flex-start;
        justify-content: center;
        padding: 48px 6px 22px;
    }

    .conteudo-recepcao-local p {
        width: calc(80vw - 12px);
        max-width: none;
        margin: 0;
        font-size: 13px;
        line-height: 1.25;
        font-weight: 400;
        letter-spacing: 0;
        text-align: center;
    }

    .conteudo-recepcao-local p span {
        display: block;
        white-space: nowrap;
    }
    
    .foto-recepcao-local {
        object-position: 58% center;
        transform: scale(1.20);
        transform-origin: 58% center;
    }
    .bloco-mapa-santa-rosa {
        height: 100svh;
        min-height: 680px;
        margin-bottom: 22px;
    }

    .foto-mapa-fundo {
        object-position: center center;
    }

    .conteudo-mapa-santa-rosa {
        justify-content: flex-start;
        padding: 74px 14px 26px;
    }

    .conteudo-mapa-santa-rosa h2 {
        margin-bottom: 26px;
        font-size: 43px;
        white-space: nowrap;
    }

    .caixa-google-maps {
        width: 86vw;
        height: 250px;
    }
}

@media (max-width: 768px) {
    .primeira-frase .texto-biblico {
        position: absolute !important;
        top: 0 !important;
        left: 20px !important;
        right: auto !important;
        bottom: 0 !important;

        width: 230px !important;
        padding: 0 !important;

        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;

        text-align: center !important;
        color: #ffffff !important;
        transform: translateY(-8px) !important;
    }

    .primeira-frase .texto-biblico p {
        max-width: 230px !important;
        margin: 0 !important;
        font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif !important;
        font-size: 18px !important;
        line-height: 1.34 !important;
        font-weight: 400 !important;
        letter-spacing: 0 !important;
        text-shadow: 0 2px 14px rgba(0, 0, 0, 0.30) !important;
    }

    .primeira-frase .texto-biblico small {
        width: 230px !important;
        margin-top: 16px !important;
        font-size: 11px !important;
        text-align: center !important;
        font-weight: 400 !important;
        letter-spacing: 0.2px !important;
        text-shadow: 0 2px 12px rgba(0, 0, 0, 0.28) !important;
    }
    
    .texto-convite-historia p {
        max-width: 330px;
        font-size: 32px;
        line-height: 1.32;
        font-weight: 300 !important;
        letter-spacing: 0;
        text-shadow: 0 2px 12px rgba(0, 0, 0, 0.22) !important;
    }
    
    .bloco-convite-imagem {
        padding: 26px 10px;
        margin: 0;
    }

    .imagem-convite {
        width: 100%;
        max-width: 100%;
        height: auto;
        object-fit: contain;
    }

    .bloco-cerimonia-local {
        height: 100svh;
        min-height: 680px;
        margin-bottom: 22px;
    }

    .foto-cerimonia-fundo {
        object-position: center center;
    }

    .efeito-branco-cerimonia {
        background: rgba(255, 255, 255, 0.58);
    }

    .conteudo-cerimonia-local {
        justify-content: center;
        padding: 28px 22px;
    }

    .texto-cerimonia-local {
        margin-bottom: 18px;
        max-width: 330px;
        font-size: 18px;
        line-height: 1.28;
        font-weight: 400;
        letter-spacing: 0.2px;
    }

    .imagem-igreja {
        width: 88%;
        max-width: 340px;
        transform: translateY(60px);
    }
}

@media (max-width: 768px) {
    .bloco-capa {
        height: 88svh !important;
        min-height: 520px !important;
        max-height: 620px !important;
        margin-bottom: 0 !important;
        overflow: hidden !important;
    }

    .foto-capa {
        object-position: center 10% !important;
        transform: scale(3.40) !important;
        transform-origin: center 10% !important;
    }

    .texto-sobre-foto h1.nome-noivos-capa {
        font-size: 60px !important;
        white-space: nowrap !important;
        max-width: 96vw !important;
        transform: translateY(-6px);
    }
}

/* =========================================================
   CONTAGEM REGRESSIVA - AJUSTE FINAL
   ========================================================= */

.contador-casamento {
    width: min(620px, 94%);
    margin: 16px auto 0;
    color: #111111;
}

.contador-numeros,
.contador-textos {
    display: grid;
    grid-template-columns: 1fr 18px 1fr 18px 1fr 18px 1fr;
    align-items: center;
    justify-items: center;
}

.contador-numeros span,
.contador-numeros b {
    font-family: "Alumni Sans", Arial, sans-serif;
    font-size: 86px;
    font-weight: 700;
    line-height: 0.9;
    letter-spacing: 1px;
}

.contador-numeros b {
    font-weight: 700;
    transform: translateY(-3px);
}

.contador-textos {
    margin-top: 12px;
}

.contador-textos small {
    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.3px;
    white-space: nowrap;
}

.contador-textos i {
    display: block;
}

@media (max-width: 768px) {
    .contador-casamento {
        width: min(350px, 97vw) !important;
        margin: 13px auto 0 !important;
    }

    .contador-numeros,
    .contador-textos {
        grid-template-columns: 1fr 7px 1fr 7px 1fr 7px 1fr !important;
    }

    .contador-numeros span,
    .contador-numeros b {
        font-size: 60px !important;
        font-weight: 450 !important;
        letter-spacing: 0 !important;
        line-height: 0.92 !important;
    }

    .contador-numeros b {
        transform: translateY(-2px) !important;
    }

    .contador-textos {
        margin-top: 8px !important;
    }

    .contador-textos small {
        font-size: 10px !important;
        font-weight: 600 !important;
        letter-spacing: 0 !important;
    }
}

/* =========================================================
   AJUSTE MAPA - FRAME MENOR + ZOOM NO FUNDO
   ========================================================= */

.bloco-mapa-santa-rosa {
    height: 620px !important;
    margin: 0 auto 28px !important;
    overflow: hidden !important;
}

.foto-mapa-fundo {
    object-position: center 30% !important;
    transform: scale(1.22) !important;
    transform-origin: center 30% !important;
}

@media (max-width: 768px) {
    .bloco-mapa-santa-rosa {
        height: 620px !important;
        min-height: 620px !important;
        margin-bottom: 22px !important;
        overflow: hidden !important;
    }

    .foto-mapa-fundo {
        object-position: center 28% !important;
        transform: scale(1.32) !important;
        transform-origin: center 28% !important;
    }

    .conteudo-mapa-santa-rosa {
        padding: 56px 14px 24px !important;
    }

    .conteudo-mapa-santa-rosa h2 {
        margin-bottom: 24px !important;
    }

    .caixa-google-maps {
        width: 86vw !important;
        height: 220px !important;
    }
}

/* =========================================================
   MAPA - BLOCO MAIS BAIXO
   ========================================================= */

.bloco-mapa-santa-rosa {
    height: 500px !important;
    min-height: 0 !important;
    margin: 0 auto 22px !important;
    overflow: hidden !important;
}

.foto-mapa-fundo {
    object-position: center 26% !important;
    transform: scale(1.38) !important;
    transform-origin: center 26% !important;
}

.conteudo-mapa-santa-rosa {
    padding: 46px 14px 18px !important;
}

.conteudo-mapa-santa-rosa h2 {
    margin-bottom: 20px !important;
}

.caixa-google-maps {
    height: 210px !important;
}

@media (max-width: 768px) {
    .bloco-mapa-santa-rosa {
        height: 470px !important;
        min-height: 0 !important;
        margin-bottom: 18px !important;
        overflow: hidden !important;
    }

    .foto-mapa-fundo {
        object-position: center 24% !important;
        transform: scale(1.45) !important;
        transform-origin: center 24% !important;
    }

    .conteudo-mapa-santa-rosa {
        padding: 42px 14px 14px !important;
    }

    .conteudo-mapa-santa-rosa h2 {
        margin-bottom: 18px !important;
        font-size: 40px !important;
    }

    .caixa-google-maps {
        width: 86vw !important;
        height: 195px !important;
    }
}

/* =========================================================
   INFORMAÇÕES IMPORTANTES
   ========================================================= */

.bloco-informacoes-importantes {
    position: relative;
    overflow: hidden;
    background: #111111;
}

.foto-informacoes {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

.overlay-info {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: rgba(0, 0, 0, 0.18);
}

.conteudo-informacoes-importantes {
    position: absolute;
    inset: 0;
    z-index: 3;

    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;

    padding: 58px 72px;
    box-sizing: border-box;

    color: #ffffff;
    text-align: left;
}

.conteudo-informacoes-importantes h2 {
    margin: 0 0 24px;

    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 58px;
    font-weight: 400;
    line-height: 1;

    color: #ffffff;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.32);
}

.conteudo-informacoes-importantes ul {
    margin: 0;
    padding-left: 24px;
    max-width: 560px;
}

.conteudo-informacoes-importantes li {
    margin-bottom: 6px;

    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 25px;
    line-height: 1.18;
    font-weight: 400;

    color: #ffffff;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.38);
}

.conteudo-informacoes-importantes li strong {
    font-weight: 500;
}


@media (max-width: 768px) {
    .bloco-informacoes-importantes {
        height: 100svh;
        min-height: 680px;
        margin-bottom: 22px;
    }

    .foto-informacoes {
        object-position: center center;
        transform: scale(1.05);
        transform-origin: center center;
    }

    .conteudo-informacoes-importantes {
        justify-content: center;
        padding: 52px 28px 42px;
    }

    .conteudo-informacoes-importantes h2 {
        margin-bottom: 20px;
        font-size: 43px;
        white-space: nowrap;
    }

    .conteudo-informacoes-importantes ul {
        max-width: 310px;
        padding-left: 18px;
    }

    .conteudo-informacoes-importantes li {
        margin-bottom: 5px;
        font-size: 19px;
        line-height: 1.18;
        font-weight: 400;
    }

    .conteudo-informacoes-importantes li strong {
        font-weight: 500;
    }
}

/* =========================================================
   BLOCO FINAL - HISTÓRIA
   ========================================================= */

.bloco-final-historia {
    position: relative;
    overflow: hidden;
}

.foto-final {
    object-position: center center;
    transform: scale(1.00);
    transform-origin: center center;
}

.texto-final-historia h2 {
    margin: 0;

    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 64px;
    font-weight: 400;
    line-height: 1.05;

    color: #ffffff;
    text-align: center;
    text-shadow: 0 2px 18px rgba(0, 0, 0, 0.34);
}

@media (max-width: 768px) {
    .bloco-final-historia {
        height: 100svh;
        min-height: 680px;
        margin-bottom: 22px;
        overflow: hidden;
    }

    .foto-final {
        object-position: center 1%;
        transform: scale(2.40);
        transform-origin: center 1%;
    }

    .texto-final-historia {
        padding: 0 26px;
    }

    .texto-final-historia h2 {
        font-size: 43px;
        line-height: 1.08;
        white-space: normal;
    }
}

/* =========================================================
   MODAL BOAS-VINDAS / LIBERAR MÚSICA
   ========================================================= */

.modal-boas-vindas {
    position: fixed;
    inset: 0;
    z-index: 99999;

    display: flex;
    align-items: center;
    justify-content: center;

    padding: 24px;
    box-sizing: border-box;

    background:
        linear-gradient(rgba(255, 255, 255, 0.46), rgba(255, 255, 255, 0.46)),
        rgba(35, 28, 23, 0.36);

    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);

    opacity: 1;
    visibility: visible;
    transition: opacity 0.45s ease, visibility 0.45s ease;
}

.modal-boas-vindas.oculto {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.card-boas-vindas {
    width: min(360px, 100%);
    padding: 34px 28px 30px;

    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 22px 65px rgba(0, 0, 0, 0.18);

    text-align: center;
    box-sizing: border-box;
}

.titulo-boas-vindas {
    margin: 0 0 12px;

    font-family: "Citadel", "Great Vibes", "Parisienne", cursive;
    font-size: 46px;
    font-weight: 400;
    line-height: 1.05;

    color: #3c2f28;
}

.texto-boas-vindas {
    margin: 0 0 24px;

    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 20px;
    line-height: 1.25;
    font-weight: 400;

    color: #4a4039;
}

.card-boas-vindas button {
    border: 0;
    padding: 12px 34px;

    background: #3c2f28;
    color: #ffffff;

    font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
    font-size: 18px;
    font-weight: 500;

    cursor: pointer;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

.card-boas-vindas button:active {
    transform: scale(0.97);
}

@media (max-width: 768px) {
    .card-boas-vindas {
        width: min(330px, 100%);
        padding: 32px 24px 28px;
    }

    .titulo-boas-vindas {
        font-size: 42px;
    }

    .texto-boas-vindas {
        font-size: 19px;
    }
}

/* =========================================================
   AJUSTE FINAL DESKTOP / PC
   Não mexe no celular
   ========================================================= */

@media (min-width: 769px) {
    body {
        padding-bottom: 0 !important;
        background: #f5f2ee !important;
    }

    .site-casamento {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        background: #ffffff !important;
    }

    .grid-duplo,
    .primeira-dupla,
    #localizacao {
        width: 100% !important;
        max-width: 1540px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 0 !important;
    }

    .bloco-capa {
        width: 100% !important;
        max-width: 1540px !important;
        height: 760px !important;
        min-height: 0 !important;
        max-height: none !important;
        margin: 0 auto !important;
        overflow: hidden !important;
    }

    .foto-capa {
        object-position: center 24% !important;
        transform: scale(1.28) !important;
        transform-origin: center 24% !important;
    }

    .texto-sobre-foto h1.nome-noivos-capa {
        font-size: 86px !important;
        line-height: 1.05 !important;
        white-space: nowrap !important;
        max-width: 96vw !important;
        transform: none !important;
    }

    .primeira-contagem,
    .primeira-frase {
        height: 760px !important;
        min-height: 0 !important;
        margin: 0 !important;
        overflow: hidden !important;
    }

    .primeira-contagem .subtitulo-script {
        font-size: 54px !important;
        margin-bottom: 16px !important;
    }

    .contador-casamento {
        width: min(560px, 92%) !important;
        margin: 14px auto 0 !important;
    }

    .contador-numeros,
    .contador-textos {
        grid-template-columns: 1fr 14px 1fr 14px 1fr 14px 1fr !important;
    }

    .contador-numeros span,
    .contador-numeros b {
        font-size: 78px !important;
        font-weight: 500 !important;
        line-height: 0.92 !important;
        letter-spacing: 0 !important;
    }

    .contador-numeros b {
        transform: translateY(-3px) !important;
    }

    .contador-textos {
        margin-top: 10px !important;
    }

    .contador-textos small {
        font-size: 14px !important;
        font-weight: 600 !important;
        letter-spacing: 0 !important;
    }

    .primeira-frase .foto-cover {
        object-position: center 6% !important;
        transform: scale(1.04) !important;
        transform-origin: center 6% !important;
    }

    .primeira-frase .texto-biblico {
        left: 58px !important;
        width: 255px !important;
        transform: translateY(-4px) !important;
    }

    .primeira-frase .texto-biblico p {
        max-width: 255px !important;
        font-size: 18px !important;
        line-height: 1.36 !important;
    }

    .primeira-frase .texto-biblico small {
        width: 255px !important;
        font-size: 11px !important;
    }

    .bloco-texto-grande {
        width: 100% !important;
        max-width: 1540px !important;
        height: 660px !important;
        min-height: 0 !important;
        margin: 0 auto !important;
        overflow: hidden !important;
    }

    .texto-convite-historia p {
        max-width: 540px !important;
        font-size: 38px !important;
        line-height: 1.22 !important;
    }

    .bloco-convite-imagem {
        width: 100% !important;
        max-width: 1540px !important;
        margin: 0 auto !important;
        padding: 44px 24px !important;
        box-sizing: border-box !important;
    }

    .imagem-convite {
        max-width: 980px !important;
        width: 100% !important;
        height: auto !important;
    }

    #localizacao {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .bloco-cerimonia-local,
    .bloco-recepcao-local {
        height: 760px !important;
        min-height: 0 !important;
        margin: 0 !important;
        overflow: hidden !important;
    }

    .texto-cerimonia-local {
        font-size: 26px !important;
        line-height: 1.25 !important;
        margin-bottom: 30px !important;
    }

    .imagem-igreja {
        width: 66% !important;
        max-width: 470px !important;
        transform: none !important;
    }

    .foto-recepcao-local {
        object-position: 56% center !important;
        transform: scale(1.10) !important;
        transform-origin: 56% center !important;
    }

    .conteudo-recepcao-local {
        padding: 64px 28px 28px !important;
    }

    .conteudo-recepcao-local p {
        width: auto !important;
        max-width: 650px !important;
        font-size: 22px !important;
        line-height: 1.25 !important;
        letter-spacing: 0.2px !important;
    }

    .conteudo-recepcao-local p span {
        display: block !important;
        white-space: nowrap !important;
    }

    .bloco-mapa-santa-rosa {
        width: 100% !important;
        max-width: 1540px !important;
        height: 500px !important;
        min-height: 0 !important;
        margin: 0 auto 22px !important;
        overflow: hidden !important;
    }

    .foto-mapa-fundo {
        object-position: center 26% !important;
        transform: scale(1.38) !important;
        transform-origin: center 26% !important;
    }

    .conteudo-mapa-santa-rosa {
        padding: 42px 24px 18px !important;
        justify-content: center !important;
    }

    .conteudo-mapa-santa-rosa h2 {
        font-size: 58px !important;
        margin-bottom: 18px !important;
        white-space: nowrap !important;
    }

    .caixa-google-maps {
        width: min(720px, 76%) !important;
        height: 210px !important;
    }

    .bloco-informacoes-importantes {
        width: 100% !important;
        max-width: 1540px !important;
        height: 760px !important;
        min-height: 0 !important;
        margin: 0 auto !important;
        overflow: hidden !important;
    }

    .foto-informacoes {
        object-position: center center !important;
        transform: scale(1.03) !important;
        transform-origin: center center !important;
    }

    .conteudo-informacoes-importantes {
        justify-content: center !important;
        align-items: flex-start !important;
        padding: 58px 82px !important;
    }

    .conteudo-informacoes-importantes h2 {
        font-size: 62px !important;
        margin-bottom: 24px !important;
        white-space: nowrap !important;
    }

    .conteudo-informacoes-importantes ul {
        max-width: 620px !important;
        padding-left: 24px !important;
    }

    .conteudo-informacoes-importantes li {
        font-size: 25px !important;
        line-height: 1.18 !important;
        margin-bottom: 7px !important;
    }

    .bloco-final-historia {
        width: 100% !important;
        max-width: 1540px !important;
        height: 760px !important;
        min-height: 0 !important;
        margin: 0 auto !important;
        overflow: hidden !important;
    }

    .foto-final {
        object-position: center 22% !important;
        transform: scale(1.18) !important;
        transform-origin: center 22% !important;
    }

    .texto-final-historia h2 {
        font-size: 66px !important;
        line-height: 1.05 !important;
        white-space: normal !important;
    }

    .baloes-fixos {
        display: none !important;
    }
}

/* =========================================================
   AJUSTE DESKTOP - CERIMÔNIA
   Só PC, não mexe no celular
   ========================================================= */

@media (min-width: 769px) {
    .bloco-cerimonia-local {
        height: 760px !important;
        min-height: 0 !important;
        overflow: hidden !important;
    }

    .foto-cerimonia-fundo {
        object-position: center 10% !important;
        transform: scale(1.08) !important;
        transform-origin: center 10% !important;
    }

    .conteudo-cerimonia-local {
        padding: 30px !important;
    }

    .texto-cerimonia-local {
        font-size: 24px !important;
        margin-bottom: 24px !important;
    }

    .imagem-igreja {
        width: 40% !important;
        max-width: 300px !important;
        transform: translateY(70px) !important;
    }
}

/* =========================================================
   AJUSTE DESKTOP - MAPA MAIS ALTO
   Só PC, não mexe no celular
   ========================================================= */

@media (min-width: 769px) {
    .bloco-mapa-santa-rosa {
        height: 680px !important;
        min-height: 0 !important;
        margin: 0 auto 28px !important;
        overflow: hidden !important;
    }

    .foto-mapa-fundo {
        object-position: center 28% !important;
        transform: scale(1.28) !important;
        transform-origin: center 28% !important;
    }

    .conteudo-mapa-santa-rosa {
        padding: 54px 24px 24px !important;
        justify-content: center !important;
    }

    .conteudo-mapa-santa-rosa h2 {
        margin-bottom: 24px !important;
        font-size: 62px !important;
    }

    .caixa-google-maps {
        width: min(760px, 78%) !important;
        height: 260px !important;
    }
}

@media (max-width: 768px) {
    .caixa-google-maps {
        margin-top: 54px !important;
    }
}