*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;overflow-x:hidden}body,html{-ms-overflow-style:none;scrollbar-width:none}body::-webkit-scrollbar,body::-webkit-scrollbar-track,html::-webkit-scrollbar,html::-webkit-scrollbar-track{display:none}body::-webkit-scrollbar-thumb,html::-webkit-scrollbar-thumb{display:none}.app{margin:0 auto;max-width:1200px;padding:20px}.header{margin-bottom:30px;text-align:center}.header h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:10px}.header p{font-size:1.2rem;opacity:.9}.main-content{grid-gap:2rem;display:grid;gap:2rem;margin-top:1rem}.content-grid{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 250px}.camera-section,.renderer{flex-direction:column;gap:12px;justify-content:start}.camera-actions,.camera-section,.renderer{align-items:center;display:flex;width:100%}.camera-actions{flex-direction:row;gap:14px;justify-content:center;margin-top:12px}.camera-actions .btn-snapshot,.camera-actions .btn-stop{margin:0;width:190px}.video-canvas{border:3px solid #ffffff4d;border-radius:20px;box-shadow:0 20px 40px #0000004d;margin-bottom:20px;max-height:60vh;max-width:100%}.filter-scroll-container{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:2rem;overflow:hidden;overscroll-behavior-x:contain;padding:0 60px;position:relative}.scroll-arrow{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:16px;font-weight:700;height:44px;opacity:0;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;visibility:hidden;width:44px}.scroll-arrow.visible{opacity:1;visibility:visible}.scroll-arrow.left{left:10px}.scroll-arrow.right{right:10px}.scroll-arrow:hover{background:#ffffff4d;transform:translateY(-50%) scale(1.05)}.filter-scrollview{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;flex-direction:row;gap:10px;max-width:90vw;overflow-x:auto;padding:10px;scroll-behavior:smooth;scroll-snap-type:x proximity;scrollbar-width:none}.filter-scrollview::-webkit-scrollbar{display:none}.filter-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:none;border-radius:25px;color:#fff;cursor:pointer;flex-shrink:0;font-weight:500;padding:12px 20px;scroll-snap-align:start;transition:all .3s ease;white-space:nowrap}.filter-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.filter-btn.active{background:#ff6b6b;box-shadow:0 4px 10px #ff6b6b66;z-index:10}.filter-dropdown{margin-bottom:30px;text-align:center}.filter-select{-webkit-appearance:none;appearance:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff3;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 24 24'%3E%3Cpath d='m7 10 5 5 5-5z'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;background-size:20px;border:none;border-radius:28px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;max-width:90vw;min-width:280px;padding:14px 24px}.filter-select:hover{background:#ffffff4d;transform:translateY(-2px)}.filter-select:focus{background:#ff4d4d4d;box-shadow:0 4px 10px #fc4e4e66;outline:none}.filter-select option{background:#667eea;color:#fff;padding:12px}.filter-intensity{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;display:flex;flex-direction:column;margin-bottom:2rem;padding:1rem}.filter-intensity,.intensity-slider{background:#ffffff1a;background:var(--card-bg)}.intensity-slider{appearance:none;-webkit-appearance:none;border-radius:5px;height:8px;outline:none;width:200px}.intensity-slider::-webkit-slider-thumb{-webkit-appearance:none;background:#4ecdc4;background:var(--btn-primary);border-radius:50%;cursor:pointer;height:20px;width:20px}.btn-clear,.btn-snapshot,.btn-start,.btn-stop,.btn-switch{background:#4ecdc4;border:none;border-radius:50px;color:#fff;cursor:pointer;font-size:1.1rem;margin:10px;padding:15px 40px;transition:all .3s}.btn-stop{background:#ff6b6b}.btn-snapshot{background:#45b7d1}.btn-switch{background:#a29bfe}.btn-clear:hover,.btn-snapshot:hover,.btn-start:hover,.btn-stop:hover,.btn-switch:hover{box-shadow:0 10px 25px #0000004d;transform:translateY(-3px)}.error{background:#ff6b6b33;border:1px solid #ff6b6b;border-radius:10px;margin:20px 0;padding:15px}.warning-banner{animation:toastSequence 5s ease-in-out forwards;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ff453ad9;border-radius:20px;bottom:15%;box-shadow:0 4px 12px #0003;color:#fff;font-size:.85rem;font-weight:500;left:50%;max-width:90%;opacity:0;padding:8px 16px;pointer-events:none;position:absolute;text-align:center;transform:translateX(-50%);width:-webkit-max-content;width:max-content;z-index:20}@keyframes toastSequence{0%{opacity:0;transform:translate(-50%,20px)}10%{opacity:1;transform:translate(-50%)}80%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-20px);visibility:hidden}}.snapshot-gallery h2{margin-bottom:20px;text-align:center}.gallery-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.snapshot-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;padding:15px;text-align:center}.snapshot-item img{border-radius:10px;height:150px;margin-bottom:10px;object-fit:cover;width:100%}.btn-download{background:#f39c12;border:none;border-radius:20px;color:#fff;cursor:pointer;padding:8px;width:100%}:root{--bg-primary:linear-gradient(135deg,#667eea,#764ba2);--text-primary:#fff;--card-bg:#ffffff1a;--btn-primary:#4ecdc4;--btn-danger:#ff6b6b}.dark-mode{--bg-primary:linear-gradient(135deg,#1a1a2e,#16213e);--text-primary:#e0e0e0;--card-bg:#0000004d;--btn-primary:#45b7d1;--btn-danger:#ff4757}body{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--bg-primary);color:#fff;color:var(--text-primary)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.btn-clear,.btn-toggle{background:#ff6b6b;background:var(--btn-danger);border:none;border-radius:25px;color:#fff;cursor:pointer;padding:10px 20px;transition:all .3s}.btn-clear:hover{background:#ff3838;transform:translateY(-2px)}.location-panel{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff1f;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0003;margin:20px 0;max-width:250px;padding:25px}.location-panel.dark{background:#00000073;border-color:#ffffff1a}.location-coords{grid-gap:14px;display:grid;font-family:Courier New,Consolas,monospace;gap:14px;grid-template-columns:1fr;margin:22px 0}.city-display{background:#45b7d133;border:1px solid #45b7d166;border-radius:14px;font-size:1.4em;font-weight:700;padding:12px 16px;text-align:center}.accuracy,.coords,.heading{background:#ffffff14;border-left:4px solid #4ecdc4;border-radius:12px;font-size:.95em;padding:10px 14px}.btn-location{border:none;border-radius:28px;cursor:pointer;font-size:1em;font-weight:600;letter-spacing:.5px;margin-top:12px;padding:16px 24px;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.btn-location.start{background:linear-gradient(135deg,#45b7d1,#4ecdc4);box-shadow:0 8px 25px #45b7d166}.btn-location.stop{background:linear-gradient(135deg,#ff4757,#ff6b6b);box-shadow:0 8px 25px #ff475766}.btn-location.retry{background:linear-gradient(135deg,#f39c12,#f1c40f)}.btn-location:hover{box-shadow:0 15px 35px #0006;transform:translateY(-3px)}.btn-location:active{transform:translateY(-1px)}.error-message{background:#ff6b6b33;border:1px solid #ff6b6b66;border-radius:12px;color:#ff6b6b;margin:15px 0;padding:15px;text-align:center}@media (max-width:768px){.app{padding:10px}.filter-controls{align-items:center;flex-direction:column}.video-canvas{max-height:50vh}.location-panel{border-left:none;border-radius:0;border-right:none;margin:15px -15px}.city-display{font-size:1.6em}.content-grid,.main-content{gap:1.5rem}.location-panel{border-radius:20px;margin:15px 0;max-width:100%;order:2;width:100%}.content-grid{grid-template-columns:1fr}}@media (max-width:480px){.header h1{font-size:2rem}.btn-start,.btn-stop{font-size:1rem;padding:12px 30px}.filter-select{font-size:1.05rem;min-width:260px;padding:16px 20px}.camera-actions{flex-direction:column;gap:10px}}
/*# sourceMappingURL=main.3ceb6dd3.css.map*/