:root{--red:#d81e2c;--red-dark:#b8121f;--bg:#f3f4f6;--panel:#fff;--border:#e2e5ea;--text:#1f2430;--muted:#6b7280;--selected:#ffd24a}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px}.app{display:flex;flex-direction:column;height:100%}.topbar{background:var(--red);color:#fff;display:flex;flex:none;align-items: center;height:56px;padding:0 18px}.brand{display:flex;align-items: center;gap:10px}.logo{font-size:22px}.brand-name{letter-spacing:.3px;font-size:20px;font-weight:800}.subbar{display:flex;color:#ffffffd9;align-items: center;gap:14px;margin-left:auto;font-size:13px}.subbar b{color:#fff}.source{font-weight:600}.source-network{color:#bbf7d0}.source-cache{color:#fed7aa}.statusbar{display:flex;box-sizing:border-box;color:#fff;background:#1f2937;flex:none;align-items: center;gap:10px;min-height:31px;padding:7px 18px}.statusbar-hidden{visibility:hidden}.statusbar-nr{font-variant-numeric:tabular-nums;font-size:16px;font-weight:800}.statusbar-sep{opacity:.5}.statusbar-name{font-size:16px;font-weight:600}.statusbar-team{letter-spacing:.5px;opacity:.7;margin-left:auto;font-size:12px;font-weight:700}.btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#fff;border-radius:6px;padding:6px 12px;font-size:13px}.btn:hover{background:#f6f7f9}.btn.ghost{background:#f3f4f6}.btn.danger{color:var(--red);border-color:#f3c2c6}.link{color:var(--red);cursor:pointer;font:inherit;text-decoration:underline;background:0 0;border:none;padding:0}.main{overflow:hidden;flex:1;min-height:0}.layout{display:grid;grid-template-columns:1.35fr 1fr;grid-template-rows:minmax(0,1fr);gap:2px;height:100%;padding:2px}.panel{background:var(--panel);border:1px solid var(--border);display:flex;overflow:hidden;border-radius:10px;flex-direction:column;min-height:0}.panel-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);border-bottom:1px solid var(--border);margin:0;padding:12px 14px;font-size:13px}.teams{overflow:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));flex:1;align-content: start;align-items: start;gap:12px;min-height:0;padding:12px}.team{position:relative;display:flex;border:1px solid var(--border);overflow:hidden;background:#fff;border-radius:8px;flex-direction:column;height:104px}.team-head{letter-spacing:.5px;color:var(--red);border-bottom:1px solid #f1f2f4;flex:none;padding:6px 8px 2px;font-size:11px;font-weight:800}.riders{overflow:auto;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:min-content;flex:1;gap:4px;min-height:0;padding:6px}.rider{display:flex;border:1px solid var(--border);cursor:pointer;font:inherit;font-variant-numeric:tabular-nums;background:#fff;border-radius:6px;justify-content:center;align-items: center;min-height:19px;padding:4px 2px;font-size:15px;font-weight:700}.rider:hover{background:#f6f7f9}.rider.assigned:hover{filter:brightness(.92)}.rider.selected{outline:3px solid var(--text);outline-offset:-1px}.hint{color:var(--muted);background:#f3f4f6;border-radius:6px;margin:12px 12px 0;padding:8px 10px;font-size:13px}.hint.active{color:#6b5300;background:#fff6da;border:1px solid #f1dd9a}.groups{overflow:auto;flex:1;min-height:0;padding:8px 12px 16px}.insert-slot{color:#0000;cursor:default;font:inherit;background:0 0;border:1px dashed #0000;border-radius:6px;width:100%;margin:2px 0;padding:3px;font-size:12px}.insert-slot.enabled{color:var(--muted);cursor:pointer;border-color:#cbd5e1}.insert-slot.enabled:hover{border-color:var(--red);color:var(--red);background:#fff5f5}.group-row{display:flex;align-items:stretch}.group-gaps{display:flex;text-align:right;flex-direction:column;flex:none;justify-content:center;gap:7px;width:62px;padding-right:8px}.gap{display:flex;flex-direction:column;line-height:1.05}.gap-label{text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-size:9px;font-weight:700}.gap-time{font-variant-numeric:tabular-nums;color:var(--text);font-size:15px;font-weight:800}.gap-lead .gap-time{color:var(--red)}.gap-leadtag{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-size:10px;font-weight:800}.group{border:2px solid var(--border);overflow:hidden;background:#fff;border-radius:8px;flex:1;min-width:0}.group.droppable{cursor:copy}.group.droppable:hover{box-shadow:0 0 0 3px #d81e2c1f}.group.source{box-shadow:0 0 0 3px var(--selected)}.group-head{display:flex;color:#fff;align-items: center;gap:8px;padding:6px 10px}.grip{display:inline-flex;color:#fff;cursor:grab;background:#ffffff38;border:none;border-radius:5px;justify-content:center;align-items: center;padding:4px 5px;line-height:0}.grip:hover{background:#fff6}.grip:active{cursor:grabbing}.group-label{flex:1;font-weight:700}.clock{display:inline-flex;color:#fff;cursor:pointer;background:#ffffff38;border:none;border-radius:5px;justify-content:center;align-items: center;padding:4px 6px;line-height:0}.clock:hover{background:#fff6}.group-count{font-variant-numeric:tabular-nums;background:#ffffff40;border-radius:999px;padding:0 8px;font-size:12px;font-weight:700}.group-body{display:flex;flex-wrap:wrap;gap:6px;min-height:38px;padding:8px}.empty{color:var(--muted);align-self: center;font-size:12px;font-style:italic}.field-summary{color:var(--muted);align-self: center;font-size:13px;font-weight:600}.chip{display:inline-flex;border:1px solid var(--border);cursor:pointer;font:inherit;background:#f7f8fa;border-radius:6px;align-items: center;gap:6px;padding:3px 8px;font-size:12px}.chip:hover{background:#eef0f3}.chip.selected{background:var(--selected);border-color:#e0b400}.chip .nr{font-variant-numeric:tabular-nums;font-weight:700}.chip .cteam{color:var(--muted);font-size:11px}.modal-overlay{position:fixed;z-index:60;display:flex;background:#0f141e8c;justify-content:center;align-items: center;padding:20px;inset:0}.modal{background:#fff;border-radius:16px;width:min(94vw,360px);padding:22px 22px 18px;box-shadow:0 18px 50px #00000059}.modal-title{margin:0 0 2px;font-size:16px}.modal-sub{color:var(--muted);margin:0 0 20px;font-size:13px;font-weight:700}.time-edit{display:flex;justify-content:center;align-items: center;gap:14px}.time-field{display:flex;flex-direction:column;align-items: center;gap:8px}.time-num{border:1px solid var(--border);text-align:center;font:inherit;font-variant-numeric:tabular-nums;color:var(--text);border-radius:10px;width:96px;height:64px;font-size:40px;font-weight:800}.time-num:focus{outline:2px solid var(--red);border-color:var(--red)}.time-unit{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-size:11px;font-weight:700}.time-colon{margin-bottom:30px;font-size:40px;font-weight:800}.step{border:1px solid var(--border);cursor:pointer;background:#f3f4f6;border-radius:10px;width:96px;height:46px;font-size:26px;font-weight:700;line-height:1}.step:hover{background:#e9ebef}.step:active{background:#dfe2e7}.modal-actions{display:flex;align-items: center;gap:10px;margin-top:22px}.modal-spacer{flex:1}.btn.primary{background:var(--red);color:#fff;border-color:var(--red);font-weight:700}.btn.primary:hover{background:var(--red-dark)}.centered{display:flex;color:var(--muted);flex-direction:column;justify-content:center;align-items: center;gap:14px;height:100%}.centered.error{color:var(--red);text-align:center;padding:24px}
