*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-tap-highlight-color:transparent}body{font-family:Inter,sans-serif;background:#1a1a2e;color:#fff;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}#app{min-height:100vh}.loading,.error{text-align:center;padding:3rem 1rem;font-size:1.2rem}.error{color:#ff6b6b}.page-404{text-align:center;padding:4rem 1rem}.page-404 h1{font-size:4rem;margin-bottom:1rem;color:#e94560}.page-404 a{color:#e94560;text-decoration:none;font-weight:600}.page-container{max-width:600px;margin:0 auto;padding:2rem 1rem}.page-header{text-align:center;margin-bottom:2rem}.page-header h1{font-size:1.75rem;margin-bottom:.5rem}.page-header p{color:#a0a0a0;font-size:.9375rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:silver}input[type=text],input[type=email],input[type=password],input[type=file]{width:100%;padding:.875rem 1rem;border:2px solid #2a2a4a;border-radius:12px;background:#16213e;color:#fff;font-size:1rem;transition:border-color .2s,box-shadow .2s}input:focus{outline:none;border-color:#e94560;box-shadow:0 0 0 3px #e945601a}input::placeholder{color:#666}input[type=file]{padding:.5rem;font-size:.875rem}input[type=file]::file-selector-button{padding:.5rem 1rem;border:none;border-radius:8px;background:#e94560;color:#fff;margin-right:1rem;cursor:pointer}.btn{width:100%;padding:1rem;border:none;border-radius:12px;background:#e94560;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .1s,opacity .2s,background .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:hover:not(:disabled){background:#d63d56}.btn-secondary{background:#2a2a4a}.btn-secondary:hover:not(:disabled){background:#3a3a5a}.btn-outline{background:transparent;border:2px solid #e94560}.btn-small{padding:.5rem 1rem;font-size:.875rem;width:auto}.text-link{color:#e94560;text-decoration:none;font-weight:500}.text-link:hover{text-decoration:underline}.card{background:#16213e;border-radius:16px;padding:1.5rem;margin-bottom:1rem;border:1px solid #2a2a4a}.card-title{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.card-meta{font-size:.875rem;color:#888}.polaroid{background:#fff;padding:12px 12px 40px;box-shadow:0 4px 6px #0000001a,0 10px 20px #0003,0 2px 4px #0000001a;transform:rotate(var(--rotation, -2deg));transition:transform .3s ease,box-shadow .3s ease;max-width:320px}.polaroid:hover{transform:rotate(0) scale(1.03);box-shadow:0 8px 12px #00000026,0 20px 40px #00000040}.polaroid img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover;background:#f0f0f0}.polaroid .caption{font-family:Caveat,cursive;font-size:1.5rem;color:#333;text-align:center;margin-top:12px;line-height:1.2}.slideshow{position:fixed;top:0;left:0;width:100%;height:100%;background:#0a0a1a;display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:100}.slideshow .polaroid-wrapper{position:absolute;animation:fadeSlide var(--duration, 8s) ease-in-out infinite;animation-delay:var(--delay, 0s);max-width:70vw;max-height:70vh;opacity:0}@keyframes fadeSlide{0%{opacity:0;transform:scale(.85) rotate(calc(var(--rotation) - 5deg))}8%{opacity:1;transform:scale(1) rotate(var(--rotation))}25%{opacity:1;transform:scale(1.02) rotate(var(--rotation))}33%{opacity:0;transform:scale(1.05) rotate(calc(var(--rotation) + 3deg))}to{opacity:0;transform:scale(.9) rotate(var(--rotation))}}.slideshow-controls{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:1rem;z-index:101}.slideshow-info{position:fixed;top:1rem;left:1rem;z-index:101;background:#0009;padding:.75rem 1rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.qr-wrapper{text-align:center;padding:2rem;background:#fff;border-radius:16px;margin-top:1.5rem;color:#333}.qr-wrapper canvas{border-radius:8px;max-width:100%}.qr-wrapper .qr-title{font-size:1.25rem;font-weight:600;margin:1rem 0 .25rem;color:#1a1a2e}.qr-wrapper .qr-url{font-size:.8125rem;color:#666;word-break:break-all;margin-top:.5rem}.camera-view{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;display:flex;flex-direction:column;z-index:50}.camera-view video{flex:1;width:100%;object-fit:cover;display:block}.camera-controls{padding:1.25rem 1rem;display:flex;align-items:center;justify-content:space-between;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);gap:1rem}.btn-snap{width:72px;height:72px;border-radius:50%;background:#fff;border:4px solid #e94560;cursor:pointer;transition:transform .1s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-snap:active{transform:scale(.9)}.btn-snap:after{content:"";width:56px;height:56px;border-radius:50%;background:#e94560;transition:background .2s}.btn-snap:active:after{background:#ff6b6b}.preview-strip{display:flex;gap:.5rem;padding:.75rem;overflow-x:auto;background:#000000e6;scrollbar-width:none}.preview-strip::-webkit-scrollbar{display:none}.preview-strip img{height:72px;border-radius:6px;border:2px solid #fff;flex-shrink:0;object-fit:cover;aspect-ratio:4/3}.camera-overlay{position:absolute;top:1rem;right:1rem;z-index:51}.event-list{display:flex;flex-direction:column;gap:1rem}.event-card{background:#16213e;border-radius:16px;padding:1.25rem;border:1px solid #2a2a4a;display:flex;justify-content:space-between;align-items:center;transition:border-color .2s}.event-card:hover{border-color:#e94560}.event-card-info h3{font-size:1.125rem;margin-bottom:.25rem}.event-card-info p{font-size:.8125rem;color:#888}.event-card-actions{display:flex;gap:.5rem}.toast-container{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.875rem 1.25rem;border-radius:12px;background:#16213e;border:1px solid #2a2a4a;color:#fff;font-size:.9375rem;animation:slideIn .3s ease;max-width:300px}.toast.success{border-color:#4ade80;background:#4ade801a}.toast.error{border-color:#ff6b6b;background:#ff6b6b1a}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:480px){.page-container{padding:1rem}.page-header h1{font-size:1.5rem}.polaroid{max-width:280px}.slideshow .polaroid-wrapper{max-width:85vw}}.landing-page{min-height:100vh;background:#1a1a2e}.landing-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;gap:3rem;max-width:1200px;margin:0 auto}.landing-hero-content{flex:1;max-width:520px}.landing-badge{display:inline-block;padding:.5rem 1rem;background:#e9456026;border:1px solid rgba(233,69,96,.3);border-radius:100px;color:#e94560;font-size:.875rem;font-weight:600;margin-bottom:1.5rem;letter-spacing:.05em}.landing-title{font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem;letter-spacing:-.02em}.landing-accent{color:#e94560;display:block}.landing-subtitle{font-size:1.125rem;color:#a0a0b8;line-height:1.6;margin-bottom:2rem}.landing-cta{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.btn-landing{padding:1.125rem 2rem;font-size:1.125rem;width:auto;min-width:240px;background:#e94560;box-shadow:0 10px 40px #e945604d}.btn-landing:hover{background:#ff6b6b;transform:translateY(-2px);box-shadow:0 15px 50px #e9456066}.landing-cta-note{font-size:.875rem;color:#666}.landing-visual{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;min-height:400px}.landing-polaroid-demo{background:#fff;padding:10px 10px 30px;box-shadow:0 8px 30px #0000004d;transform:rotate(var(--rotation, -2deg));width:220px;transition:transform .3s ease}.landing-polaroid-demo:hover{transform:rotate(0) scale(1.05);z-index:10}.demo-img{width:200px;height:150px;background:linear-gradient(135deg,#f093fb,#f5576c);display:block}.demo-caption{font-family:Caveat,cursive;font-size:1.25rem;color:#333;text-align:center;margin-top:8px}.landing-how{padding:6rem 1rem;max-width:1000px;margin:0 auto}.landing-section-title{text-align:center;font-size:2rem;font-weight:700;margin-bottom:3rem;color:#fff}.landing-steps{display:flex;align-items:flex-start;justify-content:center;gap:1rem;flex-wrap:wrap}.landing-step{flex:1;min-width:200px;max-width:220px;text-align:center;padding:1.5rem;background:#16213e;border-radius:16px;border:1px solid #2a2a4a;position:relative}.step-number{position:absolute;top:-12px;left:50%;transform:translate(-50%);width:28px;height:28px;background:#e94560;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.step-icon{font-size:2rem;margin:.5rem 0 1rem}.landing-step h3{font-size:1.125rem;margin-bottom:.5rem}.landing-step p{font-size:.875rem;color:#888;line-height:1.5}.landing-step-arrow{font-size:1.5rem;color:#e94560;align-self:center;padding-top:2rem}.landing-features{padding:4rem 1rem;max-width:1000px;margin:0 auto}.landing-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.feature-card{background:#16213e;border:1px solid #2a2a4a;border-radius:16px;padding:1.75rem;transition:border-color .2s,transform .2s}.feature-card:hover{border-color:#e94560;transform:translateY(-4px)}.feature-icon{font-size:2rem;margin-bottom:1rem}.feature-card h4{font-size:1.125rem;margin-bottom:.5rem}.feature-card p{font-size:.9375rem;color:#888;line-height:1.5}.landing-cta-bottom{text-align:center;padding:6rem 1rem;background:#16213e;margin-top:2rem}.landing-cta-bottom h2{font-size:2rem;font-weight:700;margin-bottom:.75rem}.landing-cta-bottom>p{color:#888;font-size:1.125rem;margin-bottom:2rem}.landing-footer{text-align:center;padding:2rem;background:#1a1a2e;border-top:1px solid #2a2a4a}.landing-footer p{color:#666;font-size:.875rem}@media(max-width:768px){.landing-hero{flex-direction:column;text-align:center;padding-top:3rem}.landing-title{font-size:2.5rem}.landing-cta{align-items:center}.landing-visual{order:-1;min-height:300px}.landing-polaroid-demo{width:180px}.demo-img{width:160px;height:120px}.landing-steps{flex-direction:column;align-items:center}.landing-step-arrow{transform:rotate(90deg);padding:0}.landing-step{max-width:100%;width:100%}}
