/* ============================================================
   Consultation Theme Unification — consultation-theme.css
   Goal: Make all pages follow the same visual language as the
         "상담 신청(비밀 상담 게시판)" page.
   - Mobile-first readability
   - Navy + Gold accents
   - Clean cards, consistent spacing, minimal decoration
   ============================================================ */

:root {
  --kslo-page-bg: #f6f7fb;
  --kslo-card-radius: 18px;
  --kslo-card-border: rgba(2, 6, 23, 0.08);
  --kslo-card-shadow: 0 2px 14px rgba(2, 6, 23, 0.06);
  --kslo-card-shadow-strong: 0 12px 46px rgba(2, 6, 23, 0.10);
  --kslo-focus-ring: rgba(244, 185, 66, 0.62);

  /* Readability */
  --kslo-prose-size: var(--text-base, 16px);
  --kslo-prose-leading: 1.9;
  --kslo-prose-measure: 68ch;
  --kslo-title-measure: 30ch;

  /* Align consultation step-form palette with the site navy+gold */
  --consult-gold-500: var(--gold-500, #f4b942);
  --consult-gold-400: var(--gold-400, #f7c96a);
  --consult-navy-920: var(--navy-900, #060d24);
  --consult-ink-900: var(--text-primary, #0f172a);
  --consult-ink-700: var(--text-secondary, #334155);
  --consult-ink-500: var(--text-muted, #64748b);
  --consult-surface: var(--kslo-page-bg);
}

/* Page background: light surface so white cards read like "상담 신청" */
body {
  background: linear-gradient(180deg, var(--kslo-page-bg), #f2f5fb);
}

.kslo-main {
  background: transparent;
}

/* Typography: keep everything in the same sans family as the consultation page */
.kslo-main :where(h1, h2, h3, h4, h5, h6, .hero-title, .section-title, .pasan-card-title, .seo-block-title) {
  font-family: var(--font-sans) !important;
}

/* Unified card language (radius + border + shadow) */
.kslo-main :where(
  .seo-card,
  .pasan-section-card,
  .board-card,
  .form-card,
  .profile-card,
  .insolvency-cert-card,
  .service-item,
  .loc-card,
  .trans-item,
  .photo-item,
  .service-hub-card,
  .service-card,
  .svc-card,
  .svc-subnav,
  .svc-compare-card,
  .svc-step,
  .case-item,
  .faq-item,
  .ksl-wp-card,
  .board-detail-card,
  .board-modal-box
) {
  border-radius: var(--kslo-card-radius);
  border-color: var(--kslo-card-border);
  box-shadow: var(--kslo-card-shadow);
}

.kslo-main :where(.form-card) {
  box-shadow: var(--kslo-card-shadow-strong);
}

/* Make focus styles consistent and visible */
.kslo-main :where(a, button, input, select, textarea, summary, .btn):focus-visible {
  outline-color: var(--kslo-focus-ring);
}

/* Small disclaimers/notes: readable on both light and dark surfaces */
.kslo-main .cta-note {
  margin-top: 14px;
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--text-muted, #94a3b8);
}

.kslo-main :is(.seo-hero, .hero--cases, .cta-box) .cta-note {
  color: rgba(226, 232, 240, 0.72);
}

/* Consultation step-form: use the same gold focus/ring as the board/form inputs */
.consult-step-form :is(input, select, textarea):focus {
  border-color: rgba(244, 185, 66, 0.90) !important;
  box-shadow: 0 0 0 4px rgba(244, 185, 66, 0.14) !important;
}

.consult-step-number {
  background: rgba(244, 185, 66, 0.14) !important;
  color: rgba(111, 74, 11, 0.92) !important;
}

/* ============================================================
   Site Header / Navigation (Premium polish)
   ============================================================ */

.site-header {
  background: rgba(255, 255, 255, 0.92);
  border-bottom-color: rgba(2, 6, 23, 0.08);
  backdrop-filter: saturate(1.35) blur(12px);
  -webkit-backdrop-filter: saturate(1.35) blur(12px);
}

.site-header.scrolled,
.site-header.is-scrolled {
  box-shadow: 0 12px 34px rgba(2, 6, 23, 0.06);
}

.site-header .logo-img {
  border-radius: 12px;
}

.site-header .nav-cta {
  background: var(--gold-500, #f4b942);
  color: var(--navy-900, #060d24) !important;
  border-color: rgba(6, 13, 36, 0.14);
}

.site-header .nav-cta:hover {
  background: #e8a82a;
}

/* Remove over-decorated external-link highlight inside the submenu. */
.site-header .sub-menu a[href*="kimsungilcorp.com"] {
  background: rgba(244, 185, 66, 0.14);
  color: var(--navy-900, #060d24);
  border: 1px solid rgba(244, 185, 66, 0.28);
  box-shadow: none;
  padding-right: 14px;
}

.site-header .sub-menu a[href*="kimsungilcorp.com"]::after {
  content: none;
}

.site-header .sub-menu a[href*="kimsungilcorp.com"]:hover {
  background: rgba(244, 185, 66, 0.22);
  border-color: rgba(244, 185, 66, 0.36);
}

@media (max-width: 992px) {
  /* gnb is now a sibling of site-header, not a child */
  .gnb {
    background: rgba(255, 255, 255, 0.98);
  }

  .gnb .nav-link {
    border: 1px solid rgba(2, 6, 23, 0.06);
    background: rgba(2, 6, 23, 0.02);
  }

  .gnb .nav-link::after {
    content: none;
  }

  .gnb .nav-link:hover {
    background: rgba(2, 6, 23, 0.04);
  }

  .gnb .nav-link.active,
  .gnb .nav-item.current-menu-item > .nav-link {
    background: rgba(244, 185, 66, 0.12);
  }

  .gnb .sub-menu {
    background: rgba(2, 6, 23, 0.03);
    border-color: rgba(2, 6, 23, 0.06);
  }
}

/* ============================================================
   Global Heroes (seo-hero + hero--cases)
   ============================================================ */

.kslo-main :is(.hero--cases, .seo-hero) {
  background:
    radial-gradient(900px 520px at 14% 0%, rgba(244, 185, 66, 0.16) 0%, transparent 60%),
    linear-gradient(180deg, var(--navy-950, #020617), var(--navy-900, #060d24));
}

.kslo-main :is(.hero--cases, .seo-hero) .hero-intro {
  align-items: flex-start;
  text-align: left;
  max-width: 900px;
  gap: 12px;
}

.kslo-main :is(.hero--cases, .seo-hero)
  :where(.hero-kicker, .hero-badge, .pasan-hero-kicker, .cases-kicker, .faq-hero-kicker, .contact-hero-kicker, .loc-kicker) {
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(244, 185, 66, 0.14);
  border: 1px solid rgba(244, 185, 66, 0.22);
  color: rgba(244, 185, 66, 0.92);
  letter-spacing: 0.18em;
}

.kslo-main :is(.hero--cases, .seo-hero) :where(h1, .hero-title) {
  max-width: var(--kslo-title-measure);
  text-align: left;
}

.kslo-main .seo-hero h1::after {
  left: 0;
  transform: none;
}

.kslo-main .hero--cases :where(
  .pasan-hero-title,
  .cases-title,
  .faq-hero-title,
  .contact-hero-title,
  .loc-title,
  .about-hero .hero-title,
  .corp-hero-title,
  .service-hero-title,
  .selfcheck-title,
  .hero-title,
  h1
)::after {
  left: 0;
  transform: none;
}

.kslo-main :is(.hero--cases, .seo-hero) :where(.seo-lead p, .hero-desc p) {
  font-size: var(--kslo-prose-size);
  line-height: 1.85;
}

.kslo-main :is(.hero--cases, .seo-hero) :where(.seo-lead, .hero-desc) {
  max-width: var(--kslo-prose-measure);
}

.kslo-main .service-hero-actions,
.kslo-main .hero--cases .hero-actions {
  justify-content: flex-start;
}

@media (max-width: 560px) {
  .kslo-main .service-hero-actions,
  .kslo-main .hero--cases .hero-actions {
    width: 100%;
  }

  .kslo-main .hero--cases .hero-actions :where(.btn),
  .kslo-main .service-hero-actions :where(a) {
    width: 100%;
    justify-content: center;
  }
}

/* Sticky sub-nav bars should match the header finish. */
.kslo-main :where(.pasan-nav-wrapper, .cases-nav-wrapper) {
  background: rgba(255, 255, 255, 0.88);
  border-bottom-color: rgba(2, 6, 23, 0.08);
  backdrop-filter: saturate(1.2) blur(10px);
  -webkit-backdrop-filter: saturate(1.2) blur(10px);
}

/* ============================================================
   Long-form Content (SEO cards, WP cards, board text)
   ============================================================ */

.kslo-main :where(.seo-content, .kslo-guide-source, .board-view-text, .ksl-wp-card) {
  font-size: var(--kslo-prose-size);
  line-height: var(--kslo-prose-leading);
}

.kslo-main .seo-content {
  color: rgba(15, 23, 42, 0.78);
}

.kslo-main .seo-content :where(p, ul, ol, dl, blockquote) {
  max-width: var(--kslo-prose-measure);
  text-wrap: pretty;
}

.kslo-main .seo-content :where(p, ul, ol, dl, blockquote) {
  margin-block: 0 14px;
}

.kslo-main .seo-content h2 {
  font-size: clamp(20px, 0.9vw + 18px, 26px);
  margin: clamp(34px, 4vw, 56px) 0 12px;
}

.kslo-main .seo-content h3 {
  font-size: clamp(16.5px, 0.4vw + 16px, 20px);
  margin: 24px 0 10px;
}

.kslo-main :where(.faq-answer-inner, .case-summary, .case-detail) {
  font-size: var(--kslo-prose-size);
  line-height: 1.85;
}

.kslo-main :where(.seo-content, .kslo-guide-source, .board-view-text, .ksl-wp-card) :where(blockquote) {
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(244, 185, 66, 0.18);
  background: rgba(244, 185, 66, 0.06);
}

.kslo-main :where(.seo-content, .kslo-guide-source, .board-view-text, .ksl-wp-card) :where(hr) {
  border: 0;
  height: 1px;
  background: rgba(15, 23, 42, 0.08);
  margin: 26px auto;
  max-width: var(--kslo-prose-measure);
}

/* Mobile padding on WP cards is too generous by default. */
.kslo-main .ksl-wp-card {
  padding: clamp(18px, 4vw, 32px);
}

.kslo-main .seo-breadcrumb {
  flex-wrap: wrap;
  row-gap: 6px;
  line-height: 1.35;
}

.kslo-main :where(.cta-box, .faq-cta, .loc-cta) {
  border-radius: var(--kslo-card-radius);
}

.kslo-main .cta-box {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.10);
  background:
    radial-gradient(900px 520px at 12% -10%, rgba(244, 185, 66, 0.16) 0%, transparent 62%),
    linear-gradient(135deg, var(--navy-950, #020617), var(--navy-900, #060d24));
}

.kslo-main .cta-box :where(h2, p) {
  max-width: 62ch;
  text-align: left;
}

@media (max-width: 560px) {
  .kslo-main .cta-box :where(.btn, a.btn) {
    width: 100%;
    justify-content: center;
  }
}

/* ============================================================
   Home Page: Card-on-surface layout (consultation-like)
   ============================================================ */

.kslo-index {
  background: transparent;
}

.kslo-index .hero--front {
  min-height: auto;
}

.kslo-index .section-py:not(.hero) {
  background: transparent;
  overflow: visible;
  padding-block: clamp(22px, 4.2vw, 52px);
}

.kslo-index .section-py:not(.hero) > .container {
  width: min(var(--container-max), calc(100% - (var(--container-px) + var(--container-px))));
  margin-inline: auto;
  padding: clamp(22px, 4.2vw, 48px);
  background: #ffffff;
  border: 1px solid var(--kslo-card-border);
  border-radius: var(--kslo-card-radius);
  box-shadow: var(--kslo-card-shadow);
}

/* Dark "cards" still look like a section card */
.kslo-index :is(.index-cases-section, .process-section) {
  background: transparent;
}

.kslo-index :is(.index-cases-section, .process-section) > .container {
  background:
    radial-gradient(1000px 520px at 20% -10%, rgba(244, 185, 66, 0.10) 0%, transparent 62%),
    linear-gradient(180deg, var(--navy-950), var(--navy-900));
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: var(--kslo-card-radius);
  box-shadow: 0 18px 62px rgba(2, 6, 23, 0.22);
}

/* Remove section-level decorative overlays on home for a cleaner, consultation-like feel */
.kslo-index :is(.cert-section, .trustee-section, .index-cases-section, .process-section)::before {
  content: none !important;
}

/* ============================================================
   SEO Landing Pages (service-landing-main)
   - These pages previously relied on a dedicated redesign CSS.
   - Keep them aligned with the consultation design language.
   ============================================================ */

.service-landing-main {
  background: transparent;
  color: var(--text-primary, #0f172a);
}

.service-landing-main .service-landing-shell {
  padding-block: clamp(18px, 4vw, 44px);
}

.service-landing-main .seo-hero .hero-intro {
  max-width: 860px;
}

.service-landing-main .kslo-hero-subtitle {
  margin: 0;
  color: rgba(226, 232, 240, 0.86);
  line-height: 1.85;
  font-size: var(--kslo-prose-size);
  max-width: var(--kslo-prose-measure);
}

/* Primary CTA buttons used by seo-landing template */
.service-landing-main .kslo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(241, 245, 249, 0.92);
  font-size: 15px;
  font-weight: 800;
  text-decoration: none;
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.service-landing-main .kslo-btn--primary {
  background: var(--gold-500, #f4b942);
  color: var(--navy-900, #060d24);
  border-color: rgba(6, 13, 36, 0.14);
}

.service-landing-main .kslo-btn:hover {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(244, 185, 66, 0.28);
  color: #ffffff;
}

.service-landing-main .kslo-btn--primary:hover {
  background: #e8a82a;
  color: var(--navy-900, #060d24);
}

.service-landing-main .kslo-btn--ghost {
  background: rgba(255, 255, 255, 0.06);
}

.service-landing-main .cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
  margin-top: 18px;
}

/* Cluster navigation */
.service-landing-main .kslo-related-links {
  padding: 16px 16px;
  border-radius: var(--kslo-card-radius);
  border: 1px solid var(--kslo-card-border);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--kslo-card-shadow);
}

.service-landing-main .kslo-related-links__title {
  display: block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(111, 74, 11, 0.92);
}

.service-landing-main .kslo-related-links__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.service-landing-main .kslo-related-links__grid a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255, 255, 255, 0.86);
  color: rgba(6, 13, 36, 0.90);
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.service-landing-main .kslo-related-links__grid a:hover {
  background: #ffffff;
  border-color: rgba(244, 185, 66, 0.32);
}

.service-landing-main .kslo-related-links__grid a.is-current {
  background: var(--navy-900, #060d24);
  border-color: transparent;
  color: #ffffff;
}

/* Jump navigation (section pills) */
.service-landing-main .kslo-page-nav {
  margin-top: 14px;
  padding: 10px 0;
  overflow-x: auto;
  display: flex;
  gap: 8px;
  scrollbar-width: none;
}

.service-landing-main .kslo-page-nav::-webkit-scrollbar { display: none; }

.service-landing-main .kslo-page-nav-link {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255, 255, 255, 0.86);
  color: rgba(6, 13, 36, 0.86);
  font-size: 13px;
  font-weight: 850;
  text-decoration: none;
  white-space: nowrap;
}

.service-landing-main .kslo-page-nav-link:hover {
  background: #ffffff;
  border-color: rgba(244, 185, 66, 0.32);
}

.service-landing-main .kslo-page-nav-link.is-active {
  background: rgba(244, 185, 66, 0.14);
  border-color: rgba(244, 185, 66, 0.32);
  color: var(--navy-900, #060d24);
}

/* Content inside landing cards */
.service-landing-main .kslo-prose p {
  margin: 0 0 12px;
  color: rgba(15, 23, 42, 0.74);
  line-height: 1.85;
}

.service-landing-main .seo-block-title {
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--navy-900, #060d24);
  margin-bottom: 14px;
}

.service-landing-main .seo-checklist,
.service-landing-main .seo-bullets {
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.service-landing-main .seo-checklist li,
.service-landing-main .seo-bullets li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: rgba(248, 250, 252, 0.72);
  color: rgba(15, 23, 42, 0.78);
  line-height: 1.75;
}

.service-landing-main .seo-check,
.service-landing-main .seo-dot {
  display: inline-flex;
  width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: rgba(244, 185, 66, 0.16);
  color: var(--navy-900, #060d24);
  font-weight: 900;
  font-size: 12px;
  margin-top: 2px;
}

.service-landing-main .seo-checklist-box {
  margin-top: 16px;
  padding: 16px 14px;
  border-radius: 16px;
  border: 1px solid rgba(244, 185, 66, 0.20);
  background: rgba(244, 185, 66, 0.08);
}

.service-landing-main .seo-checklist-title {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--navy-900, #060d24);
}

/* FAQ (details/summary) */
.service-landing-main .seo-faq-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.service-landing-main .seo-faq-item {
  border-radius: var(--kslo-card-radius);
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #ffffff;
  box-shadow: var(--kslo-card-shadow);
  overflow: hidden;
}

.service-landing-main .seo-faq-q {
  list-style: none;
  cursor: pointer;
  padding: 16px 16px;
  font-size: 15px;
  font-weight: 850;
  color: rgba(6, 13, 36, 0.92);
}

.service-landing-main .seo-faq-q::-webkit-details-marker { display: none; }

.service-landing-main .seo-faq-a {
  padding: 0 16px 16px;
  color: rgba(15, 23, 42, 0.76);
  line-height: 1.85;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
}

@media (max-width: 520px) {
  .service-landing-main .cta-actions { flex-direction: column; }
  .service-landing-main .kslo-btn { width: 100%; }
}

/* ============================================================
   Hero trust block (used by SEO landing pages)
   ============================================================ */

.kslo-main .kslo-hero-trust {
  margin-top: 18px;
  display: grid;
  gap: 10px;
}

@media (min-width: 720px) {
  .kslo-main .kslo-hero-trust {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }
}

.kslo-main .kslo-hero-trust__item {
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  padding: 12px 12px;
}

.kslo-main .kslo-hero-trust__head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.kslo-main .kslo-hero-trust__icon {
  width: 16px;
  height: 16px;
  color: rgba(244, 185, 66, 0.92);
  flex-shrink: 0;
}

.kslo-main .kslo-hero-trust__title {
  font-weight: 900;
  font-size: 13px;
  letter-spacing: -0.01em;
  color: rgba(255, 255, 255, 0.92);
}

.kslo-main .kslo-hero-trust__desc {
  margin: 0;
  font-size: 12.5px;
  line-height: 1.65;
  color: rgba(226, 232, 240, 0.72);
}
