:root{--red-team:#e74c3c;--red-light:#fdecea;--blue-team:#2980b9;--blue-light:#eaf2f8;--green:#27ae60;--orange:#f39c12;--bg:#f5f6fa;--card:#fff;--text:#2c3e50;--border:#e8e8e8;--font-base:18px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Apple SD Gothic Neo,Noto Sans KR,-apple-system,sans-serif;font-size:var(--font-base);-webkit-font-smoothing:antialiased;line-height:1.6}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}.app{min-height:100vh}.font-controls{z-index:1000;gap:6px;display:flex;position:fixed;top:12px;left:16px}.font-btn{background:#fff;border:2px solid #bdc3c7;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.font-btn:hover{background:#ecf0f1;transform:scale(1.1)}.header{color:#fff;text-align:center;background:linear-gradient(135deg,#2c3e50,#34495e);padding:20px 24px;position:relative}.header h1{margin-bottom:2px;font-size:1.6em}.header .subtitle{opacity:.8;font-size:.9em}.admin-toggle{color:#fff;background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;padding:8px 16px;font-size:.85em;transition:all .2s;position:absolute;top:50%;right:80px;transform:translateY(-50%)}.admin-toggle:hover{background:#ffffff40}.admin-toggle.active{background:var(--orange);border-color:var(--orange)}.tabs{border-bottom:1px solid var(--border);z-index:100;background:#fff;flex-wrap:wrap;justify-content:center;gap:8px;padding:14px 16px;display:flex;position:sticky;top:0}.tab-btn{text-align:center;background:#fff;border:2px solid #bdc3c7;border-radius:12px;min-width:100px;padding:12px 24px;font-size:1.05em;font-weight:600;transition:all .2s}.tab-btn:hover{border-color:#7f8c8d}.tab-btn.active-red{background:var(--red-team);color:#fff;border-color:var(--red-team)}.tab-btn.active-blue{background:var(--blue-team);color:#fff;border-color:var(--blue-team)}.tab-btn.active-all{background:var(--text);color:#fff;border-color:var(--text)}.tab-btn.active-stats{background:var(--green);color:#fff;border-color:var(--green)}.tab-btn.active-attend{background:var(--orange);color:#fff;border-color:var(--orange)}.tab-btn.active-admin{color:#fff;background:#8e44ad;border-color:#8e44ad}.content{max-width:1200px;margin:0 auto;padding:16px}.search-box{align-items:center;gap:8px;margin-bottom:16px;display:flex;position:relative}.voice-btn{background:#fff;border:2px solid #ddd;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.3em;transition:all .2s;display:flex}.voice-btn:hover{border-color:var(--blue-team)}.voice-btn.on{background:var(--red-team);border-color:var(--red-team);color:#fff;animation:1s infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #e74c3c66}50%{box-shadow:0 0 0 10px #e74c3c00}}.search-input-wrap{flex:1;position:relative}.search-clear{color:#666;background:#ddd;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2em;transition:background .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.search-clear:hover{background:#ccc}.search-input{border:2px solid #ddd;border-radius:12px;outline:none;width:100%;padding:14px 20px;font-size:1.1em;transition:border-color .2s}.search-input:focus{border-color:var(--blue-team)}.card{background:var(--card);border-radius:16px;margin-bottom:16px;overflow:hidden;box-shadow:0 2px 12px #00000012}.team-header{color:#fff;padding:12px 20px;font-size:1.1em;font-weight:700}.team-header.red{background:var(--red-team)}.team-header.blue{background:var(--blue-team)}.player-card{cursor:pointer;border-bottom:1px solid #f0f0f0;align-items:center;gap:12px;padding:14px 20px;transition:background .15s;display:flex}.player-card:hover{background:#f8f9fa}.player-card:last-child{border-bottom:none}.player-rank{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.95em;font-weight:700;display:flex}.player-rank.red{background:var(--red-light);color:var(--red-team)}.player-rank.blue{background:var(--blue-light);color:var(--blue-team)}.player-info{flex:1;min-width:0}.player-name{font-size:1.1em;font-weight:600}.player-team-label{color:#999;font-size:.8em;font-weight:600}.player-team-label.red{color:var(--red-team)}.player-team-label.blue{color:var(--blue-team)}.player-stats{flex-shrink:0;align-items:center;gap:10px;display:flex}.stat-badge{text-align:center;border-radius:10px;min-width:55px;padding:5px 10px}.stat-badge .label{color:#999;font-size:.7em;display:block}.stat-badge .value{font-size:1.15em;font-weight:700}.stat-badge.points{background:#fff3cd}.attendance-bar-wrap{flex-shrink:0;width:75px}.attendance-pct{text-align:center;font-size:1.05em;font-weight:700}.attendance-bar-bg{background:#ecf0f1;border-radius:4px;height:8px;margin-top:3px;overflow:hidden}.attendance-bar{border-radius:4px;height:100%;transition:width .4s}.modal-overlay{z-index:2000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:85vh;padding:28px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{font-size:1.4em}.modal-close{background:#ecf0f1;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.4em;display:flex}.modal-close:hover{background:#dfe6e9}.detail-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.detail-item{text-align:center;background:#f8f9fa;border-radius:12px;padding:14px}.detail-item .d-label{color:#888;font-size:.85em}.detail-item .d-value{margin-top:4px;font-size:1.4em;font-weight:700}.weekly-table{border-collapse:collapse;width:100%;font-size:.95em}.weekly-table th,.weekly-table td{text-align:center;border-bottom:1px solid #f0f0f0;padding:10px 8px}.weekly-table th{background:#f8f9fa;font-weight:600}.weekly-table .zero{color:#ccc}.weekly-table .high{color:var(--green);font-weight:700}.date-selector{justify-content:center;align-items:center;gap:14px;margin-bottom:16px;display:flex}.date-selector label{font-size:1.1em;font-weight:600}.date-add-btn{border:2px solid var(--green);width:44px;height:44px;color:var(--green);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5em;font-weight:700;transition:all .2s;display:flex}.date-add-btn:hover{background:var(--green);color:#fff}.date-selector select{background:#fff;border:2px solid #bdc3c7;border-radius:10px;padding:10px 14px;font-size:1.1em}.check-row{border-bottom:1px solid #f0f0f0;align-items:center;gap:12px;padding:12px 20px;display:flex}.check-row:last-child{border-bottom:none}.check-name{flex:1;font-size:1.05em;font-weight:600}.check-buttons{gap:8px;display:flex}.check-btn{text-align:center;background:#fff;border:2px solid #ddd;border-radius:10px;min-width:72px;padding:10px 16px;font-size:.95em;transition:all .2s}.check-btn.early{border-color:var(--green)}.check-btn.early.on{background:var(--green);color:#fff}.check-btn.late{border-color:var(--orange)}.check-btn.late.on{background:var(--orange);color:#fff}.check-btn.absent{border-color:var(--red-team)}.check-btn.absent.on{background:var(--red-team);color:#fff}.stats-section{margin-bottom:24px}.stats-section h3{margin-bottom:12px;padding-left:4px;font-size:1.15em}.team-vs{justify-content:center;align-items:center;gap:20px;padding:24px;display:flex}.team-vs-side{text-align:center;flex:1}.team-vs-side .tv-name{font-size:1.3em;font-weight:700}.team-vs-side .tv-value{margin-top:6px;font-size:2.2em;font-weight:700}.team-vs-side .tv-sub{color:#888;margin-top:2px;font-size:.85em}.team-vs-side.red .tv-name,.team-vs-side.red .tv-value{color:var(--red-team)}.team-vs-side.blue .tv-name,.team-vs-side.blue .tv-value{color:var(--blue-team)}.team-vs-mid{color:#bbb;font-size:1.5em;font-weight:700}.highlight-row{flex-wrap:wrap;gap:12px;display:flex}.highlight-card{text-align:center;background:#fff;border-radius:14px;flex:1;min-width:140px;padding:18px;box-shadow:0 2px 8px #0000000f}.highlight-card .h-label{color:#888;font-size:.85em}.highlight-card .h-value{margin-top:4px;font-size:1.8em;font-weight:700}.highlight-card .h-name{margin-top:4px;font-size:.95em;font-weight:600}.admin-login{text-align:center;max-width:400px;margin:60px auto}.admin-login h2{margin-bottom:20px;font-size:1.3em}.admin-login input{text-align:center;border:2px solid #ddd;border-radius:12px;outline:none;width:100%;margin-bottom:12px;padding:14px 18px;font-size:1.1em}.admin-login input:focus{border-color:#8e44ad}.admin-login button{color:#fff;background:#8e44ad;border:none;border-radius:12px;width:100%;padding:14px;font-size:1.1em;font-weight:600;transition:background .2s}.admin-login button:hover{background:#7d3c98}.admin-login .error{color:var(--red-team);margin-top:8px;font-size:.9em}.admin-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.admin-tab-btn{text-align:center;background:#fff;border:2px solid #ddd;border-radius:12px;flex:1;min-width:100px;padding:12px 10px;font-size:1em;font-weight:600;transition:all .2s}.admin-tab-btn.on{color:#fff;background:#8e44ad;border-color:#8e44ad}.admin-tab-btn:hover:not(.on){border-color:#8e44ad}.admin-section{margin-bottom:24px}.admin-section h3{color:#6c3483;background:#f0e6f6;border-radius:12px 12px 0 0;margin-bottom:12px;padding:12px 16px;font-size:1.15em}.admin-form{padding:16px 20px}.admin-form .form-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.admin-form .form-row label{min-width:80px;font-size:.95em;font-weight:600}.admin-form input,.admin-form select{border:2px solid #ddd;border-radius:10px;outline:none;flex:1;min-width:120px;padding:10px 14px;font-size:1em}.admin-form input:focus,.admin-form select:focus{border-color:#8e44ad}.admin-btn{color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:1em;font-weight:600;transition:opacity .2s}.admin-btn:hover{opacity:.85}.admin-btn.add{background:var(--green)}.admin-btn.delete{background:var(--red-team)}.admin-btn.save{background:#8e44ad}.admin-btn.export{background:var(--blue-team)}.pi-card{border-bottom:1px solid #f0f0f0}.pi-card:last-child{border-bottom:none}.pi-header{cursor:pointer;align-items:center;gap:10px;padding:14px 20px;transition:background .15s;display:flex}.pi-header:hover{background:#f8f9fa}.pi-header:active{background:#f0f0f0}.pi-name{flex:1;font-size:1.05em;font-weight:700}.pi-total{text-align:right;min-width:40px;font-size:1.1em;font-weight:700}.pi-arrow{color:#bbb;text-align:center;width:20px;font-size:.75em}.pi-body{padding:0 20px 16px}.pi-section{margin-bottom:12px}.pi-label{color:#888;margin-bottom:6px;font-size:.85em;font-weight:600}.pi-buttons{gap:8px;display:flex}.pi-btn{text-align:center;-webkit-tap-highlight-color:transparent;background:#fff;border:2px solid #ddd;border-radius:12px;flex:1;padding:14px 8px;font-size:1em;font-weight:600;line-height:1.3;transition:all .15s}.pi-btn small{opacity:.7;font-size:.75em;font-weight:400}.pi-btn:active{transform:scale(.96)}.pi-btn.early{border-color:var(--green)}.pi-btn.early.on{background:var(--green);color:#fff}.pi-btn.late{border-color:var(--orange)}.pi-btn.late.on{background:var(--orange);color:#fff}.pi-btn.absent{border-color:var(--red-team)}.pi-btn.absent.on{background:var(--red-team);color:#fff}.pi-btn.win{border-color:#2980b9}.pi-btn.win.on{color:#fff;background:#2980b9}.pi-btn.draw{border-color:#7f8c8d}.pi-btn.draw.on{color:#fff;background:#7f8c8d}.pi-btn.lose{border-color:#bdc3c7}.pi-btn.lose.on{color:#fff;background:#bdc3c7}.pi-result{text-align:center;color:#555;background:#f8f9fa;border-radius:10px;padding:10px;font-size:.95em}.pi-result strong{color:var(--text);font-size:1.2em}.date-list{flex-wrap:wrap;gap:8px;display:flex}.date-chip{background:#f0f0f0;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;font-size:.9em;font-weight:600;display:inline-flex}.chip-del{color:#888;cursor:pointer;background:#ddd;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:.9em;display:flex}.chip-del:hover{background:#ccc}.chip-del.confirm{background:var(--red-team);color:#fff;border-radius:6px;width:auto;padding:2px 8px;font-size:.8em}.chip-del.cancel{color:#fff;background:#999;border-radius:6px;width:auto;padding:2px 8px;font-size:.8em}.confirm-overlay{z-index:3000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.confirm-box{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:380px;padding:28px;box-shadow:0 8px 30px #0003}.confirm-title{color:var(--red-team);margin-bottom:12px;font-size:1.3em;font-weight:700}.confirm-msg{color:#555;white-space:pre-line;margin-bottom:24px;font-size:1em;line-height:1.6}.confirm-actions{gap:10px;display:flex}.confirm-cancel,.confirm-ok{border:none;border-radius:12px;flex:1;padding:14px;font-size:1.05em;font-weight:600;transition:opacity .2s}.confirm-cancel{color:#555;background:#ecf0f1}.confirm-cancel:hover{background:#dfe6e9}.confirm-ok{background:var(--red-team);color:#fff}.confirm-ok:hover{opacity:.85}.toast{color:#fff;z-index:3000;background:#2c3e50;border-radius:12px;padding:14px 28px;font-size:1em;font-weight:600;animation:.3s toastIn;position:fixed;bottom:30px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0003}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=768px){.header{padding:16px}.header h1{font-size:1.3em}.admin-toggle{margin:8px auto 0;font-size:.8em;display:block;position:static;transform:none}.tabs{gap:5px;padding:10px 8px}.tab-btn{min-width:70px;padding:9px 14px;font-size:.9em}.content{padding:10px}.player-card{flex-wrap:wrap;padding:10px 14px}.player-stats{justify-content:flex-end;width:100%;margin-top:4px}.stat-badge{min-width:48px;padding:4px 7px}.detail-grid{grid-template-columns:1fr 1fr}.modal{max-height:90vh;padding:20px}.team-vs{gap:12px;padding:16px}.team-vs-side .tv-value{font-size:1.8em}.highlight-card{min-width:110px;padding:14px}.check-btn{min-width:60px;padding:8px 12px;font-size:.9em}.font-controls{top:auto;bottom:12px;left:12px}.admin-form .form-row{flex-direction:column;align-items:stretch}.admin-form .form-row label{min-width:auto}}
