@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css");


/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #1428a0;
	--color-main-a2: #1428a033;
	--color-blue: #00A8FF;
	--color-ice: #91EEFF;
	--color-mint: #00C7C7;
	--color-white-a05: rgba(255, 255, 255, 0.05);
	--color-white-a1: rgba(255, 255, 255, 0.1);
	--color-white-a2: rgba(255, 255, 255, 0.2);
	--color-white-a4: rgba(255, 255, 255, 0.4);
	--color-white-a6: rgba(255, 255, 255, 0.6);
	--color-white-a8: rgba(255, 255, 255, 0.8);
	--color-white-a9: rgba(255, 255, 255, 0.9);
	--color-black-a05: rgba(0, 0, 0, 0.05);
	--color-black-a1: rgba(0, 0, 0, 0.1);
	--color-black-a2: rgba(0, 0, 0, 0.2);
	--color-black-a4: rgba(0, 0, 0, 0.4);
	--color-black-a6: rgba(0, 0, 0, 0.6);
	--color-black-a8: rgba(0, 0, 0, 0.8);
	--color-black-a9: rgba(0, 0, 0, 0.9);
	--gradient-blue: linear-gradient(95deg, var(--color-blue) -24%, #113EB0 98%, var(--color-main) 123%);
	--gradient-mint: linear-gradient(95deg, var(--color-blue) -24%, var(--color-mint) 75%);
	--box-shadow-3: 0 0 3rem rgba(0, 0, 0, 0.15);
	--font-16: max(14px, calc(0.67rem + 9.3px));   /*  16  15.3  14.6  14    */
	--font-18: calc(1rem + 8px);                   /*  18  17    16    15    */
	--font-20: max(17px, calc(1.1rem + 9px));      /*  20  18.9  17.8  17    */
	--font-23: calc(1.5rem + 8px);                 /*  23  21.5  20    18.5  */
	--font-25: calc(1.7rem + 8px);                 /*  25  23.3  21.6  19.9  */
	--font-32: calc(2rem + 12px);
	--scroll-width: 0px;
	--inner-width: calc(100vw - var(--scroll-width));
	--inner-padding: max(30px, calc(((var(--inner-width)) - 1400px) / 2));
	--outer-padding: min(var(--inner-padding), 50px);
	--font-pretendard: Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-montserrat: 'Montserrat', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-dotum: '돋움', dotum, sans-serif;
	font-size: 10px;
}
html::-webkit-scrollbar {width: 8px; background-color: #eee;}
html::-webkit-scrollbar-thumb {background-color: #444;}
body {--header-height: 90px; --right-deco: 93px; background-color: #eee; font: 16px/1.2 Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif; letter-spacing: -0.025em; color: #666; --inner-right-padding: max(var(--inner-padding), calc(30px + var(--outer-padding) + var(--right-deco) * 0.35));}
body:where(.is-fix) {--header-height: 70px;}
.is-open {overflow: hidden !important; padding-right: var(--scroll-width) !important;}
.inner {position: relative; margin-left: var(--inner-padding); margin-right: var(--inner-right-padding);}
#wrap {background-color: #fff;}

/* 오른쪽 장식 */
[class*=right-deco] {position: relative;}
[class*=right-deco]::after { position: absolute; right: var(--outer-padding); bottom: 0; width: var(--right-deco); background-color: #fff;content: ''; pointer-events: none;}
.right-deco-symbol::after { height: 54px; mask: url(../images/common/symbol_optimized.svg) no-repeat right bottom/contain; -webkit-mask: url(../images/common/symbol_optimized.svg) no-repeat right bottom/contain;}
.right-deco-line::after { height: 100%; mask: url(../images/common/symbol_line.svg) repeat-y right/contain; -webkit-mask: url(../images/common/symbol_line.svg) repeat-y right/100%;}

/* 공통 텍스트 스타일 */
.txt-bg { display: inline-block; background-color: var(--color-main); letter-spacing: normal; color: #fff; font-weight: 600;}
.txt-rect {font-weight: 400; font-family: var(--font-dotum); color: #fff; transform: translateY(-0.1em); display: inline-block;}
.txt-rect b { padding: 0.04em 0.13em; border-radius: 0.175em; background-color: var(--color-main); font-size: 0.75em; display: inline-block; letter-spacing: normal; text-indent: 0;}
.txt-rect b:not(:last-child) {margin-right: 0.15em;}
.txt-rect b:first-child {border-top-left-radius: 0;}
.txt-rect b:last-child {border-bottom-right-radius: 0;}
.txt-border {--bw: calc(1rem - 5px); display: block; width: fit-content; padding: 0.05em 0; border: solid var(--color); border-width: var(--bw) 0; color: var(--color);}

/* 글머리 기호 */
[class|="mark"] { display: flex; column-gap: 0.4em;} 
[class|="mark"] + [class|="mark"] { margin-top: 0.4em; } 
[class|="mark"]::before { flex-shrink: 0; content: "";}
.mark-hyphen::before {width: 0.4em; height: 3px; background-color: var(--color-main); margin-top: 0.6em; transform: translateY(-55%);}

@media (max-width: 1280px) { 
	:root { --inner-padding: 25px; font-size: 9px;} 
	body { --header-height: 70px; --right-deco: 62px; --inner-right-padding: calc(var(--inner-padding) * 2 + var(--right-deco) * 0.35)}
}
@media (max-width: 1024px) {	
	body { --right-deco: 0px; --inner-right-padding: var(--inner-padding);}
	[class*=right-deco]::after {display: none;}
}
@media (max-width: 768px) {	
	:root {	--inner-padding: 20px; font-size: 8px;} 
	body { --header-height: 64px;} 
	[class*=right-deco]::after {display: none;}
}
@media (max-width: 480px) {	
	:root {font-size: 7px; --box-shadow-3: 0 0 3rem rgba(0, 0, 0, 0.1);} 
	body { --header-height: 58px;} 
}
@media (max-width: 360px) {	:root {--inner-padding: 15px;} }
/* 기본 스타일 ========================================== */
/* ===================================================== */


/* ===================================================== */
/* HEADER ============================================== */
.header {position: absolute; inset: 0 0 auto; z-index: 1000;} 
.header-inner { display: flex; justify-content: space-between; align-items: center; position: fixed; z-index: 1100; width: 100%; height: var(--header-height); padding-left: var(--outer-padding); transition: .3s linear, padding 0s;} 
.header-inner::before { position: absolute; inset: 0; background-color: transparent; content: ''; transition: .3s linear; border-bottom: 1px solid var(--color-white-a1);} 
.is-open .header-inner {padding-right: var(--scroll-width);}
:is(.is-hover, .is-fix):not(.is-open) .header-inner::before { border-color: #ddd; background-color: #fff;}

/* 로고 */
.header-logo { position: relative; width: 15.8rem; margin-right: auto; transition: .3s linear;} 
.header-logo img {transition: opacity .3s linear;}
.header-logo #header-logo {opacity: 0; position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: contain;}
:is(.is-hover, .is-fix) #header-logo { opacity: 1; } 
:is(.is-hover, .is-fix) #header-logo-white { opacity: 0; }

/* GNB */
.gnb { --gnb-height: 5.3125em; font-weight: 800; transition: .3s;}
/* ▼ gnb-bg */
.gnb::before { position: absolute; inset: 100% 0 auto; height: var(--gnb-height); border-top: 1px solid #eee; background-color: #fff;content: ''; transform: scaleY(0); transform-origin: top; transition: .3s;}
.gnb-wrap { display: flex; margin-right: min(4vw, 90px); } 
.depth1 { position: relative; } 
.depth1 > a { padding: 0 2.1vw; font-size: 2rem; color: #fff; font-weight: 600;}
.depth1 > a span { display: block; position: relative; line-height: var(--header-height); letter-spacing: normal; white-space: nowrap; transition: color .3s;} 
.depth1 > a span::before { position: absolute; top: 100%; width: 100%; padding-top: 0.35em; border: solid var(--color-main); border-width: 0.25em 0; content: ''; transform: scaleX(0); transform-origin: left; transition: .3s;}
.depth2 { display: none; position: absolute; top: var(--header-height); left: 0;}
.depth2 ul {display: flex;}
.depth2 a { padding: 0 1.7vw; line-height: var(--gnb-height); white-space: nowrap; transition: color .2s;} 
.depth1:last-child .depth2 { right: 0; left: auto;}

.is-open .gnb { visibility: hidden; opacity: 0; } 
:is(.is-hover, .is-fix) .depth1 > a {color: #222; font-weight: 700;}

/* 유틸 */
.header-util { display: flex; align-self: stretch; z-index: 5; width: 10.5rem; position: relative;} 
.header-util::before {position: absolute; content: ''; width: 100%; height: 100%; left: 0; top: 0; background-color: var(--color-main);}
.is-open .header-util::before {width: calc(100% + var(--scroll-width));}

/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width: 23px; height: 23px; margin: auto;} 
.util-allmenu-btn::before { position: absolute; top: 0; right: 0; width: 7px; height: 5px; background: url(../images/common/chevron_w7.svg) no-repeat center; content: ''; transition: .3s;}
.util-allmenu-btn span { position: absolute; top: 10px; left: 0; width: 23px; height: 2px; background-color: #fff; transition: .3s;} 
.util-allmenu-btn span:nth-child(1) { width: 14px; transform: translateY(-8px); } 
.util-allmenu-btn span:nth-child(3) { transform: translateY(8px); } 
.is-open .util-allmenu-btn::before { transform: scaleY(0);}
.is-open .util-allmenu-btn span { width: 31px; transform: rotate(45deg) translate(-3px, 3px); } 
.is-open .util-allmenu-btn span:nth-child(2) { opacity: 0; } 
.is-open .util-allmenu-btn span:nth-child(3) { transform: rotate(-45deg) translate(-3px, -3px); } 

/* dim */
.gnb-dim { opacity: 0; position: fixed; inset: 0; z-index: 900; background-color: var(--color-black-a6); transition: opacity .3s; pointer-events: none; } 
.is-hover .gnb-dim { opacity: 1; } 

@media (hover: hover) and (pointer: fine) {
	.is-hover .gnb::before {transform: scaleY(1);}
	.depth1:hover > a span { color: var(--color-main); } 
	.depth1:hover > a span::before {transform: scaleX(1);}
	.depth2 a:hover {color: #222;}
	.util-allmenu-btn:hover::before { opacity: 0; transform: scaleY(0);}
	body:not(.is-open) .util-allmenu-btn:hover span:nth-child(1) {width: 23px;}
}
@media (max-width: 1024px) {
	.gnb { display: none; } 
}
@media (min-width: 769px) {
	.is-open .header-inner::before {opacity: 0;}
	.is-open .header-logo { visibility: hidden; opacity: 0;}
}
@media (max-width: 768px) {
	.is-open .header-inner::before {border-color: #ddd; background-color: #fff; transition: 0s;}
	.is-open #header-logo { opacity: 1; } 
	.is-open #header-logo-white { opacity: 0; }
}
@media (max-width: 375px) {
	.header-util {width: var(--header-height);} 
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* HEADER - 전체메뉴 =================================== */
.allmenu { --link-padding: 18%; visibility: hidden; overflow: hidden; position: fixed; z-index: 1000; width: calc(100% + var(--scroll-width)); height: 100%; } 
.allmenu-wrap { overflow: hidden; position: relative;height: 100%; background: linear-gradient(to bottom, #fff 70vh, transparent) , url(../images/common/allmenu_bg.jpg) no-repeat center bottom/cover; transform: translateY(-100%); transition: .5s;}
.allmenu-wrap::before {opacity: 0; position: absolute; right: 0; bottom: -0.4rem; z-index: 5; width: 50%; height: 30vh; background: url(../images/common/logo_long.svg) no-repeat right bottom/contain; content: ''; transform: translateY(100%); transition: transform .5s, opacity .5s;}
.allmenu-cont { overflow: hidden auto; opacity: 0; position: relative; height: 100%; padding-top: calc(var(--header-height) + 7vh + 3.5rem); transition: .5s; } 
.allmenu-cont::-webkit-scrollbar { width: 6px; } 
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); } 
.allmenu-list { display: flex;  max-width: 1400px; margin: 0 auto 12vh;} 

.is-open .allmenu { visibility: visible; width: 100%;} 
.is-open .allmenu-wrap {transform: translateY(0); }
.is-open .allmenu-wrap::before {opacity: 0.6; transform: translateY(0);}
.is-open .allmenu-cont {opacity: 1;}

.all-depth1 { flex: 1; letter-spacing: normal;} 
.all-depth1:not(:last-child) {border-right: 1px solid #eee;}
.all-depth1-btn { position: relative; width: 100%; padding: 0.2em var(--link-padding) 1.5em; font-weight: 800; font-size: 4.2rem; text-align: left; color: #222; white-space: nowrap; transition: color .5s; cursor: default;}
.all-depth1-btn::before,
.all-depth1-btn::after {position: absolute; inset: auto 0 0; padding-top: 4px; border: solid #eee; border-width: 5px 0; content: ''; }
.all-depth1-btn::after { opacity: 0;border-color: var(--color-main); transform: scaleX(0); transform-origin: left; transition: .5s;}
.all-depth2 { padding: 2.2em 0; font-size: 18px;} 
.all-depth2-btn { padding: 0.8em var(--link-padding); font-weight: 700; } 
.all-depth2-btn:hover {background-color: var(--color-main); color: #fff;}

@media (hover: hover) and (pointer: fine) {
	.all-depth1:hover .all-depth1-btn {color: var(--color-main);}
	.all-depth1:hover .all-depth1-btn::after { opacity: 1;transform: scaleX(1);}
}
@media (max-width: 1280px) {
	.all-depth2 {font-size: 17px;}
 } 
@media (max-width: 1024px) {
	.allmenu { --link-padding: 15%; }
	.allmenu-wrap::before {right: 4%; width: 92%; bottom: -0.5%; }
	.is-open .allmenu-wrap::before {opacity: 0.3;}
	.all-depth1-btn {font-size: 3.5vw;}
	.all-depth2 { font-size: 16px; padding: calc(1em + 1.5vw) 0; } 
 } 
@media (max-width: 768px) { 
	.allmenu-wrap { --link-padding: max(5%, 15px); background-color: var(--color-white-a4); background-blend-mode: overlay; }
	.is-open .allmenu-wrap::before { display: none;}
	.allmenu-cont::-webkit-scrollbar { width: 0; } 
	.allmenu-list { display: block; } 
	.allmenu .all-depth1 { border-right: 0;} 
	.all-depth1-btn { cursor: pointer; padding-top: calc(1.5em - 14px); font-size: calc(15px + 1.3vw);} 
	.all-depth1-btn span {display: flex; justify-content: space-between; align-items: center; width: 100%;}
	.all-depth1-btn span::after { flex-shrink: 0; width: 18px; height: 10px; mask-image: url(../images/common/chevron_w18.svg); -webkit-mask-image: url(../images/common/chevron_w18.svg); content: ''; transition: .3s; background-color: #222; } 
	.all-depth1-btn.on { color: var(--color-main); } 
	.all-depth1-btn.on::after {opacity: 1; transform: scaleX(1);}
	.all-depth1-btn.on span::after { transform: rotate(180deg); background-color: var(--color-main); } 
	.all-depth2 { display: none; color: #444; border-bottom: 2px solid #eee;} 
} 
@media (max-width: 480px) { 
	.all-depth1-btn {padding-top: calc(1.5em - 11px);}
	.all-depth1-btn::before,
	.all-depth1-btn::after {padding-top: 3px; border-width: 4px 0;}
	.all-depth2 {font-size: 15px;}
} 
/* HEADER - 전체메뉴 =================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer { padding: 7.5rem var(--inner-padding); background-color: #222; font-size: 15px; text-align: center; color: #fff;} 
.footer-inner { display: grid; justify-items: center; row-gap: 2.5rem;max-width: 70rem; margin: auto;}
/* 로고 */
.footer-logo {width: 16.5em; margin-bottom: 3.5rem;}
.footer-logo img {width: 100%; }
/* 주소 */
.footer-addr { display: flex; justify-content: center; width: 100%; padding: 1.1em 0; border: solid var(--color-white-a2); border-width: 1px 0; font-weight: 700; letter-spacing: 0.03925em;}
/* 메뉴 */
.footer-menu { display: flex; justify-content: end; align-items: center; margin-bottom: 1rem; font-weight: 800; color: #888;} 
.footer-menu .item { position: relative; } 
.footer-menu .item + .item::before { position: absolute; top: 50%; left: 0; width: 6px; height: 6px; border-radius: 50%; background-color: #888; content: ''; transform: translate(-50%, -50%);} 
.footer-menu .item a { padding: 1.5rem 1.1em; } 
/* 탑버튼 */
.top-btn { display: flex; position: absolute; right: calc(var(--outer-padding) - 7px); z-index: 5; width: 6.3rem; height: 6.3rem; border-radius: 50%; background-color: #fff;} 
.top-btn::before { width: 2.5rem; height: 4.1rem; margin: auto; background: url(../images/common/ico_top.svg) no-repeat center/contain; content: ''; } 
@keyframes top-btn {33% { transform: translateY(2px); }	66% { transform: translateY(-4px); }}
/* 카피라이트 */
.footer-copy { width: 100%; text-align: justify; color: #888;}
.footer-copy::before {content: 'C O P Y R I G H T  ( C )  2 0 2 4  S T 첨 단 정 밀  A L L  R I G H T S  R E S E R V E D .'; white-space: pre; } 
.footer-copy::after { display: inline-block; width: 100%; content: '';}

@media (hover: hover) and (pointer: fine) {
	.top-btn:hover::before { animation: top-btn 1.5s infinite linear; } 
}
@media (max-width: 1280px) { 
	.top-btn { right: 13px;} 
} 
@media (max-width: 1024px) {
	.footer-inner {width: 80%;}
} 
@media (max-width: 768px) {
	.footer {padding-top: 8.5rem; font-size: 14px;}
	.footer-inner {width: 100%; row-gap: 3rem;}
	.footer-addr,
	.footer-menu {font-weight: 600;}
	.footer-menu .item + .item::before { width: 5px; height: 5px; } 
	.top-btn {right: 50%; top: 0; transform: translate(50%, -50%); box-shadow: 0 0 2rem var(--color-black-a1);}
 } 
@media (max-width: 576px) {
	.footer-copy {text-align: center;}
	.footer-copy::before {content: 'COPYRIGHT (C) 2024 ST첨단정밀 \A ALL RIGHTS RESERVED.'; letter-spacing: 1vw;}
	.footer-copy::after {display: none;}
}
@media (max-width: 375px) {
	.footer-copy {font-size: 13px;}
}
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub {--sub-tab-height: 70px;}
.body-sub [class*=right-deco]::after {background-color: #f5f5f5;}
.body-sub .tob-btn {background-color: #f5f5f5;}

/* SUV-VISUAL */
.sub-visual {position: relative; height: calc(20rem + 250px); animation: fade-in 1.5s both; } 
.sub-visual-bg { overflow: hidden; position: absolute; inset: 0;} 
.sub-visual-bg span { position: absolute; inset: 0; background: #444 no-repeat center/cover; transform: scale(1.1); animation: sub-visual 5s linear both; } 
@keyframes sub-visual { to { transform: scale(1); } } 
.sub-visual-txt { display: grid; grid-template-areas: 
	"title slogan"
	". desc"; 
	align-items: center; place-content: center start; gap: 0.25em 1.5em; position: relative; z-index: 5; height: 100%; padding: 90px var(--outer-padding) var(--sub-tab-height); font-weight: 700; font-size: var(--font-20); letter-spacing: normal; color: #fff;
} 
.sub-visual-txt h2 { display: flex; grid-area: title; justify-content: end; width: 10em; padding: 0.35em 1em; background-color: var(--color-main); letter-spacing: 0.025em; animation: clip-right 0.9s ease-in-out both .3s ;} 
.sub-visual-txt h2 span {min-width: 50%; }
.sub-visual-txt h3 { grid-area: slogan; align-items: center; font-size: 2em; overflow: hidden;}
.sub-visual-txt h3 span {display: inline-block; animation: fade-up 1s 1.1s both;}
.sub-visual-txt h3 u {font-weight: 200;}
.sub-visual-txt p { grid-area: desc; font-size: 15px; letter-spacing: 0.03em; overflow: hidden;}
.sub-visual-txt p span { animation: fade-up 0.9s 1.3s both; display: inline-block;}

/* SUB-TAB */
.sub-tab { position: relative; z-index: 10; margin-top: calc(-1 * var(--sub-tab-height)); background: linear-gradient(var(--color-white-a1), var(--color-white-a1)) no-repeat top/100% 1px;  font-weight: 700; font-size: var(--font-18);} 
.sub-tab-inner { display: flex; justify-content: end; margin-right: max(var(--inner-padding), calc(var(--right-deco) * 1.2 + var(--outer-padding)));}

.sub-tab-home { width: 3em; background: url(../images/common/ico_home.svg) no-repeat center; } 
.sub-tab-item { position: relative; width: 14em;} 
.sub-tab-btn { overflow: hidden; display: block; position: relative; z-index: 5; width: 100%; height: var(--sub-tab-height); padding: 0 calc(10% + 15px) 0 10%; text-align: left; color: #fff; white-space: nowrap; text-overflow: ellipsis; transition: .2s;} 
.sub-tab-btn::before { position: absolute; top: 50%; right: 8%; width: 13px; height: 8px; background-color: #fff; mask-image: url(../images/common/chevron_w13.svg); -webkit-mask-image: url(../images/common/chevron_w13.svg); content: ''; transform: translateY(-50%); transition: .2s;} 
.sub-tab-item.is-active .sub-tab-btn {background-color: #fff; color: var(--color-main);}
.sub-tab-item.is-active .sub-tab-btn::before { background-color: var(--color-main); transform: translateY(-50%) rotate(180deg); } 
/* 리스트 */
.sub-tab-list { display: none; position: absolute; top: 100%; width: 100%; border-top: 1px solid #eee; background-color: #fff; box-shadow: 0 0 2em var(--color-black-a1); font-size: var(--font-16);} 
.sub-tab-list a { padding: 0.85em 10%; } 
.sub-tab-list li.on a { background-color: #f5f5f5; font-weight: 800; color: var(--color-main);}

/* SUB-CONTENT */
.sub-content-tit h3 { padding: 5.5rem 0 10rem; font-weight: 800; font-size: 4.5rem; text-align: center; color: #222; line-height: 1.1;} 
.sub-content-wrap::after {display: block; visibility: hidden; width: 100%; height: 1px; content: ''; margin-bottom: -1px;}

@media (hover: hover) and (pointer: fine) {
	.sub-tab-list li:not(.on) a:hover { background-color: var(--color-main); color: #fff;}
}
@media (max-width: 1280px) {
	.body-sub { --sub-tab-height: 66px; } 
	.sub-visual-txt {padding-top: var(--header-height);}
}
@media (max-width: 768px) {
	.body-sub {--sub-tab-height: 62px;} 
	.sub-visual-txt p { font-size: 14px;}
}
@media (max-width: 576px) {
	.sub-visual-txt {	grid-template-areas: "slogan" "desc" "title"; gap: 0; text-align: center; justify-content: stretch;} 
	.sub-visual-txt h2 { display: block; width: fit-content; justify-self: center; margin-top: 1em; font-size: 0.9em; animation: clip-center 0.8s ease-out both 1.3s ;} 
	.sub-visual-txt h3 { padding-bottom: 0.2em; width: 100%;}
	.sub-visual-txt h3 span {animation: fade-up .9s .2s both; }
	.sub-visual-txt p {overflow: hidden; border-top: 1px solid var(--color-white-a2); padding-top: 0.5em;}
	.sub-visual-txt p span { animation: fade-down .9s .4s both ;}

	.sub-tab { font-size: 15px; } 
	.sub-tab-inner { margin-left: var(--inner-padding);}
	.sub-tab-item { width: calc(50% - 2rem); flex-grow: 1;} 
	.sub-tab-list { font-size: 14px; font-weight: 500;} 
	.sub-tab-list a { padding: 1em 10%; } 
	.sub-tab-list li.on a { font-weight: 700;}
}
@media (max-width: 480px) {
	.body-sub { --sub-tab-height: 58px; } 
	.sub-tab { font-size: 14px; } 
	.sub-tab-inner {margin-left: 0; margin-right: 0;}
	.sub-tab-home { width: calc(var(--inner-padding) * 2 + 15px);}
}
/* SUB-LAYOUT ========================================== */
/* ===================================================== */
