html,body {font-size: 62.5%;}
@media screen and (max-width: 640px) {html,body {font-size: 62.5%;}}
body,div,dl,dt,dd,ul,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,p,blockquote {margin: 0; padding: 0;}article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }img {border: 0; -ms-interpolation-mode: bicubic;}h1,h2,h3,h4,h5,h6 {clear: both; font-size: 100%; font-weight: normal;}ul,dl,ol {text-indent: 0;}li {list-style: none;}address,caption,cite,code,dfn,var{font-style: normal; font-weight: normal;}sup {vertical-align: text-top;}sub {vertical-align: text-bottom;}input,textarea,select {font-family: inherit; font-size: inherit; font-weight:inherit;}* html input,* html textarea,* html select {font-size: 100%;}*:first-child+html+input,*:first-child html+textarea,*:first-child+html select {font-size: 100%;}caption {text-align: left;}pre,code,kbd,samp,tt {font-family: monospace;}* html pre,* html code,* html kbd,* html samp,* html tt {font-size: 108%; line-height: 100%;}*:first-child+html pre,*:first-child html+code,*:first-child html+kbd,*:first-child+html+samp,*:first-child+html tt {font-size: 108%; line-height: 100%;}input,select,textarea {font-size: 100%; font-family: Verdana, Helvetica, sans-serif;}.clear {zoom: 1;}.clear:after {content: ".";display: block;clear: both;height: 0;line-height: 0;visibility: hidden;}a{color:#333; text-decoration: none;}#breadcrumbs{width: 100%; background: #000; padding: 10px; font-size: 1.4rem;}#breadcrumbs ol{margin:0 auto; width: 1400px;}#breadcrumbs ol li {display: inline;list-style-type: none; color: #fff;}#breadcrumbs ol li a{color: #fff; padding: 0 5px;}#breadcrumbs ol li a:hover{text-decoration: underline;}#breadcrumbs ol li:before {content: " > ";}#breadcrumbs ol li:first-child:before {content:"";}#breadcrumbs ol li:first-child:before {padding:0 3px 0 0; content:"\f015"; font-family:"Font Awesome 5 Free"; font-size:16px;font-weight: 900;}@media screen and (max-width: 768px) {#breadcrumbs{margin:0px auto 10px auto; width: 100%; padding: 5px 10px; box-sizing: border-box; font-size: 1.4rem;}#breadcrumbs ol{margin:0 auto;width: 100%; padding: 0;}#breadcrumbs ol li {display: inline;list-style-type: none;}#breadcrumbs ol li a{color: #fff; padding: 0 5px;}#breadcrumbs ol li a:hover{text-decoration: underline;}#breadcrumbs ol li:before {content: " > ";}#breadcrumbs ol li:first-child:before {content:"";}#breadcrumbs ol li:first-child:before {padding:0 3px 0 0; content:"\f015"; font-family:"Font Awesome 5 Free"; font-size:16px;font-weight: 900;}}
body {font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Helvetica Neue", Arial, Meiryo, sans-serif;line-height: 1.5;overflow-x: hidden;text-rendering: optimizeLegibility;-webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "palt" 1; font-feature-settings: "palt" 1;}article{padding: 10px 0;}ol{margin: 0;}ol li{list-style-type: decimal; line-height: 3.6rem;}ol.padrow {padding:0 0 0 6rem;margin:1rem 0 5rem 0;}ol.padrow li{list-style-type: lower-roman;}

@keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
 @-moz-keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
@-webkit-keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
@-o-keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
@keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
@-moz-keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
 @-webkit-keyframes rotate-loading {
0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
@-o-keyframes rotate-loading {
 0%  {transform: rotate(0deg);-ms-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); -moz-transform: rotate(0deg);}
100% {transform: rotate(360deg);-ms-transform: rotate(360deg); -webkit-transform: rotate(360deg); -o-transform: rotate(360deg); -moz-transform: rotate(360deg);}
}
@keyframes loading-text-opacity {
0%  {opacity: 0}20% {opacity: 0}50% {opacity: 1}100%{opacity: 0}
}
@-moz-keyframes loading-text-opacity {
0%  {opacity: 0}20% {opacity: 0}50% {opacity: 1}100%{opacity: 0}
}
@-webkit-keyframes loading-text-opacity {
0%  {opacity: 0}20% {opacity: 0}50% {opacity: 1}100%{opacity: 0}
}
@-o-keyframes loading-text-opacity {
0%  {opacity: 0}20% {opacity: 0}50% {opacity: 1}100%{opacity: 0}
}

#loading {width: 100vw;height: 100vh;transition: all 1s;background-color: #000;position: fixed;top: 0;left: 0;z-index: 99999; text-align: center;}
.loaded {opacity: 0;visibility: hidden;}
#loading img{width: 100px;}
#loading .inner{position: absolute; top:50%; left: 50%; -webkit-transform: translate(-50%, -50%);-ms-transform: translate(-50%, -50%);transform: translate(-50%, -50%);width: 90%;}
#link {color: #fff;display:block;font-size: 1.2rem;text-align:center; text-decoration: none;}
#link h1{letter-spacing: .5rem; padding-left: .7rem;}
#link:hover {color: #83f0de;}
#link, #link:hover {-webkit-transition: color 0.5s ease-out;-moz-transition: color 0.5s ease-out;-ms-transition: color 0.5s ease-out;-o-transition: color 0.5s ease-out;transition: color 0.5s ease-out;}
.loading-container,.loading {height: 120px;position: relative;width: 120px;border-radius: 100%;}
.loading-container { margin: 4rem auto;}
.loading {border: 2px solid transparent;border-color: transparent #fff transparent #FFF;-moz-animation: rotate-loading 1.5s linear 0s infinite normal;-moz-transform-origin: 50% 50%;-o-animation: rotate-loading 1.5s linear 0s infinite normal;-o-transform-origin: 50% 50%;-webkit-animation: rotate-loading 1.5s linear 0s infinite normal;-webkit-transform-origin: 50% 50%;animation: rotate-loading 1.5s linear 0s infinite normal;transform-origin: 50% 50%;}
.loading-container:hover .loading {border-color: transparent #83f0de transparent #83f0de;}
.loading-container:hover .loading,.loading-container .loading {-webkit-transition: all 0.5s ease-in-out;-moz-transition: all 0.5s ease-in-out;-ms-transition: all 0.5s ease-in-out;-o-transition: all 0.5s ease-in-out;transition: all 0.5s ease-in-out;}
 #loading-text {-moz-animation: loading-text-opacity 2s linear 0s infinite normal;-o-animation: loading-text-opacity 2s linear 0s infinite normal;-webkit-animation: loading-text-opacity 2s linear 0s infinite normal;animation: loading-text-opacity 2s linear 0s infinite normal;color: #ffffff;font-family: "Century Gothic W01", "Century Gothic", sans-serif;font-size: 1.4rem;font-weight: bold;margin-top: 50px;opacity: 0;position: absolute;text-align: center;text-transform: uppercase;top: 0;width: 120px;}
.eachTextAnime span{opacity: 0;}.eachTextAnime.appeartext span{ animation:text_anime_on 1s ease-out forwards;}
@keyframes text_anime_on {0% {opacity:0;} 100% {opacity:1;}}
#contents{padding-bottom: 100px;overflow: hidden;}
#contents-t2{padding: 10.4rem 0;overflow: hidden;}
@media screen and (max-width: 640px) {
#contents-t2{padding: 8rem 0;}
}
h2{color: #000; font-size: 3.2rem; line-height: 3.2rem;}
.row-rev {-webkit-box-orient: horizontal;-webkit-box-direction: reverse;-ms-flex-direction: row-reverse;flex-direction: row-reverse;}
.flexblock{display: -webkit-box;display: -ms-flexbox;display: flex;-ms-flex-wrap: wrap;flex-wrap: wrap;}
.nowrapflex{display: -webkit-box;display: -ms-flexbox;display: flex;-ms-flex-wrap: nowrap;flex-wrap: nowrap;}
.col-2{width: calc(100% / 2);}
.col-3{width: calc(100% / 3);}
.col-4{width: calc(100% / 4);}
.col-5{width: calc(100% / 5);}
.col-6{width: calc(100% / 6);}
.imgblock{-webkit-box-flex: 0;-ms-flex: 0 0 50%;flex: 0 0 50%;line-height: 0; overflow: hidden;}
.imgblock img{-webkit-transform: scale(1);-ms-transform: scale(1);transform: scale(1);-webkit-transition-duration: 2s;-o-transition-duration: 2s;transition-duration: 2s;max-width: 100%; line-height: 0;overflow: hidden;}
.flexblock:hover .imgblock img{-webkit-transform: scale(1.1);-ms-transform: scale(1.1);transform: scale(1.1);}
.catchtx{font-size: 1.6rem;margin: 10px auto; letter-spacing: 0.3rem;}
.invisible {visibility: hidden;}
#main-visual {position:relative; width: 100%; color: #fff; box-sizing: border-box;overflow: hidden;height: 80vh; background: #000;}
#main-visual video,#main-visual img {width: 100%; height: 100vh; z-index: 1; overflow: hidden;object-fit: cover;}
.subimage img{animation:fadein2 1.5s ease-in; vertical-align: bottom;}
.subimage img.trans{transform: translate(0%,-17%);}
.subimage img.trans2{transform: translate(0%,-10%);}
@keyframes fadein2 {0% {opacity:0;}100% {opacity:1;}}
.slider{opacity: 0;transition: opacity .3s linear;}
.slider.slick-initialized{opacity: 1;}
.slide-animation{animation: fadezoom 8s 0s forwards;}
@keyframes fadezoom {0% {transform: scale(1.2);} 100% {transform: scale(1.0);}}

#sub-visual {position:relative; width: 100%; color: #fff; box-sizing: border-box;overflow: hidden;height:400px;}
#sub-visual video,#sub-visual img {position: absolute;left: 0;bottom: 0;width: 100%; height: 100%; z-index: 1; overflow: hidden;object-fit: cover;}
#tcont #main-visual {height: 100vh !important;}
.main_text {z-index:11;position: absolute;top:55%;left:50%;transform:translate(-50%,-50%);width:80%;text-align: center;}
.main_text h1{color: #ffffff;font-size: 5rem;font-weight: bold;text-shadow: 0px 0px 10px rgba(0,0,0,0.4),0px 0px 3px rgba(0,0,0,0.4); margin-bottom: 20px;}
.main_text p{color: #ffffff;font-size: 3rem;font-weight: bold;text-shadow: 0px 0px 10px rgba(0,0,0,0.4),0px 0px 3px rgba(0,0,0,0.4); letter-spacing: 3px;}
@media screen and (max-width: 640px){
.main_text {width:100%;}
.main_text.w90{width:90% !important;}
.main_text h1{font-size: 4.6rem;text-shadow: 0px 0px 5px rgba(0,0,0,0.4),0px 0px 3px rgba(0,0,0,0.4); margin-bottom: 10px;}
.main_text h1.long{font-size: 3.8rem;}
.main_text p{font-size: 2.4rem;text-shadow: 0px 0px 5px rgba(0,0,0,0.4),0px 0px 3px rgba(0,0,0,0.4);}
}
#tcont .main_text{text-align: left;}
.main_img {opacity: 0;width:100%;height:100%;object-fit: cover;font-family:'object-fit: cover;';position: absolute;left: 0;top: 0;-webkit-animation: anime 18s 0s infinite;animation: anime 18s 0s infinite;}
.main_img:nth-of-type(2) {-webkit-animation-delay: 6s;animation-delay: 6s;}
.main_img:nth-of-type(3) {-webkit-animation-delay: 10s;animation-delay: 10s;}
.main_img:nth-of-type(4) {-webkit-animation-delay: 14s;animation-delay: 14s;}
@keyframes anime {0% {opacity: 0;}8% {opacity: 1;}17% {opacity: 1;}25% {opacity: 1;transform: scale(1.2);z-index:9;}100% { opacity: 0;}}
@-webkit-keyframes anime {0% {opacity: 0;}8% {opacity: 1;}17% {opacity: 1;}25% {opacity: 0;-webkit-transform: scale(1.2);z-index:9;}100% { opacity: 0;}}
header{overflow: hidden;}
header .logo{width: 10.4rem;height: 10.4rem;-webkit-box-sizing: border-box;box-sizing: border-box;background-color: #1c1f22;position: fixed;z-index: 1000;top: 0;left: 0;}
header .logo img{width: 90%;}
header .logo a{display: -webkit-box !important;display: -ms-flexbox !important;display: flex !important;-webkit-box-pack: center;-ms-flex-pack: center;justify-content: center;-webkit-box-align: center;-ms-flex-align: center;align-items: center;width: 100%;height: 100%;}
.logolight:hover {display: block;-webkit-animation: logolight 500ms forwards ease-out;animation: logolight 500ms forwards ease-out;color: #1c1f22;}
@-webkit-keyframes logolight { 0% {opacity: 0.5;} 100% {opacity: 1;}}
@keyframes logolight {0% {opacity: 0.5;} 100% {opacity: 1;}}
.headmail {width: 10.4rem;height: 10.4rem;-webkit-box-sizing: border-box;box-sizing: border-box;position: fixed;z-index: 10001;top: 0;right: 10.4rem;background-color: #fff;cursor: pointer;text-align: center;}
.headmail a{display: -webkit-box;display: -ms-flexbox;display: flex;-webkit-box-orient: vertical;-webkit-box-direction: normal;-ms-flex-direction: column;flex-direction: column;-webkit-box-pack: center;-ms-flex-pack: center;justify-content: center;width: 100%;height: 100%;text-align: center;text-transform: uppercase;color: #1c1f22;text-decoration: none;font-family: "Century Gothic W01", "Century Gothic", sans-serif;letter-spacing: 0.05em;position: relative;-webkit-transition: all 0.6s;-o-transition: all 0.6s;transition: all 0.6s;}
.headmail a:hover{color: #ffffff; background-color: #1c1f22;}
.headmail i{font-size: 2.4rem;}
.headmail span{display: block;font-size: 1.4rem;}
.hamburger {width: 10.4rem;height: 10.4rem;padding: 3.5rem 2.5rem;-webkit-box-sizing: border-box;box-sizing: border-box;position: fixed;z-index: 10001;top: 0;right: 0;background-color: #616365;cursor: pointer;}
.inner_line {position: relative;width: 100%;height:100%;transition: 1s;border-radius: 4px;}
.hamburger span {display:block;position:absolute;width:100%;height:0.2rem;background:#fff;-webkit-transition:0.3s ease-in-out;-moz-transition:0.3s ease-in-out;transition:0.3s ease-in-out;}
.hamburger span:nth-child(1) {top: 0;}
.hamburger span:nth-child(2) {top: 50%;-webkit-transform: translateY(-50%);-ms-transform: translateY(-50%);transform: translateY(-50%);}
.hamburger span:nth-child(3) {bottom: 0;}
.hamburger.active span:nth-child(1) {top:50%;background:#fff;-webkit-transform: rotate(-45deg);-moz-transform: rotate(-45deg);transform: rotate(-45deg);}
.hamburger.active span:nth-child(2),.hamburger.active span:nth-child(3) {top: 50%;background :#fff;-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);transform: rotate(45deg);}
nav.gnav {position:fixed;z-index:1000;top:0;right:0;color:#fff;background:rgba(0,0,0,0.8);text-align:left;width: 30%; height: 100vh; overflow-y: scroll;transform:translateX(100%);transition:all 0.6s;}
nav.gnav ul.mainbox {margin: 0 auto;padding-top: 10.4rem;width: 100%;border-bottom: solid 1px #444;}
nav.gnav li.subbox{display: none; background: #333;padding-right: 0 !important;}
nav.gnav li.subbox li{border-bottom: solid 1px #666; border-top: none; }
nav.gnav li.subbox li:last-child{border: none;}
nav.gnav li.subbox.active{display: block;}
nav.gnav li .tgbtn:after{font-family: 'Material Icons';font-weight: normal;font-style: normal;font-size: 24px;display: inline-block;width: 10.4rem; height: 88px;color: #fff;line-height: 88px;text-align: center;text-transform: none; content: "add";direction: ltr;-webkit-font-smoothing: antialiased;text-rendering: optimizeLegibility;-moz-osx-font-smoothing: grayscale;font-feature-settings: 'liga'; cursor: pointer;}
nav.gnav li .tgbtn.active:after{content: "remove";}
nav.gnav ul li {list-style-type: none;padding: 0;width: 100%; box-sizing: border-box;transition: .4s all; font-size: 1.6rem; border-top: solid 1px #444;display: -webkit-box;display: -ms-flexbox;display: flex;-webkit-box-pack: justify;-ms-flex-pack: justify;justify-content: space-between;-webkit-box-align: center;-ms-flex-align: center;align-items: center;-webkit-box-sizing: border-box;box-sizing: border-box;}
nav.gnav ul li:last-child {padding-bottom: 0;border-bottom: none;}
nav.gnav ul li:hover{background :#333;}
nav.gnav ul li .mwrap{flex: 1;}
nav.gnav ul li i{width: 10.4rem; text-align: center;}
nav.gnav ul li a {display: block;color: #fff; font-weight: bold;padding: 1.5em 3rem;text-decoration :none;}
nav.gnav li.subbox a{padding: 1em 6rem !important; display: block;}
nav.gnav ul li a span{display: block; font-size: 1rem; font-weight: normal;}
nav.gnav.active {opacity: 100;display: block;transform: translateX(0%);}
.area_s{width: 10.4rem; height: 100%; position: absolute; top:0;left: 0; background: #000; color: #fff;}
.area_s p{width: 104rem; display: -webkit-box; display: -ms-flexbox; display: flex;justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; position: absolute; top: 50%;left: 50%; -webkit-transform: translate(-50%, -50%) rotate(90deg);-ms-transform: translate(-50%, -50%) rotate(90deg);transform: translate(-50%, -50%) rotate(90deg); font-size: 1.6rem;}

#pickup{position: relative; overflow: hidden; padding: 8rem 0 0 0;}
#pickup .area_s{left: auto; right: 0;}
#pickup .wrap{width: calc(100% - 10.4rem);position: relative; padding: 40px 10.4rem 150px 16.4rem; box-sizing: border-box; font-size: 1.6rem;}
#pickup .item{box-shadow: 5px 5px 10px rgba(0,0,0,0.2);}
#pickup .col-2:nth-child(2){padding-top: 15rem;}
#pickup .pdon{padding: 0px 60px 0 0;box-sizing: border-box;}
#pickup .imgarea{line-height: 0; overflow: hidden; position: relative; background: #000;}
#pickup .imgarea img{-webkit-transform: scale(1);-ms-transform: scale(1);transform: scale(1);-webkit-transition-duration: 2s;-o-transition-duration: 2s;transition-duration: 2s;max-width: 100%; line-height: 0;overflow: hidden;}
#pickup .item:hover .imgarea img{-webkit-transform: scale(1.1);-ms-transform: scale(1.1);transform: scale(1.1);}
#pickup h2{background: rgba(34,157,136,.7); width: 90%; text-align: center; padding: 15px 0; color: #fff; font-size: 2.4rem; font-weight: bold; line-height: 3rem; position: absolute; left: 50%; top:80%; box-sizing: border-box; z-index: 1000;-webkit-transform: translate(-50%, -50%);-ms-transform: translate(-50%, -50%) ;transform: translate(-50%, -50%);}
#pickup .tbox{line-height: 3rem; padding: 20px 25px;}

#business{position: relative; overflow: hidden; padding: 0px 0 0 0; font-size: 1.6rem; margin-top: 10rem;}
#business .area_s{background: #fff; color: #000 !important; letter-spacing: 0.5rem;}
#business .wrap{position: relative; padding: 50px 100px; box-sizing: border-box;width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; background: #eee;}
#business .wrap .imgarea{text-align: center; width: 950px; margin: 20px auto 0 auto;}
#business .wrap .imgarea img{width: 100%;}
#business .subbox{line-height: 3.8rem; padding: 2rem; letter-spacing: .4rem;}

#section{ font-size: 1.6rem; padding: 50px 0; box-sizing: border-box; overflow: hidden; text-align: center;}
#section h2{text-align: center;position: relative; display: inline-block; padding: 0 120px; margin-bottom: 20px;}
#section h2:before,#section h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#section h2:before {left: 0;}
#section h2:after {right: 0;}
#section .flexblock{padding: 40px 10.4rem;}
#section .pdon{padding: 0px 20px 0px 20px;box-sizing: border-box;}
#section .imgarea{line-height: 0; overflow: hidden; position: relative;}
#section .imgarea img{-webkit-transform: scale(1);-ms-transform: scale(1);transform: scale(1);-webkit-transition-duration: 2s;-o-transition-duration: 2s;transition-duration: 2s;max-width: 100%; line-height: 0;overflow: hidden;}
#section .item:hover .imgarea img{-webkit-transform: scale(1.1);-ms-transform: scale(1.1);transform: scale(1.1);}
#section h3{background: rgba(0,0,0,.5); width: 80%; text-align: center; padding: 15px 0; color: #fff; font-size: 2.4rem; font-weight: bold; line-height: 2.4rem; position: absolute; left: 50%; top:50%; box-sizing: border-box; z-index: 1000;-webkit-transform: translate(-50%, -50%);-ms-transform: translate(-50%, -50%) ;transform: translate(-50%, -50%);}
#section .tbox{line-height: 3rem; padding: 10px 15px; text-align: left;}
#section .libtn{}
#section .libtn{position: relative;z-index: 1;display: inline-block;width: 90%;padding:25px 0;background: #fff;color: #08a88d; border: solid 1px #00c9a7; box-sizing: border-box; text-align: center;transition: .3s; line-height: 0;}
#section .libtn:hover{color: #fff;}
#section .libtn::before {position: absolute;top: 0;right: 0;bottom: 0;left: 0;z-index: -1;content: '';background: #00c9a7;transform-origin: right top;transform: scale(0, 1);transition: transform .3s;}
#section .libtn:hover::before {transform-origin: left top;transform: scale(1, 1);}

/*
#newslist{position: relative; overflow: hidden;}
#newslist .area_s{background: #fff; color: #000 !important; letter-spacing: 0.5rem;}
#newslist .wrap{position: relative; padding: 100px 100px 200px 100px; box-sizing: border-box;width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; background: #eee;}
#newslist .col-3{margin-top: 40px; padding: 15px; box-sizing: border-box;}
#newslist .item{ background: #fff;box-shadow: 5px 5px 10px rgba(0,0,0,0.2); padding: 10px; font-size: 1.6rem;}
#newslist .imgarea{line-height: 0; overflow: hidden; position: relative; background: #000;}
#newslist .imgarea img{-webkit-transform: scale(1);-ms-transform: scale(1);transform: scale(1);-webkit-transition-duration: 2s;-o-transition-duration: 2s;transition-duration: 2s;max-width: 100%; line-height: 0;overflow: hidden;}
#newslist .item:hover .imgarea img{-webkit-transform: scale(1.1);-ms-transform: scale(1.1);transform: scale(1.1);}
#newslist .messagebox{ position: relative; padding: 10px 5px;}
#newslist h3{border-bottom: solid 1px #eee; padding:0 5px 5px 5px; margin-bottom: 10px; font-weight: bold; }
#newslist h3 i{margin-right: 10px;}
#newslist .section{padding:0 10px 10px 10px; font-size: 1.4rem;}
*/

#newslist{position: relative; overflow: hidden;}
#newslist .area_s{background: #fff; color: #000 !important; letter-spacing: 0.5rem;}
#newslist .wrap{position: relative; padding: 100px 100px 200px 100px; box-sizing: border-box;width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; background: #eee;}
#newslist .col-3{margin-top: 40px; padding: 15px; box-sizing: border-box;width: 100%;}
#newslist .item{ background: #fff;box-shadow: 5px 5px 10px rgba(0,0,0,0.2); padding: 10px; font-size: 1.6rem;display: flex;}
#newslist .imgarea{line-height: 0; overflow: hidden; position: relative; /*background: #000;*/ max-width: 30%;}
#newslist .imgarea img{-webkit-transform: scale(1);-ms-transform: scale(1);transform: scale(1);-webkit-transition-duration: 2s;-o-transition-duration: 2s;transition-duration: 2s;max-width: 90%; line-height: 0;overflow: hidden;}
#newslist .item:hover .imgarea img{-webkit-transform: scale(1.1);-ms-transform: scale(1.1);transform: scale(1.1);}
#newslist .messagebox{ position: relative; padding: 10px 5px;}
#newslist h3{border-bottom: solid 1px #eee; padding:0 5px 5px 5px; margin-bottom: 10px; font-weight: bold; }
#newslist h3 i{margin-right: 10px;}
#newslist .section{padding:0 10px 10px 10px; font-size: 1.4rem;}

#news{font-size: 1.6rem; padding: 15rem 0; box-sizing: border-box; overflow: hidden; text-align: center;}
#news h2{position: relative; display: inline-block; padding: 0 120px;}
#news h2:before,#news h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#news h2:before {left: 0;}
#news h2:after {right: 0;}
#news .block{margin-top: 40px;}
#news .wrap{width: 1300px; margin:0 auto; background: #fff;-webkit-box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); border: 1px solid #eee;display: flex;display: -webkit-flex;-webkit-flex-wrap: nowrap; flex-wrap: nowrap; padding: 2rem; box-sizing: border-box;}
#news .inner{position: relative;}
#news .bgcol{width: 100%; height: 300%; display: flex;position: absolute;right: -15vw;top: -200px;z-index: -1; background: #eee;}
#news .imagebox{width: 45%; line-height: 0;}
#news .imagebox img{width: 100%;}
#news .messagebox{ position: relative; padding: 20px 20px;flex: 1; text-align: left;}
#news h3{border-bottom: solid 1px #eee; padding: 10px 10px; margin-bottom: 10px; font-weight: bold; font-size: 18px;}
#news h3 i{margin-right: 10px;}
#news .section{padding:0 20px 20px 20px; line-height: 3rem;}

#access{position: relative; overflow: hidden; margin-top: -10rem; padding-bottom: 10rem;}
#access .area_s{left: auto; right: 0; background: none; color: #000;}
#access .area_s p{top: 40%;left: 50%; -webkit-transform: translate(-50%, -50%) rotate(90deg);-ms-transform: translate(-50%, -50%) rotate(90deg);transform: translate(-50%, -50%) rotate(90deg);}
#access .wrap{position: relative; width: calc(100vw - 10.4rem); margin: 0 10.4rem 0 0; box-sizing: border-box; font-size: 1.6rem;box-shadow: 5px 5px 10px rgba(0,0,0,0.2);}
#access .section{margin:0 auto;}
#access .section iframe{width: 100%; height: 600px;}

footer{background: #000; color: #fff; text-align: center;}
footer .inner{ padding: 15rem 10rem 20rem 10rem;}
footer h2{color: #fff; margin-bottom: 40px;}
footer .flexblock{margin-top: 40px;}
footer .col-3{box-sizing: border-box; padding: 4rem 0;}
footer .col-3:nth-child(2){ border-left: solid 1px #666;border-right: solid 1px #666;}
footer .item{padding:0 7rem; font-size: 1.6rem; box-sizing: border-box;}
footer .item h3{margin-bottom: 10px;}
footer .item i{font-size: 6rem; margin-bottom: 20px;}
footer .item p{margin-bottom: 20px;color: rgba(255, 255, 255, 0.8);}
footer .telno{font-size: 3.2rem; color: #fff !important;}
footer .logo{width: 150px; margin: 0 auto 2rem auto;}
footer .logo img{width: 100%; -webkit-filter: invert(.5);filter: invert(.5);}
footer .libtn{}
footer .libtn a{position: relative;z-index: 1;display: inline-block;width: 100%;padding:25px 0;background: #fff;color: #08a88d; border: solid 1px #00c9a7; box-sizing: border-box; text-align: center;transition: .3s; line-height: 0;}
footer .libtn a:hover{color: #fff;}
footer .libtn a::before {position: absolute;top: 0;right: 0;bottom: 0;left: 0;z-index: -1;content: '';background: #00c9a7;transform-origin: right top;transform: scale(0, 1);transition: transform .3s;}
footer .libtn a:hover::before {transform-origin: left top;transform: scale(1, 1);}
footer .catchtx{color: rgba(255, 255, 255, 0.8);}

footer .copyright{font-size: 14px; height: 10.4rem; background: #fff; color: #000; box-sizing: border-box; text-align: left !important;padding: 3.6rem 5rem;}
footer .copyright i{margin:0 5px;}
footer .copyright a{color: #000;text-decoration: none;}
footer .copyright .flexblock{margin-top: 0; -webkit-box-pack: justify;-ms-flex-pack: justify;justify-content: space-between;-webkit-box-align: center;-ms-flex-align: center;align-items: center;width: 100%;-webkit-box-sizing: border-box;box-sizing: border-box;}
footer .copyright h2{margin-right: 2rem; color: #000; font-size: 1.6rem; margin-bottom: 0; line-height: 1.6rem; width: 20rem;}
footer .copyright h2 img{width: 24px; line-height: 0; margin-right: 10px; vertical-align: middle;filter: grayscale(100%);}
footer .copyright .address{}
footer .copyright .copy_text{margin-left: auto; margin-right: 8rem;}

#page-top{position: fixed;bottom: 0px;right: 0px; z-index: 10000;}
#page-top a{color: #fff;text-align: center;display: block; width: 10.4rem; height: 10.4rem; background: #00c9a7; padding-top: 2.4rem; box-sizing: border-box;}
#page-top a i{font-size: 6rem;}

@media (min-width: 641px) {
#businesslist .flexblock{text-align: center;border-top: 1px solid #dfdfdf;border-bottom: 1px solid #dfdfdf;-webkit-box-align: center;-ms-flex-align: center;-moz-align-items: center;align-items: center; margin:0rem auto 0rem auto;}
#businesslist .flexblock li{font-size: 1.8rem; border-left: 1px solid #dfdfdf; box-sizing: border-box;}
#businesslist .flexblock li:nth-child(1),#businesslist .flexblock li:nth-child(4){border-left: none;}
#businesslist .flexblock li:nth-child(1),#businesslist .flexblock li:nth-child(2),#businesslist .flexblock li:nth-child(3){border-bottom: 1px solid #dfdfdf;}
}
#businesslist .flexblock li a{position: relative;z-index: 1;display: inline-block;width: 100%;padding:2.5rem 0;background: #fff;color: #08a88d; box-sizing: border-box; text-align: center;transition: .3s; line-height: 0;}
#businesslist .flexblock li.current a{background: #eee;}
#businesslist .flexblock li a span.entitle{font-size: 1.2rem; display: block;margin-top: 0.6rem; line-height: 1;}
#businesslist .flexblock li a span.jptitle{font-size: 1.8rem; display: block; line-height: 1;font-family: Noto Sans JP, sans-serif;font-weight: 400;}
#businesslist .flexblock li a:hover{color: #fff;}
#businesslist .flexblock li a::before {position: absolute;top: 0;right: 0;bottom: 0;left: 0;z-index: -1;content: '';background: #000;transform-origin: right top;transform: scale(0, 1);transition: transform .3s;}
#businesslist .flexblock li a:hover::before {transform-origin: left top;transform: scale(1, 1);}

#photography{padding: 15rem 0;overflow: hidden; margin-top: 10rem;}
#photography .catchtx{margin-bottom: 5rem;}
#photography .inner{position: relative;display: flex;display: -webkit-flex;-webkit-flex-wrap: wrap; flex-wrap: wrap;}
#photography .inner::after {content: ''; width: 100%;}
#photography .svlist {order: 1;}
#photography .bgcol{width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; height: 300%; display: flex;position: absolute;top: -200px;z-index: -1; background: #eee;}
#photography .slbox{width: 45%; height: 100%; position: relative;}
#photography .slbox img{width: 100%;}
#photography .prslider li{box-shadow: 15px 20px 20px rgba(0,0,0,0.3);}
#photography .slick-list{overflow: inherit;}
#photography .messagebox{ position: relative; padding: 0px 40px 80px 40px; box-sizing: border-box; width: 50%; margin-top: -5rem;}
#photography .svlist{display: flex;justify-content: space-between;/*align-items: center;*/flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.8rem; text-align: center; padding: 0rem 5rem;}
#photography .svlist li{padding: 10px 10px 15px 10px;width:calc(25% - 15px);display: flex;/*align-items: center;*/justify-content: center;flex-wrap: inherit;-webkit-flex-wrap: inherit;box-sizing: border-box; border-bottom: solid 6px /*#00c9a7*/#333; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 15px 5px 0 0; background: #fff;}
#photography .svlist li img{width: 100%; margin-bottom: 1rem;}
#photography .inbox{font-size: 1.6rem; padding: 0 0 0 1rem; box-sizing: border-box;}
#photography .inbox h3{font-size: 1.6rem;display: flex; align-items: center;font-weight: bold;border-top: solid 3px #fff; margin-bottom: 1.2rem; padding-top: 1.5rem; text-shadow:1px 1px 0 #fff, -1px -1px 0 #fff,-1px 1px 0 #fff, 1px -1px 0 #fff,0px 1px 0 #fff, 0 -1px 0 #fff,-1px 0 0 #fff, 1px 0 0 #fff;position: relative;}
#photography .inbox h3:after {position: absolute;content: " ";display: block;border-top: solid 3px #666;top: -3px;width: 30%;}
#photography .inbox h3 span{font-size: 2rem; margin-right: .5rem;}
#photography .inbox p{padding: 0 1rem; line-height: 2.8rem;}

#photoprice{padding: 15rem 10.4rem; font-size: 1.6rem;}
#photoprice p{line-height: 2.8rem;}
#photoprice .contarea{display: -webkit-box;display: -moz-flex;display: -ms-flexbox;display: flex;justify-content: space-between;justify-content:center;}
#photoprice .wraparea{display: -webkit-box;display: -moz-flex;display: -ms-flexbox;display: flex;justify-content: space-between;justify-content:center;flex-wrap:wrap;-webkit-flex-wrap: wrap;width: 75%;padding: 4rem 0rem;box-sizing: border-box;border-top: solid 1px #eee;}
#photoprice table tr:first-child th,#photoprice table tr:first-child td{padding-top: 2rem !important;}

#photoprice .imgsample{width: 90%; height: 100%; position: relative; margin-top: 5rem;}
#photoprice .imgsample img{width: 100%;}
#photoprice .subslider li{box-shadow: 5px 10px 20px rgba(0,0,0,0.3);}
#photoprice .slick-list{overflow: inherit;}

#photoprice .prbox-c3 table th{width: 40% !important; background: #3abea4; color: #fff; letter-spacing: .3rem;padding:2rem 0 2rem 1.5rem !important;}
#photoprice .prbox-c1 table th{width: 50% !important; background: #3abea4; color: #fff; letter-spacing: .3rem;padding:2rem 0 2rem 1.5rem !important;}
#photoprice td{text-align: right !important; padding:2rem 1.5rem 2rem 0 !important; background: #fff;}
#photoprice td span{margin-left: 2rem;}
#photoprice table{margin: 0 auto 2rem auto;}
#photoprice .prbox-c3{width:calc(33.3333333% - 3rem / 3); margin:0 3rem 0 0; box-sizing: border-box;-webkit-box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); border: 1px solid #14937a;border-bottom: 10px solid #14937a;}
#photoprice .prbox-c3:nth-child(3n){margin-right:0;}
#photoprice .prbox-c2{width:calc(50% - 2rem / 2); margin:0 2rem 0 0; box-sizing: border-box; background: #fff; text-align: center;-webkit-box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); border: 1px solid #14937a;border-bottom: 10px solid #14937a;}
#photoprice .prbox-c2:last-child{margin-right:0;}
#photoprice .prbox-c1{width:100%; margin:0 0 8rem 0; box-sizing: border-box; background: #fff; padding: 3rem 3rem; -webkit-box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); box-shadow: 0 2px 5px 0 rgb(0 0 0 / 20%); border: 1px solid #14937a;border-bottom: 10px solid #14937a;}
#photoprice .prbox-c1 p{line-height: 3.6rem; padding-left: 1rem;}
#photoprice .prbox-tt{width:100%; margin:0 0 3rem 0; box-sizing: border-box; text-align: center;}
#photoprice .contarea{box-sizing: border-box;}
#photoprice .flex-sub{margin-bottom: 10rem !important;}

.prbox-c3 h3{text-align: center;position: relative; display: inline-block; padding: 0 100px; font-size: 1.8rem; color: #fff; font-weight: bold;}
.prbox-c3 h3:before,.prbox-c3 h3:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 70px; height: 1px; background-color: #fff;}
.prbox-c3 h3:before {left: 0;}
.prbox-c3 h3:after {right: 0;}

.prbox-c2 h3{text-align: center;position: relative; display: inline-block; padding: 0 150px; font-size: 1.8rem; color: #fff; font-weight: bold;}
.prbox-c2 h3:before,.prbox-c2 h3:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #fff;}
.prbox-c2 h3:before {left: 0;}
.prbox-c2 h3:after {right: 0;}

.prbox-tt h2{text-align: center;position: relative; display: inline-block; padding: 0 150px; font-size: 2.4rem; color: #333; font-weight: bold;}
.prbox-tt h2:before,.prbox-tt h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #333;}
.prbox-tt h2:before {left: 0;}
.prbox-tt h2:after {right: 0;}

.hdtype1{background: #3abea4; border-bottom:solid 1rem #14937a; padding: 3rem 0; box-sizing: border-box; text-align: center;}
.tbinner{padding: 2rem 2rem;}
.tbinner p{font-size: 1.4rem;}
.prinner{padding: 1rem 0 3rem 0;}
.prinner p{line-height: 4rem !important;}
.prinner .fsmid{font-weight: bold; font-size: 1.8rem; padding: .5rem 0; background: #fffae9; margin: 1rem 1rem; color: #333; border-radius: 5px;}
.prinner .fsbig{font-weight: bold; font-size: 2.1rem; padding: 1rem 0; background: #fffae9; margin: 1rem 1rem; border-radius: 1rem; color: #333;}
.prinner .taleft{text-align: left; padding: 2rem 3rem 0 3rem; border-top: dashed 1px #ccc; margin: 2rem 1rem 0 1rem;}
.prinner .taleft p{line-height: 4rem !important;}

#company{padding: 15rem 15rem; font-size: 1.6rem;}
#map{padding: 15rem 15rem; font-size: 1.6rem;}
#recruit{padding: 10rem 15rem; font-size: 1.6rem;}
#recruit th,#recruit td{padding:2rem 0 2rem 1rem;}
#recruit table tr:first-child th,#recruit table tr:first-child td{padding-top: 0;}

#reclist .flexblock{text-align: center;border-top: 1px solid #dfdfdf;border-bottom: 1px solid #dfdfdf;-webkit-box-align: center;-ms-flex-align: center;-moz-align-items: center;align-items: center; margin:0rem auto 5rem auto;}
#reclist .flexblock li{font-size: 1.8rem; border-left: 1px solid #dfdfdf; box-sizing: border-box;}
#reclist .flexblock li:first-child{border-left: none;}
#reclist .flexblock li a{position: relative;z-index: 1;display: inline-block;width: 100%;padding:2.5rem 0;background: #fff;color: #08a88d; box-sizing: border-box; text-align: center;transition: .3s; line-height: 0;}
#reclist .flexblock li a span.entitle{font-size: 1.2rem; display: block;margin-top: 0.6rem; line-height: 1;}
#reclist .flexblock li a span.jptitle{font-size: 1.8rem; display: block; line-height: 1;font-family: Noto Sans JP, sans-serif;font-weight: 400;}
#reclist .flexblock li a:hover{color: #fff;}
#reclist .flexblock li a::before {position: absolute;top: 0;right: 0;bottom: 0;left: 0;z-index: -1;content: '';background: #000;transform-origin: right top;transform: scale(0, 1);transition: transform .3s;}
#reclist .flexblock li a:hover::before {transform-origin: left top;transform: scale(1, 1);}

#marketing h2{position: relative; display: inline-block; padding: 0 120px;}
#marketing h2:before,#marketing h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#marketing h2:before {left: 0;}
#marketing h2:after {right: 0;}
#marketing .flexblock{flex-wrap: nowrap; margin-top: 5rem;-webkit-box-align: center;-ms-flex-align: center;-moz-align-items: center;align-items: center;}
#marketing .imgwrap{background: #ccc; width: 40%; line-height: 0;}
#marketing .imgwrap img{width: 100%;}

#marketing{padding: 1rem 0;overflow: hidden; margin-top: 10rem; text-align: center;}
#marketing .catchtx{margin-bottom: 25rem;}
#marketing .inner{position: relative;display: flex;display: -webkit-flex;-webkit-flex-wrap: wrap; flex-wrap: wrap;}
#marketing .inner::after {content: ''; width: 100%;}
#marketing .svlist {order: 1;}
#marketing .bgcol{width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; height: 300%; display: flex;position: absolute;top: -200px;z-index: -1; background: #eee;}
#marketing .slbox{width: 45%; height: 100%; position: relative;}
#marketing .slbox img{width: 100%;}
#marketing .prslider li{box-shadow: 15px 20px 20px rgba(0,0,0,0.3);}
#marketing .slick-list{overflow: inherit;}
#marketing .messagebox{ position: relative; padding: 0px 40px 80px 40px; box-sizing: border-box; width: 50%; margin-top: -5rem;}
#marketing .svlist{display: flex;justify-content: space-between;/*align-items: center;*/flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.8rem; text-align: center; padding: 0rem 5rem;}
#marketing .svlist li{padding: 10px 10px 15px 10px;width:calc(25% - 15px);display: flex;/*align-items: center;*/justify-content: center;flex-wrap: inherit;-webkit-flex-wrap: inherit;box-sizing: border-box; border-bottom: solid 6px /*#00c9a7*/#333; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 15px 5px 0 0; background: #fff;}
#marketing .svlist li img{width: 100%; margin-bottom: 1rem;}
#marketing .inbox{font-size: 1.6rem; padding: 0 0 0 1rem; box-sizing: border-box; text-align: left;}
#marketing .inbox h3{font-size: 1.6rem;display: flex; align-items: center;font-weight: bold;border-top: solid 3px #fff; margin-bottom: 1.2rem; padding-top: 1.5rem; text-shadow:1px 1px 0 #fff, -1px -1px 0 #fff,-1px 1px 0 #fff, 1px -1px 0 #fff,0px 1px 0 #fff, 0 -1px 0 #fff,-1px 0 0 #fff, 1px 0 0 #fff;position: relative;}
#marketing .inbox h3:after {position: absolute;content: " ";display: block;border-top: solid 3px #666;top: -3px;width: 30%;}
#marketing .inbox h3 span{font-size: 2rem; margin-right: .5rem;}
#marketing .inbox p{padding: 0 1rem; line-height: 2.8rem;}

#market01,#market02{padding: 0; font-size: 1.6rem; margin-bottom: 10rem;}
#market01 .ovcont h3,#market02 .ovcont h3{font-size: 1.8rem;font-weight: bold;}
#market01 .imgwrap,#market02 .imgwrap{line-height: 0;}
#market01 .imgwrap img,#market02 .imgwrap img{width: 100%; height: 80vh; z-index: 1; overflow: hidden;object-fit: cover;}
#market01 .ovcont p,#market02 .ovcont p{line-height: 3.6rem;}
#market01 .headbox,#market02 .headbox{border-bottom: solid 2px #eee; margin-bottom: 1.2rem;position: relative; box-sizing: border-box;}
#market01 .headbox:after,#market02 .headbox:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #999;bottom: -2px;width: 45%;}
#market01 .headbox p,#market02 .headbox p{font-size: 1.4rem; line-height: 3.6rem;color: #08a88d;}

#market01 .wrap{position: relative; padding: 0rem; box-sizing: border-box;width: calc(100vw - 30rem); margin: 0 0 0 30rem;}
#market01 .ovcont{position: absolute; background: #fff; padding: 5rem 5rem 5rem 1rem; left: 0rem; bottom:0;border-radius: 0 8px 0 0; width: 40%; z-index: 1; box-sizing: border-box;}

#market02 .wrap{position: relative; padding: 0rem; box-sizing: border-box;width: calc(100vw - 30rem); margin: 0 30rem 0 0;}
#market02 .ovcont{position: absolute; background: #fff; padding: 5rem 1rem 5rem 5rem; right: 0rem; bottom:0;border-radius: 8px 0 0 0; width: 40%; z-index: 1; box-sizing: border-box;}

#realestate{padding: 10rem 0; font-size: 1.6rem;text-align: center;box-sizing: border-box; overflow: hidden;}
#realestate h2{position: relative; display: inline-block; padding: 0 120px;}
#realestate h2:before,#realestate h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#realestate h2:before {left: 0;}
#realestate h2:after {right: 0;}

#select .flexblock{text-align: center;border-top: 5px solid #312927;border-bottom: 1px solid #dfdfdf;-webkit-box-align: center;-ms-flex-align: center;-moz-align-items: center;align-items: center; margin:0rem auto 5rem auto;}
#select .flexblock li{font-size: 1.8rem; border-left: 1px solid #dfdfdf; box-sizing: border-box;}
#select .flexblock li:first-child{border-left: none;}
#select .flexblock li a{position: relative;z-index: 1;display: inline-block;width: 100%;padding:2rem 0;background: #fff;color: #000; box-sizing: border-box; text-align: center;transition: .3s; line-height: 0;}
#select .flexblock li a span.entitle{font-size: 1.2rem; display: block;margin-top: 0.6rem; line-height: 1;}
#select .flexblock li a span.jptitle{font-size: 1.8rem; display: block; line-height: 1;font-family: Noto Sans JP, sans-serif;font-weight: 400;}
#select .flexblock li a:hover{color: #fff;}
#select .flexblock li a::before {position: absolute;top: 0;right: 0;bottom: 0;left: 0;z-index: -1;content: '';background: #312927;transform-origin: 50% 0%;transform: scaleY(0);transition: transform .3s;}
#select .flexblock li a:hover::before {transform-origin: 50% 0%;transform: scaleY(1);}

#select1{padding: 5.2rem 10.4rem; font-size: 1.6rem;text-align: center;box-sizing: border-box; overflow: hidden;}
#select1 .flexblock{flex-wrap: nowrap; margin-top: 5rem; position: relative;justify-content: space-between;}
#select1 .inbox{letter-spacing: .3rem;text-align: left; width: 60%; line-height: 4rem; padding: 5rem 5rem; background: #fff; position: absolute;right: 0; bottom: -7rem;}
#select1 h3{font-size: 2.1rem;font-weight: bold; line-height: 3rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#select1 h3 span{display: block; font-size: 1.6rem; font-weight: normal; color: #666;}
#select1 h4{font-size: 2.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
#select1 h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#select1 .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 0 0 0 0;position: relative;}
#select1 .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
#select1 .imgwrap{width: 45%; height: auto; line-height: 0;}
#select1 .imgwrap img{width: 100%; height: 100%;overflow: hidden;object-fit: cover;}

#select2{padding: 10.4rem 10.4rem; font-size: 1.6rem;box-sizing: border-box; overflow: hidden;}
#select2 .flexblock{flex-wrap: nowrap; margin-top: 5rem; position: relative;}
#select2 .inbox{letter-spacing: .3rem;text-align: left; width: 60%; line-height: 4rem; padding: 0 4rem; order: 1; background: #fff; margin-top: 1rem;}
#select2 h3{font-size: 2.1rem;font-weight: bold; line-height: 3rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#select2 h3 span{display: block; font-size: 1.6rem; font-weight: normal; color: #666;}
#select2 h4{font-size: 2.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
#select2 h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#select2 .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 1.5rem 0 0 0;position: relative; box-sizing: border-box;}
#select2 .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
#select2 .imgwrap{width: 40%; line-height: 0; order: 2;}
#select2 .imgwrap img{width: 100%;}

#select3{padding: 10.4rem 10.4rem; font-size: 1.6rem;text-align: center;box-sizing: border-box; overflow: hidden;}
#select3 .flexblock{flex-wrap: nowrap; margin-top: 5rem;}
#select3 .inbox{letter-spacing: .3rem;text-align: left; width: 60%; line-height: 4rem; padding: 0 4rem;}
#select3 h3{font-size: 2.1rem;font-weight: bold; line-height: 3rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#select3 h3 span{display: block; font-size: 1.6rem; font-weight: normal; color: #666;}
#select3 h4{font-size: 2.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
#select3 h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#select3 .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 1.5rem 0 0 0;position: relative;}
#select3 .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
#select3 .imgwrap{width: 40%; line-height: 0;}
#select3 .imgwrap img{width: 100%;}

#select4{padding: 5.2rem 10.4rem; font-size: 1.6rem;box-sizing: border-box; overflow: hidden; position: relative;}
#select4 .flexblock{flex-wrap: nowrap; margin-top: 5rem;}
#select4 .inbox{letter-spacing: .3rem;text-align: left; width: 60%; line-height: 4rem; padding: 0 4rem; order: 1;}
#select4 h3{font-size: 2.1rem;font-weight: bold; line-height: 3rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#select4 h3 span{display: block; font-size: 1.6rem; font-weight: normal; color: #666;}
#select4 h4{font-size: 2.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
#select4 h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#select4 .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 1.5rem 0 0 0;position: relative; box-sizing: border-box;}
#select4 .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
#select4 .imgwrap{width: 40%; line-height: 0; order: 2; position: relative;}
#select4 .imgwrap img{width: 100%;}

.flow{width: 100%; margin: 5rem auto 0 auto;background: #eee; padding: 5rem 5rem; box-sizing: border-box; overflow: hidden;text-align: left;}
.flow .headarea{border-bottom: solid 2px #fff !important; margin-bottom: 3rem !important;}
.flow .headarea p{font-size: 1.6rem;font-weight: normal; line-height: 3rem !important; letter-spacing: .5rem; color: #333; margin-bottom: 1rem; text-align: left; padding-left: .7rem;}
.flow .odlist{display: flex;justify-content: space-between;flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.6rem; text-align: center;}
.flow .odlist li{padding: 10px 10px 15px 10px;width:calc(25% - 1.5rem);display: flex;/*align-items: center;*/ /*justify-content: center;*/box-sizing: border-box;border-top: solid 6px #312927; border-bottom: solid 3px #312927; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 1.5rem 0 1.5rem 0.5rem; background: #fff;position: relative; flex-direction: column;}
.flow .odlist li:nth-child(1),.flow .odlist li:nth-child(5){margin-left: 0;}
.flow .odlist li img{width: 100%; margin-bottom: 1rem;}
.flow .odlist h3{font-size: 1.6rem !important; font-weight: normal !important; position: relative; border-bottom: solid 1px #000; padding-left:0 !important;}
.flow .odlist h3::before {content: attr(data-number);display: inline-block;margin-right: 1rem;color: #fff; font-weight: bold;font-size: 1.8rem;letter-spacing: normal; line-height: 5rem;background: #312927; width: 5rem; height: 5rem; text-align: center !important;}
.flow .odlist .txcont{text-align: left; font-size: 1.6rem; padding: 0 1rem; line-height: 3rem;}

#inpage{padding: 5rem 0rem; font-size: 1.6rem; text-align: center;}
#inpage #hero h2{position: relative; display: inline-block; padding: 0 120px;color: #ffffff;font-size: 3.6rem;font-weight: bold;text-shadow: 0px 0px 10px rgba(0,0,0,0.4),0px 0px 3px rgba(0,0,0,0.4);}
#inpage .catchtx{line-height: 4rem; margin-bottom: 3rem;}
#inpage #hero {position:relative; width: 100%; color: #fff; box-sizing: border-box;overflow: hidden;height: 50vh; background: #000; margin-bottom: 6rem;}
#inpage #hero img {width: 100%; height: 50vh; z-index: 1; overflow: hidden;object-fit: cover; opacity: .7;}
.hero_text {z-index:11;position: absolute;top:55%;left:50%;transform:translate(-50%,-50%);width:80%;text-align: center;}
#inpage .wrap{padding: 5rem 15rem; font-size: 1.6rem;}
#inpage .wrap h3{font-size: 2.1rem;font-weight: bold; line-height: 3rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#inpage .wrap h3 span{display: block; font-size: 1.6rem; font-weight: normal; color: #666;}
#inpage .wrap .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 1.5rem 0 0 0;position: relative; box-sizing: border-box;}
#inpage .wrap .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
.texarea_t1{}
.texarea_t1 h4{font-size: 1.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
.texarea_t1 h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#inpage .wrap .flexblock{flex-wrap: nowrap; margin-bottom: 5rem;padding: 2rem 3rem 2.5rem 3rem; box-sizing: border-box;border: solid 1px #312927; box-shadow:0 3px 4px rgba(0,0,0,0.3); background: #fff; border-radius: 1rem;align-items: center;}
#inpage .wrap .flexblock:last-child{margin-bottom: 0;}
#inpage .wrap .imgwrap{width: 25rem; line-height: 0; position: relative; margin-right: 2rem;}
#inpage .wrap .imgwrap img{width: 25rem; height: 25rem; object-fit: cover; border-radius: 50%;}
#inpage .wrap .imgwrap.opt1 img{object-position: 0 50%;}
#inpage .wrap .texrow{text-align: left; padding: 5rem 5rem; background: #eee;}
#inpage .wrap th{vertical-align: top;}

#nightleisure{padding: 10rem 10.4rem; font-size: 1.6rem;text-align: center;box-sizing: border-box;}
#nightleisure h2{position: relative; display: inline-block; padding: 0 120px;}
#nightleisure h2:before,#nightleisure h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#nightleisure h2:before {left: 0;}
#nightleisure h2:after {right: 0;}
#nightleisure .nowrapflex{position: relative; padding: 0 10.4rem; box-sizing: border-box; overflow-y: scroll;}
#nightleisure .cont_l{width: 45% !important; background: #ccc; height: 500px; position: sticky; top: 0;}
#nightleisure .cont_r{width: 55%; background: #eee;}

#nightleisure .headbox{padding:0 10.4rem 5.2rem 10.4rem; font-size: 1.6rem;text-align: center;box-sizing: border-box; margin: 10rem auto 15rem auto;}
#nightleisure .flexblock{flex-wrap: nowrap; margin-top: 5rem; position: relative;justify-content: space-between;}
#nightleisure .inbox{letter-spacing: .3rem;text-align: left; width: 60%; line-height: 4rem; padding: 5rem 5rem; background: #fff; position: absolute;right: 0; bottom: -7rem;}
#nightleisure h3{font-size: 2.1rem;font-weight: bold; line-height: 3rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#nightleisure h3 span{display: block; font-size: 1.6rem; font-weight: normal; color: #666;}
#nightleisure h4{font-size: 2.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
#nightleisure h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#nightleisure .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 0 0 0 0;position: relative;}
#nightleisure .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
#nightleisure .imgwrap{width: 45%; height: auto; line-height: 0;}
#nightleisure .imgwrap img{width: 100%; height: 100%;overflow: hidden;object-fit: cover;}

.numcard{width: 100%; margin: 5rem auto;background: #f7f7f7; padding: 5rem 10.4rem; box-sizing: border-box; text-align: left;}
.numcard .headarea{border-bottom: solid 2px #fff !important; margin-bottom: 3rem !important;}
.numcard .headarea p{font-size: 1.6rem;font-weight: normal; line-height: 3rem !important; letter-spacing: .5rem; color: #333; margin-bottom: 1rem; text-align: left; padding-left: .7rem;}
.numcard .odlist{display: flex;justify-content: space-between;flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.6rem; text-align: center;}
.numcard .odlist li{padding: 10px 10px 15px 10px;width:calc(33.33333% - 1.5rem);display: flex;box-sizing: border-box;border-top: solid 6px #312927; border-bottom: solid 3px #312927; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 1.5rem 0 1.5rem 0.5rem; background: #fff;position: relative; flex-direction: column;}
.numcard .odlist li:nth-child(1),.numcard .odlist li:nth-child(4){margin-left: 0;}
.numcard .odlist li img{width: 100%; margin-bottom: 1rem;}
.numcard .odlist h3{font-size: 1.6rem !important; font-weight: normal !important; position: relative; border-bottom: solid 1px #000; padding-left:0 !important;}
.numcard .odlist h3::before {content: attr(data-number);display: inline-block;margin-right: 1rem;color: #fff; font-weight: bold;font-size: 1.8rem;letter-spacing: normal; line-height: 5rem;background: #312927; width: 5rem; height: 5rem; text-align: center !important;}
.numcard .odlist .txcont{text-align: left; font-size: 1.6rem; padding: 0 1rem; line-height: 3rem;}


#food{padding: 10rem 0; font-size: 1.6rem;text-align: center;box-sizing: border-box; overflow: hidden;}
#food h2{position: relative; display: inline-block; padding: 0 120px;}
#food h2:before,#food h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#food h2:before {left: 0;}
#food h2:after {right: 0;}

#food .achieve{background: #f7f7f7; padding: 10.4rem; margin-top: 5rem;}
#food .headbox{font-size: 1.6rem;text-align: center;box-sizing: border-box;}
#food .flexblock{flex-wrap: nowrap; position: relative;justify-content: space-between;}
#food .inbox{letter-spacing: .3rem;text-align: left; width: 60%; line-height: 4rem; padding: 5rem 5rem; background: #fff; box-sizing: border-box;}
#food h3{font-size: 2.1rem;font-weight: bold; line-height: 4rem !important; letter-spacing: .5rem; margin-bottom: 1rem; text-align: left; padding-left: .5rem; color: #312927;}
#food h3 span {display: flex;align-items: center;	color: #52c2d0;font-size: 18px;	text-transform: uppercase;}
#food h3 span::before {content: '';	display: inline-block;margin-right: 20px;width: 40px;	height: 1px;background-color: #52c2d0;}
#food h4{font-size: 2.8rem;font-weight: bold; color: #312927; letter-spacing: .3rem; margin-bottom: 1rem;}
#food h4 span{background: linear-gradient(transparent 60%, #ffffa8 0%);}
#food .headarea{font-size: 1.6rem;font-weight: bold;border-bottom: solid 2px #eee; margin-bottom: 1.2rem; padding: 0 0 0 0;position: relative;}
#food .headarea:after {position: absolute;content: " ";display: block;border-bottom: solid 2px #666;bottom: -2px;width: 30%;}
#food .imgwrap{width: 45%; height: auto; line-height: 0;}
#food .imgwrap img{width: 100%; height: 100%;overflow: hidden;object-fit: cover;}
#food .inbox table tr:first-child th,#food .inbox  table tr:first-child td{padding: 2rem 0 2rem 3rem;}
#food .inbox table th{position: relative; text-align: left !important; width: 30%; background-color: #52c2d0; color: #fff;}
#food .inbox table th:after{display: block; content: ""; width: 0px; height: 0px; position: absolute; top:calc(50% - 10px); right:-10px;border-left: 10px solid #52c2d0; border-top: 10px solid transparent; border-bottom: 10px solid transparent;}
#food .inbox table td{text-align: left !important; width: 70%; background-color: #f7f7f7;}

#production h2{position: relative; display: inline-block; padding: 0 120px;}
#production h2:before,#production h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#production h2:before {left: 0;}
#production h2:after {right: 0;}

#production{padding: 1rem 0;overflow: hidden; margin-top: 10rem; text-align: center;}
#production .catchtx{margin-bottom: 25rem;}
#production .inner{position: relative;display: flex;display: -webkit-flex;-webkit-flex-wrap: wrap; flex-wrap: wrap;}
#production .inner::after {content: ''; width: 100%;}
#production .svlist {order: 1;}
#production .bgcol{width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; height: 300%; display: flex;position: absolute;top: -200px;z-index: -1; background: #eee;}
#production .slbox{width: 45%; height: 100%; position: relative;}
#production .slbox img{width: 100%;}
#production .prslider li{box-shadow: 15px 20px 20px rgba(0,0,0,0.3);}
#production .slick-list{overflow: inherit;}
#production .messagebox{ position: relative; padding: 0px 40px 80px 40px; box-sizing: border-box; width: 50%; margin-top: -5rem;}
#production .svlist{display: flex;justify-content: space-between;/*align-items: center;*/flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.8rem; text-align: center; padding: 0rem 5rem;}
#production .svlist li{padding: 10px 10px 15px 10px;width:calc(25% - 15px);display: flex;/*align-items: center;*/justify-content: center;flex-wrap: inherit;-webkit-flex-wrap: inherit;box-sizing: border-box; border-bottom: solid 6px /*#00c9a7*/#333; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 15px 5px 0 0; background: #fff;}
#production .svlist li img{width: 100%; margin-bottom: 1rem;}
#production .inbox{font-size: 1.6rem; padding: 0 0 0 1rem; box-sizing: border-box; text-align: left;}
#production .inbox h3{font-size: 1.6rem;display: flex; align-items: center;font-weight: bold;border-top: solid 3px #fff; margin-bottom: 1.2rem; padding-top: 1.5rem; text-shadow:1px 1px 0 #fff, -1px -1px 0 #fff,-1px 1px 0 #fff, 1px -1px 0 #fff,0px 1px 0 #fff, 0 -1px 0 #fff,-1px 0 0 #fff, 1px 0 0 #fff;position: relative;}
#production .inbox h3:after {position: absolute;content: " ";display: block;border-top: solid 3px #666;top: -3px;width: 30%;}
#production .inbox h3 span{font-size: 2rem; margin-right: .5rem;}
#production .inbox p{padding: 0 1rem; line-height: 2.8rem;}

#contact{padding: 15rem 15rem; font-size: 1.6rem;box-sizing: border-box; overflow: hidden; text-align: center;}
#contact h2{position: relative; display: inline-block; padding: 0 120px;}
#contact h2:before,#contact h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#contact h2:before {left: 0;}
#contact h2:after {right: 0;}

#social{padding: 10rem 15rem; font-size: 1.6rem;box-sizing: border-box; overflow: hidden; text-align: center;}
#social h2{position: relative; display: inline-block; padding: 0 120px;}
#social h2:before,#social h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 100px; height: 1px; background-color: #666;}
#social h2:before {left: 0;}
#social h2:after {right: 0;}

#policy{padding: 15rem 15rem; font-size: 1.6rem;}
#policy h3{margin-bottom: 3rem;}
#policy h3{font-size: 1.6rem;display: flex; align-items: center;font-weight: bold;border-bottom: solid 3px #eee; margin-bottom: 1.2rem; padding-bottom: 1rem;position: relative;}
#policy h3:after {position: absolute;content: " ";display: block;border-bottom: solid 3px #666;bottom: -3px;width: 30%;}
#policy ol{margin-bottom: 5rem;}
#policy ol.mgbt{margin-bottom: 1rem !important;}
#policy .contarea{padding: 4rem 2rem 4rem 0;}

table {width:100%;overflow:hidden;border:none;border-collapse:collapse;}
table th {width:240px;padding:4rem 0 4rem 1rem;border-bottom:solid 1px #E4E4E4;box-sizing:border-box;text-align:left;}
table td {padding:4rem 0 4rem 1rem;border-bottom:solid 1px #E4E4E4; line-height: 3.2rem; text-align: left;}
table td li{list-style: square !important;}
table td li{margin-left: 2rem;}
table th i{margin-right: .5rem; color: #ff0000;}
table tr:first-child th,table tr:first-child td{padding-top: 0;}

input[type=text],input[type=email],input[type=tel] {background-color: transparent;border: 1px solid #9ba2a6;border-radius: 3px;-moz-border-radius: 3px;-ms-border-radius: 3px;color: #37454d;width: 100%;padding: 10px 12px;text-align: left;box-sizing: border-box;}
input[type=submit] {width: 40rem;text-decoration: none;background-color: #c0c0c0;color: #fff; font-weight: bold; border: none; padding: 2rem 0; text-align: center; margin: 0 auto;cursor: pointer;font-size: 1.6rem;border-radius: .7rem;-moz-border-radius: .7rem;-ms-border-radius: .7rem;}
input[type=text].w40{width: 40%;}
select{-webkit-appearance: none;-moz-appearance: none;-ms-appearance: none;appearance: none;text-indent: 0.01px;text-overflow: '';background-color: transparent;}
select::-ms-expand {display: none;}
.form-select {display: block;position: relative;width: 40%;border: 1px solid #9ba2a6;-webkit-border-radius: 3px;-moz-border-radius: 3px;-ms-border-radius: 3px;border-radius: 3px;overflow: hidden;margin-right: 0px;float: left;}
@media (max-width: 640px) {
.form-select {width: 60%;}
input[type=submit] {width: 30rem;text-decoration: none;background-color: #c0c0c0;color: #fff; font-weight: bold; border: none; padding: 2rem 0; text-align: center; margin: 0 auto;cursor: pointer;font-size: 1.6rem;border-radius: .7rem;-moz-border-radius: .7rem;-ms-border-radius: .7rem;}
}
.form-select:after {position: absolute;display: block;content: '';width: 0;height: 0;border: 6px solid transparent;border-left: 6px solid transparent;border-bottom: 6px solid transparent;border-right: 6px solid transparent;border-top: 6px solid #333;top: 50%;right: 10px;margin-top: -3px;pointer-events: none;}
.form-select select {width: 100%;padding: 10px 10px;border: none;position: relative;box-sizing: border-box;}
.form-select select:not(:target) {width: 120% \9;}
input[type=radio],input[type=checkbox] {margin: 8px 5px;}
textarea {background-color: transparent;border: 1px solid #9ba2a6;border-radius: 3px;-moz-border-radius: 3px;-ms-border-radius: 3px;color: #37454d;width: 100%;padding: 10px 12px;text-align: left;box-sizing: border-box;height: 150px;}

.titlewrap{position: relative; padding: 50px 100px; box-sizing: border-box;width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; background: #eee;}
.titlewrap_t2{padding: 5rem 10rem 20rem 10rem ;box-sizing: border-box;width: calc(100vw - 10.4rem); margin: 0 0 0 10.4rem; background: #eee;height: auto;}
.mgbt10{margin-bottom: 1rem;}
.mgbt15{margin-bottom: 1.5rem;}
.mgbt20{margin-bottom: 2rem;}
.mgbt30{margin-bottom: 3rem;}
.mgbt40{margin-bottom: 4rem;}
.mgbt50{margin-bottom: 5rem;}
.flex-sub{display: -webkit-box;display: -moz-flex;display: -ms-flexbox;display: flex; margin-bottom: 5rem;}
.ttarea{width: 25%; border-top: solid 1px #000; padding-top: 4rem; box-sizing: border-box; text-align: left;}
.ttarea h2{margin-bottom: .5rem;}
.ttarea h2.lhon{letter-spacing: .5rem;}
.ttarea h2.lhon span{display: block; margin-top: 3rem;}
.ttarea h3{margin-bottom: .5rem; font-size: 2.4rem;}
.contarea{width: 75%; padding: 4rem 0rem; box-sizing: border-box;border-top: solid 1px #eee;}
.contarea iframe{width: 100%; height: 600px;}
.contarea.ifhigh iframe{width: 100%; height: 800px;}
.contarea2{width: 75%; padding: 4rem 0rem; box-sizing: border-box;border-top: solid 1px #eee; margin:0 auto;}
.discri{margin-left: .5rem;}
.texrow{line-height: 3.6rem; letter-spacing: .3rem; margin: 3rem auto 5rem auto;}
.texrow2{line-height: 3.6rem; letter-spacing: .5rem; margin: 0rem auto 5rem auto; text-align: left;}
.intext{line-height: 3.6rem; margin: 3rem auto 5rem auto; background: #eee; border-radius: 1rem; box-sizing: border-box; padding: 1.5rem 0;}
.intext a{color:#000; text-decoration: underline;}
.prebox{padding: 20rem 0; font-size: 1.8rem; background: #eee; box-sizing: border-box; margin-top: 5rem;}

@media screen and (max-width: 640px){
#businesslist .flexblock{text-align: center;border-top: 1px solid #dfdfdf;border-bottom: 1px solid #dfdfdf;-webkit-box-align: center;-ms-flex-align: center;-moz-align-items: center;align-items: center;justify-content: center; margin:0rem auto 0rem auto;}
#businesslist .flexblock li{font-size: 1.4rem; border-left: 1px solid #dfdfdf; border-bottom: 1px solid #dfdfdf;box-sizing: border-box;}
#businesslist .flexblock li:nth-child(1),#businesslist .flexblock li:nth-child(3),#businesslist .flexblock li:nth-child(5){border-left: none;}
#businesslist .flexblock li:nth-child(5),#businesslist .flexblock li:nth-child(6){border-bottom: none;}
#businesslist .flexblock li a span.jptitle{font-size: 1.4rem; display: block; line-height: 1;font-family: Noto Sans JP, sans-serif;font-weight: 400;}
#businesslist .flexblock .col-3{width: calc(100vw / 2) !important;}

#select .flexblock{text-align: center;border-top: none;border-bottom: 1px solid #dfdfdf;border-right: 1px solid #dfdfdf; box-sizing: border-box; margin-bottom: 1rem;}
#select .flexblock li{font-size: 1.8rem; border-left: 1px solid #dfdfdf; box-sizing: border-box;border-top: 5px solid #312927;}
#select .flexblock li:first-child{border-left: 1px solid #dfdfdf;}
#select .col-4{width: 50% !important;}

#select1{padding: 8rem 0rem 0 0; font-size: 1.6rem;text-align: center;box-sizing: border-box; overflow: hidden;}
#select1 .flexblock{flex-wrap: wrap; margin-top: 0rem;}
#select1 .inbox{width: 100%;padding: 1rem; position: relative; order: 1; bottom: 0;}
#select1 .imgwrap{width: 100%; height: auto; line-height: 0; order: 2;}

#select2{padding: 6rem 0rem 0 0;}
#select2 .flexblock{flex-wrap: wrap; margin-top: 0rem;}
#select2 .inbox{width: 100%; padding: 1rem;margin-top: 0rem;}
#select2 .imgwrap{width: 100%; order: 2;}

#select3{padding: 6rem 0rem 0 0;}
#select3 .flexblock{flex-wrap: wrap; margin-top: 0rem;}
#select3 .inbox{width: 100%; padding: 1rem;margin-top: 0rem;}
#select3 .imgwrap{width: 100%; order: 2;}

#select4{padding: 6rem 0rem 0 0;}
#select4 .flexblock{flex-wrap: wrap; margin-top: 0rem;}
#select4 .inbox{width: 100%; padding: 1rem;margin-top: 0rem;}
#select4 .imgwrap{width: 100%; order: 2;}

.flow{width: 100%; margin: 5rem auto 0 auto;background: #eee; padding: 1rem 1rem;}
.flow .odlist li{width:100%; margin: 1.5rem 0;}

#inpage{padding: 6rem 0rem;}
#inpage #hero h2{position: relative; display: inline-block; padding: 0 0;color: #ffffff;font-size: 2.8rem;}
#inpage .catchtx{line-height: 3rem; margin-bottom: 3rem; padding: 2rem; text-align: left;}
#inpage #hero {height: 40vh; margin-bottom: 0rem;}
#inpage .wrap{padding: 1rem 1rem; font-size: 1.6rem;}
#inpage .wrap .flexblock{flex-wrap: wrap; margin-bottom: 3rem;padding: 2rem;}
#inpage .wrap .imgwrap{width: 100%; line-height: 0; position: relative; margin:0 0rem 2rem 0;}
#inpage .wrap .imgwrap img{width: 100%; height: 100%; object-fit: cover; border-radius: 1rem;}
#inpage .wrap .texrow{text-align: left; padding: 2rem; background: #eee;}

#photography{padding: 5rem 1.5rem;overflow: hidden; margin-top: 5rem;}
#photography .bgcol{width: calc(100vw - 5.2rem); margin: 0 0 0 5.2rem; height: 300%; display: flex;position: absolute;top: -200px;z-index: -1; background: #eee;}
#photography .slbox{width: 100%; height: 100%; position: relative;}
#photography .prslider li{box-shadow: 5px 10px 5px rgba(0,0,0,0.3);}
#photography .messagebox{ position: relative; padding: 0px 0px 40px 0px; box-sizing: border-box; width: 100%; margin-top: 5rem;text-shadow:1px 1px 0 #fff, -1px -1px 0 #fff,-1px 1px 0 #fff, 1px -1px 0 #fff,0px 1px 0 #fff, 0 -1px 0 #fff,-1px 0 0 #fff, 1px 0 0 #fff;}
#photography .svlist li{font-size: 1.6rem;}
#photography .svlist{display: flex;justify-content: space-between;flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.8rem; text-align: center; padding: 0rem 0rem;}
#photography .svlist li{padding: 10px 10px 15px 10px;width:calc(50% - 1rem);display: flex;justify-content: center;flex-wrap: inherit;-webkit-flex-wrap: inherit;box-sizing: border-box; border-bottom: solid 6px #333; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 15px 5px 0 0; background: #fff;}
#photography .inbox{font-size: 1.6rem; padding: 0 0 0 7rem; box-sizing: border-box;}

#photoprice{padding: 5rem 1.5rem 0rem 1.5rem; font-size: 1.6rem; overflow: hidden;}
#photoprice .ttarea h2{padding-left: 1rem;}
#photoprice .contarea{display: block;}
#photoprice .wraparea{display: -webkit-box;display: -moz-flex;display: -ms-flexbox;display: flex;justify-content: space-between;justify-content:center;flex-wrap:wrap;-webkit-flex-wrap: wrap;width: 100%;padding: 4rem 0rem;box-sizing: border-box;border-top: solid 1px #000;}
#photoprice .prbox-c3 table th{width: 40% !important;padding:2rem 0 2rem 1rem !important;}
#photoprice .prbox-c1 table th{width: 40% !important;padding:2rem 0 2rem 1.5rem !important;}
#photoprice th{display: table-cell !important;}
#photoprice td{text-align: right !important; padding:2rem 1rem 2rem 0 !important;display: inline-block !important;border-bottom:solid 1px #E4E4E4 !important; margin-bottom: 0 !important;}
#photoprice td span{margin-left: 0rem; display: block;}
#photoprice .prbox-c3{width:100%; margin:0 0rem 2rem 0;}
#photoprice .prbox-c2{width:100%; margin:0 0rem 2rem 0;}
#photoprice .prbox-c1{width:100%; margin:0 0 5rem 0; padding: 1.5rem 1.5rem;}
#photoprice .prbox-tt{width:100%; margin:0 0 2rem 0;}

#photoprice .imgsample{width: 100%; height: 100%; position: relative; margin-top: 3rem; margin-bottom: 1rem;}
#photoprice .imgsample img{height: 240px; object-fit: cover;}
#photoprice .subslider li{box-shadow: 5px 10px 5px rgba(0,0,0,0.3);}
#photoprice .slick-list{overflow: inherit;}
#photoprice .flex-sub{margin-bottom: 5rem !important;}
.prbox-c3 h3{padding: 0 100px;}
.prbox-c3 h3:before,.prbox-c3 h3:after {width: 70px;}
.prbox-c2 h3{padding: 0 90px;}
.prbox-c2 h3:before,.prbox-c2 h3:after {width: 65px;}
.prbox-tt h2{padding: 0 75px; font-size: 2.1rem;}
.prbox-tt h2:before,.prbox-tt h2:after {width: 55px;}

.hdtype1{padding: 2rem 0;}
.tbinner{padding: 2rem 2rem;}
.prinner{padding: 1rem 1rem;}
.prinner .taleft{padding: 2rem 0rem 0 0rem;}

#company{padding: 5rem 1.5rem; font-size: 1.6rem; overflow: hidden;}
#contact{padding: 5rem 2rem; font-size: 1.6rem; overflow: hidden;}
#contact h2{text-align: center;position: relative; display: inline-block; padding: 0 10rem; margin-bottom: 5px;}
#contact h2:before,#contact h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 70px; height: 1px; background-color: #666;}

#social{padding: 5rem 2rem; font-size: 1.6rem; overflow: hidden;}
#social h2{text-align: center;position: relative; display: inline-block; padding: 0 5rem; margin-bottom: 5px; font-size: 2.8rem;}
#social h2:before,#social h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 50px; height: 1px; background-color: #666;}

#recruit{padding: 0rem 1.5rem; font-size: 1.6rem;}
#recruit th,#recruit td{padding:1rem 0 1rem 1rem;}
#recruit table tr:first-child th,#recruit table tr:first-child td{padding-top: 1rem;}
#recruit .flex-sub{padding-top: 8rem;}

#reclist .flexblock{text-align: center;border-top: 1px solid #dfdfdf;border-bottom: 1px solid #dfdfdf;-webkit-box-align: center;-ms-flex-align: center;-moz-align-items: center;align-items: center; margin:0rem auto 0rem auto;}
#reclist .flexblock li{font-size: 1.8rem; border-left: none; box-sizing: border-box;border-bottom: 1px solid #dfdfdf;}
#reclist .flexblock li:last-child{border-bottom: none;}

#marketing{padding: 1rem 1.5rem;overflow: hidden; margin-top: 5rem;}
#marketing h2{text-align: center;position: relative; display: inline-block; padding: 0 7rem; margin-bottom: 5px;}
#marketing h2:before,#marketing h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 55px; height: 1px; background-color: #666;}
#marketing .catchtx{margin-bottom: 10rem;}
#marketing .bgcol{width: calc(100vw - 5.2rem); margin: 0 0 0 5.2rem; height: 300%; display: flex;position: absolute;top: -50px;z-index: -1; background: #eee;}
#marketing .slbox{width: 100%; height: 100%; position: relative;}
#marketing .prslider li{box-shadow: 5px 10px 5px rgba(0,0,0,0.3);}
#marketing .messagebox{ position: relative; padding: 0px 0px 40px 0px; box-sizing: border-box; width: 100%; margin-top: 5rem;text-shadow:1px 1px 0 #fff, -1px -1px 0 #fff,-1px 1px 0 #fff, 1px -1px 0 #fff,0px 1px 0 #fff, 0 -1px 0 #fff,-1px 0 0 #fff, 1px 0 0 #fff;}
#marketing .svlist li{font-size: 1.6rem;}
#marketing .svlist{display: flex;justify-content: space-between;flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.8rem; text-align: center; padding: 0rem 0rem;}
#marketing .svlist li{padding: 10px 10px 15px 10px;width:calc(50% - 1rem);display: flex;justify-content: center;flex-wrap: inherit;-webkit-flex-wrap: inherit;box-sizing: border-box; border-bottom: solid 6px #333; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 15px 5px 0 0; background: #fff;}
#marketing .inbox{font-size: 1.6rem; padding: 0 0 0 7rem; box-sizing: border-box;}

#market01 .headbox p,#market02 .headbox p{padding-bottom: 1rem;}
#market01 .ovcont p,#market02 .ovcont p{line-height: 3rem;}
#market01 .wrap{position: relative; padding: 0rem; box-sizing: border-box;width: calc(100vw - 4rem);margin: 0 0 0 4rem;}
#market01 .ovcont{position: absolute; background: #fff; padding: 3rem; left: -4rem; bottom:-2rem;border-radius: 0 8px 0 0; width: 100%; z-index: 1;}
#market02 .wrap{position: relative; padding: 0rem; box-sizing: border-box;width: calc(100vw - 4rem); margin: 0 4rem 0 0;}
#market02 .ovcont{position: absolute; background: #fff; padding: 3rem; right: -4rem; bottom:-2rem;border-radius: 8px 0 0 0; width: 100%; z-index: 1;}

#realestate{padding: 5rem 1rem; font-size: 1.6rem;text-align: center; box-sizing: border-box;}
#realestate h2{text-align: center;position: relative; display: inline-block; padding: 0 7rem; margin-bottom: 5px;}
#realestate h2:before,#realestate h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 55px; height: 1px; background-color: #666;}

#nightleisure{padding: 5rem 1rem; font-size: 1.6rem;text-align: center;}
#nightleisure h2{text-align: center;position: relative; display: inline-block; padding: 0 7rem; margin-bottom: 5px;}
#nightleisure h2:before,#nightleisure h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 70px; height: 1px; background-color: #666;}

#nightleisure .headbox{padding: 3rem 0rem 0 0; font-size: 1.6rem;text-align: center;box-sizing: border-box; overflow: hidden;margin: 0rem auto 8rem auto;}
#nightleisure .flexblock{flex-wrap: wrap; margin-top: 0rem;}
#nightleisure .inbox{width: 100%;padding: 1rem; position: relative; order: 1; bottom: 0;}
#nightleisure .imgwrap{width: 100%; height: auto; line-height: 0; order: 2;}

.numcard{width: 100%; margin: 5rem auto;padding: 2rem 1rem;}
.numcard .odlist li{width:100%; margin: 1.5rem 0;}

#food{padding: 5rem 1rem; font-size: 1.6rem;text-align: center;}
#food h2{text-align: center;position: relative; display: inline-block; padding: 0 7rem; margin-bottom: 5px;}
#food h2:before,#food h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 55px; height: 1px; background-color: #666;}
#food .achieve{background: #f7f7f7; padding: 2rem; margin-top: 5rem;}
#food .headbox{font-size: 1.6rem;text-align: center;box-sizing: border-box;}
#food .flexblock{flex-wrap: wrap; margin-top: 0rem;}
#food .inbox{width: 100%;padding: 2rem; position: relative; order: 2;}
#food .imgwrap{width: 100%; height: auto; line-height: 0; order: 1;}
#food .inbox table tr:first-child th,#food .inbox  table tr:first-child td{padding: 1rem 0 1rem 2rem;}
#food .inbox table th{position: relative; text-align: left !important; width: 100%; background-color: #52c2d0; color: #fff;}
#food .inbox table th:after{display: block; content: ""; width: 0px; height: 0px; position: absolute; top:calc(50% - 10px); right:-10px;border:none;}
#food .inbox table td{text-align: left !important; width: 100%; background-color: #f7f7f7; border-bottom: solid 1px #ccc;}

#production h2{text-align: center;position: relative; display: inline-block; padding: 0 4rem; margin-bottom: 5px;}
#production h2:before,#production h2:after{ content: ''; position: absolute; top: 50%; display: inline-block; width: 55px; height: 1px; background-color: #666;}
#production{padding: 1rem 1.5rem;overflow: hidden; margin-top: 5rem;}
#production .catchtx{margin-bottom: 10rem;}
#production .bgcol{width: calc(100vw - 5.2rem); margin: 0 0 0 5.2rem; height: 300%; display: flex;position: absolute;top: -50px;z-index: -1; background: #eee;}
#production .slbox{width: 100%; height: 100%; position: relative;}
#production .prslider li{box-shadow: 5px 10px 5px rgba(0,0,0,0.3);}
#production .messagebox{ position: relative; padding: 0px 0px 40px 0px; box-sizing: border-box; width: 100%; margin-top: 5rem;text-shadow:1px 1px 0 #fff, -1px -1px 0 #fff,-1px 1px 0 #fff, 1px -1px 0 #fff,0px 1px 0 #fff, 0 -1px 0 #fff,-1px 0 0 #fff, 1px 0 0 #fff;}
#production .svlist li{font-size: 1.6rem;}
#production .svlist{display: flex;justify-content: space-between;flex-wrap: wrap;-webkit-flex-wrap: wrap; font-size: 1.8rem; text-align: center; padding: 0rem 0rem;}
#production .svlist li{padding: 10px 10px 15px 10px;width:calc(50% - 1rem);display: flex;justify-content: center;flex-wrap: inherit;-webkit-flex-wrap: inherit;box-sizing: border-box; border-bottom: solid 6px #333; box-shadow:0 3px 4px rgba(0,0,0,0.3); margin: 15px 5px 0 0; background: #fff;}
#production .inbox{font-size: 1.6rem; padding: 0 0 0 7rem; box-sizing: border-box;}

#map{padding: 5rem 2rem; font-size: 1.6rem; overflow: hidden;}

#policy{padding: 5rem 1.5rem; font-size: 1.6rem; overflow: hidden;}
#policy h3:after {width: 30%;}
#policy .contarea{padding: 4rem 0rem;}
#policy ol{margin-bottom: 5rem;}
#policy ol.mgbt{margin-bottom: 1rem !important;}

h2{color: #000; font-size: 3.2rem; line-height: 3.2rem;font-family: "Century Gothic W01", "Century Gothic", sans-serif;}
.col-2{width: 100%;}
.col-3{width: 100%;}
.col-4{width: 100%;}
.col-5{width: 100%;}
.col-6{width: 100%;}
header .logo{width: 8rem;height: 8rem;}
.main_text h2{font-size: 4rem; line-height: 4rem;}
.headmail {width: 8rem;height: 8rem;right: 8rem;}
.hamburger {width: 8rem;height: 8rem;padding: 3rem 2.5rem;}
nav.gnav {width: 80%;}
nav.gnav ul.mainbox {padding-top: 8rem;}
nav.gnav li .tgbtn:after{width: 8rem; height: 72px;line-height: 72px;}
nav.gnav ul li i{width: 8rem; text-align: center;}
nav.gnav ul li a {padding: 1em 3rem;}
nav.gnav li.subbox a{padding: 1em 4rem !important; font-size: 1.4rem; }
.area_s{width: 100%; height: auto; position: relative; background: #000; color: #fff;}
.area_s p{width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex;justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; position: absolute; top: 50%;left: 50%; -webkit-transform: translate(-50%, -50%) rotate(0deg);-ms-transform: translate(-50%, -50%) rotate(0deg);transform: translate(-50%, -50%) rotate(0deg); font-size: 1.6rem;}

#pickup{position: relative; overflow: hidden; padding: 3rem 1rem;}
#pickup .area_s{height: 40px;}
#pickup .wrap{width: 100%;position: relative; padding: 1rem; box-sizing: border-box; font-size: 1.6rem;}
#pickup .col-2:nth-child(2){padding-top: 2rem;}
#pickup .pdon{padding: 0px 0px 0 0;box-sizing: border-box;}

#business{position: relative; overflow: hidden; padding: 0px 0 0 0; margin-top: 5rem;}
#business .area_s{display: none;}
#business .wrap{position: relative; padding: 5rem 2rem; box-sizing: border-box;width: 100%; margin: 0 0 0 0; background: #eee;}
#business .wrap .imgarea{text-align: center; width: 100%; margin: 20px auto 0 auto;}

#section{ font-size: 1.6rem; padding: 5rem 1rem;}
#section h2{text-align: center;position: relative; display: inline-block; padding: 0 10rem; margin-bottom: 20px;}
#section h2:before,#section h2:after { content: ''; position: absolute; top: 50%; display: inline-block; width: 70px; height: 1px; background-color: #666;}
#section .flexblock{padding: 1rem 1rem;}
#section h3{width: 90%; font-size: 2rem;}
#section .pdon{padding: 1rem 1rem;box-sizing: border-box;}

/*
#newslist{position: relative; overflow: hidden;}
#newslist .area_s{display: none;}
#newslist .wrap{position: relative; padding: 5rem 2rem 20rem 2rem; box-sizing: border-box;width: 100%; margin: 0 0 0 0; background: #eee;}
#newslist .col-3{margin-top: 2rem; padding: 1rem; box-sizing: border-box;}
*/

#newslist{position: relative; overflow: hidden;}
#newslist .area_s{display: none;}
#newslist .wrap{position: relative; padding: 5rem 2rem 20rem 2rem; box-sizing: border-box;width: 100%; margin: 0 0 0 0; background: #eee;}
#newslist .col-3{margin-top: 2rem; padding: 1rem; box-sizing: border-box;}
#newslist .item{ background: #fff;box-shadow: 5px 5px 10px rgba(0,0,0,0.2); padding: 10px; font-size: 1.6rem; display: block;}
#newslist .imgarea{line-height: 0; overflow: hidden; position: relative; background: #000; min-width: 100%;}
#newslist .imgarea img{-webkit-transform: scale(1);-ms-transform: scale(1);transform: scale(1);-webkit-transition-duration: 2s;-o-transition-duration: 2s;transition-duration: 2s;max-width: 100%; line-height: 0;overflow: hidden;}
#newslist .item:hover .imgarea img{-webkit-transform: scale(1.1);-ms-transform: scale(1.1);transform: scale(1.1);}
#newslist .messagebox{ position: relative; padding: 10px 5px;}

#news{padding: 5rem 1.5rem 8rem 1.5rem;}
#news h2{padding: 0 100px;}
#news h2:before,#news h2:after {width: 80px;}
#news .wrap{width: 100%;-webkit-flex-wrap: wrap; flex-wrap: wrap;}
#news .imagebox{width: 100%; line-height: 0;}
#news .messagebox{padding: 1rem 0;}
#news h3{font-size: 1.6rem;}
#news .section{padding:0 1rem 1rem 1rem; line-height: 2.4rem;}

#access{position: relative; overflow:initial; margin-top: -10rem; padding-bottom: 10rem;}
#access .area_s{width: 100%; height: auto; position: relative; background: none; color: #000;}
#access .area_s p{top: -3rem;left: 50%; -webkit-transform: translate(-50%, -50%) rotate(0deg);-ms-transform: translate(-50%, -50%) rotate(0deg);transform: translate(-50%, -50%) rotate(0deg);}
#access .wrap{position: relative; width: 100%; margin: 0 0 0 0; padding: 1rem;}
#access .section{margin:0 auto;}
#access .section iframe{width: 100%; height: 400px;}

footer .inner{ padding: 10rem 2rem 10rem 2rem;}
footer .col-3{ padding: 4rem 0;}
footer .col-3:nth-child(3){padding-bottom: 0;}
footer .col-3:nth-child(1),footer .col-3:nth-child(2){ border-left:none;border-right: none; border-bottom: solid 1px #666;}
footer .item{padding:0; font-size: 1.6rem; box-sizing: border-box;}
footer .copyright h2{margin-right: 0; color: #000; font-size: 1.6rem; margin-bottom: 0; line-height: 1.6rem; width: 100%;}
footer .copyright{font-size: 1.4rem; height: auto; padding: 3.6rem 1rem 3rem 2rem;}
footer .copyright .address{margin-right: 10rem;}
footer .copyright .copy_text{margin-left: 0; margin-right: 10rem;}
#page-top a{width: 8rem; height: 8rem; padding-top: 1.2rem;}

.flex-sub{display: -webkit-box;display: -moz-flex;display: -ms-flexbox;display: flex; margin-bottom: 5rem;flex-direction: column;}
.ttarea{width: 100%; border-top: none; padding-top: 0rem; box-sizing: border-box; position: relative; margin-bottom: 2rem;}
.ttarea h2{margin-bottom: .5rem;}
.ttarea h2.lhon span{display: block; margin-top: 1rem;}
.ttarea h3{margin-bottom: .5rem; font-size: 2.4rem;}
.contarea{width: 100%; padding: 4rem 0rem; box-sizing: border-box;border-top: solid 1px #000; position: relative;}
.contarea iframe{width: 100%; height: 400px;}
.contarea2{width: 100%; padding: 4rem 0rem; box-sizing: border-box;border-top: solid 1px #000; position: relative;}
.texrow{line-height: 3.6rem; letter-spacing: .5rem; margin: 3rem auto 5rem auto; text-align: left;}
.texrow2{line-height: 3rem; letter-spacing: 1rem; margin: 0rem auto 5rem auto; text-align: left;}
.intext{line-height: 3rem; margin: 0rem auto 3rem auto; background: #eee; border-radius: 1rem; box-sizing: border-box; padding: 1.5rem 1.5rem; text-align: left;}
table {border-spacing:0px}
table th {font-weight:bold; width:100%;display:block;padding:10px;border-bottom:solid 1px #E4E4E4;}
table td {width:100%; display:block; padding:10px; margin-bottom:10px; border-bottom:solid 0px #E4E4E4;box-sizing: border-box;}
table tr:first-child th,table tr:first-child td{padding-top: 1rem;}
table td img{width:100%;max-width:194px;}
.row_table th,.row_table td{display: block;width: 100%; box-sizing: border-box;}
.padb5{padding-bottom: 5rem !important;}

}
