      :root {
            --creme: #fdf4cb;
            --verde-escuro: #354c2b;
            --verde-medio: #4e653d;
            --overlay: rgba(253, 244, 203, 0.85);
        }

        body, html {
            margin: 0;
            padding: 0;
            font-family: 'Raleway', sans-serif;
            background-color: var(--creme);
            color: var(--verde-escuro);
            scroll-behavior: smooth;
            overflow-x: hidden;
        }

        /* Navbar Topo */
        .nav-lateral {
            position: fixed;
            top: 0; left: 0;
            width: 100%;
            height: auto;
            background: transparent;
            z-index: 1000;
            transition: background 0.5s ease, box-shadow 0.5s ease;
        }

        .nav-lateral.scrolled {
            background: var(--verde-escuro);
            box-shadow: 0 2px 20px rgba(0,0,0,0.2);
        }

        .nav-lateral nav {
            display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
            padding: 22px 40px;
            gap: 45px;
        }

        .nav-lateral a {
            color: #ffffff;
            text-decoration: none;
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.05rem;
            letter-spacing: 2px;
            text-transform: uppercase;
            white-space: nowrap;
            opacity: 1;
            position: relative;
            transition: opacity 0.3s;
        }

        .nav-lateral a::after {
            content: '';
            position: absolute;
            bottom: -4px; left: 0;
            width: 0; height: 1px;
            background: var(--creme);
            transition: width 0.3s ease;
        }

        .nav-lateral a:hover::after { width: 100%; }
        .nav-lateral a:hover { opacity: 0.7; }

        /* Hero Section */
        .hero {
            background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)), 
                        url('imagens/capa.jpeg') no-repeat center center/cover;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
        }

        .hero-content {
            background: transparent;
            color: #ffffff;
            display: flex;
            flex-direction: column;
            align-items: center;
            padding: 0 20px;
        }

        .brasao { 
            width: 350px;
            max-width: 80%;
            margin-bottom: -10px;
            filter: brightness(0) invert(1);
        }

        .data-hero { 
            color: #ffffff; 
            letter-spacing: 10px; 
            margin: 0;
            font-size: 1.1rem;
            text-transform: uppercase;
        }

        .hero-content h1 { 
            font-family: 'Cormorant Garamond', serif; 
            font-size: 4.5rem; 
            font-weight: 300; 
            margin: -5px 0 10px 0;
            text-shadow: 2px 2px 10px rgba(0,0,0,0.3);
        }

        /* Trilho do Carrossel */
        .fluxo-total {
            position: relative;
            width: 100%;
            overflow: hidden;
        }

        .trilho-carrossel {
            position: absolute;
            right: 30px;
            top: 0; bottom: 0;
            width: 160px;
            z-index: 50;
            overflow: hidden;
            pointer-events: none;
        }

        .scroll-container {
            display: flex;
            flex-direction: column;
            gap: 15px;
            animation: scrollSubindo 50s linear infinite;
        }

        @keyframes scrollSubindo {
            0% { transform: translateY(0); }
            100% { transform: translateY(-50%); }
        }

        .trilho-carrossel img {
            width: 100%;
            border-radius: 2px;
            filter: sepia(10%) contrast(0.9);
            box-shadow: 0 4px 15px rgba(0,0,0,0.2);
        }

        /* Seção Nossa História */
        #nossa-historia {
            background-color: var(--verde-escuro);
            width: 100vw;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            min-height: 100vh;
            display: flex; 
            justify-content: center;
            align-items: center;
        }

        .historia-inner {
            max-width: 1150px;
            width: 90%;
            display: grid;
            grid-template-columns: 420px 1fr;
            gap: 80px;
            align-items: center;
            padding: 100px 60px;
        }

        /* Bloco de fotos */
        .historia-fotos {
            position: relative;
            height: 580px;
        }

        .historia-foto-principal-wrap,
        .historia-foto-secundaria-wrap {
            position: absolute;
        }

        .historia-foto-principal-wrap {
            top: 0; left: 0;
            z-index: 2;
        }

        .historia-foto-secundaria-wrap {
            bottom: 0; right: 0;
            z-index: 1;
        }

        .historia-foto-principal,
        .historia-foto-secundaria {
            width: 230px;
            height: 340px;
            object-fit: cover;
            display: block;
            border: 6px solid rgba(253, 244, 203, 0.15);
            cursor: pointer;
            transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
            filter: sepia(10%) contrast(0.95);
        }

        .historia-foto-principal:hover,
        .historia-foto-secundaria:hover {
            filter: sepia(0%) contrast(1);
            border-color: rgba(253, 244, 203, 0.5);
        }

        .historia-foto-label {
            font-family: 'Cormorant Garamond', serif;
            font-size: 0.75rem;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: rgba(253, 244, 203, 0.45);
            margin-top: 10px;
            text-align: center;
        }

        /* Ornamento & entre as fotos */
        .historia-foto-ornamento {
            position: absolute;
            top: 50%; left: 50%;
            transform: translate(-50%, -50%);
            font-family: 'Cormorant Garamond', serif;
            font-size: 5rem;
            font-weight: 300;
            color: rgba(253, 244, 203, 0.08);
            z-index: 0;
            user-select: none;
            line-height: 1;
        }

        /* Bloco de texto */
        .historia-subtitulo {
            font-size: 0.72rem;
            letter-spacing: 4px;
            text-transform: uppercase;
            color: rgba(253, 244, 203, 0.45);
            margin: 0 0 14px 0;
        }

        .historia-titulo {
            font-family: 'Cormorant Garamond', serif;
            font-size: 4.2rem;
            font-weight: 300;
            color: var(--creme);
            margin: 0 0 24px 0;
            line-height: 1.0;
        }

        .historia-citacao {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.15rem;
            font-style: italic;
            color: rgba(253, 244, 203, 0.6);
            margin: 0 0 28px 0;
            padding-bottom: 28px;
            border-bottom: 1px solid rgba(253, 244, 203, 0.12);
        }

        .historia-paragrafo {
            font-size: 0.9rem;
            line-height: 1.95;
            color: rgba(253, 244, 203, 0.7);
            margin: 0 0 38px 0;
        }

        /* Perfis lado a lado */
        .historia-perfis {
            display: grid;
            grid-template-columns: 1fr 1px 1fr;
            gap: 28px;
            padding: 30px 0;
            border-top: 1px solid rgba(253, 244, 203, 0.12);
            border-bottom: 1px solid rgba(253, 244, 203, 0.12);
            margin-bottom: 36px;
        }

        .historia-perfil-nome {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.3rem;
            color: var(--creme);
            display: block;
            margin-bottom: 10px;
            letter-spacing: 1px;
        }

        .historia-perfil p {
            font-size: 0.83rem;
            line-height: 1.85;
            color: rgba(253, 244, 203, 0.6);
            margin: 0;
        }

        .historia-perfil-divisor {
            background: rgba(253, 244, 203, 0.12);
            width: 1px;
        }

        .historia-data-destaque {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1rem;
            letter-spacing: 6px;
            color: rgba(253, 244, 203, 0.3);
            margin: 0;
            text-transform: uppercase;
        }

        /* Mantém compatibilidade com o JS que usa .foto-camillo e .foto-alexya */
        .foto-camillo.trocado { opacity: 0.7; filter: sepia(20%); }
        .foto-alexya.trocado { filter: sepia(0%) contrast(1); border-color: rgba(253, 244, 203, 0.5); }

        /* Confirmação de Presença Section */
        #rsvp {
            background-color: var(--creme);
            width: 100vw;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            min-height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .rsvp-inner {
            max-width: 1150px;
            width: 90%;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 80px;
            align-items: center;
            padding: 100px 60px;
        }

        /* Lateral esquerda — decorativa */
        .rsvp-lateral {
            position: relative;
            border-right: 1px solid rgba(53, 76, 43, 0.12);
            padding-right: 80px;
        }

        .rsvp-subtitulo {
            font-size: 0.72rem;
            letter-spacing: 4px;
            text-transform: uppercase;
            color: var(--verde-medio);
            opacity: 0.6;
            margin: 0 0 14px 0;
        }

        .rsvp-titulo {
            font-family: 'Cormorant Garamond', serif;
            font-size: 4rem;
            font-weight: 300;
            color: var(--verde-escuro);
            line-height: 1.05;
            margin: 0 0 24px 0;
        }

        .rsvp-citacao {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.05rem;
            font-style: italic;
            color: var(--verde-medio);
            opacity: 0.7;
            margin: 0 0 40px 0;
            padding-bottom: 40px;
            border-bottom: 1px solid rgba(53, 76, 43, 0.12);
        }

        .rsvp-countdown-bloco {
            display: flex;
            flex-direction: column;
            gap: 4px;
        }

        .rsvp-countdown {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.8rem;
            color: var(--verde-escuro);
            margin: 0;
            line-height: 1;
        }

        .rsvp-countdown-label {
            font-size: 0.7rem;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: var(--verde-medio);
            opacity: 0.5;
        }

        .rsvp-ornamento {
            position: absolute;
            bottom: -10px; right: 60px;
            font-size: 8rem;
            color: rgba(53, 76, 43, 0.04);
            font-family: 'Cormorant Garamond', serif;
            line-height: 1;
            user-select: none;
        }

        /* Lateral direita — formulário */
        .rsvp-instrucao {
            font-size: 0.88rem;
            line-height: 1.8;
            color: #777;
            margin: 0 0 30px 0;
        }

        .rsvp-input {
            width: 100%;
            padding: 16px 20px;
            border: 1px solid rgba(53, 76, 43, 0.25);
            border-bottom: 2px solid var(--verde-escuro);
            background: transparent;
            font-family: 'Raleway', sans-serif;
            font-size: 0.9rem;
            color: var(--verde-escuro);
            outline: none;
            box-sizing: border-box;
            transition: border-color 0.3s;
            margin-bottom: 20px;
        }

        .rsvp-input:focus {
            border-color: var(--verde-escuro);
            background: rgba(53, 76, 43, 0.02);
        }

        .rsvp-input::placeholder { color: #aaa; }

        .rsvp-btn-primary {
            width: 100%;
            padding: 16px;
            background: var(--verde-escuro);
            color: var(--creme);
            border: none;
            font-family: 'Raleway', sans-serif;
            font-size: 0.72rem;
            letter-spacing: 3px;
            text-transform: uppercase;
            cursor: pointer;
            transition: background 0.3s, opacity 0.3s;
        }

        .rsvp-btn-primary:hover { opacity: 0.85; }

        .rsvp-btn-ghost {
            width: 100%;
            padding: 14px;
            background: transparent;
            color: #aaa;
            border: 1px solid #ddd;
            font-family: 'Raleway', sans-serif;
            font-size: 0.72rem;
            letter-spacing: 2px;
            text-transform: uppercase;
            cursor: pointer;
            transition: all 0.3s;
            margin-top: 10px;
        }

        .rsvp-btn-ghost:hover { border-color: #aaa; color: #777; }

        .rsvp-boas-vindas {
            font-family: 'Cormorant Garamond', serif;
            font-size: 2.4rem;
            font-weight: 300;
            color: var(--verde-escuro);
            margin: 0 0 12px 0;
        }

        .rsvp-pergunta {
            font-size: 0.9rem;
            color: #777;
            margin: 0 0 28px 0;
            line-height: 1.6;
        }

        .rsvp-botoes-decisao {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }

        .rsvp-final-icone {
            font-size: 2.5rem;
            color: var(--verde-escuro);
            opacity: 0.3;
            margin-bottom: 16px;
        }

        .rsvp-final-titulo {
            font-family: 'Cormorant Garamond', serif;
            font-size: 2.2rem;
            font-weight: 300;
            color: var(--verde-escuro);
            margin: 0 0 8px 0;
        }

        .rsvp-final-sub {
            font-size: 0.82rem;
            color: #aaa;
            letter-spacing: 1px;
            margin: 0 0 20px 0;
        }

        .rsvp-reset {
            background: none;
            border: none;
            color: #bbb;
            font-size: 0.75rem;
            text-decoration: underline;
            cursor: pointer;
            font-family: 'Raleway';
            letter-spacing: 1px;
        }

        /* Card box dentro do formulário */
        .rsvp-card {
            background: #ffffff;
            border: 1px solid rgba(53, 76, 43, 0.08);
            box-shadow: 0 8px 40px rgba(53, 76, 43, 0.08);
            padding: 44px 40px;
        }

        /* Modal RSVP estilizado */
        .modal-rsvp-box {
            background: var(--creme);
            max-width: 420px;
            width: 90%;
            padding: 48px 40px;
            position: relative;
            box-shadow: 0 30px 80px rgba(0,0,0,0.25);
        }

        .modal-brasao {
            width: 70px;
            display: block;
            margin: 0 auto 20px;
            filter: brightness(0) saturate(100%) invert(22%) sepia(20%) saturate(600%) hue-rotate(70deg) brightness(80%);
            opacity: 0.5;
        }

        .modal-rsvp-subtitulo {
            font-size: 0.68rem;
            letter-spacing: 4px;
            text-transform: uppercase;
            color: var(--verde-medio);
            opacity: 0.6;
            margin: 0 0 8px 0;
            text-align: center;
        }

        .modal-rsvp-titulo {
            font-family: 'Cormorant Garamond', serif;
            font-size: 2rem;
            font-weight: 300;
            color: var(--verde-escuro);
            margin: 0 0 10px 0;
            text-align: center;
        }

        .modal-rsvp-instrucao {
            font-size: 0.85rem;
            line-height: 1.7;
            color: #888;
            margin: 0 0 24px 0;
            text-align: center;
        }

        /* Seção Localização */
        #local {
            background-color: var(--verde-escuro);
            width: 100vw;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            min-height: 100vh;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 80px 0;
            box-sizing: border-box;
            color: var(--creme);
        }

        .local-inner {
            max-width: 1100px;
            width: 90%;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 70px;
            align-items: center;
        }

        .local-texto {
            text-align: left;
        }

        .local-subtitulo {
            font-size: 0.75rem;
            letter-spacing: 4px;
            text-transform: uppercase;
            color: rgba(253, 244, 203, 0.5);
            margin: 0 0 14px 0;
        }

        .local-texto h2 {
            font-family: 'Cormorant Garamond', serif;
            font-size: 3.8rem;
            font-weight: 300;
            color: var(--creme);
            margin: 0 0 10px 0;
            line-height: 1.1;
        }

        .local-endereco {
            font-size: 0.85rem;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: rgba(253, 244, 203, 0.6);
            margin: 0 0 40px 0;
        }

        .local-detalhes {
            display: flex;
            flex-direction: column;
            gap: 18px;
            margin-bottom: 45px;
            padding-top: 30px;
            border-top: 1px solid rgba(253, 244, 203, 0.15);
        }

        .local-detalhe {
            display: flex;
            align-items: center;
            gap: 16px;
        }

        .local-detalhe-icone {
            font-size: 1.1rem;
            width: 36px;
            height: 36px;
            border: 1px solid rgba(253, 244, 203, 0.2);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

        .local-detalhe p {
            margin: 0;
            font-size: 0.88rem;
            line-height: 1.6;
            color: rgba(253, 244, 203, 0.8);
        }

        .local-detalhe p strong {
            color: var(--creme);
            font-weight: 400;
            display: block;
            font-size: 0.78rem;
            letter-spacing: 1px;
            text-transform: uppercase;
            margin-bottom: 2px;
        }

        .local-mapa-wrapper {
            position: relative;
        }

        .local-mapa-wrapper::before {
            content: '';
            position: absolute;
            top: -15px; right: -15px;
            bottom: 15px; left: 15px;
            border: 1px solid rgba(253, 244, 203, 0.15);
            z-index: 0;
        }

        .grid-local {
            position: relative;
            z-index: 1;
            overflow: hidden;
        }

        .mapa-box { width: 100%; height: 420px; }
        .mapa-box iframe { width: 100% !important; height: 100% !important; border: 0; display: block; }

        /* btn para seção local (fundo escuro) */
        #local .btn-suave {
            border: 1px solid rgba(253, 244, 203, 0.5) !important;
            color: var(--creme) !important;
            background-color: transparent !important;
        }
        #local .btn-suave:hover {
            background-color: var(--creme) !important;
            color: var(--verde-escuro) !important;
        }

        .btn-suave {
            border: 1px solid var(--verde-escuro); padding: 15px 40px;
            background: transparent; color: var(--verde-escuro);
            text-decoration: none; transition: 0.4s;
            letter-spacing: 2px; margin-top: 30px;
            display: inline-block; cursor: pointer;
        }
        .btn-suave:hover { background: var(--verde-escuro); color: var(--creme); }

        /* Lista de Presentes Section */
        #presentes-transicao {
            background-color: var(--verde-escuro);
            width: 100vw;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            min-height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .presentes-inner {
            max-width: 1150px;
            width: 90%;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 80px;
            align-items: center;
            padding: 100px 60px;
        }

        .presentes-subtitulo {
            font-size: 0.72rem;
            letter-spacing: 4px;
            text-transform: uppercase;
            color: rgba(253, 244, 203, 0.45);
            margin: 0 0 14px 0;
        }

        .presentes-titulo {
            font-family: 'Cormorant Garamond', serif;
            font-size: 4.2rem;
            font-weight: 300;
            color: var(--creme);
            line-height: 1.0;
            margin: 0 0 24px 0;
        }

        .presentes-citacao {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.1rem;
            font-style: italic;
            color: rgba(253, 244, 203, 0.55);
            margin: 0 0 28px 0;
            padding-bottom: 28px;
            border-bottom: 1px solid rgba(253, 244, 203, 0.12);
        }

        .presentes-paragrafo {
            font-size: 0.88rem;
            line-height: 1.95;
            color: rgba(253, 244, 203, 0.65);
            margin: 0 0 40px 0;
        }

        .presentes-btn {
            display: inline-block;
            padding: 16px 44px;
            border: 1px solid rgba(253, 244, 203, 0.45);
            color: var(--creme);
            text-decoration: none;
            font-size: 0.72rem;
            letter-spacing: 3px;
            text-transform: uppercase;
            transition: all 0.4s;
        }

        .presentes-btn:hover {
            background: var(--creme);
            color: var(--verde-escuro);
            border-color: var(--creme);
        }

        /* Visual lado direito */
        .presentes-visual {
            position: relative;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 40px;
        }

        .presentes-brasao {
            width: 500px;
            position: absolute;
            opacity: 0.08;
            filter: brightness(0) invert(1);
            user-select: none;
            pointer-events: none;
        }

        .presentes-cards {
            display: flex;
            gap: 20px;
            position: relative;
            z-index: 1;
        }

        .presentes-card {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 12px;
            padding: 30px 24px;
            border: 1px solid rgba(253, 244, 203, 0.1);
            background: rgba(253, 244, 203, 0.03);
            transition: all 0.4s;
            min-width: 90px;
        }

        .presentes-card:hover {
            background: rgba(253, 244, 203, 0.07);
            border-color: rgba(253, 244, 203, 0.25);
            transform: translateY(-4px);
        }

        .presentes-card--destaque {
            border-color: rgba(253, 244, 203, 0.2);
            background: rgba(253, 244, 203, 0.06);
            transform: translateY(-8px);
        }

        .presentes-card--destaque:hover { transform: translateY(-12px); }

        .presentes-card-icone { font-size: 1.6rem; }

        .presentes-card-label {
            font-size: 0.65rem;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: rgba(253, 244, 203, 0.4);
        }

        .presentes-data {
            font-family: 'Cormorant Garamond', serif;
            font-size: 0.9rem;
            letter-spacing: 6px;
            color: rgba(253, 244, 203, 0.2);
            margin: 0;
            position: relative;
            z-index: 1;
        }

        .revelar { opacity: 0; transform: translateY(30px); transition: all 1s ease-out; }
        .revelar.ativo { opacity: 1; transform: translateY(0); }

        /* Dress Code Section */
        #dresscode {
            background-color: var(--creme);
            width: 100vw;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            min-height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .dresscode-inner {
            max-width: 1200px;
            width: 90%;
            display: grid;
            grid-template-columns: 1fr 420px;
            gap: 80px;
            align-items: center;
            padding: 100px 60px;
        }

        .dresscode-subtitulo {
            font-size: 0.75rem;
            letter-spacing: 4px;
            text-transform: uppercase;
            color: var(--verde-medio);
            margin: 0 0 12px 0;
        }

        .dresscode-texto h2 {
            font-family: 'Cormorant Garamond', serif;
            font-size: 3.8rem;
            font-weight: 300;
            color: var(--verde-escuro);
            margin: 0 0 20px 0;
            line-height: 1;
        }

        .dresscode-intro {
            font-size: 1rem;
            line-height: 1.8;
            color: var(--verde-medio);
            margin-bottom: 40px;
            max-width: 480px;
        }

        .dresscode-grid {
            display: grid;
            grid-template-columns: 1fr 1px 1fr;
            gap: 30px;
            margin-bottom: 40px;
            padding: 35px 0;
            border-top: 1px solid rgba(53, 76, 43, 0.15);
            border-bottom: 1px solid rgba(53, 76, 43, 0.15);
        }

        .dresscode-coluna h3 {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.4rem;
            font-weight: 400;
            color: var(--verde-escuro);
            letter-spacing: 1px;
            margin: 0 0 12px 0;
        }

        .dresscode-coluna p {
            font-size: 0.88rem;
            line-height: 1.9;
            color: #555;
            margin: 0;
        }

        .dresscode-divisor {
            background: rgba(53, 76, 43, 0.15);
            width: 1px;
        }

        .dresscode-alertas {
            display: flex;
            gap: 20px;
            margin-bottom: 35px;
        }

        .dresscode-alerta {
            display: flex;
            align-items: center;
            gap: 12px;
            background: rgba(53, 76, 43, 0.05);
            border: 1px solid rgba(53, 76, 43, 0.1);
            padding: 14px 20px;
            flex: 1;
            border-radius: 2px;
        }

        .alerta-icone {
            font-size: 1.2rem;
            flex-shrink: 0;
        }

        .dresscode-alerta p {
            font-size: 0.82rem;
            line-height: 1.5;
            color: var(--verde-escuro);
            margin: 0;
        }

        .dresscode-fechamento {
            font-family: 'Cormorant Garamond', serif;
            font-size: 1.2rem;
            font-style: italic;
            color: var(--verde-medio);
            line-height: 1.8;
            margin: 0;
        }

        .dresscode-imagem {
            position: relative;
            cursor: zoom-in;
        }

        .dresscode-imagem::before {
            content: '';
            position: absolute;
            top: 20px; left: 20px;
            right: -20px; bottom: -20px;
            border: 1px solid rgba(53, 76, 43, 0.2);
            z-index: 0;
        }

        .dresscode-imagem img {
            width: 100%;
            height: 620px;
            object-fit: contain;
            background-color: var(--creme);
            display: block;
            position: relative;
            z-index: 1;
            transition: opacity 0.3s ease;
        }

        .dresscode-imagem:hover img {
            opacity: 0.92;
        }

        .dresscode-zoom-hint {
            position: absolute;
            bottom: 16px; right: 16px;
            background: rgba(53, 76, 43, 0.75);
            color: var(--creme);
            font-size: 0.7rem;
            letter-spacing: 1px;
            padding: 7px 14px;
            z-index: 2;
            opacity: 0;
            transition: opacity 0.3s ease;
            pointer-events: none;
        }

        .dresscode-imagem:hover .dresscode-zoom-hint {
            opacity: 1;
        }

        /* AJUSTES MOBILE / RESPONSIVIDADE */
        @media (max-width: 1000px) {
            .trilho-carrossel { display: none; }
            .nav-lateral nav { gap: 20px; padding: 18px 20px; flex-wrap: wrap; justify-content: center; }
            .nav-lateral a { font-size: 0.85rem; letter-spacing: 1px; }
            .hero-content h1 { font-size: 2.8rem; }
            .historia-inner { grid-template-columns: 1fr; padding: 60px 20px; gap: 40px; }
            .historia-fotos { display: none; }
            .historia-titulo { font-size: 3rem; }
            .rsvp-inner { grid-template-columns: 1fr; padding: 60px 20px; gap: 50px; }
            .rsvp-lateral { border-right: none; padding-right: 0; border-bottom: 1px solid rgba(53,76,43,0.12); padding-bottom: 40px; }
            .rsvp-titulo { font-size: 2.8rem; }
            .rsvp-ornamento { display: none; }
            .presentes-inner { grid-template-columns: 1fr; padding: 60px 20px; gap: 50px; }
            .presentes-titulo { font-size: 3rem; }
            .presentes-brasao { display: none; }
            .grid-local { grid-template-columns: 1fr; }
            .rsvp-inner { padding: 40px 20px; }
            .dresscode-inner { grid-template-columns: 1fr; padding: 60px 20px; gap: 40px; }
            .dresscode-texto h2 { font-size: 2.8rem; }
            .dresscode-imagem::before { display: none; }
            .dresscode-imagem img { height: 380px; }
            .dresscode-alertas { flex-direction: column; }
            .dresscode-grid { grid-template-columns: 1fr; }
            .dresscode-divisor { display: none; }
            .local-inner { grid-template-columns: 1fr; gap: 40px; }
            .local-texto h2 { font-size: 2.5rem; }
            .local-mapa-wrapper::before { display: none; }
            .mapa-box { height: 300px; }
        }

        /* Presentes Section */
        #presentes-transicao {
            background-color: var(--verde-escuro); 
            width: 100vw;
            margin-left: calc(-50vw + 50%);
            margin-right: calc(-50vw + 50%);
            min-height: 100vh;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            text-align: center;
            color: var(--creme);
        }

        #presentes-transicao p {
            max-width: 600px;
            margin: 0 auto 30px;
            font-size: 1.1rem;
            line-height: 1.8;
        }
   