/* ══════════════════════════════════════════════════════
   FAQ PAGE
   파일: /faq.php
══════════════════════════════════════════════════════ */
.faq-eyebrow {
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: 10px;
}

.faq-headline {
  font-size: var(--fs-page-title);
  font-weight: 900;
  color: var(--clr-text);
  letter-spacing: -0.5px;
  line-height: var(--lh-tight);
  margin-bottom: 8px;
}

.faq-subhead {
  font-size: var(--fs-body);
  color: var(--clr-text-muted);
  line-height: var(--lh-readable);
  margin-bottom: 36px;
}

/* 카테고리 탭 */
.faq-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  border-bottom: 2px solid var(--clr-border);
  margin-bottom: 32px;
}

.faq-tab {
  padding: 10px 18px;
  font-size: var(--fs-ui);
  font-weight: 600;
  color: var(--clr-text-muted);
  cursor: pointer;
  border: none;
  background: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  font-family: inherit;
  transition: color var(--transition), border-color var(--transition);
}

.faq-tab:hover {
  color: var(--clr-primary);
}

.faq-tab.is-active {
  color: var(--clr-primary);
  border-bottom-color: var(--clr-primary);
}

/* 섹션 */
.faq-section {
  display: none;
}

.faq-section.is-visible {
  display: block;
}

.faq-cat-block {
  margin-bottom: 40px;
}

.faq-cat-block:last-child {
  margin-bottom: 0;
}

.faq-cat-title {
  font-size: var(--fs-caption);
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-bottom: 10px;
}

/* 아코디언 */
.faq-item {
  border-bottom: 1px solid var(--clr-border);
}

.faq-item:first-child {
  border-top: 1px solid var(--clr-border);
}

.faq-item summary {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 4px;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-q-mark {
  font-size: var(--fs-em);
  font-weight: 900;
  color: var(--clr-primary);
  flex-shrink: 0;
  width: 22px;
  text-align: center;
}

.faq-q-text {
  flex: 1;
  font-size: var(--fs-body);
  font-weight: 650;
  color: var(--clr-text);
  line-height: var(--lh-base);
}

.faq-chev {
  flex-shrink: 0;
  color: var(--clr-text-muted);
  transition: transform var(--transition);
}

.faq-item[open] .faq-chev {
  transform: rotate(180deg);
}

.faq-item[open] .faq-q-text {
  color: var(--clr-primary);
}

.faq-answer {
  display: flex;
  gap: 14px;
  padding: 4px 4px 20px;
}

.faq-a-mark {
  font-size: var(--fs-em);
  font-weight: 900;
  color: var(--clr-text-muted);
  flex-shrink: 0;
  width: 22px;
  text-align: center;
}

.faq-a-text {
  flex: 1;
  font-size: var(--fs-body);
  color: var(--clr-text-sub);
  line-height: var(--lh-docs);
}

.faq-empty {
  padding: 60px 0;
  text-align: center;
  color: var(--clr-text-muted);
  font-size: var(--fs-small);
}

.faq-empty a {
  color: var(--clr-primary);
}

@media (max-width: 600px) {
  .faq-tab {
    padding: 9px 12px;
    font-size: var(--fs-small);
  }

  .faq-q-text,
  .faq-a-text {
    font-size: var(--fs-body);
  }

  .faq-q-mark,
  .faq-a-mark {
    font-size: var(--fs-lead);
    width: 20px;
  }
}

/* ══════════════════════════════════════════════════════
   PRICING PAGE
   파일: /pricing.php
══════════════════════════════════════════════════════ */
/* ── 요금제 비교 테이블 ── */
.pc-wrap {
  border: 1px solid #dde3ea;
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}

/* 3열 그리드: 기능명 | 무료 | 유료 */
.pc-row {
  display: grid;
  grid-template-columns: 1fr 168px 168px;
}

.pc-row + .pc-row {
  border-top: 1px solid #eef0f3;
}

.pc-row:nth-child(odd):not(.pc-head):not(.pc-section):not(.pc-cta-row) {
  background: #f8fafc;
}

/* 헤더 */
.pc-head {
  background: #fff;
}

.pc-head-label {
  padding: 24px 22px;
}

.pc-head-free {
  padding: 24px 16px;
  text-align: center;
  border-left: 1px solid #eef0f3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  background: #f8fafc;
}

.pc-head-paid {
  padding: 24px 16px;
  text-align: center;
  border-left: 1px solid rgba(255,255,255,.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  background: var(--clr-primary);
  color: #fff;
}

.pc-plan-name {
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #999;
}

.pc-head-paid .pc-plan-name {
  color: rgba(255,255,255,.7);
}

.pc-price {
  font-size: var(--fs-h1);
  font-weight: 900;
  color: #1a1a1a;
  line-height: 1;
  margin-top: 2px;
}

.pc-head-paid .pc-price {
  color: #fff;
}

.pc-price-unit {
  font-size: var(--fs-caption);
  font-weight: 500;
  color: #999;
}

.pc-head-paid .pc-price-unit {
  color: rgba(255,255,255,.6);
}

.pc-price-note {
  font-size: var(--fs-xs);
  color: #bbb;
  margin-top: 2px;
}

.pc-head-paid .pc-price-note {
  color: rgba(255,255,255,.55);
}

.pc-badge-current {
  margin-top: 8px;
  font-size: var(--fs-xs);
  font-weight: 700;
  background: rgba(255,255,255,.25);
  color: #fff;
  padding: 3px 10px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.4);
}

.pc-head-free .pc-badge-current {
  background: var(--clr-primary);
  color: #fff;
  border: none;
}

/* 섹션 구분 행 */
.pc-section {
  background: #f0f4f8 !important;
  border-top: 1px solid #dde3ea !important;
}

.pc-section-lbl {
  padding: 7px 22px;
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #8a96a3;
  grid-column: 1 / -1;
}

/* 일반 셀 */
.pc-cell {
  padding: 14px 16px;
  display: flex;
  align-items: center;
}

.pc-cell-free {
  border-left: 1px solid #eef0f3;
  justify-content: center;
  background: transparent;
}

.pc-cell-paid {
  border-left: 1px solid #c8daea;
  justify-content: center;
  background: #eaf2fb;
}

/* 기능명 */
.pc-feat-name {
  font-size: var(--fs-small);
  font-weight: 600;
  color: #2c3e50;
}

.pc-feat-sub {
  font-size: var(--fs-xs);
  color: #8a96a3;
  margin-top: 2px;
  font-weight: 400;
}

/* 셀 값 */
.pc-val {
  font-size: var(--fs-small);
  font-weight: 700;
  color: #2c3e50;
  text-align: center;
}

.pc-val-sub {
  font-size: var(--fs-xs);
  color: #8a96a3;
  text-align: center;
  margin-top: 2px;
}

.pc-val-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* 체크 / 대시 */
.pc-check {
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pc-dash {
  color: #c5cdd6;
  font-size: var(--fs-h2);
  font-weight: 300;
  line-height: 1;
}

/* CTA 행 */
.pc-cta-row {
  background: #fff !important;
  border-top: 2px solid #dde3ea;
}

.pc-cta-free {
  padding: 18px 16px;
  border-left: 1px solid #eef0f3;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pc-cta-paid {
  padding: 18px 16px;
  border-left: 1px solid #c8daea;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #eaf2fb;
}

/* 구독 기간 카드 */
.period-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 48px;
}

.period-card {
  border: 1px solid #dde3ea;
  border-radius: 10px;
  padding: 16px 10px;
  text-align: center;
  background: #fff;
}

.period-months {
  font-size: var(--fs-caption);
  font-weight: 700;
  color: #666;
  margin-bottom: 6px;
}

.period-price {
  font-size: var(--fs-em);
  font-weight: 800;
  color: #1a1a1a;
  margin-bottom: 5px;
}

.period-badge {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 700;
  background: #fff3cd;
  color: #856404;
  padding: 2px 8px;
  border-radius: 8px;
}

/* 반응형 */
@media (max-width: 680px) {
  .pc-row {
    grid-template-columns: 1fr 104px 104px;
  }

  .pc-cell {
    padding: 12px 10px;
  }

  .pc-head-free,
  .pc-head-paid {
    padding: 16px 8px;
  }

  .pc-price {
    font-size: var(--fs-h2);
  }

  .pc-plan-name {
    letter-spacing: 1px;
  }

  .pc-feat-name {
    font-size: var(--fs-caption);
  }

  .pc-val {
    font-size: var(--fs-caption);
  }

  .pc-section-lbl {
    padding: 6px 12px;
  }

  .pc-cta-free,
  .pc-cta-paid {
    padding: 12px 8px;
  }
}

@media (max-width: 460px) {
  .pc-row {
    grid-template-columns: 1fr 84px 84px;
  }

  .pc-cell {
    padding: 11px 8px;
  }

  .pc-head-free,
  .pc-head-paid {
    padding: 14px 6px;
  }

  .pc-price {
    font-size: var(--fs-lead);
  }

  .pc-price-note {
    display: none;
  }

  .pc-feat-name {
    font-size: var(--fs-xs);
  }

  .pc-feat-sub {
    font-size: var(--fs-xs);
  }

  .pc-val {
    font-size: var(--fs-xs);
  }

  .pc-val-sub {
    font-size: var(--fs-xs);
  }

  .pc-cta-btn {
    font-size: var(--fs-xs) !important;
    padding: 6px 4px !important;
  }

  .period-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ══════════════════════════════════════════════════════
   ABOUT PAGE
   파일: /about.php
   설명: 서비스 소개, 핵심 기능 카드, 애드온 안내, 히스토리 타임라인
══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   About Hero
───────────────────────────────────────────────────── */
.about-eyebrow {
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: 16px;
}

.about-headline {
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 900;
  color: var(--clr-text);
  line-height: var(--lh-tight);
  letter-spacing: -1px;
  margin-bottom: 8px;
}

.about-subhead {
  font-size: var(--fs-em);
  color: var(--clr-text-muted);
  font-weight: 400;
  line-height: var(--lh-readable);
  margin-bottom: 32px;
}

.about-desc {
  font-size: var(--fs-body);
  color: var(--clr-text-sub);
  line-height: var(--lh-docs);
  margin-bottom: 48px;
  border-left: 3px solid var(--clr-primary);
  padding-left: 18px;
}

/* ─────────────────────────────────────────────────────
   About Feature Cards
───────────────────────────────────────────────────── */
.about-features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 64px;
}

.about-feat {
  border: 1px solid var(--clr-border-light);
  border-radius: 10px;
  padding: 20px;
  background: #fff;
  display: flex;
  flex-direction: column;
}

.about-feat--highlight {
  border-color: var(--clr-primary);
  border-top-width: 3px;
}

.about-feat-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--clr-primary-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  color: var(--clr-primary);
  flex-shrink: 0;
}

.about-feat--highlight .about-feat-icon {
  background: var(--clr-primary);
  color: #fff;
}

.about-feat-title {
  font-size: var(--fs-small);
  font-weight: 700;
  color: var(--clr-text);
  margin-bottom: 5px;
}

.about-feat-desc {
  font-size: var(--fs-caption);
  color: var(--clr-text-muted);
  line-height: var(--lh-base);
  flex: 1;
}

.about-clean-badge {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--clr-primary);
  background: var(--clr-primary-bg);
  border-radius: 6px;
  padding: 5px 8px;
  line-height: 1.3;
}

.about-clean-badge svg {
  flex-shrink: 0;
}

/* ─────────────────────────────────────────────────────
   About Divider
───────────────────────────────────────────────────── */
.about-divider {
  height: 1px;
  background: var(--clr-border);
  margin: 0 0 56px;
}

/* ─────────────────────────────────────────────────────
   About Addons
───────────────────────────────────────────────────── */
.about-section-title {
  font-size: clamp(21px, 3vw, 28px);
  font-weight: 800;
  color: var(--clr-text);
  line-height: var(--lh-heading);
  margin-bottom: 8px;
  letter-spacing: -0.5px;
}

.about-section-desc {
  font-size: var(--fs-body);
  color: var(--clr-text-muted);
  margin-bottom: 32px;
  line-height: var(--lh-readable);
}

.about-addons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 64px;
}

.about-addon-group {
  border: 1px solid var(--clr-border-light);
  border-radius: 12px;
  padding: 24px;
  background: #fff;
}

.about-addon-group-label {
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-bottom: 4px;
}

.about-addon-group-title {
  font-size: var(--fs-ui);
  font-weight: 800;
  color: var(--clr-text);
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--clr-border-light);
}

.about-addon-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.about-addon-item {
  display: flex;
  gap: 11px;
  align-items: flex-start;
}

.about-addon-icon {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: var(--clr-primary-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-primary);
  flex-shrink: 0;
  margin-top: 1px;
}

.about-addon-name {
  font-size: var(--fs-small);
  font-weight: 700;
  color: var(--clr-text);
  margin-bottom: 2px;
}

.about-addon-desc {
  font-size: var(--fs-caption);
  color: var(--clr-text-muted);
  line-height: var(--lh-base);
}

/* ─────────────────────────────────────────────────────
   About History Timeline
───────────────────────────────────────────────────── */
.hy-eyebrow {
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: 40px;
}

.hy-year {
  margin-bottom: 48px;
}

.hy-year-head {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.hy-year-num {
  font-size: 44px;
  font-weight: 900;
  color: var(--clr-primary);
  letter-spacing: -3px;
  line-height: 1;
  flex-shrink: 0;
}

.hy-year-rule {
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, var(--clr-primary), var(--clr-border));
}

.hy-month {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 0 20px;
  padding: 10px 0;
  border-top: 1px solid #f5f5f5;
}

.hy-month:first-child {
  border-top: none;
}

.hy-month-name {
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--clr-text-muted);
  padding-top: 3px;
  text-align: right;
  line-height: var(--lh-base);
}

.hy-event {
  display: flex;
  gap: 12px;
  align-items: baseline;
  line-height: var(--lh-readable);
  padding: 2px 0;
}

.hy-day {
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--clr-primary);
  flex-shrink: 0;
  width: 28px;
  text-align: right;
  padding-top: 2px;
  letter-spacing: 0.3px;
}

.hy-content {
  font-size: var(--fs-ui);
  color: var(--clr-text-sub);
  flex: 1;
}

.hy-empty {
  color: var(--clr-text-muted);
  font-size: var(--fs-small);
  padding: 24px 0;
}

/* ─────────────────────────────────────────────────────
   About Responsive
───────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .about-features {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 700px) {
  .about-addons {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 540px) {
  .about-features {
    grid-template-columns: 1fr;
  }

  .hy-year-num {
    font-size: 34px;
  }

  .hy-month {
    grid-template-columns: 36px 1fr;
    gap: 0 12px;
  }

  .hy-month-name {
    font-size: var(--fs-xs);
  }

  .hy-content {
    font-size: var(--fs-small);
  }
}


/* ══════════════════════════════════════════════════════
   CONTACT PAGE
   파일: /contact.php
   설명: 문의하기, 환불 문의, 첨부 안내
══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   Contact Intro
───────────────────────────────────────────────────── */
.contact-intro {
  text-align: center;
  margin-bottom: 36px;
}

.contact-intro h1 {
  font-size: var(--fs-h1);
  font-weight: 800;
  color: var(--clr-text);
  margin-bottom: 8px;
  letter-spacing: -0.5px;
  line-height: var(--lh-heading);
}

.contact-intro p {
  font-size: var(--fs-ui);
  color: var(--clr-text-muted);
  line-height: var(--lh-readable);
}

/* ─────────────────────────────────────────────────────
   Contact Form Card
───────────────────────────────────────────────────── */
.contact-card {
  background: #fff;
  border: 1px solid var(--clr-border-light);
  border-radius: 12px;
  padding: 32px 28px;
}

.contact-card .form-group {
  margin-bottom: 18px;
}

.contact-card label {
  display: block;
  font-size: var(--fs-caption);
  font-weight: 700;
  color: var(--clr-text-label);
  margin-bottom: 6px;
}

.contact-card .req {
  color: var(--clr-danger);
  margin-left: 2px;
}

.contact-card input[type=text],
.contact-card input[type=email],
.contact-card input[type=date],
.contact-card input[type=number],
.contact-card select,
.contact-card textarea {
  width: 100%;
  padding: 10px 13px;
  border: 1px solid var(--clr-border-input);
  border-radius: 7px;
  font-size: var(--fs-small);
  font-family: inherit;
  color: var(--clr-text);
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
}

.contact-card input:focus,
.contact-card select:focus,
.contact-card textarea:focus {
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px var(--clr-primary-focus);
}

.contact-card textarea {
  resize: vertical;
  min-height: 140px;
  line-height: var(--lh-readable);
}

.contact-or {
  text-align: center;
  margin-top: 24px;
  font-size: var(--fs-caption);
  color: var(--clr-text-muted);
}

.contact-or a {
  color: var(--clr-primary);
}

/* ─────────────────────────────────────────────────────
   Contact Refund Section
───────────────────────────────────────────────────── */
.refund-section {
  display: none;
  margin-top: 4px;
  padding: 18px 20px;
  background: #fffbf0;
  border: 1px solid #f0d080;
  border-radius: 10px;
}

.refund-section.is-visible {
  display: block;
}

.refund-section .refund-title {
  font-size: var(--fs-caption);
  font-weight: 800;
  color: #a07000;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.refund-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 16px;
}

.refund-notice {
  font-size: var(--fs-caption);
  color: #666;
  background: #fff;
  border: 1px solid #e2c860;
  border-radius: 7px;
  padding: 12px 14px;
  margin-top: 4px;
  line-height: var(--lh-readable);
}

.refund-notice strong {
  color: #a07000;
}

.file-hint {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: 4px;
}

/* ─────────────────────────────────────────────────────
   Contact Responsive
───────────────────────────────────────────────────── */
@media (max-width: 540px) {
  .refund-grid {
    grid-template-columns: 1fr;
  }

  .contact-card {
    padding: 20px 16px;
  }
}

/* ══════════════════════════════════════════════════════
   NOTICE PAGE
   파일: /notice.php
   설명: 공지사항 목록, 상세 보기, 이전/다음 공지 네비게이션
══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   Notice List
───────────────────────────────────────────────────── */
.notice-eyebrow {
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: 10px;
}

.notice-headline {
  font-size: var(--fs-page-title);
  font-weight: 900;
  color: var(--clr-text);
  letter-spacing: -0.5px;
  line-height: var(--lh-tight);
  margin-bottom: 32px;
}

.notice-table {
  width: 100%;
  border-collapse: collapse;
}

.notice-table th {
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--clr-text-muted);
  padding: 10px 14px;
  border-bottom: 2px solid var(--clr-border);
  text-align: left;
  white-space: nowrap;
}

.notice-table th:last-child {
  text-align: right;
}

.notice-table td {
  padding: 15px 14px;
  border-bottom: 1px solid #f5f5f5;
  font-size: var(--fs-small);
  color: var(--clr-text);
}

.notice-table td:last-child {
  text-align: right;
  white-space: nowrap;
}

.notice-table tr:hover td {
  background: #fafcff;
}

.notice-table a {
  color: var(--clr-text);
  font-weight: 600;
}

.notice-table a:hover {
  color: var(--clr-primary);
}

.notice-empty {
  text-align: center;
  padding: 60px 0;
  color: var(--clr-text-muted);
  font-size: var(--fs-small);
}

.notice-date {
  color: var(--clr-text-muted);
  font-size: var(--fs-caption);
}

/* ─────────────────────────────────────────────────────
   Notice Detail
───────────────────────────────────────────────────── */
.notice-breadcrumb {
  font-size: var(--fs-caption);
  color: var(--clr-text-muted);
  margin-bottom: 24px;
}

.notice-breadcrumb a {
  color: var(--clr-primary);
}

.notice-breadcrumb span {
  margin: 0 6px;
}

.notice-view-title {
  font-size: clamp(21px, 3.5vw, 30px);
  font-weight: 800;
  color: var(--clr-text);
  letter-spacing: -0.3px;
  margin-bottom: 8px;
  line-height: var(--lh-heading);
}

.notice-view-meta {
  font-size: var(--fs-caption);
  color: var(--clr-text-muted);
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--clr-border);
}

.notice-view-body {
  font-size: var(--fs-body);
  color: var(--clr-text-sub);
  line-height: 1.95;
  margin-bottom: 48px;
}

.notice-view-body a {
  color: var(--clr-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ─────────────────────────────────────────────────────
   Notice Navigation
───────────────────────────────────────────────────── */
.notice-nav {
  border-top: 1px solid var(--clr-border);
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 24px;
}

.notice-nav-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 13px 0;
  border-bottom: 1px solid #f5f5f5;
  font-size: var(--fs-small);
}

.notice-nav-label {
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--clr-primary);
  width: 32px;
  flex-shrink: 0;
  text-transform: uppercase;
}

.notice-nav-row a {
  color: var(--clr-text);
  flex: 1;
}

.notice-nav-row a:hover {
  color: var(--clr-primary);
}

.notice-nav-row.disabled {
  color: var(--clr-text-muted);
}

.notice-nav-empty {
  color: var(--clr-text-muted);
}

.notice-back {
  font-size: var(--fs-caption);
  color: var(--clr-primary);
}

/* ─────────────────────────────────────────────────────
   Pagination
───────────────────────────────────────────────────── */
.pagination {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-top: 32px;
}

.pagination a,
.pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 8px;
  border: 1px solid var(--clr-border);
  border-radius: 6px;
  font-size: var(--fs-caption);
  color: var(--clr-text-sub);
}

.pagination a:hover {
  border-color: var(--clr-primary);
  color: var(--clr-primary);
}

.pagination .cur {
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  color: #fff;
  font-weight: 700;
}

/* ══════════════════════════════════════════════════════
   CHECK PAGE
   파일: /check.php
   설명: 링크 안전검사, 리다이렉트 체인 추적, Google Web Risk 검사 결과
══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   Check Layout
───────────────────────────────────────────────────── */
.check-wrap {
  padding: 32px 0 48px;
}

/* ─────────────────────────────────────────────────────
   Check Header
───────────────────────────────────────────────────── */
.check-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}

.check-icon-wrap {
  width: 52px;
  height: 52px;
  background: var(--clr-primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.check-title {
  font-size: var(--fs-h2);
  font-weight: 800;
  color: var(--clr-text);
  margin-bottom: 3px;
  line-height: var(--lh-heading);
}

.check-subtitle {
  font-size: var(--fs-caption);
  color: var(--clr-text-muted);
}

/* ─────────────────────────────────────────────────────
   Check Input Form
───────────────────────────────────────────────────── */
.check-form-card {
  border: 1.5px solid #d0dde8;
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 24px;
  background: #fff;
}

.check-input-row {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.check-input-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  border: 1.5px solid var(--clr-border-input);
  border-radius: 8px;
  padding: 0 14px;
  gap: 10px;
  transition: border-color 0.18s, box-shadow 0.18s;
  background: #fff;
  min-width: 0;
}

.check-input-wrap:focus-within {
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px var(--clr-primary-focus);
}

.check-input-wrap input {
  flex: 1;
  border: none;
  outline: none;
  font-size: var(--fs-small);
  padding: 13px 0;
  background: transparent;
  min-width: 0;
  color: var(--clr-text);
}

.check-input-wrap input::placeholder {
  color: #bbb;
}

.check-submit-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 22px;
  background: var(--clr-primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: var(--fs-small);
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  font-family: inherit;
  transition: background 0.18s;
  height: 50px;
}

.check-submit-btn:hover {
  background: var(--clr-primary-dark);
}

/* ─────────────────────────────────────────────────────
   Check Result
───────────────────────────────────────────────────── */
.check-result {
  margin-bottom: 24px;
}

.check-final-box {
  border-radius: 10px;
  padding: 18px 20px;
  margin-bottom: 16px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.check-final-box.safe {
  background: var(--clr-success-bg);
  border: 1px solid var(--clr-success-border);
}

.check-final-box.unsafe {
  background: var(--clr-danger-bg);
  border: 1px solid var(--clr-danger-border);
}

.check-final-icon {
  flex-shrink: 0;
  margin-top: 1px;
}

.check-final-label {
  font-size: var(--fs-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--clr-text-muted);
  margin-bottom: 4px;
}

.check-final-url {
  font-size: var(--fs-caption);
  font-weight: 600;
  word-break: break-all;
  color: var(--clr-success-text);
}

.check-final-url.unsafe {
  color: var(--clr-danger-text);
}

.check-threat-tag {
  display: inline-block;
  margin-top: 6px;
  padding: 2px 10px;
  background: var(--clr-danger);
  color: #fff;
  border-radius: 4px;
  font-size: var(--fs-xs);
  font-weight: 700;
}

.check-result-note {
  font-size: var(--fs-xs);
  color: var(--clr-text-sub);
  margin-top: 5px;
}

.check-result-note.unsafe {
  color: var(--clr-danger-text);
  margin-top: 8px;
}

/* ─────────────────────────────────────────────────────
   Check Redirect Chain
───────────────────────────────────────────────────── */
.check-chain-card {
  border: 1px solid var(--clr-border-light);
  border-radius: 10px;
  overflow: hidden;
}

.check-chain-title {
  font-size: var(--fs-caption);
  font-weight: 700;
  color: var(--clr-text-sub);
  padding: 12px 16px;
  background: var(--clr-surface);
  border-bottom: 1px solid var(--clr-border-light);
  display: flex;
  align-items: center;
  gap: 7px;
}

.check-hop-row {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  gap: 12px;
  border-bottom: 1px solid #f0f0f0;
  font-size: var(--fs-caption);
}

.check-hop-row:last-child {
  border-bottom: none;
}

.check-hop-step {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--clr-primary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.check-hop-step.final {
  background: var(--clr-success-text);
}

.check-hop-url {
  flex: 1;
  color: var(--clr-text-label);
  word-break: break-all;
  min-width: 0;
}

.check-hop-url a {
  color: var(--clr-primary);
  text-decoration: none;
}

.check-hop-url a:hover {
  text-decoration: underline;
}

.check-hop-host {
  font-size: var(--fs-xs);
  color: #999;
  margin-top: 1px;
}

.check-hop-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.check-hop-ms {
  font-size: var(--fs-xs);
  color: #aaa;
  white-space: nowrap;
}

.check-hop-arrow {
  font-size: var(--fs-xs);
  color: #aaa;
  flex-shrink: 0;
}

/* ─────────────────────────────────────────────────────
   Check Guide
───────────────────────────────────────────────────── */
.check-guide {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border-light);
  border-radius: 10px;
  padding: 20px;
  margin-top: 24px;
}

.check-guide-title {
  font-size: var(--fs-caption);
  font-weight: 700;
  color: var(--clr-text-sub);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 7px;
}

.check-guide-steps {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.check-guide-step {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--fs-caption);
  color: var(--clr-text-sub);
  line-height: var(--lh-base);
}

.check-guide-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--clr-primary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

.check-guide-num.red {
  background: var(--clr-danger);
}

.check-final-link {
  color: var(--clr-success-text);
  word-break: break-all;
}

/* ─────────────────────────────────────────────────────
   Check Responsive
───────────────────────────────────────────────────── */
@media (max-width: 540px) {
  .check-input-row {
    flex-direction: column;
  }

  .check-submit-btn {
    width: 100%;
    height: 46px;
    justify-content: center;
  }

  .check-hop-row {
    flex-wrap: wrap;
  }

  .check-hop-meta {
    width: 100%;
    justify-content: flex-start;
    margin-left: 34px;
  }

  .check-final-box {
    flex-direction: column;
    gap: 8px;
  }
}

/* ══════════════════════════════════════════════════════
   PAYMENT PAGE
   파일: /payment.php
   설명: 유료 플랜/애드온 신청, 장바구니, 입금 안내, 완료 화면
══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   Payment Header
───────────────────────────────────────────────────── */
.pay-page-title {
  font-size: var(--fs-h2);
  font-weight: 700;
  color: var(--clr-text);
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: var(--lh-heading);
}

.pay-page-sub {
  font-size: var(--fs-small);
  color: var(--clr-text-sub);
  margin-bottom: 24px;
  line-height: var(--lh-base);
}

/* ─────────────────────────────────────────────────────
   Payment Sections
───────────────────────────────────────────────────── */
.pay-section {
  background: #fff;
  border: 1px solid var(--clr-border);
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 20px;
}

.pay-section-title {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--clr-text);
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: var(--lh-heading);
}

/* ─────────────────────────────────────────────────────
   Plan Cards
───────────────────────────────────────────────────── */
.plan-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 4px;
}

.plan-card {
  border: 2px solid var(--clr-border);
  border-radius: 10px;
  padding: 14px 10px 12px;
  text-align: center;
  position: relative;
  transition: border-color .15s, background .15s;
  display: flex;
  flex-direction: column;
}

.plan-card.in-cart {
  border-color: var(--clr-primary);
  background: var(--clr-primary-bg);
}

.plan-label {
  font-size: var(--fs-caption);
  font-weight: 600;
  color: var(--clr-text-label);
  margin-bottom: 4px;
}

.plan-price {
  font-size: var(--fs-em);
  font-weight: 700;
  color: var(--clr-primary);
}

.plan-disc {
  font-size: var(--fs-xs);
  color: var(--clr-success-dark);
  font-weight: 600;
  margin-top: 2px;
  min-height: 16px;
}

.plan-per {
  font-size: var(--fs-xs);
  color: #9ca3af;
  margin-top: 1px;
  min-height: 15px;
}

.badge-best {
  position: absolute;
  top: -9px;
  right: 8px;
  background: var(--clr-primary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
}

.plan-card .add-btn {
  margin-top: auto;
}

/* ─────────────────────────────────────────────────────
   Add Buttons
───────────────────────────────────────────────────── */
.add-btn {
  margin-top: 10px;
  width: 100%;
  padding: 7px 0;
  border-radius: 7px;
  font-size: var(--fs-xs);
  font-weight: 700;
  cursor: pointer;
  transition: all .15s;
  border: 1.5px solid var(--clr-primary);
  color: var(--clr-primary);
  background: #fff;
  font-family: inherit;
}

.add-btn:hover {
  background: var(--clr-primary);
  color: #fff;
}

.add-btn.in-cart {
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
}

.add-btn.in-cart:hover {
  background: var(--clr-danger);
  border-color: var(--clr-danger);
  color: #fff;
}

/* ─────────────────────────────────────────────────────
   Addon Cards
───────────────────────────────────────────────────── */
.pay-addon-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.pay-addon-card {
  border: 2px solid var(--clr-border);
  border-radius: 10px;
  padding: 14px;
  transition: border-color .15s, background .15s;
}

.pay-addon-card.in-cart {
  border-color: var(--clr-primary);
  background: var(--clr-primary-bg);
}

.pay-addon-card.locked {
  opacity: .6;
}

.ac-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.ac-icon {
  font-size: var(--fs-em);
}

.ac-name {
  font-size: var(--fs-caption);
  font-weight: 600;
  color: var(--clr-text);
}

.ac-badge {
  margin-left: auto;
  font-size: var(--fs-xs);
  padding: 2px 7px;
  border-radius: 8px;
  font-weight: 600;
}

.ac-desc {
  font-size: var(--fs-xs);
  color: #6b7280;
  line-height: var(--lh-heading);
  margin-bottom: 8px;
}

.ac-price {
  font-size: var(--fs-caption);
  font-weight: 700;
  color: var(--clr-primary);
}

.ac-period-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: var(--fs-xs);
  color: var(--clr-text-sub);
}

.ac-period-row select {
  padding: 3px 8px;
  border: 1px solid var(--clr-border-input);
  border-radius: 6px;
  font-size: var(--fs-xs);
  font-family: inherit;
}

/* ─────────────────────────────────────────────────────
   Notice Boxes
───────────────────────────────────────────────────── */
.pay-notice,
.pay-notice-info,
.current-plan-box {
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 16px;
  font-size: var(--fs-caption);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: var(--lh-base);
}

.pay-notice {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  color: #92400e;
}

.pay-notice-info {
  background: var(--clr-primary-bg);
  border: 1px solid #bfdbfe;
  color: #1e40af;
}

.current-plan-box {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  color: var(--clr-text-label);
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

/* ─────────────────────────────────────────────────────
   Cart Section
───────────────────────────────────────────────────── */
.cart-section {
  background: #fff;
  border: 2px solid var(--clr-primary);
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 20px;
}

.cart-section-title {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--clr-primary);
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.cart-item {
  display: flex;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #f3f4f6;
  gap: 12px;
}

.cart-item:last-of-type {
  border-bottom: none;
}

.cart-item-info {
  flex: 1;
  min-width: 0;
}

.cart-item-name {
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--clr-text);
}

.cart-item-meta {
  font-size: var(--fs-xs);
  color: #6b7280;
  margin-top: 2px;
}

.cart-item-price {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--clr-primary);
  white-space: nowrap;
}

.cart-item-del {
  background: none;
  border: none;
  color: #9ca3af;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  padding: 2px 6px;
  border-radius: 4px;
  flex-shrink: 0;
}

.cart-item-del:hover {
  color: var(--clr-danger);
  background: #fee2e2;
}

.cart-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0 0;
  margin-top: 6px;
  border-top: 2px solid var(--clr-border);
}

.cart-total-lbl {
  font-size: var(--fs-ui);
  font-weight: 700;
  color: var(--clr-text);
}

.cart-total-amt {
  font-size: var(--fs-h2);
  font-weight: 700;
  color: var(--clr-primary);
}

.cart-divider {
  border: none;
  border-top: 1px solid var(--clr-border);
  margin: 20px 0;
}

/* ─────────────────────────────────────────────────────
   Payment Method
───────────────────────────────────────────────────── */
.pay-method-label {
  font-size: var(--fs-caption);
  font-weight: 600;
  color: var(--clr-text-label);
  margin-bottom: 8px;
}

.pay-method-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}

.pay-method-tab {
  flex: 1;
  padding: 10px;
  border: 2px solid var(--clr-border);
  border-radius: 8px;
  cursor: pointer;
  text-align: center;
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--clr-text-label);
  transition: all .15s;
  background: #fff;
}

.pay-method-tab:hover {
  border-color: var(--clr-primary);
}

.pay-method-tab.active {
  border-color: var(--clr-primary);
  background: var(--clr-primary-bg);
  color: var(--clr-primary);
}

.pay-info-bank,
.pay-info-kakao {
  display: none;
}

.pay-info-bank.show,
.pay-info-kakao.show {
  display: block;
}

/* ─────────────────────────────────────────────────────
   Bank / Kakao Info
───────────────────────────────────────────────────── */
.bank-box {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: 8px;
  padding: 14px 16px;
  margin-bottom: 8px;
}

.bank-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0;
  font-size: var(--fs-small);
}

.bank-row .bl {
  color: #6b7280;
}

.bank-row .bv {
  font-weight: 600;
  color: var(--clr-text);
}

.bank-num {
  font-size: 20px;
  font-weight: 700;
  color: var(--clr-primary);
  letter-spacing: .5px;
}

.copy-btn {
  border: none;
  background: #e0f2fe;
  color: #0369a1;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: var(--fs-xs);
  font-weight: 600;
  cursor: pointer;
  margin-left: 8px;
  transition: all .15s;
  font-family: inherit;
}

.copy-btn:hover {
  background: var(--clr-primary);
  color: #fff;
}

.bank-stmt-link {
  font-size: var(--fs-caption);
  color: #6b7280;
  margin-top: 6px;
  display: block;
}

.bank-stmt-link a {
  color: var(--clr-primary);
  text-decoration: none;
  font-weight: 600;
}

.bank-stmt-link a:hover {
  text-decoration: underline;
}

.kakao-wrap {
  text-align: center;
  padding: 10px 0;
}

.kakao-wrap img {
  width: 210px;
  height: 210px;
  border-radius: 8px;
  border: 1px solid var(--clr-border);
}

.kakao-note {
  font-size: var(--fs-caption);
  color: #6b7280;
  margin-top: 8px;
}

/* ─────────────────────────────────────────────────────
   Depositor
───────────────────────────────────────────────────── */
.depositor-row {
  margin-top: 16px;
}

.depositor-row label {
  display: block;
  font-size: var(--fs-caption);
  font-weight: 600;
  color: var(--clr-text-label);
  margin-bottom: 6px;
}

.depositor-row input {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--clr-border-input);
  border-radius: 8px;
  font-size: var(--fs-small);
  box-sizing: border-box;
  font-family: inherit;
}

.depositor-row input:focus {
  outline: none;
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px var(--clr-primary-focus);
}

/* ─────────────────────────────────────────────────────
   Done Card
───────────────────────────────────────────────────── */
.done-card {
  background: var(--clr-primary-bg);
  border: 2px solid #bfdbfe;
  border-radius: 12px;
  padding: 28px 24px;
  text-align: center;
  margin-bottom: 20px;
}

.done-icon {
  margin-bottom: 14px;
}

.done-title {
  font-size: var(--fs-em);
  font-weight: 700;
  color: var(--clr-primary);
  margin-bottom: 6px;
}

.done-sub {
  font-size: var(--fs-small);
  color: var(--clr-text-label);
  margin-bottom: 20px;
}

.done-pay-box,
.done-meta-box,
.done-account {
  background: #fff;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  margin: 0 auto 16px;
  max-width: 400px;
  text-align: left;
}

.done-pay-box {
  padding: 16px;
}

.done-meta-box {
  padding: 12px 16px;
  font-size: var(--fs-small);
}

.done-account {
  padding: 14px 16px;
}

.done-item-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: var(--fs-small);
  border-bottom: 1px dashed #dbeafe;
}

.done-item-row:last-of-type {
  border-bottom: none;
}

.done-total-row {
  display: flex;
  justify-content: space-between;
  padding: 10px 0 0;
  margin-top: 4px;
  border-top: 2px solid #bfdbfe;
  font-size: var(--fs-ui);
  font-weight: 700;
}

.done-meta-row {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
}

.done-meta-row .dpl {
  color: #6b7280;
}

.done-meta-row .dpv {
  font-weight: 600;
  color: var(--clr-text);
}

.done-account .da-label {
  font-size: var(--fs-xs);
  color: var(--clr-primary);
  font-weight: 600;
  margin-bottom: 6px;
}

.done-account .da-num {
  font-size: var(--fs-em);
  font-weight: 700;
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.done-account .da-sub {
  font-size: var(--fs-xs);
  color: #6b7280;
  margin-top: 6px;
}

/* ─────────────────────────────────────────────────────
   Payment Responsive
───────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .plan-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pay-addon-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 400px) {
  .pay-addon-grid {
    grid-template-columns: 1fr;
  }
}