:root {
  --bg: #0d0f1a;
  --panel: #171a2b;
  --panel-2: #1f2336;
  --line: #2a2f48;
  --text: #e8eaf2;
  --muted: #9aa0b8;
  --accent: #ffcc4d;
  --left: #ff5d73;
  --right: #4d8bff;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: radial-gradient(1200px 600px at 50% -10%, #1a1f3a 0%, var(--bg) 60%);
  color: var(--text);
  font-family: "Pretendard", system-ui, -apple-system, "Apple SD Gothic Neo", sans-serif;
  -webkit-font-smoothing: antialiased;
}

#app { max-width: 1000px; margin: 0 auto; padding: 24px 18px 60px; }

.topbar { margin-bottom: 22px; }
.topbar-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; min-height: 34px; }
.lang-select {
  background: var(--panel); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 6px 10px; font-size: 12px; cursor: pointer; flex-shrink: 0;
}
.lang-select:focus { outline: none; border-color: var(--accent); }
.brand { text-align: center; margin-top: 6px; }
.logo {
  font-size: 34px; margin: 6px 0 4px; letter-spacing: -0.5px;
  cursor: pointer; display: inline-block; transition: opacity 0.15s; position: relative;
}
.logo:hover { opacity: 0.8; }
.logo:focus-visible { outline: 2px solid var(--accent); outline-offset: 4px; border-radius: 6px; }
.logo span { color: var(--accent); }
.beta-mark {
  font-size: 12px; font-weight: 800; color: #1a1300; background: var(--accent);
  border-radius: 6px; padding: 1px 6px; margin-left: 6px; vertical-align: super;
  letter-spacing: 0; text-transform: uppercase;
}
.tagline { color: var(--muted); margin: 0; font-size: 14px; }

/* ---------- 화면 전환 ---------- */
.screen { display: none; animation: fadeIn 0.35s ease; }
.screen.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ---------- 랜딩 ---------- */
.hero { max-width: 760px; margin: 0 auto; text-align: center; padding: 8px 4px 20px; }
.hero-badge {
  display: inline-block; font-size: 12px; font-weight: 700; color: var(--accent);
  background: rgba(255,204,77,0.1); border: 1px solid rgba(255,204,77,0.3);
  padding: 5px 12px; border-radius: 999px; margin-bottom: 16px;
}
.hero-title { font-size: 34px; line-height: 1.3; margin: 0 0 12px; letter-spacing: -0.5px; }
.hero-title .hl { color: var(--accent); }
.hero-sub { color: var(--muted); font-size: 15px; margin: 0 auto 26px; max-width: 540px; line-height: 1.6; }

/* 로그인 사용자: 로그인 정보로 진행 */
.hero-loggedin { margin: 0 auto 18px; max-width: 600px; }
.hero-loggedin[hidden] { display: none; }
.hero-loggedin .btn-huge { margin: 0 auto; display: block; }
.hero-loggedin-sub { font-size: 14px; color: var(--text); margin: 0 0 12px; font-weight: 600; }
.hero-or { font-size: 12px; color: var(--muted); margin: 16px 0 4px; position: relative; }

/* 비로그인 블록 */
#hero-anon[hidden] { display: none; }
.hero-anon-login { margin-top: 18px; }
.hero-anon-login .btn-huge { margin: 0 auto; display: block; }

.hero-start {
  display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
  background: var(--panel); border: 1px solid var(--line); border-radius: 16px;
  padding: 16px; max-width: 600px; margin: 0 auto;
}
.hero-input {
  flex: 1; min-width: 240px; padding: 13px 14px; border-radius: 10px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--text); font-size: 14px;
}
.hero-input:focus { outline: none; border-color: var(--accent); }
.hero-start .btn-huge { margin: 0; padding: 13px 26px; font-size: 15px; white-space: nowrap; }
.hero-nokey { font-size: 13px; color: var(--muted); margin: 14px 0 0; }
.link { color: var(--accent); text-decoration: none; font-weight: 600; }
.link:hover { text-decoration: underline; }

.champions { margin-top: 40px; }
.champions-title { font-size: 20px; margin: 0 0 4px; }
.champions-sub { font-size: 13px; color: var(--muted); margin: 0 0 18px; }
.champions-list {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
}
.champion-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
  padding: 16px 12px; text-align: center; cursor: pointer; color: var(--text);
  transition: transform 0.1s, border-color 0.15s, box-shadow 0.15s; font: inherit;
}
.champion-card:hover:not(.locked) { transform: translateY(-3px); border-color: var(--accent); box-shadow: 0 8px 24px -12px var(--accent); }
.champion-card.locked { opacity: 0.5; cursor: not-allowed; }
.champ-emoji { font-size: 40px; line-height: 1; }
.champ-name { font-weight: 800; font-size: 15px; margin-top: 8px; }
.champ-handle { font-size: 11px; color: var(--muted); }
.champ-blurb { font-size: 11px; color: var(--muted); margin: 8px 0 10px; line-height: 1.45; min-height: 30px; }
.champ-cta { font-size: 12px; font-weight: 700; color: var(--accent); }
.champ-lock { font-size: 12px; color: var(--muted); }

.hero-foot { margin-top: 32px; display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

/* 입장 화면 뒤로가기 */
.btn-back { margin-bottom: 12px; }

/* ---------- 로그인 모달 ---------- */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 100; display: grid; place-items: center;
  background: rgba(5,7,15,0.72); backdrop-filter: blur(3px);
  animation: fadeIn 0.2s ease;
}
.modal-backdrop[hidden] { display: none; }
.modal {
  background: var(--panel); border: 1px solid var(--line); border-radius: 18px;
  padding: 30px 28px; max-width: 420px; width: calc(100% - 40px); text-align: center;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,0.7);
  animation: pop 0.32s ease;
}
.modal-emoji { font-size: 48px; }
.modal-title { font-size: 22px; margin: 10px 0 8px; }
.modal-body { color: var(--muted); font-size: 14px; line-height: 1.7; margin: 0 0 22px; }
.modal-body b { color: var(--text); }
.modal-btns { display: flex; flex-direction: column; gap: 10px; }
.modal-btns .btn-huge { margin: 0; }

/* 프로필 편집 모달 */
.modal-profile { text-align: left; max-width: 440px; }
.modal-profile .modal-emoji, .modal-profile .modal-title { text-align: center; }
.pf-field { margin-bottom: 14px; flex: 1; }
.pf-row { display: flex; gap: 10px; }
.pf-label { display: block; font-size: 12px; color: var(--muted); font-weight: 700; margin-bottom: 6px; }
.pf-label small { font-weight: 400; }
.pf-input {
  width: 100%; padding: 11px 12px; border-radius: 10px; border: 1px solid var(--line);
  background: var(--panel-2); color: var(--text); font-size: 14px;
}
.pf-input:focus { outline: none; border-color: var(--accent); }
.pf-input:disabled { opacity: 0.5; }
.pf-msg { font-size: 12px; color: var(--muted); min-height: 16px; margin-bottom: 12px; }
.pf-msg.err { color: var(--left); }

/* 로그인 폼 (email + password) */
.modal .modal-body { margin-bottom: 16px; }
.login-form { display: flex; flex-direction: column; gap: 12px; text-align: left; }
.login-field { display: flex; flex-direction: column; gap: 5px; }
.login-field > span { font-size: 12px; color: var(--muted); font-weight: 600; }
.login-field input {
  width: 100%; box-sizing: border-box;
  background: var(--bg, #0b0e17); color: var(--text);
  border: 1px solid var(--line); border-radius: 10px;
  padding: 11px 13px; font-size: 14px; outline: none;
  transition: border-color 0.15s ease;
}
.login-field input:focus { border-color: var(--accent, #6ea8fe); }
.login-error { color: #ff6b6b; font-size: 13px; min-height: 17px; margin: 2px 0 0; text-align: center; }
.login-form .modal-btns { margin-top: 4px; }

/* ---------- 데모 프리셋 바 ---------- */
.preset-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px 14px; margin-bottom: 16px;
}
.preset-label { font-size: 13px; font-weight: 700; color: var(--accent); }
#preset-select {
  flex: 1; min-width: 220px; padding: 9px 12px; border-radius: 10px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--text);
  font-size: 13px;
}
#preset-select:focus { outline: none; border-color: var(--accent); }

/* ---------- 셋업 ---------- */
.setup-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  align-items: stretch;
}
.player-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px;
  position: relative;
  transition: box-shadow 0.2s;
}
.player-card[data-side="left"] { box-shadow: inset 3px 0 0 var(--left); }
.player-card[data-side="right"] { box-shadow: inset -3px 0 0 var(--right); }
.player-card.loading::after {
  content: "불러오는 중…";
  position: absolute; inset: 0; display: grid; place-items: center;
  background: rgba(13,15,26,0.7); border-radius: 16px; color: var(--accent); font-weight: 600;
}
.player-card h2 { margin: 0 0 12px; font-size: 18px; }

.connect-box label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.share-input {
  width: 100%; padding: 10px 12px; border-radius: 10px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--text);
  font-size: 13px; margin-bottom: 10px;
}
.share-input:focus { outline: none; border-color: var(--accent); }
.btn-row { display: flex; gap: 6px; flex-wrap: wrap; }

.btn {
  border: 1px solid var(--line); background: var(--panel-2); color: var(--text);
  padding: 9px 12px; border-radius: 10px; font-size: 13px; cursor: pointer;
  transition: transform 0.08s, background 0.15s, border-color 0.15s;
}
.btn:hover:not(:disabled) { background: #2a2f48; }
.btn:active:not(:disabled) { transform: translateY(1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-ghost { background: transparent; }
.btn-primary { background: var(--accent); color: #1a1300; border-color: var(--accent); font-weight: 700; }
.btn-primary:hover:not(:disabled) { filter: brightness(1.05); background: var(--accent); }
.btn-huge { display: block; margin: 26px auto 0; padding: 16px 40px; font-size: 18px; border-radius: 14px; }

.vs-divider {
  align-self: center; font-size: 28px; font-weight: 800; color: var(--muted);
  letter-spacing: 1px;
}

/* 지표 */
.metrics { margin-top: 14px; }
.metrics-name { font-size: 13px; margin-bottom: 8px; }
.metrics-name .src { color: var(--muted); font-size: 11px; }
.metric-row { display: grid; grid-template-columns: 64px 1fr 28px; gap: 8px; align-items: center; margin: 5px 0; font-size: 11px; }
.metric-label { color: var(--muted); }
.metric-bar { background: var(--panel-2); height: 8px; border-radius: 5px; overflow: hidden; }
.metric-bar i { display: block; height: 100%; background: linear-gradient(90deg, #4d8bff, #2ecf8b); }
.metric-val { text-align: right; color: var(--muted); }

/* 캐릭터 프리뷰 */
.char-preview {
  margin-top: 14px; padding: 14px; border-radius: 12px; text-align: center;
  border: 1px dashed var(--line); background: var(--panel-2);
}
.char-preview.empty .hint { color: var(--muted); font-size: 12px; }
.char-preview:not(.empty) { border-style: solid; border-color: var(--char-color); box-shadow: 0 0 24px -8px var(--char-color); }
.char-emoji { font-size: 46px; line-height: 1; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.4)); }
.char-title { font-size: 20px; font-weight: 800; margin-top: 6px; color: var(--char-color); }
.char-tag { font-size: 12px; color: var(--muted); margin: 2px 0 8px; }
.char-stats { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; font-size: 11px; color: var(--text); }
.char-power { margin-top: 8px; font-size: 12px; color: var(--accent); font-weight: 700; }

/* 적성 무장 매칭 카드 */
.warrior-match { margin-top: 12px; }
.warrior-match:not(.filled) { display: none; }
.warrior-match.filled {
  padding: 14px; border-radius: 12px; background: var(--panel-2);
  border: 1px solid var(--char-color); box-shadow: 0 0 20px -10px var(--char-color);
}
.wm-head { font-size: 12px; color: var(--muted); font-weight: 700; margin-bottom: 6px; }
.wm-best { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.wm-name { font-size: 22px; font-weight: 800; color: var(--char-color); }
.wm-faction {
  font-size: 11px; color: var(--text); background: var(--panel);
  border: 1px solid var(--line); padding: 1px 7px; border-radius: 999px;
}
.wm-sim { font-size: 13px; font-weight: 800; color: var(--accent); margin-left: auto; }
.wm-desc { font-size: 12px; color: var(--muted); margin: 6px 0 10px; line-height: 1.5; }
.wm-top3 { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.wm-rank {
  font-size: 11px; color: var(--muted); background: var(--panel);
  border: 1px solid var(--line); padding: 4px 8px; border-radius: 8px;
}
.wm-rank.first { color: var(--text); border-color: var(--char-color); }
.wm-rank b { color: var(--accent); }
.wm-fight { width: 100%; font-size: 13px; }

/* ---------- 전투 ---------- */
.round-banner { text-align: center; margin: 4px 0 18px; }
#round-label {
  display: inline-block; background: var(--panel); border: 1px solid var(--line);
  padding: 8px 20px; border-radius: 999px; font-weight: 800; letter-spacing: 1px;
  font-size: 15px;
}

.arena {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: end;
  gap: 12px; min-height: 230px;
  background: linear-gradient(180deg, #11152a 0%, #0d1020 100%);
  border: 1px solid var(--line); border-radius: 18px; padding: 22px 18px 0;
  position: relative; overflow: hidden;
}
.fighter { position: relative; z-index: 2; }
.fighter-left { text-align: left; }
.fighter-right { text-align: right; }

.hpbar {
  position: relative; height: 18px; background: var(--panel-2);
  border: 1px solid var(--line); border-radius: 999px; overflow: hidden; margin-bottom: 14px;
}
.hpfill { height: 100%; width: 100%; background: linear-gradient(90deg, #2ecf8b, #7ee787); transition: width 0.4s ease; }
.hpfill.low { background: linear-gradient(90deg, #ff5d73, #ff9a4d); }
.fighter-right .hpfill { float: right; }
.hptext { position: absolute; inset: 0; display: grid; place-items: center; font-size: 11px; font-weight: 700; text-shadow: 0 1px 2px rgba(0,0,0,0.6); }

.sprite-wrap { position: relative; display: inline-block; }
.fighter-right .sprite-wrap { text-align: right; }

/* 말 탄 기사 SVG 컨테이너 */
.sprite {
  width: 200px; height: 150px; display: inline-block;
  filter: drop-shadow(0 10px 8px rgba(0,0,0,0.45));
  transition: transform 0.18s ease;
}
.rider-svg { display: block; overflow: visible; }
.rider-img { display: block; width: 100%; height: 100%; object-fit: contain; }
.fighter-right .sprite { transform: scaleX(-1); } /* 오른쪽 진영은 좌우반전해 마주봄 */
.char-name { font-size: 12px; color: var(--muted); margin-top: 4px; }

/* 대기 중 미세한 호흡(말이 들썩) */
@keyframes idle-bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
.joust .horse { animation: idle-bob 1.6s ease-in-out infinite; transform-origin: center bottom; }
/* 다리 교대로 구르기(질주 중에만 빨라짐) */
.leg { transform-origin: top center; }

.arena-center { align-self: center; z-index: 3; }
.clash { font-size: 40px; opacity: 0; transition: all 0.12s; color: var(--accent); }
.clash.spark { animation: spark-burst 0.32s ease-out; }
@keyframes spark-burst {
  0%   { opacity: 0; transform: scale(0.4) rotate(0deg); }
  40%  { opacity: 1; transform: scale(2.0) rotate(-18deg); filter: drop-shadow(0 0 18px var(--accent)); }
  100% { opacity: 0; transform: scale(1.2) rotate(8deg); }
}

/* === 기마 창격(joust) === */
/* 1) 중앙으로 질주 — 왼쪽은 오른쪽으로, 오른쪽은(이미 반전됨) 같은 방향으로 전진 */
.sprite.charge-in { animation: charge-left 0.6s cubic-bezier(.4,0,.5,1); }
@keyframes charge-left {
  0%   { transform: translateX(-30px); }
  55%  { transform: translateX(48px); }   /* 중앙 충돌 지점 */
  100% { transform: translateX(0); }
}
/* 오른쪽 진영: 부모가 scaleX(-1)이라 같은 키프레임이 자연히 마주 보며 돌진 */
.fighter-right .sprite.charge-in { animation: charge-left 0.6s cubic-bezier(.4,0,.5,1); }

/* 질주 중 다리 구르기 가속 */
.sprite.charge-in .leg { animation: gallop 0.16s linear infinite; }
@keyframes gallop {
  0%,100% { transform: rotate(-14deg); }
  50%     { transform: rotate(14deg); }
}
.sprite.charge-in .tail { animation: tail-wave 0.2s ease-in-out infinite; transform-origin: right center; }
@keyframes tail-wave { 0%,100% { transform: rotate(-6deg); } 50% { transform: rotate(8deg); } }

/* 2) 창 부딪힘 — 패자: 뒤로 젖혀지며 휘청 / 승자: 창을 강하게 내지름 */
.sprite.joust-hit { animation: joust-recoil 0.34s ease-out 0.0s; }
@keyframes joust-recoil {
  0%   { transform: translateX(40px) rotate(0); }
  35%  { transform: translateX(-6px) rotate(-10deg); filter: drop-shadow(0 8px 10px rgba(255,60,90,0.6)); }
  100% { transform: translateX(0) rotate(0); }
}
.sprite.joust-push .lance { animation: lance-thrust 0.34s ease-out; transform-origin: left center; }
@keyframes lance-thrust {
  0% { transform: translateX(0) rotate(0); }
  40% { transform: translateX(8px) rotate(-3deg); }
  100% { transform: translateX(0) rotate(0); }
}

/* 피격/회피(라운드 내 개별 타격 연출) */
.sprite.hurt { animation: knight-shake 0.28s; }
@keyframes knight-shake {
  0%,100% { transform: translateX(0); }
  25% { transform: translateX(-7px) rotate(-3deg); filter: drop-shadow(0 8px 10px rgba(255,0,0,0.55)); }
  75% { transform: translateX(7px) rotate(3deg); }
}
.fighter-right .sprite.hurt { animation: knight-shake-r 0.28s; }
@keyframes knight-shake-r {
  0%,100% { transform: scaleX(-1) translateX(0); }
  25% { transform: scaleX(-1) translateX(-7px) rotate(-3deg); filter: drop-shadow(0 8px 10px rgba(255,0,0,0.55)); }
  75% { transform: scaleX(-1) translateX(7px) rotate(3deg); }
}
.sprite.dodge { transform: translateY(-16px); opacity: 0.75; }
.fighter-right .sprite.dodge { transform: scaleX(-1) translateY(-16px); opacity: 0.75; }

/* 잔디/모래 바닥 */
.arena.joust .ground {
  position: absolute; left: 0; right: 0; bottom: 0; height: 44px; z-index: 1;
  background:
    linear-gradient(180deg, #2c3b24 0%, #1d2a17 100%);
  border-top: 2px solid #3a4d2e;
}
.arena.joust .ground::after {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(90deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 26px);
}

.float-text {
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  font-weight: 800; font-size: 20px; pointer-events: none;
  animation: floatUp 0.9s ease forwards;
  text-shadow: 0 2px 4px rgba(0,0,0,0.7);
}
.float-text.hit { color: #ff9a4d; }
.float-text.crit { color: #ff3b5c; font-size: 26px; }
.float-text.aoe { color: #b06bff; }
.float-text.dot { color: #9aff8b; }
.float-text.heal { color: #2ecf8b; }
.float-text.miss { color: var(--muted); font-size: 16px; }
.float-text.ulthit { color: #ffd34d; font-size: 28px; text-shadow: 0 0 10px #ff8a00, 0 2px 4px rgba(0,0,0,0.8); }

/* === 궁극기 연출 === */
.sprite.ult-charge { animation: ult-charge 0.7s ease; }
@keyframes ult-charge {
  0%,100% { filter: drop-shadow(0 10px 8px rgba(0,0,0,0.45)); }
  40% { filter: drop-shadow(0 0 22px #ffd34d) drop-shadow(0 0 40px #ff8a00); transform: scale(1.12); }
}
.fighter-right .sprite.ult-charge { animation: ult-charge-r 0.7s ease; }
@keyframes ult-charge-r {
  0%,100% { transform: scaleX(-1); filter: drop-shadow(0 10px 8px rgba(0,0,0,0.45)); }
  40% { transform: scaleX(-1) scale(1.12); filter: drop-shadow(0 0 22px #ffd34d) drop-shadow(0 0 40px #ff8a00); }
}

/* 궁극기 풀스크린 오버레이 (화면 전체를 잠시 덮음) */
.ult-overlay {
  position: fixed; inset: 0; z-index: 9999;
  display: grid; place-items: center;
  background: radial-gradient(circle at 50% 45%, rgba(20,8,4,0.6), rgba(5,3,8,0.92));
  opacity: 0; transition: opacity 0.18s ease;
  pointer-events: none; overflow: hidden;
}
.ult-overlay.show { opacity: 1; }
.ult-overlay.out { opacity: 0; transition: opacity 0.35s ease; }
.ult-fx-img {
  width: min(92vw, 720px); max-height: 80vh; object-fit: contain;
  filter: drop-shadow(0 0 40px rgba(255,150,0,0.6));
  animation: ult-fx-pop 1.1s ease;
}
@keyframes ult-fx-pop {
  0%   { transform: scale(0.6) rotate(-6deg); opacity: 0; }
  18%  { transform: scale(1.12) rotate(2deg); opacity: 1; }
  40%  { transform: scale(1.0) rotate(0); }
  100% { transform: scale(1.04); opacity: 1; }
}
.ult-overlay-text {
  position: absolute; bottom: 14%; left: 50%; transform: translateX(-50%);
  font-size: clamp(28px, 7vw, 56px); font-weight: 900; letter-spacing: 4px;
  color: #ffd34d; text-shadow: 0 0 20px #ff8a00, 0 4px 10px rgba(0,0,0,0.9);
  white-space: nowrap; animation: ult-text 1.1s ease;
}
@keyframes ult-text {
  0% { opacity: 0; transform: translateX(-50%) scale(0.7); }
  25% { opacity: 1; transform: translateX(-50%) scale(1.1); }
  100% { opacity: 1; transform: translateX(-50%) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
  .ult-fx-img, .ult-overlay-text { animation: none; }
}
@keyframes floatUp {
  0% { opacity: 0; transform: translate(-50%, 0) scale(0.8); }
  20% { opacity: 1; transform: translate(-50%, -18px) scale(1.1); }
  100% { opacity: 0; transform: translate(-50%, -52px) scale(1); }
}

/* 로그 */
.battle-log {
  margin-top: 16px; background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 12px 14px; min-height: 120px; font-size: 13px;
}
.log-line { padding: 4px 0; border-bottom: 1px solid rgba(255,255,255,0.04); animation: fadeIn 0.2s; }
.log-line:last-child { border-bottom: none; }
.log-line .vs { color: var(--muted); font-size: 11px; margin: 0 2px; }
.log-line.round { color: var(--muted); }
.log-line.crit { color: #ff3b5c; }
.log-line.heal { color: #2ecf8b; }
.log-line.fatal { color: var(--accent); font-weight: 800; font-size: 15px; }
.log-line.ult { color: #ffd34d; font-weight: 700; }

/* ---------- 결과 ---------- */
.result-box { text-align: center; background: var(--panel); border: 1px solid var(--line); border-radius: 18px; padding: 34px 24px; }
.crown { font-size: 60px; animation: pop 0.5s ease; }
@keyframes pop { 0% { transform: scale(0); } 70% { transform: scale(1.25); } 100% { transform: scale(1); } }
#winner-name { font-size: 28px; margin: 10px 0 4px; }
#winner-sub { color: var(--muted); margin: 0 0 14px; }
.score-line { color: var(--text); font-size: 14px; line-height: 1.8; margin-bottom: 22px; }
.score-line b { color: var(--accent); }

.result-fighters { display: flex; justify-content: center; gap: 40px; margin-bottom: 26px; }
.result-fighter { padding: 16px 22px; border-radius: 14px; border: 1px solid var(--line); position: relative; min-width: 140px; }
.result-fighter.winner { border-color: var(--char-color); box-shadow: 0 0 30px -6px var(--char-color); transform: scale(1.06); }
.result-fighter.loser { opacity: 0.55; filter: grayscale(0.5); }
.rf-emoji { font-size: 50px; }
.rf-name { font-weight: 800; color: var(--char-color); margin-top: 4px; }
.rf-handle { font-size: 12px; color: var(--muted); }
.rf-badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--accent); color: #1a1300; font-weight: 800; font-size: 11px;
  padding: 3px 10px; border-radius: 999px;
}

/* 전투 후 지표 비교 */
.result-metrics {
  text-align: left; background: var(--panel-2); border: 1px solid var(--line);
  border-radius: 14px; padding: 14px 16px; margin: 0 0 18px;
}
.rm-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; font-size: 12px; }
.rm-name { font-weight: 700; }
.rm-vs { color: var(--muted); font-size: 11px; }
.rm-row { display: grid; grid-template-columns: 30px 1fr 92px 1fr 30px; align-items: center; gap: 6px; margin: 6px 0; }
.rm-label { text-align: center; font-size: 11px; color: var(--text); line-height: 1.1; }
.rm-label small { display: block; color: var(--muted); font-size: 9px; }
.rm-bar { height: 9px; background: var(--panel); border-radius: 5px; overflow: hidden; position: relative; }
.rm-bar i { position: absolute; top: 0; height: 100%; }
.rm-bar i.left { right: 0; background: linear-gradient(90deg, transparent, var(--left)); }
.rm-bar i.right { left: 0; background: linear-gradient(90deg, var(--right), transparent); }
.rm-v { font-size: 12px; color: var(--muted); text-align: center; }
.rm-v.left { text-align: right; }
.rm-v.hi { color: var(--text); font-weight: 800; }

/* 패인 분석 + showcase 유입 */
.loss-analysis {
  text-align: left; border-radius: 14px; padding: 16px 18px; margin: 0 0 18px;
  border: 1px solid var(--line);
}
.loss-analysis.me-lost { background: rgba(255,93,115,0.08); border-color: var(--left); }
.loss-analysis.me-won { background: rgba(77,139,255,0.06); border-color: var(--line); }
.la-head { font-weight: 800; font-size: 15px; margin-bottom: 4px; }
.la-target { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.la-target b { color: var(--accent); }
.la-reason { font-size: 13px; line-height: 1.6; margin: 0 0 12px; color: var(--text); }
.la-cta {
  display: block; background: var(--accent); color: #1a1300; font-weight: 700;
  font-size: 13px; line-height: 1.5; text-decoration: none; padding: 12px 14px;
  border-radius: 10px; transition: filter 0.15s;
}
.la-cta:hover { filter: brightness(1.06); }

.result-logged { color: var(--muted); font-size: 13px; margin: 6px 0 4px; min-height: 18px; }
.result-btns { display: flex; gap: 12px; justify-content: center; align-items: center; flex-wrap: wrap; }
.result-btns .btn-huge { margin-top: 14px; }

/* 상단 로그인 상태 바 — 헤더 맨 윗줄에 오른쪽 정렬(겹침 방지) */
.auth-bar {
  display: flex; gap: 6px; align-items: center; justify-content: flex-end;
  flex-wrap: wrap; flex: 1;
}
.auth-who {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--accent); font-weight: 700; margin-right: 4px;
  max-width: 46vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  background: transparent; border: 1px solid transparent; border-radius: 8px;
  padding: 5px 8px; cursor: pointer; font-family: inherit;
}
.auth-who:hover { border-color: var(--line); background: var(--panel-2); }
.auth-avatar {
  width: 22px; height: 22px; border-radius: 50%; object-fit: cover;
  border: 1px solid var(--line); background: var(--panel-2);
  display: inline-flex; align-items: center; justify-content: center; font-size: 13px; flex: 0 0 auto;
}
.auth-handle { color: var(--muted); font-weight: 400; font-size: 11px; }
.auth-gid {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px;
  color: var(--muted); font-weight: 600; background: var(--panel-2);
  border: 1px solid var(--line); padding: 1px 6px; border-radius: 6px; flex-shrink: 0;
}
.auth-bar .btn { padding: 7px 10px; font-size: 12px; }

/* 게임 아이디 칩 (대시보드) */
.game-id {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px;
  color: var(--accent); font-weight: 700; background: var(--panel-2);
  border: 1px solid var(--line); padding: 2px 10px; border-radius: 8px;
  cursor: pointer; vertical-align: middle; margin-left: 6px;
}
.game-id:hover { border-color: var(--accent); }
.dash-nick-hint.err { color: var(--left); }

/* 참전/비전투 상태 pill */
.status-pill { font-weight: 700; }
.status-pill.open { color: #2ecf8b; border-color: rgba(46,207,139,0.4); }
.status-pill.busy { color: var(--left); border-color: rgba(255,93,115,0.4); }

/* 전적 카드 차단 버튼 */
.bcard-block {
  margin-left: auto; font-size: 11px; padding: 4px 8px; border-radius: 7px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--muted);
  cursor: pointer; white-space: nowrap;
}
.bcard-block:hover { border-color: var(--left); color: var(--left); }
.bcard-block.blocked { color: var(--accent); border-color: rgba(255,204,77,0.4); }

/* ---------- 개인 전적 대시보드 ---------- */
.dash-topbar { display: flex; justify-content: space-between; margin-bottom: 14px; }
.dash-head { margin-bottom: 18px; }
.dash-who { display: flex; align-items: center; gap: 14px; }
.dash-avatar {
  width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center;
  font-size: 28px; background: var(--panel-2); border: 1px solid var(--line);
}
.dash-name { font-size: 22px; font-weight: 800; }
.dash-handle { font-size: 12px; color: var(--muted); }
.dash-title { font-size: 14px; color: var(--accent); font-weight: 700; }

/* 닉네임 편집 */
.dash-nick {
  margin-top: 14px; background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 14px 16px;
}
.dash-nick-label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; font-weight: 700; }
.dash-nick-row { display: flex; gap: 8px; flex-wrap: wrap; }
.dash-nick-input {
  flex: 1; min-width: 160px; padding: 10px 12px; border-radius: 10px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--text); font-size: 14px;
}
.dash-nick-input:focus { outline: none; border-color: var(--accent); }
.dash-nick-hint { font-size: 11px; color: var(--muted); margin-top: 8px; }

.dash-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(90px, 1fr)); gap: 10px; margin-bottom: 22px; }
.dstat {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px 8px; text-align: center;
}
.dstat-num { display: block; font-size: 22px; font-weight: 800; }
.dstat-l { font-size: 11px; color: var(--muted); }
.dstat.win .dstat-num { color: #2ecf8b; }
.dstat.lose .dstat-num { color: var(--left); }
.dstat.deal .dstat-num { color: #ff9a4d; }
.dstat.taken .dstat-num { color: #ff5d73; }

.dash-sec { font-size: 16px; margin: 0 0 12px; }

/* 업적 */
.ach-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; margin-bottom: 22px; }
.ach {
  display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-radius: 10px;
  background: var(--panel); border: 1px solid var(--line); font-size: 12px;
}
.ach.earned { border-color: var(--accent); box-shadow: 0 0 16px -10px var(--accent); }
.ach.locked { opacity: 0.45; }
.ach-icon { font-size: 20px; }
.ach-name { font-weight: 700; flex: 1; }
.ach-state { font-size: 10px; color: var(--muted); }
.ach.earned .ach-state { color: var(--accent); font-weight: 700; }

/* 캐릭터별 전적 */
.char-stats-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 22px; }
.cs-row {
  display: grid; grid-template-columns: 32px 1fr auto auto auto; gap: 10px; align-items: center;
  background: var(--panel); border: 1px solid var(--line); border-left: 4px solid var(--char-color);
  border-radius: 10px; padding: 10px 14px; font-size: 13px;
}
.cs-emoji { font-size: 22px; }
.cs-name { font-weight: 700; color: var(--char-color); }
.cs-rec { color: var(--muted); font-size: 12px; }
.cs-wr { font-weight: 800; color: var(--accent); }
.cs-dmg { font-size: 12px; color: #ff9a4d; }

/* 전투별 상세 카드 */
.dash-list { display: flex; flex-direction: column; gap: 10px; }
.bcard {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px 14px; border-left: 4px solid var(--line);
}
.bcard.win { border-left-color: #2ecf8b; }
.bcard.lose { border-left-color: var(--left); }
.bcard.draw { border-left-color: var(--muted); }
.bcard-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.bcard-badge { font-weight: 800; font-size: 12px; padding: 3px 8px; border-radius: 7px; background: var(--panel-2); }
.bcard.win .bcard-badge { color: #2ecf8b; }
.bcard.lose .bcard-badge { color: var(--left); }
.bcard-vs { font-size: 13px; flex: 1; min-width: 180px; }
.bcard-time { font-size: 11px; color: var(--muted); }
.bcard-stats { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.bs { font-size: 11px; color: var(--muted); background: var(--panel-2); padding: 3px 8px; border-radius: 7px; }
.bs.deal { color: #ff9a4d; }
.bs.taken { color: #ff5d73; }
.bs.ult { color: #ffd34d; }

/* ---------- 전적/로그 화면 ---------- */
.log-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.log-header h2 { margin: 0; font-size: 22px; }
.log-actions { display: flex; gap: 8px; }

.log-stats {
  display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px;
}
.log-stats .stat {
  flex: 1; min-width: 80px; background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 14px 10px; text-align: center;
}
.log-stats .stat-num { display: block; font-size: 24px; font-weight: 800; }
.log-stats .stat-label { font-size: 12px; color: var(--muted); }
.log-stats .stat.win .stat-num { color: #2ecf8b; }
.log-stats .stat.lose .stat-num { color: var(--left); }

.log-list { display: flex; flex-direction: column; gap: 10px; }
.log-empty { text-align: center; color: var(--muted); padding: 40px 0; }
.log-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px 14px; border-left: 4px solid var(--line);
}
.log-card.win { border-left-color: #2ecf8b; }
.log-card.lose { border-left-color: var(--left); }
.log-card.draw { border-left-color: var(--muted); }
.log-card-main { display: flex; align-items: center; gap: 14px; }
.log-outcome {
  font-weight: 800; font-size: 13px; min-width: 52px; text-align: center;
  padding: 6px 8px; border-radius: 8px; background: var(--panel-2);
}
.log-card.win .log-outcome { color: #2ecf8b; }
.log-card.lose .log-outcome { color: var(--left); }
.log-card.draw .log-outcome { color: var(--muted); }
.log-summary { font-size: 14px; }
.log-meta { font-size: 11px; color: var(--muted); margin-top: 4px; }
.sync-pending { color: var(--accent); margin-left: 4px; }

/* 반응형 */
@media (max-width: 720px) {
  .setup-grid { grid-template-columns: 1fr; }
  .vs-divider { padding: 6px 0; }
  .sprite { width: 140px; height: 105px; }
  .arena { min-height: 180px; }
  .result-fighters { gap: 16px; }
  /* 헤더: 좁은 화면에서 상태바 줄바꿈 + 로고 축소 */
  .logo { font-size: 26px; }
  .tagline { font-size: 12px; }
  .auth-bar { justify-content: center; }
  .auth-who { max-width: 100%; }
}
@media (max-width: 420px) {
  .logo { font-size: 22px; }
  .auth-bar .btn { padding: 6px 8px; font-size: 11px; }
}

/* ---------- 사이트 푸터 (showcase.aline.team 동일) ---------- */
.site-footer {
  margin-top: 40px;
  border-top: 1px solid var(--line);
  background: #0a0c16;
  color: var(--muted);
  padding: 32px 18px 40px;
}
.footer-inner { max-width: 1000px; margin: 0 auto; text-align: center; }
.footer-brand {
  font-size: 18px; font-weight: 600; letter-spacing: 2px;
  color: var(--text); margin-bottom: 14px;
}
.footer-company { font-size: 12px; line-height: 1.8; color: var(--muted); }
.footer-copy { font-size: 12px; color: var(--muted); margin-top: 12px; }
.footer-links {
  display: flex; justify-content: center; align-items: center;
  flex-wrap: wrap; gap: 0; margin: 16px 0 12px;
}
.footer-links a, .footer-contact {
  font-size: 13px; color: var(--text); text-decoration: none; padding: 0 14px;
  position: relative;
}
.footer-links a:hover { color: var(--accent); }
/* 항목 사이 구분선 */
.footer-links a:not(:first-child)::before,
.footer-contact::before {
  content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 1px; height: 12px; background: var(--line);
}
.footer-contact { color: var(--muted); cursor: default; }
.footer-tagline { font-size: 12px; color: var(--muted); margin-top: 6px; }

/* ---------- 대전 상대 찾기 (검색 + 지도) ---------- */
.find-cta { margin: 28px 0 8px; }
.find-top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.find-title { margin: 0; font-size: 22px; }

.find-tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.find-tab {
  flex: 1; padding: 12px; border-radius: 10px; border: 1px solid var(--line);
  background: var(--panel); color: var(--muted); font-size: 14px; font-weight: 700; cursor: pointer;
}
.find-tab.active { color: var(--text); border-color: var(--accent); background: var(--panel-2); }

.find-pane { display: none; }
.find-pane.active { display: block; }

.find-searchbar { display: flex; gap: 8px; margin-bottom: 12px; }
.find-input {
  flex: 1; padding: 12px 14px; border-radius: 10px; border: 1px solid var(--line);
  background: var(--panel-2); color: var(--text); font-size: 14px;
}
.find-input:focus { outline: none; border-color: var(--accent); }

.find-legend { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; font-size: 12px; color: var(--muted); margin-bottom: 12px; }
.find-legend .lg.open { color: #2ecf8b; }
.find-legend .lg.busy { color: var(--left); }
.map-hint { margin-left: auto; }

.find-results { display: flex; flex-direction: column; gap: 8px; }
.find-empty { text-align: center; color: var(--muted); padding: 30px 0; }
.find-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px 14px; border-left: 4px solid var(--line);
}
.find-card.open { border-left-color: #2ecf8b; }
.find-card.busy { border-left-color: var(--left); opacity: 0.85; }
.fc-main { flex: 1; min-width: 0; }
.fc-name { font-weight: 700; font-size: 14px; }
.fc-gid { font-family: ui-monospace, monospace; font-size: 11px; color: var(--muted); }
.fc-loc { font-size: 12px; color: var(--muted); margin-top: 2px; }
.fc-status { font-size: 12px; font-weight: 700; white-space: nowrap; }
.fc-status.open { color: #2ecf8b; }
.fc-status.busy { color: var(--left); }
.fc-btn { font-size: 13px; white-space: nowrap; }

/* 지도 */
.map-countries { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.map-country {
  padding: 8px 14px; border-radius: 999px; border: 1px solid var(--line);
  background: var(--panel); color: var(--muted); font-size: 13px; cursor: pointer;
}
.map-country.active { color: var(--text); border-color: var(--accent); background: var(--panel-2); }
.map-wrap {
  position: relative; width: 100%; border: 1px solid var(--line); border-radius: 14px;
  overflow: hidden; background: #0c1024; touch-action: none;
}
.map-wrap.panning { cursor: grabbing; }
/* 줌·팬 대상 스테이지 (SVG + 마커를 함께 변환) */
.map-stage { position: relative; transform-origin: center center; will-change: transform; }
#world-map { display: block; width: 100%; height: auto; }
.map-markers { position: absolute; inset: 0; }
.map-marker {
  position: absolute; width: 16px; height: 16px; border-radius: 50%;
  transform: translate(-50%, -50%); border: 2px solid #0c1024; cursor: pointer;
  padding: 0; transition: transform 0.1s;
}
.map-marker.open { background: #2ecf8b; box-shadow: 0 0 8px rgba(46,207,139,0.7); }
.map-marker.busy { background: var(--left); box-shadow: 0 0 6px rgba(255,93,115,0.5); }
.map-marker:hover { transform: translate(-50%, -50%) scale(1.4); z-index: 5; }
/* 줌 컨트롤 */
.map-zoom {
  position: absolute; right: 10px; bottom: 10px; z-index: 20;
  display: flex; flex-direction: column; gap: 6px;
}
.map-zoom-btn {
  width: 34px; height: 34px; border-radius: 8px; border: 1px solid var(--line);
  background: rgba(23,26,43,0.9); color: var(--text); font-size: 18px; font-weight: 700;
  cursor: pointer; display: grid; place-items: center; line-height: 1;
}
.map-zoom-btn:hover { border-color: var(--accent); color: var(--accent); }
.map-tooltip {
  position: absolute; z-index: 10; min-width: 160px; max-width: 220px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 10px 12px; box-shadow: 0 10px 30px -12px rgba(0,0,0,0.8); font-size: 13px;
}
.map-tooltip.open { border-color: #2ecf8b; }
.map-tooltip.busy { border-color: var(--left); }
.map-tooltip .mt-name { font-weight: 700; }
.map-tooltip .mt-loc { font-size: 12px; color: var(--muted); margin: 4px 0 8px; }
.map-tooltip .mt-btn { width: 100%; font-size: 13px; }

/* ---------- 전체 전적 · 랭킹 ---------- */
.log-tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.log-tab {
  flex: 1; padding: 11px; border-radius: 10px; border: 1px solid var(--line);
  background: var(--panel); color: var(--muted); font-size: 13px; font-weight: 700; cursor: pointer;
}
.log-tab.active { color: var(--text); border-color: var(--accent); background: var(--panel-2); }
.log-pane { display: none; }
.log-pane.active { display: block; }

/* 전체 전적 피드 */
.feed-list { display: flex; flex-direction: column; gap: 8px; }
.feed-row {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 12px 14px;
}
.fr-line { font-size: 14px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.fr-player { color: var(--muted); }
.fr-player small { color: var(--muted); font-size: 11px; margin-left: 2px; }
.fr-player.winner { color: var(--text); font-weight: 800; }
.fr-player.winner::after { content: " 👑"; }
.fr-vs { color: var(--muted); font-size: 12px; }
.fr-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 6px; font-size: 11px; color: var(--muted); }
.fr-tag { background: var(--panel-2); border: 1px solid var(--line); padding: 2px 8px; border-radius: 7px; }
.fr-arrow { color: var(--accent); }
.fr-time { margin-left: auto; }

.feed-pager { display: flex; align-items: center; justify-content: center; gap: 14px; margin-top: 16px; }
.feed-pageinfo { font-size: 13px; color: var(--muted); }
.feed-pager .btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* 랭킹 */
.rank-note { font-size: 13px; color: var(--muted); margin: 0 0 14px; }
.rank-list { display: flex; flex-direction: column; gap: 8px; }
.rank-row {
  display: flex; align-items: center; gap: 14px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 12px 16px;
}
.rank-no { font-size: 16px; font-weight: 800; min-width: 32px; text-align: center; color: var(--muted); }
.rank-no.top { font-size: 20px; }
.rank-name { flex: 1; font-weight: 700; font-size: 14px; }
.rank-val { font-size: 13px; color: var(--muted); }
.rank-val b { color: var(--accent); font-size: 15px; }
.rank-val small { font-size: 11px; }

/* ---------- 약관/개인정보 페이지 ---------- */
.legal-content {
  max-width: 760px; margin: 16px auto 0; background: var(--panel);
  border: 1px solid var(--line); border-radius: 14px; padding: 28px 30px;
  line-height: 1.75; color: var(--text);
}
.legal-content h1 { font-size: 24px; margin: 0 0 4px; }
.legal-content h2 { font-size: 16px; margin: 22px 0 6px; color: var(--accent); }
.legal-content p { font-size: 14px; color: var(--muted); margin: 6px 0; }
.legal-content .legal-updated { font-size: 12px; color: var(--muted); margin-bottom: 16px; }
#screen-legal .btn-back { margin-bottom: 8px; }

/* 푸터 링크가 a 태그로 바뀐 Contact도 동일 스타일 */
.footer-contact { cursor: pointer; }
