@charset "utf-8";

* { font-size: 15px; font-family: 'Pretendard', sans-serif; font-weight: 500; color: #2E2E2E; word-break: keep-all; box-sizing: border-box; letter-spacing: -0.2px; line-height: 1.4; scroll-behavior: smooth; }
*:focus { outline: none; }

body { padding: 0; margin: 0; }

a,
a:hover { display: block; width: 100%; height: 100%; display: block; color: inherit; text-decoration: none; outline: none; letter-spacing: inherit; }

ul,
li { list-style: none; margin: 0; margin-block-start: 0; margin-block-end: 0; padding: 0; font-size: inherit; color: inherit; }

span,
a,
div { font-family: inherit; font-weight: inherit; font-size: inherit; color: inherit; letter-spacing: inherit; line-height: inherit; text-shadow: none; }

button { background: transparent; padding: 0; margin: 0; border: 0; box-shadow: none; outline: none; cursor: pointer; }

input,
textarea { width: auto; border: none; outline: none; padding: 16px 24px; background-color: #F6F7F9; border-radius: 6px; font-size: 0.95em; }

textarea { resize: none; }

select { appearance: none; border: 0; outline: 0; font: inherit; background: url(../img/select_arrow.svg) no-repeat right 2.0em center; background-color: #F6F7F9; cursor: pointer; border-radius: 6px; }
select option { color: inherit; background-color: #FFFFFF; }
select:focus { outline: none; }
select::-ms-expand { display: none; }

input[type="checkbox"]:checked,
input[type="checkbox"]:not(:checked) { position: absolute; left: -9999px; }
input[type="checkbox"]:checked + label,
input[type="checkbox"]:not(:checked) + label { position: relative; display: inline-block; cursor: pointer; padding-left: 32px; font-size: 0.99em; color: #6E6E6E; }
input[type="checkbox"]:checked + label:before,
input[type="checkbox"]:not(:checked) + label:before { content: ""; position: absolute; left: 0; top: 0; width: 18px; height: 18px; background: url(../img/input_check_gy.svg) no-repeat center center; background-color: #F6F7F9; border-radius: 100%; }
input[type="checkbox"]:checked + label:after,
input[type="checkbox"]:not(:checked) + label:after { content: ""; position: absolute; left: 0; top: 0; width: 18px; height: 18px; background: url(../img/input_check_wh.svg) no-repeat center center; background-color: #367CFF; border-radius: 100%; -webkit-transition: all 0.2s ease; transition: all 0.2s ease; }
input[type="checkbox"]:not(:checked) + label:after { opacity: 0; -webkit-transform: scale(0); transform: scale(0); }
input[type="checkbox"]:checked + label:after { opacity: 1; -webkit-transform: scale(1); transform: scale(1); }

p { font-size: 1.0em; padding: 0; margin: 0; }

h1, h2, h3, h4, h5, h6 { margin: 0; }

::before,
::after { font-family: inherit; font-weight: inherit; font-style: inherit; text-rendering: optimizeLegibility; font-feature-settings: 'liga'; -webkit-font-feature-settings : 'liga'; -webkit-font-feature-overviews: 'liga'; -moz-font-feature-overviews: 'liga'; font-feature-overviews: 'liga'; -webkit-font-smoothing: antialiased; }

::-webkit-scrollbar { scrollbar-width: 8px; scrollbar-height: 4px; width: 8px; height: 4px; }
::-webkit-scrollbar-track { box-shadow: none; background-color: #fff; }
::-webkit-scrollbar-thumb { background-color: #D6D6D6; border-radius: 0;}

.fl_l { float: left; }
.fl_r { float: right; }

.btn { font-weight: 500; border-radius: 8px; text-align: center; }

.col_wh { color: #FFFFFF; }
.col_bk { color: #2E2E2E; }
.col_gy { color: #6E6E6E; }
.col_bl { color: #367CFF; }

.modal { position: fixed; top: 0; left: 0; pointer-events: none; background: rgba(0,0,0,0.8); width: 100vw; height: 100vh; z-index: 100; opacity: 0; transition: 0.3s; }
.modal.active { opacity: 1; pointer-events: auto; }
.modal.active .box { top: 50%; }
.modal .box { position: absolute; top: 70%; left: 50%; transform: translate(-50%,-50%); transition: 0.3s; display: block; background-color: #FFFFFF; box-sizing: border-box; border-radius: 20px; padding: 64px; }
.modal .box h1 { font-size: 1.5em; }
.modal .box input,
.modal .box select { width: 100%; margin-bottom: 16px; padding: 16px 24px; color: #6B7684; }
.modal .btn { width: 100%; padding: 16px 24px; }
.modal .row { display: flex; flex-direction: row; font-size: 0.85em; }

/**/
.modal .close { position: absolute; top: -20px; right: -20px; cursor: pointer; }

/* common */
section { position: relative; padding: 128px 0; }

.container { margin: 0 auto; position: relative; }
.w1160 { width: 1160px; min-width: 1160px; max-width: 1160px; }
.w480 { width: 480px; min-width: 480px; max-width: 480px; }

header { position: fixed; z-index: 99; width: 100%; height: 88px; /* box-shadow: 0px 2px 8px 0px rgba(0,0,0,0.04); */ background-color: #FFFFFF; }
header .container { display: flex; flex-direction: row; justify-content: space-between; height: 100%; align-items: center; }
header .area { height: 100%; display: flex; flex-direction: row; align-items: center; }
header .logo { margin-right: 64px; }
header .menu { display: flex; flex-direction: row; }
header .menu li { margin-right: 40px; font-size: 0.95em; font-weight: 600; }
header .menu li:last-of-type { margin-right: 0; }
header li.contact { border-radius: 24px; font-size: 0.85em; font-weight: 400; letter-spacing: 0.2px; background-color: #2E2E2E; color: #FFFFFF; }
header li.contact a { padding: 8px 24px; }
header li.hamburger { display: none; }

footer { width: 100%; background-color: #2E2E2E; padding: 80px 0; }
footer .row { font-size: 0.9em; color: #DEDEDE; }
footer .row:first-of-type { display: flex; flex-direction: row; justify-content: space-between; align-items: center; margin-bottom: 24px; }
footer .row:first-of-type div { font-weight: 700; font-size: 20px; }
footer .row:first-of-type ul { display: flex; flex-direction: row; margin-bottom: 0; }
footer .row:first-of-type ul li { margin: 0 12px; }
footer .row:first-of-type ul li:last-of-type { margin-right: 0; }
footer .row { display: block; }
footer .row ul { margin-bottom: 4px; }
footer .row ul.info { display: flex; flex-direction: row; }
footer .row ul.info li { margin: 0 12px; }
footer .row ul.info li:first-of-type { margin-left: 0; }
footer .row ul li { margin-bottom: 4px; font-weight: 400; }
footer .row ul li:last-of-type { margin-bottom: 0; }

.modal .ttl { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; margin-bottom: 24px; }
.modal .ttl h1 { margin-bottom: 8px; font-weight: 800; }
.modal .ttl h6 { font-size: 0.9em; color: #6E6E6E; }
.modal .ttl h6 span { display: block; }
.modal .row.terms { justify-content: space-between; margin: 16px 0 24px 0; }
.modal .row.terms div { display: flex; align-items: flex-start; }
.modal .row.terms div:last-of-type { text-decoration: underline; }
.modal textarea { width: 100%; height: 160px; border-radius: 6px; }
.modal button { width: 100%; padding: 16px 0; text-align: center; background-color: #367CFF; color: #FFFFFF; border-radius: 8px; }
.modal#term .cont { max-height: 360px; overflow: auto; margin-bottom: 24px; line-height: 1.6; }
.modal#term .cont p { margin-bottom: 8px; font-size: 1.1em; font-weight: 600; }
.modal#term .cont span { display: block; line-height: 1.4; }
.modal .cont img { width: 100%; }

.hero { padding: 88px 0 72px 0; }
.hero .container { display: flex; flex-direction: row; justify-content: space-between; align-items: top; padding: 128px 40px 40px 40px; }
.hero h1 { font-size: 48px; font-weight: 800; letter-spacing: -1.6px; line-height: 1.3; margin-bottom: 40px; }
.hero span { display: block; }
.hero span span { display: inline; }
.hero h6 { font-size: 1.2em; }
.hero h6 span:nth-of-type(-n+2) { display: inline-block; }
.hero .area { position: relative; z-index: 10; }
.hero .bg { position: absolute; z-index: 5; width: 100%; height: 164px; left: 0; bottom: 0; background-color: #367CFF; }
.hero .arrow { position: absolute; z-index: 10; left: 24px; bottom: 48px; display: flex; flex-direction: row; justify-content: center; align-items: center; width: 96px; height: 96px; border-radius: 100%; background-color: #2E2E2E; }
.hero .arrow img { width: 32px; }

.title { margin-bottom: 80px; }
.title span.row { display: block; }
.title h2 { font-size: 2.0em; letter-spacing: -0.8px; text-align: center; margin-bottom: 24px; }
.title h2 span .strong { display: inline; font-weight: 800; }
.title h6 { font-size: 1.2em; text-align: center; margin-bottom: 80px; }
.title h6 span span { display: inline; font-weight: 700; }

.what { background-color: #367CFF; padding-top: 0; }
.what .title h2 { font-weight: 300; }
.what .title h2 span .strong { font-weight: 600; }
.what ul { display: flex; flex-direction: row; justify-content: space-between; align-items: center; gap: 64px; }
.what ul li { width: 25%; padding: 40px 32px; background-color: #FFFFFF; border-radius: 16px; box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.08); }
.what ul li h3 { font-size: 1.6em; font-weight: 800; margin-bottom: 24px; }
.what ul li h6 { margin-bottom: 44px; }
.what ul li img { float: right; }

.who h3 { font-size: 1.6em; font-weight: 800; letter-spacing: 2px; }
.who h6 { font-size: 1.05em; line-height: 1.6; }
.who h6 span { display: block; }
.who .ceo { display: flex; flex-direction: row; justify-content: space-between; align-items: center; margin-bottom: 64px; }
.who .ceo .circle { display: flex; flex-direction: row; justify-content: center; align-items: center; width: 96px; height: 96px; margin-right: 80px; border-radius: 100%; background-color:#367CFF; color: #FFFFFF; font-size: 1.4em; font-weight: 700; }
.who .ceo .circle::after { content: ""; position: absolute; left: 96px; width: 104px; height: 1px; background-color: #367CFF; }
.who .ceo .video { width: 534px; height: 300px; overflow: hidden; border-radius: 16px; }
.who ul { display: flex; flex-direction: row; justify-content: space-between; align-items: center; gap: 64px; }
.who ul li { width: 33.333333%; min-height: 357px; padding: 40px 32px; background-color: #FFFFFF; border-radius: 16px; box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.08); }
.who ul li h5 { font-size: 1.1em; font-weight: 800; margin-bottom: 4px; }
.who ul li h3 { margin-bottom: 24px; }
.who ul li h6 { margin-top: 24px; }

.solution { background-color: #F4F4F8; }
.solution .cont { display: flex; flex-direction: row; justify-content: space-between; align-items: center; }
.solution .cont ul { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; }
.solution .cont ul li { display: flex; flex-direction: row; justify-content: flex-start; align-items: center; gap: 48px; min-width: 400px; margin-bottom: 64px; }
.solution .cont ul li:last-of-type { margin-bottom: 0; }
.solution .cont ul li:last-of-type .img::after { display: none; }
.solution .cont ul li .img { position: relative; display: flex; flex-direction: row; justify-content: center; align-items: center; width: 96px; height: 96px; border-radius: 100%; }
.solution .cont ul li .img::after { content: ""; position: absolute; left: 50%; top: 96px; width: 1px; height: 64px; }
.solution .cont ul.as_is li .img { background-color: #E9EAEB; }
.solution .cont ul.as_is li .img::after { background-color: #A5A5A5; }
.solution .cont ul.to_be li .img { background-color: #FFFFFF; box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.08); }
.solution .cont ul.to_be li .img::after { background-color: #2E2E2E; }
.solution .cont ul li .txt h3 { font-size: 1.6em; font-weight: 700; margin-bottom: 12px; }
.solution .cont ul li .txt span { display: block; color: #6E6E6E; }
.solution .cont .circle { display: flex; flex-direction: row; justify-content: center; align-items: center; width: 104px; height: 104px; border-radius: 100%; background-color: #367CFF; }
.solution .cont .circle img { width: 32px; }

.technology .cont { width: 90%; margin: 0 auto; }
.technology .cont .row { display: flex; flex-direction: row; justify-content: flex-start; align-items: center; font-size: 1.1em; border-bottom: 1px solid #D0D0D0; }
.technology .cont .row:nth-of-type(1) { height: 128px; border-top: 4px solid #367CFF; }
.technology .cont .row:nth-of-type(2) { height: 420px; }
.technology .cont .row:nth-of-type(3) { height: 72px; }
.technology .cont .row .cell { display: flex; flex-direction: row; justify-content: flex-start; align-items: center; height: 100%; padding-left: 40px; }
.technology .cont .row .cell.as_is { border-left: 1px solid #D0D0D0; border-right: 1px solid #D0D0D0; }
.technology .cont .row .cell.to_be { display: flex; flex-direction: column; justify-content: center; align-items: flex-start; }
.technology .cont .row .cate { width: 18%; color: #6E6E6E; }
.technology .cont .row .as_is { width: 37%; }
.technology .cont .row .to_be { width: 45%; font-weight: 700; }
.technology .cont .row .to_be span { display: flex; flex-direction: row; justify-content: flex-start; align-items: flex-start; margin-bottom: 8px; }
.technology .cont .row .to_be span.wrap { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; }
.technology .cont .row .to_be span.wrap .pack { margin-bottom: 0; }
.technology .cont .row .to_be span.wrap .pack span { margin-right: 24px; }
.technology .cont .row .to_be span.new { color: #367CFF; font-weight: 600; }
.technology .cont .row .to_be span.new::before { content: ""; position: relative; background: url(../img/technology_plus.svg) no-repeat; background-size: contain; width: 18px; height: 18px; margin: 2px 8px 0 0; }

.product { padding: 128px 0 80px 0; }
.product .container { display: flex; flex-direction: row; justify-content: space-between; align-items: flex-start; }
.product .txt { padding-top: 16px; }
.product .txt h4 { font-size: 1.2em; font-weight: 800; color: #367CFF; }
.product .txt h2 { font-size: 2.0em; letter-spacing: -0.6px; margin: 24px 0; }
.product .txt h2 span span { font-weight: 800; }
.product .txt h6 { font-size: 1.1em; color: #6E6E6E; }
.product .txt h6 span { display: block; }
.product .txt .btn { display: inline-block; margin-top: 40px; color: #FFFFFF; border-radius: 8px; }
.product .txt .btn a { padding: 16px 44px; }

.product.l4u { background-color: #F4F4F8; }
.product.l4u .txt .btn { background-color: #2E2E2E; }
.product.z4u .txt .btn { background-color: #BABABA; }
.product.z4u .txt .btn a { cursor: none; }

.partner { background-color: #F4F4F8; }
.partner ul { width: 100%; overflow: hidden; padding: 24px 0; margin: -24px 0; }
.partner ul li { display: flex !important; justify-content: center; align-items: center; text-align: center; background-color: #FFFFFF; margin: 0 28px; padding: 30px 0; border-radius: 12px; box-shadow: 0px 0px 16px 0px rgba(0,0,0,0.08); }
.partner ul li img { width: 180px; text-align: center; }
.partner ul .slick-list { overflow: visible; }

/**/

@media (min-width : 601px) and (max-width : 1080px) {
    * { font-size: 15px; }
	.popup { max-width: 90%; max-height: 80%; margin: 0 auto; top: 50%; transform: translateY(-50%);  }
}

@media only screen and (max-width : 600px) {
	* { font-size: 13px; }
	.w1160, .w480 { width: 94%; min-width: 94%; max-width: 94%; }

	.modal .box { width: 90%; border-radius: 12px; padding: 28px 20px; }
	.modal .box input, 
	.modal .box select { margin-bottom: 12px; padding: 12px 18px; }
	.modal .row.terms { margin: 16px 0; }
	.modal#hamburger .box { width: 60%; }
	.modal#hamburger .logo { text-align: center; margin-bottom: 8px; }
	.modal#hamburger ul li { line-height: 2.0; font-size: 1.05em; font-weight: 600; text-align: center; }
	.modal#hamburger ul li.contact { display: block; width: 100%; padding: 8px 0; background-color: #2E2E2E; color: #FFFFFF; font-size: 1.0em; font-weight: 500; border-radius: 40px; margin-top: 16px; }

	header { width: 100%; height: 60px; }
	header .logo { margin-right: 0; margin-left: 8px; }
	header .logo img { width: 96px; }
	header ul.menu,
	header li.contact { display: none; }
	header li.hamburger { display: block; margin-right: 8px; }
	header li.hamburger img { width: 20px; }
	
	footer { padding: 48px 0; }
	footer .container { width: 80%; min-width: 80%; max-width: 80%; }
	footer .row:first-of-type { flex-direction: column; justify-content: flex-start; align-items: flex-start; }
	footer .row:first-of-type ul { padding-top: 8px; }
	footer .row:first-of-type ul li:first-of-type { margin-left: 0; }
	footer .row ul.info { flex-direction: column; }
	footer .row ul.info li { margin: 0; }

	section { padding: 64px 0; }

	.hero { padding: 48px 0; }
	.hero .container { flex-direction: column; justify-content: flex-start; align-items: center; padding: 64px 0 40px 0; }
	.hero .area { display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
	.hero .area.img { align-items: center; }
	.hero h1 { font-size: 2.3em; margin-bottom: 16px; }
	.hero h6 { font-size: 1.0em; }
	.hero h6 span:nth-of-type(-n+2) { display: block; }
	.hero .img { width: 100%; height: 290px; margin-top: 40px; }
	.hero .img img { height: 100%; }
	.hero .bg { height: 120px; }
	.hero .arrow { left: calc(50% - 32px); bottom: -64px; width: 56px; height: 56px; }
	.hero .arrow img { width: 20px; }

	.title { margin-bottom: 48px; }
	.title h2 { font-size: 1.5em; margin-bottom: 12px; }
	.title h6 { font-size: 1.0em; margin-bottom: 0; }

	.what .title { padding-top: 56px; }
	.what .title h2 .row span { display: block; }
	.what .title h2 .row:nth-of-type(2) span:nth-of-type(1) span { display: inline; }
	.what ul { flex-direction: column; justify-content: flex-start; gap: 24px; align-items: center; }
	.what ul li { width: 94%; padding: 28px 24px 24px 24px; }
	.what ul li h3 { font-size: 1.4em; margin-bottom: 12px; }
	.what ul li h6 { margin-bottom: -40px; }
	.what ul li h6 span { display: block; }
	.what ul li img { width: 72px; }

	.who .ceo { display: flex; flex-direction: column; justify-content: flex-start; margin-bottom: 24px; }
	.who .ceo .circle { order: 2; width: 72px; height: 72px; margin-right: 0; font-size: 1.2em; }
	.who .ceo .circle::after { display: none; }
	.who .ceo h3 { order: 3; margin: 16px 0; }
	.who .ceo h6 { order: 4; }
	.who .ceo .video { order: 1; width: 94%; height: 200px; margin-bottom: 24px;  }
	.who .ceo .video video { object-fit: contain; }
	.who ul { flex-direction: column; justify-content: flex-start; gap: 28px; padding-top: 16px; }
	.who ul li { width: 94%; min-height: auto; padding: 28px 32px; }
	.who ul li h5 { font-size: 1.0em; margin-bottom: 0; }
	.who ul li h3 { font-size: 1.4em; margin-bottom: 0; }
	.who ul li h6 { font-size: 1.0em; margin-top: 12px; }

	.solution .title h2 .row { display: block; }
	.solution .title h6 .row span { display: block; font-weight: 500; }
	.solution .cont { display: flex; flex-direction: column; justify-content: flex-start; align-items: center; }
	.solution .cont ul li { gap: 24px; min-width: 94%; margin-bottom: 24px; }
	.solution .cont ul li .img { width: 64px; height: 64px; }
	.solution .cont ul li .img::after { top: 64px; }
	.solution .cont ul li .img img { width: 40px; }
	.solution .cont ul li .txt h3 { font-size: 1.3em; margin-bottom: 4px; }
	.solution .cont ul li .txt h6 { font-size: 0.9em; }
	.solution .cont .circle { width: 64px; height: 64px; margin: 32px 0; }
	.solution .cont .circle img { width: 20px; transform: rotate(90deg); }

	.technology .cont { width: 100%; }
	.technology .cont .row { font-size: 1.0em; }
	.technology .cont .row:nth-of-type(1) { height: 144px; }
	.technology .cont .row:nth-of-type(2) { height: 450px; }
	.technology .cont .row:nth-of-type(3) { height: 104px; }
	.technology .cont .row .cell { padding-left: 16px; padding-right: 16px; }
	.technology .cont .row .as_is { width: 33%; }
	.technology .cont .row .to_be { width: 49%; }
	.technology .cont .row .to_be span { display: block; margin-bottom: 4px; }
	.technology .cont .row .to_be span.new::before { display: inline-block; vertical-align: bottom; }
	.technology .cont .row .to_be span.wrap .pack span { margin-right: 0; }

	.product { padding: 64px 0 40px 0; }
	.product .container { flex-direction: column; justify-content: flex-start; align-items: center; }
	.product .txt { padding-top: 0; }
	.product .txt h4 { font-size: 1.0em; }
	.product .txt h2 { font-size: 1.5em; margin: 8px 0; }
	.product .txt h2 span { display: block; }
	.product .txt h2 span span { display: inline; }
	.product .txt h6 { font-size: 1.0em; }
	.product .img img { width: 100%; }
	.product .txt .btn { margin-top: 24px; margin-bottom: 40px; }
	.product .txt .btn a { padding: 12px 32px; }
	
	.partner ul li { margin: 0 16px; padding: 20px 0; }
}