@font-face { font-family: 'icomoon'; src: url("../fonts/icomoon/icomoon.eot?srf3rx"); src: url("../fonts/icomoon/icomoon.eot?srf3rx#iefix") format("embedded-opentype"), url("../fonts/icomoon/icomoon.ttf?srf3rx") format("truetype"), url("../fonts/icomoon/icomoon.woff?srf3rx") format("woff"), url("../fonts/icomoon/icomoon.svg?srf3rx#icomoon") format("svg"); font-weight: normal; font-style: normal; }
body { font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif; line-height: 1.8; font-size: 16px; background: #fff; color: #000000; font-weight: 100; overflow-x: hidden; }
.btn.btn-primary, .btn.btn-default { width: 300px; }
.btn + .btn { margin-left: 10px; }
body.fh5co-offcanvas { overflow: hidden; }
a { color: #000; -webkit-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
a:hover { text-decoration: none !important; color: #000 !important; }
p, ul, ol { margin-bottom: 1.5em; font-size: 16px; color: #000; font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif; }
h1, h2, h3, h4, h5, h6 { color: #000; font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif; font-weight: 400; margin: 0 0 30px 0; }
figure { margin-bottom: 2em; }
.vegas-timer-running .vegas-timer-progress { background: #000; }
.fh5co-bnrs img { margin: 0.5em; }
.thum_menu { overflow: hidden; background: #fff; height: 80px; width: 80px; position: relative; -webkit-border-radius: 7px; -moz-border-radius: 7px; -ms-border-radius: 7px; border-radius: 7px; float: left; margin-right: 1em; }
.thum_menu .img { height: 100px; width: 100px; position: absolute; top: 0; left: 0; -webkit-transform: translate(50%, 0%); -ms-transform: translate(50%, 0%); transform: translate(50%, 0%); }
.thum_menu .img img { position: absolute; max-height: 100%; width: auto; top: 0; left: 0; -webkit-transform: translate(-50%, 0%); -ms-transform: translate(-50%, 0%); transform: translate(-50%, 0%); height: auto; }
.page_list { text-align: center; padding-bottom: 7em; background: rgba(0, 0, 0, 0.04); }
.page_list span { margin-right: 0.5em; }
.page_list a { margin-right: 0.5em; }
#loader-bg { display: none; position: fixed !important; width: 100%; height: 100%; top: 0px; left: 0px; background: #000000; z-index: 10000000 !important; }
#loader_rogo { display: none; position: fixed !important; top: 50% !important; left: 50% !important; width: 292px; height: 119px; margin-top: -43px; margin-left: -146px; text-align: center; color: #fff; z-index: 9999; }

::-webkit-selection {
 color: #fcfcfc;
 background: #000;
}

::-moz-selection {
 color: #fcfcfc;
 background: #000;
}
::selection { color: #fcfcfc; background: #000; }
#fh5co-header { position: relative; margin-bottom: 0; z-index: 9999999; padding-top: 90px; }
.fh5co-cover, .fh5co-hero { position: relative; height: 800px; }
#fh5co-logo a { width: 220px; height: 50px; background: url(../images/logo.svg) no-repeat center center; background-size: contain; display: block; }
#fh5co-services .col-md-3 { height: 300px; background-position: center center; background-size: cover; }
.prod-title .price { text-align: right; }

@media screen and (max-width: 768px) {
.fh5co-cover, .fh5co-hero { height: 450px; }
}
.fh5co-cover.fh5co-hero-2, .fh5co-hero.fh5co-hero-2 { height: 325px; }
.fh5co-cover.fh5co-hero-2 .fh5co-overlay, .fh5co-hero.fh5co-hero-2 .fh5co-overlay { position: absolute !important; width: 100%; top: 0; left: 0; bottom: 0; right: 0; z-index: 1; background: rgba(175,168,111,0); }
.fh5co-overlay { position: absolute !important; width: 100%; top: 0; left: 0; bottom: 0; right: 0; z-index: 1; background: rgba(0, 0, 0, 0.8); }
.fh5co-cover { background-size: cover !important; background-repeat: no-repeat; position: relative; }

@media screen and (max-width: 768px) {
.fh5co-cover { heifght: inherit; padding: 3em 0; }
.top .fh5co-cover, .top .fh5co-cover_2 { height: 450px !important; }
}
.fh5co-cover .btn { padding: 1em 5em; opacity: 1; text-shadow: none; }
.fh5co-cover, .fh5co-cover_2 { height: 325px; background-position: center center; background-size: cover;}
.top .fh5co-cover, .top .fh5co-cover_2 { height: 800px; }
.fh5co-cover.fh5co-cover_2 span { display: none; }

@media screen and (max-width: 768px) {
.fh5co-cover.fh5co-cover_2 { heifght: inherit; padding: 3em 0; }
}

@media screen and (max-width: 768px) {
.fh5co-cover .desc { padding-left: 15px; padding-right: 15px; }
}

@media screen and (max-width: 768px) {
.fh5co-cover .desc h2 { font-size: 20px; }
}
.fh5co-cover .desc span { padding-left: 0.5em; color: #fff; }
.fh5co-cover .desc .tx { display: block; margin-bottom: 30px; font-size: 20px; letter-spacing: 1px; color: #fff; font-weight: normal; margin-left: -2.2em; line-height: 1.7em; padding-top: 2em; }
.fh5co-cover .desc span a { color: #fff; }
.fh5co-cover .desc span a:hover, .fh5co-cover .desc span a:focus { color: #fff !important; }
.fh5co-cover .desc span a:hover.btn, .fh5co-cover .desc span a:focus.btn { border: 2px solid #fff !important; background: transparent !important; }
.fh5co-cover .desc span a.fh5co-site-name { padding-bottom: 2px; border-bottom: 1px solid rgba(255, 255, 255, 0.7); }
/* Superfish Override Menu */
.sf-menu { margin: 0 !important; }
.sf-menu { float: right; }
.sf-menu ul { box-shadow: none; border: transparent; min-width: 12em; *width: 12em;
}
.sf-menu a { color: rgba(0,0,0,0.7); padding: 0.75em !important; font-weight: normal; border-left: none; border-top: none; border-top: none; text-decoration: none; zoom: 1; font-size: 15px; border-bottom: none !important; }
.sf-menu a:hover, .sf-menu a:focus { color: rgba(0,0,0,.50) !important; }
.sf-menu li.active a:hover, .sf-menu li.active a:focus { color: #fff; }
.sf-menu li, .sf-menu ul li, .sf-menu ul ul li, .sf-menu li:hover, .sf-menu li.sfHover { background: transparent; }
.sf-menu ul li a, .sf-menu ul ul li a { text-transform: none; padding: 0.25em 1em !important; letter-spacing: 1px; }
.sf-menu li:hover a, .sf-menu li.sfHover a, .sf-menu ul li:hover a, .sf-menu ul li.sfHover a, .sf-menu li.active a { color: #e20a0a; }
.sf-menu ul li:hover, .sf-menu ul li.sfHover { background: transparent; }
.sf-menu ul li { background: transparent; }
.sf-arrows .sf-with-ul { padding-right: 2.5em; *padding-right: 1em;
}
.sf-arrows > li > .sf-with-ul:focus:after, .sf-arrows > li:hover > .sf-with-ul:after, .sf-arrows > .sfHover > .sf-with-ul:after { border-top-color: #ccc; }
.sf-arrows ul .sf-with-ul:after { margin-top: -5px; margin-right: -3px; border-color: transparent; border-left-color: #ccc; }
.sf-arrows ul li > .sf-with-ul:focus:after, .sf-arrows ul li:hover > .sf-with-ul:after, .sf-arrows ul .sfHover > .sf-with-ul:after { border-left-color: #ccc; }
#fh5co-header-section { padding: 0; position: fixed; top: 0; left: 0; width: 100%; z-index: 2; background: #fff !important; border-bottom: solid 1px #cccccc; }
.nav-header { position: relative; float: left; width: 100%; }
#fh5co-logo { position: relative; z-index: 2; font-size: 28px; text-transform: uppercase; margin-top: 20px; margin-bottom: 20px; font-weight: 300; float: left; }
#fh5co-logo span { font-weight: 700; }

@media screen and (max-width: 768px) {
#fh5co-logo { width: 100%; float: none; text-align: center; }
}
#fh5co-logo a { color: #fff; }
#fh5co-logo a:hover, #fh5co-logo a:focus { color: #fff !important; }
#fh5co-menu-wrap { position: relative; z-index: 2; display: block; float: right; margin-top: 25px; }
#fh5co-menu-wrap .sf-menu a { padding: 1em .75em; }
#fh5co-primary-menu > li > ul li.active > a { color: #000 !important; }
#fh5co-primary-menu > li > ul li { position: relative; }
#fh5co-primary-menu .fh5co-sub-menu { visibility: hidden !important; padding: 10px 7px 10px; background: #fff; left: 0; -webkit-border-radius: 5px; -moz-border-radius: 5px; -ms-border-radius: 5px; border-radius: 5px; -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15); -moz-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15); -ms-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15); -o-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15); box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15); width: 300px !important; }
#fh5co-primary-menu .fh5co-sub-menu > li > .fh5co-sub-menu { left: 100%; }
#fh5co-primary-menu .fh5co-sub-menu:before { position: absolute; top: -9px; left: 20px; width: 0; height: 0; content: ''; }
#fh5co-primary-menu .fh5co-sub-menu:after { position: absolute; top: -8px; left: 21px; width: 0; height: 0; border-right: 8px solid transparent; border-bottom: 8px solid #fff; border-bottom: 8px solid white; border-left: 8px solid transparent; content: ''; }
#fh5co-primary-menu .fh5co-sub-menu .fh5co-sub-menu:before { top: 6px; left: 100%; }
#fh5co-primary-menu .fh5co-sub-menu .fh5co-sub-menu:after { top: 7px; right: 100%; border: none !important; }
.site-header.has-image #primary-menu .sub-menu { border-color: #ebebeb; -webkit-box-shadow: 0 5px 15px 4px rgba(0, 0, 0, 0.09); -moz-box-shadow: 0 5px 15px 4px rgba(0, 0, 0, 0.09); -ms-box-shadow: 0 5px 15px 4px rgba(0, 0, 0, 0.09); -o-box-shadow: 0 5px 15px 4px rgba(0, 0, 0, 0.09); box-shadow: 0 5px 15px 4px rgba(0, 0, 0, 0.09); }
.site-header.has-image #primary-menu .sub-menu:before { display: none; }
#fh5co-primary-menu .fh5co-sub-menu a { letter-spacing: 0; padding: 0 15px; font-size: 18px; line-height: 34px; color: #575757 !important; text-transform: none; background: none; }
#fh5co-primary-menu .fh5co-sub-menu a:hover { color: #000 !important; }
#fh5co-work-section, #fh5co-services-section, #fh5co-content-section, #fh5co-work-section_2, #fh5co-blog-section { padding: 7em 0; }

@media screen and (max-width: 768px) {
#fh5co-work-section, #fh5co-services-section, #fh5co-content-section, #fh5co-work-section_2, #fh5co-blog-section { padding: 4em 0; }
h1, h2, h3, h4, h5, h6 { color: #000; font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif; font-weight: 400; margin: 0 0 30px 0; }
}
.fh5co-section-gray { background: rgba(0, 0, 0, 0.04); }
.heading-section { padding-bottom: 1em; margin-bottom: 5em; }
.heading-section:after { position: absolute; content: ''; bottom: 0; left: 50%; width: 100px; margin-left: -50px; height: 2px; background: #000; }
.heading-section h3 { font-size: 50px; letter-spacing: 2px; text-transform: none; position: relative; font-family: 'Product Sans', Arial, sans-serif; }
.heading-section h3 span { display: block; font-size: 20px; color: #000; }
.fh5co-grid { height: 302px; background-size: cover; background-position: center center; margin-bottom: 30px; position: relative; }

@media screen and (max-width: 480px) {
.fh5co-grid { height: 400px; }
}
.fh5co-grid .image-popup { position: absolute; top: 0; bottom: 0; left: 0; right: 0; opacity: 0; display: -webkit-flex; /* Safari用 */ display: flex; -webkit-justify-content: center; /* Safari用 */ justify-content: center; -webkit-align-items: center; /* Safari用 */ align-items: center; }
.fh5co-grid .image-popup .prod-title { padding: 40px; }
.fh5co-grid .image-popup .prod-title a { }
.fh5co-grid .image-popup .prod-title h3 { margin-bottom: 10px; color: #fff; font-size: 25px; line-height: 1.5em; text-align: center; text-shadow: 0px 2px 9px #000; }
.fh5co-grid .image-popup .prod-title span { color: #fff; text-align: center; display: inline; width: 100%; }
.fh5co-grid .image-popup .prod-title .btn-primary { margin-top: 1.5em; }
.fh5co-grid:hover { -webkit-transform: scale(1.05); -moz-transform: scale(1.05); -o-transform: scale(1.05); transform: scale(1.05); }
.fh5co-grid:hover .image-popup { opacity: 1; }
.services { }
.services ul { height: 150px; }
.services span { margin-bottom: 30px; display: block; width: 100%; }
.services span i { font-size: 50px; color: #000; }
.services h3 { font-size: 20px; font-weight: 400; line-height: 1.3em; padding-bottom: 2em; height: 2em; }
#fh5co-services, #fh5co-about, #fh5co-contact, #fh5co-form, #fh5co-recruit { padding: 7em 0; }

@media screen and (max-width: 768px) {
#fh5co-services, #fh5co-about, #fh5co-contact { padding: 4em 0; }
}
#fh5co-services .fh5co-number { font-size: 30px; color: #000; position: relative; padding-top: 10px; font-style: italic; display: -moz-inline-stack; display: inline-block; zoom: 1; *display: inline;
}
#fh5co-services .fh5co-number:before { position: absolute; content: ""; width: 100%; height: 3px; top: 0; left: 0; background: #000; }
#fh5co-services .fh5co-icon { margin-bottom: 30px; margin-top: 50px; position: relative; display: -moz-inline-stack; display: inline-block; zoom: 1; *display: inline;
}

@media screen and (max-width: 768px) {
#fh5co-services .fh5co-icon { margin-top: 0px; float: none; }
}
#fh5co-services .fh5co-icon i { font-size: 200px; color: #000; }

@media screen and (max-width: 768px) {
#fh5co-services .fh5co-icon i { font-size: 100px; }
}
#fh5co-contact .contact-info { margin: 0; padding: 0; }
#fh5co-contact .contact-info li { list-style: none; margin: 0 0 20px 0; position: relative; padding-left: 40px; }
#fh5co-contact .contact-info li i { position: absolute; top: .3em; left: 0; font-size: 22px; color: rgba(0, 0, 0, 0.3); }
#fh5co-contact .contact-info li a { font-weight: 400 !important; color: rgba(0, 0, 0, 0.3); }
#fh5co-contact .form-control { -webkit-box-shadow: none; -moz-box-shadow: none; -ms-box-shadow: none; -o-box-shadow: none; box-shadow: none; border: none; border: 1px solid rgba(0, 0, 0, 0.1); font-size: 18px; font-weight: 400; -webkit-border-radius: 0px; -moz-border-radius: 0px; -ms-border-radius: 0px; border-radius: 0px; }
#fh5co-contact .form-control:focus, #fh5co-contact .form-control:active { border-bottom: 1px solid rgba(0, 0, 0, 0.5); }
#fh5co-contact input[type="text"] { height: 50px; }
#fh5co-contact .form-group { margin-bottom: 30px; }
.fh5co-testimonial { position: relative; background: #fff; padding: 4em 0; border-radius: 5px; -webkit-box-shadow: 0px 18px 88px -22px rgba(0, 0, 0, 0.58); -moz-box-shadow: 0px 18px 88px -22px rgba(0, 0, 0, 0.58); box-shadow: 0px 18px 88px -22px rgba(0, 0, 0, 0.58); }

@media screen and (max-width: 768px) {
.fh5co-testimonial { border-right: 0; margin-bottom: 80px; }
}
.fh5co-testimonial h2 { font-size: 16px; letter-spacing: 2px; text-transform: uppercase; font-weight: bold; margin-bottom: 50px; }
.fh5co-testimonial figure { position: absolute; top: -50px; left: 50%; margin-left: -44px; margin-bottom: 20px; background-size: cover; }
.fh5co-testimonial figure img { width: 88px; height: 88px; border: 10px solid #fff; background-size: cover; -webkit-border-radius: 50%; -moz-border-radius: 50%; -ms-border-radius: 50%; border-radius: 50%; }
.fh5co-testimonial blockquote { border: none; margin-bottom: 20px; }
.fh5co-testimonial blockquote p { font-style: italic; font-size: 26px; line-height: 1.6em; color: #555555; }
.fh5co-testimonial span { font-style: italic; }
.fh5co-blog { margin-bottom: 60px; }
.fh5co-blog a img { margin-bottom: 30px; width: 100%; height: auto; }

@media screen and (max-width: 768px) {
.fh5co-blog { width: 100%; }
}
.fh5co-blog .image-popup { opacity: 1; }
.fh5co-blog .image-popup span { display: inline-block; margin-bottom: 20px; }
.fh5co-blog .image-popup span.posted_by { font-style: italic; color: rgba(0, 0, 0, 0.3); font-size: 18px; }
.fh5co-blog .image-popup span.comment { float: right; }
.fh5co-blog .image-popup span.comment a { color: rgba(0, 0, 0, 0.3); }
.fh5co-blog .image-popup span.comment a i { color: #000; padding-left: 7px; }
.fh5co-blog .image-popup h3 { font-size: 26px; margin-bottom: 20px; }
.fh5co-blog .image-popup h3 a { color: rgba(0, 0, 0, 0.6); }
#fh5co-start-project-section { padding: 7em 0; background: #F64E8B; }
#fh5co-start-project-section h2 { color: white; font-size: 60px; text-transform: uppercase; font-weight: 300; }

@media screen and (max-width: 768px) {
#fh5co-start-project-section h2 { font-size: 30px; }
}
#fh5co-start-project-section a:hover, #fh5co-start-project-section a:focus, #fh5co-start-project-section a:active { color: white !important; }
#map { width: 100%; height: 500px; position: relative; }

@media screen and (max-width: 768px) {
#map { height: 200px; }
.desc.animate-box .image { width: 90% !important; margin-top: -3em !important; }
}
.desc.animate-box .image { background: url(../images/main_image.png) no-repeat center center; width: 70%; height: 100px; background-size: contain; margin: 0 auto; }
.fh5co-social-icons > a { padding: 4px 10px; color: #000; }
.fh5co-social-icons > a i { font-size: 26px; }
.fh5co-social-icons > a:hover, .fh5co-social-icons > a:focus, .fh5co-social-icons > a:active { text-decoration: none; color: #5a5a5a; }
#footer { background: #fff; padding: 1em 0; clear: both; }
#footer p { text-align: left !important; color: #000; letter-spacing: 1px; font-size: 15px; text-transform: uppercase; }
#footer p a { color: #000; }
.btn { -webkit-transition: 0.3s; -o-transition: 0.3s; transition: 0.3s; }
.btn { text-transform: uppercase; letter-spacing: 2px; -webkit-transition: 0.3s; -o-transition: 0.3s; transition: 0.3s; }
.btn.btn-primary { background: #e20a0a; color: #fff; border: none; border-bottom: solid 3px #990000 !important; }
.btn.btn-primary:hover { box-shadow: none; background: #000; color: #fff !important;  }
.btn.btn-primary:active, .btn.btn-primary:focus { box-shadow: none; background: #000; color: #fff !important; }
.btn:hover, .btn:active, .btn:focus { background: #393e46 !important; color: #fff; outline: none !important; }
.btn.btn-default:hover, .btn.btn-default:focus, .btn.btn-default:active { border-color: transparent; }
.btn.btn-border { color: #000; border: 1px solid #000 !important; width: 300px; }
.js .animate-box { opacity: 0; }
#fh5co-wrapper { position: relative; overflow-x: hidden;}
.fh5co-offcanvas { overflow: hidden; }
.fh5co-offcanvas #fh5co-wrapper { overflow: hidden !important; }
#fh5co-page { position: relative; -webkit-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
.fh5co-offcanvas #fh5co-page { -moz-transform: translateX(-240px); -webkit-transform: translateX(-240px); -ms-transform: translateX(-240px); -o-transform: translateX(-240px); transform: translateX(-240px); }

@media screen and (max-width: 768px) {
#fh5co-menu-wrap { display: none; }
.logo-jp{ margin: 0 auto 10px !important; float: none !important;}
#footer .logo a{ margin: 0 auto !important; float: none !important; }
}
#offcanvas-menu { position: absolute; top: 0; bottom: 0; z-index: 99; background: #222; right: -240px; width: 240px; padding: 20px; overflow-y: scroll !important; }
#offcanvas-menu ul { padding: 0; margin: 0; }
#offcanvas-menu ul li { padding: 0; margin: 0 0 10px 0; list-style: none; }
#offcanvas-menu ul li a { font-size: 15px; color: #fff; }
#offcanvas-menu ul li a:hover { color: #000; }
#offcanvas-menu ul li > .fh5co-sub-menu { margin-top: 9px; padding-left: 20px; }
#offcanvas-menu ul li.active > a { color: #fff; }
#offcanvas-menu ul .fh5co-sub-menu { display: block !important; }
.fh5co-nav-toggle { cursor: pointer; text-decoration: none; }
.fh5co-nav-toggle.active i::before, .fh5co-nav-toggle.active i::after { background: #fff; }
.fh5co-nav-toggle.dark.active i::before, .fh5co-nav-toggle.dark.active i::after { background: #fff; }
.fh5co-nav-toggle:hover, .fh5co-nav-toggle:focus, .fh5co-nav-toggle:active { outline: none; border-bottom: none !important; }
.fh5co-nav-toggle i { position: relative; display: -moz-inline-stack; display: inline-block; zoom: 1; *display: inline;
width: 30px; height: 2px; color: #000; font: bold 14px/.4 Helvetica; text-transform: uppercase; text-indent: -55px; background: #000; transition: all .2s ease-out; }
.fh5co-nav-toggle i::before, .fh5co-nav-toggle i::after { content: ''; width: 30px; height: 2px; background: #000; position: absolute; left: 0; -webkit-transition: 0.2s; -o-transition: 0.2s; transition: 0.2s; }
.fh5co-nav-toggle.dark i { position: relative; color: #000; background: #000; transition: all .2s ease-out; }
.fh5co-nav-toggle.dark i::before, .fh5co-nav-toggle.dark i::after { background: #000; -webkit-transition: 0.2s; -o-transition: 0.2s; transition: 0.2s; }
.fh5co-nav-toggle i::before { top: -7px; }
.fh5co-nav-toggle i::after { bottom: -7px; }
.fh5co-nav-toggle:hover i::before { top: -10px; }
.fh5co-nav-toggle:hover i::after { bottom: -10px; }
.fh5co-nav-toggle.active i { background: transparent; }
.fh5co-nav-toggle.active i::before { top: 0; -webkit-transform: rotateZ(45deg); -moz-transform: rotateZ(45deg); -ms-transform: rotateZ(45deg); -o-transform: rotateZ(45deg); transform: rotateZ(45deg); }
.fh5co-nav-toggle.active i::after { bottom: 0; -webkit-transform: rotateZ(-45deg); -moz-transform: rotateZ(-45deg); -ms-transform: rotateZ(-45deg); -o-transform: rotateZ(-45deg); transform: rotateZ(-45deg); }
.fh5co-nav-toggle { position: absolute; top: 0px; right: 0px; z-index: 9999; display: block; margin: 0 auto; display: none; cursor: pointer; }

@media screen and (max-width: 768px) {
.fh5co-nav-toggle { display: block; top: 0px; margin-top: 1.6em; }
}

@media screen and (max-width: 480px) {
.col-xxs-12 { float: none; width: 100%; }
}
.row-bottom-padded-lg { padding-bottom: 7em; }

@media screen and (max-width: 768px) {
.row-bottom-padded-lg { padding-bottom: 2em; }
}
.row-top-padded-lg { padding-top: 7em; }

@media screen and (max-width: 768px) {
.row-top-padded-lg { padding-top: 2em; }
}
.row-bottom-padded-md { padding-bottom: 4em; }

@media screen and (max-width: 768px) {
.row-bottom-padded-md { padding-bottom: 2em; }
}
.row-top-padded-md { padding-top: 4em; }

@media screen and (max-width: 768px) {
.row-top-padded-md { padding-top: 2em; }
}
.row-bottom-padded-sm { padding-bottom: 2em; }

@media screen and (max-width: 768px) {
.row-bottom-padded-sm { padding-bottom: 2em; }
}
.row-top-padded-sm { padding-top: 2em; }

@media screen and (max-width: 768px) {
.row-top-padded-sm { padding-top: 2em; }
.fh5co-cover_2 .desc { top: 50% !important; }
}
.border-bottom { border-bottom: 1px solid rgba(0, 0, 0, 0.06); }
.lead { line-height: 1.8; }
.no-js #loader { display: none; }
.js #loader { display: block; position: absolute; left: 100px; top: 0; }
.fh5co-loader { position: fixed; left: 0px; top: 0px; width: 100%; height: 100%; z-index: 9999; background: url(../images/hourglass.svg) center no-repeat #222222; }
.vegas-slide, .vegas-transition-fade, .vegas-transition-fade-in, .vegas-transition-fade-out { -webkit-backface-visibility: hidden; backface-visibility: hidden; overflow: hidden }
#offcanvas-menu ul li a:hover { color: rgba(255, 255, 255, 0.4) !important; }
.entry { max-width: 750px; margin: 0 auto; }
.entry img { width: 100%; height: auto; margin-bottom: 3em; }
.container.entry .prod-title h3 { font-size: 15px; }
.container.entry.nav { border-top: solid 1px rgba(132, 132, 132, 0.5); padding-top: 3em; }
.container.entry.nav .col-lg-4.right { float: right; }
.container.entry.nav .col-lg-4.right .thum_menu { float: right; }
.container.entry.nav .col-lg-4.left { float: left; }
.fh5co-cover .desc { top: 63%; position: absolute; width: 100%; margin-top: -60px; z-index: 2; }
.fh5co-hero.fh5co-hero-2 .fh5co-cover .desc { }
.fh5co-cover .desc h2 { color: #fff; text-transform: uppercase; font-size: 40px; margin-bottom: 10px; line-height: 1.1em; letter-spacing: 3px; font-family: 'Product Sans', Arial, sans-serif; }
#fh5co-service-section { padding-bottom: 7em; }
/*# sourceMappingURL=style.css.map */

.inr { padding: 4em 1em; }
.area_service .col-md-12 { background-position: center center; background-repeat: no-repeat; background-size: cover; }
.icon_circle { border: solid 6px #e3e3e3; border-radius: 50%;        /* CSS3草案 */ -webkit-border-radius: 50%;    /* Safari,Google Chrome用 */ -moz-border-radius: 50%; margin: 1em auto; height: 200px; width: 200px; }
.icon-how1 { background: url(../images/icon_2_1.png) no-repeat center center; background-size: 60px; }
.icon-how2 { background: url(../images/icon_2_2.png) no-repeat center center; background-size: 60px; }
.icon-how3 { background: url(../images/icon_2_3.png) no-repeat center center; background-size: 60px; }
.icon-how4 { background: url(../images/icon_2_4.png) no-repeat center center; background-size: 60px; }
.icon-func1 { background: url(../images/icon_3_1.png) no-repeat center center; background-size: 60px; }
.icon-func2 { background: url(../images/icon_3_2.png) no-repeat center center; background-size: 60px; }
.icon-func3 { background: url(../images/icon_3_3.png) no-repeat center center; background-size: 60px; }
.col-md-8.col-md-offset-2 h2 { text-align: center; }
.circle_list p { text-align: left; font-size: 18px; }
.circle_list h3 { color: #000; line-height: 1.5em; margin-bottom: 10px !important; min-height: 2em; height: 2em; }
.area_device .image { height: 300px; background-repeat: no-repeat !important; background-position: center center !important; background-size: cover; }
.area_flow .icon_circle { background-repeat: no-repeat !important; background-position: center center !important; }
.area_image .box { height: 300px; background-repeat: no-repeat !important; background-position: center center !important; background-size: cover !important; }
.bg_gray { background: #f9f9f9; padding: 7em 0; }
.bg_white { background: #fff; padding: 7em 0; }
.bg_gold { background: #000; padding: 7em 0; }
.bg_gold h2, .bg_gold p { color: #fff !important; }
.bg_gold p { padding-bottom: 3em; }
.services ul { padding: 1em 0 0 0; margin: 0; }
.services ul li { padding: 0; margin: 0; list-style-type: none; color:;
text-align: left; }
.center-block { display: block !important; margin: 0 auto; float: none; }
.hei_200 { height: 400px; }
.area_interview h4 { font-size: 30px; line-height: 1.3em; }
#fh5co-about { }
#fh5co-about dl { }
#fh5co-about dt, #fh5co-recruit dt, #fh5co-form dt { clear: both; float: left; padding: 1.5em; border-top: solid 1px #000; color: #000; width: 20%; text-align: left; }
#fh5co-about dd, #fh5co-recruit dd, #fh5co-form dd { float: left; padding: 1.5em; border-top: solid 1px #ededed; width: 80%; text-align: left; }
.border_none { border: none !important; }
.area_access { }
.area_access p { clear: both; display: block; text-align: left; }
.area_access p span { color: #6b6b6b; font-size: 12px; margin-right: 1em; padding: 0.5em; display: inline-block; border: solid 1px #6b6b6b; border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; }
#fh5co-form { }
#fh5co-form dl { }
#fh5co-form dt { clear: both; float: left; padding: 1.5em; color: #000; width: 20%; text-align: left; }
#fh5co-form dd { float: left; padding: 1.5em; width: 80%; text-align: left; }
#fh5co-form { }
#fh5co-form.conf .form-group { color: #000; }
.form-group { clear: both; }
label { cursor: pointer; display: block; padding-bottom: 1em; }
input[type="radio"] { margin-right: 0.5em; }
.area_bt { text-align: center; }
h4 span { display: block; font-size: 20px; }
.fh5co-cover .desc.top { top: 40% !important; font-size: 5vw; color: #fff; line-height: 1em; text-shadow: 0px 2px 9px #666; font-family: 'Product Sans', Arial, sans-serif; }
.side_post h3 { font-size: 20px !important; }
.side_post img { margin-bottom: 10px !important; }
.side_post .fh5co-blog { margin-bottom: 30px !important; }
.nav_left { float: left; }
.nav_left h3 { font-size: 15px !important; }
.nav_left h3 + h3 { margin-top: 0.5em; }
.nav_right h3 { font-size: 15px !important; }
.nav_right h3 + h3 { margin-top: 0.5em; }
.nav_right { float: right; }
.nav_right .thum_menu { float: right; }
h3.price { font-size: 50px; border-bottom: solid 1px; padding-bottom: 20px; }
h3.price span { font-size: 20px; }
.icon_circle { border: solid 6px #e3e3e3; border-radius: 50%;        /* CSS3草案 */ -webkit-border-radius: 50%;    /* Safari,Google Chrome用 */ -moz-border-radius: 50%; margin: 1em auto; height: 200px; width: 200px; }
.icon-how1 { background: url(common/images/icon_2_1.png) no-repeat center center; background-size: 60px; }
.icon-how2 { background: url(common/images/icon_2_2.png) no-repeat center center; background-size: 60px; }
.icon-how3 { background: url(common/images/icon_2_3.png) no-repeat center center; background-size: 60px; }
.icon-how4 { background: url(common/images/icon_2_4.png) no-repeat center center; background-size: 60px; }
.icon-func1 { background: url(common/images/icon_3_1.png) no-repeat center center; background-size: 60px; }
.icon-func2 { background: url(common/images/icon_3_2.png) no-repeat center center; background-size: 60px; }
.icon-func3 { background: url(common/images/icon_3_3.png) no-repeat center center; background-size: 60px; }
.col-md-8.col-md-offset-2 h2 { text-align: center; }
.circle_list p { text-align: left; font-size: 18px; }
.circle_list h3 { color: #000; line-height: 1.5em; margin-bottom: 10px !important; min-height: 2em; height: 2em; }
.btn-group-tab { }
.btn-group-tab { margin: 0; padding: 0; }
.btn-group-tab li { cursor: pointer; text-align: center; margin: 0; padding: 0; display: block; float: left; width: 33%; list-style-type: none; color: #000; padding: 1em; }
.btn-group-tab li.active { background: #e20a0a; color: #fff; }
.fh5co-cover_2 h2 { text-align: center; color: #fff !important; font-size: 40px !important; }
.fh5co-cover_2 span { text-align: center; }
.fh5co-cover_2 .desc { }
.box_thx { background: #ededed; padding: 2em; }
.box_thx span { display: block; font-size: 25px; }
.recruit_table td { padding: 0.5em 0; }
.recruit_table td a { color: #000 !important; }
.recruit_table td a:hover { filter: alpha(opacity=50); -moz-opacity: 0.5; opacity: 0.5; }
.cc_cont { }

@media screen and (max-width: 768px) {
#fh5co-wrapper{     overflow-x: hidden;}
.fh5co-sub-menu { display: block; }
#fh5co-about dd, #fh5co-recruit dd { width: 100%; }
.cc_cont { height: 1100px; }
.cc_fooody { height: 900px; }
.fh5co-cover .desc .tx br { display: none; }
.area_service p { width: 100%; }
#fh5co-recruit h3 { font-size: 7vw; line-height: 1.7em; }
#fh5co-about dt, #fh5co-recruit dt, #fh5co-form dt { float: none; width: 100%; padding-bottom: 0.5em; }
#fh5co-about dd, #fh5co-recruit dt, #fh5co-form dd { float: none; width: 100%; border: none; padding-top: 0; }
#fh5co-about dl { padding: 0em; }
#fh5co-recruit dl { padding: 0em; }
.area_foot_form h5 { margin-bottom: 0.5em; }
.area_foot_form p { margin-bottom: 0; }
.area_foot_form .col-md-12 { padding: 3em 0; }
.fh5co-cover .desc h2 img { width: 100%; height: auto; }
.btn + .btn { margin: 1em 0 0 -4px; }
.row { margin-left: -5px; margin-right: -5px; }
.area_bt { margin-bottom: 1em; }
.title_inv { font-size: 8vw !important; }
.area_foot_form .col-md-12 { background-attachment: scroll !important; }
.fh5co-cover .desc h2 { font-size: 6vw !important; letter-spacing: 0; }
.fh5co-cover .desc { top: 65% !important; }
.image_pc { display: none; }
.image_sp { display: block !important; width: 100%; height: auto; }
#fh5co-form dd { padding: 0; }
#fh5co-form dt { padding: 1em; }
#fh5co-about dt, #fh5co-recruit dt { padding-left: 0; padding-right: 0; }
#fh5co-about dd, #fh5co-recruit dd { padding-left: 0; padding-right: 0; }
.fh5co-cover .desc span { padding-left: 0; letter-spacing: 0 !important; }
}
#fh5co-form dl + .form-group { background: none !important; }
dl:after { content: "."; display: block; height: 0; font-size: 0; clear: both; visibility: hidden; }

@media screen and (max-width: 480px) {
.fh5co-cover .desc .tx { font-size: 4vw; margin: 1em 0 2em 0; }
.fh5co-cover .desc.top { font-size: 14vw !important; top: 24% !important; font-weight: bold; }
.fh5co-cover .desc .tx { font-weight: bold; }
.btn.btn-primary, .btn.btn-default { width: 100% !important; }
.area_foot_form .tel { font-size: 8vw !important; }
.area_foot_form .tel span { font-size: 4.5vw !important; }
.btn { font-weight: bold; }
.btn-group-tab { font-size: 3.5vw !important; }
}
.image_sp { display: none; }
.err { color: #FF0004; padding-top: 0.5em; }
.job { display: none; }
.job.active { display: block; }
.box_mail { background: #f3f3f3; text-align: center; padding: 1em; }
.flow_develop { text-align: left; position: relative; padding-bottom: 3em; }
.flow_develop .flow_box { border-bottom: dotted 2px #afafaf; padding: 2em 0 2em 1em; margin-right: 90px; }
.flow_develop .flow_box:after { content: "."; display: block; height: 0; font-size: 0; clear: both; visibility: hidden; }
.flow_develop .flow_box .row { float: left; margin: 0; padding-right: 1em; }
.flow_develop .flow_box .row h3 { font-size: 25px; margin-bottom: 10px; padding-top: 0.1em; }
.flow_develop .flow_box .row p { margin: 0; width: auto; }
.flow_develop .flow_box .image { float: right; width: 30%; height: 120px; background-size: cover; background-position: center center; display: none; }
.flow_develop .box_b { clear: both; position: relative; }
.flow_develop .flow_bar { text-align: center; background: url(../images/flow/arr_flow.png) no-repeat center bottom #f4f4f4; width: 80px; padding-bottom: 67px; position: absolute; top: 0; right: 0; bottom: 0; height: 100%; }
.flow_develop .flow_bar .num { font-size: 12px; position: absolute; bottom: 30px; width: 100%; }
.flow_develop .flow_bar .num span { font-size: 23px; display: block; line-height: 1em; }
.gmap { width: 100%; height: 400px; border: none; }
.tel a { color: #fff !important; }
.pagetop a { display: block; background-color: #000; text-align: center; color: #fff; font-size: 12px; text-decoration: none; width: 50px; height: 50px; line-height: 50px; filter: alpha(opacity=70); -moz-opacity: 0.7; opacity: 0.7; -webkit-border-radius: 7px; -moz-border-radius: 7px; -ms-border-radius: 7px; border-radius: 7px; }
.pagetop { position: fixed; bottom: 30px; right: 30px; z-index: 9999; }

@media screen and (max-width: 480px) {
br { display: none; }
p { text-align: justify !important; }
h1, h2, h3, h4, h5, h6 { font-weight: bold; }
.heading-section h3 { font-size: 25px; }
.heading-section h3 br { display: none; }
.cc_fooody { height: auto !important; }
.flow_develop .flow_box { padding-left: 0; margin-right: 70px; }
.flow_develop .flow_bar { width: 50px !important; }
.fh5co-cover.fh5co-cover_2 { background-position: center center !important; }
.fh5co-grid br { display: none; }
.fh5co-grid span { text-align: left !important; }
.area_servicedetail .col-md-4 { width: 50% !important; float: left; }
}
.services h3 { height: 2.5em; margin-bottom: 0 !important; }
.btn-square { position: absolute; bottom: 20px; right: 20px; width: 40px; height: 40px; line-height: 40px; text-align: center; background: #fff; filter: alpha(opacity=90); -moz-opacity: 0.9; opacity: 0.9; }
.btn-square .fa { margin-right: 0; }
.btn-primary .fa { margin-left: 0.5em; margin-right: -1em; }
.area_service .block_service { padding-bottom: 5em; }
.area_service .block_service .image { height: 268px; margin-bottom: 5px; }
.area_service .block_service .image a { display: block; position: relative; height: 100%; width: 100%; }
.area_service .block_service h3 { clear: both; color: rgba(0,0,0,1.00) !important; font-size: 2.2rem; font-weight: bold; text-align: center; border-bottom: 1px solid #d6d6d6; padding: 15px 0; margin: 0 0 15px 0; }
.area_service .block_service h3 a { color: rgba(0,0,0,1.00); }
.area_service .block_service p { font-size: 1.4rem; text-align: center; margin: 0 0 15px 0; }
.logo_parent { position: relative; }
.logo_area_service { width: 70%; position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); /* Safari用 */ transform: translate(-50%, -50%); }
.logo_area_service img { width: 100%; height: auto; }
.area_service a { display: block; }
.area_service .block_service .image:hover { filter: alpha(opacity=70) !important; -moz-opacity: 0.7 !important; opacity: 0.7 !important; }
.tx_main { background:#fff; padding: 5em 0 0 0; position: relative; color: #e2001e; font-size: 13px; }
.tx_main p { color: #fff !important; font-size: 20px !important; margin-bottom: 0; }
#footer p { margin: 0 !important; }
#footer .logo a { float: left; width: 220px; height: 50px; background: url(../images/logo.svg) no-repeat center center; background-size: contain; display: block; }
#footer .area_tx { float: right; text-align: right; margin-top: 12px; }
#footer .area_tx p { }
#footer .area_tx p a { margin-right: 1em; }

@media screen and (max-width: 480px) {
#footer .area_tx { float: left; margin-top: 0; margin-bottom: 10px; }
#footer .area_tx p a { margin-right: 0.5em; }
.fh5co-cover .desc .btn-primary { margin-top: 1em; }
.tx_main { padding: 1.3em 0; }
.tx_main p { text-align: left !important; color: #e2001e !important; font-size: 18px !important; margin-bottom: 0; }
.tx_main p br { display: none; }
}
.sf-menu .bt_sp_only { display: none !important; }

@media screen and (max-width: 768px) {
.sf-menu .bt_sp_only { display: block !important; }
}
.page_privacy h3 { padding-top: 1em; }

@media screen and (max-width: 768px) {
.page_privacy { padding-top: 5em !important; }
.page_privacy br { display: block !important; }
.page_privacy p { text-align: left !important; }
}
.area_foot_form .col-md-12 { background-size: cover !important; }
.left_text { text-align: left !important; }
.clear_fix:after { content: "."; display: block; height: 0; font-size: 0; clear: both; visibility: hidden; }
.area_bt.tab { display: flex; justify-content: space-between; }
.area_bt.tab .btn-primary, .area_bt.tab .btn-default { width: 30%; margin: 0; }
.box_merit { display: flex; border: solid 2px #e8e8e8; margin-bottom: 3em; }
.box_merit h3 { background: #4eac8e; color: #fff; line-height: 80px; height: 80px; margin: 0; padding: 0 20px; font-size: 16px; white-space: nowrap; }
.box_merit .arr { width: 0; height: 0; border: 40px solid transparent; border-left: 40px solid #4eac8e; }
.box_merit p { align-items: center; display: flex; margin: 0; }
table.table_develop { border: solid 1px #e8e8e8; margin-bottom: 2em; }
table.table_develop th { background: #f5f5f5; padding: 20px; font-size: 16px; font-size: 16px; }
table.table_develop td { padding: 20px; font-size: 16px; text-align: left; }
table.table_develop td span { color: #aea574; margin-right: .5em; }
.image_system { border: solid 1px #e8e8e8; padding: 30px; }
.image_case { padding: 0 4em; margin-bottom: 2em; }
.box_price { }
.box_price .title { display: flex; align-items: center; }
.box_price .title h3 { margin: 0; font-size: 25px; }
.box_price .title .price { margin: 0 0 0 auto; font-size: 30px; color: #4eac8e; }
.box_price .title .price span { font-size: 20px; }
.box_price .box_goods { }
.box_price .box_goods h4 { font-size: 12px; margin: 0; text-align: left; margin-bottom: 1em; color: #7b7b7b; }
.box_price .box_goods p { font-size: 15px; text-align: left; background: #f5f5f5; border: solid 1px #e8e8e8; padding: 1em; }
.box_price table.recipt { border: solid 2px #cdece2; }
.box_price table.recipt th { background: #cdece2; font-size: 13px; padding: 0 1em; }
.box_price table.recipt td { font-size: 15px; padding: 1em; text-align: left; border: none; }
.box_price table.recipt tr { border: none !important; }
.box_price table.recipt tr:nth-child(odd) { background: #ebf6f3; }
.box_price table.recipt tr.total { background: none !important }
.box_price table.recipt .num { text-align: right !important; }
.dev_area { padding-bottom: 4em; }
.dev_area h3 { color: #1babb5; font-size: 20px; }
.dev_area .icon { height: 200px; margin: 0 auto; }
.dev_area .icon img { height: 200px; width: auto; }
.dev_area p { padding-top: 2em; text-align: left; }
.dev_area ul { padding: 0; margin: 0; }
.dev_area ul li { color: #1babb5; list-style: none; }
.area_dev_case ul li { text-align: left; }
.area_dev_case .image { background: url(../images/bg_dev_case.png) no-repeat top center; height: 250px; }

@media screen and (max-width: 768px) {
.area_bt.tab a { margin: 0 .5em !important; }
.tx_main dl { display: block !important;  }
.tx_main dl dt { display: inline-block !important; margin-bottom: 1em; }
.tx_main dl + dl { margin-top: 1em !important; }
}
.desc.top p { color: #fff; line-height: 1.7em; margin-top: 1em; font-size: 1.7rem; letter-spacing: 2px; background: rgba(0,0,0,.5); font-weight: normal; padding: 1em; }
.tx_main a { color: #fff; font-size: 16px; letter-spacing: 1px; word-break: break-all; }
.tx_main a:hover { color: #fff !important; filter: alpha(opacity=50); -moz-opacity: 0.5; opacity: 0.5; }
.tx_main dl + dl { margin-top: .5em; }
.tx_main dl { display: flex; align-items: flex-start; margin: 0; border: solid 1px #e2001e; padding: 15px; border-radius: 3px; }
.tx_main dl dd { line-height: 1.5em; }
.tx_main dl dt { white-space: nowrap; font-size: 13px; letter-spacing: 1px; line-height: 1em; background:; padding: .5em .7em; margin-right: 2em; color: #fff; background: #e2001e; border-radius: 3px; -webkit-border-radius: 3px; -moz-border-radius: 3px; }

.logo-jp { background: url(../../common/images/logo-jp.svg) no-repeat center center; background-size: contain; width: 204px; height: 19px; float: right; margin-right: 1em; margin-bottom: .5em; }
#footer .area_tx p { clear: both; }
.area_foot_form .btn.btn-primary, .fh5co-hero.top .btn.btn-primary { background: #e20a0a; border-bottom: solid 3px #990000 !important; }
.area_foot_form .btn.btn-primary:hover, .fh5co-hero.top .btn.btn-primary:hover { background: #990000 !important; border-bottom: solid 3px #990000 !important; }
