@charset "utf-8";

/* 오답노트 제외된 문제 관리 — 디자인 시스템 토큰 단일 출처.
   페이지 wrapper(.at-container)가 max-width 768 cap + padding-inline 단일 출처. 페이지 본문은 별도 좌우 패딩 X.
   페이지 상단 여백은 첫 자식(.rl-archive-header)이, 하단 여백은 .h40 spacer가 담당. */

/* section.board-list.rl-note-archive로 wrapping된 이후로는 위 여백 글로벌 룰
   (.at-content 첫 자식 mt 0 + .at-content padding-top 6px) 단일 출처에 위임 — 페이지가 별도 위 spacer X.
   좌우 padding-inline: var(--rl-sp-1) — "비카드 요소는 +4px 안쪽" 규약(카드는 페이지 좌우에 닿음). */
/* 그룹 간 간격 원칙 — 서로 다른 성격 그룹 사이 24px(sp-6). 헤더(컨텍스트) 다음에 hero·탭·리스트
   등 다른 그룹이 오므로 sp-5(20) → sp-6(24) 회수. rl_note_archive / rl_quick_archive / rl_mock_result
   3 호스트 페이지 동시 정합. ([[feedback_group_spacing_principle]]) */
.rl-archive-header {
  margin: 0 0 var(--rl-sp-6);
  padding-inline: var(--rl-sp-1);
}
.rl-archive-subject {
  font-size: var(--rl-fs-caption);
  color: var(--rl-text-4);
  margin-bottom: var(--rl-sp-1);
}
.rl-archive-header h1 {
  font-size: var(--rl-fs-h2);
  font-weight: 700;
  color: var(--rl-ink);
  letter-spacing: var(--rl-ls-h2);
  margin: 0 0 var(--rl-sp-2);
  line-height: var(--rl-lh-snug);
}
.rl-archive-header .subcopy {
  font-size: var(--rl-fs-body-sm);
  color: var(--rl-text-3);
  line-height: var(--rl-lh-normal);
  margin: 0;
}

/* 단일 상태 archive(빠른학습 숨김 등) 상단 카운트 칩 — §3.4.2 Tag/Pill 명세 정합.
   탭 형태가 어울리지 않는 단일 뷰에서 카운트 컨텍스트만 전달. 정적 표식(hover/active 없음). */
.rl-archive-summary {
  display: inline-block;
  padding: var(--rl-sp-1) var(--rl-sp-3);
  /* 그룹 간 24px 원칙 — summary 칩과 다음 그룹(리스트/탭) 사이 호흡. sp-4(14) → sp-6(24). */
  margin: 0 0 var(--rl-sp-6);
  background: var(--rl-surface-2);
  border: 1px solid var(--rl-line-2);
  border-radius: var(--rl-r-full);
  font-size: var(--rl-fs-caption);
  font-weight: 600;
  color: var(--rl-text-3);
  line-height: var(--rl-lh-snug);
}
.rl-archive-summary strong {
  color: var(--rl-text-2);
  font-weight: 700;
}

.rl-archive-tabs {
  display: flex;
  gap: var(--rl-sp-2);
  /* 칩 라벨이 긴 경우(예: 실시간 모의시험 현황 페이지의 과목 필터 "[전체] [<긴 과목명>만]")
     줄바꿈으로 안전 — 짧은 칩만 있는 형제 페이지(rl_note_archive·rl_quick_archive·rl_mock_result)는
     2-3개 칩이 항상 한 줄에 들어가 영향 0. wrap row-gap도 sp-2로 통일. */
  flex-wrap: wrap;
  row-gap: var(--rl-sp-2);
  /* 그룹 간 24px 원칙 — 탭(컨트롤) 다음에 카드 리스트(콘텐츠) 그룹. sp-5(20) → sp-6(24). */
  margin: 0 0 var(--rl-sp-6);
  padding-inline: var(--rl-sp-1);
}
.rl-archive-tabs a {
  display: inline-flex;
  align-items: center;
  gap: var(--rl-sp-2);
  padding: var(--rl-sp-2) var(--rl-sp-4);
  border-radius: var(--rl-r-full);
  font-size: var(--rl-fs-label);
  color: var(--rl-text-2);
  background: var(--rl-surface-2);
  text-decoration: none;
  transition: color var(--rl-dur-micro) var(--rl-ease);
}
.rl-archive-tabs a.active {
  background: var(--rl-text);
  color: var(--rl-surface-elev);
  font-weight: 500;
}
@media (hover: hover) {
  .rl-archive-tabs a:hover { color: var(--rl-text); }
  .rl-archive-tabs a.active:hover { color: var(--rl-surface-elev); }
}
.rl-archive-tabs a:active { color: var(--rl-text); }
.rl-archive-tabs a.active:active { color: var(--rl-surface-elev); }
.rl-archive-tab-count {
  font-size: var(--rl-fs-caption);
  font-weight: 500;
  opacity: 0.75;
}

.rl-archive-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  /* gap 대신 item margin-bottom — collapse transition 시 형제 spacing도 함께 줄어 자연스러움. */
}
.rl-archive-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--rl-sp-3);
  padding: var(--rl-sp-3) var(--rl-sp-4);
  margin-bottom: var(--rl-sp-2);
  background: var(--rl-surface-elev);
  border: 1px solid var(--rl-line-2);
  border-radius: var(--rl-r-md);
  overflow: hidden;
  max-height: 999px;
  transition:
    opacity var(--rl-dur-emph) var(--rl-ease-out),
    transform var(--rl-dur-emph) var(--rl-ease-out),
    max-height var(--rl-dur-emph) var(--rl-ease-out),
    margin-bottom var(--rl-dur-emph) var(--rl-ease-out),
    padding-top var(--rl-dur-emph) var(--rl-ease-out),
    padding-bottom var(--rl-dur-emph) var(--rl-ease-out),
    border-top-width var(--rl-dur-emph) var(--rl-ease-out),
    border-bottom-width var(--rl-dur-emph) var(--rl-ease-out);
}
.rl-archive-list > :last-child { margin-bottom: 0; }
.rl-archive-item.is-leaving,
.rl-archive-item.is-entering {
  opacity: 0;
  max-height: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-top-width: 0;
  border-bottom-width: 0;
  pointer-events: none;
}
.rl-archive-item.is-leaving { transform: translateX(var(--rl-sp-5)); }
.rl-archive-item.is-entering { transform: translateX(calc(-1 * var(--rl-sp-5))); }
/* reduced-motion 사용자는 transition 거의 즉시 종료(접근성). */
@media (prefers-reduced-motion: reduce) {
  .rl-archive-item { transition-duration: 0.01ms; }
}
.rl-archive-item-body {
  display: flex;
  flex-direction: column;
  gap: var(--rl-sp-1);
  min-width: 0;
  flex: 1;
  color: inherit;
  text-decoration: none;
}
@media (hover: hover) {
  .rl-archive-item-body:hover .preview { color: var(--rl-primary); }
}
.rl-archive-item-body:active .preview { color: var(--rl-primary); }
.rl-archive-item .preview {
  font-size: var(--rl-fs-body-sm);
  color: var(--rl-text);
  line-height: var(--rl-lh-snug);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color var(--rl-dur-micro) var(--rl-ease);
}
.rl-archive-item .sub {
  font-size: var(--rl-fs-caption);
  color: var(--rl-text-4);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rl-archive-item .actions {
  display: flex;
  flex-shrink: 0;
}
.rl-archive-item .btn-restore {
  display: inline-flex;
  align-items: center;
  padding: var(--rl-sp-2) var(--rl-sp-4);
  font-size: var(--rl-fs-label);
  font-weight: 500;
  border-radius: var(--rl-r-btn);
  border: 1px solid var(--rl-line-2);
  background: transparent;
  color: var(--rl-primary);
  cursor: pointer;
  transition: background var(--rl-dur-micro) var(--rl-ease),
              border-color var(--rl-dur-micro) var(--rl-ease),
              color var(--rl-dur-micro) var(--rl-ease);
}
@media (hover: hover) {
  .rl-archive-item .btn-restore:hover {
    background: var(--rl-surface-2);
    border-color: var(--rl-primary);
    color: var(--rl-primary-hover);
  }
}
.rl-archive-item .btn-restore:active {
  background: var(--rl-surface-2);
  border-color: var(--rl-primary);
  color: var(--rl-primary-hover);
}
.rl-archive-item .btn-restore[disabled] { opacity: 0.6; cursor: default; }

.rl-archive-empty {
  padding: var(--rl-sp-7) var(--rl-sp-6);
  text-align: center;
  background: var(--rl-surface-2);
  border: 1px dashed var(--rl-line-2);
  border-radius: var(--rl-r-md);
  color: var(--rl-text-3);
  font-size: var(--rl-fs-body-sm);
  line-height: var(--rl-lh-normal);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--rl-sp-2);
}
.rl-archive-empty__title {
  font-size: var(--rl-fs-body);
  font-weight: 600;
  color: var(--rl-text);
  margin: 0;
}
.rl-archive-empty__desc {
  font-size: var(--rl-fs-body-sm);
  color: var(--rl-text-3);
  margin: 0;
  word-break: keep-all;
  overflow-wrap: break-word;
}
.rl-archive-empty__cta {
  margin-top: var(--rl-sp-3);
  font-size: var(--rl-fs-body-sm);
  font-weight: 500;
  color: var(--rl-primary);
  text-decoration: none;
}
@media (hover: hover) {
  .rl-archive-empty__cta:hover { color: var(--rl-primary-hover); text-decoration: none; }
}
.rl-archive-empty__cta:active { color: var(--rl-primary-hover); }

/* 무한 스크롤 sentinel/상태 — 로딩 중·끝 상태 텍스트만 노출(스피너 없이 단순 텍스트).
   자식 span은 inline 기본 + [hidden] 자동 발화 — display 명시 X(브라우저 기본 [hidden]:display:none override 회귀 차단). */
.rl-archive-scroll-status {
  padding: var(--rl-sp-5) 0;
  text-align: center;
  font-size: var(--rl-fs-caption);
  color: var(--rl-text-4);
  letter-spacing: var(--rl-ls-body);
}

/* 카드 본문 button — link 시각과 동일하게 보이도록 button 기본 chrome 제거. */
.rl-archive-item-body {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  text-align: left;
  cursor: pointer;
  font: inherit;
}

/* ── 문제 보기 시트 본문 — note.php 풀이 화면과 동일 마크업(.view-content > .question + .answer-container)
   사용. 시각·간격·폰트는 learn.css `.rl-learn .view-content` 룰이 단일 출처로 담당. archive css는
   데이터 없음 폴백 + 읽기 전용 컨텍스트 마커 override만 정의. */
.rl-archive-preview__empty {
  font-size: var(--rl-fs-body-sm);
  color: var(--rl-text-3);
  text-align: center;
  margin: var(--rl-sp-6) 0;
}
/* 읽기 전용 컨텍스트 — 오답 보기 우측 빈 원(라디오 마커) 숨김. 정답 체크 마크는 유지(.answer.correct::after). */
#archive-preview-modal .rl-learn .answer-container .answer:not(.correct)::after {
  display: none;
}
