/* nodong.css — 노동인권교육 (Phase 5) */

/* ── layout: 사이드바 + 본문 ───────────────────────────────── */
.nodong-shell {
  display: grid;
  grid-template-columns: minmax(220px, 260px) 1fr;
  gap: var(--space-6);
  align-items: start;
  max-width: var(--container-lg);
  margin: 0 auto;
  padding: var(--space-4) var(--space-6);
}
.nodong-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: sticky;
  top: var(--space-4);
  min-width: 0;
}
.nodong-main { min-width: 0; }
@media (max-width: 1023.98px) {
  .nodong-shell {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .nodong-sidebar {
    position: static;
    order: -1;
  }
}
.nodong-page { padding-bottom: var(--space-12); }

/* ── 사이드 메뉴 (다단: 그룹 + 하위 링크) ─────────────────── */
.nodong-side-nav {
  padding: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.nodong-side-nav__site {
  margin: 0 0 var(--space-3);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
}
.nodong-side-nav__site a {
  color: var(--color-fg);
  text-decoration: none;
}
.nodong-side-nav__site a:hover { color: var(--color-primary); }
.nodong-side-nav__root {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.nodong-side-nav__group {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.nodong-side-nav__label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--color-fg-muted);
  letter-spacing: var(--letter-wide);
  margin-bottom: var(--space-2);
}
.nodong-side-nav__group--admin .nodong-side-nav__label {
  color: var(--color-accent-soft-fg);
}
.nodong-side-nav__sub {
  list-style: none;
  margin: 0;
  padding: 0 0 0 var(--space-3);
  border-left: 2px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.nodong-side-nav__link,
.nodong-side-nav__sublink {
  display: block;
  padding: var(--space-2) var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-fg-muted);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: background var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}
.nodong-side-nav__link:hover,
.nodong-side-nav__sublink:hover {
  background: var(--color-bg);
  color: var(--color-fg);
}
.nodong-side-nav__link.is-active,
.nodong-side-nav__sublink.is-active {
  background: var(--color-primary-soft);
  color: var(--color-primary-soft-fg);
  font-weight: var(--fw-semibold);
}

/* ── hero ────────────────────────────────────────────────── */
.nodong-hero { margin-bottom: var(--space-6); }
.nodong-hero__title { font-size: var(--fs-2xl); font-weight: var(--fw-bold); color: var(--color-fg); }
.nodong-hero__dept { font-size: var(--fs-sm); color: var(--color-fg-muted); }
.nodong-hero__lead { font-size: var(--fs-base); color: var(--color-fg-muted); margin-top: var(--space-1); }

/* ── aside ───────────────────────────────────────────────── */
.nodong-aside { display: flex; flex-direction: column; gap: var(--space-4); }
.nodong-aside__section {
  padding: var(--space-4); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
}
.nodong-aside__title { font-size: var(--fs-sm); font-weight: var(--fw-semibold); margin-bottom: var(--space-2); }
.nodong-aside__links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-1); }
.nodong-aside__links a { font-size: var(--fs-sm); color: var(--color-primary); text-decoration: none; }
.nodong-aside__links a:hover { text-decoration: underline; }

/* ── material cards ─────────────────────────────────────── */
.material-grade-tabs { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); }
.material-grade-tab {
  padding: var(--space-1) var(--space-3); font-size: var(--fs-sm);
  border: 1px solid var(--color-border); border-radius: var(--radius-full);
  text-decoration: none; color: var(--color-fg-muted);
  transition: background var(--duration-fast);
}
.material-grade-tab.is-active { background: var(--color-primary); color: var(--color-on-dark); border-color: var(--color-primary); }
.material-list { display: flex; flex-direction: column; gap: var(--space-3); }
.material-card {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4); background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  gap: var(--space-3);
}
.material-card__title { font-weight: var(--fw-medium); color: var(--color-fg); margin-bottom: var(--space-1); }
.material-card__meta { display: flex; flex-wrap: wrap; gap: var(--space-1); }
.material-card__download { white-space: nowrap; flex-shrink: 0; }
.nodong-empty { padding: var(--space-8); text-align: center; color: var(--color-fg-muted); }

/* ── flash ───────────────────────────────────────────────── */
.nodong-flash {
  padding: var(--space-3) var(--space-5); border-radius: var(--radius-md);
  font-size: var(--fs-sm); border-left: 3px solid;
  margin: var(--space-2) 0;
}
.nodong-flash--success { background: var(--color-success-soft); color: var(--color-success); border-left-color: var(--color-success); }
.nodong-flash--danger  { background: var(--color-danger-soft);  color: var(--color-danger);  border-left-color: var(--color-danger); }
.nodong-flash--info    { background: var(--color-info-soft);    color: var(--color-info-active); border-left-color: var(--color-info-active); }
.nodong-flash--err     { background: var(--color-danger-soft);  color: var(--color-danger);  border-left-color: var(--color-danger); }

/* ── apply forms ─────────────────────────────────────────── */
.nodong-apply-wrap { max-width: var(--container-sm); margin: 0 auto; padding: var(--space-4) var(--space-6); }
.apply-batch-list { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-4); }
.apply-batch-card {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-4); border: 2px solid var(--color-border);
  border-radius: var(--radius-md); cursor: pointer; transition: border-color var(--duration-fast);
}
.apply-batch-card:has(input:checked) { border-color: var(--color-primary); background: var(--color-primary-soft); }
.apply-batch-card.is-full { opacity: .5; cursor: not-allowed; }
.apply-batch-card input[type=radio] { position: absolute; opacity: 0; }
.apply-batch-card__info { display: flex; align-items: center; gap: var(--space-2); font-weight: var(--fw-medium); }
.apply-result-card {
  padding: var(--space-5); background: var(--color-success-soft);
  border: 1px solid var(--color-success); border-radius: var(--radius-md); margin-top: var(--space-6);
}
.apply-cancel-pin { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-3) 0; }
.apply-cancel-pin__value { font-family: var(--font-mono); font-size: var(--fs-xl); letter-spacing: .2em; background: var(--color-bg); padding: var(--space-1) var(--space-3); border-radius: var(--radius-md); }
.apply-cancel-pin__note { font-size: var(--fs-xs); color: var(--color-warn); }
.apply-history-table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.apply-history-table th, .apply-history-table td { padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--color-border); }
.apply-history-row.is-cancelled { opacity: .5; text-decoration: line-through; }
.apply-empty { padding: var(--space-6); text-align: center; color: var(--color-fg-muted); }

/* ── certificate ─────────────────────────────────────────── */
.cert-card {
  padding: var(--space-5); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  display: flex; flex-direction: column; gap: var(--space-2);
}
.cert-status-chip { display: inline-block; padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); font-size: var(--fs-xs); font-weight: var(--fw-semibold); }
.cert-status-chip--pending  { background: var(--color-warn-soft);    color: var(--color-warn); }
.cert-status-chip--approved { background: var(--color-info-soft);    color: var(--color-info-active); }
.cert-status-chip--issued   { background: var(--color-success-soft); color: var(--color-success); }
.cert-status-chip--rejected { background: var(--color-danger-soft);  color: var(--color-danger); }
.cert-pwd-display {
  padding: var(--space-5); background: var(--color-success-soft);
  border: 1px solid var(--color-success); border-radius: var(--radius-md); margin-top: var(--space-4);
}

/* ── submit zone ─────────────────────────────────────────── */
.submit-zone {
  border: 2px dashed var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-8); text-align: center; cursor: pointer;
  transition: border-color var(--duration-fast), background var(--duration-fast);
  margin: var(--space-3) 0;
}
.submit-zone.is-dragover { border-color: var(--color-primary); background: var(--color-primary-soft); }
.submit-file-preview { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-3); }

/* ── related-link rows ───────────────────────────────────── */
.related-link-row { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) 0; }
.related-link-row__handle { cursor: grab; color: var(--color-fg-subtle); }

/* ── nodong-search-form ──────────────────────────────────── */
.nodong-search-form { display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: flex-end; margin-bottom: var(--space-6); }
.nodong-cert-form { display: grid; gap: var(--space-3); max-width: 480px; }

/* ── share-token 게스트 모드 banner (Phase 9 #9) ────────── */
.nodong-guest-banner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  margin: 0 auto var(--space-5);
  max-width: var(--container-lg);
  background: var(--color-warn-soft);
  border: 1px solid var(--color-warn);
  border-left: 4px solid var(--color-warn);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  font-size: var(--fs-sm);
}
.nodong-guest-banner__icon {
  flex-shrink: 0;
  font-size: var(--fs-lg);
  line-height: 1;
}
.nodong-guest-banner__body { flex: 1; }
.nodong-guest-banner__title {
  display: block;
  font-weight: 600;
  margin-bottom: var(--space-1);
  color: var(--color-warn);
}
.nodong-guest-banner__expires {
  display: inline-block;
  margin-left: var(--space-2);
  padding: 0 var(--space-2);
  font-size: var(--fs-xs);
  font-family: var(--font-mono);
  color: var(--color-fg-muted);
  background: var(--color-bg);
  border-radius: var(--radius-sm);
}

/* ── @media print ───────────────────────────────────────── */
@media print {
  .nodong-sidebar, .site-header, .site-footer { display: none !important; }
  .nodong-page, .nodong-shell, .nodong-main { padding: 0 !important; }
  body { color: #000 !important; background: #fff !important; }
}
