:root{
  --bg:#F6F8FB;--surface:#FFFFFF;--surface2:#EEF4FA;--ink:#1F2D3D;--soft:#66788A;--line:#D9E3EE;--accent:#3F7FBF;--accent2:#6EA8D9;--dark:#26384D;--deep:#172433;--safe:#21A67A;
}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:'Pretendard',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--ink);line-height:1.65}a{text-decoration:none;color:inherit}ul{list-style:none}.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.header{position:sticky;top:0;z-index:50;background:rgba(23,36,51,.96);backdrop-filter:blur(12px);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}.header-inner{max-width:1200px;margin:0 auto;padding:15px 28px;display:flex;align-items:center;justify-content:space-between;gap:22px}.logo{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;letter-spacing:-.03em}.logo-mark{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--accent2),var(--accent));display:grid;place-items:center}.nav{display:flex;align-items:center;gap:8px}.nav a{padding:10px 12px;border-radius:999px;color:rgba(255,255,255,.78);font-weight:650;font-size:15px}.nav a:hover{background:rgba(255,255,255,.08);color:#fff}.call-btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:11px 18px;border-radius:999px;font-weight:800;box-shadow:0 8px 22px rgba(63,127,191,.28)}.call-btn:hover{background:#2E6EAE}.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:28px}
.hero{background:radial-gradient(circle at 80% 10%,rgba(110,168,217,.32),transparent 32%),linear-gradient(135deg,#172433 0%,#2D4865 58%,#3F7FBF 100%);color:#fff;overflow:hidden}.hero-inner{max-width:1200px;margin:0 auto;padding:84px 28px 72px;display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center}.eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:8px 14px;border-radius:999px;font-weight:750;color:#E7F2FF;margin-bottom:22px
font-size:14px !important;
padding:8px 14px !important;
font-weight:800 !important;
line-height:1 !important;
display:inline-flex;
align-items:center;
justify-content:center;
min-height:38px;
}.hero h1{font-size:clamp(40px,6vw,74px);line-height:1.08;letter-spacing:-.055em;font-weight:850;margin-bottom:24px}.hero h1 span{color:#BFE0FF}.hero-desc{font-size:clamp(17px,2vw,22px);color:rgba(255,255,255,.84);max-width:620px;margin-bottom:34px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.primary-cta,.secondary-cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:17px 24px;border-radius:16px;font-weight:850}.primary-cta{background:#fff;color:#17324B}.secondary-cta{border:1px solid rgba(255,255,255,.35);color:#fff;background:rgba(255,255,255,.08)}.trust-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:28px}.trust-row span{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:9px 12px;font-weight:650;color:rgba(255,255,255,.82);font-size:14px}.hero-panel{position:relative;border-radius:28px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.18);padding:24px;box-shadow:0 24px 70px rgba(0,0,0,.25)}.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.panel-card{min-height:160px;background:rgba(255,255,255,.95);color:var(--ink);border-radius:22px;padding:22px;position:relative;overflow:hidden}.panel-card strong{display:block;font-size:24px;letter-spacing:-.03em;margin-bottom:8px}.panel-card p{font-size:14px;color:var(--soft);font-weight:600}.panel-card .num{position:absolute;right:18px;bottom:8px;font-size:58px;font-weight:900;color:rgba(63,127,191,.11)}.panel-card.main{grid-column:1/3;background:linear-gradient(135deg,#EEF7FF,#fff)}.panel-card.main strong{font-size:30px}.safe-badge{display:inline-flex;background:rgba(33,166,122,.12);color:var(--safe);border:1px solid rgba(33,166,122,.22);padding:5px 10px;border-radius:999px;font-size:13px;font-weight:850;margin-bottom:10px}
.section{padding:92px 0}.section.alt{background:var(--surface2)}.section-title{text-align:center;margin-bottom:46px}.section-title .label{color:var(--accent);font-size:14px;font-weight:850;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}.section-title h2{font-size:clamp(30px,4vw,46px);line-height:1.22;letter-spacing:-.04em}.section-title p{margin:15px auto 0;max-width:720px;color:var(--soft);font-size:17px}.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-card{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:28px;box-shadow:0 10px 30px rgba(31,45,61,.05);transition:.2s}.service-card:hover{transform:translateY(-5px);box-shadow:0 18px 42px rgba(31,45,61,.1)}.icon{width:48px;height:48px;border-radius:16px;background:var(--surface2);display:grid;place-items:center;font-size:25px;margin-bottom:18px}.service-card h3{font-size:24px;letter-spacing:-.035em;margin-bottom:12px}.service-card p{color:var(--soft);font-size:15px;margin-bottom:18px}.check-list li{padding:8px 0;border-top:1px dashed var(--line);font-size:14px;color:#516579}.check-list li:before{content:'✓';color:var(--accent);font-weight:900;margin-right:8px}.focus-box{background:var(--deep);color:#fff;border-radius:28px;padding:38px;display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center;box-shadow:0 24px 70px rgba(23,36,51,.2)}.focus-box h2{font-size:clamp(30px,4vw,48px);line-height: 1.32;letter-spacing:-.04em;margin-bottom:18px}.focus-box p{color:rgba(255,255,255,.78);font-size:17px}.focus-list{display:grid;gap:12px}.focus-item{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:16px 18px}.focus-item b{display:block;margin-bottom:4px}.focus-item span{color:rgba(255,255,255,.68);font-size:14px}.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.area-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:28px}.area-card h3{font-size:24px;margin-bottom:12px}.area-card p{color:var(--soft)}.keyword-cloud{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.keyword-cloud span{background:var(--surface2);border:1px solid var(--line);padding:8px 12px;border-radius:999px;color:#41566B;font-weight:700;font-size:14px}.process{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.step{background:#fff;border:1px solid var(--line);border-radius:22px;padding:26px}.step .stepnum{font-size:13px;color:var(--accent);font-weight:900;letter-spacing:.08em;margin-bottom:12px}.step h3{font-size:21px;margin-bottom:8px}.step p{color:var(--soft);font-size:15px}.cta-band{background:linear-gradient(135deg,var(--accent),#214E7C);color:#fff;border-radius:30px;padding:42px;display:flex;align-items:center;justify-content:space-between;gap:24px}.cta-band h2{font-size:clamp(28px,3.6vw,42px);letter-spacing:-.04em}.cta-band p{color:rgba(255,255,255,.78);margin-top:8px}.cta-band a{background:#fff;color:#17324B;padding:18px 26px;border-radius:16px;font-weight:900;white-space:nowrap}footer{background:var(--deep);color:rgba(255,255,255,.7);padding:46px 28px 86px;text-align:center}.footer-logo{color:#fff;font-size:22px;font-weight:850;margin-bottom:10px}.fixed-call{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:99}.fixed-call a{display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:18px;padding:16px 18px;font-size:18px;font-weight:900;box-shadow:0 14px 34px rgba(0,0,0,.25)}
@media(max-width:920px){.nav{display:none}.menu-toggle{display:block}.nav.open{display:flex;position:absolute;left:0;right:0;top:68px;background:var(--deep);padding:15px 20px;flex-direction:column;align-items:stretch}.nav.open a{border-radius:12px}.hero-inner{grid-template-columns:1fr;padding-top:62px}.service-grid,.process{grid-template-columns:1fr 1fr}.focus-box,.area-grid{grid-template-columns:1fr}.header-inner{padding:14px 20px}.call-btn span{display:none}.fixed-call{display:block}}
@media(max-width:560px){.wrap{padding:0 20px}.hero-inner{padding:48px 20px 56px}.panel-grid{grid-template-columns:1fr}.panel-card.main{grid-column:auto}.service-grid,.process{grid-template-columns:1fr}.section{padding:66px 0}.cta-band{display:block;padding:30px}.cta-band a{display:flex;margin-top:22px}.hero-actions a{width:100%}.hero h1{font-size:42px}.header .logo{font-size:20px}}

  .hero-card-title,
  .main-heading h1 {
    word-break: keep-all;
  }

  @media (max-width: 768px) {
    .hero-card-content {
      padding: 22px;
    }

    .hero-card-title {
      font-size: 30px !important;
      line-height: 1.25;
    }

    .hero-card-sub {
      font-size: 15px;
      line-height: 1.5;
    }

    .main-heading h1 {
      font-size: 34px !important;
      line-height: 1.35;
    }

    .main-heading p {
      font-size: 16px;
      line-height: 1.7;
      padding: 0 8px;
    }

    .big-cta {
      width: 100%;
      justify-content: center;
      font-size: 20px !important;
      padding: 16px 24px;
    }

    .services-title {
      font-size: 30px;
      line-height: 1.3;
    }

    .service-block h3 {
      font-size: 20px;
      line-height: 1.35;
    }
  }


  /* ===== 텍스트 줄밀림 보정 ===== */
  .nowrap-title {
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
    letter-spacing: -0.04em;
  }

  .service-card h3,
  .service-card h4,
  .process-card h3,
  .process-card h4,
  .feature-card h3,
  .feature-card h4,
  .service-block h3 {
    word-break: keep-all;
    overflow-wrap: normal;
  }

  .service-card,
  .process-card,
  .feature-card,
  .service-block {
    min-width: 0;
  }

  @media (max-width: 1180px) {
    .nowrap-title {
      font-size: clamp(20px, 2.4vw, 28px) !important;
      letter-spacing: -0.05em;
    }
  }

  @media (max-width: 768px) {
    .nowrap-title {
      white-space: nowrap;
      font-size: 22px !important;
    }
  }

  @media (max-width: 420px) {
    .nowrap-title {
      font-size: 20px !important;
    }
  }


/* ===== 메인 타이틀 최종 ===== */
.hero-main-title{
  font-size: clamp(58px, 5.8vw, 92px);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.07em;
  color:#ffffff;
  margin:0 0 32px;
  word-break: keep-all;
}

.hero-main-title span{
  display:inline-block;
  white-space: nowrap;
}

@media (max-width: 1200px){
  .hero-main-title{
    font-size: clamp(48px, 5vw, 72px);
    line-height:1.12;
  }
}

@media (max-width: 768px){
  .hero-main-title{
    font-size: 44px;
    line-height:1.18;
  }
}

@media (max-width: 480px){
  .hero-main-title{
    font-size: 34px;
    line-height:1.22;
  }
}

/* ===== 헤더 카카오 상담 버튼 ===== */
.kakao-header-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  background:#FEE500;
  color:#191919 !important;
  padding:11px 18px;
  border-radius:999px;
  font-size:15px;
  font-weight:850;
  line-height:1;
  white-space:nowrap;
  text-decoration:none !important;
  box-shadow:0 8px 22px rgba(0,0,0,.14);
  transition:all .2s ease;
}
.kakao-header-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(0,0,0,.18);
}
@media(max-width:920px){
  .kakao-header-btn{
    padding:10px 13px;
    font-size:13px;
  }
}
@media(max-width:560px){
  .header-inner{
    gap:8px;
  }
  .kakao-header-btn{
    padding:10px 11px;
    font-size:12px;
  }
}


/* ===== 모바일 헤더/툴바 크기 조정 ===== */
@media(max-width:920px){

  .header-inner{
    padding:12px 16px;
    gap:10px;
  }

  .logo{
    font-size:18px !important;
    gap:8px;
    flex-shrink:0;
  }

  .logo-mark{
    width:32px;
    height:32px;
    border-radius:10px;
    font-size:15px;
  }

  .menu-toggle{
    font-size:24px;
    padding:4px 6px;
    line-height:1;
  }

  .nav.open{
    top:62px;
    padding:12px 16px;
    gap:6px;
  }

  .nav.open a{
    padding:11px 12px;
    font-size:14px;
  }

  .call-btn{
    padding:10px 12px;
  }

  .kakao-header-btn{
    padding:10px 12px;
    font-size:12px;
  }
}

@media(max-width:560px){

  .logo{
    font-size:16px !important;
  }

  .logo-mark{
    width:28px;
    height:28px;
    font-size:13px;
  }

  .menu-toggle{
    font-size:22px;
  }

  .nav.open{
    top:58px;
  }
}


/* ===== 모바일 펼침 메뉴 크기 축소 ===== */
@media(max-width:920px){

  .nav.open{
    top:60px !important;
    padding:8px 12px !important;
    gap:4px !important;
    border-radius:0 0 16px 16px;
  }

  .nav.open a{
    padding:9px 10px !important;
    font-size:13px !important;
    font-weight:600 !important;
    line-height:1.2 !important;
    border-radius:10px !important;
  }

  .nav.open a + a{
    margin-top:2px;
  }
}

@media(max-width:560px){

  .nav.open{
    top:56px !important;
    padding:6px 10px !important;
  }

  .nav.open a{
    padding:8px 10px !important;
    font-size:12px !important;
  }
}


/* ===== 상단 배너 ===== */
.hero-top-badges{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:22px;
}

.area-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.24);
  color:#fff;
  padding:8px 14px;
  border-radius:999px;
  font-size:14px;
  font-weight:800;
  backdrop-filter:blur(8px);

min-height:38px;
line-height:1;
letter-spacing:-0.02em;
}

/* ===== 전화 버튼 강조 ===== */
.call-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:linear-gradient(135deg,#00A6FF,#006BFF) !important;
  color:#fff !important;
  padding:12px 20px;
  border-radius:999px;
  font-weight:900;
  box-shadow:0 10px 28px rgba(0,107,255,.35);
  transition:all .2s ease;
}

.call-btn:hover{
  background:#2E6EAE;
  transform:translateY(-2px);
  box-shadow:0 14px 36px rgba(63,127,191,.4);
}

@media(max-width:560px){

  .area-badge{
    font-size:12px;
    padding:7px 11px;
  }

  .call-btn{
    padding:10px 14px;
  }
}


.call-icon{
  font-size:18px;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transform:scale(1.15);
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.15));
}


/* ===== 상단 배너 동일 크기 ===== */
.hero-top-badges{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.eyebrow,
.area-badge{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:40px !important;
  padding:0 16px !important;
  border-radius:999px !important;
  font-size:14px !important;
  font-weight:800 !important;
  line-height:1 !important;
  white-space:nowrap !important;
  letter-spacing:-0.02em !important;
  box-sizing:border-box !important;
}

@media(max-width:560px){

  .eyebrow,
  .area-badge{
    height:34px !important;
    padding:0 12px !important;
    font-size:12px !important;
  }
}


/* ===== 헤더 버튼 정렬 ===== */
.header-inner{
  display:flex;
  align-items:center;
}

.call-btn,
.kakao-header-btn{
  flex-shrink:0;
}

.call-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px;
  min-height:46px;
  visibility:visible !important;
  opacity:1 !important;
}

.call-text{
  display:inline-block !important;
  white-space:nowrap;
}

.call-icon{
  font-size:18px;
  font-weight:900;
  transform:scale(1.12);
  line-height:1;
}

@media(max-width:920px){

  .call-btn{
    padding:10px 14px !important;
  }

  .call-text{
    display:none !important;
  }
}


/* ===== 전화 아이콘 표시 강제 보정 ===== */
.call-btn .call-phone-icon{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:22px;
  height:22px;
  min-width:22px;
  font-size:20px !important;
  font-weight:900 !important;
  line-height:1 !important;
  color:#fff !important;
  visibility:visible !important;
  opacity:1 !important;
  transform:scale(1.08);
}

.call-btn .call-phone-text{
  display:inline-block !important;
  white-space:nowrap;
  color:#fff !important;
}

@media(max-width:920px){
  .call-btn .call-phone-icon{
    display:inline-flex !important;
  }

  .call-btn .call-phone-text{
    display:none !important;
  }
}


/* ===== 전화 연결 버튼 최종 ===== */
.call-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px;
}

.call-btn .call-phone-icon{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:19px !important;
  line-height:1 !important;
  color:#fff !important;
  transform:scale(1.05);
}

.call-btn .call-phone-text{
  display:inline-block !important;
  color:#fff !important;
  font-weight:900 !important;
  white-space:nowrap;
}

@media(max-width:920px){

  .call-btn .call-phone-text{
    display:inline-block !important;
    font-size:13px !important;
  }

  .call-btn{
    padding:10px 14px !important;
  }
}


/* ===== 헤더 버튼 균형 조정 ===== */
.call-btn,
.kakao-header-btn{
  height:46px !important;
  min-height:46px !important;
  padding:0 18px !important;
  border-radius:999px !important;
  font-size:15px !important;
  font-weight:850 !important;
  box-sizing:border-box !important;
}

.call-btn{
  margin-left:10px !important;
}

.header-inner{
  gap:14px !important;
}

@media(max-width:920px){

  .call-btn,
  .kakao-header-btn{
    height:42px !important;
    min-height:42px !important;
    padding:0 14px !important;
    font-size:13px !important;
  }

  .call-btn{
    margin-left:6px !important;
  }
}


/* ===== 전화 연결 버튼 오른쪽 이동 ===== */
.call-btn{
  margin-left:18px !important;
}

@media(max-width:920px){
  .call-btn{
    margin-left:10px !important;
  }
}


/* ===== 전화 버튼 카카오 바로 옆 정렬 ===== */
.call-btn{
  margin-left:2px !important;
}

.header-inner{
  gap:8px !important;
}

@media(max-width:920px){

  .call-btn{
    margin-left:2px !important;
  }

  .header-inner{
    gap:6px !important;
  }
}


/* ===== FAQ 섹션 (추가) ===== */
.faq-list{max-width:860px;margin:0 auto;display:grid;gap:14px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.2s}
.faq-item[open]{box-shadow:0 12px 32px rgba(31,45,61,.08)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;font-weight:750;font-size:17px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:24px;color:var(--accent);font-weight:600;transition:.2s;flex-shrink:0}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-answer{padding:0 26px 24px;color:var(--soft);font-size:15px;line-height:1.75}

/* ===== 서브페이지 공통 (서비스/지역 페이지) ===== */
.breadcrumb{max-width:1200px;margin:0 auto;padding:18px 28px 0;font-size:14px;color:var(--soft)}
.breadcrumb a{color:var(--accent);font-weight:600}
.breadcrumb span{margin:0 6px;color:var(--line)}
.subpage-hero{background:radial-gradient(circle at 82% 12%,rgba(110,168,217,.28),transparent 34%),linear-gradient(135deg,#172433 0%,#2D4865 60%,#3F7FBF 100%);color:#fff}
.subpage-hero-inner{max-width:1200px;margin:0 auto;padding:64px 28px 58px}
.subpage-hero .eyebrow{margin-bottom:18px}
.subpage-hero h1{font-size:clamp(32px,5vw,56px);line-height:1.14;letter-spacing:-.045em;font-weight:850;margin-bottom:18px}
.subpage-hero h1 span{color:#BFE0FF}
.subpage-hero p{font-size:clamp(16px,2vw,20px);color:rgba(255,255,255,.86);max-width:660px;margin-bottom:30px}
.prose{max-width:860px;margin:0 auto}
.prose h2{font-size:clamp(24px,3vw,34px);letter-spacing:-.04em;margin:0 0 16px;line-height:1.3}
.prose h3{font-size:20px;letter-spacing:-.03em;margin:30px 0 10px}
.prose p{color:#41566B;font-size:16px;margin-bottom:16px;line-height:1.8}
.prose ul.dot{margin:0 0 18px;padding:0}
.prose ul.dot li{padding:7px 0 7px 26px;position:relative;color:#41566B;font-size:15.5px}
.prose ul.dot li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:900}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.related a{display:block;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:20px;font-weight:750;color:var(--ink);transition:.2s}
.related a:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(31,45,61,.1);border-color:var(--accent2)}
.related a small{display:block;color:var(--soft);font-weight:500;font-size:13px;margin-top:6px}
@media(max-width:760px){.related{grid-template-columns:1fr}}
