/* IOTIC Service Modal — v1.3.1 */
/* 전역 폭 흔들림 방지 */
:root { scrollbar-gutter: stable; }

/* 스코프 */
.iotic-svc-root { position: fixed; inset: 0; z-index: 9999; display: none; }
.iotic-svc-root[aria-hidden="false"] { display: block; }

.iotic-svc-backdrop{
  position: absolute; inset: 0;
  background: rgba(17,24,39,.55);
  backdrop-filter: blur(1.5px);
}

.iotic-svc-wrap{
  position: absolute; inset: 0;
  display: grid; place-items: center;
  /* padding: 4vh 16px; */
  padding: 20px 0 0 0;
  overflow: hidden; /* 내부 스크롤은 모달만 */
}

.iotic-svc-card{
  position: relative;
  width: min(960px, 92vw);
  max-width: 100%;
  background: #fff; border-radius: 16px;
  box-shadow: 4px 2px 12px rgba(0, 0, 0, 0.14);
  padding: 24px 30px 28px;
  box-sizing: border-box;
}

/* 닫기버튼 */
.iotic-svc-close{
  position: absolute; top: 30px; right: 22px;
  width: 60px; height: 60px; border-radius: 10px;
  display: grid; place-items: center;
  background: #eef3fb; color: #0b3b78; border: 0; cursor: pointer;
  font-size: 68px; line-height: 0.3;
  z-index: 9999;
}
.iotic-svc-close:hover{ background:#e2ecfa; }

/* ──────────────────────────────────
   타이틀(한글) + 서브(영문) 한 줄 정렬
   + 리드 문구는 그 아래(상단 고정)
   ────────────────────────────────── */
.iotic-svc-header{
  padding: 8px 4px 24px;
  display: block;
}
.iotic-svc-title,
.iotic-svc-sub{
  display: inline-block;           /* ← 한 줄 배치 */
  vertical-align: baseline;
}
.iotic-svc-title{
  margin:0; font-size: clamp(22px, 2.6vw, 40px);
  font-weight: 800; letter-spacing:-0.02em;
}
.iotic-svc-sub{
  margin: 0 0 0 2px;              /* ← 타이틀 오른쪽에 바짝 */
  color:#475569; font-size:24px; font-weight:800;
}

#serviceModal {margin-top: 0;}
/* 모달 헤더 고정 + 그림자 띠 */
#serviceModal .iotic-svc-header {
  position: sticky;     /* 위에 붙어있게 */
  top: 0;
  z-index: 50;
  background: #fff;
  padding-bottom: 30px;
}

/* 헤더 밑으로 전체폭 그림자 만들기 */
#serviceModal .iotic-svc-header::after {
  content: "";
  position: absolute;
  left: -30px;           /* 모달 안쪽 패딩만큼 빼주기 (네가 쓰는 패딩값에 맞춰 조절) */
  right: -30px;
  bottom: 0px;         /* 살짝 아래로 내려서 자연스럽게 */
  height: 0px;
  border-bottom: 1px solid #dddddd;
  /* box-shadow: 0 1px 0px rgba(0,0,0,.12); */
  pointer-events: none;  /* 클릭 막지 않게 */
  /* width: 107%; */
}

#serviceModal .iotic-svc-body{
  margin-top: 0px;
  padding-top: 4px;
  max-height: 70vh;
  overflow: auto;
  padding-right: 16px;
  box-sizing: content-box;
  scrollbar-width: thin;
  scrollbar-color: #2f487f #f0f3fa;
  margin-right: -4px;
  background: #fff;     /* 혹시라도 비치는 거 한번 더 차단 */
}


/* 크롬/엣지/사파리 전용: 스크롤바 트랙 위쪽 여백 */
#serviceModal .iotic-svc-body::-webkit-scrollbar {
  width: 6px;
}

#serviceModal .iotic-svc-body::-webkit-scrollbar-track {
  background: #f0f3fa;
  margin-top: 14px;    /* ← 컨텐츠 padding-top이랑 같은 값 */
  margin-bottom: 14px; /* 필요하면 아래도 */
}

#serviceModal .iotic-svc-body::-webkit-scrollbar-thumb {
  background: #2f487f;
  border-radius: 9999px;
}


/* 본문은 항상 타이틀 아래에서 시작 */
.iotic-svc-body{
  margin-top: 50px;
  max-height: 70vh;
  overflow: auto;
  padding-right: 16px;     /* 내용만 안으로 밀기 */
  box-sizing: content-box; /* 스크롤바는 오른쪽 끝에 두기 */
  scrollbar-width: thin;
  scrollbar-color: #2f487f #f0f3fa;
  margin-right: -20px;
}


/* 리치 콘텐츠 공통 */
.iotic-svc-body img{ max-width:100%; height:auto; display:block; }
.iotic-svc-lead{ color:#334155; margin:6px 0 14px; line-height:1.7; }
.iotic-svc-hero{
  width:100%; height:auto; border-radius:12px;
  display:block; margin:10px 0 40px;
}

.iotic-svc-section{ margin-top:16px; }
.iotic-svc-section h4{ margin:0 0 20px; font-size:30px; }

.iotic-svc-row{
  display:flex; align-items:center; gap:10px;
  margin: 26px 0 20px;
}
.iotic-badge{
  display:inline-block; padding:8px 16px; border-radius:999px;
  font-size:20px; background:#0b3b78; color:#fff; font-weight:700;
}
.iotic-badge.iotic-badge-blue{ background:#0b3b78; }
.iotic-badge.iotic-badge-green{ background:#0b3b78; }

.iotic-row-desc{ color:#334155; font-size:20px; }

/* 콘텐츠 카드(섹션 내) */
.iotic-svc-body .iotic-svc-card{
  /* border:1px solid #e5e7eb; border-radius:12px; */
  padding:12px; display:flex; gap:14px; align-items:center;
  margin: 8px 0 60px; background:#fff;
  max-width: 100%;
  box-sizing: border-box;
}

.iotic-thumb{
  width:min(360px, 40%); height:auto; border-radius:10px; flex:0 0 auto;
  max-width:100%;
}

/* 아이콘 3개 고정 + 텍스트는 아래 */
.iotic-svc-features{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px; width:100%;
}
.iotic-feature{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  /* background:#f8fbff; */
  /* border:1px solid #e6eefb; */
  border-radius:10px;
  padding:12px 10px;
  text-align:center;
}
.iotic-feature > img{
  width:80px; height:80px; object-fit:contain; display:block;
}
.iotic-feature p{
  margin:10px 0 0; color:#1f2937; font-size:18px; line-height:1.1;
}

@media (max-width:784px){
  #serviceModal .iotic-svc-row{
    flex-direction: column;
    align-items: flex-start; /* 가운데로 하고 싶으면 center */
    gap: 8px;
  }

  #serviceModal .iotic-svc-row > *{
    width: 100%;
    margin-top: 10px;
  }

#serviceModal .iotic-badge {padding: 10px 0px;}
.iotic-svc-body {text-align: center;}


}


/* 모바일 */
@media (max-width: 784px){
  .iotic-thumb{ width:100%; }
  .iotic-svc-header {padding: 12px 4px 0px;}
  .iotic-svc-header > p:empty {display:none;}
  .iotic-svc-card{ flex-direction:column; align-items:stretch; }
  .iotic-svc-card:last-child {margin-bottom:10px;}
  .iotic-svc-features{ grid-template-columns: repeat(2, minmax(0,1fr));}
  .iotic-svc-lead {
    margin: 6px 0 0;
    font-size: 14px;
  }

  
  #serviceModal .iotic-svc-card {
    margin: 13px auto 40px;
  }
  .iotic-svc-row {margin-bottom: 30px;}
  #serviceModal .iotic-badge {
    padding: 6px 0px;
    width: 80%;
    margin: 0 auto;
    margin-top: 20px;
    font-size: 16px;
  }

  .iotic-svc-hero {
    margin: 0px;
    margin-top: 0px;
  }

  .iotic-svc-section h4 {
    font-size: 24px;
    margin: 20px 0px 10px;
  }
 .iotic-row-desc {
  font-size: 16px;
 }

  .iotic-svc-close {
    width: 46px;
    height: 46px;
    font-size: 48px;
    z-index: 9999;
    margin-top: -10px;
  }

  .iotic-feature p {
    font-size: 16px;
    margin: 0px;
  }
  
  #serviceModal .iotic-svc-header::after {
    content: "";
    position: absolute;
    left: -20px;
    right: -20px;
    bottom: -30px;
    bottom: 0;
    height: 0;
    border-bottom: 1px solid #dddddd;
    pointer-events: none;
  }

   /* 모달 바깥 래퍼 */
  #serviceModal.iotic-svc-root{padding: 0 !important; overflow: hidden;}

  /* 모달 카드 */
  #serviceModal .iotic-svc-card{max-height: calc(100vh - 24px); margin: 12px auto 50px; display: flex; flex-direction: column; padding: 30px 20px;}
  /* 내용만 스크롤 */
  #serviceModal .iotic-svc-body{
    flex: 1 1 auto;
    overflow-y: auto;
    margin-top: 0;
    padding-top: 14px;
    background: #fff;
  }
  #serviceModal .iotic-svc-wrap {padding: 0 !important; overflow: hidden;}

  #serviceModal .iotic-svc-features{ display:block; }
  #serviceModal .iotic-feature{ display:flex; align-items:center; gap:12px; flex-direction: row;}
  #serviceModal .iotic-feature img{ width:48px; height:auto; flex:0 0 48px; }
  #serviceModal .iotic-feature > *:not(img){ text-align:left; }
#serviceModal .iotic-svc-card > p {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
}

/* 페이지 스크롤 잠금(폭 흔들림 방지 포함) */
body.iotic-svc-modal-open{
  position: fixed;
  left: 0; right: 0;
  overflow-y: scroll;     /* ← 스크롤바 공간 유지 */
  width: 100%;
}


/* 모달 내부 스크롤바 위/아래 삼각형 버튼 제거 */
.iotic-svc-body::-webkit-scrollbar-button,
.iotic-svc-wrap::-webkit-scrollbar-button {
  height: 0;
  display: none;

  
}


@media (max-width: 784px){
  /* br은 안 보이게 */
  #serviceModal .iotic-feature p br {
    display: none;
  }

  /* 자동 줄바꿈도 하지 마 */
  #serviceModal .iotic-feature p {
    white-space: nowrap;
  }
}