@import url('https://fonts.googleapis.com/css2?family=Jost:wght@200;300;400;500&display=swap');

/* ============ Base / Tema Moderno Minimalista ============ */
:root{
  --fundo:#fbfbf9; --texto:#161616; --suave:#7a7a78;
  --acento:#1a1a1a; --linha:#e6e5e1; --card:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Jost",-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  background:var(--fundo) url('padrao.svg') repeat;
  background-size:300px 300px;
  color:var(--texto);
  font-size:17px; line-height:1.8; font-weight:300; overflow-x:hidden;
}
h1,h2,h3{font-family:"Jost",sans-serif;font-weight:400;letter-spacing:3px;text-transform:uppercase}
.script{font-family:"Jost",sans-serif;font-weight:300;letter-spacing:5px;text-transform:uppercase;color:var(--texto);line-height:1.1}
a{color:var(--acento)}
img{max-width:100%;display:block}

/* ============ Utilidades ============ */
.wrap{max-width:820px;margin:0 auto;padding:0 24px}
.center{text-align:center}
.dourado{color:var(--texto)}
.divisor{display:flex;align-items:center;justify-content:center;gap:16px;margin:30px 0;color:#c7c6bf;font-size:11px}
.divisor::before,.divisor::after{content:"";height:1px;width:60px;background:var(--linha)}
.fade{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s ease}
.fade.show{opacity:1;transform:none}

/* ============ Botões ============ */
.btn{
  display:inline-block;border:1px solid var(--acento);
  background:transparent;color:var(--acento);
  font-family:"Jost",sans-serif;font-size:13px;font-weight:400;letter-spacing:2px;
  text-transform:uppercase;padding:14px 32px;border-radius:0;cursor:pointer;
  text-decoration:none;transition:.3s;
}
.btn:hover{background:var(--acento);color:#fff}
.btn-cheio{background:var(--acento);color:#fff}
.btn-cheio:hover{background:#000}

/* ============ Capa ============ */
.capa{min-height:100vh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;position:relative;padding:60px 24px;background:transparent}
.capa .selo{font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--suave);margin-bottom:14px}
.capa .nomes{font-size:clamp(40px,9vw,86px);font-weight:200;letter-spacing:10px;margin:6px 0}
/* Efeito reutilizável: nome que flutua e brilha */
.nome-anim,.capa .nomes{
  color:transparent;
  background:linear-gradient(105deg,#1a1a1a 0%,#1a1a1a 40%,#8f8f8f 48%,#e2e2e2 50%,#8f8f8f 52%,#1a1a1a 60%,#1a1a1a 100%);
  background-size:280% 100%;background-position:140% 0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:nomesFlutua 7s ease-in-out infinite, nomesBrilho 6.5s ease-in-out infinite;
  will-change:transform,background-position;
}
.capa .e{display:block;font-size:.4em;margin:.1em 0;color:var(--suave)}
.capa .saudacao{font-size:clamp(16px,3.4vw,20px);margin-top:22px;color:var(--suave);letter-spacing:1px}
.capa .saudacao .script{font-size:1.7em;color:var(--texto);display:inline-block;margin-top:8px}
.capa .data-capa{margin-top:24px;font-size:14px;letter-spacing:4px;text-transform:uppercase;color:var(--texto)}
.scroll-ind{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  color:var(--suave);font-size:12px;letter-spacing:2px;text-transform:uppercase;animation:flut 2s infinite}
@keyframes flut{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,6px)}}
@keyframes nomesFlutua{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes nomesBrilho{0%{background-position:140% 0}55%,100%{background-position:-40% 0}}

/* ============ Seções ============ */
section{padding:74px 0}
section .titulo{font-size:clamp(22px,4.5vw,32px);text-align:center;margin-bottom:10px;letter-spacing:4px}
section .sub{text-align:center;color:var(--suave);text-transform:uppercase;letter-spacing:2px;font-size:13px;margin-bottom:34px}
.texto-convite{font-size:clamp(17px,2.6vw,21px);text-align:center;max-width:600px;margin:0 auto;color:#3a3a38;font-weight:300;line-height:1.9}

/* ============ Contagem regressiva (animada / tech) ============ */
.contagem{display:flex;justify-content:center;align-items:stretch;gap:10px;flex-wrap:wrap;margin-top:14px}
.contagem .bloco{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--linha);
  border-top:2px solid var(--linha);border-radius:0;min-width:96px;padding:22px 10px 18px}
.contagem .bloco::after{content:"";position:absolute;top:-2px;left:0;height:2px;width:100%;
  background:linear-gradient(90deg,transparent 0%,var(--texto) 50%,transparent 100%);
  background-size:220% 100%;background-position:150% 0;animation:cdScan 3s linear infinite;opacity:.5}
.contagem .bloco[data-k="seg"]::after{animation-duration:1.6s;opacity:.85}
.contagem .num{font-family:"Jost",sans-serif;font-weight:200;font-size:42px;color:var(--texto);
  font-variant-numeric:tabular-nums;letter-spacing:1px;line-height:1}
.contagem .bloco.tick .num{animation:cdTick .5s cubic-bezier(.2,.75,.2,1)}
.contagem .rot{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--suave);margin-top:8px}
.cd-sep{display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:200;
  color:var(--suave);padding:0 2px;animation:cdBlink 1s steps(1,end) infinite}
@keyframes cdScan{0%{background-position:150% 0}100%{background-position:-70% 0}}
@keyframes cdTick{0%{transform:translateY(-65%);opacity:0;filter:blur(1.5px)}60%{filter:blur(0)}100%{transform:none;opacity:1}}
@keyframes cdBlink{0%,50%{opacity:.85}51%,100%{opacity:.15}}

/* ============ Ilustração dos noivos (capa) ============ */
.noivos-ilustra{display:block;width:min(230px,54vw);height:auto;margin:34px auto 4px;
  opacity:0;animation:noivosEntra 1.4s ease .3s forwards, noivosFlutua 6s ease-in-out 1.7s infinite}
@keyframes noivosEntra{0%{opacity:0;transform:translateY(18px)}100%{opacity:.92;transform:none}}
@keyframes noivosFlutua{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ============ Alerta "PENETRA" (nome não encontrado) ============ */
.alerta-penetra{
  position:relative;overflow:hidden;margin-top:18px;text-align:center;background:#fff;
  border:2px solid #e0554e;border-radius:8px;padding:26px 20px 22px;transform-origin:center;
  box-shadow:0 8px 30px rgba(224,85,78,.15);
  animation:apPop .55s cubic-bezier(.2,1.35,.4,1), apShake .5s .5s ease-in-out, apSiren 1.1s .55s ease-in-out infinite;
}
.ap-sirene{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(240,160,0,.14),transparent);
  background-size:200% 100%;animation:apScan 1.4s linear infinite}
.ap-icone{position:relative;font-size:48px;line-height:1;display:inline-block;
  animation:apWiggle 1s ease-in-out infinite}
.ap-titulo{position:relative;font-size:18px;letter-spacing:.5px;text-transform:uppercase;font-weight:500;
  margin:10px 0 12px;color:#2b2b29}
.ap-boom{display:inline-block;color:#e0554e;font-weight:700;text-shadow:0 0 1px rgba(224,85,78,.4);
  animation:apBoom .7s ease-in-out infinite}
.ap-texto{position:relative;font-size:15px;color:#55554f;font-weight:300;line-height:1.7;margin-top:8px;max-width:420px;margin-left:auto;margin-right:auto}
@keyframes apPop{0%{transform:scale(.3) rotate(-7deg);opacity:0}70%{transform:scale(1.07) rotate(1deg)}100%{transform:scale(1);opacity:1}}
@keyframes apShake{0%,100%{transform:translateX(0)}15%{transform:translateX(-10px)}30%{transform:translateX(9px)}45%{transform:translateX(-7px)}60%{transform:translateX(6px)}75%{transform:translateX(-4px)}}
@keyframes apSiren{0%,100%{box-shadow:0 8px 30px rgba(224,85,78,.15);border-color:#e0554e}50%{box-shadow:0 0 26px 3px rgba(240,160,0,.45);border-color:#f0a000}}
@keyframes apScan{0%{background-position:150% 0}100%{background-position:-50% 0}}
@keyframes apWiggle{0%,100%{transform:rotate(-12deg) scale(1)}50%{transform:rotate(12deg) scale(1.12)}}
@keyframes apBoom{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}

/* ============ Detalhes / cards ============ */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:14px}
.card{background:var(--card);border:1px solid var(--linha);border-radius:0;padding:30px;text-align:center}
.card .ic{font-size:26px;margin-bottom:12px;filter:grayscale(30%)}
.card h3{font-size:17px;margin-bottom:8px;letter-spacing:2px}
.card p{color:#55554f;font-weight:300}
@media(max-width:640px){.cards{grid-template-columns:1fr}}

/* ============ Galeria ============ */
.galeria{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}
.galeria img{aspect-ratio:3/4;object-fit:cover;border-radius:0;filter:grayscale(15%)}
@media(max-width:640px){.galeria{grid-template-columns:1fr 1fr}}

/* ============ PIX ============ */
.pix-box{background:var(--card);border:1px solid var(--linha);border-radius:0;max-width:520px;margin:20px auto 0;padding:32px;text-align:center}
.pix-chave{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:16px}
.pix-chave code{background:#f2f1ec;padding:11px 14px;border-radius:0;font-size:15px;word-break:break-all;font-family:"Jost",monospace}

/* ============ RSVP ============ */
.rsvp-box{background:var(--card);border:1px solid var(--linha);border-radius:0;max-width:560px;margin:20px auto 0;padding:36px}
.rsvp-box label{display:block;text-align:left;margin:18px 0 6px;letter-spacing:1px;font-size:13px;text-transform:uppercase;color:var(--suave)}
.rsvp-box select,.rsvp-box textarea,.rsvp-box input{
  width:100%;padding:13px 14px;border:1px solid var(--linha);border-radius:0;
  font-family:inherit;font-size:16px;background:#fff;color:var(--texto);font-weight:300}
.rsvp-box select:focus,.rsvp-box textarea:focus,.rsvp-box input:focus{outline:none;border-color:var(--acento)}
.rsvp-opcoes{display:flex;gap:12px;margin-top:8px}
.rsvp-opcoes .btn{flex:1}
.rsvp-opcoes .btn.ativo{background:var(--acento);color:#fff}
.msg-ok{text-align:center;color:var(--texto);font-size:18px;padding:10px;letter-spacing:.5px;line-height:1.7}

/* ============ Rodapé ============ */
footer{padding:64px 24px;text-align:center;border-top:1px solid var(--linha)}
footer .script{font-size:30px;letter-spacing:8px}
footer .hash{letter-spacing:3px;color:var(--suave);text-transform:uppercase;font-size:13px;margin-top:12px}

/* ============ Música ============ */
.btn-musica{position:fixed;top:18px;right:18px;z-index:50;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--linha);background:#ffffffee;color:var(--texto);cursor:pointer;font-size:16px}

/* ============ Loader / erro ============ */
.tela-central{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px}
.tela-central .script{font-size:34px;margin-bottom:14px;letter-spacing:6px}
