:root{--color-fondo:#ffebee;--color-trazo-corazon:#ff4d6d}.splash-escena{background-color:var(--color-fondo);z-index:9999;justify-content:center;align-items:center;width:100vw;height:100vh;font-family:Quicksand,sans-serif;display:flex;position:fixed;top:0;left:0;overflow:hidden}.corazon-pulsante{transform-origin:50%;opacity:.3;animation-name:pulsoCorazon;animation-timing-function:ease-in-out;animation-iteration-count:infinite;position:absolute}@keyframes pulsoCorazon{0%{opacity:.35;transform:scale(1)}50%{opacity:.8;transform:scale(1.25)}to{opacity:.35;transform:scale(1)}}.splash-vidrio{-webkit-backdrop-filter:blur(8px);z-index:1;background:#ffebee66;width:100%;height:100%;position:absolute}.contenedor-mensaje{z-index:2;opacity:0;flex-direction:column;align-items:center;gap:30px;transition:opacity 1.5s ease-out,transform 1.5s ease-out;display:flex;position:relative;transform:translateY(30px)}.contenedor-mensaje.visible{opacity:1;transform:translateY(0)}.mensaje-aniversario{color:var(--color-trazo-corazon);text-shadow:2px 2px 8px #ff4d6d33;text-align:center;margin:0;font-family:Fredoka,sans-serif;font-size:4rem;font-weight:700}.btn-entrar{color:#fff;cursor:pointer;letter-spacing:1px;background:linear-gradient(135deg,#ff4d6d 0%,#ff758c 100%);border:none;border-radius:50px;padding:15px 40px;font-family:Quicksand,sans-serif;font-size:1.3rem;font-weight:700;transition:all .3s;box-shadow:0 10px 20px #ff4d6d4d}.btn-entrar:hover{background:linear-gradient(135deg,#ff758c 0%,#ff8fa3 100%);transform:translateY(-5px)scale(1.05);box-shadow:0 15px 25px #ff4d6d80}@media (width<=768px){.mensaje-aniversario{padding:0 20px;font-size:3rem}.btn-entrar{padding:12px 30px;font-size:1.1rem}}:root{--rosa-principal:#ff9a9e;--celeste-detalle:#a1c4fd;--texto-oscuro:#4f3c40;--cristal-fondo:#ffffffd9;--cristal-borde:#ffffff80}body{min-height:100vh;color:var(--texto-oscuro);background-image:url(/assets/fondo-48tzEe-3.png);background-repeat:repeat;background-size:400px;background-attachment:fixed;justify-content:center;align-items:center;margin:0;font-family:Quicksand,sans-serif;display:flex;overflow-x:hidden}.app-container{background:var(--cristal-fondo);-webkit-backdrop-filter:blur(15px);border:1px solid var(--cristal-borde);text-align:center;border-radius:25px;width:95%;max-width:900px;padding:40px;box-shadow:0 8px 32px #ff9a9e4d}.titulo{color:#ff4d6d;background:linear-gradient(135deg,#ff4d6d 0%,#ff758c 100%);-webkit-text-fill-color:transparent;text-shadow:2px 4px 10px #ff4d6d1a;letter-spacing:0;-webkit-background-clip:text;margin-top:0;margin-bottom:15px;font-family:Fredoka,sans-serif;font-size:3.2rem;font-weight:700}.subtitulo{color:#6c4f53;letter-spacing:.5px;margin-top:-15px;margin-bottom:40px;font-family:Quicksand,sans-serif;font-size:1.25rem;font-weight:500}.sin-fotos{color:#8a6c70;margin:50px 0;font-size:1.2rem;font-weight:500}.label-usuario{color:#ff4d6d;letter-spacing:.5px;margin-bottom:8px;font-size:14px;font-weight:700;display:block}.carrusel-3d-escena{perspective:1000px;justify-content:center;align-items:center;width:100%;height:360px;margin-bottom:30px;display:flex;position:relative}.foto-tarjeta{border:1px solid var(--cristal-borde);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff4d;border-radius:15px;padding:10px;transition:all .5s ease-in-out;position:absolute;overflow:hidden;box-shadow:0 8px 20px #0000001a}.marco-imagen-3d{object-fit:cover;border-radius:10px;width:100%;height:100%;display:block}.foto-frente{z-index:10;opacity:1;width:480px;height:320px;transform:translateZ(0)scale(1)}.foto-detras{z-index:5;opacity:.6;width:480px;height:320px}.foto-izquierda{transform:translate(-55%)translateZ(-100px)scale(.7)}.foto-derecha{transform:translate(55%)translateZ(-100px)scale(.7)}.btn-flecha{border:1px solid var(--cristal-borde);width:60px;height:60px;color:var(--texto-oscuro);cursor:pointer;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:20;background:#ffffff80;border-radius:50%;justify-content:center;align-items:center;font-size:24px;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.btn-flecha:hover{box-shadow:0 0 15px var(--celeste-detalle);background:#ffffffe6}.btn-flecha-izq{left:0}.btn-flecha-der{right:0}.panel-controles{-webkit-backdrop-filter:blur(10px);opacity:80;background:#ffffff73;border:1px solid #fff9;border-radius:20px;flex-direction:column;align-items:center;gap:25px;margin-top:35px;padding:25px;animation:.8s cubic-bezier(.16,1,.3,1) .3s forwards fadeInSlide;display:flex;box-shadow:0 8px 24px #ff9a9e1a}.seccion-usuario{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.grupo-acciones{flex-flow:wrap;justify-content:center;gap:15px;width:100%;display:flex}.btn-accion{box-sizing:border-box;color:#fff;text-transform:uppercase;letter-spacing:.8px;cursor:pointer;-webkit-user-select:none;user-select:none;text-align:center;border:none;border-radius:24px;justify-content:center;align-items:center;width:210px;height:48px;font-family:Quicksand,sans-serif;font-size:14px;font-weight:700;text-decoration:none;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:inline-flex;position:relative;overflow:hidden}.btn-accion:after{content:"";pointer-events:none;background:linear-gradient(90deg,#fff0 0%,#ffffff59 50%,#fff0 100%);width:25%;height:100%;transition:all .75s;position:absolute;top:0;left:-50%;transform:skew(-25deg)}.btn-accion:hover:after{left:125%}.btn-accion:hover{transform:translateY(-4px)scale(1.02)}.btn-accion:active{transform:translateY(-1px)scale(.98)}.btn-accion:disabled{opacity:.4;cursor:not-allowed;pointer-events:none;box-shadow:none!important;transform:none!important}.btn-mostrar{background:linear-gradient(135deg,#a18cd1 0%,#fbc2eb 100%);box-shadow:0 4px 15px #a18cd159}.btn-mostrar:hover{box-shadow:0 8px 25px #a18cd18c}.btn-agregar{background:linear-gradient(135deg,#ff9a9e 0%,#fecfef 100%);box-shadow:0 4px 15px #ff9a9e59}.btn-agregar:hover{box-shadow:0 8px 25px #ff9a9e8c}.btn-eliminar{background:linear-gradient(135deg,#ff6b6b 0%,#ff8787 100%);box-shadow:0 4px 15px #ff6b6b4d}.btn-eliminar:hover{box-shadow:0 8px 25px #ff6b6b80}.foto-oculta{opacity:0;z-index:1;pointer-events:none;transform:translate(0)translateZ(-200px)scale(.5)}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}.app-container{animation:6s ease-in-out infinite float}.titulo{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards fadeInSlide}.subtitulo{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) .1s forwards fadeInSlide}.carrusel-3d-escena{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) .2s forwards fadeInSlide}.alerta-flotante{-webkit-backdrop-filter:blur(10px);color:#5e4044;z-index:9999;background:#fffffff2;border:1px solid #ff4d6d40;border-radius:20px;padding:12px 25px;font-family:Quicksand,sans-serif;font-size:15px;font-weight:700;animation:3s ease-in-out forwards alertFadeInOut;position:fixed;bottom:30px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #ff758c40}@keyframes alertFadeInOut{0%{opacity:0;transform:translate(-50%,20px)}15%{opacity:1;transform:translate(-50%)}85%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-20px)}}.input-usuario{color:#5e4044;text-align:center;box-sizing:border-box;background:#ffffff8c;border:1px solid #ff4d6d33;border-radius:12px;outline:none;width:100%;max-width:280px;padding:10px 15px;font-family:Quicksand,sans-serif;font-size:16px;font-weight:600;transition:all .3s;box-shadow:inset 0 2px 4px #00000005}.input-usuario::placeholder{color:#5e404466}.input-usuario:focus{background:#fffffff2;border-color:#ff4d6d;box-shadow:0 0 15px #ff4d6d40,inset 0 2px 4px #00000003}@media (width<=768px){.app-container{width:92%;padding:25px 15px;animation:none}.titulo{margin-bottom:8px;font-size:2.8rem}.subtitulo{margin-bottom:25px;font-size:1.05rem}.carrusel-3d-escena{height:260px;margin-bottom:20px}.foto-frente,.foto-detras{aspect-ratio:3/2;width:80vw;height:auto}.foto-izquierda{transform:translate(-30%)translateZ(-150px)scale(.65)}.foto-derecha{transform:translate(30%)translateZ(-150px)scale(.65)}.btn-flecha{width:48px;height:48px;font-size:18px}.panel-controles{gap:20px;margin-top:25px;padding:20px 15px}.grupo-acciones{flex-direction:column;align-items:center;gap:12px}.btn-accion{width:100%;max-width:280px;height:48px}}.auth-escena{box-sizing:border-box;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{-webkit-backdrop-filter:blur(15px);text-align:center;box-sizing:border-box;background:#ffffffbf;border:1px solid #fff9;border-radius:24px;width:100%;max-width:400px;padding:40px 30px;animation:.6s cubic-bezier(.16,1,.3,1) forwards fadeInSlide;box-shadow:0 12px 40px #ff9a9e40}.auth-logo{background:linear-gradient(135deg,#ff4d6d 0%,#ff758c 100%);-webkit-text-fill-color:transparent;text-shadow:2px 4px 10px #ff4d6d14;-webkit-background-clip:text;margin-top:0;margin-bottom:5px;font-family:Fredoka,sans-serif;font-size:2.6rem;font-weight:700}.auth-subtitulo{color:#6c4f53;margin-top:0;margin-bottom:25px;font-family:Quicksand,sans-serif;font-size:1.05rem;font-weight:500;line-height:1.4}.auth-form{flex-direction:column;gap:16px;width:100%;display:flex}.auth-campo{width:100%}.auth-input{color:#5e4044;box-sizing:border-box;background:#ffffff8c;border:1px solid #ff4d6d2e;border-radius:14px;outline:none;width:100%;padding:12px 18px;font-family:Quicksand,sans-serif;font-size:15px;font-weight:600;transition:all .3s;box-shadow:inset 0 2px 4px #00000003}.auth-input::placeholder{color:#5e404466}.auth-input:focus{background:#fffffff2;border-color:#ff4d6d;box-shadow:0 0 12px #ff4d6d33,inset 0 2px 4px #00000003}.btn-auth{cursor:pointer;width:100%;margin-top:8px}.auth-alerta{text-align:left;border-radius:14px;margin-bottom:20px;padding:12px 16px;font-family:Quicksand,sans-serif;font-size:14px;font-weight:600;line-height:1.4}.auth-alerta.error{color:#d62246;background:#ff4d6d1a;border:1px solid #ff4d6d40}.auth-alerta.success{color:#27ae60;background:#2ecc711a;border:1px solid #2ecc7140}.auth-toggle{color:#7d5e62;margin-top:25px;font-family:Quicksand,sans-serif;font-size:14px}.btn-toggle-link{color:#ff4d6d;cursor:pointer;background:0 0;border:none;padding:0;font-family:Quicksand,sans-serif;font-size:14px;font-weight:700;transition:color .2s}.btn-toggle-link:hover{color:#ff758c;text-decoration:underline}.btn-logout{color:#7d5e62;cursor:pointer;-webkit-backdrop-filter:blur(5px);z-index:100;background:#ffffff73;border:1px solid #fff9;border-radius:12px;padding:6px 14px;font-family:Quicksand,sans-serif;font-size:13px;font-weight:700;transition:all .3s}.btn-logout:hover{color:#d62246;background:#ff4d6d1a;border-color:#ff4d6d40;box-shadow:0 4px 12px #ff4d6d1a}.cabecera-app{z-index:100;gap:10px;display:flex;position:absolute;top:20px;right:20px}.btn-ajustes{color:#7d5e62;cursor:pointer;-webkit-backdrop-filter:blur(5px);background:#ffffff73;border:1px solid #fff9;border-radius:12px;padding:6px 14px;font-family:Quicksand,sans-serif;font-size:13px;font-weight:700;transition:all .3s}.btn-ajustes:hover{color:#ff4d6d;background:#ffffffd9;border-color:#ff4d6d40;box-shadow:0 4px 12px #ff4d6d1a}.modal-overlay{-webkit-backdrop-filter:blur(10px);z-index:99999;box-sizing:border-box;background:#00000059;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.modal-card{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#ff4d6d4d transparent;background:#ffffffb3;border:1px solid #ffffff8c;border-radius:24px;width:100%;max-width:520px;max-height:85vh;padding:30px;font-family:Quicksand,sans-serif;position:relative;overflow-y:auto;box-shadow:0 20px 50px #0000001a}.modal-card::-webkit-scrollbar{width:6px}.modal-card::-webkit-scrollbar-thumb{background-color:#ff4d6d4d;border-radius:10px}.btn-close-modal{color:#7d5e62;cursor:pointer;background:#fff9;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:15px;right:15px}.btn-close-modal:hover{color:#fff;background:#ff4d6d}.modal-title{color:#ff4d6d;text-align:center;margin-top:0;margin-bottom:20px;font-family:Fredoka,sans-serif;font-size:1.8rem}.modal-seccion{text-align:left;background:#ffffff73;border:1px solid #fff6;border-radius:16px;margin-bottom:18px;padding:18px;box-shadow:0 4px 12px #00000005}.modal-seccion h3{color:#ff4d6d;margin-top:0;margin-bottom:8px;font-family:Fredoka,sans-serif;font-size:1.2rem}.modal-explicacion{color:#7d5e62;margin-top:0;margin-bottom:12px;font-size:13px;line-height:1.4}.modal-form-inline{gap:10px;width:100%;display:flex}.modal-input{color:#5e4044;background:#ffffffb3;border:1px solid #ff4d6d33;border-radius:12px;outline:none;flex:1;padding:10px 14px;font-family:Quicksand,sans-serif;font-size:14px;font-weight:600;transition:all .3s}.modal-input:focus{background:#fff;border-color:#ff4d6d;box-shadow:0 0 8px #ff4d6d26}.btn-modal{border-radius:12px;flex-shrink:0;height:auto;padding:0 20px;font-size:14px}.modal-mini-alerta{border-radius:10px;margin-top:10px;padding:8px 12px;font-size:13px;font-weight:600}.modal-mini-alerta.success{color:#27ae60;background:#2ecc711a}.modal-mini-alerta.error{color:#c0392b;background:#e74c3c1a}.galerias-list{flex-direction:column;gap:8px;display:flex}.galeria-item{cursor:pointer;background:#fff9;border:1px solid #fffc;border-radius:12px;justify-content:space-between;align-items:center;padding:10px 14px;transition:all .3s;display:flex}.galeria-item:hover{background:#ffffffe6;transform:translateY(-2px);box-shadow:0 4px 10px #ff4d6d14}.galeria-item.activa{background:linear-gradient(135deg,#ff4d6d1a 0%,#ff758c1a 100%);border-color:#ff4d6d}.galeria-info{align-items:center;gap:8px;display:flex}.galeria-badge{color:#ff4d6d;font-size:14px}.galeria-name{color:#5e4044;font-weight:700}.galeria-owner{color:#9c8286;margin-left:5px;font-size:11px}.btn-leave-galeria{color:#e74c3c;cursor:pointer;background:0 0;border:1px solid #e74c3c66;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:700;transition:all .2s}.btn-leave-galeria:hover{color:#fff;background:#e74c3c}.btn-delete-galeria{color:#e74c3c;cursor:pointer;background:#e74c3c1a;border:1px solid #e74c3c;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:700;transition:all .2s}.btn-delete-galeria:hover{color:#fff;background:#e74c3c;box-shadow:0 4px 12px #e74c3c4d}.seccion-galeria-activa{color:#5e4044;-webkit-backdrop-filter:blur(5px);background:#ffffff73;border:1px solid #ff4d6d40;border-radius:12px;align-items:center;gap:8px;margin-bottom:12px;padding:8px 16px;font-size:13px;display:flex}.corazon-indicador{animation:1.6s infinite alternate pulseIndicador;display:inline-block}@keyframes pulseIndicador{0%{transform:scale(1)}to{transform:scale(1.15)}}.solicitudes-list{flex-direction:column;gap:8px;display:flex}.solicitud-item{background:#fff9;border:1px solid #ffffffb3;border-radius:12px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.solicitud-detalles{color:#5e4044;font-size:13px}.solicitud-acciones{gap:6px;display:flex}.btn-sol-aprobar,.btn-sol-rechazar{cursor:pointer;border:none;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;transition:all .2s}.btn-sol-aprobar{color:#fff;background:#2ecc71}.btn-sol-aprobar:hover{background:#27ae60;box-shadow:0 2px 8px #2ecc714d}.btn-sol-rechazar{color:#fff;background:#e74c3c}.btn-sol-rechazar:hover{background:#c0392b;box-shadow:0 2px 8px #e74c3c4d}@media (width<=768px){.cabecera-app{gap:8px;position:absolute;top:15px;right:15px}.btn-logout{position:static}.btn-ajustes,.btn-logout{padding:5px 10px;font-size:12px}.modal-card{max-height:90vh;padding:20px}.modal-title{font-size:1.5rem}.modal-form-inline{flex-direction:column;gap:8px}.btn-modal{width:100%;height:40px}}.alerta-vinculacion-banner{cursor:pointer;-webkit-backdrop-filter:blur(10px);color:#5e4044;box-sizing:border-box;background:#ffffff73;border:1px solid #ff4d6d59;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;width:90%;max-width:580px;margin:15px auto 20px;padding:14px 20px;font-family:Quicksand,sans-serif;font-size:14px;font-weight:700;transition:all .3s;animation:3s ease-in-out infinite alternate bannerFloat;display:flex;box-shadow:0 8px 24px #ff4d6d1f}.alerta-vinculacion-banner:hover{background:#ffffffd9;border-color:#ff4d6d;transform:translateY(-2px);box-shadow:0 12px 30px #ff4d6d38}.corazon-animado-mini{font-size:18px;animation:1.2s infinite miniHeartBeat;display:inline-block}.flecha-banner{color:#ff4d6d;font-size:18px;transition:transform .2s}.alerta-vinculacion-banner:hover .flecha-banner{transform:translate(4px)}@keyframes bannerFloat{0%{transform:translateY(0)}to{transform:translateY(-4px)}}@keyframes miniHeartBeat{0%{transform:scale(1)}20%{transform:scale(1.15)}40%{transform:scale(1)}60%{transform:scale(1.15)}80%{transform:scale(1)}to{transform:scale(1)}}.resaltado-pulsar{border:2px solid #ff4d6d!important;animation:1.5s infinite alternate pulseGlow!important}@keyframes pulseGlow{0%{background:#ffffff73;box-shadow:0 0 8px #ff4d6d33}to{background:#ff4d6d0a;box-shadow:0 0 25px #ff4d6d8c}}
