/* reset */
* { margin: 0; padding:0; }
li { list-style:none; }
a { text-decoration: none !important; color:inherit; }
img { vertical-align: top; }

/* common */
html, body { height:100%; }
html { overflow-x: hidden; }
html.fix { overflow: hidden; }
.wrap { max-width: 1600px; width:84%; min-width:1200px; margin:0 auto; position: relative; }
.wrap:after, ul:after, .cl:after { content:""; clear:both; display: block; }
.blind { width:0; height:0; font-size:0; overflow: hidden; }
.fl { display: flex; align-items: center; justify-content: center; }
.fl:after { display:none; }
.dn { display:none !important; }
.arr:after { content:""; width:10px; height:10px; display:inline-block; border-top:2px solid #fff; border-right:2px solid #fff; transform:rotate(45deg); margin-left:4px; }
.ms { font-family: 'Montserrat'; }
.cpc { color:#ff8400; }
.cpb { color:#fff; background: #ff8400; }


/* header & footer */
#w_header { position: fixed; width: 100%; left: 0; top: 0; z-index: 99; padding:20px 0;  }
#w_header .wrap { width: 94%; max-width: none; }
#w_header h1 a { display: inline-block; width:35px; height:39px;  }
#w_header h1 img { opacity: 1; transition:0.3s; }
#w_header.on h1 a { background:url('/images/logo_bl.png') no-repeat center; }
#w_header.on h1 img { opacity: 0; }

.lang { height:40px; background: #222; color:#fff; border-radius: 0 50px 50px 0; width:133px; position: absolute; right:calc(3% + 30px);  top:5px; padding-left:10px; font:16px/40px nsb; transition: 0.3s; cursor: pointer; }
.lang i {color:#222; background: #fff; border-radius: 50px; width:30px; height:30px; font-size:20px; line-height:30px; font-weight: bold; transition: 0.3s; text-align: center;line-height:32px; font-weight: bold; text-align: center; margin-left: 10px; position: relative; top:4px; transition: 0.3s; }
          
.lang p{font-weight:600;}
.lang ul { line-height:1.8; display: none; color:#ff8400; }
.lang:hover { background: #ff8400; }
.lang:hover i { color: #ff8400; }


#nav_btn { position:absolute; right:0; top:4px; }
#nav_btn .line{  width: 40px; height: 2px; background-color: #fff; display: block; margin: 8px auto; transition: all 0.3s ease-in-out; }
#nav_btn:hover{ cursor: pointer;}
#nav_btn.act .line { background-color: #fff !important; }
#nav_btn.act .line:nth-child(2){ opacity: 0;}
#nav_btn.act .line:nth-child(1){ transform: translateY(10px) rotate(45deg);}
#nav_btn.act .line:nth-child(3){ transform: translateY(-10px) rotate(-45deg);}   
#w_header.on #nav_btn .line { background-color: #333; }

#w_footer { padding:70px 0; background: #f8f8f8; width: 100%; color:#333; }
#w_footer ul li { float:left; margin-right: 40px; font-size:16px; font-weight: 700;  }
#w_footer p { margin-top: 50px; font-size:14px; font-weight: 500; }

#w_gnb { position: fixed; width: 100vw; height: 100vh; left: 101vw; top: 0; background: rgba(0,0,0,0.9); color:#fff; z-index: 90; text-align: center; font-size:36px; font-weight: 600; transition: 0.3s; }
#w_gnb.fix { left:0; }
#w_gnb ul li { margin-right: 60px; position: relative; top:0; transition: 0.3s top 0.5s; }
#w_gnb.fix ul li:nth-child(1) { top:-140px; }
#w_gnb.fix ul li:nth-child(2) { top:-70px; }
#w_gnb.fix ul li:nth-child(4) { top:70px; }
#w_gnb.fix ul li:nth-child(5) { top:140px; margin-right: 0;}
#w_gnb ul li a:hover { color:#ff8400; }



/* index */
.section { display:flex; align-items: center; justify-content: center; flex-direction: column; }
section em, .section em { font-style: normal; display: block; }
.main #section0 { background:url(/images/main1.jpg) no-repeat center/cover fixed; }
.main #section0 iframe { width: 2200px; height:1400px; margin-top:-160px; margin-bottom:-160px;opacity: 0; }
.main #section0 iframe.on { opacity:1; transition: 0.7s; }
.main #section0:before { content:""; position: absolute; left:0; top:0; width: 100%; height: 100%; background:url(/images/line1.png) no-repeat center/auto 100%; z-index:1; }
.main #section0 article { color:#fff; text-align: center; position: absolute; left: 0; top:0; width: 100%; height:100%; z-index: 2; }
.main #section0 article strong { font-size:120px; white-space: nowrap; font-weight: 600; }
.main #section0 article p { font-size:80px; font-weight: 700; }
.main #section0 article strong:nth-child(1) { margin-left: -110%; }
.main #section0 article strong:nth-child(3) { margin-left: 44%; }

.main #section1 { background:url(/images/line2.png) no-repeat center/auto 100%; text-align: center; }
.main #section1 p { font:50px/1.6 nsr; color:#333; }
.main #section1 p span { font-family: nseb; }
.main #section1 p .stroke { color:#fff; text-shadow: -1px 0 #ff8400, 0 1px #ff8400, 1px 0 #ff8400, 0 -1px #ff8400; }
.main #section1 .move p { overflow: hidden; }
/*.main #section1 .move p:first-child { position:relative; animation-name: move; animation-duration: 5s; transform: translate(-50%, 0%); animation-fill-mode:forwards; }
									@keyframes move{from{left:0px; opacity:0;} to{left:500px; opacity:1;}}
.main #section1 .move p:last-child { position:relative; animation-name: move1; animation-duration: 5s; transform: translate(50%, 0%); animation-fill-mode:forwards; }
									@keyframes move1{from{right:0px; opacity:0;} to{right:500px; opacity:1;}}*/
.main #section1 ul { width: 940px; justify-content: space-between; font-size:16px; font-weight: 400; text-transform: uppercase; margin-top: 30px; }
.main #section1 ul li { overflow: hidden;}
.main #section1 a { width:220px; border-radius: 0 50px 50px 0; background: #222; height: 40px; font-size:18px; font-weight: 600; justify-content: space-between; padding:0 5px 0 24px; margin-top: 24px;  transition: 0.3s background; }
.main #section1 a:hover { background: #ff8400; }
.main #section1 a i { color:#222; background: #fff; border-radius: 50px; width:30px; height:30px; font-size:20px; line-height:30px; font-weight: bold; transition: 0.3s; text-align: center; }
.main #section1 a:hover i { transform: rotate(90deg); color:#ff8400; }

.main #section2 { background: #ff9f00; color:#fff; }
.main #section2:before { content:""; position: absolute; left:0; top:0; width: 100%; height: 100%; background:url(/images/line3.png) no-repeat center/auto 100%; }
.main #section2 article { padding-bottom: 160px; }
.main #section2 article h2 { font:50px nsr; overflow: hidden; margin-bottom: 30px;  }
.main #section2 article h2 span { font-family: nseb; }
.main #section2 article p { font:30px/1.4 nsl; overflow: hidden;}
.main #section2 article p span { font-family: nsb; }
.main #section2 article a { width:120px; border-radius: 0 50px 50px 0; background: #222; height: 40px; font-size:18px; font-weight: 600; justify-content: space-between; padding:0 5px 0 24px; margin-top: 40px;  transition: 0.3s ; }
.main #section2 article a:hover { background: #ff8400; }
.main #section2 article a i { color:#222; background: #fff; border-radius: 50px; width:30px; height:30px; font-size:20px; line-height:30px; font-weight: bold; transition: 0.3s; text-align: center; }
.main #section2 article a:hover i { transform: rotate(90deg); color:#ff8400; }
/*.main #section2 article h2, .main #section2 article h2 p { position:relative; animation-name: move3; animation-duration: 6s; animation-fill-mode:forwards; }
							  @keyframes move3{from{opacity: 0; transform: translatey(50px);} to{opacity: 3; transform: none;}}*/
.main #section3 { background:url(/images/line4.png) no-repeat center/auto 100%; text-align: center; }
.main #section3 article p { font:50px/1.4 nsr; color:#222; overflow: hidden; }
.main #section3 article p span { font-family: nseb; }
.main #section3 article a { width:170px; border-radius: 0 50px 50px 0; background: #222; height: 40px; font-size:18px; font-weight: 600; justify-content: space-between; padding:0 5px 0 24px; margin: 40px auto 0;  transition: 0.3s; }
.main #section3 article a:hover { background: #ff8400; }
.main #section3 article a i { color:#222; background: #fff; border-radius: 50px; width:30px; height:30px; font-size:20px; line-height:30px; font-weight: bold; transition: 0.3s; text-align: center; }
.main #section3 article a:hover i { transform: rotate(90deg); color:#ff8400; }
.main #section3 .snb { position: absolute; left: 8%; bottom:100px; text-align: left; font-size:22px; font-weight: 700; line-height:1.8; z-index:10; transition:0.3s; }
.main #section3 .snb.fix { position: fixed; }
.main #section3 .snb.fix.hidden { left:-20%; }
.main #section3 .snb li {opacity:0.1; transition:0.3s; }
.main #section3 .snb li:before { content:"●"; display: inline-block; color: #ff8400; border-radius: 100%; margin-right: 10px;  font-size:18px; position: relative; top:-2px; }
.main #section3 .snb li.select.on { opacity:1; }
.main #section3 .snb li a { cursor: default; }

.main #section4, 
.main #section5, 
.main #section6, 
.main #section7 { background:url(/images/line5.png) no-repeat center/auto 100%; text-align: center; }
.main #section4 .frame,
.main #section5 .frame,
.main #section6 .frame,
.main #section7 .frame { width:calc(100% - 500px); margin-left:auto; overflow: hidden; }
.main #section4 .frame .w_slide,
.main #section5 .frame .w_slide,
.main #section6 .frame .w_slide,
.main #section7 .frame .w_slide { width:104%; padding:80px 0; position: relative; z-index:1; }
.main #section4 .frame .w_slide li,
.main #section5 .frame .w_slide li,
.main #section6 .frame .w_slide li,
.main #section7 .frame .w_slide li { float:left; margin-right: 3.5%; width:31%; position: relative; transition:1s; opacity: 0; }
.main #section4 .frame .w_slide li:nth-child(1),
.main #section5 .frame .w_slide li:nth-child(1),
.main #section6 .frame .w_slide li:nth-child(1),
.main #section7 .frame .w_slide li:nth-child(1) { top:0; }
.main #section4 .frame .w_slide li:nth-child(2),
.main #section5 .frame .w_slide li:nth-child(2),
.main #section6 .frame .w_slide li:nth-child(2),
.main #section7 .frame .w_slide li:nth-child(2) { top:80px; }
.main #section4 .frame .w_slide li:nth-child(3),
.main #section5 .frame .w_slide li:nth-child(3),
.main #section6 .frame .w_slide li:nth-child(3),
.main #section7 .frame .w_slide li:nth-child(3) { top:160px; }
.main #section4 .frame .w_slide.on li:nth-child(1),
.main #section5 .frame .w_slide.on li:nth-child(1),
.main #section6 .frame .w_slide.on li:nth-child(1),
.main #section7 .frame .w_slide.on li:nth-child(1) { top:-80px; opacity: 1; }
.main #section4 .frame .w_slide.on li:nth-child(2),
.main #section5 .frame .w_slide.on li:nth-child(2),
.main #section6 .frame .w_slide.on li:nth-child(2),
.main #section7 .frame .w_slide.on li:nth-child(2) { top:0; opacity: 1; transition-delay: 0.3s;}
.main #section4 .frame .w_slide.on li:nth-child(3),
.main #section5 .frame .w_slide.on li:nth-child(3),
.main #section6 .frame .w_slide.on li:nth-child(3),
.main #section7 .frame .w_slide.on li:nth-child(3) { top:80px; opacity: 1; transition-delay: 0.6s;}
.main #section4 .frame .w_slide li:last-child,
.main #section5 .frame .w_slide li:last-child,
.main #section6 .frame .w_slide li:last-child,
.main #section7 .frame .w_slide li:last-child { margin-right: 0; }
.main #section4 .frame .w_slide li img,
.main #section5 .frame .w_slide li img,
.main #section6 .frame .w_slide li img,
.main #section7 .frame .w_slide li img { width: 100%; }


.main #section8 { background:url(/images/line5.png) no-repeat center/auto 100%; text-align: center; }
.main #section8:before { content:""; position: absolute; left:0; top:0; width: 100%; height: 100%; background:url(/images/mv.png) no-repeat center; }
.main #section8 p { font-size:120px; font-weight: 700; text-transform: uppercase; text-align: left; padding-bottom: 140px; position: relative; }
.main #section8 p span { margin-left: -170px; }


/* about */
.about { color:#fff; }
.about .section { position: relative; }
.about .section:before { position: absolute; left: 0; top: 0; width:100%; height:100%; content:""; } 
.about #section0 { background:url(/images/bg_about1.png) no-repeat center/cover fixed; }
.about #section1 { background:url(/images/bg_about2.png) no-repeat center/cover fixed; }
.about #section2 { background:url(/images/bg_about3.png) no-repeat center/cover fixed; }
.about #section0:before { background:url(/images/a_line1.png) no-repeat center/auto 100%; }
.about #section1:before { background:url(/images/a_line2.png) no-repeat center/auto 100%; opacity: 0.2; }
.about #section2:before { background:url(/images/a_line3.png) no-repeat center/auto 100%; opacity: 0.2; }

.about article { position: relative; padding-top: 50px;}
.about p { font-size:60px; text-transform: uppercase; font-weight: 700; overflow: hidden; 
         text-shadow: 2px 2px 4px rgba(0,0,0,0.4);}
.about span { font-size:30px; font-weight: 600; margin:0 100px; display: block; overflow: hidden; 
         text-shadow: 2px 2px 4px rgba(0,0,0,0.4);}
.about strong { display: block; margin-top: 80px; text-align: center; font:18px/1.6 nsr; position: relative; 
         text-shadow: 2px 2px 5px rgba(0,0,0,0.6);}

/* sub layout */
.sv { height: 740px; text-transform: uppercase; }
.sv h2 { font-size:20px;  margin-bottom: 20px; }
.sv p { font-size:75px; line-height:1.2; color:#fff; font-weight: 700;  overflow: hidden; }
.pad { padding:150px 0 250px; }

#sub2 { background:url(/images/bg_sub2.png) no-repeat center top fixed;}
#sub4 { background:url(/images/bg_sub4.jpg) no-repeat center top fixed;}
#sub5 { background:url(/images/bg_sub5.jpg) no-repeat center top fixed;}


/* history */
#history .lnb { font-size:22px; font-weight: 700; line-height:2; float:left;  }
#history .lnb li { opacity: 0.1; transition: 0.3s; } 
#history .lnb li.select { opacity: 1; }
#history .lnb li:before { content:"●"; display: inline-block; color: #ff8400; border-radius: 100%; margin-right: 10px;  font-size:18px; position: relative; top:-2px; }
#history .lnb li a { color:#333; }
#history .lnb li.select a { color:#ff8400; }

#history article { float:right; width:64%; }
#history article h2 { font-size:30px; }
#history article > ul { border-top:2px solid #ff8400; margin-top: 50px; display: none; }
#history article > ul.on { display: block; }
#history article > ul > li { border-bottom:1px solid #ddd; padding-left: 120px; position: relative; padding-top: 24px;  }
#history article > ul > li:last-child { border-bottom:none;  }
#history article > ul > li h3 { position: absolute; left:0; font-size:22px; }
#history article > ul ul li { font:16px/1.4 nsr; color:#333; margin-bottom: 24px; }

/* process */
.process #section0 { background:url(/images/bg_sub3.jpg) no-repeat center top fixed;}
.process #section0 h2 { font-size:20px; margin-bottom: 20px; }
.process #section0 p { font-size:75px; line-height:1.2; color:#fff; font-weight: 700; text-transform: uppercase; overflow: hidden; }

.process #section1 ul { position: relative; justify-content: space-between; }
.process #section1 ul li { width:32%; }
.process #section1 ul li div { border-radius: 10px; overflow: hidden; width: 100%; position: relative; background: #000; transition: 0.3s; }
.process #section1 ul li:nth-child(2) { position: absolute; left:34%; width:32%; height: 100%; }
.process #section1 ul li:nth-child(2) div:last-child { position: absolute; bottom: 0; }
.process #section1 ul li img { width: 100%; opacity: 0.4; mix-blend-mode:screen; }
.process #section1 ul li a { color:#fff; position: absolute; left: 0; top:0; width: 100%; height: 100%; flex-direction: column; text-align: center; background:rgba(255,130,0,0); transition: 0.3s; }
.process #section1 ul li a:hover { background:rgba(255,130,0,.6); }
.process #section1 ul li a span { font-size:25px; font-weight: 700; }
.process #section1 ul li a strong { font-size:35px; margin-top: 20px; font-weight: 700;text-transform: uppercase; }

.process .fix { position: absolute; left:0; top:0; width: 100%; height:100%; }
.process .fix.on { position: fixed;}
.process .fix.on.t300 { top:300%; position: absolute; }
.process .fix.on.t400 { top:400%; position: absolute; }

.process article { position: absolute; left:0; bottom:0; color:#333;  }
.process article strong { font:700 25px Montserrat; }
.process article h2 { font:800 35px Montserrat; text-transform: uppercase; margin:30px 0;  }
.process article p { font:18px/1.6 nsr; }
.process article p span { font-family:nseb; color:#ff8400; }
.process figure { width: 700px; margin-left: auto; overflow: hidden; }
.process figure ul { width: 3500px; position: relative; transition:0.3s; left:0; }
.process figure ul li { float:left; }
.process figure img { border-radius: 30px; }
.process figure + ul { position: absolute; left:0; bottom:250px; font-size:22px; font-weight: 700; line-height:1.8; z-index:10; transition:0.3s; font-family: Montserrat; }
.process figure + ul li {opacity:0.1; transition:0.3s; }
.process figure + ul li:before { content:"●"; display: inline-block; color: #ff8400; border-radius: 100%; margin-right: 10px;  font-size:18px; position: relative; top:-2px; }
.process figure + ul li.select { opacity:1; }

/* product */
#product { padding-bottom: 0; }
#product .cont1 { padding-bottom: 200px; }
#product .cont1 p { font:18px/1.6 nsr; color:#333; }
#product .cont1 ul { margin-top: 40px; }
#product .cont1 ul li { float:left; width:23.5%; margin-right: 2%; position: relative; border-radius: 14px; overflow: hidden; cursor: pointer; }
#product .cont1 ul li:last-child { margin-right: 0; }
#product .cont1 ul li img { width: 100%; }
#product .cont1 ul li span { width: 100%; height: 100%; color:#fff; font-size:35px; text-transform: uppercase; font-weight: 700; position: absolute;  left: 0; top: 0;  transition:0.3s; }
#product .cont1 ul li:hover span { background:rgba(255,130,0,.6); }
#product .prd { height: 100vh; box-shadow: 0 -4px 4px rgba(0,0,0,0.02); }
#product .prd article { position: absolute; left:0; bottom:0; color:#333;  }
#product .prd article h2 { font:800 35px Montserrat; text-transform: uppercase; margin:30px 0;  }
#product .prd article p { font:18px/1.6 nsr; }
#product .prd figure { width: 700px; margin-left: auto; }

/* contact */
#contact article { float:left; width:48%; margin-right: 4%; }
#contact article:last-child { margin-right: 0; }
#contact article h2 { font-size:30px; font-weight: 700; line-height:1.4; height: 180px; }
#contact article div h3 { font-size:22px; color:#ff8400; padding-bottom: 16px; border-bottom:2px solid #ff8400; }
#contact article div ul li { border-bottom:1px solid #ddd; padding:20px 0; position: relative; }
#contact article div ul li label { display: block; font-weight: 700; }
#contact article div ul li input, #contact article textarea { margin-top: 20px; width: 100%; font:16px/1.6 nsr; color:#666; border:none; outline: none; }
#contact .btn { width:110px; border-radius: 0 50px 50px 0; background: #222; height: 40px; font-size:18px; font-weight: 600; justify-content: space-between; padding:0 5px 0 40px; margin-top: 40px;  transition: 0.3s; margin-left: auto; }
#contact .btn:hover { background: #ff8400; }
#contact .btn i { color:#222; background: #fff; border-radius: 50px; width:30px; height:30px; font-size:20px; line-height:30px; font-weight: bold; transition: 0.3s; text-align: center; }
#contact .btn:hover i { transform: rotate(90deg); color:#ff8400; }
#contact article:last-child div ul li { padding:26px 0; }
#contact article div ul li strong { position: absolute; left: 0; }
#contact article div ul li p { text-align: right; font:16px nsr; }
#contact article div ul li.tel { padding-bottom: 40px; }
#contact article div ul li.tel p { font:35px nseb; }
#contact article div ul li.sns { padding:10px 0; }
#contact article div ul li.sns strong { line-height:43px; }
#contact article div ul li.sns p a { margin-left: 14px; }



































