.app{flex-direction:column;width:100%;min-height:100dvh;display:flex;position:relative}.landing{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.landing-content{text-align:center;max-width:400px}.landing-icon{color:var(--accent);margin-bottom:16px}.landing h1{letter-spacing:2px;color:var(--white);margin-bottom:8px;font-family:Bebas Neue,sans-serif;font-size:64px;line-height:1}.landing-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:17px}.landing .btn-primary{border-radius:999px;width:100%;max-width:260px;padding:16px 32px;font-size:17px}.landing-hint{color:var(--text-muted);opacity:.6;margin-top:16px;font-size:13px}.permission{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.permission-content{text-align:center;max-width:380px}.permission-icon{color:var(--accent);margin-bottom:16px}.permission-content h2{color:var(--white);margin-bottom:8px;font-size:24px}.permission-content p{color:var(--text-muted);margin-bottom:24px;font-size:15px;line-height:1.5}.permission-error{color:#fca5a5;border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef44444d;margin-bottom:20px;padding:12px 16px;font-size:14px;line-height:1.4}.permission .btn-primary{border-radius:999px;padding:14px 32px}.setup-screen{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.setup-content{text-align:center;width:100%;max-width:420px;position:relative}.setup-back{position:absolute;top:-8px;left:-8px}.setup-title{letter-spacing:1px;color:var(--white);margin-bottom:4px;font-family:Bebas Neue,sans-serif;font-size:40px;line-height:1}.setup-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:15px}.setup-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.setup-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);flex-direction:column;align-items:center;gap:10px;padding:20px 16px;font-family:inherit;transition:all .15s;display:flex}.setup-card:hover{border-color:var(--accent);background:var(--surface-2)}.setup-card:active{transform:scale(.97)}.setup-card-count{color:var(--accent);font-family:Bebas Neue,sans-serif;font-size:28px;line-height:1}.setup-card-desc{color:var(--text-muted);font-size:13px}.layout-preview{flex-direction:column;justify-content:center;gap:3px;width:40px;height:64px;display:flex}.layout-preview.layout-grid{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:3px;display:grid}.layout-slot{background:var(--border);border-radius:2px;flex:1;min-height:0}.camera-screen{background:#000;flex-direction:column;flex:1;display:flex}.camera-viewport{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.camera-video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.photo-counter{z-index:10;gap:8px;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%)}.counter-dot{background:0 0;border:2px solid #fff9;border-radius:50%;width:10px;height:10px;transition:all .3s}.counter-dot.filled{background:var(--accent);border-color:var(--accent)}.captured-thumbs{z-index:10;flex-direction:column;gap:6px;display:flex;position:absolute;top:16px;right:16px}.thumb{object-fit:cover;border:2px solid #fff6;border-radius:4px;width:48px;height:36px;animation:.3s thumb-in}@keyframes thumb-in{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.camera-top-left{z-index:10;align-items:center;gap:6px;display:flex;position:absolute;top:16px;left:16px}.mute-toggle{color:#ffffffb3;min-width:auto;min-height:auto;padding:8px}.mute-toggle:hover{color:#fff}.mode-badge{color:#ffffffd9;cursor:pointer;background:#00000080;border:1px solid #fff3;border-radius:6px;padding:4px 10px;font-family:Bebas Neue,sans-serif;font-size:18px;line-height:1;transition:all .15s}.mode-badge:hover:not(:disabled){border-color:var(--accent);color:#fff;background:#000000b3}.mode-badge:disabled{opacity:.4;cursor:not-allowed}.shot-review-overlay{z-index:15;background:#0009;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.shot-review-photo{object-fit:contain;border-radius:var(--radius);max-width:80%;max-height:60%;box-shadow:0 8px 32px #00000080}.shot-review-bar{background:var(--accent);border-radius:2px;align-self:flex-start;max-width:80%;height:3px;margin-top:16px;margin-left:10%;transition:width .1s linear}.shot-review-actions{gap:12px;margin-top:16px;display:flex}.camera-controls{background:var(--bg);flex-direction:column;gap:16px;padding:12px 16px 24px;display:flex}.filter-strip{scrollbar-width:none;gap:6px;padding:4px 0;display:flex;overflow-x:auto}.filter-strip::-webkit-scrollbar{display:none}.filter-chip{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);background:0 0;border:2px solid #0000;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:4px;font-family:inherit;transition:border-color .15s;display:flex}.filter-chip:hover{border-color:var(--border)}.filter-chip.active{border-color:var(--accent);color:var(--text)}.filter-preview{object-fit:cover;border-radius:6px;flex-shrink:0;width:40px;height:40px}.filter-name{white-space:nowrap;font-size:11px}.capture-row{justify-content:center;align-items:center;gap:24px;display:flex}.capture-btn{border:4px solid var(--text);cursor:pointer;aspect-ratio:1;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;min-width:72px;height:72px;min-height:72px;padding:4px;transition:transform .1s;display:flex}.capture-btn:hover{transform:scale(1.05)}.capture-btn:active{transform:scale(.95)}.capture-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.capture-btn-inner{background:var(--white);border-radius:50%;width:100%;height:100%}.capture-info{color:var(--text-muted);text-align:center;min-width:60px;font-size:14px}.burst-toggle{cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:999px;justify-content:center;align-self:center;align-items:center;gap:8px;padding:6px 14px;transition:border-color .15s;display:flex}.burst-toggle:hover{border-color:var(--accent)}.burst-label{color:var(--text-muted);white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:12px}.burst-switch{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;border-radius:9px;flex-shrink:0;width:32px;height:18px;transition:background .15s,border-color .15s;display:block;position:relative}.burst-switch-on{background:var(--accent);border-color:var(--accent)}.burst-knob{background:var(--white);border-radius:50%;width:12px;height:12px;transition:transform .15s;position:absolute;top:2px;left:2px}.burst-switch-on .burst-knob{background:var(--bg);transform:translate(14px)}.countdown-overlay{z-index:20;background:#0000004d;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.countdown-number{color:#fff;text-shadow:0 4px 24px #00000080;font-family:Bebas Neue,sans-serif;font-size:160px;animation:.8s ease-out countdown-pop}@keyframes countdown-pop{0%{opacity:0;transform:scale(.5)}30%{opacity:1}to{opacity:0;transform:scale(1.4)}}@media (prefers-reduced-motion:reduce){.countdown-number{opacity:1;animation:none;transform:none}.thumb{animation:none}}.flash-overlay{z-index:25;pointer-events:none;background:#fff;animation:.3s ease-out forwards flash;position:absolute;inset:0}@keyframes flash{0%{opacity:0}20%{opacity:.7}to{opacity:0}}@media (prefers-reduced-motion:reduce){.flash-overlay{display:none}}.review-screen{flex-direction:column;flex:1;align-items:center;gap:24px;padding:24px 16px;display:flex;overflow-y:auto}.review-strip-container{flex:1;justify-content:center;align-items:center;min-height:0;display:flex}.assembling{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;display:flex}.review-strip{border-radius:var(--radius);max-width:100%;max-height:70vh;animation:.6s ease-out strip-reveal;box-shadow:0 20px 60px #00000080}@keyframes strip-reveal{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.review-strip{animation:none}}.review-controls{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:400px;display:flex}.theme-picker{background:var(--surface);border-radius:var(--radius);flex-wrap:wrap;justify-content:center;gap:4px;padding:4px;display:flex}.size-picker{background:var(--surface);border-radius:var(--radius);gap:4px;padding:4px;display:flex}.date-toggle{flex-direction:column;gap:8px;width:100%;display:flex}.toggle-row{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.toggle-label{color:var(--text-muted);font-size:14px}.toggle-switch{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;border-radius:12px;width:44px;height:24px;padding:0;font-family:inherit;transition:background .15s;position:relative}.toggle-switch.toggle-on{background:var(--accent);border-color:var(--accent)}.toggle-knob{background:var(--white);border-radius:50%;width:18px;height:18px;transition:transform .15s;position:absolute;top:2px;left:2px}.toggle-switch.toggle-on .toggle-knob{background:var(--bg);transform:translate(20px)}.date-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.date-input:focus{border-color:var(--accent)}.crop-section{width:100%}.crop-section-label{color:var(--text-muted);margin-bottom:8px;font-size:14px;display:block}.crop-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;display:grid}.crop-adjuster{flex-direction:column;gap:4px;display:flex}.crop-adjuster-label{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:11px;display:flex}.crop-reset{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:11px}.crop-reset:hover{text-decoration:underline}.crop-container{aspect-ratio:4/3;cursor:grab;background:var(--surface);border:1px solid var(--border);touch-action:none;border-radius:6px;width:100%;position:relative;overflow:hidden}.crop-container:active{cursor:grabbing}.crop-photo{object-fit:cover;pointer-events:none;width:100%;height:100%;transition:transform 50ms ease-out}.crop-crosshair{pointer-events:none;color:var(--white);opacity:0;transition:opacity .15s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.crop-container:hover .crop-crosshair,.crop-container:active .crop-crosshair{opacity:1}.review-actions{flex-wrap:wrap;justify-content:center;gap:8px;width:100%;display:flex}.review-actions .btn{flex:1;min-width:120px}@media (width>=768px){.landing h1{font-size:80px}.camera-screen{flex-direction:row}.camera-viewport{flex:1;min-width:0}.camera-controls{border-left:1px solid var(--border);flex-shrink:0;justify-content:center;width:220px;padding:16px}.filter-strip{flex-direction:column;max-height:min(400px,50vh);overflow:hidden auto}.filter-chip{flex-direction:row;gap:8px;padding:6px 8px}.filter-preview{width:32px;height:32px}.capture-row{gap:16px}.capture-btn{width:60px;min-width:60px;height:60px;min-height:60px}.review-screen{flex-direction:row;gap:40px;padding:40px}.review-strip-container{flex:1}.review-strip{max-height:85vh}.review-controls{max-width:240px}.review-actions{flex-direction:column}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0b;--surface:#141416;--surface-2:#1e1e22;--border:#2a2a2e;--text:#e4e4e7;--text-muted:#71717a;--accent:#fff;--accent-hover:#d4d4d8;--white:#fff;--radius:12px;--radius-sm:8px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:DM Sans,system-ui,-apple-system,sans-serif}body{min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;min-width:48px;min-height:48px;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:500;transition:all .15s;display:inline-flex}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:#0a0a0b}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover{color:var(--text);background:var(--surface-2)}.btn-sm{border-radius:var(--radius-sm);min-height:36px;padding:8px 16px;font-size:13px}.btn-active{background:var(--accent);color:#0a0a0b}.btn:disabled{opacity:.4;cursor:not-allowed}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}
