@import"https://fonts.googleapis.com/css?family=Roboto:400,500,700";#login-layout{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;padding:20px;box-sizing:border-box;position:relative;overflow:hidden}#login-layout:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:url(/login-bg.png);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}#login-layout:after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:1}#login-layout>*{position:relative;z-index:2}.ico{display:inline-flex;align-items:center;justify-content:center}.ico svg{display:block}.login-card{display:flex;align-items:center;justify-content:center;flex-direction:column;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0003,0 0 0 1px #fff3;border-radius:20px;border:1px solid rgba(255,255,255,.3);padding:48px 40px;width:100%;max-width:420px;margin:20px;animation:slideUp .5s ease-out}.logo-container{margin-bottom:32px}.logo-container .logo{display:flex;justify-content:center;align-items:center}.logo-container .logo svg{width:220px;height:auto}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:24px;font-weight:600;color:#1a1a1a;margin:0 0 8px}.login-header p{font-size:14px;color:#666;margin:0}.login-form{display:flex;flex-direction:column;width:100%}.form-group{display:flex;flex-direction:column;margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-group label{font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password]{font-size:15px;font-family:inherit;padding:12px 16px;width:100%;height:48px;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;background-color:#fafafa;transition:all .2s ease;box-sizing:border-box}.form-group input[type=text]::placeholder,.form-group input[type=email]::placeholder,.form-group input[type=password]::placeholder{color:#9ca3af}.form-group input[type=text]:hover:not(:disabled),.form-group input[type=email]:hover:not(:disabled),.form-group input[type=password]:hover:not(:disabled){border-color:#d1d5db;background-color:#fff}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=password]:focus{border-color:var(--r4n-color);background-color:#fff;box-shadow:0 0 0 3px #24a20b1a}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.7}.form-group input.input-error{border-color:#ef4444;background-color:#fef2f2}.form-group input.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.form-group button[type=submit]{margin-top:8px;width:100%;border:none;color:#fff;font-weight:600;font-family:inherit;background:linear-gradient(135deg,#24a20b,#1d8009);text-align:center;height:48px;border-radius:10px;transition:all .2s ease;-webkit-user-select:none;user-select:none;cursor:pointer;font-size:15px;letter-spacing:.3px;position:relative;overflow:hidden}.form-group button[type=submit]:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#2ab810,#24a20b);opacity:0;transition:opacity .2s ease}.form-group button[type=submit]:hover:not(:disabled):before{opacity:1}.form-group button[type=submit]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #24a20b4d}.form-group button[type=submit]:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #24a20b33}.form-group button[type=submit]:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-group button[type=submit] span{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:8px}.button-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.error-message{display:flex;align-items:center;gap:8px;color:#dc2626;margin:0 0 16px;text-align:left;padding:12px 16px;font-size:13px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;animation:shake .4s ease-out}.error-message svg{flex-shrink:0;width:18px;height:18px}.login-divider{display:flex;align-items:center;margin:24px 0;width:100%}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background-color:#e5e7eb}.login-divider span{padding:0 16px;font-size:13px;color:#9ca3af}.login-footer{text-align:center;margin-top:24px;width:100%}.login-footer p{font-size:14px;color:#6b7280;margin:0}.login-footer a{color:var(--r4n-color);font-weight:500;text-decoration:none;transition:color .2s ease}.login-footer a:hover{color:#1d8009;text-decoration:underline}.forgot-password{text-align:right;margin-top:8px;margin-bottom:8px}.forgot-password a{font-size:13px;color:#6b7280;text-decoration:none;transition:color .2s ease}.forgot-password a:hover{color:var(--r4n-color)}@media (max-width: 480px){.login-card{padding:32px 24px;margin:16px;border-radius:16px;background:#ffffffe6}.logo-container .logo svg{width:180px}.login-header h1{font-size:20px}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group button[type=submit]{height:44px;font-size:14px}}.register-card{display:flex;align-items:center;justify-content:center;flex-direction:column;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0003,0 0 0 1px #fff3;border-radius:20px;border:1px solid rgba(255,255,255,.3);padding:40px;width:100%;max-width:480px;margin:20px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.register-card .logo-container{margin-bottom:24px}.register-card .logo-container .logo{display:flex;justify-content:center;align-items:center}.register-card .logo-container .logo svg{width:180px;height:auto}.register-header{text-align:center;margin-bottom:24px}.register-header h1{font-size:22px;font-weight:600;color:#1a1a1a;margin:0 0 6px}.register-header p{font-size:14px;color:#666;margin:0}.register-form{display:flex;flex-direction:column;width:100%}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.register-form .form-group{display:flex;flex-direction:column;margin-bottom:14px}.register-form .form-group:last-child{margin-bottom:0}.register-form .form-group label{font-size:13px;font-weight:500;color:#374151;margin-bottom:5px}.register-form .form-group input[type=text],.register-form .form-group input[type=email],.register-form .form-group input[type=password],.register-form .form-group input[type=tel],.register-form .form-group select{font-size:14px;font-family:inherit;padding:10px 14px;width:100%;height:44px;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;background-color:#fafafa;transition:all .2s ease;box-sizing:border-box}.register-form .form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.register-form .form-group input::placeholder{color:#9ca3af}.register-form .form-group input:hover:not(:disabled),.register-form .form-group select:hover:not(:disabled){border-color:#d1d5db;background-color:#fff}.register-form .form-group input:focus,.register-form .form-group select:focus{border-color:var(--r4n-color);background-color:#fff;box-shadow:0 0 0 3px #24a20b1a}.register-form .form-group input:disabled,.register-form .form-group select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.7}.register-form .form-group input.input-error{border-color:#ef4444;background-color:#fef2f2}.register-form .form-group input.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.user-type-options{display:flex;gap:12px}.user-type-option{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1.5px solid #e5e7eb;border-radius:10px;background-color:#fafafa;cursor:pointer;transition:all .2s ease;font-size:14px;color:#374151}.user-type-option input[type=radio]{display:none}.user-type-option:hover{border-color:#d1d5db;background-color:#fff}.user-type-option.selected{border-color:var(--r4n-color);background-color:#24a20b0d;color:var(--r4n-color)}.user-type-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.user-type-icon svg{width:100%;height:100%}.register-form .form-group button[type=submit]{margin-top:8px;width:100%;border:none;color:#fff;font-weight:600;font-family:inherit;background:linear-gradient(135deg,#24a20b,#1d8009);text-align:center;height:48px;border-radius:10px;transition:all .2s ease;-webkit-user-select:none;user-select:none;cursor:pointer;font-size:15px;letter-spacing:.3px;position:relative;overflow:hidden}.register-form .form-group button[type=submit]:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#2ab810,#24a20b);opacity:0;transition:opacity .2s ease}.register-form .form-group button[type=submit]:hover:not(:disabled):before{opacity:1}.register-form .form-group button[type=submit]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #24a20b4d}.register-form .form-group button[type=submit]:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #24a20b33}.register-form .form-group button[type=submit]:disabled{opacity:.6;cursor:not-allowed;transform:none}.register-form .form-group button[type=submit] span{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:8px}.register-form .button-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.register-form .error-message{display:flex;align-items:center;gap:8px;color:#dc2626;margin:0 0 14px;text-align:left;padding:10px 14px;font-size:13px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;animation:shake .4s ease-out}.register-form .error-message svg{flex-shrink:0;width:18px;height:18px}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.register-footer{text-align:center;margin-top:20px;width:100%}.register-footer p{font-size:14px;color:#6b7280;margin:0}.register-footer a{color:var(--r4n-color);font-weight:500;text-decoration:none;transition:color .2s ease}.register-footer a:hover{color:#1d8009;text-decoration:underline}.password-requirements{display:flex;flex-direction:column;gap:6px;padding:12px 14px;background:#00000008;border-radius:8px;margin-bottom:8px}.password-requirements .requirement{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280;transition:color .2s ease}.password-requirements .requirement.met{color:#059669}.password-requirements .requirement .check-icon{width:16px;height:16px;flex-shrink:0;color:#d1d5db;transition:color .2s ease}.password-requirements .requirement .check-icon.checked{color:#059669}@media (max-width: 520px){.register-card{padding:28px 20px;margin:16px;border-radius:16px;background:#ffffffe6;max-width:none}.register-card .logo-container .logo svg{width:150px}.register-header h1{font-size:18px}.form-row{flex-direction:column;gap:0}.register-form .form-group input,.register-form .form-group select,.register-form .form-group button[type=submit]{height:42px;font-size:14px}.user-type-options{gap:8px}.user-type-option{padding:10px 12px;font-size:13px}}.layout-loading{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);position:relative;overflow:hidden}.layout-loading:before{content:"";position:absolute;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(36,162,11,.05) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(0,159,223,.05) 0%,transparent 50%);animation:gradient-shift 8s ease-in-out infinite;pointer-events:none}@keyframes gradient-shift{0%,to{transform:translate(-25%,-25%) rotate(0)}50%{transform:translate(-25%,-25%) rotate(180deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;position:relative;z-index:1}.loading-spinner{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.loading-spinner__circle{position:absolute;border-radius:50%;border:3px solid transparent;animation-timing-function:cubic-bezier(.4,0,.2,1)}.loading-spinner__circle--1{width:80px;height:80px;border-top-color:var(--r4n-color);border-right-color:var(--r4n-color);animation:spin-outer 1.5s linear infinite}.loading-spinner__circle--2{width:60px;height:60px;border-bottom-color:var(--logo-blue);border-left-color:var(--logo-blue);animation:spin-middle 1.2s linear infinite reverse}.loading-spinner__circle--3{width:40px;height:40px;border-top-color:#24a20b;border-right-color:#24a20b;animation:spin-inner .9s linear infinite}@keyframes spin-outer{0%{transform:rotate(0);opacity:1}50%{opacity:.8}to{transform:rotate(360deg);opacity:1}}@keyframes spin-middle{0%{transform:rotate(0);opacity:.9}50%{opacity:.7}to{transform:rotate(360deg);opacity:.9}}@keyframes spin-inner{0%{transform:rotate(0) scale(1);opacity:.8}50%{transform:rotate(180deg) scale(.95);opacity:.6}to{transform:rotate(360deg) scale(1);opacity:.8}}.loading-text{display:flex;flex-direction:column;align-items:center;gap:8px;animation:fade-in .6s ease-in-out}.loading-text__main{font-size:24px;font-weight:700;color:#2c3e50;letter-spacing:1px;animation:pulse-text 2s ease-in-out infinite}.loading-text__sub{font-size:14px;font-weight:400;color:#7f8c8d;animation:dots 1.5s steps(4,end) infinite}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.7}}@keyframes dots{0%,20%{content:""}40%{color:#7f8c8d}60%{color:#95a5a6}80%,to{color:#7f8c8d}}@media (max-width: 768px){.loading-spinner,.loading-spinner__circle--1{width:60px;height:60px}.loading-spinner__circle--2{width:45px;height:45px}.loading-spinner__circle--3{width:30px;height:30px;border-width:2px}.loading-text__main{font-size:20px}.loading-text__sub{font-size:13px}}@media (max-width: 480px){.loading-spinner{width:50px;height:50px}.loading-spinner__circle--1{width:50px;height:50px;border-width:2px}.loading-spinner__circle--2{width:38px;height:38px;border-width:2px}.loading-spinner__circle--3{width:26px;height:26px;border-width:2px}.loading-text__main{font-size:18px}.loading-text__sub{font-size:12px}.loading-container{gap:24px}}.loading-error{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;max-width:300px;animation:fade-in .3s ease-in-out;cursor:help}.loading-error__icon{width:18px;height:18px;color:#ef4444;flex-shrink:0}.loading-error__text{font-size:12px;color:#dc2626;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-reduced-motion: reduce){.loading-spinner__circle{animation-duration:3s}.layout-loading:before{animation:none}@keyframes spin-outer,@keyframes spin-middle,@keyframes spin-inner{from {transform: rotate(0deg);} to {transform: rotate(360deg);}}}#layout-error{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;font-size:30px;color:#666}.error-content{text-align:center;padding:40px}.error-content h1{color:#666;margin-bottom:20px;font-size:30px}.error-content p{color:#666;margin-bottom:30px;font-size:16px}.error-content button{padding:10px 20px;background-color:#24a20b;color:#fff;border:1px solid #1d8009;border-radius:3px;cursor:pointer;font-size:14px;font-weight:700}.error-content button:hover{background:linear-gradient(to bottom,#24a20b,#1a7309);border-color:#145807}#layout-database-error{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background-color:#fff;padding:20px}.database-error-content{text-align:center;padding:40px;background:#f7f7f7;box-shadow:0 2px 2px #0000004d;border-radius:2px;max-width:600px;width:100%}.database-error-icon{font-size:48px;margin-bottom:20px}.database-error-content h1{color:#222;margin-bottom:20px;font-size:24px;font-weight:500}.error-message{color:red;margin-bottom:30px;font-size:14px;padding:15px;background-color:transparent;border:none;border-radius:0}.error-suggestions{text-align:left;margin:30px 0;padding:20px;background-color:#fff;border-radius:2px}.error-suggestions h3{margin:0 0 15px;color:#222;font-size:14px;font-weight:500}.error-suggestions ul{margin:0;padding-left:20px;color:#666;font-size:13px}.error-suggestions li{margin-bottom:8px;line-height:1.6}.error-actions{display:flex;gap:15px;justify-content:center;margin-top:30px}.btn-retry,.btn-logout{padding:8px 16px;border:1px solid #1d8009;border-radius:3px;font-size:11px;font-weight:700;text-transform:uppercase;cursor:pointer;transition:all .218s;-webkit-user-select:none;user-select:none}.btn-retry{background:linear-gradient(to bottom,#24a20b,#1c8208);color:#fff;text-shadow:0 1px rgba(0,0,0,.1)}.btn-retry:hover{border:1px solid #145807;background:linear-gradient(to bottom,#24a20b,#1a7309);text-shadow:0 1px rgba(0,0,0,.3);box-shadow:0 1px 1px #0000001a}.btn-logout{background-color:#f5f5f5;color:#222;border-color:#d9d9d9}.btn-logout:hover{background-color:#eee;border-color:#ccc}@media (max-width: 600px){.error-actions{flex-direction:column}.btn-retry,.btn-logout{width:100%}}.waiting-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:20px}.waiting-card{display:flex;align-items:center;justify-content:center;flex-direction:column;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000004d,0 0 0 1px #fff3;border-radius:24px;border:1px solid rgba(255,255,255,.3);padding:48px 40px;width:100%;max-width:440px;animation:fadeIn .6s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.waiting-card .logo-container{margin-bottom:24px}.waiting-card .logo-container .logo{display:flex;justify-content:center;align-items:center}.waiting-card .logo-container .logo svg{width:180px;height:auto}.waiting-icon{width:80px;height:80px;margin-bottom:24px;color:#f59e0b;animation:pulse 2s ease-in-out infinite}.waiting-icon svg{width:100%;height:100%}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.waiting-content{text-align:center;margin-bottom:32px}.waiting-content h1{font-size:24px;font-weight:600;color:#1a1a1a;margin:0 0 12px}.waiting-message{font-size:15px;color:#6b7280;margin:0 0 16px;line-height:1.5}.waiting-user{font-size:14px;color:#9ca3af;margin:0}.waiting-user strong{color:#374151;font-weight:500}.waiting-info{width:100%;display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.info-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;color:#15803d;font-size:14px}.info-item svg{width:20px;height:20px;flex-shrink:0}.info-item.pending{background:#fffbeb;border-color:#fde68a;color:#b45309}.logout-button{width:100%;padding:14px 24px;border:1.5px solid #e5e7eb;border-radius:10px;background:transparent;color:#6b7280;font-size:15px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.logout-button:hover{border-color:#d1d5db;background:#f9fafb;color:#374151}.logout-button:active{background:#f3f4f6}@media (max-width: 480px){.waiting-card{padding:32px 24px;border-radius:20px}.waiting-card .logo-container .logo svg{width:150px}.waiting-icon{width:64px;height:64px}.waiting-content h1{font-size:20px}.waiting-message{font-size:14px}.info-item{padding:10px 14px;font-size:13px}}.control{flex:1 0 0;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}.control .search{position:relative;flex:1 0 0;display:flex;flex-direction:row;align-items:center;background:#eee;border-radius:4px;padding:7px}.control .search .ico-search{fill:#000;opacity:.54;width:20px;height:20px;margin-right:5px;cursor:pointer}.control .search input[type=text]{flex:1 0 0;font-size:16px;height:24px;border:none;padding:0 5px;outline:none;background:transparent}.control .search input[type=text]::-webkit-input-placeholder{color:#000;opacity:.54}.control .search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:4px;padding:0;border:none;background:transparent;cursor:pointer;opacity:.54;transition:opacity .15s ease}.control .search-clear:hover{opacity:1}.control .search-clear svg{fill:#000}.control .search-driver-tag{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 10px;background:linear-gradient(135deg,#4caf50,#45a049);border-radius:16px;color:#fff;font-size:13px;font-weight:500;white-space:nowrap;box-shadow:0 2px 4px #4caf504d}.control .search-driver-tag svg{fill:#fff;opacity:.9;flex-shrink:0}.control .search-driver-tag span{max-width:180px;overflow:hidden;text-overflow:ellipsis}.control .search-driver-tag-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:2px;padding:0;border:none;background:#fff3;border-radius:50%;cursor:pointer;transition:background-color .15s ease;flex-shrink:0}.control .search-driver-tag-remove:hover{background:#ffffff59}.control .search-driver-tag-remove svg{fill:#fff;opacity:1}.control .search-suggestions{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:4px;background:#fff;border-radius:6px;box-shadow:0 4px 16px #00000026;overflow:hidden}.control .search-suggestions-header{padding:8px 12px 4px;font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.control .search-suggestion{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;color:#333;font-size:14px;text-align:left;cursor:pointer;transition:background-color .15s ease}.control .search-suggestion:hover,.control .search-suggestion--selected{background:#f5f5f5}.control .search-suggestion svg{fill:#888;flex-shrink:0}.control .search-suggestion span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.control .actions{display:flex;flex-direction:row;align-items:center;margin-left:5px}.control .actions input[type=range]{width:80px;height:20px;padding:6px;outline:none;background:transparent;border-radius:2px;cursor:pointer;-webkit-appearance:none}.control .actions input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;height:20px;width:8px;background:#757575;margin-top:-8px;border-radius:2px;box-shadow:0 0 3px #0003}.control .actions input[type=range]:hover::-webkit-slider-thumb{background:#24a20b}.control .actions input[type=range]::-webkit-slider-runnable-track{height:5px;background:#eee;border-radius:4px}.control .actions a{display:flex;justify-content:center;align-items:center;width:32px;height:32px;margin:0 2px;border-radius:2px}.control .actions a svg{fill:#0000008a;width:20px;height:20px}.control .actions a:hover{background:#eee}.control .actions a:hover svg{fill:#000}.control .actions a.active{background:#24a20b}.control .actions a.active svg{fill:#fff}.control .modules{display:flex;flex-direction:row;align-items:center;margin-left:2px;padding-left:2px;border-left:2px solid #eee}.control .modules a{display:flex;justify-content:center;align-items:center;width:32px;height:32px;margin:0 2px;border-radius:2px}.control .modules a svg{fill:#0000008a;width:20px;height:20px}.control .modules a:hover{background:#009fdf}.control .modules a:hover svg{fill:#fff}.control .modules a.downloading{background:#24a20b}.control .modules a.downloading svg{fill:#fff}#user{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;margin-right:5px}.user-name{margin-bottom:2px;overflow:hidden;font-size:12px;font-weight:700;color:#222;display:flex;align-items:center;gap:6px}.user-role-badge{font-size:10px;font-weight:400;color:#666;background-color:#f0f0f0;padding:2px 6px;border-radius:3px;white-space:nowrap}.user-links{display:flex;align-items:center;font-size:12px}.user-links a{color:#24a20b;text-decoration:none}.user-links a:hover{text-decoration:underline}.user-delimiter{color:#24a20b;opacity:.54;margin:0 3px;-webkit-user-select:none;user-select:none}.header{flex:0 0 53px;display:flex;flex-direction:row;background:#fff;box-shadow:0 2px 4px #0003;z-index:2;min-height:53px}.header-title{flex:0 0 auto;display:flex;justify-content:center;align-items:center;padding:0 15px}.header-logo-link{display:flex;align-items:center;text-decoration:none}.header-title .logo{display:flex;justify-content:center;align-items:center}.header-title .logo svg{width:110px;height:auto}.header-nav{flex:0 0 auto;display:flex;align-items:center;gap:5px;padding:0 10px}.header-nav-link{display:flex;align-items:center;padding:8px 16px;text-decoration:none;color:#222;font-size:14px;font-weight:500;border-radius:4px;transition:background-color .2s ease;white-space:nowrap}.header-nav-link:hover{background-color:#f5f5f5}.header-nav-link.active{background-color:#e8f4fd;color:#06c}.header-center{flex:1;display:flex;justify-content:flex-start;align-items:center;padding-left:10px}.header-right{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding-right:5px}.header-menu-toggle{display:block;background:none;border:none;cursor:pointer;padding:8px;margin-right:8px;color:#222}.header-menu-toggle svg{display:block}.header-menu-toggle:hover{background-color:#f5f5f5;border-radius:4px}.header-menu-toggle-right{margin-left:8px}.header-profile-link{display:flex;align-items:center;justify-content:center;padding:8px;color:#222;text-decoration:none;border-radius:4px;transition:background-color .2s ease}.header-profile-link:hover{background-color:#f5f5f5}.header-profile-link svg{display:block}@media (max-width: 768px){.header-title{flex:0 0 auto;min-width:0;padding:0 10px}.header-title .logo svg{width:80px}.header-nav{display:none}.header-center{flex:1;overflow:hidden;min-width:0}.header-right{flex-shrink:0}}.content-mode-switcher{display:flex;background:#0000000f;border-radius:6px;padding:2px;width:100%}.content-mode-btn{display:flex;align-items:center;justify-content:center;gap:5px;flex:1;padding:6px 0;border:none;border-radius:4px;background:transparent;color:#666;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.content-mode-btn:hover{color:#333;background:#0000000a}.content-mode-btn.active{background:#fff;color:var(--r4n-color, #24a20b);box-shadow:0 1px 3px #0000001f;font-weight:600}.content-mode-btn svg{flex-shrink:0}.content-mode-btn.active svg{stroke:var(--r4n-color, #24a20b)}.events-list{flex-grow:1;overflow-y:scroll;margin-right:8px;-webkit-user-select:none;user-select:none}.events-list-section{padding:4px 0;border-bottom:1px solid #e5e5e5;margin-bottom:8px}.events-list-switcher{padding:8px 10px}.events-list-search{display:flex;align-items:center;margin:0 10px 8px;padding:0 8px;height:30px;background:#0000000d;border-radius:6px;border:1px solid transparent;transition:border-color .15s,background .15s}.events-list-search:focus-within{border-color:var(--r4n-color, #24a20b);background:#fff}.events-list-search-icon{flex-shrink:0;color:#999}.events-list-search:focus-within .events-list-search-icon{color:var(--r4n-color, #24a20b)}.events-list-search-input{flex:1;border:none;outline:none;background:transparent;font-size:12px;color:#222;padding:0 6px;height:100%;font-family:inherit}.events-list-search-input::placeholder{color:#aaa}.events-list-search-clear{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;border-radius:50%;background:#0000001f;color:#666;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.events-list-search-clear:hover{background:#0003;color:#333}.dashboard-link{display:flex;align-items:center;height:40px;text-decoration:none;color:#222;cursor:pointer;position:relative}.dashboard-link:hover{background-color:#e1e1e1}.dashboard-link.active{color:#24a20b;font-weight:700}.dashboard-link .border{flex:0 0 4px;width:4px;height:24px;background-color:transparent}.dashboard-link.active .border{background-color:#24a20b}.dashboard-link:hover:not(.active) .border{background-color:#646464}.dashboard-icon{width:20px;height:20px;margin:0 6px;opacity:.54;display:flex;align-items:center;justify-content:center}.dashboard-icon svg{width:20px;height:20px;fill:currentColor}.dashboard-link.active .dashboard-icon{opacity:1}.dashboard-link.active .dashboard-icon svg{fill:#24a20b}.dashboard-text{font-size:13px}.events-list-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 8px 10px}.events-list-section-header .section-title{font-size:11px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:.5px}.new-event-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;cursor:pointer;color:#666;border-radius:4px;transition:all .15s ease}.new-event-btn:hover{background-color:#24a20b;color:#fff}.events-list ul{list-style:none;padding:0;margin:0}.events-list li{margin:0}.events-list .event-row{display:flex;flex-direction:row;align-items:center;width:100%}.events-list .event{display:flex;flex:1 1 auto;flex-direction:row;align-items:center;color:#222;height:40px;text-decoration:none;overflow:hidden;white-space:nowrap;min-width:0;position:relative}.events-list .event-name-link{flex:1 1 auto;min-width:0;text-decoration:none;color:inherit;display:flex;align-items:center;position:relative;z-index:1;cursor:pointer}.events-list .event-name-link:hover{text-decoration:none}.events-list .event.has-children{cursor:pointer}.events-list .event:hover{text-decoration:none;background-color:#e1e1e1}.events-list .event.active{color:#24a20b;font-weight:700;background-color:transparent}.events-list .event.active:hover{background-color:transparent}.events-list .border{flex:0 0 4px;width:4px;height:24px;background-color:transparent}.events-list .event.active .border{background-color:#24a20b}.events-list .event:hover:not(.active) .border{background-color:#646464}.events-list .event-icon-wrapper{position:relative;width:20px;height:16px;margin:0 6px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.events-list .event-icon-svg{width:20px;height:16px;opacity:.54;display:inline-flex;align-items:center;justify-content:center;position:relative;z-index:1}.events-list .event-icon-svg svg{width:20px;height:16px;fill:currentColor}.events-list .event-subfolder-indicator{position:absolute;right:-4px;bottom:-2px;width:10px;height:8px;opacity:.7;z-index:2;pointer-events:none}.events-list .event-subfolder-indicator svg{width:10px;height:8px;fill:currentColor}.events-list .event.active .event-icon-svg{opacity:1}.events-list .event.active .event-icon-svg svg{fill:#24a20b}.events-list .event.active .event-subfolder-indicator svg{fill:#24a20b}.events-list .event-name{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.events-list .event-item-count{font-size:11px;color:#888;background-color:#00000014;padding:2px 6px;border-radius:10px;margin-left:4px;flex-shrink:0;font-weight:400}.events-list .event-video-count:before{content:"🎬 ";font-size:9px}.events-list .event-photo-count:before{content:"📷 ";font-size:9px}.events-list .event.active .event-item-count{color:#24a20b;background-color:#24a20b1f}.events-list .event-context-menu{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-left:auto;margin-right:8px;cursor:pointer;opacity:.6;flex-shrink:0;z-index:2}.events-list .event-context-menu:hover{opacity:1;background-color:#0000001a;border-radius:4px}.events-list .event-context-menu-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.events-list .event-context-menu-icon svg{width:20px;height:20px;fill:currentColor}.events-list-loading{display:flex;align-items:center;justify-content:center;padding-top:96px;color:#666;font-size:13px}.dashboard{padding:24px;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.dashboard-loading{display:flex;align-items:center;justify-content:center;height:200px;color:#666;font-size:14px}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e5e5}.production-info{flex:1}.production-name{margin:0 0 12px;font-size:42px;font-weight:700;color:#1a1a1a;letter-spacing:-.5px}.production-description{margin:0;font-size:14px;color:#666;max-width:600px}.dashboard-stats{display:flex;gap:24px}.stat{display:flex;flex-direction:column;align-items:center;padding:16px 24px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;min-width:100px}.stat-value{font-size:28px;font-weight:700;color:#24a20b}.stat-label{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.dashboard-content{width:100%}.section-title{font-size:18px;font-weight:600;color:#1a1a1a;margin:0 0 20px}.no-events{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#f8f9fa;border-radius:12px;text-align:center}.no-events-icon{width:48px;height:48px;margin-bottom:16px;opacity:.4}.no-events-icon svg{width:100%;height:100%;fill:#666}.no-events p{margin:0;color:#666;font-size:14px}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.event-card{display:flex;flex-direction:column;padding:20px;background:#fff;border:1px solid #e5e5e5;border-radius:12px;text-decoration:none;color:inherit;transition:all .2s ease;cursor:pointer}.event-card:hover{border-color:#24a20b;box-shadow:0 4px 12px #24a20b1a;transform:translateY(-2px)}.event-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.event-type-badge{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,#24a20b,#1d8509);color:#fff;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:4px}.event-card-title{margin:0 0 16px;font-size:18px;font-weight:600;color:#1a1a1a;line-height:1.3}.event-card-meta{display:flex;flex-direction:column;gap:8px;margin-top:auto}.meta-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#666}.meta-icon{width:16px;height:16px;flex-shrink:0}.meta-icon svg{width:100%;height:100%;fill:#999}.my-media-card{background:linear-gradient(135deg,#f0f7ee,#e8f5e4);border-color:#c8e6c0}.my-media-card:hover{border-color:#24a20b;background:linear-gradient(135deg,#e8f5e4,#d8efd2)}.my-media-badge{background:linear-gradient(135deg,#666,#555)!important}.my-media-icon-wrapper{display:flex;justify-content:center;margin:8px 0 16px}.my-media-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.my-media-icon svg{width:100%;height:100%;fill:#24a20b}@media (max-width: 768px){.dashboard{padding:16px}.dashboard-header{flex-direction:column;gap:20px}.dashboard-stats{width:100%;justify-content:center}.production-name{font-size:32px}.events-grid{grid-template-columns:1fr}}@media (max-width: 480px){.dashboard-stats{gap:12px}.stat{padding:12px 16px;min-width:80px}.stat-value{font-size:22px}}.dashboard-page{display:flex;flex-direction:column;height:100vh;width:100%}.dashboard-page.resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.dashboard-page.resizing *{cursor:col-resize!important}.dashboard-page-main{flex-grow:1;display:flex;flex-direction:row;overflow:hidden;position:relative}.dashboard-page-sidebar{flex:0 0 250px;width:250px;display:flex;flex-direction:column;padding-top:8px;border-right:1px solid #e1e1e1;background:#fff;position:relative}.dashboard-page-sidebar .sidebar-resize-handle{position:absolute;top:0;right:0;width:4px;height:100%;cursor:col-resize;background:transparent;z-index:10;transition:background-color .2s ease}.dashboard-page-sidebar .sidebar-resize-handle:hover{background:#24a20b}.dashboard-page-content{flex:1 1 0;display:flex;flex-direction:column;overflow:auto;background:#fafafa}@media (max-width: 768px){.dashboard-page-sidebar{position:fixed;left:0;top:53px;bottom:0;width:250px!important;flex-basis:250px!important;z-index:1000;box-shadow:2px 0 8px #00000026;border-right:none}.dashboard-page-sidebar .sidebar-resize-handle{display:none}.dashboard-page-content{width:100%;margin-left:0}}@media (max-width: 480px){.dashboard-page-sidebar{width:100%!important;max-width:280px}}.item-thumbnail-image{position:absolute;border:0;width:100%;height:100%;object-fit:cover;top:0;left:0}.item-thumbnail-loading{display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.item-thumbnail-loading svg{width:40px;height:40px}.item-thumbnail-driver-name{font-size:10px;color:#fff;background-color:#0000008a;border-radius:2px;padding:2px 5px;position:absolute;left:8px;bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 100px);display:inline-flex;align-items:center;gap:4px}.item-thumbnail-driver-name.item-thumbnail-analyzing{background-color:#24a20bcc;font-style:italic}.item-thumbnail-analyzing-spinner{display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px}.item-thumbnail-analyzing-spinner svg{animation:spin 1s linear infinite}.item-thumbnail-position{display:inline-flex;position:absolute;bottom:0;left:0;right:0;height:6px;background-color:#0003;overflow:hidden}.item-thumbnail-position>span{position:absolute;display:inline-flex;width:6px;transform:translate(-50%);top:0;bottom:0;background-color:red}.item-thumbnail{background-color:#fafafa;position:relative;overflow:hidden}.item-thumbnail-content{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center}.item-thumbnail-content svg{width:50%;height:50%;fill:#a6a6a6}.item-thumbnail-duration{font-size:10px;color:#fff;background-color:#0000008a;border-radius:2px;padding:2px 5px;position:absolute;right:8px;bottom:8px}.item-thumbnail-video-preview{display:inline-flex;align-items:center;justify-content:center;position:absolute;right:5px;top:5px;width:26px;height:26px;background-color:#0003;border-radius:50%;cursor:pointer}.item-thumbnail-video-preview>span{width:20px;height:20px}.item-thumbnail-video-preview svg{fill:#fff;width:20px;height:20px}.item-thumbnail-video-preview:hover{background-color:#24a20b}.item-thumbnail-warning{display:inline-flex;align-items:center;justify-content:center;position:absolute;left:5px;top:5px;width:26px;height:26px;background-color:#0003;border-radius:50%}.item-thumbnail-warning>span{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:#fff;background-color:#ffa700;border-radius:50%;font-weight:700}.title-autocomplete{position:relative;min-width:0;flex:1}.title-autocomplete__display{display:flex;align-items:center;height:18px;font-size:13px;font-weight:500;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:2px;padding:0 2px}.title-autocomplete__display:hover{background-color:#0000000f}.title-autocomplete__display--empty{color:#0006;font-style:italic;font-weight:400}.item.selected .title-autocomplete__display:hover{background-color:#ffffff26}.item.selected .title-autocomplete__display--empty{color:#ffffff80}.title-autocomplete__input{width:100%;height:18px;border:none;outline:none;background:#fffffff2;font-size:13px;font-weight:500;font-family:inherit;color:#000;padding:0 2px;border-radius:2px;box-shadow:0 0 0 1px #0003}.title-autocomplete__input:focus{box-shadow:0 0 0 2px #1976d2}.title-autocomplete__dropdown{position:fixed;min-width:180px;max-height:200px;overflow-y:auto;background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:10000;padding:2px 0}.title-autocomplete__option{display:flex;align-items:center;width:100%;padding:4px 8px;font-size:12px;color:#333;cursor:pointer;border:none;background:none;text-align:left;font-family:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.title-autocomplete__option:hover,.title-autocomplete__option--active{background-color:#e3f2fd;color:#1565c0}.title-autocomplete__option--active{font-weight:500}.title-autocomplete__empty{padding:6px 8px;font-size:12px;color:#999;font-style:italic}.title-autocomplete__saving{display:flex;align-items:center;height:18px;font-size:12px;color:#0006;font-style:italic;padding:0 2px}.item{display:inline-block;background-color:#fff;margin:0 0 8px 8px;border-radius:1px;box-shadow:0 1px 1px #0003;-webkit-user-select:none;user-select:none;cursor:pointer;vertical-align:top}.item:hover{box-shadow:0 2px 8px #00000040}.item.selected{background-color:#24a20b;box-shadow:0 2px 8px #00000040;color:#fff}.item.item-missing-driver-id{background-color:#ffebee;border:1px solid #ffcdd2}.item.item-missing-driver-id:hover{background-color:#ffcdd2;box-shadow:0 2px 8px #f443364d}.item.item-missing-driver-id.selected{background-color:#d32f2f;border-color:#c62828}.item-header{display:flex;flex-direction:row;height:20px;overflow:hidden;align-items:center}.item-checkbox{width:16px;height:16px;margin:0 4px;cursor:pointer;flex-shrink:0}.item-markers{display:flex;flex-direction:row;align-items:center;padding:0 3px}.item-date{flex-basis:100%;font-size:11px;padding:3px;overflow:hidden;text-overflow:ellipsis;text-align:right}.item-time{font-size:12px;font-weight:700;padding:3px}.item-footer{display:flex;flex-direction:row;height:40px}.item-footer-left{display:flex;flex-direction:column;justify-content:center;flex-grow:1;overflow:hidden;padding:0 8px 0 3px}.item-footer-right{display:flex;flex-direction:row;justify-content:center;align-items:center}.item-title,.item-location{display:flex;align-items:center;height:18px;font-size:13px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.item-title{font-weight:500}.item-location{font-size:11px;opacity:.7}.item-download{display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;margin:0 3px;background-color:#eee;border-radius:50%;text-decoration:none;border:none;padding:0;cursor:pointer}.item-download:hover{text-decoration:none}.item-download:hover svg{fill:#000}.item-download svg{width:18px;height:18px}.item-download.origin svg{fill:var(--r4n-color)}.item-download.encoded svg{fill:#7441a9}.item-analyze{display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;margin:0 3px;background-color:#eee;border-radius:50%;border:none;cursor:pointer;padding:0;text-decoration:none;transition:background-color .2s}.item-analyze:hover:not(:disabled){background-color:#ddd}.item-analyze:disabled{opacity:.6;cursor:not-allowed}.item-analyze.analyzing{cursor:wait}.item-analyze-spinner{animation:spin 1s linear infinite}.item-analyze svg{width:18px;height:18px;stroke:#333;color:#333}.item-analyze-analyzed svg{stroke:#24a20b;color:#24a20b}.item-analyze-analyzed:hover{background-color:#e8f5e9}.item-analyze-retry{background-color:#ffebee;border:1px solid #ffcdd2}.item-analyze-retry:hover:not(:disabled){background-color:#ffcdd2}.item-analyze-retry svg{stroke:#d32f2f;color:#d32f2f}.item-progress{display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;margin:0 3px;background-color:#eee;border-radius:50%}.item-progress svg{width:18px;height:18px}.item-progress.origin svg{fill:none;stroke:var(--r4n-color)}.item-progress.encoded svg{fill:none;stroke:#7441a9}.item-marker{display:inline-flex;justify-content:center;align-items:center;width:10px;height:10px;margin:0 3px 0 0;border:1px solid;border-radius:50%;color:#fff;font-size:8px;-webkit-user-select:none;user-select:none}.item-marker.number{background-color:#4e4e4e;border-color:#444}.item-marker.red{background-color:#fb6360;border-color:#fb3c39}.item-marker.orange{background-color:#f6a756;border-color:#f4912c}.item-marker.yellow{background-color:#f3cf5f;border-color:#f0c337}.item-marker.green{background-color:#71cb5f;border-color:#4ebf38}.item-marker.blue{background-color:#57b7f0;border-color:#2da6ed}.item-marker.purple{background-color:#cf87de;border-color:#c36ad6}.item-marker.gray{background-color:#a4a4a7;border-color:#8e8e91}.item-progress.copying,.item-progress.compressing{position:relative}.item-progress.copying svg,.item-progress.compressing svg{fill:none}.item-state-progress-icon{position:absolute;width:10px;height:10px;top:50%;left:50%;transform:translate(-50%,-50%)}.item-state-icon{display:inline-flex;justify-content:center;align-items:center;width:24px;height:24px;margin:0 3px;background-color:#eee;border-radius:50%}.item-state-icon svg{width:14px;height:14px}.item-state-icon.copied svg{stroke:#2196f3}.item-state-icon.copied{background-color:#e3f2fd}.item-photo-thumbnail{position:relative;overflow:hidden;background:var(--card-color-background, #f7f7f7)}.item-photo-thumbnail img{transition:opacity .15s ease}.item-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--card-color-background, #f7f7f7)}.item-photo-placeholder svg{stroke:#bbb}.item-photo-format{position:absolute;top:4px;right:4px;background:#0000008c;color:#fff;font-size:10px;padding:1px 5px;border-radius:3px;text-transform:uppercase;font-weight:600}.item-photo-zoom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:50%;cursor:pointer;opacity:0;transition:opacity .2s ease,transform .2s ease;z-index:2}.item-photo-zoom svg{stroke:#fff}.item-photo-thumbnail:hover .item-photo-zoom{opacity:1;transform:translate(-50%,-50%) scale(1)}.item-photo-zoom:hover{background:#000000b3}.item-photo-processing-overlay{position:absolute;bottom:0;left:0;right:0;background:#0009;display:flex;flex-direction:column;align-items:center;padding:6px 8px;gap:3px;z-index:3}.item-photo-processing-bar{width:100%;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.item-photo-processing-fill{height:100%;background:var(--r4n-color, #ff6b00);border-radius:2px;transition:width .3s ease}.item-photo-processing-text{color:#fff;font-size:10px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.item-photo-thumbnail .item-thumbnail-accuracy{opacity:.7;font-size:10px}.item-photo-thumbnail .item-thumbnail-accuracy.uncertain{color:#ff9800}.download-progress{position:fixed;bottom:20px;right:20px;background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:500px;z-index:1000}.download-progress-bar{width:100%;height:8px;background:#eee;border-radius:4px;overflow:hidden;margin-bottom:8px}.download-progress-fill{height:100%;background:#24a20b;transition:width .3s ease;border-radius:4px}.download-progress-info{display:flex;flex-direction:column;gap:4px}.download-progress-text{font-size:14px;color:#333;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.download-progress-details{display:flex;justify-content:space-between;align-items:center;gap:12px}.download-progress-stats{font-size:12px;color:#666}.download-progress-speed{font-size:12px;color:#24a20b;font-weight:500}.sdcard-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.sdcard-detail{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.sdcard-detail__header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #eee;position:sticky;top:0;background-color:#fff;z-index:1;border-radius:8px 8px 0 0}.sdcard-detail__header h3{margin:0;font-size:18px;font-weight:600;color:#333}.sdcard-detail__uuid{font-size:11px;color:#999;font-family:monospace;display:block;margin-top:2px}.sdcard-detail__header-info{display:flex;flex-direction:column;gap:12px}.sdcard-detail__close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #ddd;border-radius:4px;background-color:#fff;color:#666;cursor:pointer;transition:all .15s;font-size:18px;line-height:1}.sdcard-detail__close-btn:hover{background-color:#f0f0f0;color:#333;border-color:#ccc}.sdcard-detail__body{padding:20px;display:flex;flex-direction:column;gap:20px}.sdcard-detail__loading{text-align:center;padding:40px;color:#888}.sdcard-detail__section{background-color:#f9f9f9;border-radius:8px;padding:16px 20px;border:1px solid #eee}.sdcard-detail__section-header{font-size:16px;font-weight:600;color:#333;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #b2c819}.sdcard-detail__info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px}.sdcard-detail__info-item{display:flex;flex-direction:column;gap:2px}.sdcard-detail__info-label{font-size:12px;font-weight:500;color:#888;text-transform:uppercase;letter-spacing:.5px}.sdcard-detail__info-value{font-size:14px;color:#333;word-break:break-all}.sdcard-detail__empty{text-align:center;padding:12px;color:#999;font-size:14px;font-style:italic;margin:0}.sdcard-detail__select-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.sdcard-detail__select-label{font-size:13px;color:#666;font-weight:500;white-space:nowrap}.sdcard-detail__select{flex:1;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;background-color:#fff;cursor:pointer}.sdcard-detail__select:focus{outline:none;border-color:#b2c819}.sdcard-detail__status{padding:8px 12px;border-radius:4px;font-size:13px;margin-bottom:12px}.sdcard-detail__status--success{background-color:#d4edda;color:#155724}.sdcard-detail__status--error{background-color:#f8d7da;color:#721c24}.sdcard-detail__actions{display:flex;flex-direction:column;gap:8px}.sdcard-detail__btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.sdcard-detail__btn:disabled{background:#ccc!important;cursor:not-allowed;opacity:.7}.sdcard-detail__btn--primary{background:#b2c819;color:#fff}.sdcard-detail__btn--primary:hover:not(:disabled){background:#9ab015}.sdcard-detail__btn--secondary{background:#6c757d;color:#fff}.sdcard-detail__btn--secondary:hover:not(:disabled){background:#5a6268}.sdcard-detail__name-edit{display:flex;align-items:center;gap:4px}.sdcard-detail__name-input{flex:1;padding:4px 8px;border:1px solid #b2c819;border-radius:4px;font-size:13px;outline:none;min-width:120px}.sdcard-detail__name-input:focus{box-shadow:0 0 0 2px #b2c8194d}.sdcard-detail__name-save,.sdcard-detail__name-cancel{width:24px;height:24px;padding:0;border:none;border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.sdcard-detail__name-save{background:#b2c819;color:#fff}.sdcard-detail__name-save:disabled{background:#ccc;cursor:not-allowed}.sdcard-detail__name-cancel{background:#eee;color:#666}.sdcard-detail__name-cancel:hover{background:#ddd}.sdcard-detail__name-display{display:inline-flex;align-items:center;gap:6px;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .15s}.sdcard-detail__name-display:hover{background:#f0f0f0}.sdcard-detail__name-display svg{color:#999;flex-shrink:0}.sdcard-detail__name-display:hover svg{color:#666}.sdcard-detail__name-display em{color:#aaa;font-style:italic}@media (max-width: 768px){.sdcard-detail{max-width:100%;max-height:95vh;margin:10px}.sdcard-detail__info-grid{grid-template-columns:1fr}.sdcard-detail__select-row{flex-direction:column;align-items:stretch}}.group{margin-bottom:12px}.group-header{border-bottom:4px solid #24a20b;padding:8px 0 4px;margin:0 8px 8px;display:flex;justify-content:space-between;align-items:center}.group-header>span{display:flex;align-items:center;gap:6px}.group-header.web-card{border-bottom-color:#6366f1}.group-header.web-card .web-card-icon,.group-header.web-card strong{color:#6366f1}.group-header.photo-group{display:flex;align-items:center;justify-content:space-between;padding:8px 12px}.photo-group-info{display:flex;align-items:center;gap:8px}.photo-group-icon{opacity:.7;flex-shrink:0}.photo-group-email{color:#999;font-size:12px;margin-left:4px}.photo-group-count{background:#00000014;padding:2px 8px;border-radius:10px;font-size:11px;color:#757575;font-weight:500}.group-header-actions{display:flex;align-items:center;gap:8px}.group-items{margin-bottom:8px;display:block}.group-download-card{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#24a20b;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background .2s}.group-download-card:hover:not(:disabled){background:#1d7d09}.group-download-card:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.group-download-card svg{width:16px;height:16px;fill:currentColor}.group-analyze-card{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background .2s}.group-analyze-card:hover:not(:disabled){background:#1565c0}.group-analyze-card:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.group-analyze-card svg{width:16px;height:16px;stroke:currentColor;fill:none}.group-menu-wrapper{position:relative}.group-menu-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;color:#666;transition:all .15s}.group-menu-btn:hover{background:#e9ecef;border-color:#ddd;color:#333}.group-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.group-menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:100;min-width:180px;padding:4px 0}.group-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;cursor:pointer;font-size:13px;color:#333;text-align:left;white-space:nowrap;transition:background .1s}.group-menu-item:hover:not(:disabled){background:#f0f0f0}.group-menu-item:disabled{color:#aaa;cursor:not-allowed}.group-menu-item svg{flex-shrink:0}.group-card-label{display:inline-flex;align-items:baseline;gap:6px}.group-card-uuid{font-size:10px;color:#999;font-family:monospace}.group-sdcard-info-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:transparent;border:1px solid #ccc;border-radius:50%;cursor:pointer;color:#666;transition:all .15s}.group-sdcard-info-btn:hover{background:#e9ecef;border-color:#999;color:#333}.group-sdcard-info-btn svg{width:14px;height:14px}.upload-zone-container{width:100%}.upload-zone-layout{display:grid;grid-template-columns:280px 1fr;gap:16px;align-items:start}.upload-zone{display:flex;align-items:center;justify-content:center;height:100px;padding:16px;border:2px dashed #d1d5db;border-radius:8px;background:#fff;cursor:pointer;transition:all .15s ease}.upload-zone:hover{border-color:#9ca3af;background:#fafafa}.upload-zone.drag-over{border-color:#24a20b;background:#24a20b0d;border-style:solid}.upload-zone.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.upload-zone-input{display:none}.upload-zone-content{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.upload-zone-icon{color:#9ca3af;transition:color .15s ease}.upload-zone:hover .upload-zone-icon,.upload-zone.drag-over .upload-zone-icon{color:#24a20b}.upload-zone-text{display:flex;flex-direction:column;gap:2px}.upload-zone-primary{font-size:13px;font-weight:500;color:#374151}.upload-zone-secondary{font-size:11px;color:#9ca3af}.upload-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.upload-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px}.upload-item.completed{border-color:#24a20b4d;background:#24a20b08}.upload-item.error{border-color:#dc26264d;background:#dc262608}.upload-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.upload-item-info{display:flex;align-items:center;gap:8px}.upload-item-name{flex:1;font-size:12px;font-weight:500;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.upload-item-size{font-size:11px;color:#9ca3af;flex-shrink:0}.upload-item-status{display:flex;align-items:center;gap:8px}.upload-item-progress{flex:1;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}.upload-item-progress-bar{height:100%;background:linear-gradient(90deg,#24a20b,#16a34a);border-radius:2px;transition:width .2s ease}.upload-item-percent{font-size:11px;font-weight:500;color:#374151;min-width:32px;text-align:right}.upload-item-error-text{font-size:11px;color:#dc2626}.upload-item-completed-text{font-size:11px;font-weight:500;color:#16a34a}.upload-item-pending-text{font-size:11px;color:#9ca3af}.upload-item-actions{display:flex;gap:4px;flex-shrink:0}.upload-action-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:4px;background:#f3f4f6;color:#6b7280;cursor:pointer;transition:all .15s ease}.upload-action-btn:hover{background:#e5e7eb}.upload-action-btn.resume:hover{background:#dcfce7;color:#16a34a}.upload-action-btn.cancel:hover{background:#fee2e2;color:#dc2626}@media (max-width: 768px){.upload-zone-layout{grid-template-columns:1fr;gap:12px}.upload-zone{height:80px;padding:12px}.upload-zone-icon{width:20px;height:20px}.upload-zone-primary{font-size:12px}.upload-list{max-height:150px}.upload-item{padding:6px 10px}.upload-item-name{font-size:11px}}@media (max-width: 480px){.upload-zone{height:70px}.upload-zone-secondary{display:none}}.event-info-box{background:#fff;border-bottom:1px solid #e5e7eb;margin:0 8px}.event-info-bar{display:flex;align-items:center;gap:16px;padding:10px 12px;min-height:48px}.event-info-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.event-info-name{margin:0;font-size:15px;font-weight:600;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.event-info-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b7280}.event-info-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.event-info-badge.type{background:#24a20b1a;color:#1d8009}.event-info-date{color:#9ca3af}.event-info-stats-bar{display:flex;align-items:center;gap:16px;padding:0 12px;border-left:1px solid #e5e7eb;border-right:1px solid #e5e7eb}.stat-item{display:flex;align-items:center;gap:6px;color:#6b7280;font-size:13px;font-weight:500;white-space:nowrap}.stat-item svg{color:#9ca3af;flex-shrink:0}.stat-item span{color:#374151}.event-info-actions{display:flex;align-items:center;gap:8px}.upload-toggle-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.upload-toggle-btn:hover{background:#f9fafb;border-color:#d1d5db}.upload-toggle-btn.active{background:#24a20b14;border-color:#24a20b4d;color:#1d8009}.upload-toggle-btn.active svg{color:#24a20b}.upload-toggle-btn.has-uploads{border-color:#24a20b}.upload-toggle-btn svg{color:#9ca3af;transition:color .15s ease}.upload-toggle-btn:hover svg{color:#6b7280}.upload-count{display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#24a20b;color:#fff;font-size:11px;font-weight:600}.event-info-upload-section{padding:12px;background:#f9fafb;border-top:1px solid #e5e7eb;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 900px){.event-info-bar{flex-wrap:wrap;gap:10px}.event-info-left{flex:1 1 100%;order:1}.event-info-stats-bar{flex:1;order:2;border-left:none;padding-left:0}.event-info-actions{order:3}}@media (max-width: 640px){.event-info-bar{padding:8px 10px}.event-info-name{font-size:14px}.event-info-stats-bar{gap:12px;padding:0;border:none}.stat-item{font-size:12px;gap:4px}.stat-item svg{width:12px;height:12px}.upload-toggle-btn{padding:5px 10px;font-size:12px}.upload-toggle-btn span{display:none}.event-info-upload-section{padding:10px}}@media (max-width: 480px){.event-info-meta{flex-wrap:wrap;gap:4px}.event-info-stats-bar{gap:8px}.stat-item span{font-size:11px}}.event-grid-filters{background:#f5f5f5;border-bottom:1px solid #ddd;display:flex;flex-direction:column}.filter-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;background:none;border:none;cursor:pointer;font-size:13px;color:#333;transition:background .2s}.filter-toggle:hover{background:#e8e8e8}.filter-toggle-icon{display:flex;align-items:center;width:16px;height:16px;opacity:.7}.filter-toggle-icon svg{width:16px;height:16px;stroke:currentColor}.filter-toggle-text{font-weight:500}.filter-badge{background:#24a20b;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:600;min-width:18px;text-align:center}.filter-chevron{display:flex;align-items:center;width:14px;height:14px;margin-left:auto;opacity:.6}.filter-chevron svg{width:14px;height:14px;stroke:currentColor}.filter-content{padding:8px 12px;display:flex;flex-direction:column;gap:8px;border-top:1px solid #ddd}.filter-section{display:flex;flex-direction:column;gap:4px}.filter-row{display:flex;align-items:center;gap:8px}.filter-label{font-size:12px;font-weight:500;color:#333;white-space:nowrap}.filter-section-toggle{display:flex;align-items:center;gap:6px;padding:4px 0;background:none;border:none;cursor:pointer;text-align:left}.filter-section-toggle:hover .filter-label{color:#24a20b}.filter-chevron-small{display:flex;align-items:center;width:12px;height:12px;opacity:.6;margin-left:auto}.filter-chevron-small svg{width:12px;height:12px;stroke:currentColor}.filter-racers-content{display:flex;flex-direction:column;gap:6px;padding-left:4px}.filter-actions{display:flex;gap:8px;margin-bottom:4px}.filter-link{background:none;border:none;color:#24a20b;font-size:11px;cursor:pointer;padding:0;text-decoration:underline}.filter-link:hover:not(:disabled){color:#1d7d09}.filter-link:disabled{color:#999;cursor:not-allowed;text-decoration:none}.filter-options{display:flex;gap:4px;flex-wrap:wrap}.filter-button{padding:4px 10px;border:1px solid #ddd;background:#fff;border-radius:3px;cursor:pointer;font-size:12px;color:#333;transition:all .2s}.filter-button:hover{background:#f0f0f0;border-color:#24a20b}.filter-button.active{background:#24a20b;border-color:#24a20b;color:#fff}.racer-names-list{display:flex;flex-direction:column;gap:4px;max-height:150px;overflow-y:auto;padding:6px;background:#fff;border:1px solid #ddd;border-radius:3px}.racer-name-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer;padding:2px 0;font-size:12px;color:#333}.racer-name-checkbox:hover{color:#24a20b}.racer-name-checkbox input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:#24a20b}.racer-name-checkbox span{-webkit-user-select:none;user-select:none}.filter-actions-row{flex-wrap:wrap}.filter-action-button{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:12px;color:#333;transition:all .2s}.filter-action-button:hover:not(:disabled){background:#f0f0f0}.filter-action-button:disabled{opacity:.6;cursor:not-allowed}.filter-action-danger{border-color:#dc3545;color:#dc3545}.filter-action-danger:hover:not(:disabled){background:#dc3545;color:#fff}.filter-action-icon{display:flex;align-items:center;width:14px;height:14px}.filter-action-icon svg{width:14px;height:14px;stroke:currentColor}.download-selection{position:fixed;bottom:20px;right:20px;z-index:1000}.download-selection-panel{background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:400px}.download-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #eee}.download-selection-title{font-size:16px;font-weight:600;color:#333}.download-selection-close{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#666;border-radius:4px;transition:background .2s}.download-selection-close:hover{background:#f0f0f0}.download-selection-close svg{width:16px;height:16px;fill:currentColor}.download-selection-content{display:flex;flex-direction:column;gap:12px}.download-selection-progress{display:flex;flex-direction:column;gap:8px;padding:12px;background:#f9f9f9;border-radius:6px;margin-bottom:8px}.download-selection-progress-bar{width:100%;height:8px;background:#eee;border-radius:4px;overflow:hidden}.download-selection-progress-fill{height:100%;background:#24a20b;transition:width .3s ease;border-radius:4px}.download-selection-progress-info{display:flex;flex-direction:column;gap:4px}.download-selection-progress-text{font-size:14px;color:#333;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.download-selection-progress-details{display:flex;justify-content:space-between;align-items:center;gap:12px}.download-selection-progress-stats{font-size:12px;color:#666}.download-selection-progress-speed{font-size:12px;color:#24a20b;font-weight:500}.download-selection-info{font-size:14px;color:#666;margin:0}.download-selection-info strong{color:#333;font-weight:600}.download-selection-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#24a20b;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.download-selection-button:hover:not(:disabled){background:#1d7d09}.download-selection-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.download-selection-button svg{width:20px;height:20px;fill:currentColor}.download-selection-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.download-selection-select-folder{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#f0f0f0;border:1px solid #ddd;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;color:#333}.download-selection-select-folder:hover:not(:disabled){background:#e0e0e0}.download-selection-select-folder:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.download-selection-select-folder svg{width:18px;height:18px;fill:currentColor}.download-selection-selected-folder{font-size:14px;color:#666;padding:8px 12px;background:#f9f9f9;border-radius:6px;border:1px solid #e0e0e0}.download-selection-selected-folder strong{color:#333;font-weight:600}.download-selection-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto;margin-top:8px}.download-selection-file{display:flex;align-items:center;justify-content:space-between;padding:8px;border-radius:4px;background:#f9f9f9;transition:background .2s}.download-selection-file:hover{background:#f0f0f0}.download-selection-file.completed{background:#e8f5e9}.download-selection-file.failed{background:#ffebee}.download-selection-file.downloading{background:#e3f2fd}.download-selection-file.cancelled{background:#f5f5f5;opacity:.6}.download-selection-file-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.download-selection-file-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px;color:#666}.download-selection-file.completed .download-selection-file-icon{color:#24a20b}.download-selection-file.failed .download-selection-file-icon{color:#d32f2f}.download-selection-file.downloading .download-selection-file-icon{color:#1976d2}.download-selection-file.cancelled .download-selection-file-icon{color:#999}.download-selection-file-spinner{animation:spin 1s linear infinite}.download-selection-file-details{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.download-selection-file-name{font-size:13px;color:#333;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;flex-wrap:wrap;gap:4px}.download-selection-file-size{color:#666;font-size:.9em;font-weight:400}.download-selection-total-size{margin-top:12px;padding-top:12px;border-top:1px solid #eee;font-size:14px;color:#333;text-align:center}.download-selection-file-progress-bar{width:100%;height:4px;background:#0000001a;border-radius:2px;overflow:hidden;margin:4px 0}.download-selection-file-progress-fill{height:100%;background:#1976d2;transition:width .3s ease;border-radius:2px}.download-selection-file-speed{font-size:11px;color:#1976d2;font-weight:500}.download-selection-file-error{font-size:11px;color:#d32f2f}.download-selection-file-remove{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#999;border-radius:4px;transition:all .2s;flex-shrink:0}.download-selection-file-remove:hover:not(:disabled){background:#0000000d;color:#333}.download-selection-file-remove:disabled{opacity:.3;cursor:not-allowed}.download-selection-file-remove svg{width:16px;height:16px;fill:currentColor}.event-grid-wrapper{flex:1 1 0;display:flex;flex-direction:column;overflow:hidden}.grid{flex:1 1 0;display:flex;flex-direction:column;overflow:scroll;padding-top:8px}.grid .group{margin-bottom:12px}.grid .group-header{border-bottom:4px solid #24a20b;padding:8px 0 4px;margin:0 8px 8px}.detail .group-header{margin:0;border-bottom:none;padding:0}.grid .group-items{margin-bottom:8px}.grid .empty{align-self:center;display:flex;flex-direction:column;align-items:center;padding-top:96px}.grid .empty .error{color:#666;font-size:16px}.grid .empty .error-ico{margin-bottom:8px}.grid .empty .error-ico svg{width:60px;height:60px;fill:#ff0000b3}.grid .empty .loading{padding-top:45px}.grid .empty .loading svg{width:30px;height:30px}.grid .empty .no-files{display:flex;justify-content:center;align-items:center;width:120px;height:120px;border-radius:50%;background-color:#fafafa}.grid .empty .no-files svg{width:72px;height:72px;opacity:.2}.my-media-sections{flex:1 1 0;display:flex;flex-direction:column;overflow-y:auto;padding-top:8px;gap:4px}.my-media-section{display:flex;flex-direction:column;min-height:0}.my-media-section-header{display:flex;align-items:center;gap:8px;padding:10px 12px;margin:0 8px;border-bottom:3px solid #24a20b;color:#24a20b;-webkit-user-select:none;user-select:none}.my-media-section-header.photo{border-bottom-color:#2196f3;color:#2196f3}.my-media-section-header svg{flex-shrink:0}.my-media-section-title{font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.my-media-section-count{font-size:12px;font-weight:500;opacity:.7;margin-left:auto}.my-media-section-content{display:flex;flex-direction:column;padding:4px 0}.my-media-empty{display:flex;flex-direction:column;align-items:center;padding:32px 0;gap:8px;color:#999;font-size:13px}.my-media-empty .no-files{display:flex;justify-content:center;align-items:center;width:64px;height:64px;border-radius:50%;background-color:#fafafa}.my-media-empty .no-files svg{width:36px;height:36px;opacity:.2}.input-edit{width:100%;border:none;outline:none;background:transparent;font-size:inherit;font-family:inherit;color:inherit}.input-empty{color:#0000008a;cursor:pointer}.input-view{cursor:pointer}.input-view:hover{text-decoration:underline}.driver-dropdown{position:relative;width:100%}.driver-dropdown--loading{opacity:.6}.driver-dropdown__trigger{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;background:#0000000a;border:1px solid #e1e1e1;border-radius:6px;color:#333;font-size:13px;cursor:pointer;transition:all .15s ease;text-align:left}.driver-dropdown__trigger:hover:not(:disabled){background:#0000000f;border-color:#ccc}.driver-dropdown__trigger--open{border-color:var(--r4n-color, #24a20b);background:#fff;box-shadow:0 0 0 2px #24a20b1f}.driver-dropdown__trigger--disabled{opacity:.5;cursor:not-allowed}.driver-dropdown__icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.driver-dropdown__icon svg{width:16px;height:16px;fill:#999}.driver-dropdown__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.driver-dropdown__arrow{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;transition:transform .2s ease}.driver-dropdown__trigger--open .driver-dropdown__arrow{transform:rotate(180deg)}.driver-dropdown__arrow svg{width:18px;height:18px;fill:#999}.driver-dropdown__menu{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1000;background:#fff;border:1px solid #e1e1e1;border-radius:6px;box-shadow:0 4px 16px #0000001a;overflow:hidden}.driver-dropdown__search{padding:8px;border-bottom:1px solid #eee}.driver-dropdown__search-input{width:100%;padding:6px 10px;background:#00000008;border:1px solid #e1e1e1;border-radius:4px;color:#333;font-size:13px;outline:none;transition:border-color .15s ease}.driver-dropdown__search-input:focus{border-color:var(--r4n-color, #24a20b);background:#fff}.driver-dropdown__search-input::placeholder{color:#aaa}.driver-dropdown__list{list-style:none;margin:0;padding:4px 0;max-height:240px;overflow-y:auto}.driver-dropdown__list::-webkit-scrollbar{width:6px}.driver-dropdown__list::-webkit-scrollbar-track{background:transparent}.driver-dropdown__list::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.driver-dropdown__empty{padding:12px 16px;color:#999;font-size:13px;text-align:center}.driver-dropdown__item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;background:transparent;border:none;color:#333;font-size:13px;cursor:pointer;transition:background-color .1s ease;text-align:left}.driver-dropdown__item:hover{background:#0000000a}.driver-dropdown__item--active{background:#24a20b0f;color:var(--r4n-color, #24a20b);font-weight:500}.driver-dropdown__item-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.driver-dropdown__item-icon svg{width:16px;height:16px;fill:currentColor;opacity:.5}.driver-dropdown__item--active .driver-dropdown__item-icon svg{opacity:.8}.driver-dropdown__item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.driver-dropdown__item-check{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.driver-dropdown__item-check svg{width:16px;height:16px;fill:var(--r4n-color, #24a20b)}.driver-dropdown__error{margin-top:4px;padding:6px 10px;background:#dc35450f;border:1px solid rgba(220,53,69,.2);border-radius:4px;color:#d32f2f;font-size:12px}.driver-dropdown__placeholder{display:block;padding:6px 10px;color:#999;font-size:13px}.detail .group-header{color:#757575;font-size:13px;font-weight:400;margin-bottom:0}.group-title.one-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail .group-thumbnail{align-self:center;width:100%;margin-bottom:0}.detail .group-line{display:flex;flex-direction:row;margin-bottom:0}.detail .group-line--column{flex-direction:column;gap:4px}.detail .group-value--full{width:100%}.detail .group-label{flex:0 0 70px;font-size:13px;color:#0000008a}.detail .group-value{flex-grow:1;width:160px;font-size:13px}.detail .group-markers{display:flex;flex-direction:row;justify-content:center;margin-bottom:0}.detail .item-marker-wrapper{display:inline-flex;justify-content:center;align-items:center;width:22px;height:22px;margin:0 1px;cursor:pointer;border:1px solid transparent;border-radius:50%}.detail .item-marker-wrapper.enabled{background-color:#e0e0e0;border-color:#999}.detail .item-marker-wrapper:hover{box-shadow:0 0 2px #00000080}.detail .item-marker{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}.detail .item-marker.red{background:#fb6360;border-color:#fb3c39}.detail .item-marker.orange{background:#f6a756;border-color:#f4912c}.detail .item-marker.yellow{background:#f3cf5f;border-color:#f0c337}.detail .item-marker.green{background:#71cb5f;border-color:#4ebf38}.detail .item-marker.blue{background:#57b7f0;border-color:#2da6ed}.detail .item-marker.purple{background:#cf87de;border-color:#c36ad6}.detail .item-marker.gray{background:#a4a4a7;border-color:#8e8e91}.detail .item-marker.number{width:16px;height:16px;padding:0;border-radius:50%;background:#4e4e4e;border-color:#444;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.detail .group-warning{background-color:#ffa700;color:#fff;padding:3px;margin:6px 0;text-align:center;line-height:normal;font-size:13px}.detail .group-download{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none}.detail .group-download>span{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;margin-right:6px;vertical-align:text-bottom}.detail .group-download>span svg{width:14px;height:14px;fill:#fff}.detail .group-download.origin{color:var(--r4n-color)}.detail .group-download.origin>span{background-color:var(--r4n-color)}.detail .group-download.encoded{color:#7441a9}.detail .group-download.encoded>span{background-color:#7441a9}.detail .group-download-uploading{display:flex;align-items:center;gap:6px;color:inherit}.detail .group-download-progress{display:inline-flex;justify-content:center;align-items:center;width:18px;height:18px;flex-shrink:0}.detail .group-download-progress svg{width:18px;height:18px}.detail .delimiter{margin:10px 0 0;padding-bottom:10px;border-top:1px solid #e1e1e1;background:transparent;height:1px;min-height:1px}.detail .group-mac{color:inherit;text-decoration:none;cursor:pointer}.detail .group-mac:hover{text-decoration:underline}.detail .group-remove{display:flex;justify-content:center;align-items:center}.detail .button{padding:5px 14px;background:#0000000a;color:#555;border:1px solid #e1e1e1;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;min-width:0;height:auto;line-height:1.4;transition:background .15s,color .15s,border-color .15s,box-shadow .15s}.detail .button:hover{background:#00000012;border-color:#ccc;color:#333}.detail .button--primary{background:var(--r4n-color, #24a20b);color:#fff;border-color:var(--r4n-color, #24a20b)}.detail .button--primary:hover{opacity:.9}.detail .button--danger{color:#d32f2f;border-color:#d32f2f40;background:#d32f2f0a}.detail .button--danger:hover{background:#d32f2f1a;border-color:#d32f2f66;color:#c62828}.detail .button--warning{color:#e65100;border-color:#e6510040;background:#e651000a}.detail .button--warning:hover{background:#e651001a;border-color:#e6510066;color:#bf360c}.detail .button--disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.ai-badge{display:inline-block;padding:1px 8px;border-radius:3px;font-size:11px;font-weight:600;line-height:18px}.ai-badge--manual{background-color:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.photo-detail-viewer{background:var(--card-color-background, #f7f7f7);border-radius:4px;overflow:auto;display:flex;align-items:center;justify-content:center;min-height:120px;max-height:300px;margin-bottom:10px}.photo-detail-viewer.photo-detail-viewer--zoomed{max-height:500px}.photo-detail-image{max-width:100%;max-height:300px;object-fit:contain;cursor:zoom-in;display:block}.photo-detail-image--zoomed{max-width:none;max-height:none;width:auto;height:auto;cursor:zoom-out;min-height:200px}.photo-detail-placeholder{padding:24px;color:#999;font-size:13px}.photo-detail-downloads{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.button--download{padding:5px 14px;background:var(--r4n-color, #24a20b);color:#fff;border:1px solid var(--r4n-color, #24a20b);border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;text-decoration:none;min-width:0;height:auto;line-height:1.4;display:inline-flex;align-items:center;justify-content:center;gap:4px;transition:background .15s,border-color .15s,box-shadow .15s}.button--download:hover{background:#1b8a06;border-color:#1b8a06;box-shadow:0 1px 4px #24a20b40}.ai-badge--manual{display:inline-block;padding:2px 8px;background:#e3a008;color:#fff;border-radius:4px;font-size:12px}@media (max-width: 768px){.photo-detail-viewer,.photo-detail-image{max-height:200px}}.event-drivers-list{padding:0 6px;margin-top:10px}.event-drivers-header{color:#757575;font-size:13px;font-weight:400;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #e1e1e1}.event-drivers-items{display:flex;flex-direction:column;gap:2px}.event-driver-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;cursor:pointer;transition:background-color .15s ease}.event-driver-item:hover{background-color:#f5f5f5}.event-driver-item.active{background-color:#e8f5e9}.event-driver-item.active .event-driver-icon{color:#4caf50}.event-driver-item.active .event-driver-name{color:#2e7d32;font-weight:500}.event-driver-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:#757575;flex-shrink:0}.event-driver-icon svg{fill:currentColor}.event-driver-name{flex:1;font-size:13px;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-driver-count{font-size:12px;color:#999;background:#f0f0f0;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center;flex-shrink:0}.event-driver-item.active .event-driver-count{background:#c8e6c9;color:#2e7d32}.detail .group{padding:0 6px;line-height:30px;margin-bottom:0}.detail .group-title{font-size:20px;font-weight:700;margin-bottom:0}.group-title.editable{cursor:pointer}.group-title.editable:hover{text-decoration:underline}.detail .group-comment{font-size:11px;color:#757575;margin-top:0}.detail .group-summary{display:flex;flex-direction:row;align-items:center;cursor:pointer;padding:0}.detail .group-summary:hover{background-color:#e1e1e1}.detail .card-ico{display:inline-flex;width:auto;height:auto;margin-right:3px}.detail .card-ico svg{width:14px;height:14px;opacity:.54}.detail .card-ico.uploading svg{fill:var(--r4n-color);opacity:1}.detail .card{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-grow:1;margin-left:3px;font-size:13px}.detail .card-uuid-sub{font-size:11px;color:#0000008a}.detail .card-count{font-weight:700;font-size:11px;padding:0 6px;color:#0000008a}.detail .delimiter{margin:10px 6px 0;padding-bottom:10px;border-top:1px solid #e1e1e1;background:transparent;height:auto}#sidebar-right{flex:1;width:250px;display:flex;flex-direction:column;background:#fafafa;overflow-y:auto;overflow-x:hidden;padding-top:8px;border-left:1px solid #e1e1e1;transition:transform .3s ease;min-height:0}@media (min-width: 769px){.sidebar-right-wrapper:not(.open) #sidebar-right{width:0;flex:0 0 0;overflow:hidden;border-left:none}.sidebar-right-wrapper.open #sidebar-right,.sidebar-right-wrapper.has-selection #sidebar-right{width:250px;flex:1}}.detail{padding:0 6px;flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}#overlay{display:flex;flex-direction:column;justify-content:center;align-items:center;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;z-index:1000}#overlay-dialog{background-color:#fff;border-radius:2px;box-shadow:0 4px 8px #00000052,0 8px 40px #0006;padding:24px}#overlay-dialog-header{display:flex;flex-direction:row;margin-bottom:20px}#overlay-dialog-header .title{flex-grow:1;font-size:18px}#overlay-dialog-header .close{display:flex;justify-content:center;align-items:center;width:24px;height:24px;opacity:.7;cursor:pointer}#overlay-dialog-header .close svg{fill:#000;width:20px;height:20px}#overlay-dialog-header .close:hover{opacity:1}#overlay-dialog-buttons{display:flex;justify-content:flex-end;margin-top:24px}#overlay-dialog-buttons input[type=button],#overlay-dialog-buttons input[type=submit]{border:1px solid transparent;border-radius:2px;min-width:64px;font-weight:700;line-height:30px;outline:none;text-align:center;margin:0 8px;padding:0 16px;cursor:pointer}#overlay-dialog-buttons input[type=button]:hover,#overlay-dialog-buttons input[type=submit]:hover:not([disabled]){box-shadow:0 2px 2px #00000024,0 3px 1px -2px #0000001f,0 1px 5px #0003}#overlay-dialog-buttons input[disabled]{opacity:.5;cursor:not-allowed}#overlay-dialog-buttons input[type=button]{background-color:#fff;color:#000000de}#overlay-dialog-buttons input[type=submit]{background-color:var(--r4n-color);color:#fff}#overlay-dialog-buttons input[type=submit].alert{background-color:red}.device{display:inline-block;margin:0 0 8px 8px;width:325px;height:320px;background-color:#eee;border-radius:1px;box-shadow:0 1px 1px #0003}.device:hover{box-shadow:0 2px 8px #00000040}.device .title{color:#0000008a;font-size:16px;font-weight:500;line-height:30px;background-color:#e1e1e1;cursor:pointer;padding:6px}.device.selected .title{background-color:var(--r4n-color);color:#fff}.device .base,.device .modem{margin:6px}.device .line{display:flex;flex-direction:row;line-height:20px}.device .line .label{flex:0 0 125px}.device .line .value,.device .line .value1,.device .line .value2{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device .line .value{flex:0 0 200px}.device .line .value1,.device .line .value2{flex:0 0 100px}#overlay-monitor-layer{display:flex;justify-content:center;align-items:center;position:fixed;padding:5%;top:0;left:0;right:0;bottom:0}#overlay-monitor{position:relative;width:100%;height:100%;display:flex;flex-direction:column;background-color:#fff;border-radius:2px;box-shadow:0 4px 8px #00000052,0 8px 40px #0006;padding:24px}#overlay-monitor .loading{display:flex;align-items:center;justify-content:center;height:100%}#overlay-monitor .loading svg{width:30px;height:30px}#overlay-dialog-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:16px}#overlay-dialog-header .title{font-size:20px;font-weight:500}#overlay-dialog-header .close{cursor:pointer;width:24px;height:24px}#overlay-dialog-header .close svg{width:24px;height:24px;fill:#0000008a}#overlay-dialog-header .close:hover svg{fill:#000000de}#overlay-monitor .devices{overflow-y:auto;flex:1}#overlay-monitor .no-devices{display:flex;align-items:center;justify-content:center;height:100%;color:#0000008a;font-size:16px}#new-event-form{display:flex;flex-direction:column;gap:20px;padding:8px 0}.new-event-field{display:flex;flex-direction:column;gap:8px}.new-event-field label{font-size:13px;font-weight:500;color:#374151;margin-bottom:2px}.new-event-field input[type=text],.new-event-field input[type=url],.new-event-field select{height:48px;padding:12px 16px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:15px;background:#fafafa;color:#1a1a1a;transition:all .2s ease;width:100%;box-sizing:border-box}.new-event-field input[type=text]:hover,.new-event-field input[type=url]:hover,.new-event-field select:hover{background:#fff;border-color:#d1d5db}.new-event-field input[type=text]:focus,.new-event-field input[type=url]:focus,.new-event-field select:focus{outline:none;background:#fff;border-color:#24a20b;box-shadow:0 0 0 3px #24a20b1a}.new-event-field input[type=text]:disabled,.new-event-field input[type=url]:disabled,.new-event-field select:disabled{opacity:.6;cursor:not-allowed;background:#f3f4f6}.new-event-field input[type=text]::placeholder,.new-event-field input[type=url]::placeholder{color:#9ca3af}.new-event-field .field-hint{font-size:12px;color:#6b7280;margin-top:4px}.new-event-checkbox-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s ease}.new-event-checkbox-row:hover{background:#fff;border-color:#d1d5db}.new-event-checkbox-row input[type=checkbox]{width:20px;height:20px;accent-color:#24a20b;cursor:pointer}.new-event-checkbox-row label{font-size:15px;font-weight:500;color:#1a1a1a;cursor:pointer;margin:0}.new-event-productions{margin-top:8px}.new-event-productions .productions-loading,.new-event-productions .productions-empty{padding:16px;text-align:center;color:#6b7280;background:#fafafa;border-radius:10px;border:1.5px solid #e5e7eb;font-size:13px}.new-event-productions .productions-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto;padding:4px 0}.new-event-productions .production-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s ease}.new-event-productions .production-item:hover{background:#fff;border-color:#d1d5db}.new-event-productions .production-item.selected{background:#24a20b0d;border-color:#24a20b4d}.new-event-productions .production-item input[type=checkbox]{width:20px;height:20px;accent-color:#24a20b;cursor:pointer;flex-shrink:0}.new-event-productions .production-name{font-size:14px;color:#1a1a1a;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#new-event-form #overlay-dialog-buttons{display:flex;flex-direction:row;gap:12px;margin-top:12px;padding-top:20px;border-top:1px solid #e5e7eb}#new-event-form #overlay-dialog-buttons input[type=button],#new-event-form #overlay-dialog-buttons input[type=submit]{height:44px;padding:0 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}#new-event-form #overlay-dialog-buttons input[type=submit]{background:linear-gradient(135deg,#24a20b,#1d8009);color:#fff}#new-event-form #overlay-dialog-buttons input[type=submit]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #24a20b4d}#new-event-form #overlay-dialog-buttons input[type=submit]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}#new-event-form #overlay-dialog-buttons input[type=button]{background:#f3f4f6;color:#374151}#new-event-form #overlay-dialog-buttons input[type=button]:hover:not(:disabled){background:#e5e7eb}#edit-event-form{display:flex;flex-direction:column;gap:20px;padding:8px 0}.edit-event-field{display:flex;flex-direction:column;gap:8px}.edit-event-field label{font-size:13px;font-weight:500;color:#374151;margin-bottom:2px}.edit-event-field input[type=text],.edit-event-field input[type=url],.edit-event-field select{height:48px;padding:12px 16px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:15px;background:#fafafa;color:#1a1a1a;transition:all .2s ease;width:100%;box-sizing:border-box}.edit-event-field input[type=text]:hover,.edit-event-field input[type=url]:hover,.edit-event-field select:hover{background:#fff;border-color:#d1d5db}.edit-event-field input[type=text]:focus,.edit-event-field input[type=url]:focus,.edit-event-field select:focus{outline:none;background:#fff;border-color:#24a20b;box-shadow:0 0 0 3px #24a20b1a}.edit-event-field input[type=text]:disabled,.edit-event-field input[type=url]:disabled,.edit-event-field select:disabled{opacity:.6;cursor:not-allowed;background:#f3f4f6}.edit-event-field input[type=text]::placeholder,.edit-event-field input[type=url]::placeholder{color:#9ca3af}.edit-event-field .field-hint{font-size:12px;color:#6b7280;margin-top:4px}.edit-event-checkbox-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s ease}.edit-event-checkbox-row:hover{background:#fff;border-color:#d1d5db}.edit-event-checkbox-row input[type=checkbox]{width:20px;height:20px;accent-color:#24a20b;cursor:pointer}.edit-event-checkbox-row label{font-size:15px;font-weight:500;color:#1a1a1a;cursor:pointer;margin:0}#overlay-dialog-buttons{display:flex;flex-direction:row;gap:12px;margin-top:12px;padding-top:20px;border-top:1px solid #e5e7eb}#overlay-dialog-buttons input[type=button],#overlay-dialog-buttons input[type=submit]{height:44px;padding:0 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}#overlay-dialog-buttons input[type=submit]{background:linear-gradient(135deg,#24a20b,#1d8009);color:#fff}#overlay-dialog-buttons input[type=submit]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #24a20b4d}#overlay-dialog-buttons input[type=submit]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}#overlay-dialog-buttons input[type=button]{background:#f3f4f6;color:#374151}#overlay-dialog-buttons input[type=button]:hover:not(:disabled){background:#e5e7eb}#overlay-dialog-buttons .delete-button{background:linear-gradient(135deg,#dc3545,#c82333)!important;color:#fff!important}#overlay-dialog-buttons .delete-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}#overlay-dialog-buttons .delete-button:disabled{opacity:.6;cursor:not-allowed}.edit-event-productions{margin-top:8px}.productions-loading{padding:16px;text-align:center;color:#6b7280;background:#fafafa;border-radius:10px;border:1.5px solid #e5e7eb}.productions-lists{display:grid;grid-template-columns:1fr 1fr;gap:16px}.productions-assigned,.productions-available{display:flex;flex-direction:column;gap:8px}.productions-subtitle{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.productions-empty{padding:12px;text-align:center;color:#9ca3af;font-size:13px;background:#fafafa;border-radius:8px;border:1px dashed #e5e7eb}.productions-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px;max-height:150px;overflow-y:auto}.production-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:8px;transition:all .2s ease}.production-item:hover{background:#fff;border-color:#d1d5db}.production-item.assigned{background:#24a20b0d;border-color:#24a20b33}.production-name{font-size:14px;color:#1a1a1a;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.production-action{width:28px;height:28px;border:none;border-radius:6px;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;margin-left:8px}.production-action.add{background:#24a20b;color:#fff}.production-action.add:hover:not(:disabled){background:#1d8009;transform:scale(1.05)}.production-action.remove{background:#fee2e2;color:#dc3545}.production-action.remove:hover:not(:disabled){background:#fecaca;transform:scale(1.05)}.production-action:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 500px){.productions-lists{grid-template-columns:1fr}}.edit-event-recalculate{margin-top:8px}.recalculate-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px}.recalculate-info{display:flex;flex-direction:column;gap:2px}.recalculate-label{font-size:13px;font-weight:500;color:#374151}.recalculate-counts{font-size:12px;color:#6b7280}.recalculate-button{height:36px;padding:0 16px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:13px;font-weight:500;color:#374151;background:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.recalculate-button:hover:not(:disabled){border-color:#24a20b;color:#24a20b;background:#24a20b0d}.recalculate-button:disabled{opacity:.6;cursor:not-allowed}.recalculate-result{font-size:12px;color:#24a20b;margin-top:6px;font-weight:500}#audio-preview-layer{display:flex;justify-content:center;align-items:center;padding:5%;position:fixed;top:0;left:0;right:0;bottom:0}#audio-preview-center{position:relative;width:100%;height:80px}#audio-preview-container{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#000}#audio-preview-close{display:flex;justify-content:center;align-items:center;position:absolute;top:8px;right:8px;width:24px;height:24px;background-color:#0009;border-radius:50%;cursor:pointer}#audio-preview-close svg{fill:#fff;width:20px;height:20px}#audio-preview-close:hover{background-color:#000}#audio-preview-close:hover svg{fill:red}#audio-preview-loading{display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#audio-preview-loading svg{width:40px;height:40px}#audio-preview-error{display:flex;flex-direction:row;align-items:center;justify-content:center;position:absolute;left:0;right:0;top:0;bottom:0}#audio-preview-error .ico{margin-right:12px}#audio-preview-error .ico svg{width:24px;height:24px;fill:red}#audio-preview-error .message{color:#666;font-size:16px}#audio-preview-position{position:absolute;left:0;right:0;bottom:36px;height:8px;cursor:pointer;overflow:hidden}#audio-preview-position .progress{position:absolute;left:0;right:0;bottom:0;height:3px;background-color:#fff3}#audio-preview-position:hover .progress{height:8px}#audio-preview-position .position{position:absolute;display:inline-flex;top:0;bottom:0;background-color:red}#audio-preview-control{display:flex;flex-direction:row;align-items:center;position:absolute;left:0;right:0;bottom:0;height:36px}#audio-preview-control .ico{width:24px;height:24px;margin:0 6px;cursor:pointer}#audio-preview-control .ico svg{width:24px;height:24px;fill:#fff}#audio-preview-control .ico:hover svg{fill:red}#audio-preview-control .time{color:#fff;margin-left:6px;-webkit-user-select:none;user-select:none}#video-preview-layer{display:flex;justify-content:center;align-items:center;padding:5%;position:fixed;top:0;left:0;right:0;bottom:0}#video-preview-close{display:flex;justify-content:center;align-items:center;position:absolute;top:8px;right:8px;width:24px;height:24px;background-color:#0009;border-radius:50%;cursor:pointer;z-index:10}#video-preview-close svg{fill:#fff;width:20px;height:20px}#video-preview-close:hover{background-color:#000}#video-preview-close:hover svg{fill:red}#video-preview-loading{display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#video-preview-loading svg{width:40px;height:40px}#video-preview-error{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;left:0;right:0;top:0;bottom:0}#video-preview-error .ico{margin-bottom:8px}#video-preview-error .ico svg{width:60px;height:60px;fill:red}#video-preview-error .message{color:#666;font-size:16px}#video-preview-quality{position:absolute;left:0;top:0;background-color:#f00c;color:#fff;font-weight:700;padding:20px}#video-preview-center{position:relative;width:100%;height:100%}#video-preview-container{position:absolute;top:0;left:0;right:0;bottom:0}#video-preview-player{width:100%;height:100%;background-color:#000}#video-preview-position{position:absolute;left:0;right:0;bottom:36px;height:8px;cursor:pointer;overflow:hidden}#video-preview-position .progress{position:absolute;left:0;right:0;bottom:0;height:3px;background-color:#fff3}#video-preview-position:hover .progress{height:8px}#video-preview-position .position{position:absolute;display:inline-flex;top:0;bottom:0;background-color:red}#video-preview-control{display:flex;flex-direction:row;align-items:center;position:absolute;left:0;right:0;bottom:0;height:36px;background-color:#0009}#video-preview-control .ico{width:24px;height:24px;margin:0 6px;cursor:pointer}#video-preview-control .ico svg{width:24px;height:24px;fill:#fff}#video-preview-control .ico:hover svg{fill:red}#video-preview-control .time{color:#fff;margin-left:6px;-webkit-user-select:none;user-select:none}.video-modal-layer{display:flex;justify-content:center;align-items:center;padding:2%;position:fixed;top:0;left:0;right:0;bottom:0}.video-modal-center{position:relative;width:100%;height:100%;max-width:1400px;max-height:900px;display:flex;flex-direction:column}.video-modal-container{display:flex;flex-direction:column;position:relative;width:100%;height:100%;background-color:#1a1a1a;border-radius:8px;overflow:hidden;box-shadow:0 20px 60px #00000080}.video-modal-container:fullscreen{border-radius:0;max-width:none;max-height:none}.video-modal-container:fullscreen .video-modal-bottom-panel{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000e6);padding-top:40px}.video-modal-player-wrapper{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background-color:#000;min-height:0}.video-modal-player{width:100%;height:100%;object-fit:contain;background-color:#000}.video-modal-close{display:flex;justify-content:center;align-items:center;position:absolute;top:12px;right:12px;width:36px;height:36px;background-color:#0009;border-radius:50%;cursor:pointer;z-index:10;transition:background-color .2s ease}.video-modal-close svg{fill:#fff;width:24px;height:24px}.video-modal-close:hover{background-color:#000000e6}.video-modal-close:hover svg{fill:red}.video-modal-loading{display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.video-modal-loading svg{width:50px;height:50px}.video-modal-error{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;left:0;right:0;top:0;bottom:0;padding:20px}.video-modal-error .ico{margin-bottom:12px}.video-modal-error .ico svg{width:60px;height:60px;fill:red}.video-modal-error .message{color:#999;font-size:16px;text-align:center}.video-modal-position{position:absolute;left:0;right:0;bottom:44px;height:8px;cursor:pointer;overflow:hidden;padding:2px 0;z-index:5}.video-modal-position .progress{position:absolute;left:0;right:0;bottom:2px;height:4px;background-color:#ffffff4d;border-radius:2px;transition:height .1s ease}.video-modal-position:hover .progress{height:8px}.video-modal-position .position{position:absolute;display:inline-flex;top:0;bottom:0;background-color:var(--r4n-color, #e74c3c);border-radius:2px}.video-modal-video-control{display:flex;flex-direction:row;align-items:center;position:absolute;left:0;right:0;bottom:0;height:44px;background:linear-gradient(transparent,#000c);padding:0 8px;transition:opacity .3s ease}.video-modal-container.controls-hidden .video-modal-video-control,.video-modal-container.controls-hidden .video-modal-position,.video-modal-container.controls-hidden .video-modal-close{opacity:0;pointer-events:none}.video-modal-video-control .ico{width:28px;height:28px;margin:0 4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.video-modal-video-control .ico svg{width:24px;height:24px;fill:#fff;transition:fill .2s ease}.video-modal-video-control .ico:hover svg{fill:var(--r4n-color, #e74c3c)}.video-modal-video-control .ico-fullscreen{margin-left:auto}.video-modal-video-control .time{color:#fff;margin-left:8px;font-size:13px;-webkit-user-select:none;user-select:none}.video-modal-volume{display:flex;align-items:center;margin-left:4px}.video-modal-volume .volume-slider{width:0;height:4px;opacity:0;transition:width .2s ease,opacity .2s ease;cursor:pointer;accent-color:var(--r4n-color, #e74c3c);margin-left:4px}.video-modal-volume:hover .volume-slider{width:80px;opacity:1}.video-modal-bottom-panel{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:16px 20px;background-color:#1a1a1a;border-top:1px solid #333;flex-shrink:0}.video-modal-info{display:flex;flex-direction:column;gap:4px;overflow:hidden;flex:1;min-width:0}.video-modal-title{margin:0;font-size:18px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-modal-location{font-size:13px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-modal-driver{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#4caf50;margin-top:4px}.video-modal-driver svg{flex-shrink:0}.video-modal-driver-dropdown{margin-top:4px;min-width:180px;max-width:250px}.video-modal-driver-dropdown .driver-dropdown__trigger{background:#1e1e1ee6;border-color:#fff3}.video-modal-driver-dropdown .driver-dropdown__trigger:hover{background:#323232e6;border-color:#ffffff4d}.video-modal-driver-dropdown .driver-dropdown__menu{background:#1e1e1ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.video-modal-actions{display:flex;flex-direction:row;gap:12px;flex-shrink:0}.video-modal-action{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#333;border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease,transform .1s ease;text-decoration:none}.video-modal-action:hover{background-color:#444;transform:translateY(-1px)}.video-modal-action:active{transform:translateY(0)}.video-modal-action .ico{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.video-modal-action .ico svg{width:20px;height:20px;fill:#fff}.video-modal-action svg{flex-shrink:0}.video-modal-action-analyzed{background-color:#2e7d32}.video-modal-action-analyzed:hover{background-color:#388e3c}.video-modal-action.analyzing{background-color:#555;cursor:not-allowed}.video-modal-spinner{animation:video-modal-spin 1s linear infinite}@keyframes video-modal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.video-modal-layer{padding:0}.video-modal-center{max-width:none;max-height:none}.video-modal-container{border-radius:0}.video-modal-bottom-panel{flex-direction:column;align-items:flex-start;gap:12px;padding:12px 16px}.video-modal-info{width:100%}.video-modal-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:8px}.video-modal-action{padding:8px 12px;font-size:13px}.video-modal-action span{display:none}.video-modal-action .ico,.video-modal-action svg{width:24px;height:24px}.video-modal-title{font-size:16px}}@media (max-width: 480px){.video-modal-video-control{height:40px}.video-modal-position{bottom:40px}.video-modal-video-control .time{font-size:12px}.video-modal-volume .volume-slider{display:none}}.photo-modal-layer{display:flex;justify-content:center;align-items:center;padding:2%;position:fixed;top:0;left:0;right:0;bottom:0}.photo-modal-center{position:relative;width:100%;height:100%;max-width:1400px;max-height:900px;display:flex;flex-direction:column}.photo-modal-container{display:flex;flex-direction:column;position:relative;width:100%;height:100%;background-color:#1a1a1a;border-radius:8px;overflow:hidden;box-shadow:0 20px 60px #00000080}.photo-modal-viewer{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background-color:#000;min-height:0}.photo-modal-image-wrap{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:zoom-in}.photo-modal-image-wrap.zoomed{overflow:auto;cursor:zoom-out}.photo-modal-image-wrap.zoomed .photo-modal-image{object-fit:none;min-width:min-content;min-height:min-content}.photo-modal-image{display:block;max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none}.photo-modal-close{display:flex;justify-content:center;align-items:center;position:absolute;top:12px;right:12px;width:36px;height:36px;background-color:#0009;border-radius:50%;cursor:pointer;z-index:10;transition:background-color .2s ease}.photo-modal-close svg{fill:#fff;width:24px;height:24px}.photo-modal-close:hover{background-color:#000000e6}.photo-modal-close:hover svg{fill:red}.photo-modal-error{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;left:0;right:0;top:0;bottom:0;padding:20px}.photo-modal-error .message{color:#999;font-size:16px;text-align:center}.photo-modal-bottom-panel{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:16px 20px;background-color:#1a1a1a;border-top:1px solid #333;flex-shrink:0}.photo-modal-info{display:flex;flex-direction:column;gap:6px;overflow:hidden;flex:1;min-width:0}.photo-modal-title{margin:0;font-size:18px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-modal-exif{display:flex;flex-direction:row;flex-wrap:wrap;gap:0 16px;font-size:13px}.photo-modal-exif-item{display:inline-flex;gap:4px}.photo-modal-exif-item .label{color:#888}.photo-modal-exif-item .value{color:#fff}.photo-modal-file-info{display:flex;flex-direction:row;gap:12px;font-size:13px;color:#888}.photo-modal-driver{display:flex;align-items:center;gap:8px;margin-top:4px;color:#00ff41;font-size:14px}.photo-modal-driver svg{flex-shrink:0;opacity:.7}.photo-modal-driver-name{font-weight:600}.photo-modal-driver-accuracy{color:#888;font-weight:400;font-size:13px}.photo-modal-actions{display:flex;flex-direction:row;gap:12px;flex-shrink:0}.photo-modal-action--analyze{background-color:#2563eb;color:#fff}.photo-modal-action--analyze:hover{background-color:#3b82f6}.photo-modal-action--analyze.loading{opacity:.7;cursor:wait}.photo-modal-action--analyzing{background-color:#333;color:#facc15;cursor:default}.photo-modal-action--analyzing:hover{background-color:#333;transform:none}.photo-modal-action--bbox{background-color:#00ff4126;color:#00ff41}.photo-modal-action--bbox:hover{background-color:#00ff414d}@keyframes photo-modal-spin{to{transform:rotate(360deg)}}.photo-modal-spinner{animation:photo-modal-spin .8s linear infinite}.photo-modal-action{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#333;border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease,transform .1s ease;text-decoration:none}.photo-modal-action:hover{background-color:#444;transform:translateY(-1px)}.photo-modal-action:active{transform:translateY(0)}.photo-modal-action .ico{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.photo-modal-action .ico svg{width:20px;height:20px;fill:#fff}.photo-modal-action--remove{background-color:#e67e22}.photo-modal-action--remove:hover{background-color:#d35400}.photo-modal-action--delete{background-color:#e74c3c}.photo-modal-action--delete:hover{background-color:#c0392b}@media (max-width: 768px){.photo-modal-layer{padding:0}.photo-modal-center{max-width:none;max-height:none}.photo-modal-container{border-radius:0}.photo-modal-bottom-panel{flex-direction:column;align-items:flex-start;gap:12px;padding:12px 16px}.photo-modal-info{width:100%}.photo-modal-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:8px}.photo-modal-action{padding:8px 12px;font-size:13px}.photo-modal-title{font-size:16px}}.photo-modal-bbox-overlay{position:absolute;pointer-events:none;opacity:0;transition:opacity .5s ease;z-index:5}.photo-modal-bbox-overlay.visible{opacity:1}.photo-modal-bbox-rect{position:absolute;border:2.5px solid #00ff41;border-radius:3px;box-shadow:0 0 8px #00ff4166}.photo-modal-bbox-label{position:absolute;top:-24px;left:0;background:#000000bf;color:#00ff41;font-size:12px;font-weight:600;padding:2px 8px;border-radius:3px;white-space:nowrap;letter-spacing:.3px}#message{display:flex;flex-direction:column;align-items:center;position:fixed;top:0;left:50%;transform:translate(-50%);z-index:9000}.message-info,.message-error{position:relative;border-radius:2px;box-shadow:0 1px 4px #0006;margin-bottom:6px}.message-ico{display:flex;justify-content:center;align-items:center;position:absolute;top:0;right:0;width:24px;height:24px;border-radius:50%;cursor:pointer}.message-ico svg{width:16px;height:16px;fill:#fff}.message-info{background-color:#ffff6c}.message-info .message-text{padding:6px 24px 6px 6px}.message-error{background-color:red;color:#fff}.message-error .message-text{padding:6px 24px 6px 6px}.event-page{display:flex;flex-direction:column;height:100vh;width:100%}.event-page.resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.event-page.resizing *{cursor:col-resize!important}.event-page-main{flex-grow:1;display:flex;flex-direction:row;overflow:hidden;position:relative}.event-page-sidebar{flex:0 0 250px;width:250px;display:flex;flex-direction:column;padding-top:8px;border-right:1px solid #e1e1e1;background:#fff;position:relative}.sidebar-resize-handle{position:absolute;top:0;right:0;width:4px;height:100%;cursor:col-resize;background:transparent;z-index:10;transition:background-color .2s ease}.sidebar-resize-handle:hover{background:#24a20b}.event-page-sidebar:has(.sidebar-resize-handle:hover),.event-page:has(.sidebar-resize-handle:hover){-webkit-user-select:none;user-select:none;cursor:col-resize}.event-page-content{flex:1 1 0;display:flex;flex-direction:column;overflow:scroll;padding-top:8px;background:#fff}.sidebar-right-wrapper{flex:0 0 250px;display:flex;flex-direction:column;overflow:hidden;min-height:0}.event-page-content h2{margin:0 0 10px;color:#222;font-size:20px;padding:0 8px}.event-page-content p{color:#666;font-size:13px;padding:0 8px}@media (max-width: 768px){.event-page-sidebar{position:fixed;left:0;top:53px;bottom:0;width:250px!important;flex-basis:250px!important;z-index:1000;box-shadow:2px 0 8px #00000026}.sidebar-resize-handle{display:none}.sidebar-right-wrapper{position:relative}.sidebar-right-wrapper #sidebar-right{position:fixed;right:0;top:53px;bottom:0;width:100%;max-width:300px;z-index:1001;transform:translate(100%);transition:transform .3s ease;box-shadow:-2px 0 8px #00000026;overflow-y:auto;overflow-x:hidden;height:calc(100vh - 53px)}.sidebar-right-wrapper.has-selection.mobile-open #sidebar-right,.sidebar-right-wrapper.open #sidebar-right{transform:translate(0)}.mobile-detail-overlay{position:fixed;top:53px;left:0;right:0;bottom:0;background:#00000080;z-index:1000}.event-page-content{width:100%}}@media (max-width: 480px){.event-page-sidebar{width:100%!important;max-width:280px}.sidebar-right-wrapper.has-selection #sidebar-right{width:100%;max-width:100%}}@media (max-width: 768px){.control .search{min-width:0}.control .actions{flex-shrink:0}.control .actions input[type=range]{width:60px}}#layout-about{display:flex;align-items:center;justify-content:center;flex-direction:column}#layout-about .ico{margin:10px 0}#layout-about .ico svg{fill:var(--r4n-color);width:250px}#layout-about .contact,#layout-about .link{font-size:14px;margin:10px 0}#layout-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh}#layout-not-found .title{font-size:18px;margin-bottom:20px}#layout-not-found .link{font-size:14px}.user-role{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #ddd}.user-role-label{font-size:14px;font-weight:500;color:#333;min-width:60px}.user-role-select{flex:1;max-width:300px;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;cursor:pointer;transition:border-color .2s}.user-role-select:focus{outline:none;border-color:#b2c819}.user-role-select:hover{border-color:#b2c819}.user-role-loading{color:#666;font-size:14px}.user-management{display:flex;flex-direction:column;height:100%}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-actions{display:flex;gap:15px;align-items:center}.sync-button{padding:8px 16px;background-color:#b2c819;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s}.sync-button:hover:not(:disabled){background-color:#9ab015}.sync-button:disabled{opacity:.6;cursor:not-allowed}.user-management-header h2{margin:0;font-size:20px;font-weight:400;color:#333}.instance-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;cursor:pointer}.instance-info{padding:8px 12px;font-size:14px;color:#666;background-color:#f9f9f9;border-radius:4px}.user-management-content{display:flex;gap:20px;flex:1;min-height:0}.users-list{flex:0 0 300px;background-color:#fff;border:1px solid #ddd;border-radius:4px;overflow-y:auto}.users-list h3{margin:0;padding:15px;font-size:16px;font-weight:400;border-bottom:1px solid #ddd;background-color:#f9f9f9}.users-list ul{list-style:none;margin:0;padding:0}.user-item{padding:15px;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s}.user-item:hover{background-color:#f9f9f9}.user-item.selected{background-color:#e8f4f8;border-left:3px solid #b2c819}.user-info{margin-bottom:8px}.user-uid,.user-email{font-weight:500;color:#333;font-size:14px;margin-bottom:4px}.user-name{font-size:12px;color:#666;margin-top:2px}.user-uid-small{font-size:11px;color:#999;font-family:monospace;margin-top:2px}.user-events-count{font-size:12px;color:#999}.user-detail{flex:1;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:20px;overflow-y:auto}.empty-state{padding:40px;text-align:center;color:#999}.admin-loading{padding:40px;text-align:center;color:#666}.pending-users-section{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a;border-radius:8px;margin-bottom:24px;overflow:hidden}.pending-users-header{padding:16px 20px;background:#fbbf241a;border-bottom:1px solid #fde68a}.pending-users-header h3{margin:0;font-size:16px;font-weight:600;color:#92400e;display:flex;align-items:center;gap:10px}.pending-icon{width:20px;height:20px;color:#f59e0b}.pending-users-list{padding:16px;overflow-x:auto}.loading-pending{padding:20px;text-align:center;color:#92400e}.pending-users-table{width:100%;border-collapse:collapse;font-size:14px}.pending-users-table th{text-align:left;padding:10px 12px;font-weight:500;color:#78350f;border-bottom:1px solid #fde68a;white-space:nowrap}.pending-users-table td{padding:12px;border-bottom:1px solid #fef3c7;color:#374151}.pending-users-table tr:last-child td{border-bottom:none}.pending-users-table tr:hover td{background-color:#fbbf241a}.user-name-cell{font-weight:500}.user-type-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.user-type-badge.photo{background-color:#dbeafe;color:#1e40af}.user-type-badge.video{background-color:#dcfce7;color:#166534}.assign-production-btn{padding:6px 12px;background-color:#b2c819;color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s;white-space:nowrap}.assign-production-btn:hover{background-color:#9ab015}.assign-production-form{display:flex;gap:8px;align-items:center}.production-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;min-width:150px}.assign-btn{padding:6px 12px;background-color:#22c55e;color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s}.assign-btn:hover:not(:disabled){background-color:#16a34a}.assign-btn:disabled{opacity:.5;cursor:not-allowed}.cancel-btn{padding:6px 12px;background-color:#e5e7eb;color:#374151;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s}.cancel-btn:hover{background-color:#d1d5db}.delete-user-section{margin-top:24px;padding:16px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px}.delete-user-section h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#991b1b}.delete-warning{margin:0 0 12px;font-size:13px;color:#7f1d1d;line-height:1.4}.delete-user-btn{padding:8px 16px;background-color:#dc2626;color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s}.delete-user-btn:hover{background-color:#b91c1c}.delete-confirm{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.delete-confirm span{font-size:13px;font-weight:500;color:#991b1b}.delete-confirm-btn{padding:8px 16px;background-color:#dc2626;color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s}.delete-confirm-btn:hover:not(:disabled){background-color:#b91c1c}.delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.delete-cancel-btn{padding:8px 16px;background-color:#e5e7eb;color:#374151;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s}.delete-cancel-btn:hover:not(:disabled){background-color:#d1d5db}.delete-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.queue-dashboard{display:flex;flex-direction:column;height:100%;min-height:600px}.queue-dashboard-header{margin-bottom:20px;padding:0 0 20px;border-bottom:1px solid #ddd}.queue-dashboard-header h3{margin:0 0 8px;font-size:20px;font-weight:500;color:#333}.queue-dashboard-header p{margin:0 0 15px;font-size:14px;color:#666;line-height:1.4}.dashboard-controls{display:flex;justify-content:space-between;align-items:center;margin-top:15px}.refresh-button{padding:8px 15px;background-color:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.refresh-button:hover{background-color:#e8e8e8;border-color:#ccc}.dashboard-tabs{display:flex;gap:2px}.dashboard-tabs .tab{padding:8px 16px;background-color:#f5f5f5;color:#666;border:1px solid #ddd;cursor:pointer;font-size:14px;transition:all .2s;border-radius:0}.dashboard-tabs .tab:first-child{border-radius:4px 0 0 4px}.dashboard-tabs .tab:last-child{border-radius:0 4px 4px 0}.dashboard-tabs .tab.active{background-color:#b2c819;color:#fff;border-color:#b2c819}.dashboard-tabs .tab:not(.active):hover{background-color:#e8e8e8;border-color:#ccc}.queue-dashboard-content{flex:1;position:relative;min-height:500px;background-color:#fff;border:1px solid #ddd;border-radius:4px;overflow:hidden}.queue-dashboard-iframe{width:100%;height:100%;min-height:500px;border:none;background-color:#fff}.queue-dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:#666}.queue-dashboard-loading p{margin:10px 0 0;font-size:14px}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #b2c819;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.queue-dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;padding:20px;text-align:center;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;color:#666}.queue-dashboard-error h3{margin:0 0 10px;font-size:18px;color:#d32f2f}.queue-dashboard-error p{margin:0 0 20px;font-size:14px;line-height:1.4;max-width:400px}.retry-button{padding:10px 20px;background-color:#b2c819;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.retry-button:hover{background-color:#9db517}.error-banner{background-color:#fff3cd;color:#856404;padding:10px 15px;border:1px solid #ffeaa7;border-radius:4px;margin-bottom:20px;font-size:14px}.queue-overview{display:flex;flex-direction:column;gap:25px}.kpi-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.kpi-card{background:#fff;padding:20px;border-radius:8px;border:1px solid #e0e0e0;text-align:center;box-shadow:0 2px 4px #0000000d}.kpi-card.success{border-left:4px solid #4caf50}.kpi-card.time{border-left:4px solid #2196f3}.kpi-card.total{border-left:4px solid #ff9800}.kpi-card.completed{border-left:4px solid #8bc34a}.kpi-value{font-size:32px;font-weight:700;color:#333;margin-bottom:5px}.kpi-label{font-size:13px;color:#666;text-transform:uppercase;letter-spacing:.5px}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;min-height:400px}.chart-container{background:#fff;padding:20px;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.chart-container h4{margin:0 0 15px;font-size:16px;color:#333;text-align:center}.chart-container canvas{max-height:300px!important}.queue-details h4{margin:0 0 15px;font-size:18px;color:#333}.queue-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:15px}.queue-card{background:#fff;padding:20px;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.queue-card h5{margin:0 0 15px;font-size:16px;color:#333;font-weight:500}.queue-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:10px;border-radius:6px;background-color:#f8f9fa}.stat.waiting{background-color:#fff3cd;color:#856404}.stat.active{background-color:#d1ecf1;color:#0c5460}.stat.completed{background-color:#d4edda;color:#155724}.stat.failed{background-color:#f8d7da;color:#721c24}.stat .value{font-size:20px;font-weight:700;margin-bottom:3px}.stat .label{font-size:11px;text-transform:uppercase;letter-spacing:.3px;opacity:.8}.last-update{font-size:12px;color:#666;margin-left:15px}.demo-notice{background:#fff;padding:30px;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;text-align:center}.demo-notice h4{margin:0 0 15px;font-size:18px;color:#333}.demo-notice p{margin:0 0 15px;color:#666;line-height:1.5}.demo-notice ul{text-align:left;max-width:400px;margin:0 auto;color:#666}.demo-notice li{margin:5px 0}@media (max-width: 768px){.queue-dashboard,.queue-dashboard-content,.queue-dashboard-iframe{min-height:400px}.queue-dashboard-header h3{font-size:18px}.queue-dashboard-header p{font-size:13px}.dashboard-controls{flex-direction:column;gap:10px;align-items:stretch}.dashboard-tabs{justify-content:center}.charts-grid{grid-template-columns:1fr;gap:15px}.kpi-cards{grid-template-columns:repeat(2,1fr)}.kpi-value{font-size:24px}.queue-stats{grid-template-columns:repeat(4,1fr);gap:8px}.stat{padding:8px}.stat .value{font-size:16px}.stat .label{font-size:10px}}.device-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.device-detail{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:1000px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.device-detail__header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #eee;position:sticky;top:0;background-color:#fff;z-index:1;border-radius:8px 8px 0 0}.device-detail__header h3{margin:0;font-size:18px;font-weight:600;color:#333}.device-detail__header-info{display:flex;align-items:center;gap:12px}.device-detail__close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #ddd;border-radius:4px;background-color:#fff;color:#666;cursor:pointer;transition:all .15s;font-size:18px;line-height:1}.device-detail__close-btn:hover{background-color:#f0f0f0;color:#333;border-color:#ccc}.device-detail__body{padding:20px;display:flex;flex-direction:column;gap:20px}.device-detail__section{background-color:#f9f9f9;border-radius:8px;padding:16px 20px;border:1px solid #eee}.device-detail__section-header{font-size:16px;font-weight:600;color:#333;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #b2c819}.device-detail__info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px}.device-detail__info-item{display:flex;flex-direction:column;gap:2px}.device-detail__info-label{font-size:12px;font-weight:500;color:#888;text-transform:uppercase;letter-spacing:.5px}.device-detail__info-value{font-size:14px;color:#333;word-break:break-all}.device-detail__battery{display:flex;align-items:center;gap:6px}.device-detail__battery-icon{display:inline-flex;align-items:center}.device-detail__battery-icon--charging{color:#28a745}.device-detail__storage-bar{width:100%;height:8px;background-color:#e9ecef;border-radius:4px;overflow:hidden;margin-top:4px}.device-detail__storage-fill{height:100%;border-radius:4px;transition:width .3s}.device-detail__storage-fill--ok{background-color:#b2c819}.device-detail__storage-fill--warning{background-color:#ffc107}.device-detail__storage-fill--danger{background-color:#dc3545}.device-detail__stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.device-detail__stat-card{background-color:#fff;border-radius:6px;padding:12px;text-align:center;border:1px solid #eee}.device-detail__stat-value{font-size:20px;font-weight:700;color:#333}.device-detail__stat-value--success{color:#28a745}.device-detail__stat-value--danger{color:#dc3545}.device-detail__stat-label{font-size:12px;color:#888;margin-top:2px}.device-detail__table-wrapper{overflow-x:auto}.device-detail__table{width:100%;border-collapse:collapse;font-size:13px}.device-detail__table th,.device-detail__table td{padding:10px 8px;text-align:left;border-bottom:1px solid #eee}.device-detail__table th{font-weight:600;color:#666;background-color:#f0f0f0;white-space:nowrap;font-size:12px;text-transform:uppercase;letter-spacing:.3px}.device-detail__table tbody tr:hover{background-color:#f5f5f5}.device-detail__table tbody tr:last-child td{border-bottom:none}.device-detail__progress-bar{width:100%;min-width:80px;height:6px;background-color:#e9ecef;border-radius:3px;overflow:hidden}.device-detail__progress-fill{height:100%;background-color:#b2c819;border-radius:3px;transition:width .5s ease}.device-detail__progress-fill--copying{background-color:#17a2b8}.device-detail__progress-fill--compressing{background-color:#ffc107}.device-detail__progress-fill--uploading{background-color:#007bff}.device-detail__progress-text{font-size:11px;color:#888;white-space:nowrap}.device-detail__file-name{font-size:13px;word-break:break-all}.device-detail__file-error{font-size:11px;color:#dc3545;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.device-detail__compression-ratio{font-size:11px;color:#28a745;margin-left:4px}.device-detail__file-row--active{background-color:#f0f7ff!important}.device-detail__file-row--active:hover{background-color:#e3f0ff!important}.device-detail__file-status{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.device-detail__file-status--completed{background-color:#d4edda;color:#155724}.device-detail__file-status--uploading{background-color:#cce5ff;color:#004085}.device-detail__file-status--copying{background-color:#d1ecf1;color:#0c5460}.device-detail__file-status--compressing{background-color:#fff3cd;color:#856404}.device-detail__file-status--error{background-color:#f8d7da;color:#721c24}.device-detail__file-status--skipped{background-color:#e2e3e5;color:#383d41}.device-detail__file-status--pending{background-color:#e9ecef;color:#6c757d}.device-detail__filter{display:flex;align-items:center;gap:8px;margin-bottom:12px}.device-detail__filter label{font-size:13px;color:#666;font-weight:500}.device-detail__filter select{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;background-color:#fff;cursor:pointer}.device-detail__filter select:focus{outline:none;border-color:#b2c819}.device-detail__log-viewer{max-height:400px;overflow-y:auto;background-color:#1e1e1e;border-radius:6px;padding:12px;font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;line-height:1.6}.device-detail__log-entry{display:flex;gap:8px;padding:2px 0;white-space:pre-wrap;word-break:break-all}.device-detail__log-timestamp{color:#888;white-space:nowrap;flex-shrink:0}.device-detail__log-level{font-weight:600;white-space:nowrap;flex-shrink:0;min-width:56px;text-align:center;border-radius:3px;padding:0 4px}.device-detail__log-level--DEBUG{color:#888;background-color:#8888881a}.device-detail__log-level--INFO{color:#58a6ff;background-color:#58a6ff1a}.device-detail__log-level--WARNING,.device-detail__log-level--WARN{color:#f0a030;background-color:#f0a0301a}.device-detail__log-level--ERROR{color:#f85149;background-color:#f851491a}.device-detail__log-message{color:#d4d4d4;flex:1}.device-detail__log-empty{color:#888;text-align:center;padding:20px;font-style:italic}.device-detail__log-loading{color:#888;text-align:center;padding:20px}.device-detail__log-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.device-detail__log-refresh{font-size:11px;color:#888;display:flex;align-items:center;gap:4px}.device-detail__log-refresh-dot{width:6px;height:6px;border-radius:50%;background-color:#28a745;animation:device-detail-pulse 2s infinite}@keyframes device-detail-pulse{0%,to{opacity:1}50%{opacity:.3}}.device-detail__empty{text-align:center;padding:20px;color:#999;font-size:14px;font-style:italic}@media (max-width: 768px){.device-detail{max-width:100%;max-height:95vh;margin:10px}.device-detail__header{padding:15px}.device-detail__header h3{font-size:16px}.device-detail__body{padding:15px;gap:15px}.device-detail__section{padding:12px 15px}.device-detail__info-grid{grid-template-columns:1fr;gap:10px}.device-detail__stats-grid{grid-template-columns:repeat(2,1fr)}.device-detail__log-viewer{max-height:300px;font-size:11px}.device-detail__log-entry{flex-wrap:wrap}}.device-detail__recent-uploads{display:flex;flex-direction:column;gap:6px}.device-detail__upload-link{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;text-decoration:none;color:#333;transition:background-color .15s,border-color .15s;font-size:13px}.device-detail__upload-link:hover{background:#e9ecef;border-color:#28a745}.device-detail__upload-icon{color:#28a745;font-size:12px;flex-shrink:0}.device-detail__upload-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-detail__upload-size,.device-detail__upload-date{color:#6c757d;font-size:12px;flex-shrink:0}@media (max-width: 480px){.device-detail__stats-grid{grid-template-columns:1fr}.device-detail__filter{flex-direction:column;align-items:flex-start}.device-detail__filter select{width:100%}}.device-management{display:flex;flex-direction:column;height:100%}.device-management-title{font-size:24px;font-weight:600;color:#333;margin:0 0 20px}.device-sections-container{display:flex;flex-direction:column;gap:20px;overflow-y:auto}.device-section-card{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s}.device-section-card:hover{box-shadow:0 2px 6px #00000026}.device-section-card h3{font-size:18px;font-weight:600;color:#333;margin:0 0 15px;padding-bottom:10px;border-bottom:2px solid #b2c819}.device-section-other h3{border-bottom-color:#6c757d}.device-loading,.device-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666;font-size:16px;gap:20px}.device-error{color:#dc3545}.device-table-wrapper{overflow-x:auto;margin:0 -10px;padding:0 10px}.device-table{width:100%;border-collapse:collapse;font-size:14px}.device-table th,.device-table td{padding:12px 10px;text-align:left;border-bottom:1px solid #eee}.device-table th{font-weight:600;color:#666;background-color:#f9f9f9;white-space:nowrap}.device-table tbody tr{transition:background-color .15s}.device-table tbody tr:hover{background-color:#f5f5f5}.device-table tbody tr:last-child td{border-bottom:none}.device-mac{font-family:monospace;font-size:13px;color:#555}.device-status{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.device-status.active{background-color:#d4edda;color:#155724}.device-status.inactive{background-color:#e9ecef;color:#6c757d}.device-actions{display:flex;gap:8px;white-space:nowrap}.device-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #ddd;border-radius:4px;background-color:#fff;color:#666;cursor:pointer;transition:all .15s}.device-action-btn:hover{background-color:#f0f0f0;color:#333;border-color:#ccc}.device-action-btn-danger:hover{background-color:#fff5f5;color:#dc3545;border-color:#dc3545}.device-action-btn-warning:hover{background-color:#fff8e6;color:#e67e00;border-color:#e67e00}.device-btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.device-btn:disabled{opacity:.6;cursor:not-allowed}.device-btn-primary{background-color:#b2c819;color:#fff}.device-btn-primary:hover:not(:disabled){background-color:#9ab015}.device-btn-secondary{background-color:#f0f0f0;color:#333}.device-btn-secondary:hover:not(:disabled){background-color:#e0e0e0}.device-btn-danger{background-color:#dc3545;color:#fff}.device-btn-danger:hover:not(:disabled){background-color:#c82333}.device-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.device-modal{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.device-modal h3{margin:0;padding:20px;font-size:18px;font-weight:600;color:#333;border-bottom:1px solid #eee}.device-modal-content{padding:20px}.device-modal-field{margin-bottom:16px}.device-modal-field:last-child{margin-bottom:0}.device-modal-field label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#555}.device-modal-field input,.device-modal-field textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .15s;box-sizing:border-box}.device-modal-field input:focus,.device-modal-field textarea:focus{outline:none;border-color:#b2c819}.device-modal-field input:disabled{background-color:#f5f5f5;color:#999}.device-modal-field textarea{resize:vertical;min-height:80px}.device-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #eee;background-color:#f9f9f9;border-radius:0 0 8px 8px}.device-modal-confirm{max-width:400px}.device-confirm-message{margin:0;padding:20px;font-size:14px;color:#555;line-height:1.5}@media (max-width: 768px){.device-management-title{font-size:20px;margin-bottom:15px}.device-sections-container{gap:15px}.device-section-card{padding:15px}.device-section-card h3{font-size:16px}.device-table th,.device-table td{padding:10px 8px;font-size:13px}.device-action-btn{width:28px;height:28px}.device-modal{max-width:100%;margin:10px}.device-modal h3{font-size:16px;padding:15px}.device-modal-content{padding:15px}.device-modal-actions{padding:12px 15px;flex-direction:column}.device-modal-actions .device-btn{width:100%}}@media (max-width: 480px){.device-sections-container{gap:12px}.device-section-card{padding:12px}.device-section-card h3{font-size:15px}.device-table{font-size:12px}.device-table th,.device-table td{padding:8px 6px}.device-actions{gap:4px}.device-action-btn{width:26px;height:26px}.device-status{padding:3px 8px;font-size:11px}}.production-management{display:flex;flex-direction:column;height:100%}.production-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.production-management-title{font-size:24px;font-weight:600;color:#333;margin:0}.production-section-card{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s;flex:1;overflow:hidden;display:flex;flex-direction:column}.production-section-card:hover{box-shadow:0 2px 6px #00000026}.placeholder-text{font-size:14px;color:#999;font-style:italic;margin:0}.production-loading,.production-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666;font-size:16px;gap:20px}.production-error{color:#dc3545}.production-table-wrapper{overflow-x:auto;flex:1}.production-table{width:100%;border-collapse:collapse;font-size:14px}.production-table th,.production-table td{padding:12px 10px;text-align:left;border-bottom:1px solid #eee}.production-table th{font-weight:600;color:#666;background-color:#f9f9f9;white-space:nowrap;position:sticky;top:0}.production-table tbody tr{transition:background-color .15s}.production-table tbody tr:hover{background-color:#f5f5f5}.production-table tbody tr:last-child td{border-bottom:none}.production-name{font-weight:500;color:#333}.production-count{text-align:center;font-weight:500}.production-status{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.production-status.active{background-color:#d4edda;color:#155724}.production-status.inactive{background-color:#e9ecef;color:#6c757d}.production-actions{display:flex;gap:8px;white-space:nowrap}.production-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #ddd;border-radius:4px;background-color:#fff;color:#666;cursor:pointer;transition:all .15s}.production-action-btn:hover{background-color:#f0f0f0;color:#333;border-color:#ccc}.production-action-btn-danger:hover{background-color:#fff5f5;color:#dc3545;border-color:#dc3545}.production-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.production-btn:disabled{opacity:.6;cursor:not-allowed}.production-btn-primary{background-color:#b2c819;color:#fff}.production-btn-primary:hover:not(:disabled){background-color:#9ab015}.production-btn-secondary{background-color:#f0f0f0;color:#333}.production-btn-secondary:hover:not(:disabled){background-color:#e0e0e0}.production-btn-danger{background-color:#dc3545;color:#fff}.production-btn-danger:hover:not(:disabled){background-color:#c82333}.production-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.production-modal{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.production-modal-large{max-width:600px}.production-modal h3{margin:0;padding:20px;font-size:18px;font-weight:600;color:#333;border-bottom:1px solid #eee}.production-modal-content{padding:20px}.production-modal-error{background-color:#fff5f5;color:#dc3545;padding:10px 15px;border-radius:4px;margin-bottom:16px;font-size:14px}.production-modal-field{margin-bottom:16px}.production-modal-field:last-child{margin-bottom:0}.production-modal-field label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#555}.production-modal-field input[type=text],.production-modal-field input[type=email],.production-modal-field textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .15s;box-sizing:border-box}.production-modal-field input:focus,.production-modal-field textarea:focus{outline:none;border-color:#b2c819}.production-modal-field input:disabled{background-color:#f5f5f5;color:#999}.production-modal-field textarea{resize:vertical;min-height:80px}.production-modal-row{display:flex;gap:16px}.production-modal-row .production-modal-field{flex:1}.production-modal-checkbox label{display:flex;align-items:center;gap:8px;cursor:pointer}.production-modal-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.production-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #eee;background-color:#f9f9f9;border-radius:0 0 8px 8px}.production-modal-confirm{max-width:400px}.production-confirm-message{margin:0;padding:20px;font-size:14px;color:#555;line-height:1.5}.production-detail{display:flex;flex-direction:column;height:100%}.production-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #b2c819}.production-detail-header h3{margin:0;font-size:24px;font-weight:600;color:#333;flex:1}.production-detail-info{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px}.production-detail-field{display:flex;margin-bottom:12px}.production-detail-field:last-child{margin-bottom:0}.production-detail-field label{font-weight:500;color:#666;min-width:150px}.production-detail-field span{color:#333}.production-detail-assignments{display:grid;grid-template-columns:1fr 1fr;gap:20px;flex:1;overflow:hidden}.production-assignment{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden}.production-assignment h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#333;padding-bottom:10px;border-bottom:2px solid #b2c819}.production-assignment-search{margin-bottom:16px}.production-assignment-search input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;box-sizing:border-box}.production-assignment-search input:focus{outline:none;border-color:#b2c819}.production-assignment-content{display:flex;flex-direction:column;gap:16px;flex:1;overflow:hidden}.production-assignment-list{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.production-assignment-list h5{margin:0 0 8px;font-size:14px;font-weight:600;color:#666}.production-assignment-list ul{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.production-assignment-empty{font-size:14px;color:#999;font-style:italic;padding:10px 0}.production-assignment-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:4px;margin-bottom:4px;transition:background-color .15s}.production-assignment-item.assigned{background-color:#f0f9e8}.production-assignment-item.unassigned{background-color:#f5f5f5}.production-assignment-item:hover{background-color:#e8e8e8}.production-assignment-item.assigned:hover{background-color:#e5f5d5}.production-assignment-info{flex:1;min-width:0}.production-assignment-name{font-size:14px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.production-assignment-secondary{font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.production-assignment-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:4px;cursor:pointer;transition:all .15s;flex-shrink:0;margin-left:8px}.production-assignment-action.add{background-color:#b2c819;color:#fff}.production-assignment-action.add:hover:not(:disabled){background-color:#9ab015}.production-assignment-action.remove{background-color:#e9ecef;color:#666}.production-assignment-action.remove:hover:not(:disabled){background-color:#dc3545;color:#fff}.production-assignment-action:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1024px){.production-detail-assignments{grid-template-columns:1fr}}@media (max-width: 768px){.production-management-header{flex-direction:column;align-items:flex-start;gap:12px}.production-management-title{font-size:20px}.production-section-card{padding:15px}.production-table th,.production-table td{padding:10px 8px;font-size:13px}.production-action-btn{width:28px;height:28px}.production-modal{max-width:100%;margin:10px}.production-modal h3{font-size:16px;padding:15px}.production-modal-content{padding:15px}.production-modal-row{flex-direction:column;gap:0}.production-modal-actions{padding:12px 15px;flex-direction:column}.production-modal-actions .production-btn{width:100%}.production-detail-header{flex-wrap:wrap}.production-detail-header h3{font-size:20px;order:2;width:100%}.production-detail-field{flex-direction:column}.production-detail-field label{min-width:auto;margin-bottom:4px}}@media (max-width: 480px){.production-section-card{padding:12px}.production-table{font-size:12px}.production-table th,.production-table td{padding:8px 6px}.production-actions{gap:4px}.production-action-btn{width:26px;height:26px}.production-status{padding:3px 8px;font-size:11px}.production-assignment{padding:15px}.production-assignment h4{font-size:14px}}.admin-page{display:flex;flex-direction:column;height:100vh;width:100%}.admin-page-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:#f5f5f5}.admin-tabs{display:flex;background-color:#fff;border-bottom:1px solid #ddd;flex:0 0 auto}.admin-tab{padding:15px 30px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;color:#666;transition:all .2s}.admin-tab:hover{background-color:#f9f9f9;color:#333}.admin-tab.active{color:#333;border-bottom-color:#b2c819;font-weight:500}.admin-content{flex:1;overflow-y:auto;padding:20px}.admin-content:has(.queue-dashboard){padding:20px;display:flex;flex-direction:column}@media (max-width: 768px){.admin-tabs{flex-wrap:wrap}.admin-tab{padding:12px 20px;font-size:13px;flex:1;min-width:auto}.admin-content{padding:15px}}.racers-list{flex-grow:1;overflow-y:hidden;margin-right:8px;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column}.racers-list-search{position:relative;padding:12px;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}.racers-list-search-input{width:100%;padding:8px 32px 8px 12px;background:#0000000d;border:1px solid rgba(0,0,0,.1);border-radius:4px;color:#222;font-size:13px;outline:none;transition:all .2s}.racers-list-search-input:focus{background:#00000014;border-color:#0003}.racers-list-search-input::placeholder{color:#0006}.racers-list-search-clear{position:absolute;right:20px;top:50%;transform:translateY(-50%);background:none;border:none;color:#00000080;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.racers-list-search-clear:hover{color:#000c}.racers-list>ul{flex:1;overflow-y:auto;list-style:none;padding:0;margin:0}.racers-list li{margin:0}.racers-list .racer{display:flex;flex:0 0 40px;flex-direction:row;align-items:center;color:#222;height:40px;text-decoration:none;overflow:hidden;white-space:nowrap;cursor:pointer}.racers-list .racer:hover{background-color:#e1e1e1}.racers-list .racer.active{color:#24a20b;font-weight:700;background-color:transparent}.racers-list .racer.active:hover{background-color:transparent}.racers-list .border{flex:0 0 4px;width:4px;height:24px;background-color:transparent}.racers-list .racer.active .border{background-color:#24a20b}.racers-list .racer:hover:not(.active) .border{background-color:#646464}.racers-list .racer-icon{width:20px;height:20px;opacity:.54;margin:0 6px;display:inline-flex;align-items:center;justify-content:center}.racers-list .racer-icon svg{width:20px;height:20px;fill:currentColor}.racers-list .racer.active .racer-icon{opacity:1}.racers-list .racer.active .racer-icon svg{fill:#24a20b}.racers-list .racer-name{font-size:13px}.racers-list-loading,.racers-list-empty{display:flex;align-items:center;justify-content:center;padding-top:96px;color:#666;font-size:13px}.racers-grid{display:flex;flex-direction:column;height:100%;overflow:hidden;background-color:#f5f5f5}.racers-grid-header{display:flex;align-items:center;justify-content:space-between;padding:24px 32px 16px;background-color:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.racers-grid-title{margin:0;font-size:24px;font-weight:600;color:#222}.racers-grid-count{font-size:14px;color:#666}.racers-grid-content{flex:1;overflow-y:auto;padding:24px;display:flex;flex-wrap:wrap;gap:20px;align-content:flex-start}.racer-card{display:flex;flex-direction:column;width:240px;background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.racer-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.racer-card-thumbnail{position:relative;width:100%;height:135px;background-color:#e8e8e8;overflow:hidden;flex-shrink:0}.racer-card-thumbnail img{width:100%;height:100%;object-fit:cover}.racer-card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2)}.racer-card-placeholder .ico{width:48px;height:48px;opacity:.5}.racer-card-placeholder .ico svg{fill:#fff}.racer-card-info{padding:12px 16px;flex:1;min-height:0}.racer-card-name{margin:0 0 6px;font-size:15px;font-weight:600;color:#222;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.racer-card-stats{display:flex;align-items:center;gap:6px;font-size:13px;color:#666}.racer-card-stats .video-icon{width:16px;height:16px;opacity:.6;flex-shrink:0}.racer-card-stats .video-icon svg{fill:currentColor}.racers-grid-loading,.racers-grid-error,.racers-grid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:#666;font-size:14px}.racers-grid-loading .loading{width:40px;height:40px}.racers-grid-loading .loading svg{fill:#24a20b}.racers-grid-error .error-ico{width:48px;height:48px;opacity:.5}.racers-grid-error .error-ico svg{fill:#d32f2f}.racers-grid-empty .empty-ico{width:64px;height:64px;opacity:.3}.racers-grid-empty .empty-ico svg{fill:currentColor}@media (max-width: 768px){.racers-grid-header{padding:16px 20px 12px}.racers-grid-title{font-size:20px}.racers-grid-content{padding:16px;gap:12px}.racer-card{width:calc(50% - 6px);min-width:140px}.racer-card-thumbnail{height:auto;aspect-ratio:16 / 9}.racer-card-info{padding:10px 12px}.racer-card-name{font-size:13px}.racer-card-stats{font-size:11px}.racer-card-placeholder .ico{width:32px;height:32px}}@media (max-width: 480px){.racers-grid-content{gap:10px}.racer-card{width:calc(50% - 5px);min-width:120px}.racer-card-info{padding:8px 10px}.racer-card-name{font-size:12px;margin-bottom:4px}.racer-card-stats{font-size:10px}}.racer-items-by-event{flex:1 1 0;display:flex;flex-direction:column;overflow:hidden}.racer-items-header{display:flex;align-items:center;gap:16px;padding:16px 24px;background-color:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.racer-items-back{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:14px;color:#444;transition:all .2s}.racer-items-back:hover{background-color:#e8e8e8;border-color:#ccc}.racer-items-back .ico{width:20px;height:20px}.racer-items-back .ico svg{fill:currentColor}.racer-items-info{display:flex;align-items:baseline;gap:12px}.racer-items-name{margin:0;font-size:20px;font-weight:600;color:#222}.racer-items-count{font-size:14px;color:#666}.racer-items-by-event .grid{flex:1 1 0;display:flex;flex-direction:column;overflow:scroll;padding-top:8px}.racer-items-by-event .event-section{margin-bottom:24px}.racer-items-by-event .event-section-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#f5f5f5;border-bottom:2px solid #24a20b;margin-bottom:8px}.racer-items-by-event .event-section-title{margin:0;font-size:18px;font-weight:600;color:#222}.racer-items-by-event .event-section-count{font-size:14px;color:#666}.racer-items-by-event .event-section-content{padding:0 8px}.racer-items-by-event .empty{align-self:center;display:flex;flex-direction:column;align-items:center;padding-top:96px}.racer-items-by-event .empty .error{color:#666;font-size:16px}.racer-items-by-event .empty .error-ico{margin-bottom:8px}.racer-items-by-event .empty .error-ico svg{width:60px;height:60px;fill:#ff0000b3}.racer-items-by-event .empty .loading{padding-top:45px}.racer-items-by-event .empty .loading svg{width:30px;height:30px}.racer-items-by-event .empty .no-files{display:flex;justify-content:center;align-items:center;width:120px;height:120px;border-radius:50%;background-color:#fafafa}.racer-items-by-event .empty .no-files svg{width:72px;height:72px;opacity:.2}.racer-items-by-event .empty .empty-message{margin-top:16px;color:#666;font-size:16px}.racers-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.racers-page-main{display:flex;flex:1 1 0;overflow:hidden;position:relative}.racers-page-main-grid{display:block}.racers-page-content{flex:1 1 0;display:flex;flex-direction:column;overflow:hidden;min-width:0}.racers-page-sidebar{flex:0 0 240px;display:flex;flex-direction:column;background-color:#fafafa;border-right:1px solid #e1e1e1;overflow:hidden;transition:transform .3s ease}@media (max-width: 768px){.racers-page-sidebar{position:fixed;top:48px;left:0;bottom:0;z-index:1000;transform:translate(-100%);width:240px}.racers-page-sidebar.open{transform:translate(0)}}.mobile-menu-overlay{position:fixed;top:48px;left:0;right:0;bottom:0;background-color:#00000080;z-index:999}.sidebar-right-wrapper{flex:0 0 250px;display:flex;flex-direction:column;background-color:#fafafa;border-left:1px solid #e1e1e1;overflow:hidden;transition:transform .3s ease}@media (min-width: 769px){.sidebar-right-wrapper.has-selection,.sidebar-right-wrapper.open,.sidebar-right-wrapper.has-selection.open{flex:0 0 250px;width:250px}}@media (max-width: 768px){.sidebar-right-wrapper{position:fixed;top:48px;right:0;bottom:0;z-index:1000;transform:translate(100%);width:100%;max-width:400px}.sidebar-right-wrapper.open,.sidebar-right-wrapper.has-selection,.sidebar-right-wrapper.mobile-open{transform:translate(0)}.mobile-detail-overlay{position:fixed;top:48px;left:0;right:0;bottom:0;background-color:#00000080;z-index:998}}.user-profile-page{min-height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.user-profile-content{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:32px 24px}.user-profile-card{width:100%;max-width:480px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:32px}.user-profile-title{margin:0 0 24px;font-size:24px;font-weight:600;color:#222}.user-profile-section{margin-bottom:28px}.user-profile-section:last-of-type{margin-bottom:24px}.user-profile-section-title{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.user-profile-description{margin:0 0 16px;font-size:14px;color:#666;line-height:1.5}.user-profile-info{display:flex;flex-direction:column;gap:10px}.user-profile-info-row{display:flex;gap:12px;font-size:14px}.user-profile-info-label{min-width:80px;color:#666}.user-profile-info-value{color:#222;font-weight:500}.user-profile-role{background:#e8f4fd;color:#06c;padding:2px 8px;border-radius:4px;font-size:12px}.user-profile-btn{display:inline-block;padding:10px 20px;font-size:14px;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:background-color .2s ease}.user-profile-btn:disabled{opacity:.7;cursor:not-allowed}.user-profile-btn-primary{background:#06c;color:#fff}.user-profile-btn-primary:hover:not(:disabled){background:#0052a3}.user-profile-btn-secondary{background:#f0f0f0;color:#333}.user-profile-btn-secondary:hover{background:#e5e5e5}.user-profile-error{margin:12px 0 0;font-size:14px;color:#c00}.user-profile-qr-section{margin-top:24px;padding-top:24px;border-top:1px solid #eee;display:flex;flex-direction:column;align-items:center}.user-profile-qr-wrapper{padding:16px;background:#fff;border-radius:8px;box-shadow:0 0 0 1px #00000014;display:flex;justify-content:center;align-items:center}.user-profile-qr-wrapper svg{display:block}.user-profile-qr-note{margin:16px 0 0;font-size:13px;color:#888}.user-profile-actions{margin-top:8px}:root{--text-color: #222;--r4n-color: #24a20b;--error-color: rgba(255, 0, 0, .8);--logo-blue: #009fdf;--card-color-background: #f7f7f7;--sidebar-left-width: 250px;--sidebar-right-width: 250px}*{margin:0;padding:0;box-sizing:border-box}html{font-family:Roboto,sans-serif;font-size:13px;color:var(--text-color);background:#eee}body{margin:0;-webkit-font-smoothing:antialiased}#root{display:flex;flex-direction:column;height:100vh}a{color:var(--r4n-color);text-decoration:none}a:hover{text-decoration:underline}.grid-item-drag{position:absolute;left:0;top:0;transform:translate(-100%,-100%);width:80px;height:25px;line-height:25px;background-color:var(--r4n-color);color:#fff;border-radius:1px;padding:6px;text-align:center;font-size:12px;pointer-events:none}
