/* ═══════════ CPA 전환형 랜딩 (개인회생) — style.css 다음에 로드 ═══════════ */
/* 사이트 전체(헤더/글/푸터)를 파인그린·크림 톤으로 통일 */
body.cpa {
  --c-accent: #0e5c4f; --c-accent-soft: #d8e8e3;
  --c-bg: #f7f3ec; --c-bg-alt: #ffffff;
  background: #f7f3ec;
}
body.cpa .site-header { border-bottom-color: #e6ddcf; }
.container-lp { max-width: none; padding: 0; }

.lp {
  --ink: #16243a; --pine: #0e5c4f; --pine-d: #0a4439;
  --gold: #e0a23f; --gold-d: #c9882a; --ink-cta: #241606;
  --cream: #f7f3ec; --card: #fff; --line: #e7ddcd; --muted: #5c6b78;
  color: var(--ink); line-height: 1.7;
}
.lp em { font-style: normal; color: var(--gold); }

/* 버튼 */
.lp-btn { display: inline-block; padding: 16px 30px; border-radius: 999px;
  font-weight: 700; text-decoration: none; font-size: 1.05rem; letter-spacing: -0.01em;
  transition: transform .15s ease, box-shadow .15s ease; }
.lp-btn-primary { background: var(--gold); color: var(--ink-cta);
  box-shadow: 0 8px 22px -8px rgba(224,162,63,.65); }
.lp-btn-primary:hover { background: var(--gold-d); transform: translateY(-2px);
  box-shadow: 0 12px 26px -8px rgba(224,162,63,.7); }
.lp-btn-lg { padding: 18px 40px; font-size: 1.15rem; }

/* 히어로 */
.lp-hero { background:
    radial-gradient(120% 120% at 80% 0%, #14705f 0%, transparent 55%),
    linear-gradient(160deg, #0e5c4f 0%, #0a3d36 70%, #0a2f2d 100%);
  color: #f4efe6; padding: 72px 22px 60px; text-align: center; position: relative; overflow: hidden; }
.lp-hero::after { content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 22px 22px; pointer-events: none; }
.lp-hero-inner { max-width: 740px; margin: 0 auto; position: relative; z-index: 1; }
.lp-eyebrow { display: inline-block; font-size: .82rem; font-weight: 600; letter-spacing: .04em;
  color: #e9c789; border: 1px solid rgba(233,199,137,.45); padding: 5px 14px; border-radius: 999px; margin-bottom: 22px; }
.lp-h1 { font-family: "Gowun Batang", serif; font-size: clamp(2rem, 6.2vw, 3.05rem);
  line-height: 1.32; font-weight: 700; margin: 0 0 20px; letter-spacing: -0.01em; }
.lp-sub { font-size: 1.08rem; color: #d7e3dd; max-width: 600px; margin: 0 auto 30px; }
.lp-hero-cta { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.lp-hero-note { font-size: .8rem; color: #9fc2b8; }
.lp-trust { list-style: none; display: flex; justify-content: center; gap: 14px; flex-wrap: wrap;
  margin: 40px 0 0; padding: 0; }
.lp-trust li { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px; padding: 14px 20px; min-width: 120px; }
.lp-trust strong { display: block; color: #fff; font-size: 1rem; }
.lp-trust span { font-size: .8rem; color: #a9c7bd; }

/* 섹션 공통 */
.lp-section { max-width: 760px; margin: 0 auto; padding: 56px 22px; }
.lp-h2 { font-family: "Gowun Batang", serif; font-size: clamp(1.5rem, 4.5vw, 2rem);
  text-align: center; margin: 0 0 34px; line-height: 1.4; position: relative; }
.lp-h2::after { content: ""; display: block; width: 46px; height: 3px; background: var(--gold);
  border-radius: 3px; margin: 16px auto 0; }

/* 공감 */
.lp-pain { background: #fff; border-radius: 20px; margin-top: 8px; }
.lp-pain-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lp-pain-card { background: var(--cream); border: 1px solid var(--line); border-radius: 14px;
  padding: 22px 16px; text-align: center; font-weight: 600; color: var(--ink); }
.lp-pain-foot { text-align: center; margin: 26px 0 0; color: var(--pine); font-weight: 700; }

/* 상담 — 업체 카드 리스트 */
.lp-firms { background: linear-gradient(170deg, #103f37, #0c2f2b); color: #eef5f1;
  max-width: none; border-radius: 0; padding-left: 22px; padding-right: 22px; }
.lp-firms > * { max-width: 760px; margin-left: auto; margin-right: auto; }
.lp-firms .lp-h2 { color: #fff; }
.lp-firms-head { text-align: center; }
.lp-firms-desc { text-align: center; color: #bcd4cb; font-size: .92rem; margin: -18px auto 26px; max-width: 560px; }
.lp-firm-list { display: flex; flex-direction: column; gap: 12px; }
.lp-firm-card { display: flex; align-items: center; gap: 16px; background: #fff; color: var(--ink);
  border-radius: 16px; padding: 18px 20px; box-shadow: 0 14px 34px -18px rgba(0,0,0,.55); }
.lp-firm-badge { flex: none; width: 52px; height: 52px; border-radius: 14px;
  background: linear-gradient(150deg, #0e5c4f, #0a3d36); color: #fff; font-weight: 700;
  font-size: 1.4rem; display: grid; place-items: center; font-family: "Gowun Batang", serif; }
.lp-firm-body { flex: 1 1 auto; min-width: 0; }
.lp-firm-body h3 { margin: 0 0 3px; font-size: 1.08rem; color: var(--ink); }
.lp-firm-body p { margin: 0; font-size: .86rem; color: var(--muted); }
.lp-firm-legal { display: block; font-size: .72rem; color: #98a4ae; margin-top: 4px; }
.lp-firm-btn { flex: none; background: var(--gold); color: var(--ink-cta); font-weight: 700;
  text-decoration: none; padding: 12px 20px; border-radius: 999px; font-size: .95rem; white-space: nowrap;
  transition: background .15s, transform .15s; }
.lp-firm-btn:hover { background: var(--gold-d); transform: translateY(-1px); }
.lp-firms-foot { text-align: center; font-size: .78rem; color: #9fc2b8; margin: 22px auto 0; max-width: 600px; }

/* 글 페이지 안의 업체 카드 (post.html.j2) */
.cpa-consult { margin: 36px 0; padding: 24px; border-radius: 16px;
  background: linear-gradient(170deg, #103f37, #0c2f2b); color: #eef5f1; }
.cpa-consult-title { margin: 0 0 6px; font-size: 1.3rem; color: #fff; text-align: center;
  font-family: "Gowun Batang", serif; }
.cpa-consult-desc { margin: 0 0 18px; font-size: .9rem; color: #bcd4cb; text-align: center; }
.cpa-firm-list { display: flex; flex-direction: column; gap: 10px; }
.cpa-firm-card { display: flex; align-items: center; gap: 14px; background: #fff; color: #16243a;
  border-radius: 14px; padding: 15px 16px; }
.cpa-firm-badge { flex: none; width: 46px; height: 46px; border-radius: 12px;
  background: linear-gradient(150deg, #0e5c4f, #0a3d36); color: #fff; font-weight: 700; font-size: 1.25rem;
  display: grid; place-items: center; font-family: "Gowun Batang", serif; }
.cpa-firm-body { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; }
.cpa-firm-body strong { font-size: 1.02rem; }
.cpa-firm-tag { font-size: .82rem; color: #5c6b78; }
.cpa-firm-legal { font-size: .7rem; color: #98a4ae; margin-top: 2px; }
.cpa-firm-btn { flex: none; background: #e0a23f; color: #241606; font-weight: 700; text-decoration: none;
  padding: 11px 18px; border-radius: 999px; font-size: .9rem; white-space: nowrap; }
.cpa-firm-btn:hover { background: #c9882a; }
.cpa-consult-legal { text-align: center; font-size: .78rem; color: #9fc2b8; margin: 16px 0 0; }
.cpa-consult-btn { display: block; max-width: 360px; margin: 0 auto; text-align: center;
  background: #e0a23f; color: #241606; font-weight: 700; text-decoration: none;
  padding: 16px 24px; border-radius: 999px; font-size: 1.05rem; box-shadow: 0 10px 24px -10px rgba(224,162,63,.7); }
.cpa-consult-btn:hover { background: #c9882a; }

/* 홈 — 지역·업체 무관 공통 상담 CTA 밴드 */
.lp-cta-band { background: linear-gradient(170deg, #103f37, #0c2f2b); color: #eef5f1;
  max-width: none; border-radius: 0; text-align: center; }
.lp-cta-band .lp-h2 { color: #fff; }
.lp-cta-desc { color: #bcd4cb; font-size: .95rem; max-width: 560px; margin: -18px auto 28px; }
.lp-cta-foot { color: #9fc2b8; font-size: .78rem; margin: 20px auto 0; max-width: 560px; }

/* 업체 카드 요약(2줄 허용) */
.lp-firm-summary { font-size: .88rem; color: var(--muted); line-height: 1.55; }

/* 카테고리 글 목록: 이미지 없을 때 본문이 180px 칸에 끼이는 버그 → 전폭 카드(블로그형) */
body.cpa .post-list { gap: 14px; }
body.cpa .post-row { grid-template-columns: 1fr; background: #fff; border: 1px solid #e7ddcd;
  border-radius: 14px; padding: 22px 26px; }
body.cpa .post-row:last-child { border-bottom: 1px solid #e7ddcd; }
body.cpa .post-row-title { font-size: 1.2rem; }
body.cpa .post-row-title a { color: var(--c-text); text-decoration: none; }
body.cpa .post-row-title a:hover { color: #0e5c4f; }

/* 자격 */
.lp-qual { display: flex; flex-direction: column; gap: 16px; }
.lp-qual-item { display: flex; gap: 16px; background: #fff; border: 1px solid var(--line);
  border-radius: 16px; padding: 22px; }
.lp-num { flex: none; width: 38px; height: 38px; border-radius: 50%; background: var(--pine);
  color: #fff; font-weight: 700; display: grid; place-items: center; font-size: 1.05rem; }
.lp-qual-item h3 { margin: 4px 0 6px; font-size: 1.1rem; color: var(--ink); }
.lp-qual-item p { margin: 0; color: var(--muted); font-size: .95rem; }
.lp-mid-cta { text-align: center; margin-top: 30px; }

/* 절차 */
.lp-steps-sec { background: #fff; border-radius: 20px; }
.lp-steps { list-style: none; padding: 0; margin: 0; position: relative; }
.lp-steps::before { content: ""; position: absolute; left: 26px; top: 10px; bottom: 10px;
  width: 2px; background: var(--line); }
.lp-steps li { position: relative; padding: 0 0 26px 70px; }
.lp-steps li:last-child { padding-bottom: 0; }
.lp-step-n { position: absolute; left: 6px; top: 0; width: 42px; height: 42px; border-radius: 50%;
  background: var(--pine); color: #fff; font-weight: 700; display: grid; place-items: center; font-size: .9rem;
  box-shadow: 0 0 0 5px var(--card); }
.lp-steps h3 { margin: 6px 0 4px; font-size: 1.08rem; color: var(--ink); }
.lp-steps p { margin: 0; color: var(--muted); font-size: .94rem; }

/* 장점 */
.lp-benefits { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lp-benefit { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 22px; }
.lp-benefit h3 { margin: 0 0 8px; font-size: 1.02rem; color: var(--pine); }
.lp-benefit h3::before { content: "✓"; display: inline-grid; place-items: center; width: 22px; height: 22px;
  background: var(--pine); color: #fff; border-radius: 50%; font-size: .75rem; margin-right: 8px; vertical-align: middle; }
.lp-benefit p { margin: 0; color: var(--muted); font-size: .93rem; }

/* 지역별 */
.lp-region-desc { text-align: center; color: var(--muted); margin: -20px 0 26px; }
.lp-region-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.lp-region-list a { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--line);
  border-radius: 12px; padding: 16px 18px; text-decoration: none; color: var(--ink); font-weight: 600; transition: border-color .15s; }
.lp-region-list a:hover { border-color: var(--pine); }
.lp-region-tag { flex: none; font-size: .72rem; font-weight: 700; color: var(--pine); background: var(--c-accent-soft);
  padding: 3px 9px; border-radius: 999px; }
.lp-arr { margin-left: auto; color: var(--gold); font-size: 1.3rem; }

/* FAQ */
.lp-faq-list { display: flex; flex-direction: column; gap: 10px; }
.lp-faq-item { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 4px 20px; }
.lp-faq-item summary { cursor: pointer; font-weight: 700; color: var(--ink); padding: 16px 0; list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.lp-faq-item summary::-webkit-details-marker { display: none; }
.lp-faq-item summary::after { content: "+"; color: var(--gold); font-size: 1.4rem; font-weight: 400; flex: none; }
.lp-faq-item[open] summary::after { content: "\2013"; }
.lp-faq-item p { margin: 0 0 18px; color: var(--muted); font-size: .95rem; }

/* 마무리 CTA */
.lp-final { text-align: center; background: linear-gradient(160deg, #0e5c4f, #0a3d36); color: #f4efe6;
  max-width: none; border-radius: 0; }
.lp-final .lp-h2 { color: #fff; }
.lp-final p { color: #cfe0d9; margin: -18px 0 28px; }

/* 고정 플로팅 CTA */
.lp-sticky { position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%); z-index: 60;
  background: var(--c-accent, #0e5c4f); color: #fff; padding: 15px 26px; border-radius: 999px;
  font-weight: 700; text-decoration: none; font-size: 1.02rem; white-space: nowrap;
  box-shadow: 0 12px 30px -8px rgba(14,92,79,.7); display: flex; align-items: center; gap: 10px; }
.lp-sticky:hover { background: #0a4439; }
.lp-sticky-dot { width: 9px; height: 9px; border-radius: 50%; background: #e0a23f;
  box-shadow: 0 0 0 0 rgba(224,162,63,.7); animation: lp-pulse 1.8s infinite; }
@keyframes lp-pulse { 0% { box-shadow: 0 0 0 0 rgba(224,162,63,.7); }
  70% { box-shadow: 0 0 0 12px rgba(224,162,63,0); } 100% { box-shadow: 0 0 0 0 rgba(224,162,63,0); } }
body.cpa main { padding-bottom: 84px; }

@media (max-width: 560px) {
  .lp-pain-grid, .lp-benefits { grid-template-columns: 1fr; }
  .lp-sticky { left: 16px; right: 16px; transform: none; justify-content: center; }
}
