:root {
  --bg: #111;
  --bg2: #252525;
  --text: #e6e6e6;
  --muted: #b9b9b9;
  --brand: #e3b86f;
  --brand-2: #c49b4f;
  --line: #3a3a3a;
  --maxw: 1200px; /* 원본 레이아웃 컨테이너 폭 재현 */ /* ref: KBU HTML의 1200 컨테이너:contentReference[oaicite:1]{index=1} */
}
* {
  box-sizing: border-box;
}
html,
body {
  margin: 0;
  padding: 0;
}
body {
  background: var(--bg);
  color: var(--text);
  font: 15px/1.6 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial,
    sans-serif;
}
.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 16px;
}
a {
  color: #fff;
  text-decoration: none;
}
a:hover {
  opacity: 0.9;
}

/* 헤더 */
.site-header {
  border-bottom: 1px solid var(--line);
  background: #141414;
}
.site-header .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
}
.brand span {
  letter-spacing: 0.2px;
}
.main-nav a {
  margin-left: 18px;
  color: var(--muted);
  font-weight: 500;
}
.main-nav a:hover {
  color: #fff;
}

/* (A) 상단 12 타일 */
.brand-tiles {
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg2);
}
.tiles {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(6, 1fr);
}
.tiles li {
  background: #191919;
  border: 1px solid #2a2a2a;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 1/1;
}
.tiles img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 1200px) {
  .tiles {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 920px) {
  .tiles {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 540px) {
  .tiles {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* (B) 타이틀 영역 */
.section-title {
  padding: 16px 0 8px;
}
.chip {
  display: inline-block;
  border: 1px solid var(--brand-2);
  color: var(--brand);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
}
.section-title h1 {
  margin: 10px 0 8px;
  font-size: 22px;
}
.section-title .lead {
  color: #d2d2d2;
}

/* (C) TOP12 카드 */
.cardgrid {
  padding: 18px 0;
}
.grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1200px) {
  .grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 920px) {
  .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 540px) {
  .grid {
    grid-template-columns: 1fr;
  }
}

.card {
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  min-height: 190px;
}
.card--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
}
.kbu-emblem {
  width: 72px;
  height: 72px;
  margin: 24px auto;
  background: url("/assets/img/kbu-emblem.png") center/contain no-repeat;
  opacity: 0.6;
}

.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.card-head .l {
  display: flex;
  align-items: center;
  gap: 10px;
}
.rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid #4f4f4f;
  background: #181818;
  font-size: 12px;
  color: #d8d8d8;
}
.card-title {
  font-size: 16px;
  margin: 0;
}
.score {
  font-size: 12px;
  color: #ddd;
  border: 1px solid #444;
  border-radius: 8px;
  padding: 2px 8px;
  background: #1a1a1a;
}

.pill-row {
  display: flex;
  gap: 6px;
  margin: 8px 0 6px;
}
.pill {
  display: inline-block;
  font-size: 11px;
  padding: 3px 8px;
  border: 1px solid var(--brand-2);
  border-radius: 999px;
  color: var(--brand);
}
.card-desc {
  margin: 0 0 10px;
  color: var(--muted);
}

.progress {
  height: 6px;
  background: #1a1a1a;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid #1f1f1f;
}
.progress i {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
}
.card-link {
  margin-top: auto;
  align-self: flex-end;
  color: var(--brand);
  font-weight: 600;
}

/* (D) 평균 점수 막대 */
.scores {
  padding: 14px 0 22px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: #151515;
}
.scores h2 {
  margin: 6px 0 10px;
  font-size: 18px;
}
.bars {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.bars li {
  display: grid;
  grid-template-columns: 120px 1fr 42px;
  align-items: center;
  gap: 10px;
}
.bars .label {
  color: #ddd;
}
.bars .bar {
  height: 8px;
  background: #1a1a1a;
  border: 1px solid #222;
  border-radius: 8px;
  overflow: hidden;
}
.bars .bar i {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
}
.bars .val {
  text-align: right;
  color: #ccc;
}
@media (max-width: 920px) {
  .bars li {
    grid-template-columns: 100px 1fr 34px;
  }
}
@media (max-width: 540px) {
  .bars li {
    grid-template-columns: 90px 1fr 30px;
  }
}

/* (E) 가이드 */
.guide {
  padding: 20px 0;
}
.checklist {
  margin: 8px 0 0 0;
  padding-left: 18px;
  color: #dcdcdc;
}
.checklist li {
  margin: 6px 0;
}

/* (F) 표 */
.criteria {
  padding: 16px 0 36px;
}
.table-wrap {
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
}
.tbl {
  border-collapse: collapse;
  width: 100%;
}
.tbl th,
.tbl td {
  border-bottom: 1px solid var(--line);
  padding: 12px;
  text-align: left;
}
.tbl thead th {
  background: #1c1c1c;
}
.foot {
  margin-top: 10px;
  color: #cfcfcf;
  opacity: 0.9;
}

/* 푸터 */
.site-footer {
  border-top: 1px solid var(--line);
  background: #141414;
}
.site-footer .wrap {
  padding: 18px 16px;
  text-align: center;
  color: #bfbfbf;
}
