*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;background:#000;color:#fff;font-family:-apple-system,system-ui,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}#app{min-height:100%;display:flex;flex-direction:column}.screen{flex:1;display:flex;flex-direction:column;padding:1.5rem;max-width:480px;margin:0 auto;width:100%}h1{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}h2{font-size:1.25rem;font-weight:600}.subtitle{color:#888;margin-bottom:2rem}.input-group{display:flex;gap:.5rem;margin-bottom:1rem}input[type=text]{flex:1;background:#1a1a1a;border:1px solid #333;border-radius:10px;padding:.75rem 1rem;color:#fff;font-size:1rem;font-family:monospace;letter-spacing:2px;outline:none}input[type=text]:focus{border-color:#007aff}.btn-primary{background:#007aff;color:#fff;border:none;border-radius:10px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;white-space:nowrap}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary.btn-large{width:100%;padding:1rem;font-size:1.1rem;margin-top:1rem}.btn-secondary{background:#222;color:#fff;border:1px solid #444;border-radius:10px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;text-align:center}.btn-small{padding:.5rem 1rem;font-size:.875rem}.event-preview{background:#111;border:1px solid #222;border-radius:12px;padding:1.25rem;margin-top:.5rem}.event-meta{display:flex;justify-content:space-between;color:#888;font-size:.875rem;margin-top:.5rem}.error{color:#ff453a;font-size:.875rem;margin-top:.75rem}.hidden{display:none!important}.empty-state{text-align:center;color:#666;padding:3rem 1rem;font-size:1rem}.join-screen{justify-content:center}.reveal-banner{background:#1a1a2e;border:1px solid #2a2a4e;border-radius:8px;padding:.75rem 1rem;text-align:center;color:#88c;font-size:.85rem;margin-bottom:1rem}.upgrade-banner{background:#3a3028;border-radius:10px;padding:.85rem 1rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;margin-bottom:1rem}.upgrade-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.upgrade-banner-text strong{color:#f5e6d3;font-size:.9rem}.upgrade-banner-text span{color:#bfa98a;font-size:.8rem}.upgrade-banner-arrow{color:#bfa98a;font-size:1.5rem;line-height:1}.name-prompt{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}.name-prompt input[type=text]{width:100%;max-width:320px;text-align:center;font-family:-apple-system,system-ui,Segoe UI,sans-serif;letter-spacing:normal;margin-top:1rem}.name-prompt .btn-primary{width:100%;max-width:320px}.camera-screen{padding:0;max-width:none;position:fixed;inset:0;overflow:hidden;display:flex;flex-direction:column;height:100vh;height:100dvh;touch-action:none}.viewfinder-wrap{position:relative;flex:1;min-height:0;overflow:hidden;border-radius:0 0 24px 24px}.viewfinder-wrap video{width:100%;height:100%;object-fit:cover;display:block;transform-origin:center center;transition:transform .2s ease}.camera-top-gradient{position:absolute;top:0;left:0;right:0;height:140px;background:linear-gradient(rgba(0,0,0,.55),transparent);pointer-events:none;z-index:2}.camera-top-bar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;padding:max(env(safe-area-inset-top),12px) 20px 8px;z-index:3}.cam-back-btn{width:40px;height:40px;border-radius:50%;background:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.cam-back-btn svg{width:22px;height:22px}.camera-event-info{flex:1;text-align:center;min-width:0}.camera-event-name{font-family:"Instrument Serif",serif;font-size:18px;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.camera-timer{display:flex;align-items:center;justify-content:center;gap:4px;font-size:12px;font-weight:500;color:#d1d1d1;letter-spacing:.3px}.camera-timer.urgent{color:#ff4b4b}.camera-timer svg{width:12px;height:12px}.cam-spacer{width:40px;flex-shrink:0}.camera-controls-row{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px 12px;z-index:3}.cam-control-btn{width:44px;height:44px;border-radius:50%;background:transparent;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.cam-control-btn svg{width:24px;height:24px}.cam-control-btn.hidden{visibility:hidden}.zoom-pill{display:flex;align-items:center;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:4px;gap:0}.zoom-chip{border-radius:16px;padding:6px 14px;font-size:13px;font-weight:600;color:#ffffff80;background:transparent;border:none;cursor:pointer;transition:all .15s ease}.zoom-chip.active{background:#ffffff26;color:#ffd60a}.camera-bottom-bar{height:140px;min-height:140px;background:#000;display:flex;align-items:center;justify-content:space-between;padding:0 24px;padding-bottom:max(20px,env(safe-area-inset-bottom));flex-shrink:0}.shot-counter-group{display:flex;align-items:center;gap:8px;width:100px}.shot-wheel{display:flex;flex-direction:column;align-items:flex-end;overflow:hidden;height:80px;justify-content:center}.shot-prev,.shot-next{font-size:18px;font-weight:600;color:#fff3;line-height:1.2}.shot-current{font-size:30px;font-weight:800;color:#fff;line-height:1.2;transition:color .2s}.shot-current.urgent{color:#ff4b4b}.shot-label{display:flex;flex-direction:column}.shot-label span{font-size:10px;font-weight:700;letter-spacing:1.5px;color:#8a8a8e;text-transform:uppercase;line-height:1.4}.shutter-ring{width:88px;height:88px;border-radius:50%;border:3px solid rgba(255,255,255,.25);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:transform .1s;flex-shrink:0}.shutter-ring:active{transform:scale(.94)}.shutter-ring:disabled{opacity:.4;cursor:default}.shutter-inner{width:76px;height:76px;border-radius:50%;background:#fff;display:block;pointer-events:none}.photo-stack{width:100px;display:flex;justify-content:flex-end;position:relative;cursor:pointer}.photo-stack-cards{width:56px;height:56px;position:relative}.stack-card{width:52px;height:52px;border-radius:10px;position:absolute;top:50%;left:50%;overflow:hidden}.stack-card.back{transform:translate(-50%,-50%) translate(6px,2px) rotate(6deg);background:#ffffff14;border:2px solid rgba(255,255,255,.12)}.stack-card.front{transform:translate(-50%,-50%) rotate(-3deg);border:2px solid rgba(255,255,255,.12);background:#ffffff0f}.stack-card img{width:100%;height:100%;object-fit:cover;display:block}.stack-card.empty{border-style:dashed;background:#ffffff0f}.photo-count-badge{position:absolute;top:-4px;right:-2px;width:22px;height:22px;border-radius:50%;background:#4b9eff;border:2px solid #000;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;z-index:1}.photo-count-badge.hidden{display:none}.camera-bottom-gradient{position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(transparent,#00000073);pointer-events:none;z-index:1}.capture-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:10;transition:opacity .06s ease-out}.capture-flash.active{opacity:.7}.camera-screen .error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;padding:1rem;z-index:5}.done-screen{justify-content:center;align-items:center;text-align:center;background:#000}.done-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem}.done-check-icon{width:64px;height:64px;border-radius:50%;background:#ffffff0d;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.done-check-icon svg{width:32px;height:32px;color:#8a8a8e}.done-heading{font-family:"Instrument Serif",serif;font-size:28px;color:#fff;margin:0}.done-subtitle{color:#8a8a8e;font-size:14px;max-width:260px;text-align:center;line-height:1.5}.done-back-btn{margin-top:12px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:transparent;color:#fff;font-size:15px;font-weight:600;padding:14px 32px;cursor:pointer}.done-back-btn:active{background:#ffffff0d}.gallery-screen{padding-bottom:0}.gallery-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-shrink:0}.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;overflow-y:auto;flex:1}.photo-cell{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;border-radius:4px;background:#111}.photo-cell img{width:100%;height:100%;object-fit:cover;display:block}.photo-cell img.blurred{filter:blur(16px);transform:scale(1.1)}.blur-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#ffffffb3;font-size:.85rem;font-weight:600;background:#0000004d;pointer-events:none}.lightbox{position:fixed;inset:0;z-index:100;background:#000000f2;display:flex;align-items:center;justify-content:center}.lightbox img{max-width:100%;max-height:100%;object-fit:contain}.lightbox-close{position:absolute;top:max(1rem,env(safe-area-inset-top));right:1rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;z-index:101}
