:root{--bg:#0a0a0f;--bg-card:#13131a;--bg-card2:#1a1a24;--border:#ffffff14;--accent:#c20;--accent2:#d4af37;--text:#f0f0f0;--text-muted:#888;--green:#22c55e;--orange:#f59e0b;--blue:#3b82f6;--radius:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.wrap{max-width:860px;margin:0 auto;padding:0 16px 80px}.topbar{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#0a0a0ff0;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.topbar-logo{border-radius:6px;width:28px;height:28px}.topbar-title{color:var(--accent2);flex:1;font-size:1rem;font-weight:700}.topbar-sub{color:var(--text-muted);font-size:.75rem}.topbar-role{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:3px 8px;font-size:.65rem;font-weight:700}.role-trainer{color:var(--accent2);background:#d4af3726}.role-athlet{color:var(--green);background:#22c55e26}.topbar-logout{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:5px 10px;font-size:.75rem}.topbar-logout:hover{border-color:var(--accent);color:var(--accent)}.landing{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100dvh;padding:24px;display:flex}.landing-logo{border-radius:18px;height:72px;box-shadow:0 8px 32px #cc22004d}.landing-title{color:var(--text);font-size:1.8rem;font-weight:900}.landing-sub{color:var(--text-muted);font-size:.9rem}.landing-cards{gap:12px;width:100%;max-width:420px;margin-top:8px;display:grid}.landing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;align-items:center;gap:16px;padding:20px 24px;transition:all .15s;display:flex}.landing-card:hover{border-color:var(--accent2);background:var(--bg-card2);transform:translateY(-1px)}.landing-card-icon{font-size:2rem}.landing-card-title{font-size:1rem;font-weight:700}.landing-card-sub{color:var(--text-muted);margin-top:2px;font-size:.78rem}.login-wrap{flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100dvh;padding:24px;display:flex}.login-box{width:100%;max-width:400px}.login-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:20px;padding:0;font-size:.85rem;display:flex}.login-back:hover{color:var(--text)}.login-title{margin-bottom:4px;font-size:1.4rem;font-weight:800}.login-sub{color:var(--text-muted);margin-bottom:24px;font-size:.82rem}.form-group{gap:6px;margin-bottom:14px;display:grid}.form-label{color:var(--text-muted);font-size:.78rem;font-weight:600}.form-input{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;width:100%;padding:13px 16px;font-size:1rem;transition:border-color .15s}.form-input:focus{border-color:var(--accent2)}.form-input::placeholder{color:var(--text-muted)}.form-error{color:var(--accent);background:#cc220014;border-radius:8px;padding:10px 14px;font-size:.78rem}.btn{border-radius:var(--radius);cursor:pointer;border:none;width:100%;padding:14px;font-size:1rem;font-weight:700;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#e02800}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{border:1px solid var(--border);color:var(--text-muted);background:0 0;margin-top:8px}.btn-secondary:hover{border-color:var(--accent2);color:var(--accent2)}.pin-input-wrap{justify-content:center;gap:8px;margin:8px 0;display:flex}.pin-digit{text-align:center;background:var(--bg-card2);border:2px solid var(--border);width:48px;height:60px;color:var(--text);border-radius:10px;outline:none;font-size:1.6rem;font-weight:900;transition:border-color .15s}.pin-digit:focus{border-color:var(--accent2)}.turnier-list{gap:10px;margin-top:16px;display:grid}.turnier-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:16px;padding:16px 20px;transition:all .15s;display:flex}.turnier-card:hover{border-color:var(--accent2);background:var(--bg-card2)}.turnier-card-today{border-color:#22c55e59}.turnier-name{font-size:.95rem;font-weight:700}.turnier-sub{color:var(--text-muted);margin-top:2px;font-size:.75rem}.turnier-badge{white-space:nowrap;border-radius:20px;margin-left:auto;padding:4px 10px;font-size:.68rem;font-weight:700}.badge-heute{color:var(--green);background:#22c55e26}.badge-future{color:var(--text-muted);background:#ffffff0f}.section-head{justify-content:space-between;align-items:center;gap:12px;margin:20px 0 10px;display:flex}.section-head h2{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.78rem;font-weight:700}.athlet-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}.athlet-header{background:var(--bg-card2);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;display:flex}.athlet-name{flex:1;font-size:.95rem;font-weight:700}.athlet-sub{color:var(--text-muted);font-size:.72rem}.athlet-pin{letter-spacing:.12em;color:var(--accent2);background:#d4af371a;border-radius:8px;padding:4px 10px;font-size:.8rem;font-weight:900}.athlet-body{gap:6px;padding:10px;display:grid}.kampf-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:10px;gap:8px;padding:12px 14px;display:grid}.kampf-card.status-running{border-color:var(--green);background:#22c55e0d}.kampf-card.status-ready{border-color:var(--orange);background:#f59e0b0d}.kampf-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.kampf-badge{text-transform:uppercase;border-radius:20px;padding:3px 8px;font-size:.65rem;font-weight:700}.badge-running{color:var(--green);background:#22c55e26}.badge-ready{color:var(--orange);background:#f59e0b26}.badge-pending{color:var(--text-muted);background:#ffffff12}.badge-done{color:#555;background:#ffffff0d}.kampf-matte{color:var(--accent2);font-size:.72rem;font-weight:600}.kampf-div{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.72rem;overflow:hidden}.kampf-vs{grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;display:grid}.kname{font-size:.9rem;font-weight:700}.kname.right{text-align:right}.kname.highlight{color:var(--accent2)}.vs-label{color:var(--accent);opacity:.7;text-align:center;font-size:.72rem;font-weight:900}.kampf-result{color:var(--text-muted);text-align:center;margin-top:2px;font-size:.72rem}.sieger{color:var(--accent2);font-weight:700}.pin-btn{color:var(--accent2);cursor:pointer;background:#d4af371a;border:1px solid #d4af3740;border-radius:8px;padding:6px 12px;font-size:.78rem;font-weight:700;transition:all .15s}.pin-btn:hover{background:#d4af3733}.starts-wrap{flex-direction:column;justify-content:flex-start;align-items:center;gap:16px;min-height:100dvh;padding:24px 16px 80px;display:flex}.starts-hero{text-align:center;padding:24px 0 12px}.starts-name{font-size:1.5rem;font-weight:900}.starts-sub{color:var(--text-muted);margin-top:4px;font-size:.82rem}.starts-turnier{color:var(--accent2);margin-top:8px;font-size:.75rem;font-weight:700}.spinner{border:3px solid var(--border);border-top-color:var(--accent2);border-radius:50%;width:34px;height:34px;margin:40px auto;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--text-muted);padding:40px 16px;font-size:.9rem}.empty .emoji{margin-bottom:10px;font-size:2.2rem;display:block}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.live-dot{color:var(--green);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;font-size:.7rem;font-weight:700;display:inline-flex}.live-dot:before{content:"";background:var(--green);border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite pulse;display:block}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
