@charset "UTF-8";
/*! HTML5 Boilerplate v7.0.1 | MIT License | https://html5boilerplate.com/ */
/* main.css 1.0.0 | MIT License | https://github.com/h5bp/main.css#readme */
/* What follows is the result of much research on cross-browser styling. Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal, Kroc Camen, and the H5BP dev community and team. */
/* ========================================================================== Base styles: opinionated defaults ========================================================================== */
@import url("https://fonts.googleapis.com/css?family=Major+Mono+Display&display=swap");
html { margin: 0 auto; padding: 0; color: #333; font-size: 62.5%; line-height: 1.4; }

html.no-scroll { position: fixed; z-index: -1; height: 100vh; height: 100%; overflow: hidden !important; }

body { margin: 0 auto; padding: 0; height: auto; font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }

body.no-scroll { position: fixed; z-index: -1; height: 100vh; height: 100%; overflow: hidden !important; }

@-webkit-keyframes fadeIn { from { opacity: 0;
    -webkit-transform: translateY(0px);
            transform: translateY(0px); }
  to { opacity: 1;
    -webkit-transform: translateY(30px);
            transform: translateY(30px); } }

@keyframes fadeIn { from { opacity: 0;
    -webkit-transform: translateY(0px);
            transform: translateY(0px); }
  to { opacity: 1;
    -webkit-transform: translateY(30px);
            transform: translateY(30px); } }

/* Remove text-shadow in selection highlight: https://twitter.com/miketaylr/status/12228805301 Vendor-prefixed and regular ::selection selectors cannot be combined: https://stackoverflow.com/a/16982510/7133471 Customize the background color to match your design. */
::-moz-selection { background: #b3d4fc; text-shadow: none; }
::selection { background: #b3d4fc; text-shadow: none; }

/* A better looking default horizontal rule */
hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

/* Remove the gap between audio, canvas, iframes, images, videos and the bottom of their containers: https://github.com/h5bp/html5-boilerplate/issues/440 */
audio, canvas, iframe, img, svg, video { vertical-align: middle; }

/* Remove default fieldset styles. */
fieldset { border: 0; margin: 0; padding: 0; }

/* Allow only vertical resizing of textareas. */
textarea { resize: vertical; }

/* ========================================================================== Browser Upgrade Prompt ========================================================================== */
.browserupgrade { margin: 0.2em 0; background: #ccc; color: #000; padding: 0.2em 0; }

/* ========================================================================== Author's custom styles ========================================================================== */
::-webkit-input-placeholder { color: #A9A9A9 !important; }
::-moz-placeholder { color: #A9A9A9 !important; }
:-ms-input-placeholder { color: #A9A9A9 !important; }
::placeholder { color: #A9A9A9 !important; }

@keyframes fadeIn { from { opacity: 0; }
  to { opacity: 1; } }

img[data-speed="flag"] { opacity: 0; }

img[data-loaded="true"] { -webkit-animation: fadeIn 1s both; animation: fadeIn 1s both; }

.is-hide { display: none !important; }

.is-active { display: block !important; }

picture { margin: 0; padding: 0; display: block; }

/* ----------------------------------------------- global layout ----------------------------------------------- */
#wrapper { margin: 0; padding: 0; }

body { margin: 100px auto 0 auto; }

@media screen and (max-width: 767px) { body { margin: 70px auto 0 auto; } }

body.page__inquiry { margin-top: 0px; }

@media screen and (max-width: 767px) { body.page__inquiry { margin-top: 0px; } }

a { transition: .5s; color: #111111; }

a:hover { text-decoration: none; color: #F57E26; }

a:active { color: #004B9E; }

.btn__primary { position: relative; width: 300px; height: 60px; background: #111; border-radius: 30px; border: none; box-sizing: border-box; margin: 0; padding: 0; text-decoration: none; text-align: center; color: #fff; font-size: 16px; font-size: 1.6rem; line-height: 1.2; transition: .5s; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; }

.btn__primary .fa-angle-right { position: absolute; top: 50%; right: 20px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.btn__primary .fa-angle-left { position: absolute; top: 50%; left: 20px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.btn__primary:hover { background-color: rgba(245, 126, 38, 0.7); color: #fff; }

.btn__primary:active { background-color: rgba(0, 75, 158, 0.7); color: #fff; }

.btn__primary .fas { margin-left: 10px; }

.btn__secondary { position: relative; width: 300px; height: 60px; background: transparent; border-radius: 30px; border: 2px solid #707070; box-sizing: border-box; margin: 0; padding: 0; text-decoration: none; text-align: center; color: #525252; font-size: 16px; font-size: 1.6rem; line-height: 1.2; transition: .5s; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; }

.btn__secondary .fa-angle-right { position: absolute; top: 50%; right: 20px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.btn__secondary .fa-angle-left { position: absolute; top: 50%; left: 20px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.btn__secondary:hover { background-color: rgba(245, 126, 38, 0.7); border: none; color: #fff; }

.btn__secondary:active { background-color: rgba(0, 75, 158, 0.7); border: none; color: #fff; }

.btn__secondary .fas { margin-left: 10px; }

.btn__header { position: relative; width: auto; height: 40px; background: #F57E26; margin: 0; padding: 0; text-decoration: none; text-align: center; color: #fff; font-size: 16px; font-size: 1.6rem; line-height: 1.2; transition: .5s; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; }

.btn__header .fa-angle-right { position: absolute; top: 50%; right: 10px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.btn__header:hover { background-color: rgba(0, 75, 158, 0.7); color: #fff; }

.btn__header:active { background-color: rgba(0, 43, 90, 0.7); color: #fff; }

.btn__header .fas { margin-left: 10px; }

#global-header { position: fixed; left: 0; top: 0; width: 100%; margin: 0 auto; padding: 0; height: 100px; min-height: 100px; max-height: 100px; background-color: #fff; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); z-index: 99999; box-sizing: border-box; }

@media screen and (max-width: 767px) { #global-header { height: 70px; min-height: 70px; max-height: 70px; box-sizing: border-box; } }

#global-header .container-fluid { margin: 0; padding: 0; }

@media screen and (max-width: 767px) { #global-header .container-fluid { border-top: 10px solid #111; } }

#global-header .hd__line { position: relative; width: 100%; height: 40px; margin: 0; padding: 0; background-color: #111111; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { #global-header .hd__line { height: auto; background-color: #fff; } }

#global-header .hd__line-col { margin: 0; padding: 0; }

#global-header .hd__line-col .btn__header { width: 200px; margin: 0 0 0 auto; }

@media screen and (max-width: 767px) { #global-header .hd__line-col .btn__header { display: none; } }

#global-header .hd__line-col:nth-child(1) { width: calc( 100% - 200px); }

#global-header .hd__logo { position: absolute; left: 0; top: 0; z-index: 2; width: 230px; height: 100px; margin: 0; padding: 0; box-sizing: border-box; background: #004b9e; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }

@media screen and (max-width: 767px) { #global-header .hd__logo { width: auto; height: 60px; background: none; box-shadow: none; border-radius: none; } }

#global-header .hd__logo a { width: 100%; height: 100px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; transition: .0s; }

@media screen and (max-width: 767px) { #global-header .hd__logo a { padding-left: 10px; height: 60px; } }

#global-header .hd__logo img { margin: 0 auto 0 auto; display: block; }

@media screen and (max-width: 767px) { #global-header .hd__logo img { width: auto; height: 44px; } }

#global-header .hd__tit { margin: 0; padding: 0; width: calc( 100% - 250px); overflow: hidden; white-space: nowrap; margin-left: 240px; font-size: 14px; font-size: 1.4rem; font-weight: normal; line-height: 1.2; text-overflow: ellipsis; text-align: right; color: #fff; display: block; }

@media screen and (max-width: 767px) { #global-header .hd__tit { display: none; } }

#global-header .hd__wrap { width: 100%; margin: 0; padding: 0; }

#global-header .hd__wrap-col { margin: 0 0 0 auto; padding: 0; }

#global-header .pcmenu { width: 100%; margin: 0; padding: 0; }

@media screen and (max-width: 767px) { #global-header .pcmenu { display: none; } }

#global-header .pcmenu__navi { min-width: 680px; margin: 0 0 0 240px; padding: 0; list-style: none; }

#global-header .pcmenu__navi-list { width: 100%; margin: 0; padding: 0 25px 0 25px; list-style: none; display: -webkit-inline-flex; display: inline-flex; -webkit-justify-content: flex-end; justify-content: flex-end; -webkit-align-items: center; align-items: center; box-sizing: border-box; }

#global-header .pcmenu__navi-link { position: relative; margin: 0; padding: 0 30px 0 30px; display: block; font-size: 16px; font-size: 1.6rem; line-height: 60px; color: #111111; text-align: center; text-decoration: none; }

#global-header .pcmenu__navi-link::after { position: absolute; left: 0; bottom: 0px; width: 100%; height: 0px; content: " "; background-color: #004B9E; transition: .1s; }

#global-header .pcmenu__navi-link:hover { color: #F57E26; }

#global-header .pcmenu__navi-link:hover::after { height: 5px; bottom: 0; }

#global-header .pcmenu__navi-link.active { color: #004B9E; }

#global-header .pcmenu__navi-link.active::after { height: 5px; bottom: 0; }

#global-header .spmenu { position: absolute; top: 10px; right: 0; margin: 0; padding: 0; display: none; }

@media screen and (max-width: 767px) { #global-header .spmenu { display: block; } }

#global-header .spmenu__navi { position: relative; width: 100%; margin: 0; padding: 0; }

#global-header .spmenu__navi-list { position: fixed; top: 70px; left: 0; width: 100vw; margin: 0; padding: 0; -webkit-animation: fadeIn .2s both; animation: fadeIn .2s both; list-style: none; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); z-index: 99999; background-color: #fff; }

#global-header .spmenu__navi-items { margin: 0; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 1.0; text-align: left; }

#global-header .spmenu__navi-link { margin: 0; padding: 18px 0 18px 0; display: block; color: #111; border-bottom: 1px solid #f2f2f2; text-align: center; text-decoration: none; }

#global-header .spmenu__navi-link:nth-child(1) { border-top: 1px solid #f2f2f2; }

#global-header .spmenu .btn__orange { height: 50px; }

#global-header .spmenu .btn__orange .fa-angle-right { margin: 20px 0 0 10px; position: static; }

#global-header .spmenu__menu-icon { width: 60px; height: 60px; margin: 0 auto 0 auto; padding: 0; text-align: center; border: none; cursor: pointer; outline: none; background-color: #fff; }

#global-header .spmenu__menu-icon.active .spmenu__icon-tag { background: url(../images/common/icon_sp_menu_close@2x.png) no-repeat left center/14px 20px !important; }

#global-header .spmenu__icon-txt { margin: 5px auto 0 auto; display: block; font-size: 10px; font-size: 1rem; font-weight: 600; color: #111; }

#global-header .spmenu__icon-tag { width: 18px; height: 20px; background: url(../images/common/icon_sp_menu@2x.png) no-repeat center center/18px 20px; content: ""; margin: 5px auto; padding: 0; display: block; }

/*カレント表示*/
#page__services .pcmenu__navi-items:nth-child(1) .pcmenu__navi-link::after { height: 5px; 　bottom: 0; }

#page__works .pcmenu__navi-items:nth-child(2) .pcmenu__navi-link::after { height: 5px; 　bottom: 0; }

#page__company .pcmenu__navi-items:nth-child(3) .pcmenu__navi-link::after { height: 5px; 　bottom: 0; }

#page__recruit .pcmenu__navi-items:nth-child(4) .pcmenu__navi-link::after { height: 5px; 　bottom: 0; }

#page__products .pcmenu__navi-items:nth-child(5) .pcmenu__navi-link::after { height: 5px; 　bottom: 0; }

#contents { margin: 0 auto 0 auto; padding: 0; min-height: calc( 100vh - 240px); box-sizing: border-box; /*汎用タイトル帯*/ /*form系 グローバルエラー*/ /*コンテンツ下部のお問い合わせ*/ /*banner*/ }

@media screen and (max-width: 767px) { #contents { min-height: calc( 100vh - 285px); } }

#contents .img-max { width: 100%; height: auto; }

#contents .mv-line { position: relative; margin: 0 auto; padding: 0; max-height: calc( 525 / 1440 * 100%); }

@media screen and (max-width: 767px) { #contents .mv-line { max-height: calc( auto); overflow: hidden; } }

#contents .mv-tit { margin: 0; padding: 22px 0 23px 0; background-color: #111111; text-align: center; color: #fff; box-sizing: border-box; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }

@media screen and (max-width: 767px) { #contents .mv-tit { padding: 10px 0 15px 0; } }

#contents .mv-tit span:nth-child(1) { margin: 0 10px 0 0; padding: 0; font-family: 'Major Mono Display', monospace; font-size: 46px; font-size: 4.6rem; }

#contents .mv-tit span:nth-child(2) { font-size: 14px; font-size: 1.4rem; }

@media screen and (max-width: 767px) { #contents .mv-tit span:nth-child(2) { display: block; } }

#contents .mv-tit .photo { margin: 0 auto; padding: 0; }

#contents #error__msg { margin-top: -350px; padding-top: 350px; display: block; }

#contents .error__msg { margin: 0 auto 40px auto; padding: 0 0 0 0; border: 2px solid #dc3545; background-color: #fff; border-radius: 2px; -webkit-animation: fadeIn 1s both; animation: fadeIn 1s both; }

#contents .error__tit { margin: 0; padding: 10px 10px 10px 10px; background-color: #dc3545; font-size: 16px; font-size: 1.6rem; color: #fff; }

#contents .error__tit .fa-exclamation-triangle { color: #f5c744; }

#contents .error__list { margin: 0; padding: 15px 15px 15px 15px; font-size: 14px; font-size: 1.4rem; font-weight: bold; line-height: 1.8; color: #dc3545; }

#contents .error__items { margin: 0; padding: 0; list-style: none; }

#contents .contactbox { margin: 20px auto 0 auto; padding: 0 20px 20px 20px; }

@media screen and (max-width: 767px) { #contents .contactbox { margin: 15px auto 0 auto; padding: 0 15px 15px 15px; } }

#contents .contactbox__wrap { position: relative; margin: 0 auto; padding: 0; }

#contents .contactbox__text-wrap { position: absolute; left: 50%; top: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); margin: 0; padding: 0; line-height: 1.5; text-align: center; color: #fff; display: inline-block; box-sizing: border-box; }

@media screen and (max-width: 767px) { #contents .contactbox__text-wrap { width: 100%; padding: 0 15px 0 15px; text-align: left; display: block; } }

#contents .contactbox__text-wrap .tit { margin: 0 auto; padding: 0; font-size: 16px; font-size: 1.6rem; font-weight: normal; }

@media screen and (max-width: 767px) { #contents .contactbox__text-wrap .tit { font-size: 14px; font-size: 1.4rem; } }

#contents .contactbox__text-wrap .txt { margin: 0 auto 30px auto; padding: 0; font-size: 16px; font-size: 1.6rem; }

@media screen and (max-width: 767px) { #contents .contactbox__text-wrap .txt { font-size: 14px; font-size: 1.4rem; } }

#contents .contactbox .btn__primary { max-width: 300px; margin: 0 auto; height: 50px; line-height: 50px; background-color: #F57E26; }

@media screen and (max-width: 767px) { #contents .contactbox .btn__primary { max-width: calc( 330 / 375 * 100%); } }

#contents .contactbox .btn__primary:hover { background-color: #111111; }

#contents .contactbox .btn__primary:active { background-color: #004B9E; }

#contents .bnr-box { max-width: 400px; height: auto; margin: 30px auto 0 auto; padding: 0; display: block; text-align: center; }

#global-footer { margin: 0 auto; padding: 0 0 0 0; background-color: #111111; color: #fff; }

#global-footer .container-fluid { margin: 0; padding: 0; }

#global-footer .figure { position: absolute; bottom: 0; right: 0; margin: 0; padding: 0; display: block; }

@media screen and (max-width: 767px) { #global-footer .figure { top: auto; bottom: 0; width: 175px; height: auto; } }

#global-footer .figure img { max-width: 348px; height: auto; }

@media screen and (max-width: 767px) { #global-footer .figure img { max-width: 174px; height: auto; } }

#global-footer .ft__wrap { position: relative; width: 100%; min-height: 175px; margin: 0 auto; padding: 20px 50px 10px 50px; box-sizing: border-box; display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { #global-footer .ft__wrap { margin: 0 auto; padding: 50px 0 50px 1.5em; min-height: auto; -webkit-flex-direction: column; flex-direction: column; -webkit-justify-content: center; justify-content: center; } }

#global-footer .ft__navi-list { max-width: 560px; margin: 30px auto 0px 0; padding: 0; display: -webkit-inline-flex; display: inline-flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; -webkit-flex-wrap: wrap; flex-wrap: wrap; font-size: 16px; font-size: 1.6rem; line-height: 1.2; }

@media screen and (max-width: 767px) { #global-footer .ft__navi-list { max-width: 100%; margin: 0 auto 0 auto; -webkit-justify-content: center; justify-content: center; font-size: 14px; font-size: 1.4rem; } }

#global-footer .ft__navi-items { margin: 0 0 30px 0; padding: 0; list-style: none; }

#global-footer .ft__navi-items::after { width: 1em; height: 1em; margin: 0 20px 0 20px; content: "|"; }

#global-footer .ft__navi-link { margin: 0; padding: 0; color: #fff; text-decoration: none; }

#global-footer .ft__navi-link:hover { text-decoration: underline; color: #F57E26; }

#global-footer .ft__navi-link:active { color: #004B9E; }

#global-footer .ft__copy { margin: 0 auto; padding: 30px 0 30px 0; background-color: #1D1D1D; text-align: center; font-size: 16px; font-size: 1.6rem; font-weight: 500; font-family: Helvetica,sans-serif; line-height: 1.2; display: block; }

@media screen and (max-width: 767px) { #global-footer .ft__copy { padding: 15px 0 15px 0; font-size: 14px; font-size: 1.4rem; } }

[v-cloak] { display: none; }

#pagetop { position: fixed; bottom: 30px; right: 38px; width: 78px; cursor: pointer; transition: all 0.6s; }

@media screen and (max-width: 767px) { #pagetop { right: 5%; bottom: 2%; } }

#pagetop.v-enter, #pagetop.v-leave-to { opacity: 0; bottom: 10px; }

.stop { bottom: 275px !important; }

@media screen and (max-width: 767px) { .stop { right: 5%; bottom: 280px !important; } }

#pagetop_hack { position: fixed; bottom: 15%; right: 38px; width: 78px; cursor: pointer; display: none; }

@media screen and (max-width: 767px) { #pagetop_hack { right: 5%; bottom: 10%; } }

#pagetop_hack.active { display: block !important; }

/* ----------------------------------------------- CSS Import  ----------------------------------------------- */
/* ========================================================================== index css ========================================================================== */
@-webkit-keyframes fadeOut { 0% { opacity: 1; }
  100% { opacity: 0; } }
@keyframes fadeOut { 0% { opacity: 1; }
  100% { opacity: 0; } }

@keyframes fadeIn { 0% { opacity: 0; }
  100% { opacity: 1; } }

@-webkit-keyframes animate { 0% { -webkit-transform: translateY(0) rotate(0deg); transform: translateY(0) rotate(0deg);
    opacity: 1;
    border-radius: 0; }
  100% { -webkit-transform: translateY(-1000px) rotate(720deg); transform: translateY(-1000px) rotate(720deg);
    opacity: 0;
    border-radius: 50%; } }

@keyframes animate { 0% { -webkit-transform: translateY(0) rotate(0deg); transform: translateY(0) rotate(0deg);
    opacity: 1;
    border-radius: 0; }
  100% { -webkit-transform: translateY(-1000px) rotate(720deg); transform: translateY(-1000px) rotate(720deg);
    opacity: 0;
    border-radius: 50%; } }

@-webkit-keyframes extend { 0% { -webkit-transform: scaleY(0); transform: scaleY(0); }
  100% { -webkit-transform: scaleY(1); transform: scaleY(1); } }

@keyframes extend { 0% { -webkit-transform: scaleY(0); transform: scaleY(0); }
  100% { -webkit-transform: scaleY(1); transform: scaleY(1); } }

.fade-enter-active, .fade-leave-active { transition: opacity .5s; }

.fade-enter, .fade-leave-to { opacity: 0; }

.index-btngroup { margin: 0 auto; padding: 0; text-align: center; }

.index-btngroup .btn__primary { margin: 0 auto; }

.index-btngroup .btn__secondary { margin: 0 auto; }

.hasIndex__tit { position: absolute; left: 0; top: 0; }

/* visual-section --------------------------- */
.index-visual { position: relative; margin: 0 auto; padding: 0; }

.index-visual .mv-line__slider-wrap { max-width: 100%; height: auto; margin: 0 auto; padding: 0; text-align: center; }

@media screen and (max-width: 767px) { .index-visual .mv-line__slider-wrap { height: 390px; } }

.index-visual .swiper-slide img { width: 100%; height: auto; }

/* news-section --------------------------- */
.index-news { margin: 0 auto; padding: 0 0 80px 0; }

@media screen and (max-width: 767px) { .index-news { padding: 0 0 50px 0; } }

.index-news__info { max-width: 955px; margin: 90px auto 40px auto; padding: 0; transition: .5s; -webkit-animation: fadeIn .5s linear; animation: fadeIn .5s linear; }

@media screen and (max-width: 767px) { .index-news__info { max-width: calc( 345 / 375 * 100%); margin: 30px auto 25px auto; padding: 0 0 0 0; } }

.index-news__info .news-api { margin: 0; padding: 0; display: block; }

.index-news__info-list { width: 100%; margin: 0; padding: 0; background-color: #EAEAEA; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: stretch; align-items: stretch; }

@media screen and (max-width: 767px) { .index-news__info-list { position: relative; -webkit-flex-direction: column; flex-direction: column; -webkit-align-items: stretch; align-items: stretch; padding: 0; } }

.index-news__info-list:nth-child(even) { background-color: #F8F8F8; }

.index-news__info-list:nth-child(even) .btn { background-color: #045CBE; }

.index-news__info-tit { width: 90px; margin: auto 2px auto 0; padding: 0 0 0 15px; font-size: 12px; font-size: 1.2rem; line-height: 1.2; color: #111111; box-sizing: border-box; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { .index-news__info-tit { position: absolute; left: 0; top: 0; width: 80px; padding: 10px 0 5px 10px; border-right: 0; border-bottom: 2px solid #fff; } }

.index-news__info-txt { width: calc( 100% - 80px); margin: 0; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { .index-news__info-txt { width: calc( 100% - 0px); -webkit-align-items: stretch; align-items: stretch; } }

.index-news__info-txt .tit { margin: 0 auto 0 0; padding: 10px 10px 10px 10px; display: block; font-size: 14px; font-size: 1.4rem; line-height: 1.6; border-left: 2px solid #fff; }

@media screen and (max-width: 767px) { .index-news__info-txt .tit { padding-top: 40px; border-left: none; } }

.index-news__info-txt .btn { position: relative; min-width: 140px; min-height: 42px; height: 100%; margin: 0; padding: 0 10px 0 15px; box-sizing: border-box; background-color: #004B9E; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: center; align-items: center; font-size: 12px; font-size: 1.2rem; line-height: 42px; font-weight: bold; text-align: center; color: #fff; text-decoration: none; }

@media screen and (max-width: 767px) { .index-news__info-txt .btn { min-height: 100%; height: auto; padding: 0 20px 0 15px; } }

.index-news__info-txt .btn:hover { background-color: #F57E26; }

.index-news__info-txt .btn .fa-angle-right, .index-news__info-txt .btn .fa-external-link-alt { margin: auto 0 auto auto; }

.index-news__btn-group { margin: 0 auto 0 auto; padding: 0; text-align: center; }

.index-news__btn-group .btn__secondary { margin: 0 auto; padding: 0; }

/* services-section --------------------------- */
.index-services { margin: 0 auto; padding: 0 0 100px 0; }

@media screen and (max-width: 767px) { .index-services { padding-bottom: 50px; } }

.index-services__visual { position: relative; margin: 0; padding: 0; padding-top: calc( 30 / 1440 * 100%); padding-bottom: calc( 30 / 1440 * 100%); overflow: hidden; }

@media screen and (max-width: 767px) { .index-services__visual { padding-top: calc( 20 / 375 * 100%); padding-bottom: calc( 20 / 375 * 100%); } }

.index-services__visual-bg { position: absolute; left: 0; top: 0; z-index: -1; margin: 0; padding: 0; display: block; }

.index-services__visual-bg .img-max { width: auto; height: 100%; }

.index-services__visual-tit { margin: 0 auto; padding: 0; margin-top: calc( 30 / 1440 * 100%); margin-bottom: calc( 30 / 1440 * 100%); font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "Noto Serif JP","MS P明朝", "MS PMincho", serif; font-size: 50px; font-size: 5rem; font-weight: bold; text-align: center; color: #111; }

@media screen and (max-width: 767px) { .index-services__visual-tit { margin-top: calc( 30 / 375 * 100%); margin-bottom: calc( 30 / 375 * 100%); font-size: 25px; font-size: 2.5rem; } }

.index-services__visual-glass { max-width: calc( 700 / 1440 * 100%); margin: 0 auto 0 auto; padding: 0 0 0 0; padding-top: calc( 50 / 1440 * 100%); padding-bottom: calc( 50 / 1440 * 100%); border-radius: 10px; color: #fff; -webkit-backdrop-filter: blur(15px); backdrop-filter: blur(15px); background-color: rgba(255, 255, 255, 0.5); box-sizing: border-box; }

@media screen and (max-width: 767px) { .index-services__visual-glass { max-width: calc( 345 / 375 * 100%); padding: 20px 15px 20px 15px; } }

.index-services__visual-glass .tit { margin: 0 auto 20px auto; padding: 0; font-size: 18px; font-size: 1.8rem; line-height: 1.6; font-weight: bold; text-align: center; }

.index-services__visual-glass .tit .b { color: #FFDF89; }

@media screen and (max-width: 767px) { .index-services__visual-glass .tit { margin: 0 auto 0 auto; font-size: 14px; font-size: 1.4rem; text-align: left; } }

.index-services__visual-glass .txt { margin: 0; padding: 0; font-size: 18px; font-size: 1.8rem; line-height: 1.6; font-weight: bold; text-align: center; }

@media screen and (max-width: 767px) { .index-services__visual-glass .txt { font-size: 14px; font-size: 1.4rem; text-align: left; } }

.index-services__detail { max-width: 956px; margin: 60px auto 0 auto; padding: 0; }

@media screen and (max-width: 767px) { .index-services__detail { max-width: 345px; margin: 25px auto 0 auto; } }

.index-services__detail-tit { margin: 0 auto 40px auto; padding: 0; font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "Noto Serif JP","MS P明朝", "MS PMincho", serif; font-size: 30px; font-size: 3rem; text-align: center; line-height: 1.2; color: #111; }

@media screen and (max-width: 767px) { .index-services__detail-tit { margin: 0 auto 25px auto; } }

.index-services__detail .col-wrap { margin: 0; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: flex-start; align-items: flex-start; }

@media screen and (max-width: 767px) { .index-services__detail .col-wrap { -webkit-flex-direction: column; flex-direction: column; -webkit-justify-content: center; justify-content: center; } }

.index-services__detail .col { width: calc( 100% - 30px); margin: 0 auto 0 auto; padding: 50px 50px 50px 50px; background-color: rgba(17, 17, 17, 0.8); border-radius: 10px; text-align: center; box-sizing: border-box; }

@media screen and (max-width: 767px) { .index-services__detail .col { width: calc( 100% - 0px); } }

.index-services__detail .col.left { margin-right: 15px; }

@media screen and (max-width: 767px) { .index-services__detail .col.left { margin-right: auto; margin-bottom: 15px; } }

.index-services__detail .col.right { margin-left: 15px; }

@media screen and (max-width: 767px) { .index-services__detail .col.right { margin-left: auto; } }

.index-services__detail .col .tit { margin: 0 auto 20px auto; padding: 0; font-size: 18px; font-size: 1.8rem; line-height: 1.2; color: #fff; }

.index-services__detail .col .list { margin: 0; padding: 0; }

.index-services__detail .col .items { margin: 0; padding: 0; list-style: none; font-size: 14px; font-size: 1.4rem; line-height: 1.6; color: #fff; }

/* works-section --------------------------- */
.index-works { /*list*/ }

.index-works__wrap { max-width: 100%; margin: 0 auto; padding: 100px 0 0 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .index-works__wrap { padding: 50px 0 0 0; } }

.index-works__btngroup { margin: 0 auto 100px auto; padding: 0; text-align: center; }

@media screen and (max-width: 767px) { .index-works__btngroup { margin-bottom: 50px; } }

.index-works__btngroup .btn__secondary { margin: 0 auto; padding: 0; }

.index-works__list { margin: 0 auto; padding: 0; }

.index-works__items { position: relative; margin: 0 auto 60px auto; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: flex-end; align-items: flex-end; }

@media screen and (max-width: 767px) { .index-works__items { margin-bottom: calc( 50 / 375 * 100%); -webkit-flex-direction: column; flex-direction: column; } }

.index-works__copy { position: absolute; bottom: 10px; z-index: 1; font-size: 9px; font-size: 0.9rem; color: #666; }

.index-works__copy.right { right: 20px; text-align: right; }

@media screen and (max-width: 767px) { .index-works__copy.right { top: 2px; right: 10px; } }

.index-works__copy.left { left: 15px; bottom: 0; text-align: left; }

@media screen and (max-width: 767px) { .index-works__copy.left { top: 2px; left: 10px; } }

.index-works__pic { position: relative; margin: 0 20px 0 0; padding: 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .index-works__pic { width: calc( 100%); margin: 0 auto; } }

.index-works__pic.right { margin-left: 20px; margin-right: 0px; }

@media screen and (max-width: 767px) { .index-works__pic.right { margin-left: auto; margin-right: auto; } }

.index-works__pic-img { margin: 0; padding: 0; }

.index-works__detail { position: relative; width: calc( 566 / 1440 * 100%); min-width: calc( 566 / 1440 * 100%); margin: 0 0 10px 0; padding: 60px 40px 40px 40px; border-radius: 10px 0px 0px 10px; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); background-color: rgba(255, 255, 255, 0.9); box-sizing: border-box; overflow: hidden; }

@media screen and (max-width: 767px) { .index-works__detail { position: relative; margin: 10px auto 0 auto; padding: 20px 15px 15px 15px; width: calc( 345 / 375 * 100%); border-radius: 10px 10px 10px 10px; text-align: left; } }

.index-works__detail .caption { position: absolute; top: 0px; left: 0px; z-index: 2; width: 100%; margin: 0; border-radius: 10px 0px 0px 0px; padding: 8px 10px 8px 10px; background-color: #111; font-size: 12px; font-size: 1.2rem; line-height: 1.2; color: #fff; display: block; box-sizing: border-box; }

@media screen and (max-width: 767px) { .index-works__detail .caption { z-index: 0; border-radius: 10px 10px 0px 0px; } }

.index-works__detail .tit { margin: 0 0 5px 0; padding: 0; font-size: 20px; font-size: 2rem; line-height: 1.4; color: #111; }

@media screen and (max-width: 767px) { .index-works__detail .tit { margin: 20px auto 10px auto; } }

.index-works__detail .txt { margin: 0 0 25px 0; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 2; }

.index-works__detail .icon { margin: 0 10px 0 0; padding: 5px 10px 5px 10px; font-size: 11px; font-size: 1.1rem; line-height: 1.4; background-color: #111; color: #fff; }

.index-works__detail .btn__secondary { width: 180px; height: 50px; line-height: 50px; }

@media screen and (max-width: 767px) { .index-works__detail .btn__secondary { margin: 0 auto; } }

@media screen and (max-width: 767px) { .index-works__detail.right { text-align: left; } }

.index-works__detail.left { border-radius: 0px 10px 10px 0px; text-align: right; margin-bottom: 0px; }

@media screen and (max-width: 767px) { .index-works__detail.left { -webkit-order: 2; order: 2; text-align: left; border-radius: 0px 10px 10px 10px; } }

.index-works__detail.left .btn__secondary { margin-left: auto; }

.index-works__detail.left .caption { border-radius: 0px; }

@media screen and (max-width: 767px) { .index-works__detail.left .caption { border-radius: 10px 10px 0px 0px; } }

/* ========================================================================== inquiry page css ========================================================================== */
@media screen and (max-width: 767px) { .page__inquiry { padding-top: 70px; } }

/* inquiry --------------------------- */
#inquiry-header { position: fixed; left: 0; top: 0; width: 100%; margin: 0 auto; padding: 0; height: 100px; min-height: 100px; max-height: 100px; background-color: transparent; box-shadow: none; z-index: 99999; box-sizing: border-box; }

@media screen and (max-width: 767px) { #inquiry-header { height: 70px; min-height: 70px; max-height: 70px; border-top: 10px solid #111; background-color: #fff; border-bottom: 1px solid #ccc; } }

#inquiry-header .container-fluid { margin: 0; padding: 0; }

#inquiry-header .hd__line { position: relative; width: 100%; height: 40px; margin: 0; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { #inquiry-header .hd__line { background-color: #fff; } }

#inquiry-header .hd__line-col { margin: 0; padding: 0; }

#inquiry-header .hd__line-col .btn__primary { width: 200px; margin: 0 0 0 auto; }

@media screen and (max-width: 767px) { #inquiry-header .hd__line-col .btn__primary { display: none; } }

#inquiry-header .hd__line-col:nth-child(1) { width: calc( 100% - 200px); }

#inquiry-header .hd__logo { position: absolute; left: 0; top: 0; z-index: 2; width: 230px; height: 100px; margin: 0; padding: 0; box-sizing: border-box; background: #004b9e; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }

@media screen and (max-width: 767px) { #inquiry-header .hd__logo { width: auto; height: 60px; background: none; box-shadow: none; border-radius: none; } }

#inquiry-header .hd__logo a { width: 100%; height: 100px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; transition: .0s; }

@media screen and (max-width: 767px) { #inquiry-header .hd__logo a { padding-left: 10px; height: 60px; } }

#inquiry-header .hd__logo img { margin: 0 auto 0 auto; display: block; }

@media screen and (max-width: 767px) { #inquiry-header .hd__logo img { width: auto; height: 44px; } }

#inquiry-header .hd__tit { margin: 0; padding: 0; margin-left: 240px; font-size: 14px; font-size: 1.4rem; font-weight: normal; line-height: 1.2; color: #fff; display: block; }

@media screen and (max-width: 767px) { #inquiry-header .hd__tit { display: none; } }

#inquiry-header .hd__wrap { width: 100%; margin: 0; padding: 0; }

#inquiry-header .hd__wrap-col { margin: 0 0 0 auto; padding: 0; }

.inquiry__wrap { max-width: 100%; margin: 0 auto; padding: 0 10px 0 10px; box-sizing: border-box; }

@media screen and (max-width: 767px) { .inquiry__wrap { padding: 0; } }

.inquiry__introtxt { margin: 66px auto 100px auto; padding: 0; font-size: 16px; font-size: 1.6rem; line-height: 1.2; }

@media screen and (max-width: 767px) { .inquiry__introtxt { margin: 20px 0 40px 0; line-height: 1.6; } }

.inquiry__fluid { max-width: 820px; margin: 0 auto; padding: 34px 0 80px 0; }

@media screen and (max-width: 767px) { .inquiry__fluid { max-width: calc( 335 / 375 * 100%); padding: 25px 0 50px 0; } }

.inquiry__fluid input[type="text"].form-control { font-size: 16px; font-size: 1.6rem; text-indent: 1em; height: 60px; color: #373737; box-sizing: border-box; }

@media screen and (max-width: 767px) { .inquiry__fluid input[type="text"].form-control { text-indent: .5em; height: 44px; } }

.inquiry__fluid input[type="text"]::-webkit-input-placeholder { color: #989898; }

.inquiry__fluid input[type="text"]::-moz-placeholder { color: #989898; }

.inquiry__fluid input[type="text"]:-ms-input-placeholder { color: #989898; }

.inquiry__fluid input[type="text"]::placeholder { color: #989898; }

.inquiry__fluid textarea.form-control { font-size: 16px; font-size: 1.6rem; text-indent: 0; height: 178px; color: #373737; padding: 20px 20px 20px 20px; box-sizing: border-box; }

@media screen and (max-width: 767px) { .inquiry__fluid textarea.form-control { padding: 10px 10px 10px 10px; height: 134px; } }

.inquiry__fluid textarea::-webkit-input-placeholder { color: #989898; }

.inquiry__fluid textarea::-moz-placeholder { color: #989898; }

.inquiry__fluid textarea:-ms-input-placeholder { color: #989898; }

.inquiry__fluid textarea::placeholder { color: #989898; }

.inquiry__fluid .custom-select { margin: 0; padding: 0 0 0 1.5em; height: 60px; font-size: 16px; font-size: 1.6rem; box-sizing: border-box; color: #000; }

@media screen and (max-width: 767px) { .inquiry__fluid .custom-select { padding: 0 0 0 1em; height: 44px; } }

.inquiry__fluid .custom-select option { color: #000; }

.inquiry__fluid .inq__label { margin: 0 0 10px 0; padding: 0; font-size: 16px; font-size: 1.6rem; color: #111111; }

@media screen and (max-width: 767px) { .inquiry__fluid .inq__label { font-size: 15px; font-size: 1.5rem; } }

.inquiry__fluid .icon__type { width: 53px; margin: 0 10px 0 0; padding: 4px 0 4px 0; border-radius: 3px; font-size: 13px; font-size: 1.3rem; font-weight: 600; color: #fff; display: inline-block; text-align: center; }

@media screen and (max-width: 767px) { .inquiry__fluid .icon__type { width: 43px; font-size: 10px; font-size: 1rem; } }

.inquiry__fluid .icon--any { background-color: #B3B3B3; }

.inquiry__fluid .icon--rqd { background-color: #F25D5D; }

.inquiry__fluid .form-check { padding-left: 0; }

.inquiry__fluid .form-check-label { margin-left: 5px; font-size: 16px; font-size: 1.6rem; }

@media screen and (max-width: 767px) { .inquiry__fluid .form-check-label { margin-left: 10px; font-size: 12px; font-size: 1.2rem; } }

.inquiry__fluid .form-check-label a { text-decoration: underline; }

.inquiry__fluid .form-check-label a:hover { text-decoration: none; }

.inquiry__fluid .form-check-input { font-size: 20px; font-size: 2rem; margin-left: 0px; }

@media screen and (max-width: 767px) { .inquiry__fluid .form-check-input { -webkit-transform: scale(1.4); transform: scale(1.4); } }

.inquiry__fluid .invalid-feedback { margin: 1em auto 1em auto; padding: 0; font-size: 14px; font-size: 1.4rem; font-weight: bold; display: block; }

.inquiry__fluid .invalid-feedback .fa-exclamation-triangle { color: #f5c744; }

.inquiry__fluid .valid-feedback { margin: 1em auto 1em auto; padding: 0; font-size: 14px; font-size: 1.4rem; font-weight: bold; display: block; }

.inquiry__fluid .php-feedback { margin: 1em auto 1em auto; padding: 0; font-size: 14px; font-size: 1.4rem; font-weight: 600; color: #dc3545; }

.inquiry__btnset { width: 100%; margin: 50px auto 50px auto; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; text-align: center; }

@media screen and (max-width: 767px) { .inquiry__btnset { width: auto; width: calc( 100% - 1em); margin: 0 auto 0 auto; -webkit-flex-direction: column; flex-direction: column; } }

.inquiry__btnset .inline__left { width: 50%; margin-right: 10px; box-sizing: border-box; }

.inquiry__btnset .inline__left button { width: 100%; }

@media screen and (max-width: 767px) { .inquiry__btnset .inline__left { width: 100%; margin-right: 0; } }

.inquiry__btnset .inline__right { width: 50%; margin-left: 10px; box-sizing: border-box; }

.inquiry__btnset .inline__right button { width: 100%; }

@media screen and (max-width: 767px) { .inquiry__btnset .inline__right { width: 100%; margin-left: 0; } }

.inquiry__btnset.finish { margin-bottom: 80px; }

@media screen and (max-width: 767px) { .inquiry__btnset.finish { margin: 50px auto 0 auto; } }

.inquiry__btnset .btn__original { width: 600px; height: 96px; line-height: 96px; margin: 0 auto; padding: 0; outline: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; font-size: 18px; font-size: 1.8rem; }

@media screen and (max-width: 767px) { .inquiry__btnset .btn__original { width: 100%; height: 68px; line-height: 68px; font-size: 13px; font-size: 1.3rem; } }

.inquiry__btnset .btn__confirm { min-width: auto; height: 96px; line-height: 96px; background: #6a6a6a; margin: 0; padding: 0; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); text-decoration: none; text-align: center; color: #fff; font-size: 16px; font-size: 1.6rem; line-height: 39px; display: block; transition: .5s; -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; }

@media screen and (max-width: 767px) { .inquiry__btnset .btn__confirm { width: 100%; height: 68px; line-height: 68px; font-size: 13px; font-size: 1.3rem; } }

.inquiry__btnset .btn__confirm:hover { opacity: 0.7; }

.inquiry__btnset .btn__confirm:active { background: #6a6a6a; box-shadow: none; opacity: 1.0; }

.inquiry__btnset .btn__confirm .fas { margin-left: 10px; }

.inquiry__formwrap { margin-bottom: 40px; }

@media screen and (max-width: 767px) { .inquiry__formwrap { margin-bottom: 20px; } }

.inquiry__readonly-text { margin: 15px 0 0 0; padding: 0; font-size: 16px; font-size: 1.6rem; color: #212121; }

@media screen and (max-width: 767px) { .inquiry__readonly-text { font-size: 12px; font-size: 1.2rem; } }

.inquiry__finish { max-width: 820px; margin: 210px auto 0 auto; padding: 0; box-sizing: border-box; color: #212121; }

@media screen and (max-width: 767px) { .inquiry__finish { max-width: 100%; margin: 110px auto 30px auto; padding: 0 15px 0 15px; } }

.inquiry__finish .tit { margin: 0 auto 20px auto; padding: 0; font-size: 24px; font-size: 2.4rem; font-weight: bold; line-height: 1.8; }

@media screen and (max-width: 767px) { .inquiry__finish .tit { font-size: 18px; font-size: 1.8rem; } }

.inquiry__finish .txt { margin: 0 auto 100px auto; padding: 0; font-size: 16px; font-size: 1.6rem; line-height: 1.8; color: #666666; }

@media screen and (max-width: 767px) { .inquiry__finish .txt { margin: 0 auto 20px auto; font-size: 12px; font-size: 1.2rem; } }

/* ========================================================================== works page css ========================================================================== */
.works { /*works detail*/ }

.works__wrap { max-width: 100%; margin: 0 auto; padding: 100px 0 0 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .works__wrap { padding: 50px 0 0 0; } }

.works__btngroup { margin: 0 auto 100px auto; padding: 0; text-align: center; }

@media screen and (max-width: 767px) { .works__btngroup { margin-bottom: 50px; } }

.works__btngroup .btn__secondary { margin: 0 auto; padding: 0; }

.works__dpage-wrap { max-width: 100%; margin: 100px auto 0 auto; padding: 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .works__dpage-wrap { margin-top: 50px; } }

.works__dpage { margin: 0 auto; padding: 0; }

.works__dpage-tit { max-width: 1000px; margin: 0 auto 20px auto; padding: 0 0 10px 0; font-size: 20px; font-size: 2rem; font-weight: bold; line-height: 1.0; text-align: center; color: #004B9E; border-bottom: 1px solid #004B9E; box-sizing: border-box; }

@media screen and (max-width: 767px) { .works__dpage-tit { max-width: calc( 100% - 40px); } }

.works__dpage-tit::before { content: " "; display: block; height: 12rem; margin-top: -12rem; visibility: hidden; }

@media screen and (max-width: 767px) { .works__dpage-tit::before { height: 10rem; margin-top: -10rem; } }

.works__dpage-tbl { max-width: 1000px; margin: 0 auto 100px auto; padding: 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .works__dpage-tbl { max-width: 100%; margin: 0 auto 50px auto; padding: 0 20px 0 20px; } }

.works__dpage-table { width: 100%; margin: 0 auto; padding: 0; border-collapse: collapse; }

.works__dpage-table thead { background-color: #111111; }

.works__dpage-table th { margin: 0; padding: 20px 20px 20px 20px; font-size: 14px; font-size: 1.4rem; text-align: left; color: #fff; border: none; }

.works__dpage-table th:nth-child(1) { width: 60%; }

@media screen and (max-width: 767px) { .works__dpage-table th:nth-child(1) { width: 50%; } }

.works__dpage-table td { margin: 0; padding: 20px 15px 20px 15px; line-height: 1.6; border-bottom: 1px solid #E6E6E6; }

.works__dpage-table td:nth-child(1) { font-size: 16px; font-size: 1.6rem; }

.works__dpage-table td:nth-child(2) { font-size: 14px; font-size: 1.4rem; }

.works__dpage-table td:nth-child(3) { font-size: 14px; font-size: 1.4rem; }

/* ========================================================================== company page css ========================================================================== */
/* company list --------------------------- */
.company__wrap { max-width: 100%; margin: 0 auto; padding: 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .company__wrap { padding: 0; } }

.company__map { position: relative; max-width: 1000px; height: 350px; margin: 100px auto 0 auto; }

@media screen and (max-width: 767px) { .company__map { max-width: calc( 345 / 375 * 100%); margin: 30px auto 20px auto; } }

.company__map iframe { position: absolute; left: 0; top: 0; width: 100%; height: 100%; margin: 0; padding: 0; }

.company__address { max-width: 1000px; margin: 20px auto 65px auto; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 1.2; text-align: left; }

@media screen and (max-width: 767px) { .company__address { max-width: 345px; margin: 0 auto 30px auto; color: #666666; } }

.company__profile { margin: 0; padding: 0; padding-top: 50px; padding-bottom: 100px; background-color: #F5F7FF; }

@media screen and (max-width: 767px) { .company__profile { padding: 0 15px 0 15px; padding-top: calc( 30 / 375 * 100%); padding-bottom: calc( 50 / 375 * 100%); } }

.company__profile.group { background-color: #fff; }

.company__profile-tit { max-width: 1000px; margin: 0 auto 15px auto; padding: 0 0 10px 0; font-size: 20px; font-size: 2rem; font-weight: bold; line-height: 1.0; text-align: center; color: #111; border-bottom: 1px solid #111; }

.company__profile-table { max-width: 1000px; margin: 0 auto; padding: 0; }

.company__profile-table .virtual-tbl { margin: 0; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: stretch; align-items: stretch; -webkit-flex-wrap: wrap; flex-wrap: wrap; background-color: #fff; border-top: 1px solid #E6E6E6; }

.company__profile-table .virtual-tbl .th { min-width: 100px; margin: 0; padding: 20px 20px 20px 20px; background: #111; font-size: 14px; font-size: 1.4rem; font-weight: bold; line-height: 1.2; color: #fff; border-bottom: 1px solid #E6E6E6; box-sizing: border-box; }

@media screen and (max-width: 767px) { .company__profile-table .virtual-tbl .th { padding: 15px 15px 15px 15px; } }

.company__profile-table .virtual-tbl .th .small { font-size: 8px; font-size: 0.8rem; }

.company__profile-table .virtual-tbl .td { position: relative; width: calc( 100% - 100px); margin: 0; padding: 17px 45px 15px 15px; border-bottom: 1px solid #E6E6E6; box-sizing: border-box; }

@media screen and (max-width: 767px) { .company__profile-table .virtual-tbl .td { padding: 15px 15px 15px 15px; color: #666666; } }

.company__profile-table .virtual-tbl .txt { margin: 0; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 1.6; }

.company__profile-table .virtual-tbl .panel { margin: 10px 0 10px 0; padding: 10px 10px 10px 10px; border-radius: 5px; }

.company__profile-table .virtual-tbl .panel .b { font-size: 15px; font-size: 1.5rem; font-weight: bold; line-height: 1.6; display: block; }

.company__profile-table .virtual-tbl .panel .t { font-size: 14px; font-size: 1.4rem; line-height: 1.6; }

.company__profile-table .virtual-tbl .panel--red { background-color: #F8E7E7; }

.company__profile-table .virtual-tbl .panel--red .b { color: #9E0000; }

.company__profile-table .virtual-tbl .panel--blue { background-color: #D1E2F7; }

.company__profile-table .virtual-tbl .panel--blue .b { color: #004B9E; }

.company__profile-table .virtual-tbl .panel + .panel { margin-top: 0px; }

.company__group { margin: 0; padding: 0; }

/* ========================================================================== products page css ========================================================================== */
/* products list --------------------------- */
.products__wrap { width: 100%; margin: 0 auto; padding: 100px 10px 0 10px; box-sizing: border-box; }

@media screen and (max-width: 767px) { .products__wrap { padding: 30px 15px 0 15px; } }

.products__intro-text { margin: 0 auto 100px auto; padding: 0; text-align: center; font-size: 14px; font-size: 1.4rem; line-height: 1.6; }

@media screen and (max-width: 767px) { .products__intro-text { margin: 0 auto 50px auto; text-align: left; } }

.products__card-wrap { max-width: 1440px; margin: 0 auto 70px auto; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-flex-wrap: wrap; flex-wrap: wrap; -webkit-align-items: flex-start; align-items: flex-start; }

@media screen and (max-width: 767px) { .products__card-wrap { width: 100%; margin: 0 auto 35px auto; padding: 0 0 0 0; -webkit-flex-direction: column; flex-direction: column; } }

.products__card-col { max-width: calc( 100% / 3); margin: 0 0 0 0; padding: 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .products__card-col { max-width: calc( 100%); } }

.products__card-col:nth-child(3) { margin-right: -20px; }

.products__card-col:nth-child(5) { margin-right: -20px; }

.products__card { max-width: 450px; margin: 0 20px 30px 0; padding: 15px 20px 30px 20px; background: #fff; border-radius: 10px; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); text-align: left; box-sizing: border-box; transition: .5s; }

@media screen and (max-width: 767px) { .products__card { margin: 0 0 15px 0; } }

.products__card:hover { margin-top: -15px; }

@media screen and (max-width: 767px) { .products__card { max-width: 100%; padding: 15px 15px 20px 15px; } }

.products__card .tit { margin: 0 auto 15px auto; padding: 0; font-size: 24px; font-size: 2.4rem; line-height: 1.2; font-family: "Helvetica",sans-serif; font-weight: bold; text-align: center; color: #004B9E; }

.products__card .tit.end { color: #111; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }

.products__card .tit.end span { margin: 0 0 0 4px; padding: 0 20px 0 20px; border-radius: 3px; background-color: #111; font-size: 16px; font-size: 1.6rem; font-weight: normal; line-height: 1.6; color: #fff; display: inline-block; }

.products__card .txt { margin: 10px auto 20px auto; padding: 0; font-size: 16px; font-size: 1.6rem; font-weight: bold; line-height: 1.6; text-align: center; color: #004B9E; }

@media screen and (max-width: 767px) { .products__card .txt { text-align: left; } }

.products__card .btn__secondary { max-width: 300px; width: auto; margin: 0 auto; height: 50px; line-height: 50px; }

@media screen and (max-width: 767px) { .products__card .btn__secondary { width: 100%; } }

.products__data { margin: 0 auto 10px auto; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; -webkit-flex-wrap: wrap; flex-wrap: wrap; font-size: 14px; font-size: 1.4rem; line-height: 1.6; color: #111; }

.products__data-items { position: relative; width: 100%; margin: 0; padding: 0; list-style: none; border-bottom: 1px solid #EDEDED; box-sizing: border-box; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

.products__data-items:last-child { border-bottom: none; }

.products__data-items .icon { width: 20px; height: 20px; margin: 10px 3px auto 0; padding: 0; display: block; box-sizing: border-box; }

.products__data-items .icon-01 { background: url(../images/products/icon_01.svg) no-repeat center center; }

.products__data-items .icon-02 { background: url(../images/products/icon_02.svg) no-repeat center center; }

.products__data-items .icon-03 { background: url(../images/products/icon_03.svg) no-repeat center center; }

.products__data-wrap { width: calc( 100% - 20px); margin: 0; padding: 10px 0 10px 0; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: flex-start; align-items: flex-start; -webkit-flex-wrap: wrap; flex-wrap: wrap; box-sizing: border-box; }

.products__data-tit { margin: 0; padding: 0; display: block; }

.products__data-txt { margin: 0; padding: 0; display: block; }

.products__data-op { width: 100%; margin: 10px 0 0 0; padding: 13px 15px 13px 15px; display: block; background-color: #EDEDED; border-radius: 5px; box-sizing: border-box; }

.products__data-op .b { color: #F25D5D; }

/* ========================================================================== recruit page css ========================================================================== */
/* recruit list --------------------------- */
.recruit__wrap { position: relative; max-width: 100%; margin: 0 auto; padding: 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .recruit__wrap { padding: 0; } }

.recruit__visual { position: relative; margin: 0; padding: 0; padding-top: calc( 30 / 1440 * 100%); padding-bottom: calc( 30 / 1440 * 100%); overflow: hidden; }

@media screen and (max-width: 767px) { .recruit__visual { padding-top: calc( 20 / 375 * 100%); padding-bottom: calc( 20 / 375 * 100%); } }

.recruit__visual-bg { position: absolute; left: 0; top: 0; z-index: -1; margin: 0; padding: 0; display: block; }

@media screen and (max-width: 767px) { .recruit__visual-bg { width: 180%; left: -80%; } }

.recruit__visual-bg .img-max { width: auto; height: 100%; }

.recruit__visual-tit { margin: 0 auto; padding: 0; font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "Noto Serif JP","MS P明朝", "MS PMincho", serif; font-size: 30px; font-size: 3rem; font-weight: bold; text-align: center; color: #fff; }

@media screen and (max-width: 767px) { .recruit__visual-tit { margin-top: calc( 20 / 375 * 100%); margin-bottom: calc( 20 / 375 * 100%); font-size: 25px; font-size: 2.5rem; } }

.recruit__visual-text { width: calc( 950 / 1440 * 100%); margin: 30px auto 0 auto; padding: 0; color: #fff; box-sizing: border-box; }

@media screen and (max-width: 767px) { .recruit__visual-text { width: 100%; margin: 0 auto 0 auto; padding: 0 25px 25px 25px; } }

.recruit__visual-text .txt { margin: 0 auto 30px auto; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 1.6; text-align: center; }

@media screen and (max-width: 767px) { .recruit__visual-text .txt { text-align: left; display: block; } }

.recruit__visual-text .btn__primary { margin: 0 auto; background-color: #F57E26; color: #111; }

.recruit__visual-text .btn__primary:hover { background-color: #004B9E; color: #fff; }

.recruit__detail-wrap { max-width: 960px; margin: 80px auto 0 auto; padding: 0 0 0 0; }

@media screen and (max-width: 767px) { .recruit__detail-wrap { max-width: 345px; margin: 30px auto 0 auto; } }

.recruit__detail { max-width: 590px; margin: 0 auto; padding: 0; }

.recruit__detail-tit { margin: 0 auto 50px auto; padding: 0; font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "Noto Serif JP","MS P明朝", "MS PMincho", serif; font-size: 30px; font-size: 3rem; font-weight: bold; line-height: 1.2; text-align: center; }

@media screen and (max-width: 767px) { .recruit__detail-tit { margin: 0 auto 30px auto; } }

.recruit__detail-list { margin: 0 auto 50px auto; padding: 0; font-size: 20px; font-size: 2rem; line-height: 1.6; text-align: left; list-style: none; }

.recruit__detail-items { margin: 0 auto; padding: 0 0 0 1em; text-indent: -1em; }

.recruit__detail-undertxt { margin: 0 auto 100px auto; padding: 0 0 0 20px; text-align: left; font-size: 20px; font-size: 2rem; line-height: 1.6; }

@media screen and (max-width: 767px) { .recruit__detail-undertxt { text-align: left; margin: 0 auto 50px auto; } }

.recruit__btn-group { max-width: 960px; margin: 0 auto; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { .recruit__btn-group { max-width: 345px; -webkit-flex-direction: column; flex-direction: column; margin-bottom: 35px; } }

.recruit__btn-text { margin: 0 auto; padding: 0; text-align: center; display: -webkit-flex; display: flex; -webkit-flex-direction: column; flex-direction: column; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }

.recruit__btn-text span { margin: 0; padding: 0; }

.recruit__btn-text span:nth-child(1) { margin: 35px 0 auto 0; font-size: 24px; font-size: 2.4rem; line-height: 1.0; font-weight: bold; display: block; }

.recruit__btn-text span:nth-child(2) { font-size: 14px; font-size: 1.4rem; line-height: 1.6; text-align: left; display: block; }

.recruit__btn-type { width: 460px; min-height: 190px; margin: 0 auto 80px auto; padding: 50px 50px 50px 50px; border-radius: 5px; text-decoration: none; display: block; box-sizing: border-box; color: #fff; }

@media screen and (max-width: 767px) { .recruit__btn-type { width: 100%; margin-bottom: 15px; } }

.recruit__btn-type:hover { color: #fff; opacity: 0.8; }

.recruit__btn-type.db { background-color: #002B5A; }

.recruit__btn-type.b { background-color: #004B9E; }

.recruit__btn-type.disable { pointer-events: none; }

/* ========================================================================== news page css ========================================================================== */
/* news --------------------------- */
.news__wrap { margin: 0 auto; padding: 0; }

.news__list { max-width: 956px; margin: 100px auto 50px auto; padding: 0; transition: .5s; -webkit-animation: fadeIn .5s linear; animation: fadeIn .5s linear; }

@media screen and (max-width: 767px) { .news__list { max-width: calc( 345 / 375 * 100%); margin: 50px auto 25px auto; } }

.news__items { margin: 0; padding: 0; background-color: #EAEAEA; list-style: none; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }

@media screen and (max-width: 767px) { .news__items { -webkit-flex-direction: column; flex-direction: column; -webkit-align-items: flex-start; align-items: flex-start; } }

.news__items:nth-child(even) { background-color: #F8F8F8; }

.news__items span { padding: 10px 10px 10px 10px; box-sizing: border-box; }

.news__items span:nth-child(1) { min-width: 90px; font-size: 11px; font-size: 1.1rem; border-right: 2px solid #fff; }

@media screen and (max-width: 767px) { .news__items span:nth-child(1) { min-width: auto; border-right: none; border-bottom: 2px solid #fff; } }

.news__items span:nth-child(2) { font-size: 14px; font-size: 1.4rem; line-height: 1.6; }

.news__pager { max-width: 281px; margin: 0 auto 100px auto; padding: 0; }

@media screen and (max-width: 767px) { .news__pager { max-width: 345px; margin: 0 auto 80px auto; text-align: center; } }

.news__pager a { width: 100%; height: 100%; text-decoration: none; color: #004B9E; display: block; cursor: pointer; }

.news__pager .disabled { pointer-events: none; }

.news__pager .prev { min-width: 40px; min-height: 40px; line-height: 40px; margin: 0; padding: 0; font-size: 16px; font-size: 1.6rem; text-align: center; border-right: 1px solid #DDDDDD; }

.news__pager .next { min-width: 40px; min-height: 40px; line-height: 40px; margin: 0; padding: 0; font-size: 16px; font-size: 1.6rem; text-align: center; }

.news__pager-num { margin: 0; padding: 0; list-style: none; display: -webkit-inline-flex; display: inline-flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; border: 1px solid #DDDDDD; border-radius: 4px; }

.news__pager-item { min-width: 40px; min-height: 40px; line-height: 40px; margin: 0; padding: 0; font-size: 16px; font-size: 1.6rem; text-align: center; border-right: 1px solid #DDDDDD; }

.news__pager-item.active { background-color: #F57E26; color: #fff; }

.news__pager-item.active a { color: #fff; }

/* ========================================================================== privacy page css ========================================================================== */
/* privacy list --------------------------- */
.privacy__wrap { max-width: 100%; margin: 0 auto; padding: 100px 0 100px 0; box-sizing: border-box; }

@media screen and (max-width: 767px) { .privacy__wrap { padding: 20px 15px 30px 15px; } }

.privacy__text { max-width: 820px; margin: 0 auto 30px auto; padding: 0; color: #111; }

.privacy__text .tit { margin: 0 0 20px 0; padding: 0 0 10px 0; font-size: 14px; font-size: 1.4rem; line-height: 1.2; border-bottom: 1px solid #111; }

.privacy__text .txt { margin: 0; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 1.8; }

.privacy__text .list { margin: 20px 0 20px 1em; padding: 0; font-size: 14px; font-size: 1.4rem; line-height: 1.8; }

.privacy__text .list li { margin: 0; padding: 0 0 0 1em; text-indent: -1em; list-style: none; }

.privacy__text .child { margin-left: 2em; }

.privacy__btn { max-width: 820px; margin: 0 auto; padding: 0; }

@media screen and (max-width: 767px) { .privacy__btn .btn__secondary { margin: 0 auto; } }

/* ========================================================================== Helper classes ========================================================================== */
/* Hide visually and from screen readers */
.hidden { display: none !important; }

.pc-hidden { display: none; }

@media screen and (max-width: 320px) { .pc-hidden { display: none; } }

@media screen and (max-width: 767px) { .pc-hidden { display: block; } }

.sp-hidden { display: block; }

@media screen and (max-width: 767px) { .sp-hidden { display: none; } }

/* Hide only visually, but have it available for screen readers: https://snook.ca/archives/html_and_css/hiding-content-for-accessibility 1. For long content, line feeds are not interpreted as spaces and small width causes content to wrap 1 word per line: https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe */
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; white-space: nowrap; /* 1 */ }

.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; white-space: inherit; }

/* Extends the .visuallyhidden class to allow the element to be focusable when navigated to via the keyboard: https://www.drupal.org/node/897638 */
/* Hide visually and from screen readers, but maintain layout */
.invisible { visibility: hidden; }

/* Clearfix: contain floats For modern browsers 1. The space content is one way to avoid an Opera bug when the `contenteditable` attribute is included anywhere else in the document. Otherwise it causes space to appear at the top and bottom of elements that receive the `clearfix` class. 2. The use of `table` rather than `block` is only necessary if using `:before` to contain the top-margins of child elements. */
.clearfix:before { content: " "; /* 1 */ display: table; /* 2 */ }

.clearfix:after { content: " "; /* 1 */ display: table; /* 2 */ clear: both; }

/* ========================================================================== EXAMPLE Media Queries for Responsive Design. These examples override the primary ('mobile first') styles. Modify as content requires. ========================================================================== */
@media only screen and (min-width: 35em) { /* Style adjustments for viewports that meet the condition */ }

@media print, (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 1.25dppx), (min-resolution: 120dpi) { /* Style adjustments for high resolution devices */ }

/* ========================================================================== Print styles. Inlined to avoid the additional HTTP request: https://www.phpied.com/delay-loading-your-print-css/ ========================================================================== */
@media print { * { background: transparent !important; color: #000 !important; /* Black prints faster */ box-shadow: none !important; text-shadow: none !important; } *:before, *:after { background: transparent !important; color: #000 !important; /* Black prints faster */ box-shadow: none !important; text-shadow: none !important; } a { text-decoration: underline; } a:visited { text-decoration: underline; } a[href]:after { content: " (" attr(href) ")"; } abbr[title]:after { content: " (" attr(title) ")"; } /* Don't show links that are fragment identifiers, or use the `javascript:` pseudo protocol */ a[href^="#"]:after, a[href^="javascript:"]:after { content: ""; } pre { white-space: pre-wrap !important; border: 1px solid #999; page-break-inside: avoid; } blockquote { border: 1px solid #999; page-break-inside: avoid; } /* Printing Tables: http://css-discuss.incutio.com/wiki/Printing_Tables */ thead { display: table-header-group; } tr, img { page-break-inside: avoid; } p, h2, h3 { orphans: 3; widows: 3; } h2, h3 { page-break-after: avoid; } }
