:root { --bg: #07090e; --bg-soft: #0f1420; --panel: #131a28; --panel-2: #0c1220; --line: #273149; --text: #f3f7ff; --muted: #98a7c8; --accent: #e10600; --accent-2: #ff3b30; --ok: #26c281; --warn: #f5a623; --surface-soft: rgba(255, 255, 255, 0.02); --surface-card: rgba(255, 255, 255, 0.03); --surface-elevated: rgba(255, 255, 255, 0.025); --field-bg: #0f1522; --field-text: var(--text); --table-head-bg: rgba(255, 255, 255, 0.03); --table-hover-bg: rgba(255, 255, 255, 0.02); --danger-soft: rgba(225, 6, 0, 0.08); --danger-text: #ffd0d0; --shadow: 0 12px 32px rgba(0, 0, 0, 0.35); } body[data-theme="nord"] { --bg: #0b1220; --bg-soft: #131d31; --panel: #182235; --panel-2: #10192b; --line: #31425f; --text: #edf3ff; --muted: #a7b8d8; --accent: #5e81ac; --accent-2: #88c0d0; --ok: #79c9a4; --warn: #f0c674; --surface-soft: rgba(255, 255, 255, 0.025); --surface-card: rgba(255, 255, 255, 0.04); --surface-elevated: rgba(255, 255, 255, 0.03); --field-bg: #132033; --field-text: var(--text); --table-head-bg: rgba(255, 255, 255, 0.04); --table-hover-bg: rgba(255, 255, 255, 0.03); --danger-soft: rgba(191, 97, 106, 0.14); --danger-text: #ffd8db; --shadow: 0 12px 32px rgba(4, 10, 18, 0.42); } body[data-theme="light"] { --bg: #eef2f8; --bg-soft: #f7f9fc; --panel: #ffffff; --panel-2: #ecf1f7; --line: #cfd8e6; --text: #152033; --muted: #5f708d; --accent: #d62828; --accent-2: #ef4444; --ok: #1f9d67; --warn: #c98914; --surface-soft: rgba(20, 32, 51, 0.03); --surface-card: rgba(20, 32, 51, 0.05); --surface-elevated: rgba(20, 32, 51, 0.04); --field-bg: #ffffff; --field-text: #152033; --table-head-bg: rgba(20, 32, 51, 0.05); --table-hover-bg: rgba(20, 32, 51, 0.03); --danger-soft: rgba(214, 40, 40, 0.08); --danger-text: #8e1b1b; --shadow: 0 10px 28px rgba(27, 45, 78, 0.12); } * { box-sizing: border-box; } body { margin: 0; font-family: Barlow, "Segoe UI", sans-serif; color: var(--text); background: radial-gradient(circle at 15% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 30%), radial-gradient(circle at 100% 80%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 30%), linear-gradient(160deg, color-mix(in srgb, var(--bg) 90%, #000 10%) 0%, var(--bg-soft) 55%, var(--bg) 100%); min-height: 100vh; } .app-shell { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; } .sidebar { border-right: 1px solid var(--line); background: linear-gradient(180deg, rgba(225, 6, 0, 0.1), transparent 25%), repeating-linear-gradient( -32deg, rgba(255, 255, 255, 0.02) 0, rgba(255, 255, 255, 0.02) 6px, transparent 6px, transparent 18px ), var(--panel-2); padding: 20px 16px; position: sticky; top: 0; height: 100vh; } .brand { display: flex; align-items: center; gap: 12px; padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 12px; } .brand-mark { width: 46px; height: 46px; border-radius: 10px; display: grid; place-items: center; font-family: Orbitron, sans-serif; font-weight: 800; background: linear-gradient(135deg, #ff574f 0%, var(--accent) 55%, #8b0000 100%); box-shadow: 0 8px 20px rgba(225, 6, 0, 0.5); } .brand h1 { margin: 0; font-family: Orbitron, sans-serif; font-size: 1.05rem; letter-spacing: 0.5px; } .brand p { margin: 4px 0 0; color: var(--muted); font-size: 0.84rem; } .nav { display: grid; gap: 8px; padding-top: 6px; } .nav-item { border: 1px solid var(--line); background: var(--surface-soft); color: var(--text); border-radius: 10px; padding: 10px 12px; text-align: left; cursor: pointer; transition: all 0.2s ease; font-weight: 600; } .nav-item:hover { border-color: #405076; transform: translateX(3px); } .nav-item.active { border-color: rgba(255, 88, 79, 0.55); background: linear-gradient(90deg, rgba(225, 6, 0, 0.3), rgba(225, 6, 0, 0.1)); } .sidebar-footer { position: absolute; left: 16px; right: 16px; bottom: 16px; color: var(--muted); } .badge { display: inline-block; border-radius: 999px; padding: 5px 10px; font-size: 0.8rem; font-weight: 700; border: 1px solid; } .badge-online { color: #b8ffd6; border-color: rgba(38, 194, 129, 0.7); background: rgba(38, 194, 129, 0.18); } .badge-offline { color: #ffd2cf; border-color: rgba(225, 6, 0, 0.7); background: rgba(225, 6, 0, 0.15); } .content { padding: 20px 24px 26px; } .topbar { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--line); padding-bottom: 14px; } .topbar h2 { margin: 0; font-family: Orbitron, sans-serif; letter-spacing: 0.4px; } .topbar p { margin: 6px 0 0; color: var(--muted); } .chip { margin: 0; border: 1px solid var(--line); border-radius: 999px; padding: 8px 12px; font-weight: 600; background: var(--surface-soft); } .topbar-right { display: flex; align-items: center; gap: 10px; } .lang-wrap { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); font-size: 0.86rem; } .lang-select { width: 70px; padding: 6px 8px; border-radius: 8px; } .theme-wrap { min-width: 120px; } .theme-select { min-width: 120px; } .view { margin-top: 16px; } .grid { display: grid; gap: 14px; } .cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); } .stat-card { background: linear-gradient(170deg, color-mix(in srgb, var(--accent) 12%, transparent), transparent 40%), linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%); border: 1px solid var(--line); border-radius: 14px; padding: 14px; box-shadow: var(--shadow); } .stat-card p { margin: 0; color: var(--muted); } .stat-card h3 { margin: 6px 0; font-family: Orbitron, sans-serif; font-size: 1.5rem; } .panel-row { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; margin-top: 14px; } .panel { background: linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%); border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow); overflow: hidden; } .panel-header { padding: 12px 14px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; } .panel-header-with-pill { gap: 10px; } .panel-header h3 { margin: 0; font-size: 1rem; letter-spacing: 0.3px; } .panel-body { padding: 12px 14px; } .settings-grid { gap: 10px; } .settings-grid-toggles .toggle { min-height: 40px; } .actions { display: flex; gap: 10px; flex-wrap: wrap; } .btn { border: 1px solid color-mix(in srgb, var(--line) 72%, var(--accent) 28%); background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 88%, white 12%) 0%, var(--panel-2) 100%); color: var(--text); border-radius: 10px; font-weight: 700; padding: 9px 12px; cursor: pointer; } .btn:hover { border-color: color-mix(in srgb, var(--line) 45%, var(--accent) 55%); } .btn-primary { border-color: #b11714; background: linear-gradient(180deg, #f20d07 0%, #d30702 52%, #8e0603 100%); } .btn-danger { border-color: #843137; background: linear-gradient(180deg, #8f222a, #66181e); } .btn-mini { padding: 3px 8px; font-size: 0.76rem; } .form-grid { display: grid; gap: 10px; } .field-card { display: grid; gap: 8px; align-content: start; padding: 12px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-elevated); } .field-card-checkbox { grid-column: span 2; } .field-label { font-weight: 700; } .field-hint { color: var(--muted); font-size: 0.84rem; line-height: 1.4; } .cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); } .cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); } .cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); } .btn.is-active { border-color: #d30702; box-shadow: inset 0 0 0 1px rgba(242, 13, 7, 0.25); } .race-wizard-steps, .manage-step-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; } .wizard-step, .manage-step-card { padding: 10px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-elevated); display: grid; gap: 5px; } .manage-step-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; } .wizard-step span { width: 26px; height: 26px; border-radius: 999px; display: grid; place-items: center; border: 1px solid var(--line); font-weight: 800; } .wizard-step strong, .manage-step-card strong { font-size: 0.92rem; } .wizard-step-active { border-color: rgba(225, 6, 0, 0.55); background: rgba(225, 6, 0, 0.08); } .wizard-step-complete span, .wizard-step-active span { border-color: #d30702; background: rgba(225, 6, 0, 0.16); } .manage-step-card p { margin: 0; color: var(--muted); line-height: 1.38; } .manage-step-meta { font-size: 0.78rem; color: var(--muted); } .manage-step-card-link { cursor: pointer; transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease; } .manage-step-card-link:hover { border-color: rgba(225, 6, 0, 0.32); transform: translateY(-1px); } .manage-step-card-link:focus-visible { outline: none; border-color: rgba(225, 6, 0, 0.52); box-shadow: 0 0 0 3px rgba(225, 6, 0, 0.12); } .status-chip { display: inline-flex; align-items: center; justify-content: center; min-width: 72px; padding: 4px 8px; border-radius: 999px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; border: 1px solid var(--line); } .status-chip-complete { background: rgba(46, 204, 113, 0.12); border-color: rgba(46, 204, 113, 0.35); color: #9ef0bf; } .status-chip-pending { background: rgba(136, 149, 178, 0.12); border-color: rgba(136, 149, 178, 0.28); color: #c9d3e8; } .status-chip-attention { background: rgba(245, 166, 35, 0.12); border-color: rgba(245, 166, 35, 0.34); color: #ffd391; } .manage-step-card-complete { border-color: rgba(46, 204, 113, 0.22); } .manage-step-card-attention { border-color: rgba(245, 166, 35, 0.28); } .race-wizard-footer { display: flex; justify-content: space-between; align-items: center; gap: 10px; } .wizard-summary-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; } .wizard-summary-item-wide { grid-column: span 2; } .race-stage-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr); gap: 12px; } .race-setup-shell { display: grid; grid-template-columns: minmax(0, 1.75fr) minmax(250px, 0.9fr); gap: 12px; align-items: start; } .race-setup-main, .race-format-sections, .race-summary-list { display: grid; gap: 12px; } .race-setup-modebar { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; } .race-setup-toggle { gap: 8px; } .race-format-section, .race-summary-card, .race-actions-panel { border: 1px solid var(--line); border-radius: 12px; background: var(--surface-elevated); overflow: hidden; } .race-format-section .panel-header, .race-summary-card .panel-header, .race-actions-panel .panel-header { background: var(--surface-soft); } .race-format-grid { gap: 10px; } .race-preset-actions-card, .race-format-note-card, .race-format-context-card { align-content: start; } .race-format-context-card { grid-column: span 2; border-color: rgba(225, 6, 0, 0.22); background: rgba(225, 6, 0, 0.06); } .race-preset-actions-card-compact .actions-inline { justify-content: flex-start; } .race-format-save-row { display: flex; justify-content: flex-end; } .race-summary-item { display: grid; gap: 4px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: var(--surface-card); } .race-summary-item span { color: var(--muted); font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.06em; } .race-summary-item strong { font-size: 0.92rem; line-height: 1.35; } .race-summary-card { position: sticky; top: 16px; } .race-summary-card .panel-body { display: grid; gap: 10px; } .race-summary-warnings { display: grid; gap: 8px; padding: 12px; border: 1px solid rgba(245, 166, 35, 0.34); border-radius: 12px; background: rgba(245, 166, 35, 0.08); } .race-summary-warnings strong { font-size: 0.86rem; } .race-summary-warnings ul { margin: 0; padding-left: 18px; display: grid; gap: 6px; } .summary-warning-link { display: inline; padding: 0; border: 0; background: transparent; color: #ffd391; text-align: left; cursor: pointer; font: inherit; } .summary-warning-link:hover { text-decoration: underline; } .panel-header-inline { padding: 0; border: 0; background: transparent; } .guide-overview-grid, .guide-section-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; } .guide-overview-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } .guide-overview-card { padding: 14px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-card); display: grid; gap: 8px; } .guide-overview-card strong { font-size: 0.95rem; } .guide-overview-card p { margin: 0; color: var(--muted); line-height: 1.5; } .guide-list { margin: 0; padding-left: 18px; display: grid; gap: 8px; } .guide-list li { line-height: 1.5; } input, select { width: 100%; background: var(--field-bg); border: 1px solid var(--line); border-radius: 10px; color: var(--field-text); padding: 9px 10px; } input:focus, select:focus { outline: none; border-color: #6578a4; box-shadow: 0 0 0 3px rgba(225, 6, 0, 0.18); } .log-box { margin: 10px 0 0; min-height: 120px; max-height: 260px; overflow: auto; border: 1px solid var(--line); border-radius: 10px; padding: 10px; background: color-mix(in srgb, var(--panel-2) 94%, black 6%); color: var(--text); white-space: pre-wrap; font-family: "SFMono-Regular", Consolas, monospace; font-size: 0.82rem; } .data-table { width: 100%; border-collapse: collapse; } .data-table thead { background: var(--table-head-bg); } .data-table th, .data-table td { text-align: left; border-bottom: 1px solid var(--line); padding: 9px 8px; font-size: 0.95rem; } .data-table tr.passing-invalid td { background: var(--danger-soft); color: var(--danger-text); } .data-table th { color: var(--muted); font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.55px; } .data-table tbody tr:hover { background: var(--table-hover-bg); } .simple-list { margin: 0; padding: 0; list-style: none; } .simple-list li { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--line); padding: 8px 0; } .assignment-group { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 12px; padding: 10px; margin-bottom: 10px; } .assignment-group h4 { margin: 0 0 8px; } .assignment-group ul { margin: 0; padding-left: 18px; } .assignment-group li { margin-bottom: 6px; } .actions-inline { display: flex; gap: 6px; flex-wrap: wrap; } .form-error { grid-column: 1 / -1; margin: 0; color: color-mix(in srgb, var(--accent) 62%, white 38%); font-size: 0.9rem; } .quick-add-actions { justify-content: flex-end; } .dashboard-live-stack { display: grid; gap: 14px; } .dashboard-live-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; } .dashboard-live-card { border: 1px solid var(--line); border-radius: 14px; padding: 14px 16px; background: var(--surface-card); } .dashboard-live-card span, .dashboard-live-card small { display: block; color: var(--muted); } .dashboard-live-card strong { display: block; margin: 8px 0 4px; font-family: Orbitron, sans-serif; font-size: 1.1rem; } .timing-top-grid { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.8fr); gap: 12px; } .timing-compact-card { border: 1px solid var(--line); border-radius: 14px; padding: 12px; background: var(--surface-card); display: grid; gap: 10px; } .timing-compact-card-wide { min-width: 0; } .timing-compact-label { color: var(--muted); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; } .timing-session-summary { display: grid; gap: 14px; } .timing-session-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; } .timing-session-head strong { font-size: 1.05rem; } .timing-session-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; } .timing-session-stat { border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; background: rgba(255, 255, 255, 0.03); } .timing-session-stat span { display: block; color: var(--muted); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; } .timing-session-stat strong { display: block; margin-top: 6px; font-family: Orbitron, sans-serif; } .quick-add-spacer { display: flex; align-items: center; min-height: 42px; } .check-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; } .check-card { display: flex; gap: 10px; align-items: center; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255, 255, 255, 0.02); } .check-card input { width: auto; } .team-card, .team-standings-block { border: 1px solid var(--line); border-radius: 14px; background: rgba(255, 255, 255, 0.03); } .team-create-form { align-items: center; } .team-card { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; padding: 14px 16px; margin-bottom: 10px; } .team-standings-block { padding: 14px; margin-bottom: 12px; } .team-standings-block h4 { margin: 0 0 10px; } .team-log-grid { display: grid; gap: 12px; } .team-log-card { border: 1px solid var(--line); border-radius: 14px; padding: 12px; background: rgba(255, 255, 255, 0.02); } .team-log-card h5 { margin: 0 0 8px; } .table-primary { font-weight: 700; } .table-subnote { margin-top: 4px; color: var(--muted); font-size: 0.8rem; } .table-subnote-warn { color: #ffb7a9; } .data-table tr.leaderboard-invalid td { background: rgba(225, 106, 0, 0.06); } .data-table tr.judge-selected-row td { background: rgba(225, 6, 0, 0.08); } .grid-editor-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; } .drag-list { display: grid; gap: 10px; } .drag-item { display: flex; align-items: center; gap: 12px; padding: 12px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255, 255, 255, 0.03); cursor: grab; } .drag-item:hover { border-color: #60739b; } .drag-item-active { opacity: 0.5; } .drag-item-over { border-color: rgba(225, 6, 0, 0.8); background: rgba(225, 6, 0, 0.12); } .logo-preview { border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: rgba(255, 255, 255, 0.03); } .logo-preview img, .overlay-logo { max-width: 180px; max-height: 90px; object-fit: contain; } .overlay-logo { display: block; margin-bottom: 12px; } .position-grid h4, .final-card h4 { margin: 0; } .position-grid-list, .matrix-slots { display: grid; gap: 10px; margin-top: 12px; } .position-grid-list { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } .position-grid-item, .matrix-slot, .matrix-session-row, .final-card { border: 1px solid var(--line); border-radius: 12px; background: rgba(255, 255, 255, 0.03); } .position-grid-item, .matrix-slot, .matrix-session-row { display: flex; gap: 10px; align-items: center; padding: 10px 12px; } .final-matrix { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 12px; } .final-card { padding: 12px; } .final-card-header { display: flex; align-items: center; justify-content: space-between; gap: 10px; } .matrix-slot { justify-content: space-between; } .matrix-slot-reserved { border-color: rgba(245, 166, 35, 0.6); background: rgba(245, 166, 35, 0.12); } .matrix-session-list { display: grid; gap: 8px; margin-top: 12px; } .matrix-session-row { justify-content: space-between; } .overlay-mode .sidebar, .overlay-mode .topbar { display: none; } .overlay-mode .app-shell { display: block; } .overlay-mode .content { padding: 0; } .overlay-shell { min-height: 100vh; padding: 10px; background: radial-gradient(circle at 15% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 30%), radial-gradient(circle at 100% 80%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 30%), linear-gradient(160deg, color-mix(in srgb, var(--bg) 90%, #000 10%) 0%, var(--bg-soft) 55%, var(--bg) 100%); } .overlay-header { display: flex; justify-content: space-between; gap: 8px; align-items: center; margin-bottom: 6px; } .overlay-header-main { display: flex; align-items: center; gap: 8px; min-width: 0; } .overlay-header-copy { min-width: 0; } .overlay-kicker-row { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; margin-bottom: 1px; } .overlay-header h1 { margin: 0; font-family: Orbitron, sans-serif; font-size: clamp(0.92rem, 1.35vw, 1.25rem); line-height: 1.02; } .overlay-kicker { margin: 0; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.56rem; } .overlay-header-sub { margin: 1px 0 0; color: var(--muted); font-size: 0.66rem; } .overlay-meta { text-align: right; display: grid; justify-items: end; gap: 4px; } .overlay-clock { font-family: Orbitron, sans-serif; font-size: clamp(1.12rem, 1.9vw, 1.7rem); font-weight: 800; } .overlay-fullscreen-btn { align-self: start; } .overlay-status { color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.56rem; text-align: right; } .overlay-board { display: grid; grid-template-columns: minmax(0, 1.98fr) minmax(156px, 0.27fr); gap: 6px; } .overlay-board-tv { grid-template-columns: 1fr; } .overlay-shell-tv .overlay-header { margin-bottom: 6px; opacity: 0.78; } .overlay-shell-tv .overlay-header:hover { opacity: 1; } .overlay-shell-public { min-height: 100vh; } .overlay-shell-obs .overlay-header { margin-bottom: 8px; } .overlay-obs-layout { display: grid; gap: 8px; } .overlay-obs-config { display: grid; gap: 10px; margin-top: 12px; } .overlay-obs-config .panel-header-inline { margin-bottom: 0; } .overlay-obs-config .panel-header-inline span { color: var(--muted); font-size: 0.78rem; } .overlay-obs-main { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; align-items: stretch; } .overlay-obs-brandline, .overlay-obs-feature, .overlay-obs-standings, .overlay-obs-clockblock { border: 1px solid var(--line); border-radius: 12px; background: color-mix(in srgb, var(--panel) 90%, transparent); box-shadow: var(--shadow); } .overlay-obs-brandline { display: flex; align-items: center; gap: 10px; padding: 8px 10px; } .overlay-obs-logo { width: 36px; height: 36px; } .overlay-obs-brandline h2 { margin: 0; font-family: Orbitron, sans-serif; font-size: clamp(1rem, 1.65vw, 1.45rem); line-height: 1.05; } .overlay-obs-meta { display: flex; flex-wrap: wrap; gap: 5px 8px; margin-top: 4px; color: var(--muted); font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.06em; } .overlay-obs-clockblock { min-width: 190px; padding: 8px 12px; display: grid; align-content: center; justify-items: end; } .overlay-obs-clockblock strong { font-family: Orbitron, sans-serif; font-size: clamp(1.4rem, 2.2vw, 2.15rem); line-height: 1; } .overlay-obs-clockblock span { color: var(--muted); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.08em; } .overlay-obs-content { display: grid; grid-template-columns: minmax(240px, 0.78fr) minmax(0, 1.42fr); gap: 8px; } .overlay-obs-feature, .overlay-obs-standings { padding: 8px; } .overlay-fastest-banner-obs { min-height: 112px; } .overlay-obs-gridhint { display: grid; gap: 2px; margin-top: 8px; color: var(--muted); font-size: 0.68rem; } .overlay-obs-gridhint strong { color: var(--text); font-size: 0.72rem; } .overlay-obs-standings { display: grid; gap: 4px; } .overlay-obs-row { display: grid; grid-template-columns: 26px minmax(150px, 1.5fr) repeat(4, minmax(66px, 0.44fr)); gap: 5px; align-items: center; padding: 5px 6px; border: 1px solid color-mix(in srgb, var(--line) 84%, white 16%); border-radius: 8px; background: var(--surface-card); } .overlay-obs-row-leader { border-color: color-mix(in srgb, var(--accent) 58%, var(--line) 42%); background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, transparent), var(--surface-card)); } .overlay-obs-driver strong, .overlay-obs-metric strong { display: block; } .overlay-obs-driver strong { font-size: clamp(0.76rem, 0.95vw, 0.9rem); line-height: 1.05; } .overlay-obs-driver span, .overlay-obs-metric label { color: var(--muted); font-size: 0.54rem; text-transform: uppercase; letter-spacing: 0.05em; } .overlay-shell-obs-layout-grid .overlay-header, .overlay-shell-obs-layout-lowerthird .overlay-header { margin-bottom: 8px; } .overlay-obs-feature-gridonly { padding: 10px; } .overlay-obs-lowerthird { display: grid; gap: 8px; align-content: end; min-height: calc(100vh - 32px); } .overlay-obs-lowerthird-head, .overlay-obs-lowerthird-rows { border: 1px solid var(--line); border-radius: 12px; background: color-mix(in srgb, var(--panel) 92%, transparent); box-shadow: var(--shadow); } .overlay-obs-lowerthird-head { display: flex; justify-content: space-between; align-items: end; gap: 12px; padding: 10px 12px; } .overlay-obs-lowerthird-head h2 { margin: 0; font-family: Orbitron, sans-serif; font-size: clamp(1rem, 1.6vw, 1.4rem); } .overlay-obs-lowerthird-clock { font-family: Orbitron, sans-serif; font-size: clamp(1.1rem, 1.8vw, 1.6rem); } .overlay-obs-lowerthird-rows { display: grid; gap: 4px; padding: 8px; } .overlay-obs-lowerthird-row { display: grid; grid-template-columns: 24px minmax(180px, 1fr) repeat(3, auto); gap: 10px; align-items: center; padding: 6px 8px; border-radius: 8px; background: var(--surface-card); } .overlay-obs-lowerthird-row strong { font-size: 0.92rem; line-height: 1.05; } .overlay-obs-lowerthird-row span { color: var(--muted); font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.05em; } .overlay-shell-obs-theme-transparent { background: transparent; } .overlay-shell-obs-theme-transparent .overlay-obs-brandline, .overlay-shell-obs-theme-transparent .overlay-obs-feature, .overlay-shell-obs-theme-transparent .overlay-obs-standings, .overlay-shell-obs-theme-transparent .overlay-obs-clockblock, .overlay-shell-obs-theme-transparent .overlay-obs-lowerthird-head, .overlay-shell-obs-theme-transparent .overlay-obs-lowerthird-rows { background: color-mix(in srgb, var(--panel) 72%, transparent); backdrop-filter: blur(10px); } .overlay-shell-obs-theme-chroma { background: #00ff00; } .overlay-shell-obs-theme-chroma .overlay-header, .overlay-shell-obs-theme-chroma .overlay-kicker, .overlay-shell-obs-theme-chroma .overlay-header-sub, .overlay-shell-obs-theme-chroma .overlay-status { color: #101010; } .overlay-shell-obs-theme-chroma .overlay-obs-brandline, .overlay-shell-obs-theme-chroma .overlay-obs-feature, .overlay-shell-obs-theme-chroma .overlay-obs-standings, .overlay-shell-obs-theme-chroma .overlay-obs-clockblock, .overlay-shell-obs-theme-chroma .overlay-obs-lowerthird-head, .overlay-shell-obs-theme-chroma .overlay-obs-lowerthird-rows, .overlay-shell-obs-theme-chroma .overlay-fastest-banner-obs { background: rgba(9, 10, 18, 0.92); border-color: rgba(255, 255, 255, 0.14); } .overlay-shell-obs-theme-chroma .overlay-obs-row, .overlay-shell-obs-theme-chroma .overlay-obs-lowerthird-row { background: rgba(20, 22, 33, 0.94); } .overlay-shell-obs-theme-chroma .overlay-fullscreen-btn { background: rgba(20, 22, 33, 0.9); } @media (max-width: 1100px) { .overlay-obs-content { grid-template-columns: 1fr; } .overlay-obs-row { grid-template-columns: 24px minmax(120px, 1.3fr) repeat(4, minmax(60px, 0.44fr)); } } .overlay-speaker { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr); gap: 18px; } .overlay-speaker-main { border: 1px solid var(--line); border-radius: 18px; padding: 28px; background: color-mix(in srgb, var(--panel) 88%, transparent); box-shadow: var(--shadow); } .overlay-speaker-label { font-family: Orbitron, sans-serif; font-size: 1rem; color: var(--muted); letter-spacing: 0.1em; } .overlay-speaker-main h2 { margin: 12px 0; font-family: Orbitron, sans-serif; font-size: clamp(2.8rem, 6vw, 5rem); } .overlay-speaker-side, .overlay-results { display: grid; gap: 16px; } .overlay-team-layout { display: grid; gap: 12px; } .overlay-team-podium { border: 1px solid var(--line); border-radius: 14px; padding: 10px; background: color-mix(in srgb, var(--panel) 88%, transparent); box-shadow: var(--shadow); } .overlay-team-podium-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; } .overlay-team-card { border: 1px solid color-mix(in srgb, var(--line) 82%, white 18%); border-radius: 12px; padding: 10px 12px; background: var(--surface-card); display: grid; gap: 6px; } .overlay-team-card strong { font-family: Orbitron, sans-serif; font-size: clamp(0.95rem, 1.5vw, 1.25rem); } .overlay-team-card p, .overlay-team-card small { margin: 0; } .overlay-team-card-1 { border-color: color-mix(in srgb, var(--accent) 58%, var(--line) 42%); background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, transparent), var(--surface-card)); } .overlay-table-wrap, .overlay-side-card, .overlay-empty { border: 1px solid var(--line); border-radius: 12px; background: color-mix(in srgb, var(--panel) 88%, transparent); box-shadow: var(--shadow); } .overlay-table-wrap { padding: 3px 5px 5px; } .overlay-display-wrap { display: grid; gap: 6px; } .overlay-fastest-banner, .overlay-leaderboard-card { border: 1px solid var(--line); border-radius: 12px; background: color-mix(in srgb, var(--panel) 90%, transparent); box-shadow: var(--shadow); } .overlay-fastest-banner { display: flex; justify-content: space-between; align-items: end; gap: 6px; padding: 6px 8px; background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, transparent), color-mix(in srgb, var(--accent) 4%, transparent)), color-mix(in srgb, var(--panel) 92%, transparent); } .overlay-fastest-banner span, .overlay-fastest-driver { color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; } .overlay-fastest-banner strong { display: block; margin-top: 1px; font-family: Orbitron, sans-serif; font-size: clamp(0.94rem, 1.45vw, 1.26rem); } .overlay-leaderboard-card { padding: 4px; } .overlay-leaderboard-card-tv { min-height: calc(100vh - 118px); } .overlay-shell-dense .overlay-logo { width: 34px; height: 34px; } .overlay-fastest-banner-dense { align-items: center; } .overlay-fastest-banner-copy { min-width: 0; } .overlay-fastest-driver { font-size: 0.68rem; text-align: right; } .overlay-fastest-meta { color: var(--muted); font-size: 0.52rem; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; } .overlay-leaderboard-card-dense .overlay-section-head { display: none; } .overlay-race-metric strong, .overlay-race-best strong { font-size: clamp(0.72rem, 0.88vw, 0.84rem); line-height: 1.02; } .overlay-race-pos .pos-pill { min-width: 20px; height: 20px; font-size: 0.62rem; } .overlay-shell-dense .pill { padding: 3px 6px; font-size: 0.54rem; } .overlay-shell-dense .btn.overlay-fullscreen-btn { padding: 6px 8px; font-size: 0.66rem; } .overlay-section-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; } .overlay-section-head h3 { margin: 0; } .overlay-stats-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; } .overlay-stat-card { border: 1px solid var(--line); border-radius: 16px; background: linear-gradient(180deg, color-mix(in srgb, var(--surface-card) 85%, white 15%), var(--surface-soft)); padding: 14px 16px; } .overlay-stat-card span, .overlay-stat-card small { display: block; color: var(--muted); } .overlay-stat-card strong { display: block; margin: 8px 0 4px; font-family: Orbitron, sans-serif; font-size: clamp(1.4rem, 2vw, 2.1rem); } .overlay-side { display: grid; gap: 4px; font-size: 0.72rem; } .overlay-side-card { padding: 5px; } .overlay-rotating-card { min-height: 180px; } .overlay-side-card h3 { margin: 0 0 2px; font-size: 0.7rem; } .overlay-passing { display: flex; justify-content: space-between; gap: 4px; padding: 2px 0; border-bottom: 1px solid var(--line); } .overlay-passing:last-child { border-bottom: 0; } .overlay-side-card .overlay-passing strong { font-size: 0.66rem; line-height: 1.15; } .overlay-side-card .overlay-passing span { font-family: Orbitron, sans-serif; font-size: 0.58rem; color: var(--text); white-space: nowrap; } .overlay-side-card .pill { padding: 3px 7px; font-size: 0.54rem; } .overlay-race-list { display: grid; gap: 3px; } .overlay-race-row { display: grid; grid-template-columns: 30px minmax(148px, 1.42fr) repeat(6, minmax(62px, 0.38fr)); gap: 4px; align-items: center; padding: 4px 5px; border: 1px solid color-mix(in srgb, var(--line) 84%, white 16%); border-radius: 8px; background: var(--surface-card); } .overlay-race-row-leader { border-color: color-mix(in srgb, var(--accent) 58%, var(--line) 42%); background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, transparent), var(--surface-card)); } .overlay-race-row-invalid { border-color: rgba(245, 166, 35, 0.4); box-shadow: inset 0 0 0 1px rgba(245, 166, 35, 0.08); } .overlay-race-driver strong, .overlay-race-metric strong, .overlay-race-best strong { display: block; } .overlay-race-driver strong { font-size: clamp(0.75rem, 0.92vw, 0.88rem); line-height: 1.02; } .overlay-race-driver span, .overlay-race-metric label, .overlay-race-best label { color: var(--muted); font-size: 0.46rem; text-transform: uppercase; letter-spacing: 0.06em; } .overlay-invalid-note { display: block; margin-top: 2px; color: color-mix(in srgb, var(--warn) 75%, white 25%); font-size: 0.5rem; text-transform: uppercase; letter-spacing: 0.06em; } .overlay-prediction { margin-top: 1px; max-width: 122px; } .overlay-prediction-meta { display: flex; justify-content: space-between; gap: 4px; margin-bottom: 1px; max-width: 122px; } .overlay-prediction-meta label, .overlay-prediction-meta span { color: var(--muted); font-size: 0.5rem; text-transform: uppercase; letter-spacing: 0.06em; } .overlay-prediction-track { height: 2px; max-width: 122px; border-radius: 999px; overflow: hidden; background: color-mix(in srgb, var(--line) 58%, white 42%); } .overlay-prediction-fill { height: 100%; border-radius: 999px; } .overlay-prediction-good { background: linear-gradient(90deg, #b7ffd4, #26c281); } .overlay-prediction-warn { background: linear-gradient(90deg, #ffe69a, #f5a623); } .overlay-prediction-late { background: linear-gradient(90deg, #ffd0d0, #e10600); animation: overlayPredictionLatePulse 1.1s ease-in-out infinite; } @keyframes overlayPredictionLatePulse { 0%, 100% { opacity: 0.55; } 50% { opacity: 1; } } .overlay-race-metric strong, .overlay-race-best strong { font-family: Orbitron, sans-serif; font-size: clamp(0.88rem, 1.2vw, 1.08rem); } .overlay-empty { display: grid; place-items: center; min-height: calc(100vh - 48px); text-align: center; padding: 24px; } .pill { border: 1px solid var(--line); border-radius: 999px; font-size: 0.78rem; padding: 3px 8px; color: var(--muted); } .pill-green { border-color: rgba(38, 194, 129, 0.6); color: #b7ffd4; } .pos-pill { display: inline-grid; place-items: center; width: 32px; height: 22px; border-radius: 999px; border: 1px solid var(--line); font-weight: 800; } .pos-1 { background: linear-gradient(180deg, #ffd95a, #d3a80e); color: #1a1400; border-color: #ffd95a; } .pos-2 { background: linear-gradient(180deg, #dce4ef, #99a7b9); color: #0f141b; border-color: #dce4ef; } .pos-3 { background: linear-gradient(180deg, #d19562, #8c5d34); color: #1a0f05; border-color: #d19562; } .best { color: color-mix(in srgb, var(--accent-2) 50%, white 50%); font-weight: 700; } .toggle { display: inline-flex; align-items: center; gap: 8px; } .error { color: color-mix(in srgb, var(--accent) 56%, white 44%); min-height: 18px; } .finish-banner { margin-top: 10px; display: inline-block; padding: 6px 10px; border-radius: 8px; border: 1px solid color-mix(in srgb, var(--accent) 70%, transparent); background: color-mix(in srgb, var(--accent) 18%, transparent); color: color-mix(in srgb, var(--accent) 45%, white 55%); font-weight: 700; } .modal-overlay { position: fixed; inset: 0; background: color-mix(in srgb, var(--bg) 78%, transparent); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: 24px; z-index: 40; } .modal-card { width: min(760px, 100%); max-height: 88vh; overflow: auto; border: 1px solid var(--line); border-radius: 16px; background: linear-gradient(180deg, rgba(225, 6, 0, 0.08), transparent 20%), linear-gradient(180deg, #131a28 0%, #101724 100%); box-shadow: 0 18px 50px rgba(0, 0, 0, 0.55); } .hint { margin: 10px 0 0; color: var(--muted); font-size: 0.9rem; } .mt-16 { margin-top: 16px; } @media (max-width: 1200px) { .cols-4, .cols-5 { grid-template-columns: repeat(2, minmax(0, 1fr)); } .panel-row { grid-template-columns: 1fr; } } @media (max-width: 820px) { .app-shell { grid-template-columns: 1fr; } .sidebar { position: static; height: auto; } .sidebar-footer { position: static; margin-top: 14px; } .cols-3, .cols-4, .cols-5 { grid-template-columns: 1fr; } .race-setup-modebar, .race-format-save-row, .race-wizard-footer { align-items: stretch; flex-direction: column; } .topbar { flex-direction: column; align-items: flex-start; gap: 10px; } .field-card-checkbox { grid-column: span 1; } .overlay-board { grid-template-columns: 1fr; } .timing-top-grid { grid-template-columns: 1fr; } .overlay-stats-row { grid-template-columns: 1fr; } .overlay-race-row { grid-template-columns: 42px 1fr; gap: 6px; padding: 8px; } .overlay-speaker { grid-template-columns: 1fr; } .overlay-team-podium-grid { grid-template-columns: 1fr; } .overlay-header { align-items: flex-start; flex-direction: column; } .overlay-header-main { align-items: flex-start; } .modal-overlay { padding: 12px; } }