:root{
  --bg:#050a0f; --panel:#121c2a; --panel2:#081018; --line:#26364b; --line2:#223044;
  --gold:#d4ad63; --gold2:#f2cc78; --text:#f7fbff; --muted:#95a4b8; --cyan:#22d3d3; --red:#ff5b6b;
  --blue:#193e73;
}
*{box-sizing:border-box} body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans KR",Roboto,sans-serif;}
.topbar{height:72px;background:#101927;border-bottom:1px solid var(--gold);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:10;}
.brand{color:var(--gold);font-size:24px;font-weight:900;letter-spacing:.03em;display:flex;gap:12px;align-items:center}.brand-icon{font-size:25px}.nav{display:flex;gap:10px}.nav-btn{border:0;background:transparent;color:#bac4d2;font-weight:800;padding:12px 18px;border-radius:8px;cursor:pointer;font-size:15px}.nav-btn:hover{background:rgba(255,255,255,.06);color:white}.nav-btn.active{background:#2a3443;color:var(--gold)}
.container{max-width:1360px;margin:0 auto;padding:42px 24px 80px}.season-switch{display:flex;justify-content:flex-end;margin-bottom:24px}.season-switch>div,.season-switch{gap:8px}.season-btn{border:1px solid var(--line);background:var(--panel);color:var(--muted);padding:11px 22px;font-weight:900;cursor:pointer}.season-btn:first-child{border-radius:12px 0 0 12px}.season-btn:last-child{border-radius:0 12px 12px 0}.season-btn.active{background:var(--gold);color:#081018;border-color:var(--gold)}
.page{display:none}.page.active{display:block;animation:fade .25s ease}@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.title{display:flex;align-items:center;gap:12px;color:var(--gold);font-size:32px;font-weight:950;margin:0 0 32px}.grid{display:grid;gap:24px}.grid-3{grid-template-columns:2fr 1fr 1fr}.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 40px rgba(0,0,0,.22)}.card-pad{padding:26px}.card-title{color:var(--gold);font-weight:900;font-size:19px;margin-bottom:24px;display:flex;gap:8px;align-items:center}.top-list{display:flex;flex-direction:column;gap:14px}.top-row{background:var(--panel2);border-left:2px solid var(--gold);border-radius:9px;padding:18px 20px;display:flex;justify-content:space-between;align-items:center}.top-left{display:flex;align-items:center;gap:22px}.rank-num{font-size:24px;color:#ffe164;font-weight:950;width:28px;text-align:center}.name{font-weight:900}.elo{color:var(--gold);font-size:14px}.subtle{color:var(--muted);font-size:14px}.stat-body{text-align:center;padding:18px 0 8px}.stat-name{color:var(--gold);font-size:22px;font-weight:950;margin-bottom:14px}.stat-main{color:var(--cyan);font-size:36px;font-weight:950;letter-spacing:.02em}.stat-sub{color:var(--muted);margin-top:12px}.table-wrap{overflow:auto;border:1px solid var(--line2);border-radius:10px}table{width:100%;border-collapse:collapse;min-width:860px}th{background:var(--panel2);color:var(--gold);font-size:14px;padding:16px;text-align:center;white-space:nowrap}td{padding:16px;text-align:center;border-top:1px solid var(--line2);white-space:nowrap}tr.rank-1{background:rgba(247,211,98,.10)}tr.rank-2{background:rgba(148,163,184,.10)}tr.rank-3{background:rgba(168,85,247,.10)}.player-cell{display:flex;align-items:center;gap:14px;text-align:left;font-weight:900}.avatar{width:36px;height:36px;border-radius:999px;background:#142237;border:1px solid #264260;display:inline-flex;align-items:center;justify-content:center;color:var(--gold);font-weight:950}.tier{display:inline-block;border:1px solid rgba(255,255,255,.1);padding:5px 11px;border-radius:6px;font-size:12px;font-weight:900}.tier-master,.tier-그랜드{background:rgba(126,34,206,.35);color:#e9d5ff}.tier-diamond,.tier-다이아{background:rgba(30,64,175,.35);color:#bfdbfe}.tier-platinum,.tier-플래{background:rgba(15,118,110,.35);color:#99f6e4}.tier-gold,.tier-골드{background:rgba(161,98,7,.35);color:#fde68a}.tier-silver,.tier-실버{background:rgba(113,113,122,.35);color:#f4f4f5}.tier-bronze,.tier-브론즈{background:rgba(120,53,15,.35);color:#fed7aa}.tier-iron,.tier-아이언{background:rgba(71,85,105,.45);color:#cbd5e1}.cyan{color:var(--cyan)}.red{color:var(--red)}.gold{color:var(--gold)}.controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;margin-bottom:22px}.searchbox{background:var(--panel2);border:1px solid #2a3b51;color:white;border-radius:8px;height:42px;padding:0 14px;min-width:280px;outline:none}.searchbox:focus,.select:focus,input:focus{border-color:var(--gold)}.pill-wrap{display:flex;flex-wrap:wrap;gap:8px}.pill{border:1px solid #2a3b51;background:#243044;color:#ccd6e3;padding:8px 12px;border-radius:6px;font-weight:800;cursor:pointer}.pill.active{background:var(--gold);border-color:var(--gold);color:#081018}.btn{border:0;background:var(--blue);color:white;padding:13px 20px;border-radius:8px;font-weight:900;cursor:pointer}.btn.gold{background:var(--gold);color:#081018}.btn.blue-btn{background:var(--blue);color:white}.btn:hover{filter:brightness(1.08)}
.card#match_input_card.file-drag-over {
  border: 2px dashed var(--gold);
  background: rgba(212, 173, 99, 0.04);
  box-shadow: 0 0 20px rgba(212, 173, 99, 0.15);
}
.btn.small-btn{padding:6px 12px;font-size:12px;border-radius:6px;font-weight:800}
.ranking-header-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.excel-actions{display:flex;gap:10px;align-items:center}.ocr-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--panel2);border:1px solid var(--line2);border-radius:10px;padding:14px 16px;margin-bottom:22px}.match-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;width:100%}.team-title{font-size:21px;font-weight:950;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.team-kda-badge{font-size:14px;font-weight:800;background:rgba(255,255,255,.08);padding:4px 10px;border-radius:6px;color:var(--muted)}
.team-title.win .team-kda-badge{background:rgba(34,211,211,.15);color:var(--cyan)}
.team-title.lose .team-kda-badge{background:rgba(255,139,149,.15);color:#ff8b95}
.team-title{font-size:21px;font-weight:950;margin-bottom:16px}.team-title.win{color:var(--cyan)}.team-title.lose{color:#ff8b95}.input-row{display:grid;grid-template-columns:80px 30px 1.4fr repeat(3,.7fr);gap:10px;align-items:center;background:var(--panel2);border:1px solid var(--line2);border-radius:10px;padding:10px;margin-bottom:10px;width:100%;transition:all 0.2s ease;position:relative}
.drag-handle{cursor:grab;color:var(--muted);font-size:18px;text-align:center;user-select:none;display:flex;align-items:center;justify-content:center;height:100%;border-right:1px solid var(--line2);padding-right:10px}
.role-label{color:var(--gold);font-weight:900;text-align:center;border-right:1px solid var(--line2);padding-right:10px}
.input-row.dragging{opacity:0.4;border:1px dashed var(--gold);background:rgba(212,173,99,0.05)}
.input-row.drag-over{border:1px solid var(--cyan);background:rgba(34,211,211,0.05);transform:scale(1.01)}
.name-input-wrap{position:relative;width:100%}.name-input-wrap input{padding-right:34px}.clear-name-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:20px;height:20px;border:0;border-radius:999px;background:#2a3443;color:var(--muted);font-weight:900;line-height:20px;padding:0;cursor:pointer}.clear-name-btn:hover{background:var(--red);color:white}.input-row label{color:var(--gold);font-weight:900;text-align:center}.input-row input,.select{height:40px;background:var(--panel);border:1px solid #2a3b51;border-radius:8px;color:white;padding:0 10px;outline:none;width:100%}.notice{background:rgba(212,173,99,.1);border:1px solid rgba(212,173,99,.35);border-radius:10px;color:#f5d799;padding:14px 16px;margin-bottom:20px}.pair-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:28px}.pair-card{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:22px}.pair-title{font-size:20px;font-weight:950;margin-bottom:14px}.pair-rate{font-size:34px;font-weight:950;color:var(--cyan);margin-bottom:10px}.recent-grid{display:grid;grid-template-columns:1fr;gap:10px}.recent-card{background:var(--panel2);border:1px solid var(--line2);border-radius:10px;padding:16px}.recent-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;margin-bottom:8px}.recent-teams{display:grid;grid-template-columns:1fr 1fr;gap:16px}.empty{color:var(--muted);text-align:center;padding:70px 0}.footer-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;flex-wrap:wrap}.small{font-size:12px;color:var(--muted)}
@media(max-width:1100px){.topbar{height:auto;align-items:flex-start;flex-direction:column;padding:16px}.nav{width:100%;overflow:auto}.grid-3,.match-grid,.pair-cards,.recent-teams{grid-template-columns:1fr}.container{padding:28px 14px}.title{font-size:27px}.searchbox{min-width:100%;width:100%}.card{overflow:hidden}.ocr-actions{align-items:flex-start;flex-direction:column}.ocr-actions .btn{width:100%}}
.scope-tabs{display:flex;gap:8px;margin:-4px 0 22px;flex-wrap:wrap}.scope-btn{border:1px solid var(--line);background:#243044;color:#ccd6e3;padding:10px 16px;border-radius:8px;font-weight:900;cursor:pointer}.scope-btn.active{background:var(--gold);border-color:var(--gold);color:#081018}.pair-badge{display:inline-block;background:rgba(212,173,99,.14);border:1px solid rgba(212,173,99,.35);color:var(--gold);border-radius:999px;padding:4px 9px;font-size:12px;font-weight:900;margin-bottom:12px}.record-filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.match-record{background:var(--panel2);border:1px solid var(--line2);border-radius:12px;margin-bottom:14px;overflow:hidden}.match-head{width:100%;border:0;background:#0d1621;color:var(--text);padding:15px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;text-align:left}.match-head:hover{background:#121f2f}.record-teams{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px 18px;border-top:1px solid var(--line2);color:#dce6f3}.record-detail{display:none;padding:0 18px 18px}.record-detail.open{display:block}.detail-table table{min-width:760px}.detail-table th,.detail-table td{padding:12px 14px}
/* 모달 기본 스타일 */
.modal {
  display: none;
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  align-items: center;
  justify-content: center;
}
.modal.open {
  display: flex;
}
.modal-content {
  background-color: var(--panel);
  border: 1px solid var(--gold);
  border-radius: 14px;
  width: 90%;
  max-width: 500px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  animation: modalFade 0.25s ease;
}
@keyframes modalFade {
  from { opacity: 0; transform: translateY(-20px); }
  to { opacity: 1; transform: translateY(0); }
}
.modal-header {
  padding: 20px;
  border-bottom: 1px solid var(--line2);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-header h2 {
  margin: 0;
  color: var(--gold);
  font-size: 20px;
  font-weight: 900;
}
.close-btn {
  color: var(--muted);
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
}
.close-btn:hover {
  color: white;
}
.modal-body {
  padding: 20px;
}
.form-group {
  margin-bottom: 18px;
}
.form-group label {
  display: block;
  color: var(--gold);
  font-weight: 800;
  font-size: 14px;
  margin-bottom: 8px;
}
.form-group input {
  width: 100%;
  height: 42px;
  background: var(--panel2);
  border: 1px solid var(--line2);
  border-radius: 8px;
  color: white;
  padding: 0 12px;
  outline: none;
}
.form-group input:focus {
  border-color: var(--gold);
}
.modal-footer {
  padding: 20px;
  border-top: 1px solid var(--line2);
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
@media(max-width:900px){.record-teams{grid-template-columns:1fr}.match-head{align-items:flex-start;flex-direction:column}.record-filters{width:100%;justify-content:stretch}.record-filters .select{width:100%}}
