.toast{position:relative;display:flex;flex-direction:column;min-width:300px;max-width:500px;padding:1rem;border-radius:12px;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;transform:translateY(-20px);transition:opacity .3s ease,transform .3s ease;margin-bottom:.75rem}.toast-visible{opacity:1;transform:translateY(0)}.toast-error{background-color:#dc2626f2;border:1px solid rgba(248,113,113,.3);color:#fff}.toast-warning{background-color:#d97706f2;border:1px solid rgba(251,191,36,.3);color:#fff}.toast-success{background-color:#16a34af2;border:1px solid rgba(74,222,128,.3);color:#fff}.toast-info{background-color:#2563ebf2;border:1px solid rgba(96,165,250,.3);color:#fff}.toast-header{display:flex;align-items:flex-start;gap:.75rem}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.toast-content{flex:1;min-width:0}.toast-message{margin:0;font-size:.95rem;line-height:1.5;font-weight:500;word-wrap:break-word}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#ffffff1a;border:none;border-radius:6px;color:currentColor;cursor:pointer;transition:background-color .2s;min-width:44px;min-height:44px}.toast-close:hover{background-color:#fff3}.toast-close:active{background-color:#ffffff4d}.toast-troubleshooting{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2)}.toast-expand-button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem;background:#ffffff1a;border:none;border-radius:6px;color:currentColor;font-size:.85rem;font-weight:500;cursor:pointer;transition:background-color .2s;text-align:left;min-height:44px}.toast-expand-button:hover{background-color:#ffffff26}.toast-expand-button:active{background-color:#fff3}.expand-icon{flex-shrink:0;transition:transform .2s ease}.expand-icon.expanded{transform:rotate(180deg)}.troubleshooting-list{margin:.75rem 0 0;padding-left:1.5rem;list-style:disc}.troubleshooting-list li{margin-bottom:.5rem;font-size:.85rem;line-height:1.5;opacity:.95}.troubleshooting-list li:last-child{margin-bottom:0}@media (max-width: 480px){.toast{min-width:280px;max-width:calc(100vw - 2rem);padding:.875rem}.toast-message{font-size:.9rem}.toast-expand-button,.troubleshooting-list li{font-size:.8rem}}@media (min-width: 768px){.toast{max-width:600px}}.toast-container{position:fixed;z-index:9999;display:flex;flex-direction:column;pointer-events:none;max-height:100vh;overflow-y:auto;padding:1rem}.toast-container>*{pointer-events:auto}.toast-container-top-right{top:0;right:0;align-items:flex-end}.toast-container-top-left{top:0;left:0;align-items:flex-start}.toast-container-top-center{top:0;left:50%;transform:translate(-50%);align-items:center}.toast-container-bottom-right{bottom:0;right:0;align-items:flex-end;flex-direction:column-reverse}.toast-container-bottom-left{bottom:0;left:0;align-items:flex-start;flex-direction:column-reverse}.toast-container-bottom-center{bottom:0;left:50%;transform:translate(-50%);align-items:center;flex-direction:column-reverse}@media (max-width: 480px){.toast-container{padding:.75rem;left:0!important;right:0!important;transform:none!important;align-items:stretch!important}.toast-container>*{width:100%;max-width:none}}.toast-container::-webkit-scrollbar{width:6px}.toast-container::-webkit-scrollbar-track{background:transparent}.toast-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.toast-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:linear-gradient(135deg,#1a1a1a,#2d2d2d)}.login-card{width:100%;max-width:400px;background-color:#2a2a2a;border-radius:12px;padding:2rem;box-shadow:0 8px 32px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;margin:0 0 .5rem;color:#fff;font-weight:600}.login-header p{font-size:.95rem;color:#888;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#ccc}.form-group input{padding:.75rem 1rem;font-size:1rem;border:2px solid #3a3a3a;border-radius:8px;background-color:#1a1a1a;color:#fff;transition:border-color .2s,background-color .2s;min-height:44px}.form-group input:focus{outline:none;border-color:#646cff;background-color:#222}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:#666}.error-message{padding:.75rem 1rem;background-color:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:8px;color:#ff6b6b;font-size:.9rem;text-align:center}.login-button{padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background-color:#646cff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .1s;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px}.login-button:hover:not(:disabled){background-color:#5558dd}.login-button:active:not(:disabled){transform:scale(.98)}.login-button:disabled{opacity:.7;cursor:not-allowed}.button-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{margin-top:1.5rem;text-align:center}.login-footer p{font-size:.85rem;color:#888;margin:0}@media (max-width: 480px){.login-card{padding:1.5rem}.login-header h1{font-size:1.75rem}.form-group input,.login-button{font-size:16px}}@media (max-height: 600px) and (orientation: landscape){.login-container{padding:.5rem}.login-card{padding:1rem}.login-header{margin-bottom:1rem}.login-form{gap:1rem}}.results-display{background-color:#2a2a2af2;border-radius:12px;padding:1rem;max-height:60vh;overflow-y:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.results-empty{display:flex;align-items:center;justify-content:center;min-height:200px}.results-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#666;text-align:center}.results-placeholder svg{opacity:.5}.results-placeholder p{margin:0;font-size:1.1rem;font-weight:500;color:#888}.results-placeholder span{font-size:.9rem;color:#666}.results-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.results-header h3{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:#fff}.results-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.timestamp{font-size:.85rem;color:#888}.confidence-badge{display:inline-block;padding:.25rem .5rem;background-color:#646cff33;border:1px solid rgba(100,108,255,.3);border-radius:4px;font-size:.8rem;font-weight:500;color:#8b93ff}.results-content{display:flex;flex-direction:column;gap:1rem}.criteria-list{display:flex;flex-direction:column;gap:.75rem}.criterion-item{background-color:#1a1a1a99;border-radius:8px;padding:.75rem;border:1px solid rgba(255,255,255,.05)}.criterion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.criterion-name{font-size:.9rem;font-weight:600;color:#ccc}.criterion-confidence{font-size:.85rem;color:#888;font-weight:500}.criterion-category{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.category-name{font-size:1rem;font-weight:500;color:#fff}.price-range{font-size:.9rem;color:#4ade80;font-weight:500}.category-unclassified{font-size:.9rem;color:#888;font-style:italic}.criterion-reasoning{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.05);font-size:.85rem;color:#999;line-height:1.4}.results-summary{background-color:#646cff1a;border:1px solid rgba(100,108,255,.2);border-radius:8px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.summary-item{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.summary-item.summary-description{flex-direction:column;align-items:flex-start}.summary-label{font-size:.85rem;color:#aaa;font-weight:500}.summary-value{font-size:.9rem;color:#fff;font-weight:600}.results-footer{padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05);text-align:center}.processing-time{font-size:.8rem;color:#666}.results-display::-webkit-scrollbar{width:6px}.results-display::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.results-display::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.results-display::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width: 480px){.results-display{padding:.75rem;font-size:.9rem}.results-header h3{font-size:1rem}.criterion-item{padding:.625rem}}.status-indicators{display:flex;flex-direction:column;gap:.5rem}.status-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:#2a2a2acc;border-radius:8px;font-size:.85rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05)}.status-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.status-text{flex:1;font-weight:500}.status-detail{font-size:.75rem;color:#888}.network-status.online{border-left:3px solid #4ade80}.network-status.online .status-icon{color:#4ade80}.network-status.offline{border-left:3px solid #f87171}.network-status.offline .status-icon{color:#f87171}.classification-status.enabled{border-left:3px solid #60a5fa}.classification-status.enabled .status-icon{color:#60a5fa}.classification-status.processing{border-left:3px solid #fbbf24}.classification-status.processing .status-icon{color:#fbbf24}.classification-status.disabled{border-left:3px solid #888}.classification-status.disabled .status-icon{color:#888}.camera-status.active{border-left:3px solid #4ade80}.camera-status.active .status-icon{color:#4ade80}.camera-status.inactive{border-left:3px solid #888}.camera-status.inactive .status-icon{color:#888}.camera-status.error{border-left:3px solid #f87171}.camera-status.error .status-icon{color:#f87171}.spinner-small{width:14px;height:14px;border:2px solid rgba(251,191,36,.2);border-top-color:#fbbf24;border-radius:50%;animation:spin .8s linear infinite}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background-color:#dc262626;border:1px solid rgba(220,38,38,.3);border-left:3px solid #f87171;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.error-content{display:flex;align-items:center;gap:.75rem;flex:1}.error-content svg{flex-shrink:0;color:#f87171}.error-text{font-size:.9rem;color:#fca5a5;line-height:1.4}.error-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:none;border:none;border-radius:4px;color:#fca5a5;cursor:pointer;transition:background-color .2s;min-width:44px;min-height:44px}.error-close:hover{background-color:#dc262633}.error-close:active{background-color:#dc26264d}@media (max-width: 480px){.status-item{padding:.4rem .625rem;font-size:.8rem}.status-icon{width:18px;height:18px}.error-banner{padding:.625rem .75rem}.error-text{font-size:.85rem}}@media (min-width: 768px){.status-indicators{flex-direction:row;flex-wrap:wrap}.status-item{flex:0 1 auto}.error-banner{flex:1 1 100%}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998}.loading-spinner{position:relative;display:inline-block}.loading-spinner-small{width:24px;height:24px}.loading-spinner-medium{width:48px;height:48px}.loading-spinner-large{width:72px;height:72px}.spinner-ring{position:absolute;border:3px solid transparent;border-top-color:#646cff;border-radius:50%;animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.loading-spinner-small .spinner-ring{border-width:2px}.loading-spinner-large .spinner-ring{border-width:4px}.spinner-ring:nth-child(1){width:100%;height:100%;animation-delay:-.45s}.spinner-ring:nth-child(2){width:80%;height:80%;top:10%;left:10%;animation-delay:-.3s;border-top-color:#818cf8}.spinner-ring:nth-child(3){width:60%;height:60%;top:20%;left:20%;animation-delay:-.15s;border-top-color:#a5b4fc}.spinner-ring:nth-child(4){width:40%;height:40%;top:30%;left:30%;border-top-color:#c7d2fe}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{margin:0;font-size:1rem;color:#fff;text-align:center;font-weight:500}@media (max-width: 480px){.loading-message{font-size:.9rem}}.skeleton{background-color:#ffffff1a;border-radius:4px;position:relative;overflow:hidden}.skeleton-text{height:1em;margin-bottom:.5rem;border-radius:4px}.skeleton-rectangular{border-radius:8px}.skeleton-circular{border-radius:50%}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-wave:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:skeleton-wave 1.5s infinite}@keyframes skeleton-wave{0%{left:-100%}to{left:100%}}.skeleton-results{padding:1rem;display:flex;flex-direction:column;gap:1rem}.skeleton-criteria-list{display:flex;flex-direction:column;gap:1rem}.skeleton-criterion{padding:1rem;background-color:#2a2a2a80;border-radius:12px;display:flex;flex-direction:column;gap:.75rem}.skeleton-criterion-header{display:flex;justify-content:space-between;align-items:center}.skeleton-video{position:relative;width:100%;height:100%;background-color:#1a1a1a;display:flex;align-items:center;justify-content:center}.skeleton-video-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:1rem}@media (max-width: 480px){.skeleton-results,.skeleton-criterion{padding:.75rem}}.camera-container{width:100%;height:100vh;position:relative;overflow:hidden;background-color:#000}.video-container{width:100%;height:100%;position:relative}.video-feed{width:100%;height:100%;object-fit:cover;background-color:#000}.video-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.video-overlay>*{pointer-events:auto}.top-bar{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem;gap:1rem;background:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,transparent 100%)}.status-container{flex:1;max-width:600px;display:flex;flex-direction:column;gap:.5rem}.battery-warning{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:#fbbf2433;border:1px solid rgba(251,191,36,.4);border-left:3px solid #fbbf24;border-radius:8px;font-size:.85rem;color:#fbbf24;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.battery-warning svg{flex-shrink:0}.logout-button{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background-color:#2a2a2acc;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;cursor:pointer;transition:background-color .2s,transform .1s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logout-button:hover{background-color:#3c3c3ce6}.logout-button:active{transform:scale(.95)}.bottom-controls{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 100%)}.results-panel{max-width:600px;margin:0 auto;width:100%;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.control-buttons{display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap}.control-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.75rem 1.25rem;background-color:#2a2a2ae6;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:80px;min-height:80px}.control-button:hover:not(:disabled){background-color:#3c3c3cf2;border-color:#fff3;transform:translateY(-2px)}.control-button:active:not(:disabled){transform:translateY(0) scale(.98)}.control-button:disabled{opacity:.5;cursor:not-allowed}.control-button.primary{background-color:#646cffe6;border-color:#646cff80;min-width:100px;min-height:100px}.control-button.primary:hover:not(:disabled){background-color:#646cff;border-color:#646cffcc}.control-button.primary.active{background-color:#dc2626e6;border-color:#dc262680}.control-button.primary.active:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626cc}.control-button.secondary{background-color:#2a2a2ae6;border-color:#ffffff1a}.control-button svg{flex-shrink:0}.control-button span{font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 480px){.top-bar,.bottom-controls{padding:.75rem}.control-buttons{gap:.75rem}.control-button{min-width:70px;min-height:70px;padding:.625rem 1rem}.control-button.primary{min-width:90px;min-height:90px}.control-button span{font-size:.75rem}}@media (orientation: landscape){.top-bar{padding:.75rem 1rem}.bottom-controls{flex-direction:row;align-items:flex-end;padding:.75rem 1rem}.results-panel{flex:1;max-width:400px}.control-buttons{flex-shrink:0}}@media (min-width: 768px){.top-bar,.bottom-controls{padding:1.5rem}.control-button{min-width:90px;min-height:90px}.control-button.primary{min-width:110px;min-height:110px}}video::-webkit-media-controls{display:none!important}video::-webkit-media-controls-enclosure{display:none!important}@supports (object-fit: cover){.video-feed{object-fit:cover}}.camera-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background-color:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100}.App{width:100%;height:100vh;overflow:hidden;background-color:#1a1a1a;color:#fff}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#1a1a1a;color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#646cff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-loading p{margin-top:1rem;font-size:1.1rem;color:#888}@media (max-width: 768px){.App{font-size:14px}}.App{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}*{box-sizing:border-box;margin:0;padding:0}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:touch}body{min-width:320px;min-height:100vh;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}button,a,input[type=button],input[type=submit]{min-height:44px;min-width:44px;-webkit-tap-highlight-color:transparent;transition:all .2s ease}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text;font-size:16px}*{touch-action:manipulation}.scrollable{overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.scrollable::-webkit-scrollbar{width:6px}.scrollable::-webkit-scrollbar-track{background:transparent}.scrollable::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}@media (orientation: portrait){body{display:flex;flex-direction:column}}@media (orientation: landscape){body{display:flex;flex-direction:row}}@media (max-width: 374px){:root{font-size:14px}button,a,input[type=button],input[type=submit]{min-height:40px;min-width:40px}}@media (min-width: 375px) and (max-width: 767px){:root{font-size:16px}}@media (min-width: 768px){:root{font-size:16px}button,a,input[type=button],input[type=submit]{min-height:48px;min-width:48px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){:root{-webkit-font-smoothing:subpixel-antialiased}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-color-scheme: dark){:root{color:#ffffffde;background-color:#1a1a1a}}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}@supports (padding: max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-top:max(0px,env(safe-area-inset-top));padding-bottom:max(0px,env(safe-area-inset-bottom))}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.no-scroll{overflow:hidden;position:fixed;width:100%;height:100%}
