.tsc-dev-ui{font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;border:1px solid #ddd;border-radius:6px;padding:10px;max-width:520px;background:#fff}
.tsc-dev-title{font-weight:600;margin-bottom:6px}
.tsc-dev-info{font-size:12px;color:#444;display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;margin-bottom:8px}
.tsc-dev-ws{font-size:12px;margin:6px 0;color:#0b5}
.tsc-dev-state,.tsc-dev-phase,.tsc-dev-timer{font-size:12px;margin:2px 0}
.tsc-dev-controls{margin-top:8px}
.tsc-dev-controls button{padding:6px 10px;margin-right:8px;border-radius:4px;border:1px solid #ccc;background:#f7f7f7;cursor:pointer}
.tsc-dev-controls button:hover{background:#f0f0f0}
.tsc-dev-log{font-size:12px;color:#555;margin-top:4px}
/* Mockup theme (minimal subset) */
:root{--primary-green:#419134;--dark-green:#2E7D32;--accent-green:#00E676;--black:#0A0A0A;--white:#fff;--gray:#F5F5F5;--red:#FF4444}
.tsc-theme{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--black)}
.tsc-card-header{background:linear-gradient(135deg,var(--primary-green),var(--dark-green));color:#fff;padding:16px 18px;border-top-left-radius:12px;border-top-right-radius:12px}
.tsc-panel{border:1px solid #e5e7eb;border-radius:12px;background:#fff}
.tsc-btn{padding:10px 16px;border:none;border-radius:8px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s ease;background:var(--gray);color:var(--black)}
.tsc-btn:hover{filter:brightness(.98);transform:translateY(-1px)}
.tsc-btn-primary{background:var(--primary-green);color:#fff}
.tsc-btn-primary:hover{background:var(--dark-green)}
.tsc-btn-danger{background:var(--red);color:#fff}
.tsc-badge{display:inline-block;padding:6px 10px;border-radius:25px;font-weight:700;font-size:12px}
.tsc-badge-ok{background:var(--accent-green);color:#fff}
.tsc-badge-warn{background:#FF9800;color:#fff}

.tsc-hero{position:relative;overflow:hidden;border-radius:28px;padding:clamp(28px,4vw,48px);color:rgba(241,252,246,0.95);box-shadow:0 32px 80px rgba(15,26,19,0.22),0 0 0 1px rgba(21,71,52,0.12);isolation:isolate}
.tsc-hero::before{content:"";position:absolute;inset:-35% -15% auto;height:clamp(280px,42vw,420px);background:radial-gradient(420px 320px at 22% 32%,rgba(110,232,132,0.22),transparent 70%),radial-gradient(520px 320px at 78% 24%,rgba(15,26,19,0.18),transparent 75%);opacity:.82;pointer-events:none;z-index:-2}
.tsc-hero::after{content:"";position:absolute;inset:-120px -120px auto;height:clamp(120px,28vw,220px);background:radial-gradient(260px 180px at 30% 40%,rgba(255,255,255,0.16),transparent 70%);opacity:.35;pointer-events:none;z-index:-1}
.tsc-hero--tone-emerald{background:linear-gradient(180deg,rgba(21,71,52,0.92),rgba(16,36,28,0.94))}
.tsc-hero--tone-slate{background:linear-gradient(180deg,rgba(26,35,40,0.96),rgba(14,18,20,0.96))}
.tsc-hero__inner{display:flex;align-items:flex-start;justify-content:space-between;gap:clamp(16px,4vw,48px);flex-wrap:wrap}
.tsc-hero__content{display:grid;gap:12px;max-width:clamp(460px,60vw,720px)}
.tsc-hero__eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;border:1.5px solid rgba(241,252,246,0.28);background:rgba(15,26,19,0.18);font-size:.72rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase}
.tsc-hero__title{margin:0;font-size:clamp(2.8rem,5vw,4.4rem);letter-spacing:-.02em;line-height:1.04;background-image:linear-gradient(105deg,rgba(110,232,132,0.95),rgba(63,143,60,0.92),rgba(22,52,33,0.9));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 14px 32px rgba(8,17,13,0.32)}
.tsc-hero__lead{font-size:clamp(1rem,1.6vw,1.3rem);color:rgba(241,252,246,0.78);margin:0}
.tsc-hero__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.tsc-hero__actions .tsc-btn{background:rgba(15,26,19,0.16);border-color:rgba(241,252,246,0.18);color:rgba(241,252,246,0.95)}
.tsc-hero__actions .tsc-btn:hover{background:rgba(15,26,19,0.26)}
.tsc-hero__aside{display:grid;gap:12px;min-width:220px;padding:18px;border-radius:20px;background:rgba(15,26,19,0.28);border:1px solid rgba(241,252,246,0.18);box-shadow:0 18px 38px rgba(0,0,0,0.18)}
.tsc-hero__stat-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(241,252,246,0.6)}
.tsc-hero__stat-value{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;letter-spacing:-.02em;color:rgba(241,252,246,0.96)}
.tsc-hero__stat-meta{font-size:.8rem;color:rgba(241,252,246,0.72)}
.tsc-hero__footer{margin-top:clamp(18px,3vw,28px)}
.tsc-hero__footer .tsc-hero__chips{display:flex;flex-wrap:wrap;gap:8px}
.tsc-hero__chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid rgba(241,252,246,0.24);background:rgba(15,26,19,0.12);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(241,252,246,0.92);transition:background .25s ease,border-color .25s ease,color .25s ease,transform .25s ease;cursor:pointer}
.tsc-hero__chip:hover{background:rgba(15,26,19,0.18);transform:translateY(-1px)}
.tsc-hero__chip.is-active{background:rgba(241,252,246,0.14);border-color:rgba(241,252,246,0.42);color:rgba(241,252,246,0.98);box-shadow:0 18px 32px rgba(8,17,13,0.28)}
.tsc-hero--center{text-align:center}
.tsc-hero--center .tsc-hero__inner{flex-direction:column;align-items:center}
.tsc-hero--center .tsc-hero__aside{margin-top:12px;width:100%}
.tsc-hero--compact{padding:clamp(12px,2.4vw,24px);min-height:auto}
.tsc-hero--compact::before,.tsc-hero--compact::after{display:none}
.tsc-hero--compact .tsc-hero__title{font-size:clamp(1.8rem,4vw,2.6rem);text-shadow:none}
.tsc-hero--compact .tsc-hero__content{gap:6px}
.tsc-hero--compact .tsc-hero__inner{gap:12px}
.tsc-hero--compact .tsc-hero__actions{margin-top:0}
@media (max-width:900px){.tsc-hero__inner{flex-direction:column;align-items:center;text-align:center}.tsc-hero__content{align-items:center}.tsc-hero__actions{justify-content:center}.tsc-hero__aside{width:100%}}

/* Control v2 styles */
.tsc-control-root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#e2e8f0;background:radial-gradient(circle at top,#0f172a,#020617 65%);border-radius:28px;padding:32px 36px;box-shadow:0 30px 80px rgba(15,23,42,0.4);position:relative;overflow:hidden}
.tsc-control-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px;margin-bottom:28px}
.tsc-control-kicker{text-transform:uppercase;letter-spacing:0.35em;font-size:12px;color:rgba(148,210,189,0.85)}
.tsc-control-title{font-size:32px;font-weight:700;margin:0;color:#f8fafc}
.tsc-control-title .highlight{color:#4ade80}
.tsc-control-status-group{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:12px}
.tsc-control-status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(148,210,189,0.2);color:#d1fae5;font-weight:600;border:1px solid rgba(148,210,189,0.35);transition:background .2s ease}
.tsc-control-status-pill.is-connected{background:rgba(34,197,94,0.25);border-color:rgba(34,197,94,0.5);color:#bbf7d0}
.tsc-control-last-event{color:#94a3b8}
.tsc-control-layout{display:grid;gap:28px;grid-template-columns:minmax(320px,420px) minmax(520px,1fr);align-items:stretch}
.tsc-control-card{background:rgba(15,23,42,0.7);border:1px solid rgba(148,163,184,0.25);border-radius:24px;padding:24px;box-shadow:0 20px 60px rgba(15,23,42,0.35);position:relative}
.tsc-control-lock-banner{display:none;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;padding:12px 16px;border-radius:14px;background:rgba(251,191,36,0.12);border:1px solid rgba(251,191,36,0.4);color:#fcd34d;font-size:13px}
.tsc-control-lock-banner.is-visible{display:flex}
.tsc-control-lock-button{background:transparent;border:1px solid rgba(251,191,36,0.6);color:#fcd34d;font-size:12px;padding:6px 12px;border-radius:10px;font-weight:600;cursor:pointer;transition:background .2s ease}
.tsc-control-lock-button:hover{background:rgba(251,191,36,0.12)}
.tsc-control-meta{display:grid;gap:6px;margin-bottom:18px;font-size:13px;color:#cbd5f5}
.tsc-control-meta-row{display:flex;justify-content:space-between;gap:12px;color:#94a3b8}
.tsc-control-meta-clock{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:700;color:#bef264}
.tsc-control-manual-btn{width:100%;margin-bottom:18px;padding:10px 16px;border-radius:14px;background:linear-gradient(135deg,#34d399,#22c55e);color:#022c22;font-weight:700;border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}
.tsc-control-manual-btn:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(34,197,94,0.35)}
.tsc-control-manual-btn:disabled{background:rgba(148,163,184,0.2);color:#94a3b8;cursor:not-allowed;box-shadow:none}
.tsc-control-teams{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:18px}
.tsc-control-team-card{background:rgba(2,6,23,0.6);border:1px solid rgba(148,163,184,0.3);border-radius:18px;padding:18px;box-shadow:inset 0 0 0 1px rgba(12,74,110,0.2);text-align:center;transition:border .2s ease}
.tsc-control-team-kicker{text-transform:uppercase;letter-spacing:.24em;font-size:11px;color:var(--tsc-ink-soft);margin-bottom:6px}
.tsc-control-team-name{font-size:19px;font-weight:600;color:var(--tsc-ink-primary);margin-bottom:8px}
.tsc-control-team-score{font-size:44px;font-weight:800;color:var(--tsc-ink-primary);margin-bottom:14px}
.tsc-control-goal-btn{width:100%;padding:8px 12px;border-radius:12px;border:none;background:rgba(226,232,240,0.95);color:#020617;font-weight:600;cursor:pointer;transition:background .2s ease}
.tsc-control-goal-btn:hover{background:rgba(226,232,240,0.9)}
.tsc-control-goal-btn:disabled{background:rgba(71,85,105,0.35);color:#94a3b8;cursor:not-allowed}
.tsc-control-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:20px}
.tsc-control-action{padding:10px 12px;border-radius:12px;border:1px solid rgba(148,163,184,0.35);background:rgba(15,23,42,0.6);color:#cbd5f5;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .2s ease}
.tsc-control-action:hover{background:rgba(59,130,246,0.18);transform:translateY(-1px)}
.tsc-control-action.primary{background:linear-gradient(135deg,#38bdf8,#0ea5e9);border:none;color:#f8fafc}
.tsc-control-action.danger{background:linear-gradient(135deg,#f97316,#ef4444);border:none;color:#fff}
.tsc-control-action:disabled{background:rgba(51,65,85,0.35);color:#64748b;border-color:rgba(51,65,85,0.4);cursor:not-allowed;transform:none}
.tsc-control-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:end}
.tsc-control-input-field{display:flex;flex-direction:column;gap:6px;color:#94a3b8;font-size:12px}
.tsc-control-input{border-radius:12px;border:1px solid rgba(148,163,184,0.35);background:rgba(15,23,42,0.6);color:#f8fafc;padding:10px 12px;font-size:14px}
.tsc-control-input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 1px #0ea5e9}
.tsc-control-match-load{padding:10px 14px;border-radius:12px;background:rgba(34,197,94,0.18);border:1px solid rgba(34,197,94,0.45);color:#bbf7d0;font-weight:600;cursor:pointer;transition:background .2s ease}
.tsc-control-match-load:hover{background:rgba(34,197,94,0.28)}
.tsc-control-match-load:disabled{background:rgba(51,65,85,0.4);border-color:rgba(51,65,85,0.5);color:#64748b;cursor:not-allowed}
.tsc-control-schedule-card{background:rgba(15,23,42,0.7);border:1px solid rgba(148,163,184,0.25);border-radius:24px;padding:24px;box-shadow:0 20px 60px rgba(15,23,42,0.35);position:relative;overflow:hidden;display:flex;flex-direction:column}
.tsc-control-schedule-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}
.tsc-control-schedule-title strong{display:block;font-size:18px;font-weight:700;color:#f8fafc}
.tsc-control-schedule-title span{display:block;font-size:12px;color:#94a3b8;margin-top:4px}
.tsc-control-schedule-badge{padding:6px 12px;border-radius:999px;background:rgba(34,197,94,0.18);border:1px solid rgba(34,197,94,0.4);color:#bbf7d0;font-size:12px;font-weight:600}
.tsc-control-schedule-canvas{position:relative;border-radius:18px;background:rgba(2,6,23,0.6);border:1px solid rgba(71,85,105,0.4);overflow:hidden;min-height:320px;max-height:720px;overflow-y:auto;flex:1 1 auto}
.tsc-control-schedule-grid{position:relative;height:100%}
.tsc-control-schedule-axis{position:absolute;left:0;top:0;bottom:0;background:rgba(15,23,42,0.9);border-right:1px solid rgba(71,85,105,0.5)}
.tsc-control-schedule-axis-line{position:absolute;left:0;right:0;height:1px;background:rgba(71,85,105,0.35)}
.tsc-control-schedule-axis-line.is-strong{height:2px;background:rgba(59,130,246,0.38)}
.tsc-control-schedule-axis-label{position:absolute;right:10px;font-size:11px;font-weight:600;color:#94a3b8}
.tsc-control-schedule-column{position:absolute;top:0;bottom:0;padding-top:48px;padding-bottom:32px}
.tsc-control-schedule-column-bg{position:absolute;left:0;right:0;top:48px;bottom:32px;background:linear-gradient(180deg,rgba(15,23,42,0.28),rgba(30,41,59,0.65));border-left:1px solid rgba(71,85,105,0.35);border-right:1px solid rgba(71,85,105,0.35)}
.tsc-control-match-card{position:absolute;left:12px;right:12px;padding:10px 18px;border-radius:18px;background:rgba(34,197,94,0.16);border:1px solid rgba(34,197,94,0.3);color:#f8fafc;box-shadow:0 16px 32px rgba(15,118,110,0.24);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border .2s ease;display:flex;align-items:center;gap:12px;min-height:24px}
.tsc-control-match-card:hover{transform:translateY(-1px);box-shadow:0 20px 42px rgba(13,148,136,0.32)}
.tsc-control-match-card.is-selected{border-color:#facc15;background:rgba(250,204,21,0.32);box-shadow:0 18px 46px rgba(250,204,21,0.34);color:#0f172a}
.tsc-control-match-card.is-live{border-color:rgba(220,38,38,0.65);box-shadow:0 18px 44px rgba(220,38,38,0.28);background:rgba(248,113,113,0.14)}
.tsc-control-match-card.is-finished{background:rgba(148,163,184,0.16);border-color:rgba(148,163,184,0.4);color:#cbd5f5}
.tsc-control-match-score{font-family:"DM Mono",ui-monospace,Menlo,Consolas,monospace;font-size:14px;font-weight:700;letter-spacing:0.08em;color:#f8fafc;display:inline-flex;align-items:center}
.tsc-control-match-card.is-finished .tsc-control-match-score{color:#f0fdf4}
.tsc-control-match-card.is-dragging{z-index:20;border-style:dashed;cursor:grabbing}
.tsc-control-match-teams{display:flex;flex:1 1 auto;align-items:center;gap:10px;font-size:13px;font-weight:600;color:#ffffff;white-space:nowrap;overflow:hidden;min-width:0}
.tsc-control-match-teams span{display:inline-flex;align-items:center;line-height:1}
.tsc-control-match-teams .match-seed{font-family:"DM Mono",ui-monospace,Menlo,Consolas,monospace;font-weight:700;font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,0.72);padding-right:6px}
.tsc-control-match-teams .match-slot{font-family:"DM Mono",ui-monospace,Menlo,Consolas,monospace;font-weight:700;font-size:12px;letter-spacing:.08em;color:rgba(255,255,255,0.72);padding-right:6px}
.tsc-control-match-teams .match-home,.tsc-control-match-teams .match-away{max-width:40%;overflow:hidden;text-overflow:ellipsis}
.tsc-control-match-teams .match-home,.tsc-control-match-teams .match-away{color:#ffffff}
.tsc-control-match-teams .vs{opacity:.45;font-weight:500}
.tsc-control-match-teams .match-score{margin-left:8px}
.tsc-control-match-teams .match-meta{margin-left:auto;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(234,255,244,0.78)}
.tsc-control-match-card.is-finished .match-meta{color:rgba(203,213,225,0.78)}
.tsc-control-match-card.is-live .match-meta{color:#fde68a}
.tsc-control-schedule-empty{padding:60px 24px;text-align:center;font-size:14px;color:#94a3b8}

.tsc-control-modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,0.78);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:1000}
.tsc-control-modal-backdrop.is-visible{display:flex}
.tsc-control-modal{width:min(460px,92vw);background:rgba(15,23,42,0.95);border:1px solid rgba(148,163,184,0.35);border-radius:24px;padding:24px;box-shadow:0 30px 80px rgba(15,23,42,0.6);color:#f8fafc}
.tsc-control-modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.tsc-control-modal-kicker{text-transform:uppercase;letter-spacing:.35em;font-size:11px;color:#34d399}
.tsc-control-modal-title{margin:4px 0 0;font-size:22px;font-weight:600;color:#f8fafc}
.tsc-control-modal-close{background:transparent;border:1px solid rgba(148,163,184,0.4);color:#cbd5f5;font-size:12px;padding:6px 10px;border-radius:999px;cursor:pointer}
.tsc-control-modal-sub{font-size:13px;color:#94a3b8;margin-bottom:16px}
.tsc-control-modal-form{display:grid;gap:14px;margin-bottom:14px}
.tsc-control-modal-field{display:flex;flex-direction:column;gap:6px;font-size:12px;color:#cbd5f5}
.tsc-control-modal-input{border-radius:12px;border:1px solid rgba(148,163,184,0.35);background:rgba(15,23,42,0.6);color:#f8fafc;padding:10px;font-size:14px}
.tsc-control-modal-input.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:16px;color:#bbf7d0}
.tsc-control-modal-input:focus{outline:none;border-color:#38bdf8}
.tsc-control-modal-frozen{background:rgba(0,0,0,0.3);border-radius:12px;padding:10px 12px;font-size:12px;color:#94a3b8}
.tsc-control-modal-frozen span{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:#bef264;font-weight:600}
.tsc-control-modal-error{color:#fda4af;font-size:12px;min-height:14px}
.tsc-control-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}
.tsc-control-modal-cancel{background:transparent;border:1px solid rgba(148,163,184,0.4);color:#cbd5f5;padding:8px 14px;border-radius:12px;font-size:13px;cursor:pointer}
.tsc-control-modal-save{background:linear-gradient(135deg,#34d399,#22c55e);border:none;color:#022c22;padding:8px 18px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 14px 30px rgba(34,197,94,0.35)}
.tsc-control-modal-save:disabled{background:rgba(51,65,85,0.5);color:#94a3b8;box-shadow:none;cursor:not-allowed}
.tsc-bracket-page{width:100%;min-height:100vh;display:flex;flex-direction:column;gap:clamp(12px,3vw,24px);margin-top:calc(var(--nav-height,80px)*-1);padding:calc(var(--nav-height,80px)+clamp(12px,3vw,24px)) clamp(14px,4vw,48px) clamp(28px,6vw,48px);background:radial-gradient(circle at top,rgba(6,78,59,0.18),rgba(15,23,42,0.6));box-sizing:border-box}
.tsc-bracket-layout{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:clamp(12px,2.6vw,22px);align-items:flex-start}
.tsc-bracket-cluster{display:grid;grid-template-columns:minmax(320px,420px) repeat(auto-fit,minmax(200px,1fr));gap:clamp(16px,3vw,26px);align-items:start;width:100%;grid-column:1 / -1}
.tsc-bracket-cluster>.tsc-bracket-stage-card{height:100%;min-height:100%}
.tsc-bracket-cluster>.tsc-bracket-groups{grid-column:2 / -1}
.tsc-bracket-stage-card{display:flex;flex-direction:column;gap:10px;padding:18px 20px;border-radius:20px;border:1px solid rgba(94,234,212,0.26);background:rgba(6,47,31,0.86);box-shadow:0 18px 38px rgba(4,20,14,0.45);min-height:auto}
.tsc-bracket-stage-header{display:flex;align-items:center;justify-content:space-between;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(226,232,240,0.72)}
.tsc-bracket-stage-name{margin:0;font-size:.78rem;font-weight:700;color:rgba(240,253,244,0.92);letter-spacing:.12em;text-transform:uppercase}
.tsc-bracket-stage-count{font-size:.68rem;color:rgba(226,232,240,0.58)}
.tsc-bracket-list{list-style:none;margin:0;padding:0;display:grid;gap:2px}
.tsc-bracket-row{display:flex;align-items:center;justify-content:flex-start;gap:6px;padding:4px 0;font-size:.8rem;line-height:1.1;color:rgba(226,232,240,0.92);border-bottom:1px dashed rgba(148,163,184,0.18)}
.tsc-bracket-row:last-child{border-bottom:none}
.tsc-bracket-row .vs{opacity:.45;margin:0 4px}
.tsc-bracket-row-info{font-weight:600;color:rgba(236,253,245,0.92);margin-left:4px}
.tsc-bracket-row.is-live .tsc-bracket-row-info{color:#f87171}
.tsc-bracket-row.is-finished .tsc-bracket-row-info{color:#34d399}
.tsc-bracket-row.is-empty{justify-content:flex-start;color:rgba(226,232,240,0.6);border-bottom:none}
.tsc-bracket-empty{width:100%;padding:12px;border-radius:12px;border:1px dashed rgba(148,163,184,0.35);background:rgba(15,23,42,0.45);color:rgba(226,232,240,0.78);text-align:center;font-size:.85rem}
.tsc-bracket-row-names{display:flex;align-items:center;gap:6px;flex:0 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tsc-bracket-row-seed{font-family:"DM Mono",ui-monospace,Menlo,Consolas,monospace;font-size:.68rem;font-weight:700;letter-spacing:.12em;color:rgba(226,232,240,0.7)}
.tsc-bracket-row-slot{font-size:.7rem;color:rgba(226,232,240,0.6);padding-right:6px}
.tsc-bracket-row .team{max-width:28%;overflow:hidden;text-overflow:ellipsis}
.tsc-bracket-row{flex-wrap:nowrap}
.tsc-bracket-row-info{margin-left:4px;white-space:nowrap}
.tsc-bracket-page .tsc-hero{margin-bottom:4px}
.tsc-bracket-status{font-size:.75rem;color:rgba(241,252,246,0.68)}
.tsc-bracket-groups{margin-top:clamp(18px,3vw,32px);display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(14px,3vw,24px)}
.tsc-bracket-group-card{background:rgba(255,255,255,0.96);border:1px solid rgba(15,59,36,0.12);border-radius:18px;box-shadow:0 16px 34px rgba(15,59,36,0.14);padding:18px}
.tsc-bracket-group-header{margin:0 0 12px;font-size:.85rem;letter-spacing:.24em;text-transform:uppercase;color:#0f3b24}
.tsc-bracket-group-table{width:100%;border-collapse:collapse;font-size:.78rem;color:#0f3b24}
.tsc-bracket-group-table thead th{font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#0b2e1c;padding-bottom:6px;border-bottom:1px solid rgba(15,59,36,0.12)}
.tsc-bracket-group-table tbody td{padding:6px 4px;border-bottom:1px dotted rgba(15,59,36,0.18)}
.tsc-bracket-group-table tbody tr:last-child td{border-bottom:none}
.tsc-bracket-group-table tbody tr:nth-child(odd){background:rgba(15,59,36,0.05)}
.tsc-bracket-group-table tbody td:first-child{font-weight:600;white-space:nowrap}
.tsc-observer-page{width:100%;min-height:100vh;display:flex;flex-direction:column;gap:clamp(24px,4vw,40px);padding:clamp(24px,5vw,56px) clamp(20px,6vw,72px) clamp(40px,8vw,80px);box-sizing:border-box;background:radial-gradient(circle at top,rgba(15,52,34,0.32),rgba(15,23,42,0.82));color:#f8fafc}
.tsc-observer-hero .tsc-hero__title{font-size:clamp(2.2rem,4.5vw,3.6rem)}
.tsc-observer-actions{display:flex;gap:12px;flex-wrap:wrap}
.tsc-observer-fullscreen{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:14px;border:1.5px solid rgba(241,252,246,0.24);background:rgba(15,26,19,0.24);color:rgba(241,252,246,0.92);font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:transform .2s ease,background .2s ease,border .2s ease}
.tsc-observer-fullscreen:hover,.tsc-observer-fullscreen:focus-visible{transform:translateY(-1px);background:rgba(15,26,19,0.35);border-color:rgba(241,252,246,0.38)}
.tsc-observer-fullscreen.is-active{background:rgba(34,197,94,0.18);border-color:rgba(34,197,94,0.42);color:#bbf7d0}
.tsc-observer-scoreboard{display:grid;grid-template-columns:repeat(3,minmax(240px,1fr));gap:clamp(20px,3vw,32px);align-items:stretch}
.tsc-observer-team{position:relative;display:grid;gap:18px;padding:clamp(24px,4vw,40px);border-radius:28px;background:linear-gradient(180deg,rgba(17,24,39,0.62),rgba(17,24,39,0.86));border:1.5px solid rgba(148,163,184,0.24);box-shadow:0 24px 48px rgba(15,23,42,0.45);text-align:center;justify-items:center}
.tsc-observer-team.leading{border-color:rgba(74,222,128,0.55);box-shadow:0 0 0 1px rgba(74,222,128,0.32),0 28px 52px rgba(15,118,110,0.45)}
.tsc-observer-team .team-name{font-size:clamp(1.6rem,3.2vw,2.4rem);font-weight:800;line-height:1.1}
.tsc-observer-team .team-score{font-size:clamp(3.2rem,6vw,5.2rem);font-weight:900;color:#bbf7d0;text-shadow:0 8px 24px rgba(13,148,136,0.45)}
.tsc-observer-team .score-change{position:absolute;top:18px;right:18px;min-width:48px;min-height:48px;padding:6px 16px;border-radius:999px;background:rgba(74,222,128,0.85);color:#022c22;font-size:.85rem;font-weight:800;letter-spacing:.12em;display:inline-flex;align-items:center;justify-content:center;text-transform:uppercase;box-shadow:0 12px 24px rgba(74,222,128,0.45)}
.tsc-observer-vs{display:grid;gap:24px;justify-items:center;align-content:center;padding:clamp(24px,4vw,36px);border-radius:26px;background:radial-gradient(circle at 50% 35%,rgba(34,197,94,0.18),rgba(15,23,42,0.82));border:1.5px solid rgba(34,197,94,0.32);box-shadow:inset 0 0 0 1px rgba(15,23,42,0.45)}
.tsc-observer-vs .match-number{font-size:.85rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(226,232,240,0.72)}
.tsc-observer-vs .game-status{font-size:.9rem;font-weight:800;letter-spacing:.4em}
.tsc-observer-vs .game-status.live{color:#34d399}
.tsc-observer-vs .game-status.paused{color:#facc15}
.tsc-observer-vs .game-time{font-size:clamp(2.4rem,5vw,4rem);font-weight:900;color:rgba(236,254,255,0.96);text-shadow:0 14px 32px rgba(15,23,42,0.45)}
.tsc-observer-footer{display:grid;gap:clamp(16px,3vw,28px);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.tsc-observer-next,.tsc-observer-meta{display:grid;gap:8px;padding:clamp(18px,3vw,26px);border-radius:22px;border:1px solid rgba(148,210,189,0.22);background:linear-gradient(180deg,rgba(11,27,23,0.6),rgba(11,27,23,0.78));box-shadow:0 18px 42px rgba(2,21,18,0.55)}
.tsc-observer-next .panel-title,.tsc-observer-meta .panel-title{font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(226,232,240,0.65)}
.tsc-observer-next .next-match-info{font-size:clamp(1.1rem,2.6vw,1.6rem);font-weight:700;color:rgba(241,252,246,0.92)}
.tsc-observer-next .next-match-time{font-size:.95rem;color:rgba(226,232,240,0.7)}
.tsc-observer-meta .tsc-observer-last-teams{margin:0;font-size:1rem;font-weight:700;color:rgba(241,252,246,0.92)}
.tsc-observer-meta .tsc-observer-last-score{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(34,197,94,0.18);color:#bbf7d0;font-weight:700;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase}
.tsc-observer-meta .tsc-observer-last-meta{font-size:.85rem;color:rgba(226,232,240,0.72)}
.tsc-observer-meta p{margin:0}
@media (max-width:960px){.tsc-observer-scoreboard{grid-template-columns:1fr}.tsc-observer-vs{order:-1}}

/* Soft surface overrides */
:root{
  --tsc-surface-gradient: linear-gradient(180deg, rgba(236, 252, 244, 0.96), rgba(211, 241, 225, 0.92));
  --tsc-ink-primary: #0f3b24;
  --tsc-ink-muted: rgba(15, 59, 36, 0.68);
  --tsc-ink-soft: rgba(15, 59, 36, 0.42);
}

.tsc-control-root{
  background: var(--tsc-surface-gradient);
  color: var(--tsc-ink-primary);
  box-shadow: 0 24px 48px rgba(15, 59, 36, 0.18);
}
.tsc-control-title{color:var(--tsc-ink-primary);} 
.tsc-control-status-pill{background:rgba(34,139,89,0.14);border:1px solid rgba(34,139,89,0.28);color:var(--tsc-ink-primary);} 
.tsc-control-status-pill.is-connected{background:rgba(34,197,94,0.22);border-color:rgba(34,197,94,0.36);color:#0b3f25;}
.tsc-control-last-event{color:var(--tsc-ink-muted);} 
.tsc-control-card{background:rgba(255,255,255,0.9);border:1px solid rgba(15,59,36,0.1);box-shadow:0 16px 36px rgba(15,59,36,0.16);} 
.tsc-control-meta{color:var(--tsc-ink-muted);} 
.tsc-control-meta-row{color:var(--tsc-ink-soft);} 
.tsc-control-meta-clock{color:#14683d;} 
.tsc-control-manual-btn{background:linear-gradient(135deg,#2ec27e,#1ba05f);color:#062c18;} 
.tsc-control-manual-btn:disabled{background:rgba(15,59,36,0.08);color:var(--tsc-ink-soft);} 
.tsc-control-team-card{background:rgba(255,255,255,0.92);border:1px solid rgba(15,59,36,0.12);box-shadow:0 10px 20px rgba(15,59,36,0.12);} 
.tsc-control-match-card{color:var(--tsc-ink-primary);} 
.tsc-control-match-time{color:var(--tsc-ink-muted);} 
.tsc-control-match-teams{color:var(--tsc-ink-primary);} 
.tsc-control-match-teams .vs{opacity:.45;} 
.tsc-control-match-teams .match-slot{color:var(--tsc-ink-muted);} 
.tsc-control-match-teams .match-meta{color:var(--tsc-ink-soft);} 
.tsc-control-modal{background:rgba(255,255,255,0.96);color:var(--tsc-ink-primary);border:1px solid rgba(15,59,36,0.12);} 
.tsc-control-modal-kicker{color:#177a49;} 
.tsc-control-modal-title{color:var(--tsc-ink-primary);} 
.tsc-control-modal-sub{color:var(--tsc-ink-muted);} 
.tsc-control-modal-input{background:rgba(255,255,255,0.9);color:var(--tsc-ink-primary);border:1px solid rgba(15,59,36,0.18);} 
.tsc-control-modal-frozen{background:rgba(15,59,36,0.06);color:var(--tsc-ink-muted);} 
.tsc-control-modal-cancel{border-color:rgba(15,59,36,0.18);color:var(--tsc-ink-primary);} 
.tsc-control-modal-save{background:linear-gradient(135deg,#2ec27e,#1ba05f);color:#062c18;}

.tsc-bracket-page{
  background: var(--tsc-surface-gradient);
  margin-top: calc(var(--nav-height,80px) * -1);
  padding-top: calc(var(--nav-height,80px) + clamp(24px,4vw,36px));
}
.tsc-bracket-stage-card{background:rgba(255,255,255,0.94);border:1px solid rgba(15,59,36,0.12);box-shadow:0 16px 30px rgba(15,59,36,0.14);} 
.tsc-bracket-stage-header{color:var(--tsc-ink-soft);} 
.tsc-bracket-stage-name{color:var(--tsc-ink-primary);} 
.tsc-bracket-stage-count{color:var(--tsc-ink-soft);} 
.tsc-bracket-list{gap:2px;} 
.tsc-bracket-row{color:var(--tsc-ink-primary);border-bottom:1px dashed rgba(15,59,36,0.18);} 
.tsc-bracket-row .vs{color:var(--tsc-ink-soft);opacity:1;} 
.tsc-bracket-row-info{color:var(--tsc-ink-muted);margin-left:4px;} 
.tsc-bracket-row.is-empty{color:var(--tsc-ink-muted);} 
.tsc-bracket-empty{background:rgba(255,255,255,0.9);color:var(--tsc-ink-muted);border:1px dashed rgba(15,59,36,0.16);} 
.tsc-bracket-row-seed{color:var(--tsc-ink-soft);} 
.tsc-bracket-row-slot{color:var(--tsc-ink-soft);} 
.tsc-bracket-group-card{background:rgba(255,255,255,0.96);border:1px solid rgba(15,59,36,0.12);box-shadow:0 16px 34px rgba(15,59,36,0.14);} 
.tsc-bracket-group-header{color:var(--tsc-ink-soft);} 
.tsc-bracket-group-table thead th{color:var(--tsc-ink-muted);border-bottom:1px solid rgba(15,59,36,0.12);} 
.tsc-bracket-group-table tbody td{border-bottom:1px dotted rgba(15,59,36,0.12);} 
.tsc-bracket-group-table tbody tr:nth-child(odd){background:rgba(15,59,36,0.05);} 
.tsc-bracket-group-table tbody td:first-child{color:var(--tsc-ink-primary);} 

@media (max-width: 1200px){
  .tsc-bracket-layout{
    display:flex;
    flex-direction:column;
    gap:clamp(14px,3vw,24px);
  }

  .tsc-bracket-layout > *{
    width:100%;
  }
}

@media (max-width: 1024px){
  .tsc-bracket-cluster{
    grid-template-columns:minmax(0,1fr);
    gap:clamp(14px,4vw,22px);
  }

  .tsc-bracket-cluster > .tsc-bracket-stage-card,
  .tsc-bracket-cluster > .tsc-bracket-groups{
    grid-column:1;
  }
}

.tsc-observer-page{background:var(--tsc-surface-gradient);} 
.tsc-observer-team{background:rgba(255,255,255,0.94);border:1px solid rgba(15,59,36,0.12);color:var(--tsc-ink-primary);box-shadow:0 18px 32px rgba(15,59,36,0.12);} 
.tsc-observer-team .team-name{color:var(--tsc-ink-primary);} 
.tsc-observer-team .team-score{color:#167a4a;text-shadow:none;} 
.tsc-observer-vs{background:rgba(255,255,255,0.96);border:1px solid rgba(15,59,36,0.14);box-shadow:inset 0 0 0 1px rgba(15,59,36,0.08);} 
.tsc-observer-vs .match-number{color:var(--tsc-ink-soft);} 
.tsc-observer-vs .game-status{color:#157347;} 
.tsc-observer-vs .game-time{color:var(--tsc-ink-primary);text-shadow:none;} 
.tsc-observer-next,.tsc-observer-meta{background:rgba(255,255,255,0.94);border:1px solid rgba(15,59,36,0.12);box-shadow:0 18px 32px rgba(15,59,36,0.1);color:var(--tsc-ink-primary);} 
.tsc-observer-next .panel-title,.tsc-observer-meta .panel-title{color:var(--tsc-ink-soft);} 
.tsc-observer-next .next-match-info{color:var(--tsc-ink-primary);} 
.tsc-observer-next .next-match-time{color:var(--tsc-ink-muted);} 
.tsc-observer-meta .tsc-observer-badge{background:rgba(23,122,73,0.12);color:var(--tsc-ink-primary);} 
.tsc-observer-meta .tsc-observer-badge.is-paused{background:rgba(249,189,4,0.18);color:#8f6200;} 
.tsc-observer-meta p{color:var(--tsc-ink-muted);} 

.tsc-bracket-status{color:var(--tsc-ink-muted);} 

body{background:var(--tsc-surface-gradient);} 
.tsc-control-kicker{color:var(--tsc-ink-soft);} 
.tsc-control-status-group{color:var(--tsc-ink-muted);} 

.tsc-control-schedule-grid .tsc-control-match-card,
.tsc-control-schedule-grid .tsc-control-match-card span {
  color: rgba(241, 252, 246, 0.96);
}

.tsc-control-schedule-grid .tsc-control-match-teams .match-slot {
  color: rgba(226, 232, 240, 0.72);
}

.tsc-control-schedule-grid .tsc-control-match-teams .match-meta {
  color: rgba(203, 213, 225, 0.82);
}
