@charset "utf-8";
/* up date 2016-12-01 */

.drawernavbar-header { display: none }
.sp { display: none; }

@media screen and (max-width: 767px) {
/*==============================================================*/
/* 各ページ共通 */
/*==============================================================*/
body { line-height: 1.5em; font-size: 12px; min-width: inherit; }
a { display: inline; }
.pc { display: none; }
.sp { display: block; margin: 0; }
.pad10LRsp { padding-left: 10px; padding-right: 10px; }
.pad10sp { padding: 10px!important; }
.mb10sp { margin-bottom: 10px!important; }
.mb20sp { margin-bottom: 20px!important; }
.mt10sp { margin-top: 10px!important; }
.mt20sp { margin-top: 20px!important; }
.clearSp { clear: both!important; }
.nonePc { display: block!important; }
.noneSp { display: none!important; }
.contentsWrap, .contentsWrap2 { margin: 0 auto; width: 96% }
/*==============================================================*/
/* header */
/*==============================================================*/
.drawernavbar-header { display: inherit; padding: 10px; height: 60px; width:100%; position:fixed; background:#fff;}
#header { z-index: 100; background: #fff;  box-sizing: border-box; height:60px;}
.drawer-brand img { height: auto; width: 40px; }
.drawer-brand span { display: inline-block; vertical-align: middle; color: #00226f; font-size: 12px; margin: 0 0 0 10px; font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif }
#headerIn { display: none; }
.js-hiraku-header-fixed { left: 0; top: 0; transition: margin-left 0.3s ease-in-out 0s; width: 100%; position: fixed; }
#drawerMenu .contact { margin: 10px; }
#drawerMenu .contact img { margin: 0 10px 2px 0; }
#drawerMenu .contact a { background: #5bcc90; padding: 10px 0; display: block; text-align: center; color: #fff; font-size: 14px; }
#drawerMenu .tel { margin: 0 10px 10px; font-size: 22px; text-align: center; }
#drawerMenu .tel img { margin: 0 10px 5px 0; }
/*ドロワーメニューリスト*/
#drawerMenu ul { margin: 0 0 10px; }
#drawerMenu li { letter-spacing: normal; vertical-align: top; }
#drawerMenu li a { background: #fff; display: block; text-decoration: none; border-bottom: 1px solid #eee; font-weight: bold; color: #00226f; padding: 10px 20px; box-sizing: border-box; transform: rotate(0.028deg); }
#drawerMenu li a::after { content: attr(data-text); display: block; font-size: 10px; }
#drawerMenu li a::before { display: block; font-size: 15px; content: '\f105'; font-family: FontAwesome; position: absolute; right: 20px; top: 38%; }
/**/
#drawerMenu p { display: inline-block; margin: 0 2% 0 3%; width: 46%; text-align: center; font-weight: bold; }
#drawerMenu p:first-child a { background: #00226f; color: #fff; text-decoration: none; display: block; border-radius: 5px; padding: 10px; }
#drawerMenu p:nth-child(2) a { background: #038356; color: #fff; text-decoration: none; display: block; border-radius: 5px; padding: 10px; }
#drawerMenu p:nth-child(2) { margin: 0; }
#drawerMenu i { display: block; font-size: 20px; margin: 0 0 5px; }
/*==============================================================*/
/* トップページ */
/*==============================================================*/
/*メインイメージ*/
#mainimg { height: auto; background: #ddd url(../../img/sp/sp-main.jpg) no-repeat center 0; background-size: 100%; overflow: inherit; padding: 100% 0 0; max-height: inherit; margin: 60px 0 0; }
#mainimg video { display: none; }
/*メニューボタン*/
.top-service { position: inherit; width: 100%; bottom: 0; }
.top-service li, .top-service li:last-child {  width: 30%; margin: 0 2% 0 0; }
.top-service ul{ width:100%;top: 330px; bottom:0;}
.top-service a:hover { opacity: 1; }
/**/
#top-contents { padding: 50px 0; }
#top-contents .contentsWrap > div { width: 100%; margin: 0 auto; float: none; }
#top-contents .catch { line-height: 1.5; font-size: 20px; margin: 0 0 10px; }
#top-contents .txt { margin: 0 0 20px; }
#top-contents .contentsWrap > p { float: none; margin: 0; }
#top-contents .contentsWrap > p img { display: block; margin: 0 auto; }
/*=====会社案内=====*/
#company { padding: 50px 0; }
#company .contentsWrap { width: 94%; }
#company .company { width: 100%; margin: 0 0 50px; height: auto; padding: 20px 20px 50px; box-sizing: border-box; }
#company .company h2 { width: 70%; display: inline-block; vertical-align: middle; }
#company .recruit { width: 100%; background-size: 100%; margin: 0 0 20px }
#company .logo { width: 25%; font-size: 10px; line-height: 1.2; display: inline-block; vertical-align: middle; }
#company .logo img { margin: 0 0 2px; }
#company address { margin: 0; width: 100%; }
#company address p:first-child { left: inherit; }
#company .map a { margin: 0 0 0 20px; }
#company .recruit a { padding: 120px 0 25px; }
#company .recruit p:first-child { padding: 20px; }
#company .btn a { padding-top: 10px; }
/*==============================================================*/
/* footer */
/*==============================================================*/
.footerIn { width: auto; margin: 0 auto; }
.footerIn ul, .footerIn address { display: none; }
#footer .bgGray { padding: 10px 5px; position: relative; z-index: 5; }
.footerIn .copy { display: block; margin: 0; letter-spacing: 0; line-height: 1.5; }
/*ページトップ*/
#pagetop { right: 10px; top: -50px; width: 100px; height: 50px; }
#pagetop a { background: #00226f; color: #fff; text-align: center; text-decoration: none; font-size: 12px; transform: skew(0deg, 0); display: block; padding: 25px 0 0; }
#pagetop a:hover { background: #274FAA; }
#pagetop span { display: block; transform: skew(0deg, 0); position: relative; }
#pagetop span:after { display: block; content: '\f106'; font-family: FontAwesome; position: relative; top: -38px; font-size: 18px; }
/*==============================================================*/
/* 下層ページ */
/*==============================================================*/
#page-headerbg { z-index: 9999; }
#page-headerbg #header { background: #fff; height: auto; position:fixed;}
/*タイトルエリア*/
#ttlArea { padding:60px 0 0;}
#ttlArea h2 { float: none; padding: 10px; margin: 10px 0; font-size: 20px; }
#breadcrumb { display: none; }
/**/
.ttl { font-size: 18px; margin-bottom:20px;}
/*==============================================================*/
/* 業務案内 */
/*==============================================================*/
#serviceMain { background-size: 200% auto; background-position: 40% top; height: 250px; }
#serviceSuggestion { padding: 90px 0 60px; margin-top: -60px; }
#serviceSuggestion .txt1 { width: auto; margin: 0 0 40px; }
#serviceSuggestion > p { float: none; }
#serviceSuggestion > p img { margin: 0 auto; display: block; }
#serviceSuggestion a { width:100%;}
#serviceSuggestion .mb50 { margin-bottom:30px !important;}
#serviceUtilization { background-size: cover; margin-top: -60px; padding-top: 50px; }
#serviceSuggestion .txt { margin-bottom:50px;}
#serviceConsultation h3 { font-size:20px;}
#serviceUtilization dl { float: none; width: 100%; margin: 0 0 30px; }
#serviceUtilization dl:nth-child(3), #serviceUtilization dl:nth-child(5) { margin: 0 0 30px; }
#serviceUtilization dt { padding: 5px; font-size: 16px; }
#serviceUtilization dt > span:first-child { padding: 5px 15px 5px 10px; }
#serviceUtilization dt > span { padding-left: 15px; }
#serviceUtilization dt > span:nth-child(2) { width:80%;}
#serviceUtilization dd { padding: 20px; }
#serviceConsultation .rightF { width:100%;}
#serviceConsultation .leftF { margin-bottom:20px;}
/*==============================================================*/
/* 会社案内 */
/*==============================================================*/
#companyMain { background-size: 260% auto; background-position: 40% top; height: 250px; }
#companyOverview { padding: 30px 0; }
#companyOverview th { padding: 10px; width: 30%; }
#companyOverview td { padding: 10px; }
#map_custmomize { height: 350px; }
#companyOverview h4 { font-size: 18px; }
#companyOverview .signature { margin:10px 0 40px; }

/*==============================================================*/
/* お問い合わせ */
/*==============================================================*/
#contactMain { background-position: 50% 35%; background-size: 206% auto; height: 250px; background-attachment:inherit;}
#contactContents { padding: 30px 0; }
#contactContents > p { font-size:18px; letter-spacing:0;}
#contactContents address { float: none; display: block; padding: 0 0 20px; }
#contactContents address p { display: block; margin: 0 auto; padding: 20px 20px 0; width: 94%; }
.mfp input, .mfp textarea { width: 100%; }
form#mailformpro dl dt:nth-of-type(odd) { background: #f6f7f9 !important; }
form#mailformpro dl dt { padding: 10px 5px; }
form#mailformpro input,form#mailformpro textarea { max-width:100%;}

/*==============================================================*/
/* 採用情報 */
/*==============================================================*/
#recruitMain { background-position: 60% top; background-size: 250% auto; padding: 0; height:auto; }
#recruitMain p { padding: 50px 2% 20px; }
#recruitMain p:last-child { padding: 0 2% 50px; }
#recruitOverview { padding: 30px 0; }
#recruitOverview .recruitwrap { width: 100%; margin: 0 auto 20px; }
#recruitOverview .recruitwrap:nth-child(2n) { margin: 0 auto 20px; }
#recruitOverview .txt { margin: 0 0 30px; text-align:left !important; font-size:14px;}
#recruitOverview .txt p { margin-bottom:20px;}
#recruitOverview .txt img:first-child { width:70%; max-width:406px;}
#recruitOverview h4 { font-size: 18px; }
#recruitOverview table {
    margin: 0 0 50px;}
#recruitOverview th { padding: 10px; width: 30%; }
#recruitOverview td { padding: 10px; }
#recruitOverview ul { width:auto; margin-bottom:30px;}
#recruitOverview li { padding:10px; font-size:16px;}
#recruitOverview li::before { margin:0 10px;}
#recruitOverview > p { font-size:14px; line-height:1.8;}
#recruitOverview .mb50 { margin-bottom:30px !important;}
.recruitcontact { margin-bottom:50px;}
.recruitcontact ul { width:100%;}
.recruitcontact p { font-size: 16px; margin: 0 0 10px; }
#recruitOverview .recruitcontact ul { width: 100%; margin: 0 0 50px; }
.recruitcontact li { font-size: 12px; line-height: 1; }
.recruitcontact li img { display: block; margin: 0 auto 5px; }
.recruitcontact li::after { top:30px;}
.policyList { margin: 0 auto 100px; }
}
