/* ============================================================
   inv.css — Estilos compartidos de invitaciones Luna v2
   Cada invitacion define su PALETA en un <style>:root{...}</style>
   Variables esperadas:
   --bg1 --bg2 --bg3 --panel --oro --oro-lt --oro-dk
   --accent --accent-lt --texto --tenue --gris --borde --glitter
   --glow1 (resplandor metal) --glow2 (resplandor acento)
============================================================ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--bg1);color:var(--texto);overflow-x:hidden}

#glitter{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.chispa{position:absolute;border-radius:50%;background:var(--glitter);box-shadow:0 0 6px 1px var(--glitter);animation:subir linear infinite;opacity:0}
@keyframes subir{0%{transform:translateY(100vh) scale(.6);opacity:0}10%{opacity:.9}50%{opacity:.5}90%{opacity:.2}100%{transform:translateY(-10vh) scale(1);opacity:0}}
.twinkle{position:absolute;color:var(--oro-lt);pointer-events:none;animation:tw 3s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:0;transform:scale(.4)}50%{opacity:.9;transform:scale(1)}}

.shimmer{background:linear-gradient(100deg,var(--oro-dk) 18%,var(--oro-lt) 40%,#fff 50%,var(--oro-lt) 60%,var(--oro-dk) 82%);
  background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;animation:brillo 5s linear infinite}
@keyframes brillo{to{background-position:-220% center}}

.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:60px 24px;position:relative;z-index:1;background:radial-gradient(120% 80% at 50% 0%,var(--bg2) 0%,var(--bg1) 55%,#000 130%)}
.hero::after{content:'✦';position:absolute;top:28px;right:30px;font-size:24px;color:var(--borde)}
.hero::before{content:'✦';position:absolute;top:28px;left:30px;font-size:24px;color:var(--borde)}
.foto-perfil-wrap{width:182px;height:182px;border-radius:50%;padding:5px;margin:0 auto 26px;position:relative;
  background:conic-gradient(from 0deg,var(--oro-dk),var(--oro-lt),var(--oro),var(--oro-lt),var(--oro-dk));
  box-shadow:0 0 38px var(--glow1),0 0 70px var(--glow2)}
.foto-perfil-wrap::after{content:'';position:absolute;inset:5px;border-radius:50%;border:1px solid rgba(255,255,255,.25)}
.foto-perfil{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;border:3px solid var(--bg1)}
.hero-pre{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--oro);margin-bottom:18px}
.linea-oro{width:90px;height:1px;margin:0 auto 22px;background:linear-gradient(90deg,transparent,var(--oro),transparent)}
.hero-nombre{font-family:'Cormorant Garamond',serif;font-size:clamp(50px,12vw,98px);font-weight:400;line-height:1.04;position:relative;z-index:1}
.hero-nombre .amp{display:block;font-style:italic;font-size:.5em;color:var(--accent-lt);margin:2px 0}
.hero-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(18px,4.2vw,26px);color:var(--accent-lt);margin-top:10px}
.hero-fecha-wrap{margin:34px auto 0;border:1px solid var(--borde);padding:20px 38px;display:inline-block;position:relative;background:rgba(0,0,0,.25);backdrop-filter:blur(2px)}
.hero-fecha-wrap::before,.hero-fecha-wrap::after{content:'✦';color:var(--oro);position:absolute;font-size:10px;left:50%;transform:translateX(-50%)}
.hero-fecha-wrap::before{top:-6px}.hero-fecha-wrap::after{bottom:-6px}
.hero-fecha{font-size:22px;font-weight:300;letter-spacing:.16em;color:var(--oro-lt)}
.hero-lugar{font-size:12px;color:var(--tenue);letter-spacing:.12em;margin-top:8px}
.scroll-hint{font-size:10px;color:var(--gris);letter-spacing:.24em;text-transform:uppercase;margin-top:42px;animation:pulso 2s infinite}
@keyframes pulso{0%,100%{opacity:.35}50%{opacity:1}}

.contenido{position:relative;z-index:1}
section{padding:74px 24px;max-width:680px;margin:0 auto}
section:nth-child(even){background:linear-gradient(180deg,transparent,var(--bg3),transparent)}
.titulo-seccion{text-align:center;margin-bottom:40px}
.titulo-seccion .ornamento{color:var(--oro);font-size:16px;letter-spacing:.4em;display:block;margin-bottom:10px}
.titulo-seccion h2{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,6.5vw,46px);font-weight:400}
.titulo-seccion p{color:var(--tenue);font-size:13px;margin-top:8px;letter-spacing:.05em;font-weight:300}
.frase{text-align:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(20px,5vw,30px);line-height:1.5;color:var(--oro-lt);font-weight:300}
.frase span{color:var(--accent-lt)}

.contador{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:360px;margin:0 auto}
.cnt-bloque{text-align:center;min-width:0;background:var(--panel);border:1px solid var(--borde);padding:16px 6px;border-radius:4px;box-shadow:0 0 22px rgba(255,255,255,.04) inset}
.cnt-num{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,11vw,52px);font-weight:400;line-height:1;display:block}
.cnt-lbl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gris);margin-top:7px;display:block}
.cnt-fin{font-size:22px;color:var(--oro-lt);font-family:'Cormorant Garamond',serif}

.programa-lista{list-style:none;position:relative}
.programa-lista::before{content:'';position:absolute;left:24px;top:6px;bottom:6px;width:1px;background:linear-gradient(180deg,transparent,var(--oro),transparent)}
.prog-item{display:flex;align-items:flex-start;gap:18px;padding:18px 0}
.prog-icono{width:50px;height:50px;border:1px solid var(--borde);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--panel);z-index:1}
.prog-icono svg{width:24px;height:24px;stroke:var(--oro);fill:none;stroke-width:1.5}
.prog-hora{min-width:52px;font-size:12px;color:var(--accent-lt);font-weight:500;padding-top:4px}
.prog-info h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:400;margin-bottom:2px}
.prog-info p{font-size:12px;color:var(--tenue);font-weight:300}

.ubica-card{display:flex;align-items:center;gap:16px;padding:18px;border:1px solid var(--borde);border-radius:4px;text-decoration:none;color:inherit;transition:.25s;margin-bottom:12px;background:var(--panel)}
.ubica-card:hover{border-color:var(--oro)}
.ubica-icon{width:52px;height:52px;border:1px solid var(--borde);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ubica-icon svg{width:24px;height:24px;stroke:var(--oro);fill:none;stroke-width:1.5}
.ubica-card h3{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;margin-bottom:2px}
.ubica-card p{font-size:12px;color:var(--tenue);font-weight:300}
.ubica-flecha{margin-left:auto;color:var(--oro)}

.padrinos{display:grid;gap:14px}
.padrino{text-align:center;padding:20px;border:1px solid var(--borde);background:var(--panel);border-radius:4px}
.padrino .rol{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-lt);margin-bottom:6px}
.padrino .nom{font-family:'Cormorant Garamond',serif;font-size:21px}

.dresscode-box{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.dc-item{padding:22px;border:1px solid var(--borde);background:var(--panel);text-align:center;border-radius:4px}
.dc-item svg{width:30px;height:30px;stroke:var(--oro);fill:none;stroke-width:1.4;margin-bottom:8px}
.dc-item h4{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:400;margin-bottom:4px}
.dc-item p{font-size:11px;color:var(--tenue);font-weight:300}
.dc-note{text-align:center;font-size:12px;color:var(--tenue);margin-top:8px}
.color-chip{display:inline-block;width:26px;height:26px;border-radius:50%;margin:0 4px;border:2px solid rgba(255,255,255,.25);vertical-align:middle}

.pases-badge{text-align:center;padding:32px 24px;border:1px solid var(--borde);background:var(--panel);border-radius:6px;box-shadow:0 0 26px rgba(0,0,0,.2) inset}
.pases-num{font-family:'Cormorant Garamond',serif;font-size:84px;line-height:1;display:block}
.pases-lbl{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--tenue);margin-top:8px;display:block}

.regalo-box{text-align:center;padding:28px;border:1px solid var(--borde);background:var(--panel);border-radius:4px}
.regalo-box svg{width:34px;height:34px;stroke:var(--oro);fill:none;stroke-width:1.4;margin-bottom:12px}
.regalo-box p{font-size:13px;color:var(--tenue);line-height:1.7;font-weight:300}
.regalo-box+.regalo-box{margin-top:14px}
.regalo-tit{font-family:'Cormorant Garamond',serif;font-size:23px;font-weight:400;margin-bottom:8px;color:var(--oro-lt)}
.regalo-link{display:inline-block;margin-top:16px;padding:11px 22px;border:1px solid var(--oro);border-radius:4px;color:var(--oro-lt);text-decoration:none;font-size:11px;letter-spacing:.1em;text-transform:uppercase;transition:.25s}
.regalo-link:hover{background:rgba(255,255,255,.08)}
.transfer{margin-top:22px;text-align:left;border:1px solid var(--borde);border-radius:6px;overflow:hidden;background:rgba(0,0,0,.20)}
.tr-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--borde)}
.tr-row:last-of-type{border-bottom:none}
.tr-lbl{color:var(--gris);letter-spacing:.08em;text-transform:uppercase;font-size:10px;flex-shrink:0}
.tr-val{color:var(--texto);font-weight:500;font-size:13px;text-align:right;word-break:break-all}
.copy-btn{width:100%;padding:13px;border:none;border-top:1px solid var(--borde);cursor:pointer;
  background:linear-gradient(100deg,var(--oro-dk),var(--oro-lt),var(--oro-dk));background-size:200% auto;
  color:var(--bg1);font-family:'Montserrat',sans-serif;font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;animation:brillo 5s linear infinite}
.copy-btn:active{transform:scale(.98)}

.upload-card{text-align:center;padding:34px 24px;border:1px dashed var(--oro);background:var(--panel);border-radius:8px}
.upload-card svg{width:40px;height:40px;stroke:var(--oro);fill:none;stroke-width:1.4;margin-bottom:14px}
.upload-card p{font-size:13px;color:var(--tenue);line-height:1.7;font-weight:300;margin-bottom:20px}
.upload-btn{display:inline-block;padding:15px 30px;border:none;cursor:pointer;border-radius:4px;
  background:linear-gradient(100deg,var(--oro-dk),var(--oro-lt),var(--oro-dk));background-size:200% auto;
  color:var(--bg1);font-family:'Montserrat',sans-serif;font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;animation:brillo 5s linear infinite;box-shadow:0 6px 20px var(--glow1)}
.upload-btn:active{transform:scale(.97)}
#uploadStatus{margin-top:16px;font-size:13px;color:var(--oro-lt);min-height:20px}

.wa-btn{display:flex;align-items:center;gap:16px;padding:20px 24px;border-radius:4px;background:rgba(37,211,102,.10);border:1px solid rgba(37,211,102,.35);text-decoration:none;color:inherit;transition:.25s}
.wa-btn:hover{background:rgba(37,211,102,.18)}
.wa-btn svg{width:28px;height:28px;fill:#4ee07f;flex-shrink:0}
.wa-btn h3{color:#4ee07f;font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:400;margin-bottom:2px}
.wa-btn p{font-size:12px;color:var(--tenue);font-weight:300}
.wa-btn .arrow{margin-left:auto;color:#4ee07f}

.div{text-align:center;color:var(--borde);letter-spacing:14px;font-size:10px;padding:6px 0;position:relative;z-index:1}
footer{text-align:center;padding:50px 24px 64px;color:var(--tenue);font-size:12px;position:relative;z-index:1;border-top:1px solid var(--borde);background:var(--bg3)}
footer .logo{font-family:'Cormorant Garamond',serif;font-size:30px;margin-bottom:8px;display:block;font-style:italic}
footer .firma{margin-top:6px;font-size:11px;color:var(--gris)}
footer .credito{margin-top:20px;font-size:12px;color:var(--gris)}
footer .credito a{color:var(--oro);text-decoration:none;font-weight:500;border-bottom:1px solid var(--borde)}
footer .credito a:hover{color:var(--oro-lt)}

@media(max-width:480px){
  .dresscode-box{grid-template-columns:1fr}
  .contador{gap:6px}.cnt-bloque{padding:14px 4px}.cnt-lbl{font-size:10.5px;letter-spacing:.05em}
  .titulo-seccion p{font-size:14px}.hero-lugar{font-size:13px}.prog-info h3{font-size:18px}.prog-info p{font-size:13px}
  .ubica-card p{font-size:13px}.dc-item p{font-size:12.5px}.regalo-box p{font-size:14px}.tr-lbl{font-size:11px}.tr-val{font-size:13.5px}.frase{font-size:23px}
}
