.hero{background:linear-gradient(135deg, var(--celeste-light) 0%, var(--celeste-primary) 50%, var(--celeste-dark) 100%);background-image:url(/images/hero-background.jpg);background-position:50% 40%;background-repeat:no-repeat;background-size:cover;background-attachment:scroll;justify-content:center;align-items:flex-end;height:100vh;display:flex;position:relative;overflow:hidden}@media (width>=769px){.hero{background-image:url(/images/hero-background-desktop.jpg);background-position:50%}}@media (width<=1024px) and (width>=769px){.hero{background-position:50% 35%}}@media (width<=768px){.hero{background-image:url(/images/hero-background.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;background-attachment:scroll;min-height:100vh}}.hero-overlay{z-index:1;background:linear-gradient(#0003 0%,#0000004d 50%,#00000080 100%);width:100%;height:100%;position:absolute;top:0;left:0}.hero-content{z-index:2;text-align:center;color:var(--white);width:100%;max-width:1000px;padding:4rem 2rem 8rem;position:relative}.hero-crown{margin-bottom:2rem}.crown-icon{color:var(--gold);filter:drop-shadow(0 4px 8px #0000004d);font-size:4rem}.hero-title{letter-spacing:3px;text-shadow:3px 3px 6px #0000004d;margin-bottom:1rem;font-size:5rem;font-weight:700}.hero-subtitle{letter-spacing:8px;margin-bottom:1.5rem;font-size:1.8rem;font-weight:300}.hero-date{letter-spacing:4px;margin-bottom:3rem;font-size:1.5rem;font-weight:400}.countdown{margin-top:3rem}.countdown h3{letter-spacing:2px;margin-bottom:1.5rem;font-size:1.5rem;font-weight:400}.countdown-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:15px;min-width:100px;padding:1.5rem 2rem;transition:transform .3s,box-shadow .3s;box-shadow:0 8px 32px #0000001a}.countdown-box:hover{transform:translateY(-5px);box-shadow:0 12px 40px #0003}.countdown-number{font-size:2.5rem;font-weight:700;font-family:var(--font-heading);display:block}.countdown-label{text-transform:uppercase;letter-spacing:1px;margin-top:.5rem;font-size:.9rem;font-weight:300;display:block}.scroll-indicator{z-index:3;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.scroll-arrow{color:var(--white);cursor:pointer;font-size:2rem}@media (width<=768px){.hero-title{font-size:3rem}.hero-subtitle{letter-spacing:4px;font-size:1.2rem}.hero-date{font-size:1.2rem}.countdown-boxes{gap:1rem}.countdown-box{min-width:80px;padding:1rem 1.5rem}.countdown-number{font-size:2rem}.countdown-label{font-size:.7rem}.crown-icon{font-size:3rem}}.event-details{background:var(--off-white);padding:5rem 2rem}.container{max-width:1200px;margin:0 auto}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{color:var(--celeste-dark);margin-bottom:1rem;font-size:3rem}.divider{background:linear-gradient(90deg, var(--celeste-primary), var(--gold));width:100px;height:3px;margin:0 auto}.events-grid{grid-template-columns:1fr;gap:3rem;max-width:900px;margin:0 auto;display:grid}.event-card{background:var(--white);box-shadow:0 10px 30px var(--shadow);border-radius:20px;padding:2.5rem;transition:transform .3s,box-shadow .3s}.event-card-full{grid-column:1}.event-card:hover{transform:translateY(-10px);box-shadow:0 15px 40px #00000026}.event-icon{color:var(--celeste-primary);text-align:center;margin-bottom:1.5rem;font-size:3rem}.event-card h3{color:var(--text-dark);text-align:center;margin-bottom:1.5rem;font-size:2rem}.event-carousel{background:#000;border-radius:15px;justify-content:center;align-items:center;width:100%;min-height:300px;max-height:600px;margin-bottom:2rem;display:flex;position:relative;overflow:hidden}.carousel-images{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.carousel-image{opacity:0;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .5s ease-in-out;display:flex;position:absolute;top:0;left:0}.carousel-image.active{opacity:1;z-index:1;position:relative}.carousel-image img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:600px;display:block}.carousel-btn{z-index:10;color:var(--celeste-dark);cursor:pointer;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.2rem;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-btn:hover{background:var(--white);transform:translateY(-50%)scale(1.1);box-shadow:0 4px 15px #0003}.carousel-btn.prev{left:20px}.carousel-btn.next{right:20px}.carousel-indicators{z-index:10;gap:10px;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.event-info{margin-bottom:2rem}.info-item{align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.info-item svg{color:var(--celeste-primary);flex-shrink:0;margin-top:.2rem;font-size:1.5rem}.info-item strong{color:var(--text-dark);margin-bottom:.3rem;font-size:1.1rem;display:block}.info-item p{color:#666;font-size:1rem;line-height:1.5}.address{font-style:italic;font-size:.9rem!important}.event-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.btn-primary{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-dark));min-width:200px;color:var(--white);cursor:pointer;border:none;border-radius:25px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.8rem 1.5rem;font-weight:600;text-decoration:none;transition:all .3s;display:flex}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #4682b466}@media (width<=768px){.events-grid{grid-template-columns:1fr}.section-header h2{font-size:2rem}.event-card{padding:2rem}.event-carousel{min-height:250px;max-height:500px}.carousel-image img{max-height:500px}.carousel-btn{width:40px;height:40px;font-size:1rem}.carousel-btn.prev{left:10px}.carousel-btn.next{right:10px}.carousel-indicators{bottom:15px}.indicator{width:10px;height:10px}.event-actions{flex-direction:column}.btn-primary{width:100%}}@media (width<=480px){.event-carousel{min-height:200px;max-height:400px}.carousel-image img{max-height:400px}}.gallery{background:var(--white);padding:4rem 2rem}.gallery-container{max-width:1200px;margin:0 auto}.countdown-section{text-align:center;margin-bottom:4rem}.countdown-title{color:var(--text-dark);font-size:2rem;font-family:var(--font-heading);letter-spacing:1px;margin-bottom:2rem}.countdown-boxes{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.countdown-box{border:2px solid var(--celeste-primary);background:linear-gradient(135deg,#87ceeb33,#4682b433);border-radius:15px;flex-direction:column;justify-content:center;align-items:center;min-width:100px;padding:1.5rem 2rem;transition:all .3s;display:flex;box-shadow:0 4px 15px #0000001a}.countdown-box:hover{border-color:var(--celeste-dark);transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.countdown-number{color:var(--celeste-dark);font-size:2.5rem;font-weight:700;font-family:var(--font-heading)}.countdown-label{color:var(--text-dark);text-transform:uppercase;letter-spacing:1px;margin-top:.5rem;font-size:.9rem;font-weight:600}.gallery-carousel{aspect-ratio:4/5;border-radius:30px;width:100%;max-width:800px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 20px 60px #0003}.carousel-wrapper{width:100%;height:100%;position:relative}.gallery-image{opacity:0;background-position:50%;background-size:cover;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .8s ease-in-out;display:flex;position:absolute;top:0;left:0}.gallery-image.active{opacity:1;z-index:1}.gallery-image img{object-fit:cover;width:100%;height:100%;display:block}.gallery-btn{z-index:10;color:var(--celeste-dark);cursor:pointer;background:#ffffffd9;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.2rem;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 12px #00000026}.gallery-btn:hover{background:var(--white);transform:translateY(-50%)scale(1.1);box-shadow:0 6px 20px #0003}.gallery-btn.prev{left:20px}.gallery-btn.next{right:20px}.gallery-indicators{z-index:10;gap:12px;display:flex;position:absolute;bottom:25px;left:50%;transform:translate(-50%)}.indicator{border:2px solid var(--white);cursor:pointer;background:#ffffff80;border-radius:50%;width:12px;height:12px;padding:0;transition:all .3s}.indicator.active{background:var(--white);transform:scale(1.3)}.indicator:hover{background:#fffc}@media (width<=768px){.gallery{padding:3rem 1rem}.countdown-title{font-size:1.5rem}.countdown-boxes{gap:1rem}.countdown-box{min-width:80px;padding:1rem 1.5rem}.countdown-number{font-size:2rem}.countdown-label{font-size:.8rem}.gallery-carousel{aspect-ratio:3/4;border-radius:20px}.gallery-btn{width:40px;height:40px;font-size:1rem}.gallery-btn.prev{left:10px}.gallery-btn.next{right:10px}.indicator{width:10px;height:10px}}@media (width<=480px){.countdown-boxes{gap:.8rem}.countdown-box{min-width:70px;padding:.8rem 1rem}.countdown-number{font-size:1.5rem}.gallery-carousel{aspect-ratio:9/16;border-radius:15px}.gallery-indicators{gap:8px;bottom:15px}}.rsvp{background:linear-gradient(135deg, var(--celeste-light) 0%, var(--white) 100%);padding:5rem 2rem}.subtitle{color:var(--text-dark);margin-top:1rem;font-size:1.2rem}.deadline{color:var(--celeste-dark);margin-top:.5rem;font-size:1rem;font-weight:600}.rsvp-card{background:var(--white);max-width:700px;box-shadow:0 15px 40px var(--shadow);border-radius:20px;margin:0 auto;padding:3rem}.rsvp-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-dark);align-items:center;gap:.5rem;font-weight:600;display:flex}.form-group label svg{color:var(--celeste-primary)}.form-group input,.form-group select,.form-group textarea{border:2px solid var(--celeste-light);border-radius:10px;padding:.8rem 1rem;font-size:1rem;transition:all .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--celeste-primary);outline:none;box-shadow:0 0 0 3px #87ceeb1a}.form-row{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.btn-submit{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-dark));color:var(--white);border-radius:25px;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex}.btn-submit:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 20px #4682b466}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.alert{text-align:center;border-radius:10px;padding:1rem;font-weight:600;animation:.3s slideDown}.alert-success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.alert-error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.rsvp-card{padding:2rem}.form-row{grid-template-columns:1fr}}.spotify-section{background:var(--white);padding:5rem 2rem}.section-icon{color:var(--celeste-primary);margin-bottom:1rem;font-size:3rem}.spotify-content{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:3rem;margin-top:3rem;display:grid}.spotify-player,.song-suggestion-form{background:var(--off-white);box-shadow:0 10px 30px var(--shadow);border-radius:20px;padding:2.5rem}.spotify-player h3,.song-suggestion-form h3{color:var(--text-dark);text-align:center;margin-bottom:1.5rem;font-size:1.8rem}.spotify-button{color:var(--white);background:#1db954;border-radius:25px;justify-content:center;align-items:center;gap:.8rem;margin-bottom:2rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex}.spotify-button:hover{background:#1ed760;transform:translateY(-3px);box-shadow:0 8px 20px #1db95466}.spotify-button svg{font-size:1.5rem}.spotify-embed-placeholder{text-align:center;color:var(--white);background:linear-gradient(135deg,#1db954,#1ed760);border-radius:15px;flex-direction:column;justify-content:center;align-items:center;min-height:250px;padding:3rem;display:flex}.spotify-logo{margin-bottom:1rem;font-size:4rem}.spotify-embed-placeholder p{margin-bottom:.5rem;font-size:1.3rem;font-weight:600}.spotify-embed-placeholder small{opacity:.8;font-size:.9rem}.song-suggestion-form form{flex-direction:column;gap:1rem;display:flex}.btn-add-song{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-dark));color:var(--white);border-radius:25px;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem;padding:1rem;font-weight:600;transition:all .3s;display:flex}.btn-add-song:hover{transform:translateY(-3px);box-shadow:0 8px 20px #4682b466}.success-message{color:#155724;text-align:center;background:#d4edda;border-radius:10px;margin-top:1rem;padding:1rem;animation:.3s slideDown}@media (width<=768px){.spotify-content{grid-template-columns:1fr}.spotify-player,.song-suggestion-form{padding:2rem}}.dresscode{background:var(--off-white);padding:5rem 2rem}.dresscode-card{background:var(--white);max-width:900px;box-shadow:0 15px 40px var(--shadow);border-radius:20px;margin:0 auto;padding:3rem}.dresscode-main{text-align:center;border-bottom:2px solid var(--celeste-light);margin-bottom:3rem;padding-bottom:2rem}.dresscode-main h3{color:var(--celeste-dark);margin-bottom:1rem;font-size:2.5rem}.dresscode-description{color:var(--text-dark);margin-bottom:1.5rem;font-size:1.2rem}.dresscode-note{color:#856404;background:#fff3cd;border-radius:25px;align-items:center;gap:.5rem;padding:.8rem 1.5rem;font-weight:600;display:inline-flex}.dresscode-note svg{font-size:1.2rem}.dresscode-suggestions{margin-bottom:3rem}.dresscode-suggestions h4{color:var(--text-dark);text-align:center;margin-bottom:1.5rem;font-size:1.5rem}.suggestions-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1.5rem;display:grid}.suggestion-card{text-align:center;background:var(--off-white);border-radius:15px;padding:1.5rem;transition:transform .3s}.suggestion-card:hover{transform:translateY(-5px)}.suggestion-image-placeholder{background:linear-gradient(135deg, var(--celeste-light), var(--celeste-primary));border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;font-size:2.5rem;display:flex}.suggestion-card p{color:var(--text-dark);font-weight:600}.color-palette{text-align:center}.color-palette h4{color:var(--text-dark);margin-bottom:1.5rem;font-size:1.5rem}.colors{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.color-circle{width:60px;height:60px;box-shadow:0 4px 10px var(--shadow);cursor:pointer;border:3px solid var(--white);border-radius:50%;transition:transform .3s}.color-circle:hover{transform:scale(1.1)}.colors-list{flex-direction:column;align-items:center;gap:.8rem;padding:0;list-style:none;display:flex}.colors-list li{color:var(--text-dark);background:var(--off-white);border-left:4px solid var(--celeste-primary);border-radius:10px;padding:.8rem 1.5rem;font-size:1.1rem;font-weight:500;transition:all .3s}.colors-list li:hover{background:var(--celeste-light);transform:translate(5px)}@media (width<=768px){.dresscode-card{padding:2rem}.dresscode-main h3{font-size:2rem}.suggestions-grid{grid-template-columns:repeat(2,1fr)}.colors{gap:.8rem}.color-circle{width:50px;height:50px}}.gifts{background:linear-gradient(135deg, var(--white) 0%, var(--celeste-light) 100%);padding:5rem 2rem}.gifts-grid{flex-wrap:wrap;justify-content:center;gap:2.5rem;max-width:1200px;margin-top:3rem;margin-left:auto;margin-right:auto;display:flex}.gift-card{background:var(--white);box-shadow:0 10px 30px var(--shadow);border-radius:20px;padding:4rem;transition:transform .3s,box-shadow .3s}.gift-card-compact{max-width:900px;margin:0 auto}.gift-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000026}.gift-icon{color:var(--celeste-primary);text-align:center;margin-bottom:1.5rem;font-size:3rem}.mp-icon{color:#0af}.gift-card h3{color:var(--text-dark);text-align:center;margin-bottom:1.5rem;font-size:1.8rem}.payment-details{flex-direction:column;gap:1.2rem;display:flex}.detail-item{background:var(--off-white);border-radius:10px;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.detail-item strong{color:var(--celeste-dark);text-transform:uppercase;letter-spacing:1px;font-size:.9rem}.detail-value{justify-content:space-between;align-items:center;gap:1rem;display:flex}.detail-value span{word-break:break-all;font-family:Courier New,monospace;font-size:1rem}.btn-copy{background:var(--celeste-primary);color:var(--white);border-radius:8px;flex-shrink:0;padding:.5rem .8rem;transition:all .3s}.btn-copy:hover{background:var(--celeste-dark);transform:scale(1.05)}.mp-description{text-align:center;color:#666;margin-bottom:1.5rem}.btn-mercadopago{color:var(--white);background:linear-gradient(135deg,#0af,#0080ff);border-radius:25px;justify-content:center;align-items:center;gap:.8rem;margin-bottom:2rem;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.btn-mercadopago:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0af6}.qr-placeholder{text-align:center}.qr-code{background:var(--off-white);border:3px dashed var(--celeste-primary);border-radius:15px;justify-content:center;align-items:center;width:150px;height:150px;margin:0 auto 1rem;display:flex}.qr-code span{color:var(--celeste-dark);font-size:2rem;font-weight:700}.qr-placeholder p{color:#666;font-size:.9rem}.gift-list-card{grid-column:span 1}.gift-list-description{text-align:center;color:#666;margin-bottom:1.5rem}.gift-list-options{flex-direction:column;gap:1rem;display:flex}.btn-gift-list{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-dark));color:var(--white);text-align:center;border-radius:15px;padding:1rem;font-weight:600;transition:all .3s}.btn-gift-list:hover{transform:translate(5px);box-shadow:0 5px 15px #4682b466}@media (width<=768px){.gifts-grid{grid-template-columns:1fr}.gift-card{padding:2rem}}.floating-music-button{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-dark));border:3px solid var(--white);width:60px;height:60px;color:var(--white);cursor:pointer;z-index:100;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.5rem;transition:all .3s;display:flex;position:fixed;bottom:30px;left:30px;box-shadow:0 8px 25px #0000004d}.floating-music-button:hover{background:linear-gradient(135deg, var(--celeste-dark), var(--celeste-primary));transform:scale(1.15);box-shadow:0 12px 35px #0006}.floating-music-button:active{transform:scale(.95)}@media (width<=768px){.floating-music-button{width:55px;height:55px;font-size:1.3rem;bottom:20px;left:20px}}@media (width<=480px){.floating-music-button{width:50px;height:50px;font-size:1.1rem;bottom:15px;left:15px}}.floating-music-button.playing{animation:2s infinite pulse}@keyframes pulse{0%,to{box-shadow:0 4px 15px #25d36666}50%{box-shadow:0 4px 25px #25d366b3}}.guest-view{min-height:100vh}.navbar{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px var(--shadow);background:#fffffff2;transition:transform .3s;position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}.navbar.visible{transform:translateY(0)}.navbar-content{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex}.navbar-brand{font-family:var(--font-heading);color:var(--celeste-dark);font-size:1.5rem;font-weight:700}.menu-toggle{color:var(--celeste-dark);background:0 0;font-size:1.5rem;display:none}.nav-menu{gap:2rem;list-style:none;display:flex}.nav-menu li{cursor:pointer;color:var(--text-dark);font-weight:600;transition:color .3s;position:relative}.nav-menu li:after{content:"";background:var(--celeste-primary);width:0;height:2px;transition:width .3s;position:absolute;bottom:-5px;left:0}.nav-menu li:hover{color:var(--celeste-primary)}.nav-menu li:hover:after{width:100%}.footer{background:linear-gradient(135deg, var(--celeste-dark), var(--celeste-primary));color:var(--white);text-align:center;padding:4rem 2rem 2rem}.footer-content{max-width:800px;margin:0 auto}.social-links h3{margin-bottom:1.5rem;font-size:1.5rem}.social-icons{justify-content:center;gap:1.5rem;margin-bottom:1rem;display:flex}.social-icons a{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.5rem;transition:all .3s;display:flex}.social-icons a:hover{background:var(--white);color:var(--celeste-primary);transform:translateY(-5px)}.hashtag{letter-spacing:1px;margin-top:1rem;font-size:1.2rem;font-weight:600}.footer-divider{background:#ffffff4d;width:100px;height:2px;margin:2rem auto}.footer-message{margin-bottom:1rem;font-size:1.1rem;font-style:italic;line-height:1.6}.footer-date{margin-bottom:2rem;font-size:1.3rem;font-weight:600}.footer-credits{opacity:.8;border-top:1px solid #fff3;margin-top:2rem;padding-top:2rem;font-size:.9rem}.whatsapp-float{width:60px;height:60px;color:var(--white);z-index:999;background:#25d366;border-radius:50%;justify-content:center;align-items:center;font-size:2rem;transition:all .3s;animation:2s infinite pulse;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 15px #25d36666}.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 20px #25d36699}@media (width<=768px){.menu-toggle{display:block}.nav-menu{background:var(--white);width:70%;height:calc(100vh - 70px);box-shadow:-5px 0 15px var(--shadow);flex-direction:column;padding:2rem;transition:right .3s;position:fixed;top:70px;right:-100%}.nav-menu.active{right:0}.nav-menu li{border-bottom:1px solid var(--celeste-light);padding:1rem 0}.whatsapp-float{width:50px;height:50px;font-size:1.5rem;bottom:1.5rem;right:1.5rem}}.admin-view{background:linear-gradient(135deg, var(--celeste-light), var(--white));min-height:100vh;padding:40px 20px}.admin-header{text-align:center;margin-bottom:50px}.admin-header h1{color:var(--celeste-dark);font-size:2.5rem;font-family:var(--font-heading);margin-bottom:10px}.admin-header p{color:var(--celeste-primary);font-size:1.1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;max-width:1200px;margin-bottom:50px;margin-left:auto;margin-right:auto;display:grid}.stat-card{text-align:center;background:#fff;border-radius:12px;padding:30px;transition:all .3s;box-shadow:0 4px 15px #0000001a}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.stat-card.confirmed{border-top:4px solid #4caf50}.stat-card.not-attending{border-top:4px solid #f44336}.stat-card.total{border-top:4px solid var(--celeste-primary)}.stat-card.songs{border-top:4px solid var(--gold)}.stat-number{color:var(--celeste-dark);margin-bottom:10px;font-size:2.5rem;font-weight:700;display:block}.stat-label{color:#666;font-size:.95rem;font-weight:600;display:block}.admin-section{background:#fff;border-radius:12px;max-width:1200px;margin-bottom:40px;margin-left:auto;margin-right:auto;padding:40px;box-shadow:0 4px 15px #00000014}.section-title-bar{border-bottom:2px solid var(--celeste-light);justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;display:flex}.section-title-bar h2{color:var(--celeste-dark);font-size:1.8rem;font-family:var(--font-heading);align-items:center;gap:10px;margin:0;display:flex}.section-title-bar h2 svg{color:var(--gold)}.section-actions{gap:10px;display:flex}.btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 20px;font-size:.95rem;font-weight:600;transition:all .3s;display:flex}.btn-export{background:var(--celeste-primary);color:#fff}.btn-export:hover{background:var(--celeste-dark);transform:translateY(-2px);box-shadow:0 4px 12px #4682b44d}.btn-danger{color:#fff;background:#f44336}.btn-danger:hover{background:#d32f2f;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.btn-delete-item{color:#f44336;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;font-size:1.2rem;transition:all .3s;display:flex}.btn-delete-item:hover{color:#d32f2f;background:#f443361a}.data-list{flex-direction:column;gap:15px;display:flex}.empty-state{text-align:center;color:#999;padding:60px 20px}.empty-state p{margin:0;font-size:1.1rem}.confirmation-item{border-left:4px solid var(--celeste-primary);background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e0e0e0;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:15px;padding:20px;transition:all .3s;display:flex}.confirmation-item:hover{border-color:var(--celeste-primary);box-shadow:0 4px 12px #87ceeb33}.item-header{flex:1;justify-content:space-between;align-items:center;gap:15px;margin-bottom:12px;display:flex}.item-name{color:var(--celeste-dark);word-break:break-word;font-size:1.1rem;font-weight:700}.badge-attendance{white-space:nowrap;border-radius:20px;padding:6px 12px;font-size:.85rem;font-weight:600}.badge-attendance.attending{color:#2e7d32;background:#e8f5e9}.badge-attendance.not-attending{color:#c62828;background:#ffebee}.item-details{flex-direction:column;flex:1;gap:8px;display:flex}.detail-row{gap:10px;font-size:.95rem;display:flex}.detail-row .label{color:#666;min-width:90px;font-weight:600}.detail-row .value{color:#333;word-break:break-word;flex:1}.badge-guests{color:var(--celeste-dark);background:#87ceeb33;border-radius:4px;padding:4px 8px;font-weight:600;display:inline-block}.message-text{color:#666;border-left:3px solid var(--gold);background:#00000005;border-radius:4px;padding:8px 12px;font-style:italic}.song-item{border-left:4px solid var(--gold);background:linear-gradient(135deg,#fffef0,#fff);border:1px solid #f0e0c0;border-radius:8px;justify-content:space-between;align-items:center;gap:15px;padding:20px;transition:all .3s;display:flex}.song-item:hover{border-color:var(--gold);box-shadow:0 4px 12px #d4af3733}.item-content{flex:1}.song-title{color:var(--celeste-dark);margin-bottom:5px;font-size:1.1rem;font-weight:700}.song-artist{color:#666;margin-bottom:8px;font-size:.95rem}.song-date{color:#999;font-size:.85rem}@media (width<=768px){.admin-view{padding:20px 15px}.admin-section{margin-bottom:30px;padding:25px 20px}.section-title-bar{flex-direction:column;align-items:flex-start;gap:15px}.section-title-bar h2{font-size:1.4rem}.section-actions{width:100%}.section-actions .btn{flex:1;justify-content:center;font-size:.85rem}.confirmation-item,.song-item{flex-direction:column;align-items:flex-start}.item-header{flex-direction:column;align-items:flex-start;width:100%}.badge-attendance{align-self:flex-start}.btn-delete-item{align-self:flex-end;margin-top:-10px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.stat-card{padding:20px}.stat-number{font-size:2rem}.stat-label{font-size:.85rem}}@media (width<=480px){.admin-header h1{font-size:1.8rem}.section-title-bar h2{font-size:1.1rem}.detail-row{flex-direction:column;gap:5px}.detail-row .label{min-width:auto}.btn{padding:8px 12px;font-size:.8rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}.loading-container{min-height:400px;color:var(--celeste-primary);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.admin-import-button-area{text-align:center;margin-bottom:40px}.btn-import-csv{background:linear-gradient(135deg, var(--gold), #d4af37);color:var(--white);cursor:pointer;border:none;border-radius:6px;padding:12px 30px;font-size:1rem;font-weight:600;transition:all .3s}.btn-import-csv:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af374d}.import-csv-section{border:2px dashed var(--gold);background:linear-gradient(135deg,#fffef0,#f5f5f5);border-radius:12px;max-width:1200px;margin-bottom:40px;margin-left:auto;margin-right:auto;padding:30px}.import-header{text-align:center;margin-bottom:30px}.import-header h3{color:var(--celeste-dark);font-size:1.5rem;font-family:var(--font-heading);justify-content:center;align-items:center;gap:10px;margin:0 0 10px;display:flex}.import-header p{color:#666;margin:0;font-size:.95rem}.file-upload-area{margin-bottom:30px;position:relative}.file-upload-area input{display:none}.file-upload-area label{border:2px dashed var(--celeste-primary);cursor:pointer;color:var(--celeste-dark);-webkit-user-select:none;user-select:none;background:#fff;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:40px;font-weight:600;transition:all .3s;display:flex}.file-upload-area label:hover{border-color:var(--celeste-dark);background:#87ceeb1a;transform:scale(1.02)}.file-upload-area label:active{background:#87ceeb26}.file-upload-area label small{color:#999;margin-top:8px;font-size:.85rem;font-weight:400;display:block}.file-upload-area.drag-over label{border-color:var(--celeste-dark);background:#87ceeb33;border-width:3px}.column-mapping{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:25px;padding:25px}.column-mapping h4{color:var(--celeste-dark);margin:0 0 20px;font-size:1.1rem}.mapping-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;display:grid}.mapping-item{flex-direction:column;display:flex}.mapping-item label{color:#333;margin-bottom:8px;font-size:.9rem;font-weight:600}.mapping-item select{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:6px;padding:10px;font-size:.9rem;transition:all .3s}.mapping-item select:focus{border-color:var(--celeste-primary);outline:none;box-shadow:0 0 0 3px #87ceeb1a}.preview-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:25px;padding:25px;overflow-x:auto}.preview-section h4{color:var(--celeste-dark);margin:0 0 15px;font-size:1.1rem}.preview-table{overflow-x:auto}.preview-table table{border-collapse:collapse;width:100%;font-size:.9rem}.preview-table thead{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-light));color:#fff}.preview-table th{text-align:left;padding:12px;font-weight:600}.preview-table td{color:#333;border-bottom:1px solid #eee;padding:12px}.preview-table tbody tr:hover{background:#87ceeb0d}.import-actions{justify-content:center;gap:15px;display:flex}.btn-import{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:6px;align-items:center;gap:8px;padding:12px 30px;font-weight:600;transition:all .3s;display:flex}.btn-import:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4caf504d}.btn-import:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{color:#fff;cursor:pointer;background:#999;border:none;border-radius:6px;padding:12px 30px;font-weight:600;transition:all .3s}.btn-cancel:hover:not(:disabled){background:#777;transform:translateY(-2px)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.import-results{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:30px}.result-success{color:#2e7d32;background:#e8f5e9;border-left:4px solid #4caf50;border-radius:6px;align-items:center;gap:10px;margin-bottom:20px;padding:20px;font-weight:600;display:flex}.result-success svg{font-size:1.5rem}.result-error{color:#c62828;background:#ffebee;border-left:4px solid #f44336;border-radius:6px;margin-bottom:20px;padding:20px}.result-error ul{margin:15px 0 0;padding-left:20px}.result-error li{margin:5px 0;font-size:.9rem}.btn-close{background:var(--celeste-primary);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;padding:10px 20px;font-weight:600;transition:all .3s}.btn-close:hover{background:var(--celeste-dark);transform:translateY(-2px)}@media (width<=768px){.import-csv-section{padding:20px}.file-upload-area label{padding:25px 15px}.mapping-grid{grid-template-columns:1fr}.import-actions{flex-direction:column}.btn-import,.btn-cancel{justify-content:center;width:100%}.preview-table{font-size:.8rem}.preview-table th,.preview-table td{padding:8px}}.admin-login{background:linear-gradient(135deg, var(--celeste-light), var(--celeste-primary), var(--celeste-dark));justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{background:var(--white);border-radius:20px;width:100%;max-width:450px;padding:3rem;animation:.5s fadeIn;box-shadow:0 20px 60px #0003}.login-header{text-align:center;margin-bottom:2rem}.lock-icon{color:var(--celeste-primary);margin-bottom:1rem;font-size:3rem}.login-header h2{color:var(--text-dark);margin-bottom:.5rem;font-size:2rem}.login-header p{color:#666;font-size:1rem}.login-form{flex-direction:column;gap:1.5rem;display:flex}.login-form .form-group{flex-direction:column;gap:.5rem;display:flex}.login-form label{color:var(--text-dark);align-items:center;gap:.5rem;font-weight:600;display:flex}.login-form label svg{color:var(--celeste-primary)}.login-form input{border:2px solid var(--celeste-light);border-radius:10px;padding:.8rem 1rem;font-size:1rem;transition:all .3s}.login-form input:focus{border-color:var(--celeste-primary);outline:none;box-shadow:0 0 0 3px #87ceeb1a}.btn-login{background:linear-gradient(135deg, var(--celeste-primary), var(--celeste-dark));color:var(--white);border-radius:25px;margin-top:1rem;padding:1rem;font-size:1.1rem;font-weight:600;transition:all .3s}.btn-login:hover{transform:translateY(-3px);box-shadow:0 8px 20px #4682b466}.error-message{color:#721c24;text-align:center;background:#f8d7da;border-radius:10px;padding:.8rem;font-weight:600;animation:.5s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-footer{text-align:center;border-top:1px solid var(--celeste-light);margin-top:2rem;padding-top:2rem}.login-footer a{color:var(--celeste-dark);font-weight:600;transition:color .3s}.login-footer a:hover{color:var(--celeste-primary)}@media (width<=768px){.login-card{padding:2rem}.login-header h2{font-size:1.5rem}}:root{--celeste-primary:#87ceeb;--celeste-light:#b0e0e6;--celeste-dark:#4682b4;--white:#fff;--off-white:#f8f9fa;--text-dark:#2c3e50;--gold:#d4af37;--shadow:#0000001a;--font-heading:"Playfair Display", serif;--font-body:"Montserrat", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text-dark);background-color:var(--white);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input,textarea{font-family:var(--font-body)}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--off-white)}::-webkit-scrollbar-thumb{background:var(--celeste-primary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--celeste-dark)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}.fade-in{animation:.8s ease-out fadeIn}.float{animation:3s ease-in-out infinite float}
