
@charset "utf-8";

/*
* File       : site-custom.css
* Author     : B-WORKER
*      
 * SUMMARY:
 * 0) ROOT
 * 1) WRAP
 * 2) SITE CUSTOM 
    - 사이트 전반적으로 함께 쓰이는 속성
	- 메인, 서브 함께 쓰이는 속성
*/

/* **************************************** *
 * font set
 * **************************************** */
body{font-size:var(--default); color:var(--b-default); line-height: 1.6;}
body,input,textarea,button,select{font-family:'Outfit', "Pretendard", '맑은 고딕', '돋움', Dotum, '굴림', Gulim, Sans-serif;}

@media (max-width:860px){
	body{font-size:16rem;}
	body,
	p,
	li,
	a{word-break: keep-all;}
}

@media (max-width:540px){
	body{letter-spacing: -0.1rem; font-size:15rem;}
	p {line-height: 1.6;}
}

/* **************************************** *
 * global root
 * **************************************** */
 :root {
    /* 포인트 */
	--c-primary: #1F30FF;
	--c-second: #2999FF;
	--c-gradient: linear-gradient(180deg, #16182B 20%, #1F30FF 55%, #2999FF 75%, #FFF 100%);
    --c-gradient-reserve: linear-gradient(0deg, #16182B 20%, #1F30FF 55%, #2999FF 75%, #FFF 100%);

    /* title / body */
	--b-title: #131822;
	--b-default: #666666;
	--b-light: #90A0AF;

	--w: #fff;

	--bg-dark: #16182B;
	--bg-light: #F0F5FA;

	--br-01: #E1E1E1;

	/* 게시판용 root */
	--border-01: #eee;

	--trans-01:all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
	--trans-02:all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	--trans-03:all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	--trans-04:all 0.5s ease;

	--lang-en:'Outfit';
	--lang-ko:"Pretendard";
	--default:17rem;

	--font-65:65rem;
    --font-40:40rem;
    --font-28:28rem;
    --font-22:22rem;
	--font-18:18rem;
    --font-17:17rem;
    --font-16:16rem;
    --font-15:15rem;
    --font-14:14rem;
    --font-13:13rem;
    
	--space250:250rem;
    --space230:230rem;
	--space200:200rem;
    --space180:180rem;
    --space150:150rem;
	--space140:140rem;
	--space80:80rem;
	--space75:75rem;
    --space60:60rem;

    --op-b05:rgba(0,0,0,.05);
    --op-b10:rgba(0,0,0,.1);
    --op-b20:rgba(0,0,0,.2);
    --op-b30:rgba(0,0,0,.3);
    --op-b40:rgba(0,0,0,.4);
    --op-b50:rgba(0,0,0,.5);
    --op-b60:rgba(0,0,0,.6);
    --op-b70:rgba(0,0,0,.7);
    --op-b80:rgba(0,0,0,.8);
    --op-b90:rgba(0,0,0,.9);

    --op-w05:rgba(255,255,255,.05);
    --op-w10:rgba(255,255,255,.1);
    --op-w20:rgba(255,255,255,.2);
    --op-w30:rgba(255,255,255,.3);
    --op-w40:rgba(255,255,255,.4);
    --op-w50:rgba(255,255,255,.5);
    --op-w60:rgba(255,255,255,.6);
    --op-w70:rgba(255,255,255,.7);
    --op-w80:rgba(255,255,255,.8);
    --op-w90:rgba(255,255,255,.9);
}

h2, h3, h4, h5, h6 {color: var(--b-title);}

/* 폰트 셋 */
[data-font-kr="3xl"], h2, h3 {font-size: var(--font-65); font-weight: 700; line-height: 1.3;}
[data-font-kr="2xl"], h4 {font-size: var(--font-40); font-weight: 700; line-height: 1.4;}
[data-font-kr="xl"], h6 {font-size: var(--font-28); font-weight: 700; line-height: 1.4;}
[data-font-kr="lg"] {font-size: var(--font-22); font-weight: 700;}
[data-font-kr="md"] {font-size: var(--font-18); line-height: 1.5;}
[data-font-kr="md bold"] {font-size: var(--font-18); font-weight: 700; line-height: 1.5;}

[data-font-kr] {font-family: var(--lang-ko); letter-spacing: -0.3px;}
[data-font-kr="medium"] {font-weight: 500;}
[data-font-kr="semibold"] {font-weight: 600;}
[data-font-kr="bold"] {font-weight: 700;}
[data-font-kr="small"] {font-size: var(--font-15);}
[data-font-kr="small semibold"] {font-size: var(--font-15); font-weight: 600;}

[data-font-en] {font-family: var(--lang-en); font-size: var(--font-16);}
[data-font-en="bold"] {font-weight: 700;} 
[data-font-en="small"] {font-size: var(--font-14); font-weight: 700;} 
[data-font-en="xsmall"] {font-size: var(--font-13); font-weight: 700;} 

 /* 컬러 기본 셋 */
 [data-color="c1"]{color:var(--c-primary) !important;}
 [data-color="c2"]{color:var(--c-second) !important;}
 [data-color="b1"]{color:var(--b-title) !important;}
 [data-color="b2"]{color:var(--b-default) !important;}

 [data-color="w"],
 [data-color="w"] *{color: var(--w);} /* 영역만 글자 흰색 */

 [data-bg="dark"]{background-color: var(--bg-dark) !important;}
 [data-bg="light"]{background-color: var(--bg-light) !important;}
 
 /* boarder 값 기본 셋 */
 [data-border]{border:1px solid;}
 [data-radius]{overflow:hidden;}
 [data-radius="10"]{border-radius:max(0.5208vw, 5rem);}
 [data-radius="20"]{border-radius:max(1.0417vw, 10rem);}
 [data-radius="30"]{border-radius:max(1.5625vw, 10rem);}
 [data-radius="40"]{border-radius:max(2.0833vw, 10rem);}

@media all and (max-width:1200px){
	:root {
		--font-65:52rem;
	}
}

@media all and (max-width:1023px){
	:root {
		--font-65:44rem;
		--font-40:32rem;
		--font-28:22rem;
		--font-22:18rem;

		--space250:180rem;
		--space230:150rem;
		--space200:150rem;
		--space180:120rem;
		--space150:120rem;
		--space60:50rem;
	}
}

@media (max-width:860px){
	:root {
		/* --lang-ko:-apple-system, BlinkMacSystemFont, Sans-serif; */
		--font-65:42rem;

		--space140:100rem;
     
	}
}

@media (max-width: 540px){
	:root {
		--font-65:27rem;
		--font-40:22rem;
		--font-28:20rem;
		--font-22:18rem;
		--font-18:16rem;
		--font-17:15rem;
		--font-16:14rem;
		--font-15:14rem;
		--font-14:13rem;
		--font-13:12rem;

		--default:15rem;

		--space250:140rem;
		--space230:100rem;
		--space200:100rem;
		--space180:80rem;
		--space150:80rem;
		--space140:80rem;
		--space80:50rem;
		--space60:40rem;
	}
}

/* **************************************** *
 * wrapper
 * **************************************** */
 *[class^="wrap"]{position:relative;margin:0 auto;}

 .sub-inner{margin: 0 var(--margin);}
 .wrap{max-width:1520rem;}
 .wrap-wide{max-width:1700rem;}
 .wrap-narrow{max-width:1206rem;} /* 빼지마세요 */
 
 /* @media all and (max-width:1919px){
	 .wrap-wide{margin: 0 60rem;	 max-width: none;}
 }
  */
 @media all and (max-width:1480px){
	 .wrap{margin:0 60rem;max-width:none;}
 }
 
 @media all and (max-width:1023px){
	 *[class^="wrap"]{margin:0 40rem;max-width:none;width: auto;}
 }
 
 @media all and (max-width:860px){
	 *[class^="wrap"]{margin:0 20rem;}
 }

 /* **************************************** *
 * swiper set
 * 
 * 사이트 기본 슬라이드 스타일에 맞게 마음껏 수정하면 됩니다.
 * 특정 페이지에서만 다른 스타일 슬라이드를 사용한다면 부모 클레스 상쇄하여 사용 
 * **************************************** */
 .swiper-controls .wrap *{cursor:pointer;}
 .swiper-container img{width:100%;}
 .swiper-controls > div{cursor: pointer;}
 .button-next.swiper-button-disabled,
 .button-prev.swiper-button-disabled{opacity:0.5;}
 
 .swiper-controls{display:flex; justify-content:center; align-items:center;}
 .swiper-controls *[class^="swiper-btn--"]{position:relative;width:14rem;height:14rem;cursor:pointer;display: flex;align-items: center;margin: 0 25rem;font-size: 0;}
 .swiper-controls *[class^="swiper-btn--"] i {display: none;}
 .swiper-controls *[class^="swiper-btn--"]::after{position: absolute; left: 0; top: 0; content:"";display:block;min-width: 14rem;height: 14rem;background:url(../img/layout/arrow-slide.svg) no-repeat 50% 50%;background-size: contain;}
 .swiper-controls .swiper-btn--prev{flex-direction: row-reverse;}
 
 .swiper-controls .swiper-btn--next::after{/* transform:rotate(-90deg); */}
 .swiper-controls .swiper-btn--prev::after{transform: rotate(180deg);}
 .swiper-controls .swiper-button-disabled{opacity: 0.5;}
 
 .swiper-pagination-bullet{width:10rem;height:10rem;background: #b7b7b7;border-radius:100%;}
 .swiper-pagination{display:flex; gap:15rem;}
 .swiper-pagination-bullet-active {opacity: 1;	background: var(--c-primary);}


/* **************************************** *
 * site custom
 * **************************************** */

/* button common */
*.btn-basic{display:inline-flex;justify-content:space-between;align-items:center;position:relative;box-sizing:border-box; min-width: 60rem; height: 60rem; padding: 0 20rem;background:var(--w);transition: var(--trans-01);border-radius: 100rem;}
*.btn-basic span {display: inline-block; margin-right: 20rem; font-weight:600;font-size:var(--font-15);color: var(--b-title); transition: var(--trans-01);}
*.btn-basic::after{content:"";display:block;width: 20rem; height:20rem; background-size: contain; background-position:50% 50%;background-image:url(../img/layout/arrow-basic.svg);background-repeat:no-repeat; transition: var(--trans-01);}

@media (hover: hover) and (pointer: fine){
	*.btn-basic:hover{background: var(--c-primary); box-shadow: 0 0 20px 0 rgba(17, 35, 255, 0.70);}
    *.btn-basic:hover span {color: var(--w);}
    *.btn-basic:hover::after {background-image: url(../img/layout/arrow-basic_w.svg);}
}


@media all and (max-width:1023px){
	*.btn-basic {min-width: 52rem; height: 52rem; padding: 0 15rem;}
}

@media (max-width: 540px){
	*.btn-basic{height: 50rem; padding:15rem 20rem;font-size:14rem;}
}

/* 마우스커스텀 */    
#cursor{mix-blend-mode:normal;position:fixed; top:0; left:0; z-index:1000; pointer-events:none; will-change:transform;}
#cursor .cur_cir{opacity:0; width:32px; height:32px; margin-top:-50%; margin-left:-50%; transition:opacity 0.3s cubic-bezier(0.25, 1, 0.5, 1), background-color 0.3s cubic-bezier(0.25, 1, 0.5, 1), width 0.3s cubic-bezier(0.25, 1, 0.5, 1), height 0.3s cubic-bezier(0.25, 1, 0.5, 1); border-radius:50%;}
#cursor .cur_cir span {text-transform: uppercase;}

#cursor.on .cur_cir::before{width:100%; text-align:center;display:block; position:absolute; top:50%; left:50%; font-weight:700; font-size:var(--font-14); color:#fff; letter-spacing:-0.03em; transform:translate(-50%, -50%);}
#cursor.on .cur_cir {position:relative; opacity:1; transform:rotate(0) scale(1) translate(0, 0) !important;}

#cursor.overlay .cur_cir{width:130rem; height:130rem; background:linear-gradient(326deg, #1F30FF 33.61%, #2999FF 86.38%); border: 1px solid var(--op-b10); box-shadow: 0 15rem 20rem 0 rgba(0, 0, 0, 0.40);}
#cursor.overlay .cur_cir span {width: 100%; height: 100%; padding: 0 15rem; gap: 10rem; color: var(--w); font-weight:700; font-size:var(--font-14);}
#cursor.overlay .cur_cir span::before,
#cursor.overlay .cur_cir span::after {position: relative; width: 16rem; height: 16rem; content:''; background: url(../img/layout/arrow-top.svg) no-repeat center / contain; transform: rotate(90deg);}
#cursor.overlay .cur_cir span::before {transform: rotate(270deg);}

#cursor.test .cur_cir{position:relative; opacity:1; width:117rem; height:117rem; background-color:#cc3838; transform:rotate(0) scale(1) translate(0, 0) !important;}
#cursor.test .cur_cir::before{content:"더보기"; display:block; position:absolute; top:50%; left:50%; font-weight:700; font-size:15px; color:#fff; letter-spacing:-0.03em; transform:translate(-50%, -50%);}

[cursor-type]{cursor: pointer;}

@media (max-width: 1023px){
	#cursor{display: none !important;}
} 

