
/* =============================
   (주)두노소프트 — soarit 스타일 매칭 CSS
   파일명: style.css
   구조 대상: header.hdr .wrap .logo #gnb.gnb .submenu  .hero .cards .card .ftr
   ============================= */

/* Reset & base */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Apple SD Gothic Neo, Noto Sans KR, Pretendard, Inter, sans-serif;
  color: #111827;
  background: #ffffff;
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul, li { margin: 0; padding: 0; list-style: none; }

/* Layout helpers */
.wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

/* =============================
   Header / GNB
   ============================= */
.hdr {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #ffffff;
  border-bottom: 1px solid #e5e7eb; /* light gray */
}
.hdr .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 92px;
  gap: 34px;
}
.logo img {
  height: 64px; /* 로고 높이 통일 */
  width: auto;
}

/* GNB */
.gnb > ul {
  display: flex;
  align-items: center;
  gap: 4px;
}
.gnb > ul > li {
  position: relative;
}
.gnb > ul > li > a {
  display: block;
  padding: 30px 28px;
  font-size: 20px;
  font-weight: 600;
  color: #1f2937; /* slate-800 */
  transition: color .2s ease, background-color .2s ease;
}
.gnb > ul > li > a:hover,
.gnb > ul > li:hover > a {
  color: #0d47a1; /* primary */
  background: rgba(13, 71, 161, 0.06);
  border-radius: 6px;
}

/* Submenu (dropdown) */
.submenu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  width: 200px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  border-radius: 10px;
  padding: 10px 8px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(6px);
  transition: opacity .18s ease, transform .18s ease;
}
.gnb > ul > li:hover .submenu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.submenu ul > li > a {
  display: block;
  padding: 10px 12px;
  color: #374151; /* slate-700 */
  border-radius: 8px;
  transition: background-color .15s ease, color .15s ease;
  font-weight: 500;
}
.submenu ul > li > a:hover {
  background: #f3f4f6;
  color: #0d47a1;
}

/* =============================
   Hero
   ============================= */
.hero {
  position: relative;
  min-height: 56vh;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.hero > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.05) brightness(.9);
  z-index: -1;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  /*background: linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,.25));*/
  z-index: 0;
}
.hero .caption {
  position: relative;
  z-index: 1;
  text-align: center;
  color: #ffffff;
  padding: 4rem 1rem;
}
.hero .caption h1 {
  font-size: clamp(1.8rem, 4vw, 3rem);
  margin: .25rem 0 .75rem 0;
  line-height: 1.2;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 14px rgba(0,0,0,.35);
}
.hero .caption p {
  font-size: 1.1rem;
  color: #e5e7eb;
  margin: .25rem 0 0 0;
}

/* =============================
   Cards section
   ============================= */
.cards {
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  transition: transform .2s ease, box-shadow .2s ease;
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0,0,0,.08);
}
.card > img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.card h3 {
  margin: 12px;
  text-align: center;
  font-size: 1.5rem;
  color: #1f2937;
}
/* ===== Business Area 카드: 이미지 좌, 텍스트 우 ===== */
.card_b {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 18px;
}

.card_b > img {
  flex: 0 0 480px;       /* 고정 폭(원하는 폭으로 조정 가능) */
  height: 320px;         /* 고정 높이 */
  object-fit: cover;
  border-radius: 10px;   /* 이미지 모서리도 살짝 둥글게(옵션) */
}

.card_b__content {
  flex: 1 1 auto;
  min-width: 0;
}

.card_b__content h3 {
  margin: 4px 0 10px 0;
  font-size: 1.8rem;     /* 기존 카드 제목 크기와 조화 */
  text-align: center;      /* 가운데 정렬 → 좌측 정렬로 변경 */
}

.card_b__content dl {
  margin: 0;
}

.main-a__biz-data {
  margin: 0 0 6px 0;
  color: #374151;
  line-height: 1.5;
}

/* 모바일 대응 */
@media (max-width: 860px) {
  .card_b {
    flex-direction: column;
    align-items: flex-start;
  }
  .card_b > img {
    width: 100%;
    height: 200px;
  }
  .card_b__content h3 {
    font-size: 1.35rem;
  }
}


/* =============================
   Footer
   ============================= */
.ftr {
  background: #0f172a;
  color: #94a3b8;
  margin-top: 48px;
}
.ftr .wrap {
  padding: 20px 16px;
  text-align: center;
}

/* =============================
   Responsive
   ============================= */
@media (max-width: 1024px) {
  .gnb > ul > li > a { padding: 18px 14px; }
  .submenu { width: 190px; }
  .hero { min-height: 48vh; }
}

@media (max-width: 860px) {
  .hdr .wrap {
    flex-wrap: wrap;
    gap: 8px 16px;
    padding: 10px 0;
    height: auto;
  }
  .logo img { height: 38px; }
  .gnb { width: 100%; }
  .gnb > ul { justify-content: space-between; flex-wrap: wrap; }
  .gnb > ul > li { flex: 1 1 auto; }
  .gnb > ul > li > a { padding: 12px; text-align: center; }
  .submenu {
    position: static;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    box-shadow: none;
    border: 0;
    padding: 0;
    width: 100%;
  }
  .submenu ul { display: flex; gap: 6px; padding: 8px 0 0 0; }
  .submenu ul > li { flex: 1 1 auto; }
  .submenu ul > li > a { padding: 10px; text-align: center; background: #f9fafb; }
  .submenu ul > li > a:hover { background: #eef2ff; }
  .cards { grid-template-columns: 1fr; }
  /*.hero .caption { padding: 2.5rem 1rem; }*/
}


/* Hide '서비스 살펴보기' button/link in hero section */
.hero .caption a,
.hero .caption button {
  display: none !important;
}

/* 1) hover-틈 제거 & 접근성 강화 */
.gnb > ul > li { position: relative; }

/* hover에서 li 아래에 보이지 않는 브릿지(12px) 추가: 마우스가 내려갈 때 hover가 끊기지 않음 */
.gnb > ul > li::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  height: 12px;       /* 브릿지 높이 */
}

/* 2) 서브메뉴 위치를 정확히 붙이기 (gap 제거) */
.submenu {
  top: 100% !important;   /* calc(100% + 8px) → 100%로 */
  margin-top: 0 !important;
  transform: none;        /* translateY 제거 */
  z-index: 1000;          /* 헤더 위에 떠 있도록 */
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease; /* transform 트랜지션은 삭제 */
}

/* 3) 보여줄 때 상태(hover + 키보드 포커스 + 클릭 토글용 .open) */
.gnb > ul > li:hover .submenu,
.gnb > ul > li:focus-within .submenu,
.gnb > ul > li.open .submenu {
  opacity: 1;
  pointer-events: auto;
}

/* ===== Business Area: 이미지/텍스트를 박스로 분리 & 중앙 정렬 ===== */
.card_b{
  display:grid;
  grid-template-columns: 1fr 1fr;   /* 좌:이미지박스 / 우:텍스트박스 */
  gap: 24px;
  align-items: stretch;
  max-width: 1100px;
  margin: 28px auto;                /* 화면 중앙 배치 */
  padding: 0 12px;
}

.card_b__box,
.card_b__panel{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:16px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 220px;                /* 두 박스 높이 균형 */
}

/* 이미지 박스 내부 이미지 맞춤 */
.card_b__box img{
  width:100%;
  height:100%;
  object-fit:cover;                  /* 필요 시 contain 으로 변경 */
  border-radius:12px;
}

/* 텍스트 패널 타이틀/목록 정돈 */
.card_b__panel h3{
  width:38%;
  margin: 4px 0 12px 0;
  font-size:1.35rem;
  text-align:left;
}
.card_b__panel dl{ width:100%; margin:0; }
.main-a__biz-data{ margin:0 0 8px 0; color:#374151; line-height:1.6; }

/* 반응형: 좁은 화면에선 세로 스택 */
@media (max-width: 860px){
  .card_b{
    grid-template-columns: 1fr;
    gap:16px;
    margin:20px auto;
  }
  .card_b__box, .card_b__panel{ min-height: auto; }
  .card_b__box img{ height: 200px; object-fit: cover; }
}

/* --- 모바일 메뉴 안정화 패치 --- */
@media (max-width: 860px) {
  /* 0) 전체 가로 스크롤 방지 */
  html, body { overflow-x: hidden; }

  /* 1) 상단 영역 정렬 안정화 */
  .hdr .wrap { align-items: stretch; }

  /* 2) GNB를 세로형으로 바꾸고 칸격 균일화 */
  .gnb { width: 100%; }
  .gnb > ul {
    display: flex;
    flex-direction: column;   /* 세로 스택 */
    gap: 6px;
  }
  .gnb > ul > li { width: 100%; }

  /* 3) 버튼(상위 메뉴) 터치 영역 축소 & 폰트 다운 → 줄바꿈/삐뚤림 방지 */
  .gnb > ul > li > a {
    padding: 14px 12px;       /* 기존 30px → 14px */
    font-size: 16px;          /* 기존 20px → 16px */
    line-height: 1.2;
    text-align: left;         /* 좌측 정렬(원하면 center로) */
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
  }

  /* 4) 모바일에선 서브메뉴 항상 펼치지 말고 기본은 숨김 */
  .submenu {
    position: static;         /* 오버레이 제거 */
    display: none;            /* 기본 숨김 */
    opacity: 1;
    pointer-events: auto;
    transform: none;
    border: 0;
    box-shadow: none;
    padding: 6px 0 0 0;
    width: 100%;
    margin: 0;
  }
  /* 클릭(.open) 또는 키보드 포커스 시에만 펼침 */
  .gnb > ul > li.open .submenu,
  .gnb > ul > li:focus-within .submenu { display: block; }

  /* 5) 서브메뉴 항목은 세로 나열 & 줄바꿈 허용 */
  .submenu ul { display: block; }
  .submenu ul > li > a {
    display: block;
    padding: 10px 12px;
    background: #f9fafb;
    border-radius: 8px;
    margin-bottom: 4px;
  }

  /* 6) 데스크톱용 hover-브릿지는 모바일에서 비활성화(깜빡임 방지) */
  .gnb > ul > li::after { display: none; }
}

