@import"https://fonts.googleapis.com/css?family=Roboto:400,500,700";#login-layout{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background-color:#fff}.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-color:#f7f7f7;box-shadow:0 2px 2px #0000004d;border-radius:2px;padding:40px 0;width:360px}.logo-container{margin-bottom:15px}.logo-container .logo{display:flex;justify-content:center;align-items:center}.logo-container .logo svg{width:250px;height:auto}.login-form{display:flex;flex-direction:column;justify-content:center;width:274px}.form-group{display:flex;flex-direction:column;margin:5px 0}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password]{font-size:14px;padding:0 8px;width:274px;height:36px;border:1px solid #d9d9d9;border-top:1px solid #c0c0c0;outline:none}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=password]:focus{border-color:#24a20b}.form-group button{margin:5px 0;width:100%;border:1px solid #1d8009;color:#fff;font-weight:700;text-shadow:0 1px rgba(0,0,0,.1);background:linear-gradient(to bottom,#24a20b,#1c8208);text-align:center;height:36px;border-radius:3px;transition:all .218s;-webkit-user-select:none;user-select:none;cursor:pointer;font-size:11px;text-transform:uppercase}.form-group button:hover:not(:disabled){border:1px solid #145807;color:#fff;text-shadow:0 1px rgba(0,0,0,.3);background:linear-gradient(to bottom,#24a20b,#1a7309);text-decoration:none;box-shadow:0 1px 1px #0000001a}.form-group button:disabled{opacity:.6;cursor:not-allowed}.error-message{color:red;margin:5px 0;text-align:center;padding:5px 0;width:274px;font-size:13px}#layout-loading{display:flex;align-items:center;justify-content:center;height:100vh;width:100%}.loading-spinner{width:30px;height:30px;border:3px solid #f3f3f3;border-top:3px solid #24a20b;border-radius:50%;animation:spin 1s linear infinite}#layout-loading p{margin-top:20px;color:#666;font-size:13px}#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%}}.control{flex:1 0 0;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}.control .search{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 .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 200px;display:flex;justify-content:center;align-items:center}.header-title .logo{display:flex;justify-content:center;align-items:center}.header-title .logo svg{width:110px;height:auto}.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}@media (max-width: 768px){.header-title{flex:0 0 auto;min-width:0}.header-title .logo svg{width:80px}.header-center{flex:1;overflow:hidden;min-width:0}.header-right{flex-shrink:0}}.events-list .new{display:flex;align-items:center;justify-content:center;padding:0 0 10px}.events-list .new .button{padding:6px 16px;background-color:var(--r4n-color);color:#fff;border:none;border-radius:2px;font-size:13px;font-weight:700;cursor:pointer;min-width:96px;height:27px;line-height:15px}.events-list .new .button:hover{background-color:#1e8a0a}.events-list{flex-grow:1;overflow-y:scroll;margin-right:8px;-webkit-user-select:none;user-select:none}.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-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}.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)}.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}.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}.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}.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-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}.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}.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}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.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}.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}.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-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:6px 16px;background:red;color:#fff;border:none;border-radius:2px;cursor:pointer;font-size:13px;font-weight:700;min-width:96px;height:27px;line-height:15px}.detail .button:hover{background:#d00}.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-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 input[type=text]{border-radius:1px;border:1px solid #d9d9d9;border-top:1px solid #c0c0c0;height:25px;width:250px;font-size:13px;padding:1px 8px;outline:none}#new-event-form label{display:block;margin-bottom:4px;font-size:13px;color:#222}#new-event-form select{border-radius:1px;border:1px solid #d9d9d9;border-top:1px solid #c0c0c0;height:25px;width:250px;font-size:13px;padding:1px 8px;outline:none;background:#fff}#new-event-form>div{margin-bottom:12px}#edit-event-form{display:flex;flex-direction:column;gap:16px}#edit-event-form>div{display:flex;flex-direction:column;gap:8px}#edit-event-form label{font-weight:500;color:var(--text-primary)}#edit-event-form input[type=text],#edit-event-form select{padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--bg-secondary);color:var(--text-primary)}#edit-event-form input[type=text]:focus,#edit-event-form select:focus{outline:none;border-color:var(--primary-color)}#edit-event-form input[type=text]:disabled,#edit-event-form select:disabled{opacity:.6;cursor:not-allowed}#overlay-dialog-buttons{display:flex;flex-direction:row;gap:8px;margin-top:8px}#overlay-dialog-buttons .delete-button{background-color:var(--error-color, #dc3545);color:#fff;border:none}#overlay-dialog-buttons .delete-button:hover:not(:disabled){background-color:var(--error-color-hover, #c82333)}#overlay-dialog-buttons .delete-button:disabled{opacity:.6;cursor:not-allowed}#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}#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;order:-1;display:flex;flex-direction:column;padding-top:8px;border-right:1px solid #e1e1e1;background:#fff;transition:transform .3s ease;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}@media (min-width: 769px){.event-page-sidebar:not(.open){width:0!important;flex:0 0 0!important;overflow:hidden;border-right:none}.event-page-sidebar.open{transition:transform .3s ease}}.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;transform:translate(-100%);transition:transform .3s ease;box-shadow:2px 0 8px #00000026}.sidebar-resize-handle{display:none}.event-page-sidebar.open{transform:translate(0)}.mobile-menu-overlay{position:fixed;top:53px;left:0;right:0;bottom:0;background:#00000080;z-index:999}.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%;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}.event-assignment{display:flex;flex-direction:column;height:100%}.event-assignment h3{margin:0 0 20px;font-size:18px;font-weight:400;color:#333}.event-search{margin-bottom:20px}.event-search-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.event-search-input:focus{outline:none;border-color:#b2c819}.event-assignment-content{display:flex;gap:20px;flex:1;min-height:0;overflow-y:auto}.assigned-events,.unassigned-events{flex:1;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;padding:15px;overflow-y:auto}.assigned-events h4,.unassigned-events h4{margin:0 0 15px;font-size:14px;font-weight:500;color:#333}.event-list{list-style:none;margin:0;padding:0}.event-item{display:flex;justify-content:space-between;align-items:center;padding:12px;margin-bottom:8px;background-color:#fff;border:1px solid #ddd;border-radius:4px;transition:all .2s}.event-item:hover{border-color:#b2c819}.event-item.assigned{border-left:3px solid #b2c819}.event-info{flex:1}.event-name{font-weight:500;color:#333;font-size:14px;margin-bottom:4px}.event-id{font-size:12px;color:#999;font-family:monospace}.event-action{width:28px;height:28px;border:none;border-radius:50%;cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s}.event-action.add{background-color:#b2c819;color:#fff}.event-action.add:hover{background-color:#9ab015}.event-action.remove{background-color:#f44336;color:#fff}.event-action.remove:hover{background-color:#d32f2f}.event-action:disabled{opacity:.5;cursor:not-allowed}.empty-state{padding:40px;text-align:center;color:#999;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}.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}.admin-loading{padding:40px;text-align:center;color:#666}.event-management{display:flex;flex-direction:column;height:100%}.event-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.event-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}.event-management-content{flex:1;overflow-y:auto;background-color:#fff;border:1px solid #ddd;border-radius:4px}.events-table{width:100%;border-collapse:collapse}.events-table thead{background-color:#f9f9f9;position:sticky;top:0;z-index:1}.events-table th{padding:12px 15px;text-align:left;font-weight:500;font-size:14px;color:#333;border-bottom:2px solid #ddd}.events-table td{padding:12px 15px;font-size:14px;color:#666;border-bottom:1px solid #eee}.events-table tbody tr:hover{background-color:#f9f9f9}.event-id{font-family:monospace;font-size:12px;color:#999}.empty-state{padding:40px;text-align:center;color:#999}#admin-page{display:flex;flex-direction:column;height:100vh;background-color:#f5f5f5}.admin-header{background-color:#fff;padding:20px;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;align-items:center}.admin-header h1{margin:0;font-size:24px;font-weight:400;color:#333}.admin-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background-color:#f5f5f5;transition:background-color .2s;text-decoration:none}.admin-close:hover{background-color:#e0e0e0}.admin-close svg{width:20px;height:20px;fill:#666}.admin-close:hover svg{fill:#333}.admin-tabs{display:flex;background-color:#fff;border-bottom:1px solid #ddd}.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}.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}.racer-items-by-event{flex:1 1 0;display:flex;flex-direction:column;overflow:hidden}.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-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}}: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}
