:root{--bg-deep: #0d0a08;--bg-surface: #1a1411;--bg-card: #241c17;--bg-elevated: #2e241d;--border: #3d3029;--border-light: #4a3d33;--cream: #f5e6d3;--cream-muted: #d4c4b0;--cream-soft: #bfad99;--burgundy: #8b2020;--burgundy-deep: #6b1818;--burgundy-glow: #a83030;--gold: #c9a96e;--gold-muted: #a08650;--text-primary: #f0e6da;--text-secondary: #9c8b7a;--text-tertiary: #6b5d52;--success: #7ab87a;--error: #c75050;--font-display: "Cormorant Garamond", "Georgia", serif;--font-body: "Space Grotesk", sans-serif}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100dvh;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;outline:none}.booth{max-width:430px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative}.booth-header{padding:1.25rem 1.25rem .75rem;text-align:center;position:relative}.booth-header:after{content:"";display:block;width:40px;height:1px;background:var(--gold);margin:.6rem auto 0;opacity:.5}.booth-logo{max-width:160px;height:auto;margin:-.5rem auto -.75rem;display:block}.booth-header h1{font-family:var(--font-display);font-size:1.4rem;font-weight:500;letter-spacing:.06em;color:var(--cream);font-style:italic}.booth-header .venue-name{font-size:.7rem;color:var(--text-secondary);margin-top:.2rem;letter-spacing:.12em;text-transform:uppercase}.steps{display:flex;justify-content:center;gap:.5rem;padding:.5rem 1rem 1rem}.step-dot{width:6px;height:6px;border-radius:50%;background:var(--border);transition:all .3s ease}.step-dot.active{background:var(--gold);width:24px;border-radius:3px;box-shadow:0 0 8px #c9a96e4d}.step-dot.done{background:var(--success)}.setup-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:2rem}.setup-screen .btn{flex:none}.setup-screen h2{font-family:var(--font-display);font-size:1.8rem;font-weight:400;color:var(--cream);letter-spacing:.02em}.photo-count-picker{display:flex;gap:1rem}.count-btn{width:72px;height:72px;border-radius:12px;background:var(--bg-surface);border:1.5px solid var(--border);color:var(--cream-muted);font-family:var(--font-display);font-size:1.6rem;font-weight:600;transition:all .25s ease}.count-btn.selected{border-color:var(--gold);background:var(--bg-card);color:var(--gold);transform:scale(1.08);box-shadow:0 0 16px #c9a96e26}.camera-container{flex:1;display:flex;flex-direction:column;align-items:center;padding:0 1rem}.viewfinder{width:100%;max-width:360px;aspect-ratio:3/4;border-radius:4px;overflow:hidden;position:relative;background:#0a0806;border:1px solid var(--border);box-shadow:0 0 0 4px var(--bg-deep),0 0 0 5px var(--border),0 8px 32px #0009}.viewfinder video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.viewfinder canvas{display:none}.photo-counter{position:absolute;top:12px;right:12px;background:#0d0a08b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;color:var(--cream);border:1px solid rgba(201,169,110,.2)}.tone-badge{position:absolute;bottom:12px;left:12px;background:#0d0a0899;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 10px;border-radius:16px;font-size:.65rem;color:var(--cream-soft);letter-spacing:.04em;text-transform:uppercase}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0d0a0880;z-index:10}.countdown-number{font-family:var(--font-display);font-size:7rem;font-weight:400;color:var(--cream);text-shadow:0 2px 30px rgba(139,32,32,.4);animation:countPulse 1s ease-in-out}@keyframes countPulse{0%{transform:scale(1.5);opacity:0}30%{transform:scale(1);opacity:1}80%{opacity:1}to{opacity:0}}.flash-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--cream);z-index:20;animation:flash .3s ease-out forwards}@keyframes flash{0%{opacity:.85}to{opacity:0}}.illumination-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;z-index:9999;opacity:1}.flash-toggle{position:absolute;top:12px;left:12px;width:36px;height:36px;border-radius:50%;background:#0d0a08b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(201,169,110,.2);color:var(--cream-soft);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .25s ease;opacity:.5;z-index:15}.flash-toggle.on{opacity:1;border-color:var(--gold);color:var(--gold);box-shadow:0 0 10px #c9a96e40}.shutter-btn{margin-top:1.25rem;width:68px;height:68px;border-radius:50%;background:var(--cream);border:3px solid var(--border);position:relative;transition:transform .15s;box-shadow:0 0 0 3px var(--bg-deep),0 0 0 4px var(--gold-muted)}.shutter-btn:active{transform:scale(.92)}.shutter-btn:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;border:1.5px solid var(--gold-muted)}.filter-section{padding:1rem}.filter-section h3{font-family:var(--font-display);font-size:.95rem;font-weight:400;font-style:italic;color:var(--text-secondary);margin-bottom:.25rem;text-align:center;letter-spacing:.02em}.filter-hint{font-size:.65rem;color:var(--text-tertiary);text-align:center;margin-bottom:.75rem;letter-spacing:.02em}.filter-row{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}.filter-chip{padding:.45rem 1rem;border-radius:20px;background:var(--bg-surface);border:1px solid var(--border);color:var(--cream-soft);font-size:.78rem;font-weight:500;transition:all .25s ease;letter-spacing:.02em}.filter-chip.active{border-color:var(--gold);color:var(--gold);background:var(--bg-card);box-shadow:0 0 12px #c9a96e1a}.layout-section{padding:0 1rem}.layout-section h3{font-family:var(--font-display);font-size:.95rem;font-weight:400;font-style:italic;color:var(--text-secondary);margin-bottom:.6rem;text-align:center;letter-spacing:.02em}.layout-row{display:flex;gap:.6rem;justify-content:center}.layout-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.6rem;border-radius:10px;background:var(--bg-surface);border:1.5px solid var(--border);transition:all .25s ease;width:72px}.layout-card.active{border-color:var(--gold);background:var(--bg-card);box-shadow:0 0 16px #c9a96e26}.layout-label{font-size:.6rem;color:var(--cream-soft);letter-spacing:.06em;text-transform:uppercase;font-weight:500}.layout-card.active .layout-label{color:var(--gold)}.layout-icon{width:48px;height:56px;display:flex;flex-direction:column;gap:2px;align-items:center;justify-content:center;position:relative}.layout-icon .layout-block{background:var(--cream-soft);border-radius:1.5px;opacity:.5;transition:opacity .2s}.layout-card.active .layout-icon .layout-block{background:var(--gold);opacity:.8}.layout-icon--classic{gap:2px}.layout-icon--classic .layout-block{width:28px;height:14px}.layout-icon--classic[data-count="1"] .layout-block{height:36px}.layout-icon--classic[data-count="2"] .layout-block{height:22px}.layout-icon--grid{flex-direction:row;flex-wrap:wrap;gap:2px;justify-content:center;align-content:center}.layout-icon--grid[data-count="1"] .layout-block{width:36px;height:36px}.layout-icon--grid[data-count="2"] .layout-block{width:20px;height:28px}.layout-icon--grid[data-count="3"] .layout-block:nth-child(1),.layout-icon--grid[data-count="3"] .layout-block:nth-child(2){width:20px;height:22px}.layout-icon--grid[data-count="3"] .layout-block:nth-child(3){width:42px;height:16px}.layout-icon--elegant{gap:2px}.layout-icon--elegant[data-count="1"] .layout-block{width:32px;height:36px}.layout-icon--elegant[data-count="2"] .layout-block:first-child{width:36px;height:28px}.layout-icon--elegant[data-count="2"] .layout-block:nth-child(2){width:36px;height:14px}.layout-icon--elegant[data-count="3"] .layout-block:first-child{width:36px;height:26px}.layout-icon--elegant[data-count="3"] .layout-block:nth-child(2),.layout-icon--elegant[data-count="3"] .layout-block:nth-child(3){width:17px;height:14px}.layout-icon--elegant[data-count="3"]{flex-direction:row;flex-wrap:wrap;justify-content:center;align-content:center}.layout-icon--elegant[data-count="3"] .layout-block:first-child{flex-basis:100%}.layout-icon--film{background:var(--bg-elevated);border-radius:3px;padding:3px 8px;flex-direction:column;gap:2px}.layout-icon--film .layout-block{width:26px;height:12px}.layout-icon--film[data-count="1"] .layout-block{height:30px}.layout-icon--film[data-count="2"] .layout-block{height:18px}.layout-icon--film .film-holes{position:absolute;top:4px;bottom:4px;width:4px;display:flex;flex-direction:column;justify-content:space-evenly}.layout-icon--film .film-holes:before,.layout-icon--film .film-holes:after{content:"";width:3px;height:3px;border-radius:.5px;background:var(--cream-soft);opacity:.3}.layout-card.active .layout-icon--film .film-holes:before,.layout-card.active .layout-icon--film .film-holes:after{background:var(--gold);opacity:.5}.layout-icon--film .film-holes.left{left:1px}.layout-icon--film .film-holes.right{right:1px}.layout-row--compact{margin-top:.5rem}.layout-chip{padding:.35rem .75rem;border-radius:16px;background:var(--bg-surface);border:1px solid var(--border);color:var(--cream-soft);font-size:.7rem;font-weight:500;transition:all .25s ease;letter-spacing:.03em}.layout-chip.active{border-color:var(--gold);color:var(--gold);background:var(--bg-card)}.preview-filters{display:flex;flex-direction:column;align-items:center}.preview-screen{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem;gap:1rem}.strip-preview{width:200px;border-radius:4px;box-shadow:0 4px 24px #00000080,0 0 0 1px var(--border);border:3px solid var(--bg-card)}.preview-actions{display:flex;gap:.6rem;width:100%;max-width:320px}.btn{flex:1;padding:.85rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;text-align:center;transition:all .2s ease;max-height:52px;letter-spacing:.02em}.btn-primary{background:var(--burgundy);color:var(--cream);border:1px solid var(--burgundy-glow)}.btn-primary:active{background:var(--burgundy-deep)}.btn-secondary{background:var(--bg-surface);color:var(--cream-muted);border:1px solid var(--border)}.btn-secondary:active{background:var(--bg-card)}.btn-download{background:var(--cream);color:var(--bg-deep)}.btn-download:active{background:var(--cream-muted)}.btn-retake{background:var(--bg-elevated);color:var(--cream-soft);border:1px solid var(--border)}.btn-retake:active{background:var(--bg-card)}.done-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem;text-align:center}.done-screen .btn{flex:none;width:100%}.done-screen .checkmark{font-size:2.5rem;color:var(--gold)}.done-screen h2{font-family:var(--font-display);font-size:1.6rem;font-weight:400;color:var(--cream);font-style:italic}.done-screen p{color:var(--text-secondary);font-size:.85rem;letter-spacing:.02em}.print-status{padding:.6rem 1.2rem;border-radius:20px;background:var(--bg-surface);border:1px solid var(--border);font-size:.8rem;color:var(--gold);letter-spacing:.02em}.loading-screen{flex:1;display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text-secondary);gap:.5rem}.spinner{width:20px;height:20px;border:1.5px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
