@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
v2.0 | 20110126
License: none (public domain)
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* グラデション */
.mt0 {
  margin-top: 0px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.mt1 {
  margin-top: 1px !important;
}

.mb1 {
  margin-bottom: 1px !important;
}

.pt1 {
  padding-top: 1px !important;
}

.pb1 {
  padding-bottom: 1px !important;
}

.mt2 {
  margin-top: 2px !important;
}

.mb2 {
  margin-bottom: 2px !important;
}

.pt2 {
  padding-top: 2px !important;
}

.pb2 {
  padding-bottom: 2px !important;
}

.mt3 {
  margin-top: 3px !important;
}

.mb3 {
  margin-bottom: 3px !important;
}

.pt3 {
  padding-top: 3px !important;
}

.pb3 {
  padding-bottom: 3px !important;
}

.mt4 {
  margin-top: 4px !important;
}

.mb4 {
  margin-bottom: 4px !important;
}

.pt4 {
  padding-top: 4px !important;
}

.pb4 {
  padding-bottom: 4px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.mt6 {
  margin-top: 6px !important;
}

.mb6 {
  margin-bottom: 6px !important;
}

.pt6 {
  padding-top: 6px !important;
}

.pb6 {
  padding-bottom: 6px !important;
}

.mt7 {
  margin-top: 7px !important;
}

.mb7 {
  margin-bottom: 7px !important;
}

.pt7 {
  padding-top: 7px !important;
}

.pb7 {
  padding-bottom: 7px !important;
}

.mt8 {
  margin-top: 8px !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

.pt8 {
  padding-top: 8px !important;
}

.pb8 {
  padding-bottom: 8px !important;
}

.mt9 {
  margin-top: 9px !important;
}

.mb9 {
  margin-bottom: 9px !important;
}

.pt9 {
  padding-top: 9px !important;
}

.pb9 {
  padding-bottom: 9px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.mt11 {
  margin-top: 11px !important;
}

.mb11 {
  margin-bottom: 11px !important;
}

.pt11 {
  padding-top: 11px !important;
}

.pb11 {
  padding-bottom: 11px !important;
}

.mt12 {
  margin-top: 12px !important;
}

.mb12 {
  margin-bottom: 12px !important;
}

.pt12 {
  padding-top: 12px !important;
}

.pb12 {
  padding-bottom: 12px !important;
}

.mt13 {
  margin-top: 13px !important;
}

.mb13 {
  margin-bottom: 13px !important;
}

.pt13 {
  padding-top: 13px !important;
}

.pb13 {
  padding-bottom: 13px !important;
}

.mt14 {
  margin-top: 14px !important;
}

.mb14 {
  margin-bottom: 14px !important;
}

.pt14 {
  padding-top: 14px !important;
}

.pb14 {
  padding-bottom: 14px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.mt16 {
  margin-top: 16px !important;
}

.mb16 {
  margin-bottom: 16px !important;
}

.pt16 {
  padding-top: 16px !important;
}

.pb16 {
  padding-bottom: 16px !important;
}

.mt17 {
  margin-top: 17px !important;
}

.mb17 {
  margin-bottom: 17px !important;
}

.pt17 {
  padding-top: 17px !important;
}

.pb17 {
  padding-bottom: 17px !important;
}

.mt18 {
  margin-top: 18px !important;
}

.mb18 {
  margin-bottom: 18px !important;
}

.pt18 {
  padding-top: 18px !important;
}

.pb18 {
  padding-bottom: 18px !important;
}

.mt19 {
  margin-top: 19px !important;
}

.mb19 {
  margin-bottom: 19px !important;
}

.pt19 {
  padding-top: 19px !important;
}

.pb19 {
  padding-bottom: 19px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.mt21 {
  margin-top: 21px !important;
}

.mb21 {
  margin-bottom: 21px !important;
}

.pt21 {
  padding-top: 21px !important;
}

.pb21 {
  padding-bottom: 21px !important;
}

.mt22 {
  margin-top: 22px !important;
}

.mb22 {
  margin-bottom: 22px !important;
}

.pt22 {
  padding-top: 22px !important;
}

.pb22 {
  padding-bottom: 22px !important;
}

.mt23 {
  margin-top: 23px !important;
}

.mb23 {
  margin-bottom: 23px !important;
}

.pt23 {
  padding-top: 23px !important;
}

.pb23 {
  padding-bottom: 23px !important;
}

.mt24 {
  margin-top: 24px !important;
}

.mb24 {
  margin-bottom: 24px !important;
}

.pt24 {
  padding-top: 24px !important;
}

.pb24 {
  padding-bottom: 24px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.mt26 {
  margin-top: 26px !important;
}

.mb26 {
  margin-bottom: 26px !important;
}

.pt26 {
  padding-top: 26px !important;
}

.pb26 {
  padding-bottom: 26px !important;
}

.mt27 {
  margin-top: 27px !important;
}

.mb27 {
  margin-bottom: 27px !important;
}

.pt27 {
  padding-top: 27px !important;
}

.pb27 {
  padding-bottom: 27px !important;
}

.mt28 {
  margin-top: 28px !important;
}

.mb28 {
  margin-bottom: 28px !important;
}

.pt28 {
  padding-top: 28px !important;
}

.pb28 {
  padding-bottom: 28px !important;
}

.mt29 {
  margin-top: 29px !important;
}

.mb29 {
  margin-bottom: 29px !important;
}

.pt29 {
  padding-top: 29px !important;
}

.pb29 {
  padding-bottom: 29px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.mt31 {
  margin-top: 31px !important;
}

.mb31 {
  margin-bottom: 31px !important;
}

.pt31 {
  padding-top: 31px !important;
}

.pb31 {
  padding-bottom: 31px !important;
}

.mt32 {
  margin-top: 32px !important;
}

.mb32 {
  margin-bottom: 32px !important;
}

.pt32 {
  padding-top: 32px !important;
}

.pb32 {
  padding-bottom: 32px !important;
}

.mt33 {
  margin-top: 33px !important;
}

.mb33 {
  margin-bottom: 33px !important;
}

.pt33 {
  padding-top: 33px !important;
}

.pb33 {
  padding-bottom: 33px !important;
}

.mt34 {
  margin-top: 34px !important;
}

.mb34 {
  margin-bottom: 34px !important;
}

.pt34 {
  padding-top: 34px !important;
}

.pb34 {
  padding-bottom: 34px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.mt36 {
  margin-top: 36px !important;
}

.mb36 {
  margin-bottom: 36px !important;
}

.pt36 {
  padding-top: 36px !important;
}

.pb36 {
  padding-bottom: 36px !important;
}

.mt37 {
  margin-top: 37px !important;
}

.mb37 {
  margin-bottom: 37px !important;
}

.pt37 {
  padding-top: 37px !important;
}

.pb37 {
  padding-bottom: 37px !important;
}

.mt38 {
  margin-top: 38px !important;
}

.mb38 {
  margin-bottom: 38px !important;
}

.pt38 {
  padding-top: 38px !important;
}

.pb38 {
  padding-bottom: 38px !important;
}

.mt39 {
  margin-top: 39px !important;
}

.mb39 {
  margin-bottom: 39px !important;
}

.pt39 {
  padding-top: 39px !important;
}

.pb39 {
  padding-bottom: 39px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.mt41 {
  margin-top: 41px !important;
}

.mb41 {
  margin-bottom: 41px !important;
}

.pt41 {
  padding-top: 41px !important;
}

.pb41 {
  padding-bottom: 41px !important;
}

.mt42 {
  margin-top: 42px !important;
}

.mb42 {
  margin-bottom: 42px !important;
}

.pt42 {
  padding-top: 42px !important;
}

.pb42 {
  padding-bottom: 42px !important;
}

.mt43 {
  margin-top: 43px !important;
}

.mb43 {
  margin-bottom: 43px !important;
}

.pt43 {
  padding-top: 43px !important;
}

.pb43 {
  padding-bottom: 43px !important;
}

.mt44 {
  margin-top: 44px !important;
}

.mb44 {
  margin-bottom: 44px !important;
}

.pt44 {
  padding-top: 44px !important;
}

.pb44 {
  padding-bottom: 44px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.mt46 {
  margin-top: 46px !important;
}

.mb46 {
  margin-bottom: 46px !important;
}

.pt46 {
  padding-top: 46px !important;
}

.pb46 {
  padding-bottom: 46px !important;
}

.mt47 {
  margin-top: 47px !important;
}

.mb47 {
  margin-bottom: 47px !important;
}

.pt47 {
  padding-top: 47px !important;
}

.pb47 {
  padding-bottom: 47px !important;
}

.mt48 {
  margin-top: 48px !important;
}

.mb48 {
  margin-bottom: 48px !important;
}

.pt48 {
  padding-top: 48px !important;
}

.pb48 {
  padding-bottom: 48px !important;
}

.mt49 {
  margin-top: 49px !important;
}

.mb49 {
  margin-bottom: 49px !important;
}

.pt49 {
  padding-top: 49px !important;
}

.pb49 {
  padding-bottom: 49px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

html {
  font-size: 62.5%;
}

body {
  font: normal normal normal 15px/1.5 "メイリオ", "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "Open Sans", sans-serif, osaka, Arial, Verdana, sans-serif;
  -webkit-font-feature-settings: "palt" !important;
          font-feature-settings: "palt" !important;
  -webkit-font-smoothing: antialiased !important;
  width: 100%;
  height: auto;
  color: #212426;
  font-weight: 500;
}

img {
  vertical-align: bottom;
}

#wrapper {
  position: relative;
  height: 100%;
  background: #fefefe;
  z-index: 4;
  overflow: hidden;
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media (max-width: 767px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
}
@media (max-width: 767px) {
  .sp-mt0 {
    margin-top: 0px !important;
  }
  .sp-mb0 {
    margin-bottom: 0px !important;
  }
  .sp-pt0 {
    padding-top: 0px !important;
  }
  .sp-pb0 {
    padding-bottom: 0px !important;
  }
  .sp-mt1 {
    margin-top: 1px !important;
  }
  .sp-mb1 {
    margin-bottom: 1px !important;
  }
  .sp-pt1 {
    padding-top: 1px !important;
  }
  .sp-pb1 {
    padding-bottom: 1px !important;
  }
  .sp-mt2 {
    margin-top: 2px !important;
  }
  .sp-mb2 {
    margin-bottom: 2px !important;
  }
  .sp-pt2 {
    padding-top: 2px !important;
  }
  .sp-pb2 {
    padding-bottom: 2px !important;
  }
  .sp-mt3 {
    margin-top: 3px !important;
  }
  .sp-mb3 {
    margin-bottom: 3px !important;
  }
  .sp-pt3 {
    padding-top: 3px !important;
  }
  .sp-pb3 {
    padding-bottom: 3px !important;
  }
  .sp-mt4 {
    margin-top: 4px !important;
  }
  .sp-mb4 {
    margin-bottom: 4px !important;
  }
  .sp-pt4 {
    padding-top: 4px !important;
  }
  .sp-pb4 {
    padding-bottom: 4px !important;
  }
  .sp-mt5 {
    margin-top: 5px !important;
  }
  .sp-mb5 {
    margin-bottom: 5px !important;
  }
  .sp-pt5 {
    padding-top: 5px !important;
  }
  .sp-pb5 {
    padding-bottom: 5px !important;
  }
  .sp-mt6 {
    margin-top: 6px !important;
  }
  .sp-mb6 {
    margin-bottom: 6px !important;
  }
  .sp-pt6 {
    padding-top: 6px !important;
  }
  .sp-pb6 {
    padding-bottom: 6px !important;
  }
  .sp-mt7 {
    margin-top: 7px !important;
  }
  .sp-mb7 {
    margin-bottom: 7px !important;
  }
  .sp-pt7 {
    padding-top: 7px !important;
  }
  .sp-pb7 {
    padding-bottom: 7px !important;
  }
  .sp-mt8 {
    margin-top: 8px !important;
  }
  .sp-mb8 {
    margin-bottom: 8px !important;
  }
  .sp-pt8 {
    padding-top: 8px !important;
  }
  .sp-pb8 {
    padding-bottom: 8px !important;
  }
  .sp-mt9 {
    margin-top: 9px !important;
  }
  .sp-mb9 {
    margin-bottom: 9px !important;
  }
  .sp-pt9 {
    padding-top: 9px !important;
  }
  .sp-pb9 {
    padding-bottom: 9px !important;
  }
  .sp-mt10 {
    margin-top: 10px !important;
  }
  .sp-mb10 {
    margin-bottom: 10px !important;
  }
  .sp-pt10 {
    padding-top: 10px !important;
  }
  .sp-pb10 {
    padding-bottom: 10px !important;
  }
  .sp-mt11 {
    margin-top: 11px !important;
  }
  .sp-mb11 {
    margin-bottom: 11px !important;
  }
  .sp-pt11 {
    padding-top: 11px !important;
  }
  .sp-pb11 {
    padding-bottom: 11px !important;
  }
  .sp-mt12 {
    margin-top: 12px !important;
  }
  .sp-mb12 {
    margin-bottom: 12px !important;
  }
  .sp-pt12 {
    padding-top: 12px !important;
  }
  .sp-pb12 {
    padding-bottom: 12px !important;
  }
  .sp-mt13 {
    margin-top: 13px !important;
  }
  .sp-mb13 {
    margin-bottom: 13px !important;
  }
  .sp-pt13 {
    padding-top: 13px !important;
  }
  .sp-pb13 {
    padding-bottom: 13px !important;
  }
  .sp-mt14 {
    margin-top: 14px !important;
  }
  .sp-mb14 {
    margin-bottom: 14px !important;
  }
  .sp-pt14 {
    padding-top: 14px !important;
  }
  .sp-pb14 {
    padding-bottom: 14px !important;
  }
  .sp-mt15 {
    margin-top: 15px !important;
  }
  .sp-mb15 {
    margin-bottom: 15px !important;
  }
  .sp-pt15 {
    padding-top: 15px !important;
  }
  .sp-pb15 {
    padding-bottom: 15px !important;
  }
  .sp-mt16 {
    margin-top: 16px !important;
  }
  .sp-mb16 {
    margin-bottom: 16px !important;
  }
  .sp-pt16 {
    padding-top: 16px !important;
  }
  .sp-pb16 {
    padding-bottom: 16px !important;
  }
  .sp-mt17 {
    margin-top: 17px !important;
  }
  .sp-mb17 {
    margin-bottom: 17px !important;
  }
  .sp-pt17 {
    padding-top: 17px !important;
  }
  .sp-pb17 {
    padding-bottom: 17px !important;
  }
  .sp-mt18 {
    margin-top: 18px !important;
  }
  .sp-mb18 {
    margin-bottom: 18px !important;
  }
  .sp-pt18 {
    padding-top: 18px !important;
  }
  .sp-pb18 {
    padding-bottom: 18px !important;
  }
  .sp-mt19 {
    margin-top: 19px !important;
  }
  .sp-mb19 {
    margin-bottom: 19px !important;
  }
  .sp-pt19 {
    padding-top: 19px !important;
  }
  .sp-pb19 {
    padding-bottom: 19px !important;
  }
  .sp-mt20 {
    margin-top: 20px !important;
  }
  .sp-mb20 {
    margin-bottom: 20px !important;
  }
  .sp-pt20 {
    padding-top: 20px !important;
  }
  .sp-pb20 {
    padding-bottom: 20px !important;
  }
  .sp-mt21 {
    margin-top: 21px !important;
  }
  .sp-mb21 {
    margin-bottom: 21px !important;
  }
  .sp-pt21 {
    padding-top: 21px !important;
  }
  .sp-pb21 {
    padding-bottom: 21px !important;
  }
  .sp-mt22 {
    margin-top: 22px !important;
  }
  .sp-mb22 {
    margin-bottom: 22px !important;
  }
  .sp-pt22 {
    padding-top: 22px !important;
  }
  .sp-pb22 {
    padding-bottom: 22px !important;
  }
  .sp-mt23 {
    margin-top: 23px !important;
  }
  .sp-mb23 {
    margin-bottom: 23px !important;
  }
  .sp-pt23 {
    padding-top: 23px !important;
  }
  .sp-pb23 {
    padding-bottom: 23px !important;
  }
  .sp-mt24 {
    margin-top: 24px !important;
  }
  .sp-mb24 {
    margin-bottom: 24px !important;
  }
  .sp-pt24 {
    padding-top: 24px !important;
  }
  .sp-pb24 {
    padding-bottom: 24px !important;
  }
  .sp-mt25 {
    margin-top: 25px !important;
  }
  .sp-mb25 {
    margin-bottom: 25px !important;
  }
  .sp-pt25 {
    padding-top: 25px !important;
  }
  .sp-pb25 {
    padding-bottom: 25px !important;
  }
  .sp-mt26 {
    margin-top: 26px !important;
  }
  .sp-mb26 {
    margin-bottom: 26px !important;
  }
  .sp-pt26 {
    padding-top: 26px !important;
  }
  .sp-pb26 {
    padding-bottom: 26px !important;
  }
  .sp-mt27 {
    margin-top: 27px !important;
  }
  .sp-mb27 {
    margin-bottom: 27px !important;
  }
  .sp-pt27 {
    padding-top: 27px !important;
  }
  .sp-pb27 {
    padding-bottom: 27px !important;
  }
  .sp-mt28 {
    margin-top: 28px !important;
  }
  .sp-mb28 {
    margin-bottom: 28px !important;
  }
  .sp-pt28 {
    padding-top: 28px !important;
  }
  .sp-pb28 {
    padding-bottom: 28px !important;
  }
  .sp-mt29 {
    margin-top: 29px !important;
  }
  .sp-mb29 {
    margin-bottom: 29px !important;
  }
  .sp-pt29 {
    padding-top: 29px !important;
  }
  .sp-pb29 {
    padding-bottom: 29px !important;
  }
  .sp-mt30 {
    margin-top: 30px !important;
  }
  .sp-mb30 {
    margin-bottom: 30px !important;
  }
  .sp-pt30 {
    padding-top: 30px !important;
  }
  .sp-pb30 {
    padding-bottom: 30px !important;
  }
  .sp-mt31 {
    margin-top: 31px !important;
  }
  .sp-mb31 {
    margin-bottom: 31px !important;
  }
  .sp-pt31 {
    padding-top: 31px !important;
  }
  .sp-pb31 {
    padding-bottom: 31px !important;
  }
  .sp-mt32 {
    margin-top: 32px !important;
  }
  .sp-mb32 {
    margin-bottom: 32px !important;
  }
  .sp-pt32 {
    padding-top: 32px !important;
  }
  .sp-pb32 {
    padding-bottom: 32px !important;
  }
  .sp-mt33 {
    margin-top: 33px !important;
  }
  .sp-mb33 {
    margin-bottom: 33px !important;
  }
  .sp-pt33 {
    padding-top: 33px !important;
  }
  .sp-pb33 {
    padding-bottom: 33px !important;
  }
  .sp-mt34 {
    margin-top: 34px !important;
  }
  .sp-mb34 {
    margin-bottom: 34px !important;
  }
  .sp-pt34 {
    padding-top: 34px !important;
  }
  .sp-pb34 {
    padding-bottom: 34px !important;
  }
  .sp-mt35 {
    margin-top: 35px !important;
  }
  .sp-mb35 {
    margin-bottom: 35px !important;
  }
  .sp-pt35 {
    padding-top: 35px !important;
  }
  .sp-pb35 {
    padding-bottom: 35px !important;
  }
  .sp-mt36 {
    margin-top: 36px !important;
  }
  .sp-mb36 {
    margin-bottom: 36px !important;
  }
  .sp-pt36 {
    padding-top: 36px !important;
  }
  .sp-pb36 {
    padding-bottom: 36px !important;
  }
  .sp-mt37 {
    margin-top: 37px !important;
  }
  .sp-mb37 {
    margin-bottom: 37px !important;
  }
  .sp-pt37 {
    padding-top: 37px !important;
  }
  .sp-pb37 {
    padding-bottom: 37px !important;
  }
  .sp-mt38 {
    margin-top: 38px !important;
  }
  .sp-mb38 {
    margin-bottom: 38px !important;
  }
  .sp-pt38 {
    padding-top: 38px !important;
  }
  .sp-pb38 {
    padding-bottom: 38px !important;
  }
  .sp-mt39 {
    margin-top: 39px !important;
  }
  .sp-mb39 {
    margin-bottom: 39px !important;
  }
  .sp-pt39 {
    padding-top: 39px !important;
  }
  .sp-pb39 {
    padding-bottom: 39px !important;
  }
  .sp-mt40 {
    margin-top: 40px !important;
  }
  .sp-mb40 {
    margin-bottom: 40px !important;
  }
  .sp-pt40 {
    padding-top: 40px !important;
  }
  .sp-pb40 {
    padding-bottom: 40px !important;
  }
  .sp-mt41 {
    margin-top: 41px !important;
  }
  .sp-mb41 {
    margin-bottom: 41px !important;
  }
  .sp-pt41 {
    padding-top: 41px !important;
  }
  .sp-pb41 {
    padding-bottom: 41px !important;
  }
  .sp-mt42 {
    margin-top: 42px !important;
  }
  .sp-mb42 {
    margin-bottom: 42px !important;
  }
  .sp-pt42 {
    padding-top: 42px !important;
  }
  .sp-pb42 {
    padding-bottom: 42px !important;
  }
  .sp-mt43 {
    margin-top: 43px !important;
  }
  .sp-mb43 {
    margin-bottom: 43px !important;
  }
  .sp-pt43 {
    padding-top: 43px !important;
  }
  .sp-pb43 {
    padding-bottom: 43px !important;
  }
  .sp-mt44 {
    margin-top: 44px !important;
  }
  .sp-mb44 {
    margin-bottom: 44px !important;
  }
  .sp-pt44 {
    padding-top: 44px !important;
  }
  .sp-pb44 {
    padding-bottom: 44px !important;
  }
  .sp-mt45 {
    margin-top: 45px !important;
  }
  .sp-mb45 {
    margin-bottom: 45px !important;
  }
  .sp-pt45 {
    padding-top: 45px !important;
  }
  .sp-pb45 {
    padding-bottom: 45px !important;
  }
  .sp-mt46 {
    margin-top: 46px !important;
  }
  .sp-mb46 {
    margin-bottom: 46px !important;
  }
  .sp-pt46 {
    padding-top: 46px !important;
  }
  .sp-pb46 {
    padding-bottom: 46px !important;
  }
  .sp-mt47 {
    margin-top: 47px !important;
  }
  .sp-mb47 {
    margin-bottom: 47px !important;
  }
  .sp-pt47 {
    padding-top: 47px !important;
  }
  .sp-pb47 {
    padding-bottom: 47px !important;
  }
  .sp-mt48 {
    margin-top: 48px !important;
  }
  .sp-mb48 {
    margin-bottom: 48px !important;
  }
  .sp-pt48 {
    padding-top: 48px !important;
  }
  .sp-pb48 {
    padding-bottom: 48px !important;
  }
  .sp-mt49 {
    margin-top: 49px !important;
  }
  .sp-mb49 {
    margin-bottom: 49px !important;
  }
  .sp-pt49 {
    padding-top: 49px !important;
  }
  .sp-pb49 {
    padding-bottom: 49px !important;
  }
  .sp-mt50 {
    margin-top: 50px !important;
  }
  .sp-mb50 {
    margin-bottom: 50px !important;
  }
  .sp-pt50 {
    padding-top: 50px !important;
  }
  .sp-pb50 {
    padding-bottom: 50px !important;
  }
}
.contact p, footer .footer-contact, footer .footer-contact .flex-wrap .footer-bt, footer .footer-add .inner p, footer .footer-menu .sec-box.footer-menu-block > ul > li a, .section {
  letter-spacing: 0.4px;
  font-family: "UD Shin Go Regular JIS2004", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "meiryo", "Helvetica Neue", "arial", sans-serif;
  font-size: 15px;
  line-height: 1.8;
  -webkit-font-feature-settings: "palt" !important;
          font-feature-settings: "palt" !important;
  -webkit-font-smoothing: antialiased !important;
  letter-spacing: 0.08em;
}

.main-title h1, .sec__r h2, .business h4, .recruit .voice_photo .voice_title_area .voice_title_area_inner p.voice__pickup, .recruit .voice_photo .voice_title_area .voice_title_area_inner p.voice__title, .recruit p.font20, .company .message .sec__inner p,
.company .message .sec__inner h3, .company .message .sec__inner p.company_catch,
.company .message .sec__inner h3.company_catch, .company .groups_wrap .groups_name, .company .font20, .navi-area nav.pc ul a, h1,
h2,
h3,
h4,
h5,
h6 {
  letter-spacing: 0.4px;
  font-family: "UD Shin Go DemiBold JIS2004", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "meiryo", "Helvetica Neue", "arial", sans-serif;
  font-size: 15px;
  line-height: 1.8;
  -webkit-font-feature-settings: "palt" !important;
          font-feature-settings: "palt" !important;
  -webkit-font-smoothing: antialiased !important;
  letter-spacing: 0.08em;
}

.flex-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media (max-width: 767px) {
  .flex-wrap {
    display: block;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: 0.1em;
}

h2 {
  font-size: 30px;
  font-size: 3rem;
}
@media (max-width: 767px) {
  h2 {
    font-size: 20px;
    font-size: 2rem;
  }
}

h3 {
  padding: 0 0.5em;
  font-size: 24px;
  font-size: 2.4rem;
  border-left: solid 8px #0378a6;
  text-align: left;
}
@media (max-width: 767px) {
  h3 {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

h4 {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  color: #0378a6;
  margin-bottom: 0.8em;
}
@media (max-width: 767px) {
  h4 {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

h5 {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
}
@media (max-width: 767px) {
  h5 {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

h6 {
  font-size: 15px;
  font-size: 1.5rem;
}
@media (max-width: 767px) {
  h6 {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

img {
  max-width: 100%;
}

.sec-txt {
  line-height: 1.8;
  letter-spacing: 0.1em;
}

.indent, .list__round li {
  padding-left: 1em;
  text-indent: -1em;
}

.section {
  margin: 30px auto auto auto;
  text-align: center;
}

.sec-txt {
  font-size: 15px;
  font-size: 1.5rem;
}

a:hover, a:hover img {
  text-decoration: none;
}

a:hover {
  color: rgba(218, 21, 58, 0.2);
}

/*!
 * jquery-drawer v3.2.2
 * Flexible drawer menu using jQuery, iScroll and CSS.
 * http://git.blivesta.com/drawer
 * License : MIT
 * Author : blivesta <design@blivesta.com> (http://blivesta.com/)
 */
/*!------------------------------------*\
    Base
\*!------------------------------------*/
.drawer-open {
  overflow: hidden !important;
}

.drawer-nav {
  position: fixed;
  z-index: 101;
  top: 0;
  overflow: hidden;
  width: 16.25rem;
  height: 100%;
  color: #222;
  background-color: #fff;
}

.drawer-brand {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 3.75rem;
  display: block;
  padding-right: 0.75rem;
  padding-left: 0.75rem;
  text-decoration: none;
  color: #222;
}

.drawer-menu {
  margin: 0;
  padding: 0;
  list-style: none;
}

.drawer-menu-item {
  font-size: 1rem;
  display: block;
  padding: 0.75rem;
  text-decoration: none;
  color: #222;
}

.drawer-menu-item:hover {
  text-decoration: underline;
  color: #555;
  background-color: transparent;
}

/*! overlay */
.drawer-overlay {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}

.drawer-open .drawer-overlay {
  display: block;
}

/*!------------------------------------*\
    Top
\*!------------------------------------*/
.drawer--top .drawer-nav {
  top: -100%;
  left: 0;
  width: 100%;
  height: auto;
  max-height: 100%;
  -webkit-transition: top 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: top 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.drawer--top.drawer-open .drawer-nav {
  top: 0;
}

.drawer--top .drawer-hamburger,
.drawer--top.drawer-open .drawer-hamburger {
  right: 0;
}

/*!------------------------------------*\
    Left
\*!------------------------------------*/
.drawer--left .drawer-nav {
  left: -16.25rem;
  -webkit-transition: left 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: left 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.drawer--left.drawer-open .drawer-nav,
.drawer--left .drawer-hamburger,
.drawer--left.drawer-open .drawer-navbar .drawer-hamburger {
  left: 0;
}

.drawer--left.drawer-open .drawer-hamburger {
  left: 16.25rem;
}

/*!------------------------------------*\
    Right
\*!------------------------------------*/
.drawer--right .drawer-nav {
  right: -16.25rem;
  -webkit-transition: right 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: right 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.drawer--right.drawer-open .drawer-nav,
.drawer--right .drawer-hamburger,
.drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
  right: 0;
}

.drawer--right.drawer-open .drawer-hamburger {
  right: 16.25rem;
}

/*!------------------------------------*\
    Hamburger
\*!------------------------------------*/
.drawer-hamburger {
  position: fixed;
  z-index: 104;
  top: 0;
  display: block;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  width: 2rem;
  padding: 0;
  padding-top: 18px;
  padding-right: 0.75rem;
  padding-bottom: 30px;
  padding-left: 0.75rem;
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  border: 0;
  outline: 0;
  background-color: transparent;
}

.drawer-hamburger:hover {
  cursor: pointer;
  background-color: transparent;
}

.drawer-hamburger-icon {
  position: relative;
  display: block;
  margin-top: 10px;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  width: 100%;
  height: 2px;
  -webkit-transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  background-color: #222;
}

.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  position: absolute;
  top: -10px;
  left: 0;
  content: " ";
}

.drawer-hamburger-icon:after {
  top: 10px;
}

.drawer-open .drawer-hamburger-icon {
  background-color: transparent;
}

.drawer-open .drawer-hamburger-icon:before,
.drawer-open .drawer-hamburger-icon:after {
  top: 0;
}

.drawer-open .drawer-hamburger-icon:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.drawer-open .drawer-hamburger-icon:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

/*!------------------------------------*\
    accessibility
\*!------------------------------------*/
/*!
 * Only display content to screen readers
 * See: http://a11yproject.com/posts/how-to-hide-content
 */
.sr-only {
  position: absolute;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
}

/*!
 * Use in conjunction with .sr-only to only display content when it's focused.
 * Useful for "Skip to main content" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1
 * Credit: HTML5 Boilerplate
 */
.sr-only-focusable:active,
.sr-only-focusable:focus {
  position: static;
  overflow: visible;
  clip: auto;
  width: auto;
  height: auto;
  margin: 0;
}

/*!------------------------------------*\
    Sidebar
\*!------------------------------------*/
.drawer--sidebar {
  background-color: #fff;
}

.drawer--sidebar .drawer-contents {
  background-color: #fff;
}

@media (min-width: 64em) {
  .drawer--sidebar .drawer-hamburger {
    display: none;
    visibility: hidden;
  }
  .drawer--sidebar .drawer-nav {
    display: block;
    -webkit-transform: none;
    transform: none;
    position: fixed;
    width: 12.5rem;
    height: 100%;
  }
  /*! Left */
  .drawer--sidebar.drawer--left .drawer-nav {
    left: 0;
    border-right: 1px solid #ddd;
  }
  .drawer--sidebar.drawer--left .drawer-contents {
    margin-left: 12.5rem;
  }
  /*! Right */
  .drawer--sidebar.drawer--right .drawer-nav {
    right: 0;
    border-left: 1px solid #ddd;
  }
  .drawer--sidebar.drawer--right .drawer-contents {
    margin-right: 12.5rem;
  }
  /*! container */
  .drawer--sidebar .drawer-container {
    max-width: 48rem;
  }
}
@media (min-width: 75em) {
  .drawer--sidebar .drawer-nav {
    width: 16.25rem;
  }
  .drawer--sidebar.drawer--left .drawer-contents {
    margin-left: 16.25rem;
  }
  .drawer--sidebar.drawer--right .drawer-contents {
    margin-right: 16.25rem;
  }
  /*! container */
  .drawer--sidebar .drawer-container {
    max-width: 60rem;
  }
}
/*!------------------------------------*\
    Navbar
\*!------------------------------------*/
.drawer--navbarTopGutter {
  padding-top: 3.75rem;
}

.drawer-navbar .drawer-navbar-header {
  border-bottom: 1px solid #ddd;
  background-color: #fff;
}

.drawer-navbar {
  z-index: 102;
  top: 0;
  width: 100%;
}

/*! .drawer-navbar modifier */
.drawer-navbar--fixed {
  position: fixed;
}

.drawer-navbar-header {
  position: relative;
  z-index: 102;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  height: 3.75rem;
  padding: 0 0.75rem;
  text-align: center;
}

.drawer-navbar .drawer-brand {
  line-height: 3.75rem;
  display: inline-block;
  padding-top: 0;
  padding-bottom: 0;
  text-decoration: none;
}

.drawer-navbar .drawer-brand:hover {
  background-color: transparent;
}

.drawer-navbar .drawer-nav {
  padding-top: 3.75rem;
}

.drawer-navbar .drawer-menu {
  padding-bottom: 7.5rem;
}

@media (min-width: 64em) {
  .drawer-navbar {
    height: 3.75rem;
    border-bottom: 1px solid #ddd;
    background-color: #fff;
  }
  .drawer-navbar .drawer-navbar-header {
    position: relative;
    display: block;
    float: left;
    width: auto;
    padding: 0;
    border: 0;
  }
  .drawer-navbar .drawer-menu--right {
    float: right;
  }
  .drawer-navbar .drawer-menu li {
    float: left;
  }
  .drawer-navbar .drawer-menu-item {
    line-height: 3.75rem;
    padding-top: 0;
    padding-bottom: 0;
  }
  .drawer-navbar .drawer-hamburger {
    display: none;
  }
  .drawer-navbar .drawer-nav {
    position: relative;
    left: 0;
    overflow: visible;
    width: auto;
    height: 3.75rem;
    padding-top: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  .drawer-navbar .drawer-menu {
    padding: 0;
  }
  /*! dropdown */
  .drawer-navbar .drawer-dropdown-menu {
    position: absolute;
    width: 16.25rem;
    border: 1px solid #ddd;
  }
  .drawer-navbar .drawer-dropdown-menu-item {
    padding-left: 0.75rem;
  }
}
/*!------------------------------------*\
    Dropdown
\*!------------------------------------*/
.drawer-dropdown-menu {
  display: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0;
  background-color: #fff;
}

.drawer-dropdown-menu > li {
  width: 100%;
  list-style: none;
}

.drawer-dropdown-menu-item {
  line-height: 3.75rem;
  display: block;
  padding: 0;
  padding-right: 0.75rem;
  padding-left: 1.5rem;
  text-decoration: none;
  color: #222;
}

.drawer-dropdown-menu-item:hover {
  text-decoration: underline;
  color: #555;
  background-color: transparent;
}

/*! open */
.drawer-dropdown.open > .drawer-dropdown-menu {
  display: block;
}

/*! drawer-caret */
.drawer-dropdown .drawer-caret {
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: 4px;
  -webkit-transition: opacity 0.2s ease, -webkit-transform 0.2s ease;
  transition: opacity 0.2s ease, -webkit-transform 0.2s ease;
  transition: transform 0.2s ease, opacity 0.2s ease;
  transition: transform 0.2s ease, opacity 0.2s ease, -webkit-transform 0.2s ease;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  vertical-align: middle;
  border-top: 4px solid;
  border-right: 4px solid transparent;
  border-left: 4px solid transparent;
}

/*! open */
.drawer-dropdown.open .drawer-caret {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

/*!------------------------------------*\
    Container
\*!------------------------------------*/
.drawer-container {
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 64em) {
  .drawer-container {
    max-width: 60rem;
  }
}
@media (min-width: 75em) {
  .drawer-container {
    max-width: 70rem;
  }
}
header {
  height: 90px;
  position: fixed;
  z-index: 9998;
  width: 100%;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(28%, #fff), color-stop(60%, #fff), to(rgba(255, 255, 255, 0.88)));
  background-image: linear-gradient(180deg, #fff 28%, #fff 60%, rgba(255, 255, 255, 0.88) 100%);
  -webkit-box-shadow: 0px 2px 20px 0px rgba(1, 0, 26, 0.07);
  box-shadow: 0px 2px 20px 0px rgba(1, 0, 26, 0.07);
}
@media (max-width: 767px) {
  header {
    height: 70px;
  }
}
header .header-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 767px) {
  header .header-wrap {
    height: 70px;
    width: 100%;
  }
}
header .header-wrap .header_logo img {
  width: 230px;
}
header .header-wrap .inner {
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 767px) {
  header .header-wrap .inner {
    display: none;
  }
}
header .header-wrap .header-tel {
  margin-right: 130px;
}
header .header-wrap .header-tel img {
  width: 233px;
}
@media (max-width: 767px) {
  header .header-wrap .header-tel {
    display: none;
  }
}
header .bt-header-contact {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 9999;
}
header .bt-header-contact a {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-image: -webkit-gradient(linear, left top, right top, from(#0378A6), to(#12B2F1));
  background-image: linear-gradient(90deg, #0378A6 0%, #12B2F1 100%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: height 150ms cubic-bezier(0.165, 0.84, 0.44, 1), width 150ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: height 150ms cubic-bezier(0.165, 0.84, 0.44, 1), width 150ms cubic-bezier(0.165, 0.84, 0.44, 1);
  overflow: hidden;
  position: relative;
  height: 130px;
  width: 130px;
  color: #fff;
}
header .bt-header-contact a:before {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  content: "";
  display: inline-block;
  vertical-align: middle;
  background-image: -webkit-gradient(linear, left top, right top, from(#0096D1), to(#9DE0FA));
  background-image: linear-gradient(90deg, #0096D1 0%, #9DE0FA 100%);
  opacity: 0;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-transition: opacity 150ms cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform 150ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: opacity 150ms cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform 150ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: opacity 150ms cubic-bezier(0.165, 0.84, 0.44, 1), transform 150ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: opacity 150ms cubic-bezier(0.165, 0.84, 0.44, 1), transform 150ms cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform 150ms cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transform: translateX(-150px);
  transform: translateX(-150px);
  height: 100%;
  width: 100%;
  z-index: 1;
}
header .bt-header-contact a:hover {
  color: #fff;
  text-decoration: none;
}
header .bt-header-contact a:hover:before {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
header .bt-header-contact a span {
  font-weight: 600;
  line-height: 1;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  z-index: 9;
}
header .bt-header-contact a span:before {
  font-family: "Material Icons";
  content: "\e0be";
  display: inline-block;
  vertical-align: middle;
  color: #fff;
  padding-bottom: 8px;
}
@media (max-width: 767px) {
  header .bt-header-contact {
    display: none;
  }
}

footer {
  background-color: #03588c;
  margin-top: 80px;
  color: #fff;
  position: relative;
}
footer a.bt-wh span:before {
  color: #fff;
  font-family: "Material Icons";
  content: "\e0be";
  display: inline-block;
  color: #fff;
  padding-right: 8px;
}
footer a.bt-wh span:hover:before {
  color: #03588c;
}
footer a:hover {
  text-decoration: none;
}
footer .footer-contact {
  background: #0378a6;
  background: -webkit-gradient(linear, left top, right top, color-stop(52%, #0378a6), to(#12b2f1));
  background: linear-gradient(to right, #0378a6 52%, #12b2f1 100%);
  padding: 20px 0px;
  font-size: 20px;
  font-size: 2rem;
}
@media (max-width: 767px) {
  footer .footer-contact {
    padding: 20px 0px 55px 0px;
  }
}
footer .footer-contact .flex-wrap {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 767px) {
  footer .footer-contact .flex-wrap {
    text-align: center;
  }
}
footer .footer-contact .flex-wrap .footer-bt {
  margin-left: auto;
}
@media (max-width: 767px) {
  footer .footer-contact .flex-wrap .footer-bt {
    margin-top: 10px;
  }
}
footer .footer-add .inner.flex-wrap {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
footer .footer-add .inner p.comp-name {
  border: solid 1px #fff;
  padding: 3px;
  margin-right: 10px;
}
footer .footer-add .inner p a {
  color: #fff;
  text-decoration: none;
}
footer .footer-menu {
  padding: 30px 0px;
  border-bottom: solid 1px #bfbfbf;
}
@media (max-width: 767px) {
  footer .footer-menu {
    padding: 55px 0px 20px 0px;
  }
}
@media (max-width: 767px) {
  footer .footer-menu .sec-box.footer-add {
    text-align: center;
  }
  footer .footer-menu .sec-box.footer-add .comp-name {
    margin-bottom: 10px;
  }
}
footer .footer-menu .sec-box.footer-menu-block {
  -webkit-box-flex: 2;
      -ms-flex: 2;
          flex: 2;
}
@media (max-width: 767px) {
  footer .footer-menu .sec-box.footer-menu-block {
    display: none;
  }
}
footer .footer-menu .sec-box.footer-menu-block > ul {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
footer .footer-menu .sec-box.footer-menu-block > ul > li a {
  font-weight: 600;
  color: #fff;
}
footer .footer-menu .sec-box.footer-menu-block > ul > li ul li a {
  font-size: 12px;
  line-height: 1;
  color: #fff;
  -webkit-transition: color 200ms;
  transition: color 200ms;
}
footer .footer-menu .sec-box.footer-menu-block > ul > li ul li a:before {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  content: "";
  display: inline-block;
  vertical-align: middle;
  background-color: #fff;
  margin-right: 10px;
  height: 1px;
  width: 5px;
}

.copylight {
  text-align: center;
  font-size: 10px;
  font-size: 1rem;
  padding: 10px 0px;
}

a {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  -webkit-transition: 0.2s ease-in;
  text-decoration: none;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  cursor: pointer;
  position: relative;
  color: #03588C;
}
a img {
  opacity: 1;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
a:hover {
  color: rgba(218, 21, 58, 0.2);
  text-decoration: none;
}
a:hover img {
  opacity: 0.5;
  text-decoration: none;
}
a.bt-wh, a.bt-bl {
  border-radius: 3px;
}
a.bt-bl {
  position: relative;
  display: inline-block;
  padding: 0.5em 4em;
  border: 1px solid #0378a6;
  color: #0378a6;
  text-align: center;
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background-color: #fff;
}
a.bt-bl:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: "";
  background: #0378a6;
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
a.bt-bl:hover {
  color: #fff;
}
a.bt-bl:hover:before {
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
a.bt-wh {
  position: relative;
  display: inline-block;
  padding: 0.5em 4em;
  border: 1px solid #fff;
  color: #fff;
  text-align: center;
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
a.bt-wh:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: "";
  background: #fff;
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
a.bt-wh:hover {
  color: #0378a6;
}
a.bt-wh:hover:before {
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}

.btarea {
  padding: 0 20px;
}

#pageTop {
  position: absolute;
  bottom: 50px;
  right: 20px;
  cursor: pointer;
}
@media (max-width: 767px) {
  #pageTop {
    position: absolute;
    left: 53%;
    bottom: 50%;
    right: inherit;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    margin: auto;
  }
}
#pageTop .line {
  position: absolute;
  top: 30px;
  left: 0;
  display: block;
  width: 1px;
  height: 45px;
  background-color: #FFF;
  -webkit-animation: line_to_left 2s cubic-bezier(0.04, 0.435, 0.315, 0.9) infinite;
  animation: line_to_left 2s cubic-bezier(0.04, 0.435, 0.315, 0.9) infinite;
}

@-webkit-keyframes line_up {
  0% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: bottom center;
    transform-origin: bottom center;
  }
  50% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: bottom center;
    transform-origin: bottom center;
  }
  51% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top center;
    transform-origin: top center;
  }
  to {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top center;
    transform-origin: top center;
  }
}

@keyframes line_up {
  0% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: bottom center;
    transform-origin: bottom center;
  }
  50% {
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-transform-origin: bottom center;
    transform-origin: bottom center;
  }
  51% {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top center;
    transform-origin: top center;
  }
  to {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    -webkit-transform-origin: top center;
    transform-origin: top center;
  }
}
.bg-gray {
  background-color: #f2f2f2;
  padding: 60px 0px;
}
@media (max-width: 767px) {
  .bg-gray {
    padding: 30px 0px;
  }
}

.r_bg_wh {
  background-color: #fff;
  border-radius: 5px;
}

.table-side {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  text-align: left;
  border: solid 1px #bfbfbf;
}

.table-side tr {
  border-bottom: solid 1px #bfbfbf;
}
.table-side tr:first-child {
  border-top: solid 1px #bfbfbf;
}

.table-side th,
.table-side td {
  text-align: center;
  padding: 15px;
  border-right: solid 1px #bfbfbf;
}
@media (max-width: 767px) {
  .table-side th,
  .table-side td {
    display: block;
    border-style: none;
  }
}

.table-side td {
  text-align: left;
}

.table-side th {
  background-color: #0378a6;
  color: #fff;
}

table {
  max-width: 100%;
  width: 100%;
}
table.table__bl {
  color: #0378a6;
}
table.table__bl th {
  font-weight: bold;
  width: 20%;
}
table.table__bl th, table.table__bl td {
  padding: 10px;
  border: 1px solid #0378a6;
  color: #03588c;
  vertical-align: middle;
  margin-bottom: 3px;
  font-size: 13px;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
}
.cp_breadcrumb *,
.cp_breadcrumb *:after,
.cp_breadcrumb *:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.cp_breadcrumb {
  margin: 1em auto;
  background-color: #fff;
}
@media (max-width: 767px) {
  .cp_breadcrumb {
    margin-top: -18px;
  }
}

.cp_breadcrumb a {
  text-decoration: none;
  color: #03588C;
}

.cp_breadcrumb .breadcrumbs {
  padding-left: 0;
  margin-top: 0;
  margin-bottom: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (max-width: 767px) {
  .cp_breadcrumb .breadcrumbs {
    padding: 5px;
  }
}

.cp_breadcrumb li {
  display: inline-block;
  position: relative;
  padding-right: 24px;
  margin-right: 8px;
  color: #212426;
  font-size: 12px;
  font-size: 1.2rem;
}

.cp_breadcrumb li::before {
  content: "›";
  width: 1em;
  height: 1em;
  line-height: 1;
  text-align: center;
  font-size: 1em;
  color: inherit;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.cp_breadcrumb li:last-child {
  margin-right: 0;
  padding-right: 0;
  color: #212426;
}

.cp_breadcrumb li:last-child::before {
  content: normal;
}

ul.colum2:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
ul.colum2 > .col,
ul.colum2 > li {
  margin-left: 15px;
  width: calc((100% - 30px) / 2);
}
ul.colum2 > .col:first-child,
ul.colum2 > li:first-child {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum2 {
    margin-left: 0px !important;
  }
}
ul.colum2 li:nth-of-type(3n) {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum2 li {
    float: none !important;
    width: 100% !important;
    margin-top: 10px !important;
    margin-left: 0px !important;
  }
}
ul.colum3:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
ul.colum3 > .col,
ul.colum3 > li {
  margin-left: 10px;
  width: calc((100% - 30px) / 3);
}
ul.colum3 > .col:first-child,
ul.colum3 > li:first-child {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum3 {
    margin-left: 0px !important;
  }
}
ul.colum3 li:nth-of-type(4n) {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum3 li {
    float: none !important;
    width: 100% !important;
    margin-top: 10px !important;
    margin-left: 0px !important;
  }
}
ul.colum4:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
ul.colum4 > .col,
ul.colum4 > li {
  margin-left: 10px;
  width: calc((100% - 40px) / 4);
}
ul.colum4 > .col:first-child,
ul.colum4 > li:first-child {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum4 {
    margin-left: 0px !important;
  }
}
ul.colum4 li:nth-of-type(5n) {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum4 li {
    float: none !important;
    width: 100% !important;
    margin-top: 10px !important;
    margin-left: 0px !important;
  }
}
ul.colum5:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
ul.colum5 > .col,
ul.colum5 > li {
  margin-left: 10px;
  width: calc((100% - 50px) / 5);
}
ul.colum5 > .col:first-child,
ul.colum5 > li:first-child {
  margin-left: 0px;
}
@media (max-width: 767px) {
  ul.colum5 {
    margin-left: 0px !important;
  }
}
@media (max-width: 767px) {
  ul.colum5 li {
    float: none !important;
    width: 100% !important;
    margin-top: 10px !important;
    margin-left: 0px !important;
  }
}

.font18 {
  font-size: 20px;
  font-size: 2rem;
}

.font20 {
  font-size: 20px;
  font-size: 2rem;
}

.font22 {
  font-size: 22px;
  font-size: 2.2rem;
}

.font24 {
  font-size: 22px;
  font-size: 2.2rem;
}

.font26 {
  font-size: 22px;
  font-size: 2.2rem;
}

.font28 {
  font-size: 22px;
  font-size: 2.2rem;
}

.list__round {
  margin-left: 16px;
}
.list__round li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.list__round li:before {
  content: "";
  width: 5px;
  height: 5px;
  display: inline-block;
  background-color: #212426;
  border-radius: 50%;
  position: relative;
  top: -1px;
  margin-right: 5px;
}

.google__map {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
}
.google__map iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}

.drawer-hamburger {
  z-index: 99999;
}

.navi-area {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 800;
  min-width: 384px;
}
.navi-area button.drawer-hamburger {
  display: none;
}
@media (max-width: 767px) {
  .navi-area button.drawer-hamburger {
    display: block;
  }
}
.navi-area nav.pc ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-right: 10px;
}
.navi-area nav.pc ul li {
  padding: 0 15px;
  height: 90px;
  text-align: center;
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.navi-area nav.pc ul li:before {
  content: "";
  width: 1px;
  height: 40px;
  background-color: #E5E8E8;
  position: absolute;
  left: 0;
  top: 50%;
  margin: -20px 0 0 0;
  z-index: 1;
}
.navi-area nav.pc ul li:last-child:after {
  content: "";
  width: 1px;
  height: 40px;
  background-color: #E5E8E8;
  position: absolute;
  right: 0;
  top: 50%;
  margin: -20px 0 0 0;
  z-index: 1;
}
.navi-area nav.pc ul a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 90px;
  line-height: 1.5;
  text-decoration: none;
  color: #222222;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  font-weight: bold;
  font-size: 14px;
}
.navi-area nav.pc ul a:after {
  position: absolute;
  border-bottom: solid 4px #0378a6;
  bottom: 0;
  content: "";
  display: block;
  transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  width: 0;
}
.navi-area nav.pc ul a:hover:after {
  width: 100%;
}
.navi-area nav.pc ul span {
  font-size: 11px;
  font-size: 1.1rem;
  display: block;
  color: #03588c;
  text-align: center;
}

#nav-toggle {
  position: fixed;
  top: 18px;
  right: 12px;
  height: 32px;
  cursor: pointer;
}
#nav-toggle > div {
  position: relative;
  width: 36px;
}
#nav-toggle span {
  width: 100%;
  height: 1px;
  left: 0;
  display: block;
  background: #333;
  position: absolute;
  -webkit-transition: top 0.5s ease, -webkit-transform 0.6s ease-in-out;
  transition: top 0.5s ease, -webkit-transform 0.6s ease-in-out;
  transition: transform 0.6s ease-in-out, top 0.5s ease;
  transition: transform 0.6s ease-in-out, top 0.5s ease, -webkit-transform 0.6s ease-in-out;
}
#nav-toggle span:nth-child(1) {
  top: 0;
}
#nav-toggle span:nth-child(2) {
  top: 12px;
}
#nav-toggle span:nth-child(3) {
  top: 24px;
}
#nav-toggle:hover span:nth-child(1) {
  top: 4px;
}
#nav-toggle:hover span:nth-child(3) {
  top: 23px;
}

.open #nav-toggle span {
  background: #000;
}
.open #nav-toggle span:nth-child(1) {
  top: 15px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.open #nav-toggle span:nth-child(2) {
  top: 15px;
  width: 0;
  left: 50%;
}
.open #nav-toggle span:nth-child(3) {
  top: 15px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

/* z-index */
#nav-toggle {
  z-index: 1000;
}

#container {
  z-index: 900;
}

#gloval-nav {
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  position: fixed;
  top: 70px;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 990;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  visibility: hidden;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 29px;
  opacity: 0;
  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

#gloval-nav a {
  display: block;
  color: #fff;
  text-decoration: none;
  padding: 15px 0;
  font-size: 20px;
  font-size: 2rem;
  -webkit-transition: color 0.6s ease;
  transition: color 0.6s ease;
  font-weight: 500;
  border-bottom: 1px solid #FFF;
}
#gloval-nav a:hover {
  color: #666;
}
#gloval-nav ul {
  list-style: none;
}
#gloval-nav ul li {
  opacity: 0;
  -webkit-transform: translateX(200px);
          transform: translateX(200px);
  -webkit-transition: opacity 0.2s ease, -webkit-transform 0.6s ease;
  transition: opacity 0.2s ease, -webkit-transform 0.6s ease;
  transition: transform 0.6s ease, opacity 0.2s ease;
  transition: transform 0.6s ease, opacity 0.2s ease, -webkit-transform 0.6s ease;
}
#gloval-nav ul li:nth-child(2) {
  -webkit-transition-delay: 0.15s;
          transition-delay: 0.15s;
}
#gloval-nav ul li:nth-child(3) {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
#gloval-nav ul li:nth-child(4) {
  -webkit-transition-delay: 0.45s;
          transition-delay: 0.45s;
}
#gloval-nav ul li:nth-child(5) {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
#gloval-nav ul li:nth-child(6) {
  -webkit-transition-delay: 0.75s;
          transition-delay: 0.75s;
}
#gloval-nav ul li:nth-child(7) {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}
#gloval-nav ul li span.tel-num a {
  border-style: none;
  font-weight: 800;
  font-family: "PT Serif", serif;
  font-size: 30px;
  font-size: 3rem;
}
#gloval-nav ul li span.tel-num a:before {
  font-family: "Material Icons";
  content: "\e0b0";
  display: inline-block;
  padding-right: 7px;
}

/* open */
.open {
  overflow: hidden;
}
.open #gloval-nav {
  visibility: visible;
  opacity: 1;
}
.open #gloval-nav li {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition: opacity 0.9s ease, -webkit-transform 1s ease;
  transition: opacity 0.9s ease, -webkit-transform 1s ease;
  transition: transform 1s ease, opacity 0.9s ease;
  transition: transform 1s ease, opacity 0.9s ease, -webkit-transform 1s ease;
}

.fixed-side {
  position: fixed;
  top: 0;
}

.bottom-side {
  position: absolute;
  bottom: 0;
}

.static-side {
  position: static;
}

.sub__nav {
  border-color: #dde9f4;
  border-style: solid;
  border-width: 1px 1px 0 1px;
}
.sub__nav_item {
  background: #f4f9fc;
  border-color: #dde9f4;
  border-style: solid;
  border-width: 0px 0px 1px 0px;
}
.sub__nav_link {
  font-weight: bold;
  padding: 20px;
  display: block;
  position: relative;
}
.sub__nav_link:before {
  font-family: "Material Icons";
  content: "\e409";
  color: #03588C;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -12px;
}
.sub__nav_child {
  margin-left: 30px;
}
.sub__nav_child_item {
  border-color: #dde9f4;
  border-style: solid;
  border-width: 0px 0px 1px 0px;
}
.sub__nav_child_link {
  padding: 5px;
  font-weight: normal;
  color: #212426;
  display: block;
  position: relative;
}
.sub__nav_child_link:before {
  font-family: "fontello";
  content: "\f105";
  position: absolute;
  color: #212426;
  top: 50%;
  right: 10px;
  margin-top: -12px;
}

.main-title {
  padding: 120px 0 62px;
  background-image: url(../img/page-title.png);
  background-position: center;
  background-size: cover;
}
@media (max-width: 767px) {
  .main-title {
    padding: 82px 0 40px;
  }
}
.main-title h1 {
  position: relative;
  z-index: 10;
  display: inline-block;
}
@media (max-width: 767px) {
  .main-title h1 {
    display: block;
    text-align: center;
  }
}
.main-title h1 span {
  display: block;
}
.main-title h1 span.page-title-en {
  text-align: center;
  color: #85ddff;
}
.main-title h1 span.page-title-jp {
  font-size: 36px;
  font-size: 3.6rem;
  color: #fff;
}
@media (max-width: 767px) {
  .main-title h1 span.page-title-jp {
    font-size: 20px;
    font-size: 2rem;
  }
}

.section .top-box {
  margin-top: -30px;
  background-color: #fff;
}
@media (max-width: 767px) {
  .section .top-box {
    margin-top: 0px;
  }
}

.sec {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: left;
}
@media (max-width: 767px) {
  .sec {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.sec__l {
  width: 75%;
  margin-right: 30px;
}
.sec__l h1,
.sec__l h2,
.sec__l h3,
.sec__l h4,
.sec__l h5,
.sec__l h6 {
  margin-bottom: 0.8em;
}
@media (max-width: 767px) {
  .sec__l {
    width: 100%;
  }
}
.sec__r {
  width: 25%;
  position: relative;
}
@media (max-width: 767px) {
  .sec__r {
    width: 100%;
  }
}
.sec__r h2 {
  background-color: #03588c;
  color: #fff;
  font-size: 18px;
  font-size: 1.8rem;
  padding: 20px;
  margin: 0px;
}
.sec__box {
  margin-bottom: 20px;
}
.sec__wrap {
  margin-bottom: 40px;
}
@media (max-width: 767px) {
  .sec__wrap {
    margin-bottom: 20px;
  }
}
.sec__wrap .flex-wrap {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.sec__inner {
  margin-top: 10px;
}
.business h4 {
  border-bottom: 1px solid #0378a6;
}
.business .facility__title {
  position: relative;
  margin-bottom: 0.5em;
  padding-left: 18px;
}
.business .facility__title:before {
  background: #212426;
  content: "";
  height: 10px;
  width: 10px;
  left: 0;
  position: absolute;
  top: 8px;
}

.recruit .voice_photo {
  margin-bottom: 10px;
}
.recruit .voice_photo .voice_title_area {
  background-image: -webkit-gradient(linear, left top, right top, from(#0378A6), to(#12B2F1));
  background-image: linear-gradient(90deg, #0378A6 0%, #12B2F1 100%);
  position: relative;
  width: 40%;
}
@media (max-width: 767px) {
  .recruit .voice_photo .voice_title_area {
    position: static;
    width: 100%;
  }
}
.recruit .voice_photo .voice_title_area .voice_title_area_inner {
  position: absolute;
  top: 50%;
  right: 0px;
  width: 120%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  background-color: rgba(3, 120, 166, 0.6);
  margin-left: -100px;
  padding: 10px;
}
@media (max-width: 767px) {
  .recruit .voice_photo .voice_title_area .voice_title_area_inner {
    background-color: transparent;
    margin-left: 0px;
    position: static;
    -webkit-transform: none;
            transform: none;
  }
}
.recruit .voice_photo .voice_title_area .voice_title_area_inner p {
  color: #fff;
}
.recruit .voice_photo .voice_title_area .voice_title_area_inner p.voice__pickup {
  font-size: 20px;
  font-size: 2rem;
  padding-bottom: 10px;
  border-bottom: 1px solid #fff;
}
.recruit .voice_photo .voice_title_area .voice_title_area_inner p.voice__title {
  font-size: 30px;
  font-size: 3rem;
}
.recruit .voice_photo figure {
  width: 60%;
}
@media (max-width: 767px) {
  .recruit .voice_photo figure {
    width: 100%;
  }
}
.recruit p.font20 {
  font-size: 20px;
  font-size: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  /* 垂直中心 */
  color: #0378a6;
}
.recruit p.font20:before {
  border-top: 1px solid;
  content: " ";
  width: 3em;
  /* 線の長さ */
  margin-right: 1em;
  /* 文字の右隣 */
}
@media (max-width: 767px) {
  .recruit p.font20:before {
    display: none;
  }
}
.recruit .voice__txt {
  margin-bottom: 20px;
}
.company .message {
  position: relative;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  .company .message {
    margin-bottom: 10px;
  }
}
.company .message .sec__inner {
  position: absolute;
  top: 50%;
  right: 0px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  background-color: rgba(3, 120, 166, 0.6);
  padding: 10px;
  width: 60%;
}
@media (max-width: 767px) {
  .company .message .sec__inner {
    position: static;
    -webkit-transform: none;
            transform: none;
    margin-bottom: 0px;
    width: 100%;
  }
}
.company .message .sec__inner p,
.company .message .sec__inner h3 {
  color: #fff;
}
.company .message .sec__inner p.company_catch,
.company .message .sec__inner h3.company_catch {
  font-size: 20px;
  font-size: 2rem;
  border-bottom: 1px solid #fff;
  padding-bottom: 0.5em;
  margin-bottom: 20px;
}
.company .message .sec__inner h3 {
  font-size: 30px;
  font-size: 3rem;
  border-left: none;
  margin-bottom: 0px;
  padding: 0px;
}
@media (max-width: 767px) {
  .company .message .sec__inner h3 {
    font-size: 20px;
    font-size: 2rem;
  }
}
.company .groups_wrap {
  margin-bottom: 15px;
}
.company .font20 {
  font-size: 20px;
  font-size: 2rem;
  margin-bottom: 10px;
}

.privacy .r_bg_wh,
.contact .r_bg_wh,
.news .r_bg_wh {
  margin: auto;
  width: 80%;
  padding: 35px;
}
@media (max-width: 767px) {
  .privacy .r_bg_wh,
  .contact .r_bg_wh,
  .news .r_bg_wh {
    width: 95%;
    padding: 15px;
  }
}
.privacy .sec__add,
.contact .sec__add,
.news .sec__add {
  border: 1px solid #bfbfbf;
  padding: 20px;
}

.news {
  text-align: left;
}
.news__data {
  background-color: #f2f2f2;
  font-size: 12px;
  font-size: 1.2rem;
  padding: 5px 0px;
  margin-top: 15px;
}
.news .news__list {
  margin-top: 30px;
}
.news .news__list a {
  display: block;
}
.news .news__list a span {
  display: inline-block;
  margin-left: 10px;
}
@media (max-width: 767px) {
  .news .news__list a span {
    display: block;
  }
}

.contact label {
  position: relative;
}
@media (max-width: 767px) {
  .contact label {
    width: 100%;
  }
}
.contact .badge {
  background-color: #da322a;
  position: absolute;
  right: 0px;
}
@media (max-width: 767px) {
  .contact .badge {
    right: 10px;
  }
}
.contact .form-group {
  padding: 20px 0px;
  border-bottom: solid 1px #bfbfbf;
}

.page-img {
  position: relative;
  z-index: 1;
  min-height: 100%;
  min-height: 50vh;
  width: 100%;
  background-color: coral;
}

.top-main-inner {
  position: relative;
  width: 100%;
  min-height: 720px;
  background-image: url(../img/main-img.png);
  background-position: center;
  background-size: cover;
  position: relative;
}
@media (max-width: 767px) {
  .top-main-inner {
    min-height: 350px;
  }
}
.top-main-inner .top-img {
  position: absolute;
  top: 45%;
  left: 2%;
}
@media (max-width: 767px) {
  .top-main-inner .top-img img {
    width: 230px;
  }
}
.top-main-inner .main-img {
  position: relative;
  z-index: 1;
}
.top-main-inner .section {
  margin-top: 0px !important;
  margin-bottom: 0px !important;
}
.top-main-inner .section.news {
  bottom: -45px;
  position: absolute;
  width: 100%;
  z-index: 999;
  text-align: left;
}
.top-main-inner .section .news-innner {
  position: relative;
  height: 100px;
}
.top-main-inner .section .news-innner .news-title {
  width: 100%;
  position: absolute;
  font-size: 20px;
  font-size: 2rem;
  color: #fff;
  height: 50px;
  top: 15px;
  left: 0px;
  font-weight: 700;
  z-index: 20;
}
.top-main-inner .section .news-innner .news-title .block {
  margin-left: 15%;
}
.top-main-inner .section .news-innner .news-title .innner {
  position: relative;
  height: 50px;
}
.top-main-inner .section .news-innner .news-title .innner:before {
  content: " ";
  position: absolute;
  top: 0;
  left: 0;
  width: 80%;
  height: 100%;
  background-color: #0378a6;
  z-index: -100;
  font-family: "Open Sans", sans-serif;
}
.top-main-inner .section .news-innner .news-list {
  position: absolute;
  height: 50px;
  right: 0;
  bottom: 2px;
  z-index: 21;
}
@media (max-width: 767px) {
  .top-main-inner .section .news-innner .news-list {
    width: 95%;
  }
}
.top-main-inner .section .news-innner .news-list .block {
  margin-left: 21%;
  width: 79%;
  height: 50px;
}
@media (max-width: 767px) {
  .top-main-inner .section .news-innner .news-list .block {
    height: auto;
    width: 100%;
    padding: 10px;
  }
}
@media (max-width: 767px) {
  .top-main-inner .section .news-innner .news-list .block span {
    display: block;
  }
}
@media (max-width: 767px) {
  .top-main-inner .section .news-innner .news-list .block .news-bt {
    margin-top: 10px;
  }
}
.top-main-inner .section .news-innner .news-list .flex-wrap {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.top-main-inner .section .news-innner .news-list span {
  margin-left: 10px;
}
.top-main-inner .section .news-innner .news-list .news-bt {
  margin-left: auto;
}
.top-main-inner .section .news-innner .news-list .innner {
  height: 50px;
  position: relative;
}
@media (max-width: 767px) {
  .top-main-inner .section .news-innner .news-list .innner {
    height: auto;
  }
}
.top-main-inner .section .news-innner .news-list .innner:before {
  content: " ";
  position: absolute;
  bottom: 0px;
  right: 0;
  width: 80%;
  height: 100%;
  background-color: #f2f2f2;
  z-index: -99;
}

.section.concept, .section.top-business {
  margin-top: 0px;
}
.section.top-business h2 span, .section.recruit h2 span {
  display: block;
}
.section.top-business h2 span.page-title-en, .section.recruit h2 span.page-title-en {
  text-align: center;
  font-size: 12px;
  font-size: 1.2rem;
}
@media (max-width: 767px) {
  .section.top-business h2 span.page-title-jp, .section.recruit h2 span.page-title-jp {
    font-size: 20px;
    font-size: 2rem;
  }
}

.section.concept {
  padding: 90px 0 75px 0;
  background-image: url(../img/bg-concept.png);
  background-position: center;
  background-size: cover;
}
.section.concept h2 {
  margin-bottom: 30px;
  text-align: center;
}
@media (max-width: 767px) {
  .section.concept {
    width: 100%;
    padding: 130px 0 50px 0;
  }
}
.section.concept .block {
  width: 100%;
  margin: auto;
  text-align: left;
}
@media (min-width: 768px) {
  .section.concept .block {
    width: 75%;
  }
}
@media (max-width: 767px) {
  .section.concept .block {
    width: 100%;
  }
}
.section.top-business .title-inner {
  background-image: url(../img/bg-business-title.png);
  background-position: center;
  background-size: cover;
  padding: 50px 0 60px;
}
@media (max-width: 767px) {
  .section.top-business .title-inner {
    padding: 30px 0 40px;
    display: block;
  }
}
.section.top-business .title-inner h2 {
  position: relative;
  z-index: 10;
  color: #fff;
  text-align: center;
}
@media (max-width: 767px) {
  .section.top-business .title-inner h2 {
    display: block;
  }
}
.section.top-business .bg-inner {
  background-image: url(../img/patt.png);
  background-repeat: repeat;
}
.section.top-business .bg-mask {
  height: 100%;
  background: rgba(255, 255, 255, 0.8);
  padding-bottom: 55px;
}
@media (max-width: 767px) {
  .section.top-business .bg-mask {
    padding-bottom: 20px;
  }
}
.section.top-business ul.business-block {
  position: relative;
  margin-top: -30px;
}
.section.top-business ul.business-block .flex-wrap {
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.section.top-business ul.business-block li {
  background-color: #fff;
  padding: 10px;
  border: solid 1px #0378a6;
}
.section.top-business ul.business-block li .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.section.top-business ul.business-block li .business-title,
.section.top-business ul.business-block li .business-desc,
.section.top-business ul.business-block li .business-img {
  margin-top: 10px;
}
.section.top-business ul.business-block li .business-title {
  font-weight: 800;
  line-height: 1.2;
  font-size: 20px;
  font-size: 2rem;
}
@media (max-width: 767px) {
  .section.top-business ul.business-block li .business-title {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
.section.top-business ul.business-block li .business-desc {
  text-align: left;
}
.section.top-business ul.business-block li .business-img {
  margin-top: auto;
}
.section.top-business .btarea {
  padding: 20px 0px;
}
.section.top-business .btarea a {
  color: #212426;
}
.section.top-business .btarea a:hover {
  color: #fff;
}
.section.recruit {
  position: relative;
  margin: 45px 0 175px 0;
}
@media (max-width: 767px) {
  .section.recruit {
    background-color: #f2f2f2;
    margin: 0px 0 80px 0;
    padding: 20px 0px;
  }
}
.section.recruit:before {
  content: "";
  display: block;
  position: absolute;
  bottom: -21px;
  left: 0;
  width: 64%;
  height: 70%;
  background-color: #f2f2f2;
  z-index: -100;
}
@media (max-width: 767px) {
  .section.recruit:before {
    display: none;
  }
}
@media (max-width: 767px) {
  .section.recruit .flex-wrap {
    position: static;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.section.recruit .title-inner {
  display: inline-block;
}
@media (max-width: 767px) {
  .section.recruit .title-inner {
    display: block;
    text-align: center;
  }
}
.section.recruit .left-text {
  width: 50vw;
}
.section.recruit .left-text .block {
  padding: 0px 0px 0px 10%;
  text-align: left;
}
@media (max-width: 767px) {
  .section.recruit .left-text .block {
    padding: 0 10px;
  }
}
.section.recruit .left-text .recruit-sub p {
  line-height: 1.3;
  font-size: 24px;
  font-size: 2.4rem;
  margin-top: 15px;
}
.section.recruit .left-text .recruit-sub,
.section.recruit .left-text .recruit-desc {
  text-align: left;
}
.section.recruit .left-text .recruit-desc {
  margin-top: 60px;
}
@media (max-width: 767px) {
  .section.recruit .left-text .recruit-desc {
    margin-top: 24px;
  }
}
.section.recruit .right-img {
  width: 50vw;
}
.section.recruit .right-img img {
  width: 100%;
  margin-top: 80px;
}
@media (max-width: 767px) {
  .section.recruit .right-img img {
    max-width: initial !important;
    position: absolute;
    top: 95%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 800px;
    height: auto;
    margin-top: 0px;
  }
}
.section.recruit .btarea {
  padding: 20px 0px;
  text-align: center;
}
.section.bn-link li {
  height: auto;
  margin: 0 auto;
  overflow: hidden;
  cursor: pointer;
}
.section.bn-link li.comp__photo {
  width: 40%;
}
@media (max-width: 767px) {
  .section.bn-link li.comp__photo {
    width: 100%;
    height: auto;
  }
}
.section.bn-link li.comp__map {
  width: 60%;
}
@media (max-width: 767px) {
  .section.bn-link li.comp__map {
    width: 100%;
    height: auto;
  }
}
@media (max-width: 767px) {
  .section.bn-link li {
    width: 100%;
    height: auto;
  }
}
.section.bn-link li img {
  max-width: 100%;
}
.section.bn-link a {
  position: relative;
}
.section.bn-link .bn-link-name {
  bottom: 0;
  font-size: 16px;
  font-size: 1.6rem;
  color: #fff;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  left: 20px;
  height: 45px;
  position: absolute;
  z-index: 1;
}
.section.bn-link .bn-link-name span.strength:before, .section.bn-link .bn-link-name span.secret:before, .section.bn-link .bn-link-name span.flow:before {
  font-family: "fontello";
  display: inline-block;
  padding-right: 8px;
}
.section.bn-link .bn-link-name span.strength:before {
  content: "\e824";
}
.section.bn-link .bn-link-name span.secret:before {
  content: "\e81c";
}
.section.bn-link .bn-link-name span.flow:before {
  content: "\e823";
}
.section .bn-link__body {
  width: 100%;
  margin-bottom: 0px;
}

.top .google__map {
  padding-bottom: 42.8% !important;
}
@media (max-width: 767px) {
  .top .google__map {
    padding-bottom: 56.25% !important;
  }
}
.top footer {
  margin-top: 0px !important;
}