.carousel-wrap{margin:0 1rem 1.5rem;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,var(--blue-light) 0%,var(--blue) 100%);aspect-ratio:3 / 4;min-height:420px;position:relative}.carousel{display:flex;width:100%;height:100%;scroll-snap-type:x mandatory;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}.carousel::-webkit-scrollbar{display:none}.carousel-slide{flex:0 0 100%;width:100%;height:100%;scroll-snap-align:start;scroll-snap-stop:always;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#e0e7ff,#e0f2fe)}.carousel-slide.placeholder{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:var(--ink);font-size:.95rem;opacity:.7;text-align:center;padding:1rem}.carousel-slide img,.carousel-slide video,.carousel-video{width:100%;height:100%;object-fit:contain;display:block}.carousel-slide-video{background:#000}.carousel-dots{display:flex;justify-content:center;gap:.5rem;padding:.75rem}.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--blue-light);opacity:.5;border:none;cursor:pointer;transition:opacity .2s,transform .2s}.carousel-dot.active{opacity:1;transform:scale(1.2);background:var(--blue)}.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;border:none;background:#ffffffe6;color:var(--ink);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0000001a;transition:background .2s,transform .2s;z-index:2}.carousel-nav:hover{background:#fff;transform:translateY(-50%) scale(1.05)}.carousel-nav.prev{left:.75rem}.carousel-nav.next{right:.75rem}.rsvp-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#1e293b80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rsvp-modal{width:100%;max-width:400px;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0003;padding:1.75rem}.rsvp-modal-title{font-family:Fredoka,sans-serif;font-size:1.5rem;color:var(--blue);margin:0 0 .5rem;text-align:center}.rsvp-modal-subtitle{font-size:.95rem;color:var(--ink);opacity:.85;margin:0 0 1.25rem;text-align:center;line-height:1.4}.rsvp-modal-error{font-size:.9rem;color:#b91c1c;margin:0 0 1rem;text-align:center}.rsvp-modal-success{font-size:.95rem;color:#15803d;margin:0 0 1rem;text-align:center}.rsvp-form{display:flex;flex-direction:column;gap:.75rem}.rsvp-name-row{display:flex;gap:.5rem;align-items:center}.rsvp-input{flex:1;padding:.65rem 1rem;font-family:Quicksand,sans-serif;font-size:1rem;border:1px solid #e2e8f0;border-radius:10px;color:var(--ink);transition:border-color .2s}.rsvp-input::placeholder{color:var(--slate);opacity:.7}.rsvp-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #2563eb26}.rsvp-remove{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1;color:var(--ink);background:#f1f5f9;border:none;border-radius:10px;cursor:pointer;transition:background .2s}.rsvp-remove:hover:not(:disabled){background:#e2e8f0}.rsvp-remove:disabled{opacity:.4;cursor:not-allowed}.rsvp-add{padding:.5rem 0;font-family:Quicksand,sans-serif;font-size:.95rem;font-weight:600;color:var(--blue);background:none;border:none;cursor:pointer;text-align:left;transition:color .2s}.rsvp-add:hover{color:var(--blue-dark)}.rsvp-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.rsvp-btn{flex:1;padding:.75rem 1rem;font-family:Quicksand,sans-serif;font-size:1rem;font-weight:600;border-radius:10px;cursor:pointer;transition:transform .2s,box-shadow .2s}.rsvp-cancel{color:var(--ink);background:#f1f5f9;border:none}.rsvp-cancel:hover{background:#e2e8f0}.rsvp-submit{color:#fff;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);border:none;box-shadow:0 2px 8px #2563eb4d}.rsvp-submit:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.list-page{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem}.list-card{width:min(560px,calc(100vw - 2rem));background:#fff;border-radius:24px;box-shadow:0 12px 40px #2d2a3214,0 0 0 1px #2d2a320a;overflow:hidden;padding:1.75rem 1.5rem 2rem}.list-title{font-family:Fredoka,sans-serif;font-size:clamp(1.75rem,5vw,2.25rem);font-weight:600;text-align:center;color:var(--blue);margin:0 0 .25rem;line-height:1.2}.list-subtitle{text-align:center;font-size:1rem;color:var(--ink);opacity:.85;margin:0 0 1.25rem}.list-back{display:inline-block;margin-bottom:1.5rem;font-size:.95rem;color:var(--blue);text-decoration:none;font-weight:500}.list-back:hover{text-decoration:underline}.list-message{text-align:center;margin:1rem 0;font-size:1rem;color:var(--ink)}.list-loading{opacity:.8}.list-error{color:#b91c1c}.list-empty{opacity:.85}.list-rsvps{list-style:none;margin:0;padding:0}.list-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border-radius:12px;background:#2563eb0f;margin-bottom:.5rem;border:1px solid rgba(37,99,235,.1)}.list-item:last-child{margin-bottom:0}.list-name{font-weight:500;color:var(--ink)}.list-date{font-size:.9rem;color:var(--ink);opacity:.7}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle at 10% 20%,rgba(37,99,235,.12) 0%,transparent 30%),radial-gradient(circle at 90% 80%,rgba(147,197,253,.2) 0%,transparent 30%),radial-gradient(circle at 50% 50%,rgba(30,64,175,.06) 0%,transparent 40%)}.bg-silhouettes{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.4;background-image:url(/dino1.svg),url(/dino1.svg),url(/dino1.svg),url(/dino1.svg),url(/dino1.svg),url(/dino1.svg),url(/dino2.svg),url(/dino2.svg),url(/dino2.svg),url(/dino2.svg),url(/dino2.svg),url(/dino2.svg),url(/star.svg),url(/star.svg),url(/star.svg),url(/star.svg),url(/star.svg),url(/star.svg),url(/star.svg),url(/star.svg),url(/shark.svg),url(/shark.svg),url(/shark.svg),url(/shark.svg),url(/shark.svg),url(/shark.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/fish.svg),url(/turtle.svg),url(/turtle.svg),url(/turtle.svg),url(/turtle.svg),url(/turtle.svg),url(/turtle.svg),url(/football.svg),url(/football.svg),url(/football.svg),url(/football.svg),url(/football.svg),url(/football.svg),url(/basketball.svg),url(/basketball.svg),url(/basketball.svg),url(/basketball.svg),url(/basketball.svg),url(/basketball.svg),url(/bucket.svg),url(/bucket.svg),url(/bucket.svg),url(/bucket.svg),url(/bucket.svg),url(/bucket.svg),url(/duck.svg),url(/duck.svg),url(/duck.svg),url(/duck.svg),url(/duck.svg),url(/duck.svg);background-size:200px 133px,120px 80px,95px 63px,150px 100px,140px 140px,90px 90px,110px 110px,75px 75px,180px 135px,100px 75px,70px 52px,85px 64px,55px 41px,130px 97px,100px 50px,65px 32px,82px 41px,48px 24px,60px 30px,45px 22px,55px 28px,38px 19px,72px 36px,50px 25px,80px 50px,55px 34px,65px 41px,42px 26px,70px 70px,45px 45px,58px 58px,38px 38px,90px 90px,55px 55px,72px 72px,48px 48px,80px 100px,50px 62px,62px 78px,42px 52px,100px 80px,65px 52px,82px 66px,52px 42px,115px 77px,88px 59px,160px 107px,78px 52px,92px 92px,68px 68px,105px 79px,128px 85px,44px 29px,96px 72px,74px 55px,148px 111px,56px 37px,66px 44px;background-position:0% 5%,55% 8%,22% 42%,90% 32%,88% 18%,12% 35%,65% 78%,38% 12%,72% 55%,25% 70%,95% 85%,8% 58%,52% 28%,78% 92%,3% 52%,78% 25%,18% 82%,92% 55%,68% 78%,35% 15%,92% 42%,12% 92%,58% 48%,82% 72%,18% 88%,48% 65%,75% 12%,5% 22%,8% 72%,82% 38%,32% 62%,95% 18%,42% 5%,95% 68%,15% 48%,68% 88%,62% 92%,28% 22%,45% 75%,88% 52%,88% 8%,5% 48%,72% 35%,25% 58%,40% 3%,7% 65%,62% 15%,18% 28%,85% 62%,50% 82%,33% 48%,92% 8%,10% 88%,70% 38%,45% 12%,5% 45%,78% 68%,22% 18%,95% 42%,55% 72%,88% 28%,12% 52%,65% 5%,38% 85%;background-repeat:no-repeat}main{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem}.invite-card{width:min(560px,calc(100vw - 2rem));background:#fff;border-radius:24px;box-shadow:0 12px 40px #2d2a3214,0 0 0 1px #2d2a320a;overflow:hidden;padding-bottom:2rem}.invite-card h1{font-family:Fredoka,sans-serif;font-size:clamp(1.75rem,5vw,2.25rem);font-weight:600;text-align:center;color:var(--blue);padding:1.75rem 1rem .5rem;line-height:1.2}.subtitle{text-align:center;font-size:1.1rem;color:var(--ink);opacity:.85;padding:0 1rem 1rem}.subtitle-name{font-family:Fredoka,sans-serif;font-size:1.5rem;color:var(--blue)}.details{padding:0 1.75rem 1rem;text-align:center}.details p{margin-bottom:.6rem;font-size:1.05rem;line-height:1.5}.details .highlight{font-family:Fredoka,sans-serif;font-size:1.35rem;color:var(--blue);margin:1rem 0 .5rem}.details .time{font-weight:600;color:var(--ink)}.details .place{color:var(--ink);opacity:.9}.place-link{color:var(--blue);font-weight:600;text-decoration:none;border-bottom:2px solid rgba(37,99,235,.4);padding-bottom:2px;transition:border-color .2s,opacity .2s}.place-link:hover{border-bottom-color:var(--blue);opacity:1}.details-note{margin-top:1rem;opacity:.85}.cta-rsvp{display:block;margin:1.5rem auto 0;padding:.85rem 2rem;font-family:Quicksand,sans-serif;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);border:none;border-radius:999px;cursor:pointer;box-shadow:0 4px 16px #2563eb59;transition:transform .2s,box-shadow .2s}.cta-rsvp:hover{transform:scale(1.03);box-shadow:0 6px 20px #2563eb73}footer{text-align:center;padding:1.5rem 1rem;font-size:.9rem;color:var(--ink);opacity:.6}:root{--cream: #f0f4f8;--blue: #2563eb;--blue-light: #93c5fd;--blue-dark: #1d4ed8;--slate: #64748b;--ink: #1e293b}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Quicksand,sans-serif;background:var(--cream);color:var(--ink);min-height:100vh;overflow-x:hidden}
