:root {
  --bg: #0e1015; --panel: #171a21; --panel2: #1e222b; --line: #2a2f3a;
  --txt: #e7e9ef; --muted: #98a1b2; --accent: #5b8cff; --accent-d: #3f6ddb;
  --good: #36c275; --ok: #8bd14f; --warn: #e0b94a; --bad: #e2683f; --dead: #9aa3b2;
  --radius: 14px; --shadow: 0 4px 18px rgba(0,0,0,.35);
}
* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--bg); color: var(--txt); font-size: 15px; line-height: 1.5;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Apple SD Gothic Neo",
    "Noto Sans KR", Roboto, sans-serif;
}
a { color: var(--accent); text-decoration: none; }

/* ===== Topbar ===== */
.topbar {
  position: sticky; top: 0; z-index: 50; display: flex; align-items: center;
  justify-content: space-between; gap: 12px; padding: 12px 18px;
  background: rgba(14,16,21,.9); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand { font-weight: 800; font-size: 19px; color: var(--txt); letter-spacing: -.3px; }
.brand span { color: var(--accent); }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.db-stats { color: var(--muted); font-size: 12.5px; text-align: right; }
.btn-ghost {
  background: var(--panel2); color: var(--txt); border: 1px solid var(--line);
  border-radius: 10px; padding: 8px 12px; cursor: pointer; font-size: 13px; white-space: nowrap;
}
.btn-ghost:hover { border-color: var(--accent); color: #fff; }
/* ES-EZ 커피 후원 — DB 업데이트와 동일 크기, 커피색 유지 */
.btn-coffee {
  display: inline-flex; align-items: center; gap: 4px; font-size: 13px; white-space: nowrap;
  padding: 8px 12px; border-radius: 10px; cursor: pointer; font-weight: 600;
  background: #6f4e37; color: #f4e9dc; border: 1px solid #5a3d2b;
}
.btn-coffee:hover { background: #815c41; color: #fff; }

/* ===== Sync banner ===== */
.sync-banner { padding: 8px 18px; background: var(--panel); border-bottom: 1px solid var(--line); }
.sync-bar { height: 6px; background: var(--panel2); border-radius: 4px; overflow: hidden; }
.sync-fill { height: 100%; width: 0; background: linear-gradient(90deg,var(--accent),#7aa2ff); transition: width .3s; }
.sync-msg { font-size: 12px; color: var(--muted); }

.container { max-width: 1180px; margin: 0 auto; padding: 18px; }

/* ===== Search + filters ===== */
.searchwrap { margin-bottom: 12px; }
.search {
  width: 100%; padding: 14px 16px; font-size: 16px; color: var(--txt);
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px; outline: none;
}
.search:focus { border-color: var(--accent); }
.filters { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 8px; }

/* multi-select dropdown */
.ms { position: relative; }
.ms-btn {
  display: flex; align-items: center; gap: 8px; background: var(--panel); color: var(--txt);
  border: 1px solid var(--line); border-radius: 10px; padding: 9px 13px; cursor: pointer; font-size: 14px;
}
.ms-btn:hover { border-color: var(--accent); }
.ms-btn .cnt {
  background: var(--accent); color: #fff; border-radius: 999px; font-size: 11px;
  padding: 1px 7px; font-weight: 700;
}
.ms-btn .caret { color: var(--muted); font-size: 11px; }
.ms-panel {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 40; width: 280px; max-width: 86vw;
  background: var(--panel2); border: 1px solid var(--line); border-radius: 12px;
  box-shadow: var(--shadow); padding: 10px; display: none;
}
.ms-panel.open { display: block; }
.ms-search {
  width: 100%; padding: 8px 10px; margin-bottom: 8px; background: var(--panel); color: var(--txt);
  border: 1px solid var(--line); border-radius: 8px; outline: none; font-size: 13px;
}
.ms-list { max-height: 260px; overflow-y: auto; }
.ms-opt {
  display: flex; align-items: center; gap: 9px; padding: 7px 8px; border-radius: 8px; cursor: pointer; font-size: 14px;
}
.ms-opt:hover { background: var(--panel); }
.ms-opt input { accent-color: var(--accent); width: 16px; height: 16px; }
.ms-opt small { color: var(--muted); margin-left: auto; }

.active-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 10px; }
.chip {
  display: inline-flex; align-items: center; gap: 6px; background: var(--accent-d); color: #fff;
  border-radius: 999px; padding: 4px 10px; font-size: 12.5px;
}
.chip b { font-weight: 700; }
.chip .x { cursor: pointer; opacity: .85; }
.chip-clear { background: var(--panel2); color: var(--muted); cursor: pointer; }

.result-count { color: var(--muted); font-size: 13px; margin: 4px 2px 14px; }

/* ===== Game cards ===== */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 16px; }
.gcard {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; cursor: pointer; display: flex; flex-direction: column; transition: transform .12s, border-color .12s;
}
.gcard:hover { transform: translateY(-3px); border-color: var(--accent); }
.gcard .art { aspect-ratio: 3/4; background: var(--panel2) center/cover no-repeat; position: relative; }
.gcard .art .badge {
  position: absolute; top: 8px; left: 8px; font-size: 11.5px; font-weight: 700; color: #fff;
  padding: 3px 8px; border-radius: 999px; backdrop-filter: blur(3px); background: rgba(0,0,0,.45);
}
.gcard .body { padding: 11px 12px 13px; }
.gcard .title { font-weight: 700; font-size: 14.5px; line-height: 1.35; margin-bottom: 6px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gcard .sys { color: var(--muted); font-size: 12px; margin-bottom: 8px; }
.gcard .meta { display: flex; flex-wrap: wrap; gap: 6px; font-size: 11.5px; color: var(--muted); }
.gcard .meta span { background: var(--panel2); padding: 2px 7px; border-radius: 6px; }

/* perf colors */
.perf { color:#fff; font-weight:700; }
.perf-1{background:var(--good)} .perf-2{background:var(--ok)} .perf-3{background:var(--warn)}
.perf-4{background:var(--bad)} .perf-5,.perf-6,.perf-7,.perf-8{background:var(--dead)}

/* ===== Pager ===== */
.pager { display: flex; justify-content: center; align-items: center; gap: 8px; margin: 26px 0 10px; }
.pager button {
  background: var(--panel); color: var(--txt); border: 1px solid var(--line); border-radius: 9px;
  padding: 8px 14px; cursor: pointer; font-size: 14px;
}
.pager button:disabled { opacity: .4; cursor: default; }
.pager .cur { color: var(--muted); font-size: 13px; }

/* ===== Detail ===== */
.back { display: inline-flex; gap: 6px; align-items: center; color: var(--muted); cursor: pointer; margin-bottom: 14px; font-size: 14px; }
.back:hover { color: var(--txt); }
.ghead { display: flex; gap: 18px; margin-bottom: 22px; }
.ghead .art { width: 130px; aspect-ratio: 3/4; border-radius: 12px; background: var(--panel2) center/cover; flex: none; }
.ghead h1 { font-size: 24px; margin: 2px 0 8px; line-height: 1.25; }
.ghead .sub { color: var(--muted); font-size: 14px; }
.ghead .tags { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.ghead .tags span { background: var(--panel2); border: 1px solid var(--line); padding: 4px 10px; border-radius: 8px; font-size: 12.5px; color: var(--muted); }

.sec-title { font-size: 16px; font-weight: 700; margin: 26px 0 12px; display:flex; align-items:center; gap:8px;}
.sec-title small { color: var(--muted); font-weight: 400; font-size: 13px; }

/* listing (기기별 세팅) */
.lcard { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; margin-bottom: 12px; overflow: hidden; }
.lhead { display: flex; align-items: center; gap: 12px; padding: 13px 15px; cursor: pointer; }
.lhead:hover { background: var(--panel2); }
.lhead .dev { font-weight: 700; font-size: 15px; }
.lhead .emu { color: var(--muted); font-size: 13px; }
.lhead .right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.pill { font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 999px; }
.lhead .arrow { color: var(--muted); transition: transform .15s; }
.lcard.open .lhead .arrow { transform: rotate(90deg); }
.lbody { display: none; padding: 4px 15px 16px; border-top: 1px solid var(--line); }
.lcard.open .lbody { display: block; }

.note { background: var(--panel2); border-radius: 9px; padding: 11px 13px; margin: 12px 0; font-size: 13.5px; }
.note .orig { color: var(--muted); font-size: 12px; margin-top: 6px; white-space: pre-wrap; }
.note .ko { white-space: pre-wrap; }

.setcat { margin-top: 14px; }
.setcat h4 { font-size: 13px; color: var(--accent); margin: 0 0 7px; text-transform: uppercase; letter-spacing: .4px; }
.kv { display: grid; grid-template-columns: 180px 1fr; gap: 2px 14px; }
.kv .k { color: var(--muted); font-size: 13px; padding: 5px 0; }
.kv .v { font-size: 13.5px; padding: 5px 0; word-break: break-word; }
.kv .v.copyable { cursor: pointer; }
.kv .v code { background: var(--panel2); padding: 1px 6px; border-radius: 5px; }
.muted-note { color: var(--muted); font-size: 13px; padding: 8px 0; }
.btn-load { background: var(--accent-d); color:#fff; border:none; border-radius:8px; padding:7px 12px; cursor:pointer; font-size:13px; }

/* ===== Comments ===== */
.comments { margin-top: 30px; border-top: 1px solid var(--line); padding-top: 18px; }
.cform { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.cform .row { display: flex; gap: 8px; }
.cform input.nick { width: 160px; }
.cform input.pw { width: 130px; letter-spacing: 2px; }
.citem .cdel { cursor: pointer; margin-left: 8px; opacity: .5; font-size: 12.5px; }
.citem .cdel:hover { opacity: 1; }
.cform input, .cform textarea {
  background: var(--panel); border: 1px solid var(--line); color: var(--txt); border-radius: 9px;
  padding: 10px 12px; font-size: 14px; outline: none; font-family: inherit; resize: vertical;
}
.cform textarea { flex: 1; min-height: 64px; }
.cform .submit { align-self: flex-end; background: var(--accent); color:#fff; border:none; border-radius:9px; padding:9px 18px; cursor:pointer; font-weight:700; }
.clist { display: flex; flex-direction: column; gap: 10px; }
.citem { display: flex; gap: 12px; background: var(--panel); border: 1px solid var(--line); border-radius: 11px; padding: 12px 14px; }
.citem .cmain { flex: 1; min-width: 0; }
.citem .cnick { font-weight: 700; font-size: 13.5px; }
.citem .ctime { color: var(--muted); font-size: 11.5px; margin-left: 8px; }
.citem .cbody { margin-top: 4px; font-size: 14px; white-space: pre-wrap; word-break: break-word; }
.thumb {
  display: flex; flex-direction: column; align-items: center; gap: 2px; flex: none;
  background: var(--panel2); border: 1px solid var(--line); border-radius: 10px; padding: 6px 11px;
  cursor: pointer; color: var(--muted); min-width: 52px;
}
.thumb:hover { border-color: var(--accent); }
.thumb.voted { background: var(--accent-d); border-color: var(--accent); color: #fff; }
.thumb .ic { font-size: 16px; }
.thumb .n { font-size: 13px; font-weight: 700; }

.empty { color: var(--muted); text-align: center; padding: 40px 0; }
.spinner { text-align:center; color:var(--muted); padding: 30px 0; }

/* 정발(한국어) 제목 */
.gcard .title-ko { color: var(--muted); font-size: 12px; margin: -3px 0 6px; }
.ghead .h1-ko { color: var(--muted); font-size: 15px; margin: -4px 0 8px; }

/* multiselect hint */
.ms-hint { color: var(--muted); font-size: 11.5px; padding: 2px 4px 8px; }
.ms-opt .ms-tx { flex: 1; }

/* ===== 게임상세: 필터 바 + 표 ===== */
.gfilter { display: flex; flex-wrap: wrap; gap: 10px; margin: 6px 0 14px; }
.gfilter .gsearch { flex: 1; min-width: 180px; padding: 10px 13px; background: var(--panel); color: var(--txt); border: 1px solid var(--line); border-radius: 10px; outline: none; font-size: 14px; }
.gfilter .gsearch:focus { border-color: var(--accent); }
.gfilter select { background: var(--panel); color: var(--txt); border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; font-size: 14px; }

.ltable-count { color: var(--muted); font-size: 12.5px; margin-bottom: 8px; }
.ltable { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--panel); }
.ltr { display: grid; grid-template-columns: 1fr 1fr 120px 64px 28px; align-items: center; gap: 10px; padding: 12px 15px; border-top: 1px solid var(--line); cursor: pointer; }
.ltr:first-of-type, .lthead { border-top: none; }
.ltr:not(.lthead):hover { background: var(--panel2); }
.lthead { background: var(--panel2); color: var(--muted); font-size: 12px; font-weight: 700; cursor: default; text-transform: uppercase; letter-spacing: .3px; }
.ltr .c-dev b { font-weight: 700; font-size: 14.5px; }
.ltr .c-dev small { display: block; color: var(--muted); font-size: 12px; }
.ltr .c-emu { color: var(--txt); font-size: 13.5px; }
.ltr .c-cmt { color: var(--muted); font-size: 12.5px; }
.ltr .c-go { color: var(--muted); font-size: 18px; text-align: center; }
.ltable .ltable-count { padding: 10px 15px 0; margin: 0; }

/* ===== 세팅 상세 페이지 ===== */
.lhead-detail { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 16px 18px; margin-bottom: 14px; }
.lhd-game { font-size: 19px; font-weight: 800; margin-bottom: 8px; }
.lhd-game .lhd-ko { color: var(--muted); font-size: 14px; font-weight: 400; }
.lhd-row { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.lhd-dev { font-weight: 700; font-size: 15px; }
.lhd-emu { color: var(--muted); font-size: 14px; }

.detail-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin: 6px 0 10px; flex-wrap: wrap; }
.tb-left { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sib-cap { color: var(--muted); font-size: 12.5px; }
.sib-sel { background: var(--panel); color: var(--txt); border: 1px solid var(--line); border-radius: 9px; padding: 8px 11px; font-size: 13px; max-width: 320px; }
.sib-sel:hover { border-color: var(--accent); }
.more-badge { display: inline-block; margin-left: 7px; background: var(--accent-d); color: #fff; font-size: 11px; padding: 1px 7px; border-radius: 999px; }
.toggle { display: inline-flex; align-items: center; gap: 8px; background: var(--panel); border: 1px solid var(--line); border-radius: 999px; padding: 7px 14px; cursor: pointer; font-size: 13px; color: var(--muted); user-select: none; }
.toggle input { accent-color: var(--accent); width: 15px; height: 15px; }
.toggle:hover { border-color: var(--accent); color: var(--txt); }

.settings-area .note { background: var(--panel2); border-radius: 10px; padding: 13px 15px; margin-bottom: 14px; }
.note .note-h { font-size: 12px; color: var(--accent); font-weight: 700; margin-bottom: 6px; text-transform: uppercase; }
.note .ko { white-space: pre-wrap; font-size: 14px; }
.note .orig { color: var(--muted); font-size: 12px; margin-top: 6px; }

.setcat { margin-bottom: 16px; }
.setcat h4 { font-size: 12.5px; color: var(--accent); margin: 0 0 8px; text-transform: uppercase; letter-spacing: .4px; }
.settbl { display: grid; grid-template-columns: 200px 1fr; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.settbl .st-k { background: var(--panel2); color: var(--muted); font-size: 13px; padding: 9px 13px; border-top: 1px solid var(--line); }
.settbl .st-v { font-size: 13.5px; padding: 9px 13px; border-top: 1px solid var(--line); word-break: break-word; }
.settbl .st-k:nth-child(1), .settbl .st-v:nth-child(2) { border-top: none; }
.settbl .st-v.copyable { cursor: pointer; }
.settbl .st-v code { background: var(--panel2); padding: 1px 6px; border-radius: 5px; font-size: 12.5px; }
.muted-note { color: var(--muted); font-size: 13px; padding: 10px 0; }

/* ===== retrodb 기기 스펙 패널 ===== */
.spec-panel { background: linear-gradient(180deg, rgba(91,140,255,.08), transparent); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; margin-bottom: 14px; }
.spec-h { font-size: 14px; font-weight: 700; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.spec-h small { color: var(--muted); font-weight: 400; font-size: 11.5px; }
.spec-h .spec-tier { margin-left: auto; font-size: 13px; }
.spec-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 8px 16px; }
.spec-cell { display: flex; gap: 8px; font-size: 13px; }
.spec-cell .sk { color: var(--muted); min-width: 52px; flex: none; }
.spec-cell .sv { color: var(--txt); word-break: break-word; }

@media (max-width: 640px) {
  .ltr { grid-template-columns: 1fr 88px 26px; gap: 8px; }
  .ltr .c-emu { display: none; }
  .lthead .c-emu { display: none; }
  .settbl { grid-template-columns: 1fr; }
  .settbl .st-k { border-top: 1px solid var(--line); }
  .settbl .st-v { padding-top: 2px; }
  .settbl .st-k:nth-child(1) { border-top: none; }
}

/* conf 추출 버튼 */
.extract-btn {
  background: linear-gradient(180deg, var(--accent), var(--accent-d));
  color: #fff; border: 0; border-radius: 9px; padding: 8px 14px;
  font-size: 13px; font-weight: 700; cursor: pointer; white-space: nowrap;
  box-shadow: var(--shadow);
}
.extract-btn:hover:not(:disabled) { filter: brightness(1.08); }
.extract-btn:disabled { opacity: .7; cursor: default; }

/* 관리자 전용: conf 추출 로그 (#admin) */
.admin-head h1 { font-size: 22px; margin: 4px 0 2px; }
.admin-head .sub { color: var(--muted); font-size: 13px; margin-bottom: 14px; }
.admin-summary { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 16px; }
.admin-summary .as-col { flex: 1; min-width: 220px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 12px 14px; }
.admin-summary h4 { margin: 0 0 8px; font-size: 13px; color: var(--accent); }
.as-row { display: flex; justify-content: space-between; gap: 10px; padding: 3px 0; font-size: 13px; border-bottom: 1px solid var(--line); }
.as-row span { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.as-row b { color: var(--txt); }
.admin-table { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.atr { display: grid; grid-template-columns: 150px 120px 1.4fr 1fr 1.2fr 1.4fr; gap: 8px; padding: 9px 12px; font-size: 12.5px; border-bottom: 1px solid var(--line); align-items: center; }
.atr:last-child { border-bottom: 0; }
.atr.athead { background: var(--panel2); color: var(--muted); font-weight: 700; }
.atr code { font-size: 11.5px; color: var(--ok); word-break: break-all; }
.atr .a-ip { color: var(--accent); }
.atr .a-ua { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.atr small { color: var(--muted); }

@media (max-width: 640px) {
  .container { padding: 14px; }
  .cards { grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 12px; }
  .ghead .art { width: 96px; }
  .ghead h1 { font-size: 20px; }
  .kv { grid-template-columns: 1fr; }
  .kv .k { padding-bottom: 0; }
  .kv .v { padding-top: 0; padding-bottom: 8px; }
  .db-stats { display: none; }
  .cform .row { flex-direction: column; }
  .cform input.nick { width: 100%; }
  .atr { grid-template-columns: 1fr 1fr; grid-auto-rows: auto; gap: 2px 8px; }
  .atr.athead { display: none; }
  .atr .a-ua { grid-column: 1 / -1; }
}
