/* ═══════════════════════════════════════
   styles/components.css — 과목 카드, 빈 상태, 다운로드 배너
   ═══════════════════════════════════════ */

/* 과목 카드 */
.subject-card {
  background: #fff;
  border: 1px solid var(--paper-edge);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 10px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .03);
}

.subject-card-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid rgba(44, 36, 22, .06);
  padding-bottom: 6px;
  margin-bottom: 8px;
}

.subject-card-name {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: .9rem;
  color: var(--ink);
}

.subject-card-score {
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 600;
  color: var(--accent);
}

.imagination-box {
  background: var(--accent-glow);
  border: 1px solid rgba(184, 146, 46, .2);
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 8px;
  min-height: 60px;
}

.imagination-box .imag-label {
  font-family: var(--font-sans);
  font-size: .6rem;
  font-weight: 600;
  color: var(--accent);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.imagination-box .imag-text {
  font-family: var(--font-sans);
  font-size: .7rem;
  color: var(--ink-light);
  line-height: 1.75;
  word-break: keep-all;
}

.gap-detail {
  font-family: var(--font-sans);
  font-size: .72rem;
  color: var(--ink);
  font-weight: 500;
  padding: 0 2px;
  margin-bottom: 6px;
  line-height: 1.6;
  word-break: keep-all;
}

.plan-box {
  background: rgba(244, 240, 230, .5);
  border: 1px solid var(--paper-edge);
  border-radius: 6px;
  padding: 10px 12px;
  font-family: var(--font-sans);
  font-size: .7rem;
  color: var(--ink-light);
  line-height: 1.75;
  word-break: keep-all;
}

/* 빈 상태 */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 250px;
  color: var(--ink-faint);
  text-align: center;
}

.empty-icon {
  font-size: 2.5rem;
  margin-bottom: 14px;
  opacity: .5;
  display: none
}

.empty-state p {
  font-family: var(--font-sans);
  font-size: .78rem;
  margin-bottom: 2px;
  text-align: center;
}

/* 다운로드 배너 */
.download-banner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--accent-glow);
  border: 1px solid rgba(184, 146, 46, .25);
  border-radius: 8px;
  padding: 14px 16px;
  margin-top: 16px;
}

.download-banner span {
  font-family: var(--font-sans);
  font-size: .78rem;
  font-weight: 600;
  color: var(--accent);
}

.dl-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border: none;
  border-radius: 20px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(122, 92, 30, .2);
  transition: all .2s;
}

.dl-btn:hover {
  background: var(--cover)
}

.dl-btn:disabled {
  opacity: .5;
  cursor: not-allowed
}