:root{--primary:#2196f3;--bg:#fff;--card-bg:#f9f9f9;--border:#ccc;--text:#333;--text-light:#666;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace}*{box-sizing:border-box}body{font:16px/1.5 var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0}h1{margin:0;font-size:20px;font-weight:700}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.navbar{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;align-items:center;gap:12px;padding:12px 20px;display:flex;position:sticky;top:0}.nav-back{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:15px}.nav-title{color:var(--text);flex:1;font-size:17px;font-weight:700}.lang-selector{background:var(--bg);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:3px 6px;font-family:inherit;font-size:13px}.page{max-width:900px;margin:0 auto;padding:20px}.pit-page{max-width:1200px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.pit-header-controls{align-items:center;gap:12px;display:flex}.pit-stat-inline{color:var(--text-light);font-size:14px}.btn{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:5px;padding:10px 20px;font-size:15px}.btn:hover{background:#f5f5f5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:#1e88e5}.btn-primary:disabled{background:#90caf9;border-color:#90caf9}.btn-sm{padding:6px 14px;font-size:14px}.btn-danger{color:#fff;background:#f44336;border-color:#f44336}.btn-danger:hover{background:#d32f2f}.btn-full{width:100%;margin-top:16px}.race-list{flex-direction:column;gap:8px;display:flex}.race-item{background:var(--primary);color:#fff;text-align:left;border:none;border-radius:5px;justify-content:space-between;align-items:center;padding:12px 16px;font-size:15px;display:flex}.race-item:hover{background:#1e88e5}.race-id{opacity:.8;font-size:12px}.form{flex-direction:column;gap:4px;display:flex}.form-label{flex-direction:column;gap:4px;margin-top:10px;font-size:14px;font-weight:700;display:flex}.form-input{border:1px solid var(--border);border-radius:5px;padding:8px;font-size:15px;font-weight:400}.form-buttons{gap:10px;margin-top:16px;display:flex}.form-buttons .btn{flex:1}.scanner-container{border:1px solid var(--border);border-radius:8px;margin-bottom:16px;overflow:hidden}#qr-reader{width:100%}#qr-reader video{border-radius:8px}.iframe-container{border:1px solid var(--border);border-radius:8px;height:400px;margin-top:16px;overflow:hidden}.iframe-container iframe{border:none;width:100%;height:100%}.kart-shape{cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0;transition:transform .15s,box-shadow .15s;position:relative}.kart-shape:active{cursor:grabbing}.kart-shape:hover{transform:translateY(-2px)}.kart-svg{width:100%;height:100%;display:block}.kart-compact{width:165px;height:120px}.kart-full{width:180px;height:132px}.kart-overlay{pointer-events:none;flex-direction:row;justify-content:center;align-items:center;gap:4px;display:flex;position:absolute;inset:16% 8% 16% 10%;overflow:hidden}.kart-col-left{flex-direction:column;flex:1;justify-content:center;align-items:flex-start;gap:0;min-width:0;display:flex}.kart-col-right{font-family:var(--mono);color:#fffffff2;text-shadow:0 1px 2px #00000080;white-space:pre;flex-direction:column;flex-shrink:0;justify-content:center;align-items:flex-end;gap:0;padding-left:6px;font-size:8px;line-height:1.25;display:flex}.kart-full .kart-col-right{font-size:9px}.kart-num{color:#fff;text-shadow:0 1px 3px #0009;font-size:18px;font-weight:800;line-height:1.1}.kart-full .kart-num{font-size:22px}.kart-team-name{color:#fff;text-shadow:0 1px 2px #00000080;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:9px;font-weight:700;line-height:1.25;overflow:hidden}.kart-full .kart-team-name{font-size:10px}.kart-driver-name{color:#ffffffe6;text-shadow:0 1px 2px #0006;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:8px;line-height:1.25;overflow:hidden}.kart-full .kart-driver-name{font-size:9px}.kart-num-row{align-items:center;gap:4px;display:flex}.kart-cat-label{letter-spacing:.3px;white-space:nowrap;border-radius:3px;padding:1px 3px;font-size:7px;font-weight:700;line-height:1.1;box-shadow:0 1px 2px #0000004d}.kart-full .kart-cat-label{padding:1px 4px;font-size:8px}.kart-dummy{opacity:.55;cursor:grab}.kart-dummy:hover{opacity:.75}.kart-num-dummy{color:#888;text-shadow:none;font-size:28px}.kart-full.kart-dummy .kart-num-dummy{font-size:34px}.kart-queue{border:2px dashed var(--border);background:#f0f0f0;border-radius:10px;min-height:120px;margin-bottom:20px;padding:10px;transition:border-color .2s,background .2s}.kart-queue.drag-over{border-color:var(--primary);background:#e3f2fd}.queue-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:600}.queue-track{align-items:flex-start;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.queue-empty{color:#aaa;padding:20px 0;font-size:13px;font-style:italic}.pit-lanes{flex-direction:column-reverse;gap:0;display:flex}.lanes-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.lanes-title{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.config-bar{flex-wrap:wrap;gap:20px;margin-bottom:16px;display:flex}.config-item{color:var(--text-light);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.stepper{color:var(--text);align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.pit-lane{background:repeating-linear-gradient(90deg,#0000,#0000 48px,#00000008 48px 50px),#e8e8e8;border:2px solid #ddd;border-bottom:none;align-items:stretch;min-height:148px;transition:border-color .2s,background-color .2s;display:flex}.pit-lane:first-child{border-bottom:2px solid #ddd;border-radius:0 0 8px 8px}.pit-lane:last-child{border-radius:8px 8px 0 0}.pit-lane:only-child{border-bottom:2px solid #ddd;border-radius:8px}.pit-lane.drag-over{border-color:var(--primary);background-color:#e3f2fd}.lane-label{writing-mode:vertical-lr;text-orientation:mixed;color:#fff;letter-spacing:1px;text-transform:uppercase;background:#777;flex-shrink:0;justify-content:center;align-items:center;min-width:28px;padding:8px 6px;font-size:12px;font-weight:700;display:flex;transform:rotate(180deg)}.pit-lane:first-child .lane-label{border-radius:0 0 0 6px}.pit-lane:last-child .lane-label{border-radius:6px 0 0}.pit-lane:only-child .lane-label{border-radius:6px 0 0 6px}.lane-track{flex:1;align-items:center;gap:4px;min-height:0;padding:8px 12px;display:flex;overflow-x:auto}.lane-insert-zone{border-radius:3px;flex-shrink:0;align-self:stretch;width:6px;transition:background .15s,width .15s}.lane-insert-zone.insert-drag-over{background:var(--primary);width:8px}.lane-kart-slot{border-left:3px solid #0000;flex-shrink:0;padding-left:4px;transition:border-color .15s}.lane-kart-slot.slot-drag-over{border-left-color:var(--primary)}.lane-placeholder{color:#bbb;font-size:13px;font-style:italic}.add-dummy-btn{color:#aaa;cursor:pointer;background:0 0;border:2px dashed #bbb;border-radius:8px;flex-shrink:0;justify-content:center;align-self:center;align-items:center;width:40px;height:60px;font-size:24px;font-weight:700;transition:border-color .15s,color .15s;display:flex}.add-dummy-btn:hover{border-color:var(--primary);color:var(--primary)}.bin{color:#b44;background:#fdf2f2;border:2px dashed #dbb;border-radius:10px;justify-content:center;align-items:center;gap:10px;margin-top:20px;padding:16px;font-size:14px;font-weight:600;transition:border-color .2s,background .2s,color .2s;display:flex}.bin.drag-over{color:#c62828;background:#ffebee;border-color:#e53935}.bin-icon{width:22px;height:22px}.empty-text{color:var(--text-light);text-align:center;padding:20px}.loading{text-align:center;color:var(--primary);padding:20px}.mode-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px;display:grid}@media (width<=700px){.mode-grid{grid-template-columns:1fr}}.mode-card{border:2px solid var(--border);background:var(--bg);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:28px 16px;transition:border-color .2s,box-shadow .2s;display:flex}.mode-card:hover{border-color:var(--primary);box-shadow:0 2px 12px #2196f326}.mode-icon{color:var(--primary);background:#2196f31a;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:32px;font-weight:800;display:flex}.mode-title{color:var(--text);font-size:16px;font-weight:700}.mode-desc{color:var(--text-light);font-size:13px}.mode-badge{color:#fff;background:#4caf50;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:11px;font-weight:600;display:inline-block}.counter-badge{color:#fff;background:#4caf50;border-radius:5px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.counter-badge-off{background:#9e9e9e}.manual-disconnected{color:var(--text-light);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.manual-disconnected-icon{opacity:.4;margin-bottom:12px;font-size:48px}.manual-disconnected h2{color:var(--text);margin:0 0 8px;font-size:18px}.manual-disconnected p{margin:0;font-size:14px}.live-timing-frame{border:1px solid var(--border);border-radius:8px;flex:1;min-height:700px;margin-top:12px;overflow:hidden}.live-timing-frame iframe{border:none;width:100%;height:100%;min-height:700px}.info-banner{color:#1565c0;background:#e3f2fd;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-size:14px}.wknd-card{color:#fff;text-align:left;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffffff14;border-radius:10px;flex-direction:column;gap:6px;width:100%;padding:14px 18px;font-size:15px;transition:transform .15s,box-shadow .15s;display:flex}.wknd-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.wknd-card-top{align-items:center;gap:8px;display:flex}.wknd-card-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:15px;font-weight:700;overflow:hidden}.wknd-card-stats{color:#ffffff8c;gap:16px;font-size:12px;display:flex}.wknd-status-badge{color:#fff;letter-spacing:.3px;text-transform:uppercase;border-radius:12px;flex-shrink:0;padding:2px 10px;font-size:11px;font-weight:600}.wknd-card-wrapper{position:relative}.wknd-demo-popover{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #9c27b04d;border-radius:12px;flex-direction:column;gap:12px;margin-top:6px;padding:14px;display:flex}.wknd-demo-speed-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.wknd-demo-speed-row .wknd-label{color:#fff9}.wknd-btn-demo{color:#fff;background:linear-gradient(135deg,#9c27b0,#7b1fa2);box-shadow:0 2px 8px #9c27b04d}.wknd-btn-demo:hover:not(:disabled){box-shadow:0 4px 16px #9c27b066}.wknd-create-page{max-width:520px}.wknd-create-title{margin-bottom:4px;font-size:24px;font-weight:800}.wknd-create-subtitle{color:var(--text-light);margin:0 0 24px;font-size:14px}.wknd-form{flex-direction:column;gap:18px;display:flex}.wknd-field{flex-direction:column;gap:6px;display:flex}.wknd-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.wknd-input{color:var(--text);background:#f5f7fa;border:2px solid #0000;border-radius:10px;outline:none;padding:12px 16px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s,background .2s}.wknd-input::placeholder{color:#aab}.wknd-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #2196f31f}.wknd-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:transform .1s,box-shadow .15s,background .2s,opacity .2s;display:inline-flex}.wknd-btn:active{transform:scale(.97)}.wknd-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.wknd-btn-primary{color:#fff;background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 2px 8px #2196f34d}.wknd-btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #2196f366}.wknd-btn-outline{border:2px solid var(--border);color:var(--text);background:0 0;padding:10px 20px}.wknd-btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#2196f30a}.wknd-btn-ghost{color:var(--text-light);background:0 0}.wknd-btn-ghost:hover{color:var(--text);background:#0000000a}.wknd-btn-full{width:100%}.wknd-btn-icon{font-size:18px;line-height:1}.wknd-qr-section{margin-top:2px}.wknd-qr-buttons{gap:10px;display:flex}.wknd-qr-buttons .wknd-btn{flex:1}.wknd-scanner{border:2px solid var(--border);border-radius:12px;overflow:hidden}.wknd-scanner #wknd-qr-reader{width:100%}.wknd-scanner #wknd-qr-reader video{border-radius:10px}.wknd-error{color:#c62828;background:#fff3f3;border:1px solid #ffcdd2;border-radius:8px;padding:10px 14px;font-size:13px}.wknd-actions{flex-direction:column;gap:8px;margin-top:8px;display:flex}.wknd-divider{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:12px;margin:4px 0;font-size:12px;display:flex}.wknd-divider:before,.wknd-divider:after{content:"";background:var(--border);flex:1;height:1px}.dash-page{max-width:900px}.dash-title{margin-bottom:16px;font-size:22px;font-weight:800}.dash-card{color:#fff;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #ffffff0f;border-radius:14px;margin-bottom:14px;padding:20px}.dash-status-row{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.dash-status-left{align-items:center;gap:10px;display:flex}.dash-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dash-status-text{text-transform:uppercase;letter-spacing:.5px;font-size:14px;font-weight:700}.dash-recording-pill{color:#81c784;background:#4caf5026;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.dash-recording-dot{background:#4caf50;border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite dashPulse}@keyframes dashPulse{0%,to{opacity:1}50%{opacity:.3}}.dash-stats{align-items:center;gap:0;display:flex}.dash-stat{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.dash-stat-value{color:#fff;font-size:28px;font-weight:800;line-height:1.1}.dash-stat-label{text-transform:uppercase;letter-spacing:.5px;color:#ffffff73;font-size:11px;font-weight:600}.dash-stat-divider{background:#ffffff1a;flex-shrink:0;width:1px;height:40px}.dash-race-banner{color:#ffb74d;cursor:pointer;background:#ff98001f;border:1px solid #ff980040;border-radius:10px;align-items:center;gap:10px;width:100%;margin-top:18px;padding:12px 16px;font-size:14px;font-weight:600;transition:background .2s;display:flex}.dash-race-banner:hover{background:#ff980033}.dash-race-banner-dot{background:#ff9800;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1.5s ease-in-out infinite dashPulse}.dash-race-banner-arrow{opacity:.8;margin-left:auto;font-size:13px}.dash-section-title{color:#fff;margin:0 0 16px;font-size:16px;font-weight:700}.dash-card .wknd-label{color:#ffffff80}.dash-card .wknd-input{color:#fff;background:#ffffff12;border:2px solid #ffffff1a}.dash-card .wknd-input::placeholder{color:#ffffff4d}.dash-card .wknd-input:focus{border-color:var(--primary);background:#ffffff1a;box-shadow:0 0 0 3px #2196f333}.dash-steppers{flex-wrap:wrap;gap:24px;margin-bottom:18px;display:flex}.dash-stepper-group{flex-direction:column;gap:8px;display:flex}.dash-stepper{background:#ffffff12;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:0;display:flex;overflow:hidden}.dash-stepper-btn{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;font-weight:700;transition:background .15s;display:flex}.dash-stepper-btn:hover{background:#ffffff1a}.dash-stepper-btn:active{background:#ffffff26}.dash-stepper-value{text-align:center;color:#fff;min-width:36px;font-size:18px;font-weight:800}.dash-btn-warning{color:#fff;background:linear-gradient(135deg,#ff9800,#f57c00);margin-bottom:8px;box-shadow:0 2px 8px #ff98004d}.dash-btn-warning:hover:not(:disabled){box-shadow:0 4px 16px #ff980066}.dash-btn-danger{color:#fff;background:linear-gradient(135deg,#ef5350,#c62828);box-shadow:0 2px 8px #c628284d}.dash-btn-danger:hover:not(:disabled){box-shadow:0 4px 16px #c6282866}@keyframes kartFadeIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes kartSlideIn{0%{opacity:0;transform:translateY(-10px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.queue-track .kart-shape{animation:.3s ease-out kartFadeIn}.lane-kart-slot,.snake-row .kart-shape,.lane-track .kart-shape{transition:transform .25s,opacity .25s}.mobile-menu-btn,.mobile-dropdown{display:none}@media (orientation:portrait) and (width<=768px){.pit-page{box-sizing:border-box;flex-direction:column;max-width:100%;padding:6px;display:flex}.page-header{gap:4px;margin-bottom:4px}.page-header h1{font-size:14px}.pit-header-controls{gap:6px}.pit-stat-inline{font-size:11px}.counter-badge{padding:2px 6px;font-size:10px}.btn-sm{padding:3px 8px;font-size:11px}.config-bar,.desktop-only{display:none}.mobile-menu-btn{padding:2px 8px;font-size:16px;display:inline-flex!important}.mobile-dropdown{background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;margin-bottom:4px;padding:8px;display:flex;box-shadow:0 4px 12px #0000001a}.mobile-dropdown-row{justify-content:center;align-items:center;gap:8px;display:flex}.mobile-dropdown .config-item{font-size:12px}.mobile-dropdown .stepper{gap:6px;font-size:13px}.kart-compact,.kart-full{width:128px;height:85px}.kart-overlay{text-align:center;justify-content:center;align-items:center;gap:0;inset:22% 18%}.kart-col-right{display:none}.kart-col-left{text-align:center;align-items:center;width:100%}.kart-num{font-size:22px;line-height:1}.kart-full .kart-num,.kart-compact .kart-num{font-size:22px}.kart-team-name{white-space:normal;word-break:break-word;text-overflow:clip;text-align:center;max-width:100%;font-size:9px;line-height:1.15;overflow:hidden}.kart-full .kart-team-name,.kart-compact .kart-team-name{font-size:9px}.kart-driver-name{display:none}.kart-num-row{justify-content:center;gap:2px}.lane-track .kart-num-row{flex-direction:column;align-items:center;gap:1px}.kart-cat-label{padding:1px 4px!important;font-size:8px!important}.kart-num-dummy{font-size:24px}.kart-queue{flex-shrink:0;min-height:0;margin-bottom:4px;padding:4px 6px}.queue-label{margin-bottom:2px;font-size:10px}.queue-empty{padding:8px 0;font-size:10px}.pit-lanes{flex-direction:row;gap:4px;min-height:0;display:flex}.lanes-header{display:none}.pit-lane{border:2px solid #ddd;border-radius:8px;flex-direction:column;flex:1;min-width:0;min-height:0}.pit-lane:first-child{border-radius:8px}.pit-lane:last-child{border-bottom:2px solid #ddd;border-radius:8px}.pit-lane:only-child{border-radius:8px}.pit-lane:first-child .lane-label,.pit-lane:last-child .lane-label,.pit-lane:only-child .lane-label{border-radius:6px 6px 0 0}.lane-label{writing-mode:horizontal-tb;text-orientation:initial;text-align:center;border-radius:6px 6px 0 0;width:100%;min-width:0;padding:4px;font-size:10px;transform:none}.lane-track{flex-direction:column;align-items:stretch;gap:2px;padding:2px 0;overflow:hidden auto}.lane-insert-zone{align-self:stretch;width:auto;height:4px}.lane-insert-zone.insert-drag-over{width:auto;height:6px}.lane-kart-slot{border-top:3px solid #0000;border-left:none;padding:0}.lane-kart-slot.slot-drag-over{border-top-color:var(--primary);border-left-color:#0000}.lane-track .kart-shape{aspect-ratio:100/140;min-width:0;width:100%!important;height:auto!important}.lane-track .kart-svg{transform:rotate(90deg)}.lane-track .kart-shape{animation:.3s ease-out kartSlideIn}.lane-track .kart-overlay{text-align:center;justify-content:center;align-items:center;inset:8% 22%}.queue-track .kart-shape{aspect-ratio:auto;width:128px!important;height:85px!important}.add-dummy-btn{border-width:1px;width:100%;height:32px;font-size:18px}.bin{flex-grow:0;flex-shrink:0;gap:8px;margin-top:6px;padding:16px;font-size:12px}.bin-icon{width:20px;height:20px}.navbar{gap:8px;padding:6px 10px}.nav-title{font-size:14px}.nav-back{font-size:13px}}
