:root{
    --bm-bg:#070917;
    --bm-bg-soft:#10142a;
    --bm-card:#0b1024;
    --bm-card-soft:#111934;
    --bm-gold:#f4cf6a;
    --bm-gold-soft:#ffe6a2;
    --bm-gold-dark:#a77424;
    --bm-ink:#f8f1dc;
    --bm-muted:#b9b1c9;
    --bm-white:rgba(255,255,255,0.92);
    --bm-line:rgba(244,207,106,0.26);
    --bm-line-soft:rgba(255,255,255,0.12);
    --bm-shadow:0 34px 90px rgba(0,0,0,0.42);
    --bm-radius-xl:34px;
    --bm-radius-lg:24px;
    --bm-radius-md:18px;
    --bm-max:860px;
}

*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    min-width:320px;
    min-height:100vh;
    color:var(--bm-ink);
    font-family:'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background:
        linear-gradient(180deg, rgba(5,7,20,0.78), rgba(5,7,20,0.92)),
        url("fondo.png") center center / cover no-repeat fixed;
    overflow-x:hidden;
    text-rendering:optimizeLegibility;
    -webkit-font-smoothing:antialiased;
}

body::before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    background:
        linear-gradient(90deg, rgba(244,207,106,0.09) 0 1px, transparent 1px 100%),
        linear-gradient(180deg, rgba(244,207,106,0.06) 0 1px, transparent 1px 100%);
    background-size:84px 84px;
    mask-image:radial-gradient(circle at center, black, transparent 72%);
    opacity:0.34;
}

img{
    max-width:100%;
    display:block;
}

a{
    color:inherit;
    text-decoration:none;
}

p,
h1,
h2{
    overflow-wrap:anywhere;
}

.bm-page{
    position:relative;
    width:100%;
    min-height:100vh;
    padding:24px 12px 34px;
}

.bm-phone-card{
    position:relative;
    width:100%;
    max-width:var(--bm-max);
    margin:0 auto;
    overflow:hidden;
    border:1px solid var(--bm-line);
    border-radius:var(--bm-radius-xl);
    background:
        radial-gradient(circle at 0% 0%, rgba(244,207,106,0.12), transparent 26%),
        radial-gradient(circle at 100% 16%, rgba(88,79,181,0.24), transparent 32%),
        linear-gradient(180deg, rgba(13,18,42,0.98), rgba(6,8,20,0.98));
    box-shadow:var(--bm-shadow);
    padding:30px 18px 28px;
    isolation:isolate;
}

.bm-phone-card::before{
    content:"";
    position:absolute;
    inset:12px;
    border:1px solid rgba(244,207,106,0.13);
    border-radius:calc(var(--bm-radius-xl) - 10px);
    pointer-events:none;
    z-index:-1;
}

.bm-phone-card::after{
    content:"";
    position:absolute;
    left:50%;
    top:8px;
    width:104px;
    height:18px;
    border-radius:0 0 18px 18px;
    transform:translateX(-50%);
    background:#02030a;
    border:1px solid rgba(255,255,255,0.12);
    border-top:0;
    opacity:0.92;
}

.bm-ornament{
    position:absolute;
    width:260px;
    height:260px;
    pointer-events:none;
    opacity:0.72;
    background:url("flores.png") center center / contain no-repeat;
    filter:drop-shadow(0 18px 34px rgba(0,0,0,0.28));
}

.bm-ornament-top{
    top:-84px;
    left:-82px;
}

.bm-ornament-bottom{
    right:-92px;
    bottom:-96px;
    transform:rotate(180deg);
}

.bm-hero{
    position:relative;
    min-height:auto;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    text-align:center;
    padding:44px 10px 34px;
}

.bm-kicker,
.bm-section-eyebrow{
    margin:0;
    color:var(--bm-muted);
    font-size:0.72rem;
    font-weight:700;
    letter-spacing:0.22em;
    text-transform:uppercase;
}

.bm-script{
    margin:14px 0 0;
    font-family:'Parisienne', cursive;
    font-size:clamp(2rem, 8vw, 4.2rem);
    line-height:1;
    color:var(--bm-gold);
    text-shadow:0 0 34px rgba(244,207,106,0.18);
}

.bm-title{
    margin:14px 0 24px;
    max-width:720px;
    font-family:'Cormorant Garamond', Georgia, serif;
    font-size:clamp(3rem, 9vw, 6.1rem);
    line-height:0.98;
    font-weight:700;
    color:var(--bm-gold-soft);
    text-shadow:0 18px 40px rgba(0,0,0,0.34);
}

.bm-parents{
    width:min(100%, 620px);
    margin:0 auto 28px;
    padding:0 12px;
    text-align:center;
}

.bm-parents-label{
    margin:0 0 8px;
    color:var(--bm-white);
    font-size:0.92rem;
    font-weight:600;
    line-height:1.45;
    letter-spacing:0.02em;
}

.bm-parents-names{
    color:var(--bm-white);
    font-size:0.96rem;
    font-weight:700;
    line-height:1.5;
}

.bm-date-card{
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    gap:14px;
    width:min(100%, 560px);
    margin:4px auto 0;
    padding:14px 16px;
    border-top:1px solid var(--bm-line);
    border-bottom:1px solid var(--bm-line);
}

.bm-date-card span{
    color:var(--bm-ink);
    font-size:0.78rem;
    font-weight:700;
    letter-spacing:0.18em;
    text-transform:uppercase;
}

.bm-date-card strong{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:76px;
    height:76px;
    border-radius:999px;
    border:1px solid rgba(244,207,106,0.42);
    background:rgba(244,207,106,0.08);
    color:var(--bm-gold);
    font-family:'Cormorant Garamond', Georgia, serif;
    font-size:3rem;
    line-height:1;
}

.bm-time{
    margin:18px 0 0;
    color:var(--bm-white);
    font-size:1rem;
    font-weight:700;
    letter-spacing:0.18em;
    text-transform:uppercase;
}

.bm-main-place{
    margin:18px 0 0;
    color:var(--bm-gold-soft);
    font-family:'Cormorant Garamond', Georgia, serif;
    font-size:1.35rem;
    font-weight:700;
}

.bm-message{
    width:min(100%, 620px);
    margin:18px auto 0;
    color:var(--bm-muted);
    font-size:0.98rem;
    line-height:1.8;
}

.bm-action-grid{
    position:sticky;
    top:10px;
    z-index:20;
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:10px;
    margin:0 auto 20px;
    padding:10px;
    border:1px solid rgba(244,207,106,0.16);
    border-radius:24px;
    background:rgba(7,9,23,0.76);
    box-shadow:0 18px 45px rgba(0,0,0,0.24);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
}

.bm-action{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:7px;
    min-height:76px;
    border:1px solid rgba(244,207,106,0.18);
    border-radius:18px;
    background:linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.025));
    color:var(--bm-ink);
    font-size:0.72rem;
    font-weight:800;
    letter-spacing:0.08em;
    text-transform:uppercase;
    transition:transform 220ms ease, border-color 220ms ease, background 220ms ease;
}

.bm-action:hover{
    transform:translateY(-2px);
    border-color:rgba(244,207,106,0.46);
    background:rgba(244,207,106,0.10);
}

.bm-action-icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:32px;
    height:32px;
    border-radius:12px;
    background:linear-gradient(180deg, var(--bm-gold-soft), var(--bm-gold));
    color:#101020;
    font-size:1.2rem;
    font-weight:900;
    box-shadow:0 8px 20px rgba(244,207,106,0.18);
}

.bm-section{
    position:relative;
    margin-top:18px;
    padding:26px 18px;
    border:1px solid rgba(244,207,106,0.16);
    border-radius:var(--bm-radius-lg);
    background:
        radial-gradient(circle at 14% 0%, rgba(244,207,106,0.12), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,0.072), rgba(255,255,255,0.025));
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.08);
}

.bm-section-title,
.bm-location-title{
    margin:10px 0 0;
    color:var(--bm-gold-soft);
    font-family:'Cormorant Garamond', Georgia, serif;
    font-size:clamp(2rem, 5vw, 3.2rem);
    line-height:1;
    font-weight:700;
    text-align:center;
}

.bm-section-copy{
    margin:12px auto 0;
    max-width:620px;
    color:var(--bm-muted);
    font-size:1rem;
    line-height:1.75;
    text-align:center;
}

.bm-countdown{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:10px;
    margin-top:18px;
}

.bm-countdown-item{
    min-height:94px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(244,207,106,0.18);
    border-radius:18px;
    background:rgba(255,255,255,0.055);
}

.bm-countdown-item strong{
    color:var(--bm-gold);
    font-family:'Cormorant Garamond', Georgia, serif;
    font-size:2.35rem;
    line-height:1;
}

.bm-countdown-item span{
    margin-top:6px;
    color:var(--bm-muted);
    font-size:0.7rem;
    font-weight:800;
    letter-spacing:0.14em;
    text-transform:uppercase;
}

.bm-intro{
    text-align:center;
}

.bm-locations{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    padding:0;
    border:0;
    background:transparent;
    box-shadow:none;
}

.bm-location-card{
    min-height:100%;
    padding:26px 18px;
    border:1px solid rgba(244,207,106,0.16);
    border-radius:var(--bm-radius-lg);
    background:
        radial-gradient(circle at 80% 0%, rgba(244,207,106,0.13), transparent 32%),
        linear-gradient(180deg, rgba(255,255,255,0.074), rgba(255,255,255,0.026));
    text-align:center;
}

.bm-location-time{
    margin:14px 0 0;
    color:var(--bm-white);
    font-size:0.85rem;
    font-weight:800;
    letter-spacing:0.18em;
    text-transform:uppercase;
}

.bm-location-place{
    margin:12px 0 0;
    color:var(--bm-gold-soft);
    font-size:1.15rem;
    font-weight:800;
}

.bm-location-address{
    margin:10px auto 0;
    color:var(--bm-muted);
    font-size:0.94rem;
    line-height:1.65;
}

.bm-button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:46px;
    margin-top:18px;
    padding:12px 18px;
    border:1px solid rgba(244,207,106,0.38);
    border-radius:999px;
    background:linear-gradient(180deg, var(--bm-gold-soft), var(--bm-gold));
    color:#101020;
    font-size:0.78rem;
    font-weight:900;
    letter-spacing:0.12em;
    text-transform:uppercase;
    box-shadow:0 14px 34px rgba(244,207,106,0.18);
    transition:transform 220ms ease, box-shadow 220ms ease;
}

.bm-button:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 42px rgba(244,207,106,0.25);
}

.bm-info-panel{
    text-align:center;
}

.bm-panel-main{
    margin:12px 0 0;
    color:var(--bm-gold-soft);
    font-size:1.15rem;
    font-weight:800;
}

.bm-qr{
    width:190px;
    height:190px;
    margin:18px auto 0;
    padding:12px;
    border-radius:20px;
    background:#fff;
}


.bm-rsvp{
    text-align:center;
    background:
        radial-gradient(circle at 14% 0%, rgba(244,207,106,0.14), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,0.074), rgba(255,255,255,0.026));
}

.bm-rsvp-content{
    width:100%;
    max-width:620px;
    margin:18px auto 0;
    text-align:left;
    color:var(--bm-ink);
}

.bm-rsvp-content [hidden]{
    display:none !important;
}

.bm-rsvp-content .rsvp-section,
.bm-rsvp-content .rsvp-card,
.bm-rsvp-content .rsvp-container{
    width:100%;
    max-width:100%;
    margin:0;
    padding:0;
    border:0;
    background:transparent;
    box-shadow:none;
    color:inherit;
}

.bm-rsvp-content .rsvp-card{
    display:block;
}

.bm-rsvp-content .rsvp-card > * + *{
    margin-top:14px;
}

.bm-rsvp-content h1,
.bm-rsvp-content h2,
.bm-rsvp-content h3,
.bm-rsvp-content h4{
    margin:0;
    color:var(--bm-gold-soft);
    font-family:'Cormorant Garamond', Georgia, serif;
    font-size:clamp(2rem, 5vw, 3rem);
    line-height:1;
    font-weight:700;
    text-align:center;
}

.bm-rsvp-content p{
    margin:0;
    color:var(--bm-muted);
    font-size:0.96rem;
    line-height:1.7;
    text-align:center;
}

.bm-rsvp-content .rsvp-summary{
    display:grid;
    gap:8px;
    margin:16px 0;
    padding:14px;
    border:1px solid rgba(244,207,106,0.18);
    border-radius:16px;
    background:rgba(255,255,255,0.045);
}

.bm-rsvp-content .rsvp-summary p{
    text-align:left;
    color:var(--bm-ink);
    font-size:0.92rem;
    line-height:1.55;
}

.bm-rsvp-content .rsvp-summary strong{
    color:var(--bm-gold-soft);
    font-weight:800;
}

.bm-rsvp-content .rsvp-summary span{
    color:var(--bm-white);
}

.bm-rsvp-content .rsvp-form{
    display:grid;
    gap:14px;
    width:100%;
    margin:0;
    padding:0;
}

.bm-rsvp-content .form-group{
    display:block;
    width:100%;
    margin:0;
    padding:0;
}

.bm-rsvp-content label{
    display:block;
    margin:0 0 7px;
    color:var(--bm-gold-soft);
    font-size:0.74rem;
    font-weight:900;
    letter-spacing:0.12em;
    line-height:1.35;
    text-transform:uppercase;
}

.bm-rsvp-content input,
.bm-rsvp-content select,
.bm-rsvp-content textarea{
    display:block;
    width:100%;
    min-height:48px;
    margin:0;
    padding:12px 14px;
    border:1px solid rgba(244,207,106,0.24);
    border-radius:14px;
    background:rgba(7,9,23,0.74);
    color:var(--bm-ink);
    font:inherit;
    line-height:1.4;
    outline:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.06);
    appearance:none;
}

.bm-rsvp-content textarea{
    min-height:96px;
    resize:vertical;
}

.bm-rsvp-content select{
    padding-right:38px;
    background-image:
        linear-gradient(45deg, transparent 50%, var(--bm-gold) 50%),
        linear-gradient(135deg, var(--bm-gold) 50%, transparent 50%);
    background-position:
        calc(100% - 20px) 52%,
        calc(100% - 14px) 52%;
    background-size:6px 6px, 6px 6px;
    background-repeat:no-repeat;
}

.bm-rsvp-content input::placeholder,
.bm-rsvp-content textarea::placeholder{
    color:rgba(248,241,220,0.48);
}

.bm-rsvp-content select option{
    background:#0b1024;
    color:var(--bm-ink);
}

.bm-rsvp-content input[readonly],
.bm-rsvp-content input[disabled],
.bm-rsvp-content select[disabled],
.bm-rsvp-content textarea[disabled]{
    opacity:0.72;
    cursor:not-allowed;
}

.bm-rsvp-content input[type="radio"],
.bm-rsvp-content input[type="checkbox"]{
    display:inline-block;
    width:auto;
    min-height:auto;
    margin:0;
    padding:0;
    accent-color:var(--bm-gold);
}

.bm-rsvp-content input:-webkit-autofill,
.bm-rsvp-content textarea:-webkit-autofill,
.bm-rsvp-content select:-webkit-autofill{
    -webkit-text-fill-color:var(--bm-ink);
    box-shadow:0 0 0 1000px #0b1024 inset;
}

.bm-rsvp-content input:focus,
.bm-rsvp-content select:focus,
.bm-rsvp-content textarea:focus{
    border-color:rgba(244,207,106,0.68);
    box-shadow:
        0 0 0 4px rgba(244,207,106,0.14),
        inset 0 1px 0 rgba(255,255,255,0.08);
}

.bm-rsvp-content button,
.bm-rsvp-content input[type="submit"],
.bm-rsvp-content .submit-button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:100%;
    min-height:50px;
    margin:4px 0 0;
    padding:13px 18px;
    border:0;
    border-radius:999px;
    background:linear-gradient(180deg, var(--bm-gold-soft), var(--bm-gold));
    color:#101020;
    font:inherit;
    font-size:0.78rem;
    font-weight:900;
    letter-spacing:0.14em;
    line-height:1.2;
    text-align:center;
    text-transform:uppercase;
    cursor:pointer;
    box-shadow:0 14px 34px rgba(244,207,106,0.18);
    transition:transform 220ms ease, box-shadow 220ms ease, opacity 220ms ease;
}

.bm-rsvp-content button:hover,
.bm-rsvp-content input[type="submit"]:hover,
.bm-rsvp-content .submit-button:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 42px rgba(244,207,106,0.25);
}

.bm-rsvp-content button:disabled,
.bm-rsvp-content input[type="submit"]:disabled,
.bm-rsvp-content .submit-button:disabled{
    opacity:0.62;
    cursor:not-allowed;
    transform:none;
}

.bm-rsvp-content [data-rsvp-success],
.bm-rsvp-content [data-rsvp-error]{
    margin-top:14px;
    padding:12px 14px;
    border-radius:14px;
    font-size:0.92rem;
    line-height:1.55;
    text-align:center;
}

.bm-rsvp-content [data-rsvp-success]{
    border:1px solid rgba(244,207,106,0.28);
    background:rgba(244,207,106,0.1);
    color:var(--bm-gold-soft);
}

.bm-rsvp-content [data-rsvp-error]{
    border:1px solid rgba(248,113,113,0.34);
    background:rgba(248,113,113,0.1);
    color:#fecaca;
}
@media (min-width: 768px){
    .bm-page{
        padding:46px 22px 64px;
    }

    .bm-phone-card{
        padding:46px 44px 42px;
    }

    .bm-hero{
        min-height:580px;
    }
}

@media (max-width: 640px){
    .bm-page{
        padding:8px 6px 22px;
    }

    .bm-phone-card{
        max-width:430px;
        min-height:calc(100vh - 16px);
        border-radius:30px;
        padding:28px 12px 18px;
    }

    .bm-phone-card::before{
        inset:9px;
        border-radius:22px;
    }

    .bm-hero{
        min-height:auto;
        padding:42px 8px 18px;
    }

    .bm-message{
    margin-bottom:0;
    }

    .bm-action-grid{
        margin-top:6px;
        margin-bottom:18px;
    }

    .bm-title{
        font-size:clamp(3rem, 15vw, 4.7rem);
    }

    .bm-script{
        font-size:clamp(2rem, 12vw, 3.5rem);
    }

    .bm-date-card{
        grid-template-columns:1fr;
        gap:8px;
        margin-top:22px;
    }

    .bm-date-card strong{
        order:-1;
        width:68px;
        height:68px;
        margin:0 auto;
        font-size:2.7rem;
    }

    .bm-message{
        font-size:0.92rem;
        line-height:1.65;
    }

    .bm-action-grid{
        top:6px;
        grid-template-columns:repeat(4, minmax(0, 1fr));
        gap:7px;
        margin-top:6px;
        margin-bottom:18px;
        padding:7px;
        border-radius:20px;
    }

    .bm-action{
        min-height:68px;
        border-radius:15px;
        font-size:0.58rem;
        letter-spacing:0.05em;
    }

    .bm-action-icon{
        width:29px;
        height:29px;
        border-radius:11px;
        font-size:1rem;
    }

    .bm-section{
        padding:22px 13px;
        border-radius:22px;
    }

    .bm-countdown{
        gap:7px;
    }

    .bm-countdown-item{
        min-height:82px;
        border-radius:15px;
    }

    .bm-countdown-item strong{
        font-size:1.9rem;
    }

    .bm-countdown-item span{
        font-size:0.58rem;
        letter-spacing:0.08em;
    }

    .bm-locations{
        grid-template-columns:1fr;
    }

    .bm-button{
        width:100%;
        max-width:320px;
    }
}

@media (prefers-reduced-motion: reduce){
    *,
    *::before,
    *::after{
        animation-duration:0.001ms !important;
        animation-iteration-count:1 !important;
        scroll-behavior:auto !important;
        transition-duration:0.001ms !important;
    }
}
