@charset "UTF-8";
/* hanbom.com _ project _ name _ yymmdd */

/* for Developer */
.sub.publications .total-area + #data-form {border-top: 1px solid var(--bluegray-dark); padding-top: 40px; margin-top: 16px;}
.sub.publications.list #data-form + div {margin-top: 60px;}
@media all and (max-width: 768px) {
    .sub.publications.list #data-form + div {margin-top: 30px;}
    .sub.publications .total-area + #data-form {padding-top: 30px; margin-top: 20px;}
}

.article-body .text-wrap *:not(img):not(figure *) em{font-style: italic;}

/* page search */
.sub.search{}
.sub.search .search-color{color: var(--blue); font-weight: 700}
.sub.search #data-form .search-form{ max-width: 820px; margin: 0 auto;}
.sub.search #data-form .search-form .input-text{background-color: var(--white); color: #000; caret-color: #000;}
.sub.search .button-area.pack-center{margin-top: clamp(24px,6.4vw,40px); flex-wrap: wrap;}
.sub.search .button-area.pack-center .btn.keywords{padding-inline: 16px; height: clamp(32px,8.53vw,40px); font-size: clamp(14px,3.73vw,16px); border-radius: 100px; background-color: var(--dark-gray)}

.sub.search #data-form + .content-wrap{margin-top: 120px}

.sub.search .item.normal{ background-color: var(--dark-gray); }
.sub.search .item.normal:not(.thumnail) .text-wrap{ background-color: var(--dark-gray); gap:10px;}
.sub.search .item.normal .text-wrap .title{}
.sub.search .item.normal .text-wrap .text{font-weight: 400}

.sub.search .title-wrap .section-title{ font-weight: 400; margin-right: 6px;}
.sub.search .title-wrap .count{padding: 10px 15px; background-color: var(--blue); border-radius: 25px; line-height: 1;}
.sub.search .title-wrap .btn.page-more{ }
.sub.search .title-wrap + .pack-down,
.sub.search .title-wrap + .data-list,
.sub.search .title-wrap + .board-list,
.sub.search .data-list + .button-area{margin-top: 40px;}
.sub.search .button-area{}
.sub.search .button-area .btn.more{padding: 10px 20px; background-color: var(--blue); border-radius: 100px; font-size: 18px;}


.sub.search .section.news .data-list li{display: none;}
.sub.search .section.news .item{height: 100%;}
.sub.search .section.news .item:hover .text-wrap > .title{color: var(--white)}

.sub.search .pack-down{
    display: flex; flex-direction: column;
}
.sub.search .pack-down .section-title.small{font-weight: 500;}


@media all and (max-width: 768px) {
    .sub.search #data-form + .content-wrap{margin-top: 30px}
    .sub.search .title-wrap + .pack-down,
    .sub.search .title-wrap + .data-list,
    .sub.search .title-wrap + .board-list,
    .sub.search .data-list + .button-area{margin-top: 20px;}
    .sub.search .button-area .btn.more{font-size: 16px;}
    .sub.search .title-wrap .count{padding: 8px 14px}
}

/* 20250110  Ctrl + F 사용을 위한 수정 */
body{ -ms-overflow-style: none; }
::-webkit-scrollbar { display: none; }
/* // 20250110  Ctrl + F 사용을 위한 수정 */

/* 20250113 메인 뉴스 버튼 수정 */
.main .section.news .title-wrap.flex-both .section-title.large{ width: auto; }

/* 20250331 스팩 팝업수정 */
#popupSpec2 .img-wrap{max-height: none;}


#wrap.dark input{caret-color: white;}

/* Download CTA - 내부 요소만 중앙 정렬 */
.section.download-cta .gutter-100 {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    width: 100% !important;
}

/* 버튼 영역 마진 확보 */
.section.download-cta .button-area {
    display: flex;
    justify-content: center;
    width: 100%;
}

/* System Requirements - 전체 박스 레이아웃 (넓게 확장) */
.section.sysreq .sysreq-box {
    background-color: #f8f9fa;
    padding: 60px 80px !important; /* 내부 여백 충분히 확보 */
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box;
    display: block !important; /* 레이아웃 꼬임 방지 */
}

/* 제목 잘림 현상 수정 */
.section.sysreq .spec-title {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 35px;
    color: #000;
    text-align: left;
    display: block;
    overflow: visible; /* 글자 잘림 방지 */
}

/* 리스트 정렬 최적화 */
.section.sysreq .spec-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.section.sysreq .spec-list li {
    display: flex;
    align-items: flex-start;
    font-size: 16px;
    line-height: 1.8;
    margin-bottom: 12px;
    text-align: left;
}

/* 불렛(·) 고정 너비로 배치 */
.section.sysreq .spec-list li::before {
    content: "·";
    font-weight: bold;
    width: 25px; /* 불렛 영역 고정 */
    flex-shrink: 0;
    color: #000;
}

/* 레이블(CPU, RAM 등) 너비 고정하여 줄맞춤 */
.section.sysreq .spec-list li strong {
    width: 180px; /* 이 수치를 조절하여 레이블과 값 사이 간격 조정 */
    flex-shrink: 0;
    font-weight: 700;
    color: #000;
    display: inline-block;
}

/* 실제 사양 값 스타일 */
.section.sysreq .spec-list li span,
.section.sysreq .spec-list li {
    color: #555;
    flex: 1; /* 남은 공간 모두 차지 */
    word-break: keep-all;
}

/* 하단 노트 스타일 */
.section.sysreq .spec-note {
    margin-top: 30px;
    font-size: 14px;
    color: #888;
    line-height: 1.6;
    display: block;
}
/* 모바일 환경 대응 (tomocube_dev.css 하단 추가) */
@media all and (max-width: 768px) {
    /* 1. Download CTA 버튼 텍스트 오버플로우 및 크기 수정 */
    .section.download-cta {
        padding: 40px 20px !important;
    }
    .section.download-cta .button-area .btn {
        font-size: 15px !important; /* 모바일용 폰트 크기 축소 */
        padding: 16px 20px !important;
        height: auto !important;
        white-space: normal !important; /* 버튼 텍스트 줄바꿈 허용 */
        word-break: keep-all;
        line-height: 1.4;
        width: 100%; /* 버튼을 화면 너비에 맞게 확장 */
        box-sizing: border-box;
    }

    /* 2. System Requirements 레이아웃 최적화 */
    .section.sysreq .sysreq-box {
        padding: 30px 20px !important; /* 내부 여백 축소 */
    }
    .section.sysreq .spec-title {
        font-size: 20px;
        margin-bottom: 20px;
    }
    .section.sysreq .spec-list li {
        display: block !important; /* Flex 가로 정렬 해제 */
        margin-bottom: 15px;
        line-height: 1.6;
    }
    .section.sysreq .spec-list li::before {
        width: auto !important;
        display: inline !important;
        margin-right: 6px;
    }
    .section.sysreq .spec-list li strong {
        width: auto !important; /* 180px 고정 너비 해제 */
        display: inline !important;
        margin-right: 8px;
    }
}
.section.use-cases .use-cases-list {
    display: flex;
    flex-direction: column;
    gap: 50px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.section.use-cases .use-case-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    background: #f8f9fa;
    padding: 50px 60px;
    gap: 60px;
}

.section.use-cases .use-case-text {
    flex: 1;
    text-align: left;
}

.section.use-cases .use-case-text .title {
    font-size: 36px;
    font-weight: 700;
    margin-bottom: 25px;
    color: #000;
    line-height: 1.3;
    word-break: keep-all;
    display: block;
}

.section.use-cases .use-case-text .text-box .text {
    font-size: 16px;
    line-height: 1.7;
    color: #444;
}

.section.use-cases .use-case-img {
    flex: 1;
    max-width: 50%;
    overflow: hidden;
    display: flex;
}

.section.use-cases .use-case-img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
}

/* 모바일 환경 대응 */
@media all and (max-width: 768px) {
    .section.use-cases .use-case-card {
        flex-direction: column;
        padding: 30px 20px;
        gap: 30px;
    }
    .section.use-cases .use-case-img {
        max-width: 100%;
    }
    .section.use-cases .use-case-text .title {
        font-size: 26px;
    }
}

/* Hero 타이틀 반응형 크기 조절 및 줄바꿈 오류 보정 */
.section.model .model-title {
    /* 뷰포트 너비에 따라 50px ~ 84px 사이에서 자동으로 크기 변환 */
    font-size: clamp(50px, 5vw + 10px, 84px) !important; 
    word-break: keep-all !important;
}

/* 상표 기호(™) 분리 현상 완벽 해결 */
.section.model .model-title {
    /* 기존 코드 유지 */
    font-size: clamp(50px, 5vw + 10px, 84px) !important; 
    word-break: keep-all !important;
    overflow-wrap: break-word !important; /* 긴 단어 강제 줄바꿈 방지 보완 */
}

/* 기호가 앞 단어에 완전히 종속되도록 수정 */
.section.model .model-title em.sign {
    display: inline !important; /* 블록 취급 해제 */
    vertical-align: super !important; /* 위첨자 정렬 */
    font-size: 0.5em !important; /* 기호 크기 조정 (필요에 따라 0.5~0.6em 사용) */
    line-height: 0 !important; /* 기호가 전체 줄간격에 영향을 주지 않도록 차단 */
    margin-left: 2px !important; /* 단어와의 미세 간격 조정 */
}
/* 1200px 이하 해상도 (작은 랩탑 등) 여백 최적화 */
@media all and (max-width: 1200px) {
    .section.model .gutter-100.flex-960 {
        gap: 40px !important; /* 기존 60px에서 축소하여 텍스트 공간 확보 */
    }
}

/* 992px 이하 태블릿 해상도: 강제 세로(1단) 배치로 전환하여 레이아웃 붕괴 원천 차단 */
@media all and (max-width: 992px) {
    .section.model .gutter-100.flex-960 {
        flex-direction: column !important;
        gap: 30px !important;
    }
    .section.model .view-sticky.img-content,
    .section.model .detail-wrap {
        flex: none !important;
        width: 100% !important;
    }
    .section.model .detail-wrap {
        text-align: center; /* 세로 배치 시 안정감을 위해 중앙 정렬 */
    }
    .section.model .model-title {
        text-align: center;
    }
}
/* System Requirements - 단일 박스 세로(상하) 배치 레이아웃 */
.section.sysreq .sysreq-box {
    display: flex !important;
    flex-direction: column !important; /* 세로 방향으로 나열 */
    gap: 50px !important; /* 위아래 그룹 간격 */
    padding: 60px 80px !important; 
    background-color: #f8f9fa !important;
    width: 100% !important;
    max-width: none !important;
}

.section.sysreq .spec-group {
    width: 100% !important;
}

/* 두 사양 사이의 구분선 스타일 */
.section.sysreq .spec-divider {
    border: 0;
    border-top: 1px solid #e0e0e0; /* 연한 회색 선 */
    width: 100%;
    margin: 0;
}

/* 글로벌 CSS의 좌측 여백/정렬 속성을 완전히 덮어씌우는 최상위 우선순위(ID) 중앙 정렬 */

/* 카드 3개 묶음 전체를 화면 중앙(가운데)으로 정렬 */
.section.benefit .content-list {
    display: flex !important;
    justify-content: center !important; /* 부모 컨테이너 기준 중앙 배치 */
    gap: 30px !important; /* 카드 사이의 여백 (기존 레이아웃 유지) */
}
/* 모바일/태블릿 (992px 이하) 슬라이더 3번째 카드 누락 오류 해결 */
@media all and (max-width: 992px) {
    .section.benefit .content-list {
        justify-content: flex-start !important; /* Swiper 기본 위치 계산 축으로 복구 */
        gap: 0 !important; /* 슬라이드 너비 계산과 충돌하는 CSS 간격 강제 제거 */
    }
}
/* 상단 대문 영역 회색 박스 크기 복구 (이전 코드 삭제 후 적용) */
.section.model .view-sticky.img-content .img-area {
    width: 100% !important;
    max-width: none !important; /* 회색 박스는 다시 100% 채움 */
}

/* 회색 박스 안쪽의 실제 이미지만 크기 축소 및 정중앙 배치 */
.section.model .product-gallery .swiper-slide {
    display: flex !important;
    justify-content: center !important; /* 가로 중앙 */
    align-items: center !important;     /* 세로 중앙 */
    height: 100% !important;           /* 슬라이드 높이 꽉 채움 */
}

.section.model .product-gallery .swiper-slide .img-wrap {
    width: 70% !important; /* 이미지 크기를 회색 박스 대비 70%로 축소 (원하는 수치로 조절 가능) */
    height: auto !important;
    max-height: 80% !important; /* 이미지가 위아래로 너무 꽉 차는 것 방지 */
    margin: 0 auto !important;  /* 가로 중앙 정렬 */
    /* 내부 이미지 정렬 */
    display: flex !important;
    justify-content: center;
    align-items: center;
}

.section.model .product-gallery .swiper-slide .img-wrap img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important; /* 비율 유지하며 축소 영역에 맞춤 */
    display: block !important;
}
/* ============================================
   App Note 카드 - 중간 해상도 가독성 보정
   2026-04-15 추가 (제목이 썸네일 가리는 문제)
   ============================================ */
/* App Note 카드 - 해상도별 제목 폰트/패딩 보정 */

/* 태블릿 세로 */
@media all and (min-width: 769px) and (max-width: 960px) {
  .sub.resources.app-note .item.thumnail .title { font-size: 14px; line-height: 1.3; word-break: keep-all; }
  .sub.resources.app-note .item.thumnail .text-wrap { padding: 20px; }
}

/* 태블릿 가로 ~ 소형 노트북 */
@media all and (min-width: 961px) and (max-width: 1280px) {
  .sub.resources.app-note .item.thumnail .title { font-size: 16px; line-height: 1.3; word-break: keep-all; }
  .sub.resources.app-note .item.thumnail .text-wrap { padding: 24px; }
}

/* 일반 노트북 */
@media all and (min-width: 1281px) and (max-width: 1600px) {
  .sub.resources.app-note .item.thumnail .title { font-size: 18px; line-height: 1.3; word-break: keep-all; }
  .sub.resources.app-note .item.thumnail .text-wrap { padding: 32px; }
}