:root{--aqua: #00778B;--aqua-dark: #005f70;--aqua-light: #009ab3;--gold: #FCD116;--gold-dark: #d4a800;--black: #000;--white: #fff;--grey: #1a1a1a;--grey-mid: #2d2d2d;--grey-light: #444;--text-muted: #888;--bg: #000;--card: #1a1a1a;--radius: 10px;--radius-lg: 16px;--header-h: 64px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--white);min-height:100vh}body{display:flex;flex-direction:column}#app{flex:1;display:flex;flex-direction:column;min-height:100vh}.center-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.auth-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--black)}.auth-dart-emoji{font-size:52px;text-align:center;margin-bottom:8px;-webkit-user-select:none;user-select:none}.auth-logo{width:280px;max-width:90vw;height:auto;border-radius:12px;margin-bottom:24px;display:block}.auth-box{width:100%;max-width:440px;background:var(--grey);border:2px solid var(--aqua);border-radius:16px;padding:32px}.auth-title{font-size:22px;font-weight:700;color:var(--gold);text-align:center;letter-spacing:2px;text-transform:uppercase;margin:0 0 24px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;color:var(--gold);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.form-input,.form-select{width:100%;height:52px;padding:0 14px;background:var(--grey-mid);border:2px solid var(--grey-light);border-radius:var(--radius);color:var(--white);font-size:16px;outline:none;transition:border-color .15s;font-family:inherit}.form-input:focus,.form-select:focus{border-color:var(--gold)}.form-select{padding-right:36px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23fcd116' d='M1 1l5 5 5-5z'/></svg>");background-repeat:no-repeat;background-position:right 14px center}.form-error{display:block;min-height:20px;color:#ff8080;font-size:13px;margin-bottom:12px;text-align:center}.btn{width:100%;height:52px;background:var(--aqua);color:var(--white);border:2px solid transparent;border-radius:var(--radius);font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;font-family:inherit}.btn:hover:not(:disabled){background:var(--aqua-light)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.gold,.btn.btn-gold{background:var(--gold);color:var(--black)}.btn.gold:hover:not(:disabled),.btn.btn-gold:hover:not(:disabled){background:var(--gold-dark)}.btn.btn-aqua{background:var(--aqua);color:var(--white)}.btn.btn-aqua:hover:not(:disabled){background:var(--aqua-light)}.btn.btn-full{width:100%}.btn.btn-lg{height:60px;font-size:20px}.btn.btn-outline{background:transparent;color:var(--white);border-color:var(--grey-light)}.btn.btn-outline:hover:not(:disabled){border-color:var(--gold);color:var(--gold)}.btn.btn-danger{background:#e74c3c;color:var(--white)}.btn.btn-danger:hover:not(:disabled){background:#c0392b}.btn.ghost{background:transparent;color:var(--text-muted);border-color:var(--grey-light);text-transform:none;letter-spacing:0;font-weight:500}.btn.ghost:hover:not(:disabled){color:var(--white);border-color:var(--text-muted)}.error{margin-top:16px;padding:12px 16px;background:#dc323226;border:1px solid rgba(220,50,50,.4);border-radius:var(--radius);color:#ff8080;font-size:14px;text-align:center}.dashboard{padding:24px;max-width:600px;margin:0 auto}.dashboard h2{font-size:24px;color:var(--gold);margin:0 0 8px}.dashboard .meta{color:var(--text-muted);font-size:14px;margin-bottom:24px}.dashboard .meta .role{display:inline-block;padding:2px 10px;background:var(--aqua);color:var(--white);border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin-left:8px}.placeholder{padding:24px;background:var(--card);border-radius:var(--radius);color:var(--text-muted);font-size:14px;margin-bottom:16px}.app-shell{flex:1;display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:var(--header-h);background:var(--aqua);border-bottom:3px solid var(--gold);gap:12px}.header-logo{display:flex;align-items:center;gap:12px;min-width:0}.header-logo img{height:44px;width:44px;border-radius:6px;object-fit:cover;flex-shrink:0}.brand-line{font-size:20px;font-weight:700;color:var(--gold);letter-spacing:2px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#header-user{font-size:13px;color:#ffffffd9;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header .btn.ghost{color:#ffffffe6;border-color:#ffffff4d;background:transparent}.app-header .btn.ghost:hover:not(:disabled){color:var(--gold);border-color:var(--gold)}.app-header .header-spacer{width:80px;flex-shrink:0}.user-menu{display:flex;align-items:center;gap:12px;min-width:0}.user-name{color:var(--text-muted);font-size:14px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn.compact{width:auto;height:38px;padding:0 14px;font-size:14px;font-weight:500}.btn.large{height:64px;font-size:18px}.home,.wizard{flex:1;padding:20px;max-width:720px;margin:0 auto;width:100%}.section-title{font-size:20px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:1px;margin:24px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--aqua)}.page-wrap{flex:1;padding:16px;max-width:1200px;margin:0 auto;width:100%}.action-row{display:flex;gap:10px;margin-bottom:12px}.action-row .btn{flex:1;min-height:52px}.action-row .btn.shrink{flex:0 0 auto;width:auto;padding:0 18px}.card-aqua{background:var(--grey);border:1px solid var(--aqua);border-radius:var(--radius);padding:14px}.match-card{background:var(--grey);border:1px solid var(--aqua);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:6px}.match-type-list{display:flex;flex-direction:column;gap:10px}.sub-label{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:16px 0 8px}.match-type-btn{width:100%;display:flex;align-items:center;gap:14px;padding:14px 20px;background:var(--grey-mid);border:3px solid var(--grey-light);border-radius:var(--radius);color:var(--white);cursor:pointer;text-align:left;transition:background .15s,border-color .15s;font-family:inherit}.match-type-btn:hover{border-color:var(--text-muted)}.match-type-btn.selected{border-color:var(--gold);background:#fcd11614}.match-type-btn .icon{font-size:32px;line-height:1;flex-shrink:0}.match-type-btn .label{font-size:22px;font-weight:600;color:var(--white)}.match-type-btn .desc{font-size:13px;color:var(--text-muted);margin-top:2px}.slot-toggle-row{display:flex;gap:8px;margin-bottom:12px}.slot-toggle-btn{flex:1;height:52px;background:var(--grey-mid);border:2px solid var(--grey-light);border-radius:var(--radius);color:var(--white);font-size:16px;font-weight:600;cursor:pointer;font-family:inherit}.slot-toggle-btn.selected{background:var(--aqua);border-color:var(--aqua-light)}.practice-toggle{display:flex;align-items:center;justify-content:space-between;background:var(--grey-mid);border:2px solid var(--grey-light);border-radius:var(--radius);padding:12px 16px;margin-bottom:8px}.practice-toggle .label{font-size:16px;color:var(--white);font-weight:600}.practice-toggle .sub{font-size:12px;color:var(--text-muted);margin-top:2px}.practice-toggle .pill{padding:8px 18px;border-radius:999px;font-size:13px;font-weight:700;text-transform:uppercase;background:var(--grey-light);color:var(--white);border:none;cursor:pointer;font-family:inherit}.practice-toggle.on{border-color:var(--gold);background:#fcd11614}.practice-toggle.on .pill{background:var(--gold);color:var(--black)}.player-slot{display:flex;align-items:center;gap:12px;background:var(--grey-mid);border:2px solid var(--grey-light);border-radius:var(--radius);padding:10px 14px;margin-bottom:8px}.player-slot .slot-num{font-size:28px;font-weight:700;color:var(--gold);width:32px;text-align:center;flex-shrink:0}.player-slot .slot-body{flex:1;min-width:0}.player-slot .slot-name{font-size:16px;font-weight:600;color:var(--white)}.player-slot .slot-hint{font-size:12px;color:var(--text-muted);margin-top:2px}.player-slot.empty{border-style:dashed;cursor:pointer}.player-slot.empty:hover{border-color:var(--gold)}.player-picker-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.player-pick-btn{width:100%;background:var(--grey-mid);border:1px solid var(--grey-light);border-radius:var(--radius);padding:12px 16px;text-align:left;color:var(--white);cursor:pointer;font-family:inherit;font-size:15px}.player-pick-btn:hover{border-color:var(--gold)}.player-pick-btn:disabled{opacity:.4;cursor:not-allowed}.match-list{display:flex;flex-direction:column;gap:12px}.match-card{background:var(--card);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:6px}.match-card .row{display:flex;align-items:center;gap:10px}.match-card .game-label{font-weight:600;color:var(--white);font-size:15px}.match-card .tag{background:var(--grey);color:var(--text-muted);font-size:11px;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}.match-card .date{margin-left:auto;color:var(--text-muted);font-size:13px}.match-card .players{color:var(--text-muted);font-size:14px}.match-card .winner{color:var(--text-muted);font-size:13px}.match-card .winner strong{color:var(--gold);font-weight:600}.match-card .in-progress{color:var(--aqua-light);font-size:13px;font-weight:500}.match-card .meta{color:var(--text-muted);font-size:13px}.wizard-step{margin-bottom:8px}.wizard-actions{margin-top:32px}.row-between{display:flex;align-items:center;justify-content:space-between}.hint{font-size:12px;color:var(--text-muted);text-transform:none;letter-spacing:0}.chip-row{display:flex;gap:10px;flex-wrap:wrap}.chip-row.wrap{flex-wrap:wrap}.chip{background:var(--grey);border:1px solid var(--grey-mid);color:var(--white);border-radius:999px;padding:12px 18px;font-size:15px;cursor:pointer;transition:background .15s,border-color .15s;display:inline-flex;align-items:center;gap:8px;min-height:44px}.chip:hover{border-color:var(--grey-light)}.chip.selected{background:var(--aqua);border-color:var(--aqua-light);color:var(--white)}.chip .seat-num{background:var(--gold);color:var(--black);font-weight:700;font-size:12px;border-radius:999px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center}.match-card.clickable{cursor:pointer;transition:background .15s}.match-card.clickable:hover{background:#232323}.header-spacer{width:80px}.active-match{flex:1;display:flex;flex-direction:column;padding:12px;max-width:1000px;margin:0 auto;width:100%;gap:10px}.players-row{display:flex;gap:6px}.player-panel{flex:1;min-width:0;background:var(--black);border:3px solid var(--grey-mid);border-radius:8px;padding:10px 8px;text-align:center;display:flex;flex-direction:column;gap:4px;transition:border-color .2s,box-shadow .2s}.player-panel.active{border-color:var(--gold);box-shadow:0 0 16px #fcd11640}.player-panel.winner{border-color:var(--aqua-light);box-shadow:0 0 16px #009ab340}.panel-name{font-size:13px;font-weight:600;color:var(--aqua-light);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-panel.active .panel-name{color:var(--gold)}.panel-score{font-size:56px;font-weight:700;color:var(--white);font-variant-numeric:tabular-nums;line-height:1}.player-panel.active .panel-score{color:var(--gold)}.players-3 .panel-score{font-size:48px}.players-4 .panel-score,.players-5 .panel-score,.players-6 .panel-score,.players-7 .panel-score,.players-8 .panel-score{font-size:40px}.panel-darts{font-size:11px;color:var(--text-muted)}.score-entry{background:var(--card);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}.dart-slots{display:flex;gap:10px;justify-content:center}.dart-slot{width:80px;height:56px;background:var(--grey);border:2px solid var(--grey-mid);border-radius:var(--radius);color:var(--text-muted);font-size:22px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer}.dart-slot.filled{border-color:var(--gold);color:var(--gold);background:var(--grey)}.turn-total{text-align:center;font-size:22px;color:var(--aqua-light);font-weight:500}.turn-total strong{font-size:28px;font-weight:700;margin-left:6px}.turn-total.busted{color:#ff8080}.multiplier-row{display:flex;gap:8px}.mult-btn{flex:1;height:56px;background:var(--grey);border:2px solid var(--grey-light);border-radius:var(--radius);color:var(--white);font-size:18px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s;font-family:inherit}.mult-btn.selected.mult-s{background:var(--grey-mid);border-color:var(--white);color:var(--white)}.mult-btn.selected.mult-d{border-color:var(--aqua-light);color:var(--aqua-light)}.mult-btn.selected.mult-t{border-color:var(--gold);color:var(--gold)}.number-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.num-btn{height:56px;background:var(--grey);border:2px solid var(--grey-light);border-radius:var(--radius);color:var(--white);font-size:18px;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.num-btn:hover:not(:disabled){background:var(--grey-mid)}.num-btn:active{background:var(--aqua)}.num-btn:disabled{opacity:.5;cursor:not-allowed}.bull-btn{border-color:#27ae60;color:#2ecc71}.miss-row{display:flex}.miss-btn{flex:1;background:#e74c3c;color:var(--white);border-color:#c0392b;font-size:20px}.miss-btn:hover:not(:disabled){background:#c0392b}.entry-actions{display:flex;gap:8px;margin-top:4px}.entry-actions .btn{flex:1;height:48px}.win-banner{background:linear-gradient(135deg,var(--aqua) 0%,var(--aqua-dark) 100%);border-radius:var(--radius-lg);padding:28px 20px;text-align:center;color:var(--white)}.win-title{font-size:28px;font-weight:700;color:var(--gold);margin-bottom:4px}.win-sub{font-size:14px;color:#fffc;margin-bottom:20px}.win-actions{display:flex;gap:10px;justify-content:center}.win-actions .btn{width:auto;flex:0 1 auto;min-width:140px}@media(min-width:768px){.panel-score{font-size:80px}.players-3 .panel-score{font-size:64px}.players-4 .panel-score,.players-5 .panel-score,.players-6 .panel-score,.players-7 .panel-score,.players-8 .panel-score{font-size:52px}.num-btn{height:76px;font-size:22px}.mult-btn{height:68px;font-size:22px}.dart-slot{width:96px;height:64px;font-size:26px}}@media(max-width:600px){.home,.wizard{padding:16px}.app-header{padding:12px 14px}.user-name{display:none}.header-spacer{width:50px}.panel-score{font-size:44px}.players-3 .panel-score{font-size:36px}.players-4 .panel-score,.players-5 .panel-score,.players-6 .panel-score,.players-7 .panel-score,.players-8 .panel-score{font-size:30px}.num-btn,.mult-btn{height:50px;font-size:16px}.dart-slot{width:60px;height:48px;font-size:18px}}
