@charset "UTF-8";
img, legend {
  border: 0
}

#breadCrumbs a, audio, canvas, video {
  display: inline-block
}

.bscTbl01 table, table {
  border-collapse: collapse
}

.editor p, pre {
  word-wrap: break-word
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: local('Noto Sans Japanese Light'), local('NotoSansJapanese-Light'), url(https://fonts.gstatic.com/s/notosansjp/v25/-F6pfjtqLzI2JPCgQBnw7HFQaioa1Xdj.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Noto Sans Japanese Regular'), local('NotoSansJapanese-Regular'), url(https://fonts.gstatic.com/s/notosansjp/v25/-F62fjtqLzI2JPCgQBnw7HFYwQgM.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local('Noto Sans Japanese Medium'), local('NotoSansJapanese-Medium'), url(https://fonts.gstatic.com/s/notosansjp/v25/-F6pfjtqLzI2JPCgQBnw7HFQMisa1Xdj.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: local('Noto Sans Japanese Bold'), local('NotoSansJapanese-Bold'), url(https://fonts.gstatic.com/s/notosansjp/v25/-F6pfjtqLzI2JPCgQBnw7HFQei0a1Xdj.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: local('Noto Sans Japanese Black'), local('NotoSansJapanese-Black'), url(https://fonts.gstatic.com/s/notosansjp/v25/-F6pfjtqLzI2JPCgQBnw7HFQQi8a1Xdj.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Serif JP';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: local('Noto Serif JP Light'), local('NotoSerifJP-Light'), url(https://fonts.gstatic.com/s/notoserifjp/v7/xn77YHs72GKoTvER4Gn3b5eMZHKMdkkVUQ.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Serif JP';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Noto Serif JP'), local('NotoSerifJP-Regular'), url(https://fonts.gstatic.com/s/notoserifjp/v7/xn7mYHs72GKoTvER4Gn3b5eMbNmuYA.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Serif JP';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local('Noto Serif JP Medium'), local('NotoSerifJP-Medium'), url(https://fonts.gstatic.com/s/notoserifjp/v7/xn77YHs72GKoTvER4Gn3b5eMZCqNdkkVUQ.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Serif JP';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: local('Noto Serif JP SemiBold'), local('NotoSerifJP-SemiBold'), url(https://fonts.gstatic.com/s/notoserifjp/v7/xn77YHs72GKoTvER4Gn3b5eMZAaKdkkVUQ.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Serif JP';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: local('Noto Serif JP Bold'), local('NotoSerifJP-Bold'), url(https://fonts.gstatic.com/s/notoserifjp/v7/xn77YHs72GKoTvER4Gn3b5eMZGKLdkkVUQ.otf) format('opentype')
}

@font-face {
  font-family: 'Noto Serif JP';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: local('Noto Serif JP Black'), local('NotoSerifJP-Black'), url(https://fonts.gstatic.com/s/notoserifjp/v7/xn77YHs72GKoTvER4Gn3b5eMZFqJdkkVUQ.otf) format('opentype')
}

@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/josefinsans/v15/Qw3PZQNVED7rKGKxtqIqX5E-AVSJrOCfjY46_GbQbMZhKg.ttf) format('truetype')
}

@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/josefinsans/v15/Qw3PZQNVED7rKGKxtqIqX5E-AVSJrOCfjY46_DjQbMZhKg.ttf) format('truetype')
}

@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/josefinsans/v15/Qw3PZQNVED7rKGKxtqIqX5E-AVSJrOCfjY46_ObXbMZhKg.ttf) format('truetype')
}

@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/josefinsans/v15/Qw3PZQNVED7rKGKxtqIqX5E-AVSJrOCfjY46_N_XbMZhKg.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(https://fonts.gstatic.com/s/roboto/v20/KFOjCnqEu92Fr1Mu51TjARc9.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(https://fonts.gstatic.com/s/roboto/v20/KFOkCnqEu92Fr1Mu52xP.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(https://fonts.gstatic.com/s/roboto/v20/KFOjCnqEu92Fr1Mu51S7ABc9.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(https://fonts.gstatic.com/s/roboto/v20/KFOjCnqEu92Fr1Mu51TzBhc9.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: local('Roboto Black Italic'), local('Roboto-BlackItalic'), url(https://fonts.gstatic.com/s/roboto/v20/KFOjCnqEu92Fr1Mu51TLBBc9.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: local('Roboto Light'), local('Roboto-Light'), url(https://fonts.gstatic.com/s/roboto/v20/KFOlCnqEu92Fr1MmSU5vAw.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Roboto'), local('Roboto-Regular'), url(https://fonts.gstatic.com/s/roboto/v20/KFOmCnqEu92Fr1Me5Q.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(https://fonts.gstatic.com/s/roboto/v20/KFOlCnqEu92Fr1MmEU9vAw.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(https://fonts.gstatic.com/s/roboto/v20/KFOlCnqEu92Fr1MmWUlvAw.ttf) format('truetype')
}

@font-face {
  font-family: Roboto;
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: local('Roboto Black'), local('Roboto-Black'), url(https://fonts.gstatic.com/s/roboto/v20/KFOlCnqEu92Fr1MmYUtvAw.ttf) format('truetype')
}

@font-face {
  font-family: Heebo;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: local('Heebo Light'), local('Heebo-Light'), url(https://fonts.gstatic.com/s/heebo/v5/NGS3v5_NC0k9P9ldb6RMkKs.ttf) format('truetype')
}

@font-face {
  font-family: Heebo;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Heebo'), local('Heebo-Regular'), url(https://fonts.gstatic.com/s/heebo/v5/NGS6v5_NC0k9P9H2TbQ.ttf) format('truetype')
}

@font-face {
  font-family: Heebo;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local('Heebo Medium'), local('Heebo-Medium'), url(https://fonts.gstatic.com/s/heebo/v5/NGS3v5_NC0k9P9kFbqRMkKs.ttf) format('truetype')
}

@font-face {
  font-family: Heebo;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: local('Heebo Bold'), local('Heebo-Bold'), url(https://fonts.gstatic.com/s/heebo/v5/NGS3v5_NC0k9P9lNaKRMkKs.ttf) format('truetype')
}

@font-face {
  font-family: Heebo;
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: local('Heebo Black'), local('Heebo-Black'), url(https://fonts.gstatic.com/s/heebo/v5/NGS3v5_NC0k9P9l1aqRMkKs.ttf) format('truetype')
}

@font-face {
  font-family: Oswald;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/oswald/v31/TK3_WkUHHAIjg75cFRf3bXL8LICs169vsUZiYA.ttf) format('truetype')
}

@font-face {
  font-family: Oswald;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/oswald/v31/TK3_WkUHHAIjg75cFRf3bXL8LICs1_FvsUZiYA.ttf) format('truetype')
}

@font-face {
  font-family: Oswald;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/oswald/v31/TK3_WkUHHAIjg75cFRf3bXL8LICs18NvsUZiYA.ttf) format('truetype')
}

@font-face {
  font-family: Oswald;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/oswald/v31/TK3_WkUHHAIjg75cFRf3bXL8LICs1y9osUZiYA.ttf) format('truetype')
}

@font-face {
  font-family: Oswald;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/oswald/v31/TK3_WkUHHAIjg75cFRf3bXL8LICs1xZosUZiYA.ttf) format('truetype')
}


/*! normalize.css v2.0.1 | MIT License | git.io/normalize */

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary {
  display: block
}

audio:not([controls]) {
  display: none;
  height: 0
}

[hidden] {
  display: none
}

html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%
}

body, figure {
  margin: 0
}

h1 {
  font-size: 2em
}

abbr[title] {
  border-bottom: 1px dotted
}

b, strong {
  font-weight: 700
}

dfn {
  font-style: italic
}

mark {
  background: #ff0;
  color: #000
}

code, kbd, pre, samp {
  font-family: monospace, serif;
  font-size: 1em
}

pre {
  white-space: pre;
  white-space: pre-wrap
}

q {
  quotes: "\201C" "\201D" "\2018" "\2019"
}

small {
  font-size: 80%
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
  position: relative
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

svg:not(:root) {
  overflow: hidden
}

fieldset {
  border: 1px solid silver;
  margin: 0 2px;
  padding: .35em .625em .75em
}

legend {
  padding: 0
}

button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
  margin: 0
}

#breadCrumbs, #breadCrumbs a {
  font-size: .92em;
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, メイリオ, verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #7b7474
}

button, input {
  line-height: normal
}

button, html input[type=button], input[type=reset], input[type=submit] {
  -webkit-appearance: button;
  cursor: pointer
}

button[disabled], input[disabled] {
  cursor: default
}

input[type=checkbox], input[type=radio] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0
}

input[type=search] {
  -webkit-appearance: textfield;
  -webkit-box-sizing: content-box;
  box-sizing: content-box
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0
}

textarea {
  overflow: auto;
  vertical-align: top
}

table {
  border-spacing: 0
}

#subMv .mvInr {
  background-attachment: fixed;
  background-position: center center;
  background-size: cover;
  max-width: 100%;
  width: 100%;
  margin-top: 54px;
  position: relative
}

.lowerPage {
  padding: 120px 0 60px
}

#wrap {
  margin-left: 100px;
  overflow: hidden
}

@media (max-width:1024px) {
  #wrap {
    margin-left: 0
  }
}

#breadCrumbs {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  margin: 0 auto;
  padding: 10px 5px;
  background-color: #eaeaea
}

.pager a, .subscribeBtn p {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#breadCrumbs a {
  text-decoration: underline
}

#breadCrumbs i {
  font-size: 120%;
  vertical-align: text-top
}

#thanks {
  padding-top: 80px
}

@media (max-width:768px) {
  #subMv .mvInr {
    background-repeat: no-repeat;
    background-attachment: initial;
    background-position: center center
  }
  #thanks {
    padding-top: 80px
  }
}

.bscBox01 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 30px;
  color: #0068b7;
  background-color: #fff
}

.bscBox02, .bscTbl01 table td, .bscTbl01 table th {
  background-color: #fff;
  -webkit-box-sizing: border-box
}

.bscBox02 {
  box-sizing: border-box;
  padding: 2.5em;
  border: 4px solid #009dda
}

.indList, .indListS {
  margin-bottom: 15px
}

.indList li, .indListS li {
  padding-left: 1em;
  margin-bottom: 5px;
  text-indent: -1em
}

.indList li::before, .indListS li::before {
  content: "●";
  font-size: 50%;
  margin-right: 5px;
  vertical-align: middle;
  color: #0068b7
}

.indList li {
  line-height: 170%
}

@media (max-width:480px) {
  .indList li {
    font-size: 3.2vw
  }
}

.indListS li {
  font-size: 1.1rem!important;
  line-height: 130%
}

.numList, .numListS {
  margin-bottom: 15px;
  padding-left: 1.6em
}

.numList li, .numListS li {
  list-style: decimal;
  margin-bottom: 5px
}

.numList li {
  line-height: 150%
}

@media (max-width:480px) {
  .numList li {
    font-size: 3.2vw
  }
  .clm4 li.fadeIn {
    -webkit-transition-delay: .3s!important;
    transition-delay: .3s!important
  }
}

.numListS li {
  font-size: 1.1rem!important;
  line-height: 130%
}

.bscTbl01 table {
  border-left: 1px solid #ddd;
  border-top: 1px solid #ddd;
  width: 100%
}

.bscTbl01 table td, .bscTbl01 table th {
  font-size: 1em;
  box-sizing: border-box;
  border-right: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  line-height: 1.4;
  padding: 20px 20px 17px;
  text-align: left
}

.pager, .privacyCheckBox, .selectBox, .subscribeBtn {
  text-align: center
}

.bscTbl01 table th {
  background-color: #ddd;
  border-bottom: 1px solid #fff
}

.bscTbl01 table tr.head th {
  background-color: #009dda;
  color: #fff
}

.bscTbl01 table tr:last-child th {
  border-bottom: 1px solid #ddd
}

.bscTbl01+.bscTbl01 {
  margin-top: 3.5em
}

.bscTbl01.tblScroll table {
  table-layout: fixed
}

.bscTbl01.tblScroll table td, .bscTbl01.tblScroll table th {
  display: table-cell;
  width: auto
}

@media (max-width:768px) {
  .tblScroll::after {
    content: "※フリックで横スクロールができます。";
    display: block;
    font-size: 1em;
    margin-top: 1em
  }
  .tblScroll .tblScrollInr {
    overflow-x: auto
  }
  .tblScroll .tblScrollInr::-webkit-scrollbar {
    height: 5px
  }
  .tblScroll .tblScrollInr::-webkit-scrollbar-track {
    border-radius: 10px;
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .1);
    box-shadow: inset 0 0 6px rgba(0, 0, 0, .1)
  }
  .tblScroll .tblScrollInr::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, .3);
    border-radius: 10px;
    -webkit-box-shadow: 0 0 0 1px rgba(255, 255, 255, .3);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, .3)
  }
  .tblScroll table {
    margin-bottom: 0;
    width: 250%;
    table-layout: fixed
  }
  .tblScroll table td, .tblScroll table th {
    display: table-cell;
    vertical-align: top
  }
}

.clm2 figcaption, .clm3 figcaption, .clm4 figcaption {
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.4
}

#header, .clm2, .clm3, .clm4, .moveBox .inr, .selectBox {
  overflow: hidden
}

.clm4 li {
  float: left;
  margin-right: 1.3%;
  width: 24%
}

.clm4 li:nth-child(4n) {
  margin-right: 0
}

.clm4 li+li+li+li+li {
  margin-top: 2em
}

.clm4 figcaption {
  margin-bottom: 10px
}

.clm3 li {
  float: left;
  margin-bottom: 20px;
  margin-right: 1.3%;
  width: 32.4%
}

.clm3 li:nth-child(3n) {
  margin-right: 0
}

.clm3 figcaption {
  margin-bottom: 10px
}

.clm2 li {
  float: left;
  margin-bottom: 20px;
  width: 48.5%
}

.clm2 li.even, .clm2 li:nth-child(2n) {
  float: right
}

@media (max-width:480px) {
  .clm2 li.fadeIn, .clm3 li.fadeIn {
    -webkit-transition-delay: .3s!important;
    transition-delay: .3s!important
  }
}

.clm2 figcaption {
  margin-bottom: 10px
}

.pager {
  margin-top: 4em
}

.pager a {
  font-size: 20px;
  font-family: Heebo, sans-serif;
  font-weight: 400;
  background-color: #d5e1e6;
  color: #000;
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
  margin: 0 2px;
  padding: 13px 15px 12px;
  text-decoration: none;
  position: relative;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

.bscTbl01.contactForm .leadCauText, .bscTbl01.contactForm table tbody td, .privacyCheckBox, .req {
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, メイリオ, verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}

@media (max-width:768px) {
  .pager a {
    padding: 10px 12px 8px
  }
}

.pager a:hover {
  opacity: .8
}

.pager a.current {
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%);
  color: #fff
}

#topcontrol {
  display: none;
  z-index: 900;
  position: fixed;
  right: 20px;
  bottom: 20px;
  -webkit-transform: translateZ(0);
  transform: translateZ(0)
}

#topcontrol a {
  background-color: #0068b7;
  display: block;
  height: 60px;
  width: 60px;
  filter: alpha(opacity=70)!important;
  opacity: .7!important;
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out
}

#topcontrol a:hover {
  filter: alpha(opacity=10)!important;
  opacity: 1!important;
  -webkit-transform: scale(1.2);
  transform: scale(1.2)
}

#topcontrol a::after {
  content: "";
  display: block;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  color: #fff;
  border-top: 4px solid #fff;
  border-right: 4px solid #fff;
  width: 10px;
  height: 10px;
  position: absolute;
  top: 26px;
  left: 22px;
  border-radius: 2px
}

@media (max-width:1024px) {
  #topcontrol, #topcontrol a {
    width: 40px;
    height: 40px
  }
  #topcontrol {
    bottom: 10px!important;
    right: 10px!important
  }
  #topcontrol a::after {
    top: 18px;
    left: 14px;
    border-width: 2px
  }
}

.bscTbl01.contactForm {
  border-top: 1px solid #bfbfbf
}

.bscTbl01.contactForm .leadCauText {
  text-align: center;
  margin-top: 4em
}

.bscTbl01.contactForm .leadCauText::before {
  content: "※";
  color: #c1341d
}

.bscTbl01.contactForm table {
  border: none;
  max-width: 960px;
  margin: 2em auto 0
}

.bscTbl01.contactForm table tbody tr {
  border-bottom: 1px solid #bfbfbf
}

.bscTbl01.contactForm table tbody tr:first-child th {
  width: 30%
}

.bscTbl01.contactForm table tbody td, .bscTbl01.contactForm table tbody th {
  font-size: 1.1em;
  line-height: 1.4
}

.bscTbl01.contactForm table tbody th {
  background: 0 0;
  border: none;
  position: relative;
  padding: 3em 1em 3em 3em;
  line-height: 1.2;
  vertical-align: top
}

.bscTbl01.contactForm table tbody th::before {
  content: "";
  display: inline-block;
  width: 1.5em;
  height: 2px;
  background-color: #009dda;
  position: absolute;
  left: 1em;
  top: 3.5em
}

@media (max-width:1024px) {
  .bscTbl01.contactForm table tbody th {
    padding-bottom: 0
  }
}

.bscTbl01.contactForm table tbody td {
  background: 0 0;
  border: none;
  padding: 3em 1em;
  vertical-align: top
}

.privacyCheckBox .bscBtn01 a i, .req, input {
  vertical-align: middle
}

.bscTbl01.contactForm table tbody td input[type=text], .bscTbl01.contactForm table tbody td textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #efefef;
  border: 2px solid transparent;
  -webkit-transition: all .3s cubic-bezier(.445, .05, .55, .95);
  transition: all .3s cubic-bezier(.445, .05, .55, .95)
}

.bscTbl01.contactForm table tbody td input[type=text]:focus, .bscTbl01.contactForm table tbody td textarea:focus {
  outline: 0;
  border: 2px solid rgba(0, 157, 218, .5)!important;
  background-color: inherit!important;
  border-radius: 3px
}

.bscTbl01.contactForm table tbody td.nc input.empty, .bscTbl01.contactForm table tbody td.nc select.empty, .bscTbl01.contactForm table tbody td.nc textarea.empty {
  border: 2px solid #eeb5b1;
  background-color: #ffeeed;
  border-radius: 3px
}

.bscTbl01.contactForm table tbody td input[type=text] {
  padding: .7em 1em .5em
}

@media (max-width:1024px) {
  .bscTbl01.contactForm table tbody td {
    padding: 2em 1em
  }
}

.subscribeBtn {
  max-width: 700px;
  margin: 3em auto 0
}

.subscribeBtn p {
  background-color: #0068b7;
  border: none;
  color: #fff;
  display: inline-block;
  width: 49%;
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  position: relative
}

.subscribeBtn p+p {
  margin-left: 1.3%
}

@media (max-width:768px) {
  .subscribeBtn p {
    float: none;
    width: 100%
  }
  .subscribeBtn p+p {
    margin-left: 0;
    margin-top: 1em
  }
}

.subscribeBtn p i {
  display: inline-block;
  font-size: .6em;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 15%;
  color: #fff
}

.subscribeBtn p:hover {
  opacity: .8
}

.subscribeBtn p.disabled {
  opacity: .1;
  pointer-events: none
}

.subscribeBtn p.return {
  background-color: #dedede;
  color: #000
}

.subscribeBtn p.return input {
  color: #000
}

.subscribeBtn p.return i {
  color: #000;
  left: 15%;
  right: auto
}

.subscribeBtn p input {
  display: block;
  width: 100%;
  background: 0 0;
  border: none;
  color: #fff;
  padding: 1.3em 0 1.2em;
  line-height: 140%;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  text-decoration: none
}

.inputClm2 li, .req {
  display: inline-block
}

input.textFocus {
  color: #333
}

input.wFull, input.wL, input.wLL, input.wM, input.wS, input.wSS {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 1px solid #ccc;
  font-size: 1.3rem;
  line-height: 140%;
  padding: 8px 10px
}

input.wFull:focus, input.wL:focus, input.wLL:focus, input.wM:focus, input.wS:focus, input.wSS:focus {
  background-color: #efefef
}

select.slctArea, textarea.txtarea {
  background-color: #fcfbf8;
  -webkit-box-sizing: border-box;
  border: 1px solid #ccc
}

.wSS {
  width: 85px
}

.wS {
  width: 170px
}

.wM {
  width: 270px
}

.wL {
  width: 470px
}

.wLL {
  width: 80%
}

.imeOn {
  ime-mode: active
}

.imeOff {
  ime-mode: disabled
}

textarea.txtarea {
  box-sizing: border-box;
  height: 200px;
  padding: 10px;
  width: 100%
}

option {
  font-size: 1.4rem!important
}

label {
  cursor: pointer
}

label:hover {
  color: #999
}

input[type=checkbox], input[type=radio] {
  margin-right: 3px
}

.formErr {
  color: #e54e52;
  font-weight: 700
}

select.slctArea {
  box-sizing: border-box;
  margin-bottom: 5px;
  padding: 8px
}

select.slctArea[multiple=multiple] option {
  background-color: transparent!important
}

input.inputErr, textarea.inputErr {
  background-color: #fadfde
}

input:focus, select:focus, textarea:focus {
  background-color: #eee
}

.req {
  background-color: #e60012;
  color: #fff;
  font-size: 1.1rem;
  padding: .4em .8em;
  margin-left: 3px;
  margin-right: 5px
}

.agreeBtn {
  margin-top: 1em
}

.errText {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #c1341d;
  font-size: .9em;
  font-weight: 600;
  margin-bottom: 1em
}

.errText+.errText {
  margin-top: 0
}

.cauText {
  color: #333;
  font-size: .85em;
  line-height: 1.4!important;
  margin-top: 1em
}

.inputClm2 li {
  float: none;
  width: auto;
  margin-bottom: 0
}

.inputClm2 li:nth-child(2) {
  float: none;
  margin-left: 1em
}

.inputClm2 li input, .inputClm2 li span {
  display: inline-block;
  vertical-align: middle
}

.inputClm2 li span {
  margin-right: 1em
}

@media (max-width:1024px) {
  .inputClm2 li {
    display: block;
    width: 100%
  }
  .inputClm2 li span {
    display: block;
    margin-bottom: 1em;
    width: auto;
    margin-right: 0
  }
  .inputClm2 li input {
    width: 100%
  }
  .inputClm2 li:nth-child(2) {
    margin-top: 1em;
    margin-left: 0
  }
}

.cBoxList li {
  display: inline-block
}

.cBoxList li+li {
  margin-left: 1.5em
}

@media (max-width:768px) {
  .cBoxList li {
    display: block;
    margin-top: 1em
  }
  .cBoxList li+li {
    margin-left: 0
  }
}

.cBoxList li label {
  position: relative;
  margin: .5em;
  cursor: pointer
}

.cBoxList li label input {
  position: relative;
  margin: 0 1rem 0 0;
  cursor: pointer
}

.cBoxList li label input::after, .cBoxList li label input::before {
  position: absolute;
  content: ""
}

.cBoxList li label input::before {
  z-index: 1;
  top: 1.25px;
  top: .125rem;
  left: 1.88px;
  left: .1875rem;
  width: 7.5px;
  width: .75rem;
  height: 3.75px;
  height: .375rem;
  -webkit-transition: -webkit-transform .2s cubic-bezier(.45, 1.8, .5, .75);
  transition: -webkit-transform .2s cubic-bezier(.45, 1.8, .5, .75);
  transition: transform .2s cubic-bezier(.45, 1.8, .5, .75);
  transition: transform .2s cubic-bezier(.45, 1.8, .5, .75), -webkit-transform .2s cubic-bezier(.45, 1.8, .5, .75);
  -webkit-transform: rotate(-45deg) scale(0, 0);
  transform: rotate(-45deg) scale(0, 0);
  border: 2px solid #0068b7;
  border-top-style: none;
  border-right-style: none
}

.selectBox select, a {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

.cBoxList li label input:checked::before {
  -webkit-transform: rotate(-45deg) scale(1, 1);
  transform: rotate(-45deg) scale(1, 1)
}

.cBoxList li label input::after {
  top: -1.25px;
  top: -.125rem;
  left: 0;
  width: 10px;
  width: 1rem;
  height: 10px;
  height: 1rem;
  cursor: pointer;
  border: 2px solid #ccc;
  background: #fff
}

.cBoxList+.cBoxList {
  margin-top: 1.5em
}

@media (max-width:768px) {
  .cBoxList+.cBoxList {
    margin-top: 1em
  }
}

.formAddressArea .selectBox, .formAddressArea p:not(.first) {
  margin-top: 1em
}

.selectBox {
  max-width: 470px;
  width: 100%;
  position: relative;
  background: #efefef
}

.selectBox select {
  width: 100%;
  padding: .7em 1em .5em;
  cursor: pointer;
  text-indent: .01px;
  text-overflow: ellipsis;
  outline: 0;
  background: 0 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 2px solid transparent;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

.selectBox select::-ms-expand {
  display: none
}

.selectBox::before {
  width: 0;
  height: 0;
  padding: 0;
  content: "";
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 8px solid #009dda;
  pointer-events: none;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 15px
}

.privacyCheckBox {
  max-width: 1000px;
  border: 4px solid #009dda;
  padding: 3em;
  margin: 5em auto 0
}

.privacyCheckBox .inr {
  max-width: 800px;
  margin: 0 auto
}

.privacyCheckBox h3 {
  font-size: 1.2em;
  padding-bottom: 1em;
  border-bottom: 1px solid #009dda
}

.privacyCheckBox p {
  margin-top: 2em
}

.privacyCheckBox p.caution {
  color: #c1341d
}

.privacyCheckBox .bscBtn01 {
  max-width: 320px;
  margin: 2em auto 0
}

.privacyCheckBox .bscBtn01 a {
  background-color: #0068b7;
  font-family: "Noto Serif JP", serif;
  font-size: 1.1em
}

.privacyCheckBox .bscBtn01 a i {
  position: static;
  font-size: .6em;
  margin-right: .5em
}

.privacyCheckBox .bscBtn01 a:hover {
  background-color: rgba(0, 104, 183, .8)
}

.privacyCheckBox .agreeBtn {
  padding: 1em;
  border: 2px solid #eeb5b1;
  background-color: #ffeeed
}

.privacyCheckBox .agreeBtn label {
  position: relative;
  margin: .5em;
  cursor: pointer
}

.privacyCheckBox .agreeBtn label input {
  position: relative;
  margin: 0 1rem 0 0;
  cursor: pointer
}

.privacyCheckBox .agreeBtn label input::before {
  position: absolute;
  z-index: 1;
  top: 1.25px;
  top: .125rem;
  left: 1.88px;
  left: .1875rem;
  width: 7.5px;
  width: .75rem;
  height: 3.75px;
  height: .375rem;
  content: "";
  -webkit-transition: -webkit-transform .2s cubic-bezier(.45, 1.8, .5, .75);
  transition: -webkit-transform .2s cubic-bezier(.45, 1.8, .5, .75);
  transition: transform .2s cubic-bezier(.45, 1.8, .5, .75);
  transition: transform .2s cubic-bezier(.45, 1.8, .5, .75), -webkit-transform .2s cubic-bezier(.45, 1.8, .5, .75);
  -webkit-transform: rotate(-45deg) scale(0, 0);
  transform: rotate(-45deg) scale(0, 0);
  border: 2px solid #0068b7;
  border-top-style: none;
  border-right-style: none
}

.privacyCheckBox .agreeBtn label input:checked::before {
  -webkit-transform: rotate(-45deg) scale(1, 1);
  transform: rotate(-45deg) scale(1, 1)
}

.privacyCheckBox .agreeBtn label input::after {
  position: absolute;
  top: -1.25px;
  top: -.125rem;
  left: 0;
  width: 10px;
  width: 1rem;
  height: 10px;
  height: 1rem;
  content: "";
  cursor: pointer;
  border: 2px solid #ccc;
  background: #fff
}

@media (max-width:1024px) {
  #breadCrumbs {
    display: none
  }
  #contents {
    margin: 0 auto;
    width: 100%
  }
  #main {
    float: none;
    width: 100%
  }
  #main .topicsList article {
    width: 48.5%;
    margin: 0
  }
  #main .topicsList article:nth-child(2n) {
    float: right
  }
  #main .topicsList article+article+article {
    margin-top: 3em
  }
}

@media (max-width:1024px) and (max-width:480px) {
  #main .topicsList article {
    width: 100%;
    float: none
  }
  #main .topicsList article:nth-child(2n) {
    float: none
  }
  #main .topicsList article+article {
    margin-top: 2em
  }
}

@media (max-width:1024px) {
  .bscBox01, .bscBox02 {
    padding: 5%
  }
  .bscTbl01 td, .bscTbl01 th {
    display: block;
    padding: 10px 3%;
    width: 100%
  }
  .clm3 li, .clm4 li {
    margin-right: 0;
    width: 48.5%
  }
  .bscTbl01.scroll td, .bscTbl01.scroll th {
    display: table-cell
  }
  .clm4 li {
    float: left
  }
  .clm4 li.even, .clm4 li:nth-child(2n) {
    float: right
  }
  .clm4 li+li+li {
    margin-top: 2em
  }
  .clm4 li:nth-child(4n) {
    margin-right: 0
  }
  .clm3 li {
    float: left
  }
  .clm3 li.even, .clm3 li:nth-child(2n) {
    float: right
  }
  .subscribeBtn input {
    padding: 15px 0 13px;
    margin-top: 5px;
    width: 100%
  }
  input.wL, input.wLL, input.wM, input.wS, input.wSS {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
  }
  .wSS {
    width: 30%
  }
  .wS {
    width: 50%
  }
  .wL, .wLL, .wM {
    width: 100%
  }
  .imeOn {
    ime-mode: active
  }
  .imeOff {
    ime-mode: disabled
  }
  textarea.txtarea {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    height: 200px;
    width: 100%
  }
  select.timearea {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 50%
  }
  option {
    font-size: 1.4rem!important
  }
  label {
    cursor: pointer
  }
  label:hover {
    color: #999
  }
  input[type=checkbox], input[type=radio] {
    margin-right: 3px
  }
  .formErr {
    color: #e54e52;
    font-weight: 700
  }
  input.inputErr, textarea.inputErr {
    background-color: #fadfde
  }
  .req {
    font-size: 10px;
    line-height: 100%;
    margin-left: 3px;
    padding: 2px 5px;
    margin-right: 5px;
    vertical-align: middle
  }
  .cauText {
    display: block
  }
  body {
    padding-top: 0
  }
}

.editor .editorBtn01 a, body * {
  -webkit-box-sizing: border-box
}

a, a:focus, a:hover, a:link {
  color: #333;
  cursor: pointer;
  outline: 0;
  text-decoration: none
}

body::after, html {
  background-color: #fff
}

html {
  font-size: 62.5%
}

body, dd, dl, dt, h1, h2, h3, h4, h5, h6, img, li, ol, p, pre, ul {
  margin: 0;
  padding: 0
}

body {
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, メイリオ, verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.3em;
  font-size: 13px;
  color: #000;
  font-weight: 500;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
  letter-spacing: 1px;
  padding-top: 0;
  background-repeat: repeat
}

@media (max-width:480px) {
  body {
    font-size: 12px
  }
}

@media all and (-ms-high-contrast:none) {
  body {
    font-family: "メイリオ", Meiryo, "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
  }
}

body * {
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box
}

body h1, body h2, body h3, body h4, body h5, body h6 {
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, メイリオ, verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 600
}

a {
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden
}

a:focus, a:hover, a:link {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

a:hover {
  text-decoration: none
}

ol, ul {
  list-style-type: none
}

::selection {
  background-color: rgba(0, 104, 183, .7);
  color: #fff
}

::-moz-selection {
  background-color: rgba(0, 104, 183, .7);
  color: #fff
}

body::after {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: opacity .8s ease;
  transition: opacity .8s ease
}

body.fadeOut::after {
  opacity: 1;
  visibility: visible
}

.moveBox .inr {
  display: block;
  position: relative;
  width: auto;
  font-style: normal
}

#header #gNav ul li, .imgShadow img {
  display: inline-block
}

.moveBox .inr:after, .moveBox .inr:before {
  height: 100%;
  content: "";
  position: absolute;
  top: 0;
  left: 0
}

.moveBox .inr:before {
  background-color: #009dda;
  width: 100%;
  z-index: 2;
  -webkit-transition: all .8s cubic-bezier(.77, 0, .175, 1);
  transition: all .8s cubic-bezier(.77, 0, .175, 1)
}

.moveBox .inr:after {
  background-color: #0068b7;
  width: 100%;
  z-index: 1;
  -webkit-transition: all .8s cubic-bezier(.77, 0, .175, 1);
  transition: all .8s cubic-bezier(.77, 0, .175, 1);
  -webkit-transition-delay: .1s;
  transition-delay: .1s
}

.moveBox.vt.showTime .inr:after, .moveBox.vt.showTime .inr:before {
  top: 100%
}

.moveBox.hr.showTime .inr:after, .moveBox.hr.showTime .inr:before {
  left: 100%
}

.fadeIn {
  opacity: 0;
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  -webkit-transition: all .8s cubic-bezier(.25, .46, .45, .94);
  transition: all .8s cubic-bezier(.25, .46, .45, .94)
}

.fadeIn.on {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

.fadeBlur, body.scroll #bkgColorBox .copy {
  opacity: 0
}

.fadeIn.fadeOnly {
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

.fadeBlur {
  -webkit-filter: blur(100px);
  filter: blur(100px);
  -webkit-transition: all .8s cubic-bezier(.25, .46, .45, .94);
  transition: all .8s cubic-bezier(.25, .46, .45, .94)
}

#header, .imgShadow img {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

.fadeBlur.on {
  opacity: 1!important;
  -webkit-filter: blur(0)!important;
  filter: blur(0)!important
}

.imgShadow {
  line-height: 0
}

.imgShadow img {
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  -webkit-transform: translate(7px, 7px);
  transform: translate(7px, 7px);
  -webkit-transition-delay: .8s;
  transition-delay: .8s;
  max-width: 100%
}

.imgShadow.on img {
  -webkit-transform: translate(0);
  transform: translate(0);
  -webkit-box-shadow: 14px 14px 0 #f0f0f0;
  box-shadow: 14px 14px 0 #f0f0f0
}

@media (max-width:768px) {
  .imgShadow img {
    -webkit-transform: translate(3px, 3px);
    transform: translate(3px, 3px)
  }
  .imgShadow.on img {
    -webkit-box-shadow: 6px 6px 0 #f0f0f0;
    box-shadow: 6px 6px 0 #f0f0f0
  }
}

#header #gNav, #header .logo {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%)
}

body.scroll #header {
  background-color: rgba(255, 255, 255, .6);
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, .6);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, .6);
  height: 60px
}

body.scroll #header #gNav li a {
  color: #000
}

#header {
  position: fixed;
  z-index: 600;
  top: 0;
  width: 100%;
  height: 110px;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#header .logo {
  transform: translateY(-50%);
  width: 230px;
  left: 0;
  margin: 0 20px
}

#header .logo a img {
  max-width: 100%;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#header .logo a:hover img {
  opacity: .8
}

#header #gNav {
  transform: translateY(-50%);
  right: 30px
}

#header #gNav ul li a {
  display: block;
  font-size: 16px;
  padding: 8px 20px;
  text-decoration: none;
  color: #fff;
  font-weight: 600
}

@media (min-width:767px) {
  #header #gNav ul li a:hover {
    color: #0068b7
  }
}

#spHeader, #spNav, .spMenu {
  display: none
}

@media (max-width:1024px) {
  #spHeader, #spHeader .logo a img {
    width: 100%
  }
  #gNav, #header, #sideBar {
    display: none
  }
  #spHeader {
    background-color: rgba(89, 165, 222, .8);
    height: 60px;
    padding: 7px 0;
    display: block;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 980;
    -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
    transition: all .3s cubic-bezier(.455, .03, .515, .955)
  }
  #spHeader #spNav, #spHeader .spMenu span {
    -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
  }
  #spHeader .logo {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 10px
  }
  #spHeader .logo a {
    display: block;
    max-width: 230px
  }
  #spHeader ul {
    overflow: hidden;
    zoom: 1;
    position: absolute;
    right: 55px;
    top: 16px
  }
  #spHeader li {
    float: left;
    margin: 0 5px;
    text-align: center
  }
  #spHeader li a {
    color: #fff;
    line-height: 1
  }
  #spHeader .spMenu {
    cursor: pointer;
    display: block;
    height: 60px;
    width: 60px;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 1010
  }
  #spHeader .spMenu span {
    background-color: #fff;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: inline-block;
    vertical-align: top;
    zoom: 1;
    height: 2px;
    width: 34px;
    position: absolute;
    right: 13px;
    transition: all .3s cubic-bezier(.455, .03, .515, .955)
  }
  #spHeader .spMenu span:nth-of-type(1) {
    top: 18px
  }
  #spHeader .spMenu span:nth-of-type(2) {
    top: 28px
  }
  #spHeader .spMenu span:nth-of-type(3) {
    top: 38px
  }
  #spHeader .spMenu.active {
    height: 40px;
    width: 40px
  }
  #spHeader .spMenu.active span {
    background-color: #000
  }
  #spHeader .spMenu.active span:nth-of-type(1) {
    -webkit-transform: translateY(10px) rotate(-45deg);
    transform: translateY(10px) rotate(-45deg)
  }
  #spHeader .spMenu.active span:nth-of-type(2) {
    opacity: 0
  }
  #spHeader .spMenu.active span:nth-of-type(3) {
    -webkit-transform: translateY(-10px) rotate(45deg);
    transform: translateY(-10px) rotate(45deg)
  }
  #spHeader .spMenu.active small {
    color: #000
  }
  #spHeader #spNav {
    height: 100%;
    display: block;
    transition: all .3s cubic-bezier(.455, .03, .515, .955);
    visibility: hidden;
    padding-top: 59px;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 990;
    -webkit-transform: translateY(5%);
    transform: translateY(5%);
    background-color: #fff;
    opacity: 0
  }
  #spHeader #spNav.active {
    visibility: visible;
    opacity: 1;
    top: 0;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
  #spHeader #spNav #spBg {
    height: 100%;
    width: 500%;
    position: fixed;
    right: -50%;
    top: 0;
    z-index: -1;
    opacity: 0;
    -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
    transition: all .3s cubic-bezier(.455, .03, .515, .955);
    pointer-events: none
  }
  #spHeader #spNav.active #spBg {
    right: 0;
    opacity: 1;
    pointer-events: auto
  }
  #spHeader #spNav::after {
    background-color: #f9f9f9;
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1
  }
  #spHeader #spNav::after, #spHeader #spNav::before {
    opacity: 0;
    -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
    transition: all .3s cubic-bezier(.455, .03, .515, .955)
  }
  #spHeader #spNav.active::after, #spHeader #spNav.active::before {
    opacity: 1
  }
  #spHeader #spNav .closeBtn {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 15px 3%;
    text-align: right
  }
  #spHeader #spNav nav {
    border-top: 1px solid #eee;
    -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
    transition: all .3s cubic-bezier(.455, .03, .515, .955);
    height: calc(100vh - 59px);
    overflow-y: scroll
  }
  #spHeader #spNav nav ul {
    position: static
  }
  #spHeader #spNav nav ul li {
    border-bottom: 1px solid #eee;
    width: 100%;
    float: none;
    margin: 0
  }
  #spHeader #spNav nav ul li.logoImg a {
    padding: 5px 0
  }
  #spHeader #spNav nav ul li.logoImg a img {
    max-width: 160px
  }
  #spHeader #spNav nav ul li button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%
  }
  #spHeader #spNav nav ul li a, #spHeader #spNav nav ul li button, #spHeader #spNav nav ul li span {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #666;
    font-weight: 300;
    text-align: center;
    display: block;
    padding: 20px 10px;
    position: relative
  }
}

#bkgColorBox, #bkgColorBox .bkgSlider div {
  height: 100vh
}

@media (max-width:1024px) and (max-width:480px) {
  #spHeader #spNav nav ul li a, #spHeader #spNav nav ul li button, #spHeader #spNav nav ul li span {
    font-size: 2.70833vw
  }
}

@media (max-width:1024px) {
  #spHeader #spNav nav ul li a i, #spHeader #spNav nav ul li button i, #spHeader #spNav nav ul li span i {
    font-size: 1.3em;
    color: #0068b7;
    text-align: right;
    margin: -.5em auto auto;
    position: absolute;
    right: 5%;
    top: 50%;
    z-index: 2
  }
  #spHeader #spNav nav ul li a:hover {
    background-color: rgba(0, 73, 114, .63);
    color: #fff;
    text-decoration: none
  }
  #spHeader #spNav nav ul li a:hover::before {
    color: #fff
  }
  #spHeader #spNav nav ul li .subNav {
    display: none
  }
  #spHeader #spNav nav ul li .subNav li {
    border-bottom: none
  }
  #spHeader #spNav nav ul li .subNav li a {
    font-size: .8em;
    padding: 14px 2em 12px 1.5em
  }
  #spHeader #spNav nav ul li.sub span {
    position: relative
  }
  #spHeader #spNav nav ul li.sub span::after, #spHeader #spNav nav ul li.sub span::before {
    content: "";
    display: block;
    width: 9px;
    border-bottom: 1px solid #0068b7;
    right: 6.3%;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
    transition: all .3s cubic-bezier(.455, .03, .515, .955)
  }
  #spHeader #spNav nav ul li.sub span::after {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
  }
  #spHeader #spNav nav ul li.sub span.active::after {
    -webkit-transform: rotate(0);
    transform: rotate(0)
  }
}

#bkgColorBox .copy, .editor .editorBtn01 a i {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#footer {
  background-color: #fff;
  padding: 60px 0 90px;
  width: 100%
}

@media (max-width:768px) {
  #footer {
    padding: 40px 0
  }
}

#footer .ftInr {
  margin: 0 auto;
  position: relative;
  max-width: 1200px;
  width: 97%
}

#footer .ftInr .fL {
  float: left;
  width: 45%
}

@media (max-width:1024px) {
  #footer .ftInr .fL {
    float: none;
    width: 100%;
    text-align: center;
    margin-bottom: 10px
  }
}

#footer .ftInr .fL .flogo {
  margin-bottom: 10px
}

#footer .ftInr .fL .flogo img {
  width: 230px
}

@media (max-width:1024px) {
  #footer .ftInr .fL .flogo img {
    width: 100%;
    max-width: 300px
  }
}

.editor iframe, .editor img, .editor table {
  max-width: 100%
}

#footer .ftInr .fL .linkList li {
  display: inline-block;
  padding-right: 10px
}

#footer .ftInr .fL .linkList li:last-child {
  padding-right: 0
}

@media (max-width:768px) {
  #footer .ftInr .fL .linkList li {
    padding-right: 20px
  }
}

#footer .ftInr .fL .linkList li a {
  font-size: 13px
}

#footer .ftInr .fL .linkList li a i {
  font-size: 10px
}

#footer .ftInr .fR {
  float: right;
  width: 55%
}

#footer .ftInr .fR .linkList {
  text-align: right
}

@media (max-width:1024px) {
  #footer .ftInr .fL .linkList li a {
    font-size: 15px
  }
  #footer .ftInr .fR {
    float: none;
    width: 100%
  }
  #footer .ftInr .fR .linkList {
    text-align: center
  }
}

@media (max-width:480px) {
  #footer .ftInr .fL .linkList, #footer .ftInr .fR .linkList {
    margin-bottom: 20px
  }
}

#footer .ftInr .fR .linkList.mb10 {
  margin-bottom: 10px
}

@media (max-width:480px) {
  #footer .ftInr .fR .linkList.mb10 {
    margin-bottom: 20px
  }
}

#footer .ftInr .fR .linkList li {
  display: inline-block;
  padding-right: 10px
}

.editor h2::after, .editor h3::after {
  display: block;
  content: ""
}

#footer .ftInr .fR .linkList li:last-child {
  padding-right: 0
}

#footer .ftInr .fR .linkList li a {
  font-size: 15px
}

.footer-pmark {
  position: absolute;
  right: 0;
  bottom: -78px;
}

.footer-pmark img {
  max-width: 80px;
  height: auto;
  width: 7vw;
}

@media(max-width:1390px) {
  .footer-pmark {
    right: 3vw;
  }
  @media(max-width:1390px) {
    .footer-pmark {
      right: 80px;
    }
    @media(max-width:1024px) {
      #footer {
        padding: 60px 0 30px;
      }
      .footer-pmark {
        margin-top: 2em;
        position: relative;
        right: 0;
        bottom: 0;
        text-align: center;
      }
      .footer-pmark img {
        width: 80px;
      }
    }
  }
}

@media (min-width:767px) {
  #footer .ftInr .fL .linkList li a:hover, #footer .ftInr .fR .linkList li a:hover {
    text-decoration: underline;
    color: #0068b7
  }
  .footer-pmark img {
    width: 70px;
  }
}

#bkgColorBox {
  width: 100vw;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1
}

#bkgColorBox .bkgSlider {
  margin: 0;
  overflow: hidden;
  position: relative;
  z-index: -5
}

#bkgColorBox .bkgSlider div img {
  width: 100%;
  height: 100%
}

#bkgColorBox .bkgColorBoxInr {
  width: 100vw;
  height: 100vh;
  opacity: .4;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: linear-gradient(30deg, #1bd2e0, #5fb3e5 30%, #83e3c7 60%, #cce592 100%);
  -webkit-animation: Gradient 5s ease infinite;
  animation: Gradient 5s ease infinite
}

.bscBtn01 a:hover, .editor .editorBtn01 a:hover {
  opacity: .8
}

#bkgColorBox .copy {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  right: 50px;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  z-index: 1
}

@media (max-width:1300px) {
  #bkgColorBox .copy {
    right: 1%
  }
}

#bkgColorBox .copy p {
  font-size: 11px;
  color: #fff;
  font-family: Roboto, sans-serif
}

@-webkit-keyframes Gradient {
  0%, 100% {
    background-position: 50% 0
  }
  50% {
    background-position: 50% 100%
  }
}

@keyframes Gradient {
  0%, 100% {
    background-position: 50% 0
  }
  50% {
    background-position: 50% 100%
  }
}

.editor {
  margin-bottom: 60px
}

.editor img {
  height: auto
}

.editor p {
  line-height: 2;
  font-size: 18px;
  table-layout: fixed
}

.editor h2, .editor h3 {
  color: #000;
  font-size: 20px;
  font-weight: 600;
  padding-bottom: 10px
}

.editor h1, .editor h2, .editor h3, .editor h4, .editor h5, .editor h6 {
  line-height: 1.4;
  margin-bottom: 1em
}

.editor h2 {
  position: relative
}

.editor h2::after {
  width: 100%;
  height: 2px;
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%);
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: 0
}

.editor h3 {
  padding-left: 1em;
  position: relative
}

.editor h3::after {
  width: .8em;
  height: 3px;
  position: absolute;
  top: 40%;
  -webkit-transform: translate(-1em, -50%);
  transform: translate(-1em, -50%);
  background-color: #009dda
}

.bscBtn01 a i, .bscBtn02 a i, .uniqBtn01 a i {
  top: 38%;
  font-weight: 600
}

.editor ul {
  margin-bottom: 15px
}

.editor ul li {
  line-height: 170%;
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 5px;
  position: relative
}

.editor ul li::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  left: 0;
  background-color: #acacac;
  border-radius: 10px;
  margin-right: .5em
}

.editor table {
  width: auto!important
}

.editor table td, .editor table th {
  line-height: 2;
  font-size: 18px
}

.editor table td p, .editor table th p {
  table-layout: fixed;
  word-wrap: break-word
}

@media (max-width:768px) {
  #footer .ftInr .fR .linkList li {
    padding-right: 20px
  }
  .editor table {
    width: 100%!important
  }
  .editor table td, .editor table th {
    display: block;
    width: 100%
  }
}

.editor a {
  text-decoration: underline
}

.bscBtn01 a, .editor .editorBtn01 a {
  zoom: 1;
  text-decoration: none;
  letter-spacing: 0
}

.editor .editorImgName {
  text-align: right;
  line-height: 0
}

.editor .editorImgName p {
  padding: 5px 20px;
  color: #fff;
  line-height: 1.2;
  font-size: 16px;
  text-align: right;
  background-color: #009dda;
  display: inline-block
}

.editor .editorPdfLink {
  margin: 10px 0
}

.editor .editorPdfLink a {
  color: #0068b7;
  font-weight: 900;
  font-size: 16px
}

.editor .editorPdfLink a img {
  width: 18px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 10px
}

.editor .editorFltImgWrap {
  overflow: hidden;
  margin-bottom: 3em
}

.editor .editorFltImgL {
  float: left;
  margin: 0 25px 20px 0
}

.editor .editorFltImgR {
  float: right;
  margin: 0 0 20px 25px
}

.editor .editorFltImgL, .editor .editorFltImgR {
  max-width: 45%;
  margin-bottom: 0
}

.editor .editorBtn01 {
  text-align: center
}

.editor .editorBtn01 a {
  box-sizing: border-box;
  display: inline-block;
  vertical-align: top;
  line-height: 140%;
  position: relative;
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%);
  font-size: 15px;
  padding: 20px 80px;
  color: #fff;
  border-radius: 50px
}

.editor .editorBtn01 a i {
  font-size: 1em;
  font-weight: 600;
  right: 3%;
  top: 38%;
  position: absolute;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  left: 30px;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

@media (max-width:1024px) {
  .editor .editorFltImgL, .editor .editorFltImgR {
    max-width: 100%;
    float: none;
    margin: 0;
    text-align: center
  }
  .editor .editorFltImgL img, .editor .editorFltImgR img {
    max-width: 100%;
    margin-bottom: 5px
  }
  .editor .editorBtn01 a {
    display: block;
    padding: 15px 20px 13px;
    width: 100%;
    max-width: 100%
  }
}

.editor .editorTbl01 table {
  width: 100%!important
}

.editor .editorTbl01 table td, .editor .editorTbl01 table th {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-bottom: 1px solid #d1dde2;
  line-height: 1.4;
  padding: 20px 20px 17px;
  text-align: left
}

.bscBtn01 a, .bscBtn02 a {
  -webkit-box-sizing: border-box;
  color: #fff
}

.editor .editorTbl01 table tr.head th {
  background-color: #009dda;
  color: #fff;
  border-right: 1px solid #fff
}

.editor .editorTbl01 table tr.head th:nth-child(2) {
  background-color: rgba(0, 157, 218, .8)
}

.editor .editorTbl01 table tr:last-child th {
  border-bottom: 1px solid #dedede
}

.editor .editorTbl02 table {
  width: 100%
}

.editor .editorTbl02 table td, .editor .editorTbl02 table th {
  vertical-align: top;
  border-bottom: none;
  padding: 0 0 20px;
  text-align: left;
  font-size: 18px
}

@media (max-width:768px) {
  .editor .editorTbl02 table {
    display: block
  }
  .editor .editorTbl02 table td, .editor .editorTbl02 table th {
    font-size: 14px;
    display: block;
    width: 100%
  }
}

.editor .editorTbl02 table th {
  text-align: center;
  width: 180px;
  color: #fff
}

@media (max-width:768px) {
  .editor .editorTbl02 table th {
    width: auto;
    text-align: left
  }
}

.bscBtn01, .uniqBtn01 {
  text-align: center
}

.editor .editorTbl02 table th.color01 span {
  padding: 5px 20px;
  border-radius: 25px;
  background-color: #0068b7
}

.editor .editorTbl02 table th.color02 span {
  padding: 5px 20px;
  border-radius: 25px;
  background-color: #009dda
}

.editor .editorTbl02 table td {
  font-size: 16px
}

@media (max-width:768px) {
  .editor .editorTbl02 table td {
    font-size: 14px;
    display: block;
    width: 100%
  }
}

.bscBtn01 a {
  box-sizing: border-box;
  display: inline-block;
  vertical-align: top;
  line-height: 140%;
  position: relative;
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%);
  font-size: 15px;
  padding: 20px 80px;
  border-radius: 50px
}

.bscBtn01 a i {
  font-size: 1em;
  right: 3%;
  position: absolute;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  left: 30px;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

@media (max-width:1024px) {
  .bscBtn01 a {
    display: block;
    padding: 15px 20px 13px;
    width: 100%;
    max-width: 100%
  }
}

.bscBtn02 a, .uniqBtn01 a {
  display: inline-block;
  vertical-align: top;
  letter-spacing: .2em;
  line-height: 140%
}

.bscBtn01.wNormal {
  max-width: 370px;
  margin: 0 auto
}

.bscBtn02 a {
  font-size: 1.3rem;
  box-sizing: border-box;
  zoom: 1;
  padding: 15px 20px 13px;
  text-decoration: none;
  position: relative;
  border: 1px solid #fff
}

#top #sec04 .btnLink li a, .uniqBtn01 a {
  -webkit-box-sizing: border-box;
  zoom: 1;
  text-decoration: none
}

.bscBtn02 a i {
  font-size: 1em;
  position: absolute;
  right: 3%
}

.bscBtn02 a:hover {
  background-color: #fff;
  color: #0068b7
}

.bscBtn02 a:hover i {
  color: #0068b7
}

.uniqBtn01 a {
  box-sizing: border-box;
  background-color: transparent;
  font-size: 11px;
  padding: 20px 0;
  color: #000;
  border: 1px solid #000;
  margin: 0 auto;
  width: 200px;
  position: relative;
  overflow: hidden;
  z-index: 1
}

.uniqBtn01 a i {
  font-size: 1em;
  position: absolute;
  right: 3%
}

@media (max-width:1024px) {
  .uniqBtn01 a {
    display: block;
    padding: 20px 5%;
    width: 100%;
    max-width: 100%
  }
}

.uniqBtn01 a::after, .uniqBtn01 a::before {
  content: "";
  position: absolute;
  -webkit-transition: all .3s;
  transition: all .3s;
  width: 100%;
  height: 100%;
  z-index: -1
}

#news #main .newsList li dl, #news #main .newsTitle li a {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

.uniqBtn01 a::after {
  bottom: 0;
  left: 0
}

.uniqBtn01 a::before {
  opacity: 0;
  top: 0;
  right: 0;
  background: rgba(76, 93, 118, .6);
  -webkit-transform: scale(.1, 1);
  transform: scale(.1, 1)
}

.uniqBtn01 a:hover {
  letter-spacing: 5px;
  color: #fff;
  font-weight: 600
}

.uniqBtn01 a:hover::before {
  opacity: 1;
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1)
}

.uniqBtn01 a:hover::after {
  -webkit-transform: scale(1, .1);
  transform: scale(1, .1);
  opacity: 0
}

@media (max-width:768px) {
  .uniqBtn01 a:hover {
    letter-spacing: .2em;
    color: #000;
    font-weight: 500
  }
  .uniqBtn01 a:hover::before {
    opacity: 0
  }
  .uniqBtn01 a:hover::after {
    -webkit-transform: scale(1, .1);
    transform: scale(1, .1);
    opacity: 0
  }
}

#news #main .detail .contactBox .mail:hover, #news #main .detail .contactBox .tel:hover, #news #main .newsTitle li:hover a {
  opacity: .8
}

.head01Inr.tL {
  text-align: left
}

.head01Inr.tL .head01::before {
  left: 0
}

.head01Inr.tL .head01::after {
  right: -10%
}

.head01Inr.tR {
  text-align: right
}

.head01Inr.tR .head01::before {
  right: 0
}

.head01Inr.tR .head01::after {
  left: -10%
}

.head01Inr .head01 {
  display: inline-block;
  font-size: 76px;
  color: #000;
  font-family: "Josefin Sans", sans-serif;
  letter-spacing: -3px;
  position: relative;
  line-height: 1
}

@media (max-width:1024px) {
  .head01Inr .head01 {
    font-size: 62px
  }
}

@media (max-width:768px) {
  .head01Inr .head01 {
    font-size: 52px
  }
}

@media (max-width:480px) {
  .head01Inr .head01 {
    font-size: 42px
  }
}

.head01Inr .head01::after, .head01Inr .head01::before {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 10px;
  position: absolute;
  letter-spacing: 3px
}

.head01Inr .head01::before {
  content: attr(data-text);
  top: -20px;
  display: block;
  line-height: 1.5
}

.head01Inr .head01::after {
  content: "";
  display: inline-block;
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#59a5de), to(#3ad0dd));
  background: linear-gradient(90deg, #59a5de 0, #3ad0dd 100%);
  opacity: .8;
  width: 100%;
  height: 40px;
  bottom: 0
}

@media (max-width:1024px) {
  .head01Inr .head01::after {
    height: 30px
  }
}

.head02 {
  text-align: center;
  color: #000;
  font-size: 34px;
  letter-spacing: 3px;
  line-height: 1.3
}

@media (max-width:768px) {
  .head01Inr .head01::after {
    height: 20px
  }
  .head01Inr .head01.spline::before {
    top: -50px
  }
  .head02 {
    font-size: 30px
  }
}

@media (max-width:480px) {
  .head01Inr .head01::after {
    height: 10px
  }
  .head02 {
    font-size: 28px
  }
}

.head02::after {
  content: attr(data-text);
  display: block;
  font-size: 15px;
  font-family: Heebo, sans-serif;
  color: #009dda
}

.head03 {
  position: relative;
  font-size: 28px;
  margin-bottom: 40px;
  color: #000
}

.head03::after, .head03::before {
  content: "";
  display: block;
  height: 2px;
  position: absolute;
  bottom: -20px;
  left: 0
}

.head03::before {
  width: 100%;
  background-color: #0068b7
}

.head03::after {
  width: 20%;
  background-color: #009dda
}

.head04::after, .head04::before, .head05::after, .head05::before {
  content: "";
  display: block;
  width: 2px;
  left: 0;
  top: 0
}

@media (max-width:768px) {
  .head03 {
    font-size: 22px
  }
}

@media (max-width:480px) {
  .head03 {
    font-size: 20px;
    margin-bottom: 50px
  }
}

.head04, .head05 {
  margin-bottom: 10px;
  padding-bottom: 5px
}

.head04 {
  border-bottom: 1px solid #999;
  position: relative;
  padding-left: 30px;
  font-size: 20px
}

@media (max-width:480px) {
  .head04 {
    font-size: 16px;
    padding-left: 15px
  }
}

.head04::after, .head04::before {
  background-color: #d6d5c6;
  height: 80%;
  position: absolute
}

.head04::before {
  background-color: #3d3d3d;
  height: 10px;
  z-index: 2
}

.head05 {
  position: relative;
  padding-left: 30px;
  font-size: 20px
}

@media (max-width:480px) {
  .head05 {
    font-size: 16px;
    padding-left: 15px
  }
}

.head05::after, .head05::before {
  background-color: #d6d5c6;
  height: 80%;
  position: absolute
}

.head05::before {
  background-color: #3d3d3d;
  height: 10px;
  z-index: 2
}

@font-face {
  font-family: icomoon;
  src: url(fonts/icomoon.eot?moiwxg);
  src: url(fonts/icomoon.eot?moiwxg#iefix) format("embedded-opentype"), url(fonts/icomoon.ttf?moiwxg) format("truetype"), url(fonts/icomoon.woff?moiwxg) format("woff"), url(fonts/icomoon.svg?moiwxg#icomoon) format("svg");
  font-weight: 400;
  font-style: normal;
  font-display: block
}

[class*=" icon-"], [class^=icon-] {
  font-family: icomoon!important;
  speak: none;
  font-style: normal;
  font-weight: 400;
  -webkit-font-feature-settings: normal;
  font-feature-settings: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

.clear, br.clear {
  clear: both;
  line-height: 0
}

.icon-mail02:before {
  content: "\e906"
}

.icon-download:before {
  content: "\e900"
}

.icon-tab:before {
  content: "\e901"
}

.icon-rigth:before {
  content: "\e902"
}

.icon-tel:before {
  content: "\e903"
}

.icon-mail:before {
  content: "\e904"
}

.icon-under:before {
  content: "\e905"
}

.icon-file-text2:before {
  content: "\e926"
}

.icon-folder:before {
  content: "\e92f"
}

.icon-phone-hang-up:before {
  content: "\e943"
}

.icon-cancel-circle:before {
  content: "\ea0d"
}

.icon-cross:before {
  content: "\ea0f"
}

.icon-arrow-up:before {
  content: "\ea32"
}

.icon-arrow-right:before {
  content: "\ea34"
}

.icon-arrow-down:before {
  content: "\ea36"
}

.icon-arrow-left:before {
  content: "\ea38"
}

.icon-arrow-up2:before {
  content: "\ea3a"
}

.icon-arrow-right2:before {
  content: "\ea3c"
}

.icon-arrow-down2:before {
  content: "\ea3e"
}

.icon-arrow-left2:before {
  content: "\ea40"
}

.icon-circle-up:before {
  content: "\ea41"
}

.icon-circle-right:before {
  content: "\ea42"
}

.icon-circle-down:before {
  content: "\ea43"
}

.icon-circle-left:before {
  content: "\ea44"
}

.icon-new-tab:before {
  content: "\ea7e"
}

.icon-facebook:before {
  content: "\ea90"
}

.icon-facebook2:before {
  content: "\ea91"
}

.icon-instagram:before {
  content: "\ea92"
}

.icon-twitter:before {
  content: "\ea96"
}

.icon-youtube:before {
  content: "\ea9d"
}

.icon-chevron-left:before {
  content: "\f053"
}

.icon-chevron-right:before {
  content: "\f054"
}

.icon-plus-circle:before {
  content: "\f055"
}

.icon-minus-circle:before {
  content: "\f056"
}

.icon-times-circle:before {
  content: "\f057"
}

.icon-check-circle:before {
  content: "\f058"
}

.icon-angle-double-left:before {
  content: "\f100"
}

.icon-angle-double-right:before {
  content: "\f101"
}

.icon-angle-left:before {
  content: "\f104"
}

.icon-angle-right:before {
  content: "\f105"
}

.icon-angle-up:before {
  content: "\f106"
}

.icon-angle-down:before {
  content: "\f107"
}

#contents {
  margin: 0 auto;
  width: 100%;
  overflow: hidden;
  background-color: #fff
}

section, section.last {
  margin-bottom: 0
}

section {
  clear: both;
  padding: 60px 0
}

.scInr, .scInrS, .scInrSS, .scInrW, .scInrWW {
  margin: 0 auto;
  width: 97%
}

.scInr {
  max-width: 1240px
}

.scInrS {
  max-width: 1000px
}

.scInrSS {
  max-width: 880px
}

.scInrW {
  max-width: 1366px
}

.scInrWW {
  max-width: 1550px
}

.is-pc {
  display: block!important
}

.is-sp {
  display: none!important
}

@media (max-width:768px) {
  .is-pc {
    display: none!important
  }
  .is-sp {
    display: block!important
  }
}

.cf:after, .cf:before {
  content: "";
  display: table
}

.spTel {
  pointer-events: none
}

.w5 {
  width: 5%!important
}

.w10 {
  width: 10%!important
}

.w15 {
  width: 15%!important
}

.w18 {
  width: 18%!important
}

.w20 {
  width: 20%!important
}

.w25 {
  width: 25%!important
}

.w30 {
  width: 30%!important
}

.w35 {
  width: 35%!important
}

.w40 {
  width: 40%!important
}

.w45 {
  width: 45%!important
}

.w50 {
  width: 50%!important
}

.w55 {
  width: 55%!important
}

.w60 {
  width: 60%!important
}

.w65 {
  width: 65%!important
}

.w70 {
  width: 70%!important
}

.w75 {
  width: 75%!important
}

.w80 {
  width: 80%!important
}

.w85 {
  width: 85%!important
}

.w90 {
  width: 90%!important
}

.w95 {
  width: 95%!important
}

.w100 {
  width: 100px
}

.w200 {
  width: 200px
}

.w300 {
  width: 300px
}

.w400 {
  width: 400px
}

.w450 {
  width: 450px
}

.w500 {
  width: 500px
}

.w600 {
  width: 600px
}

.wFull {
  width: 100%!important
}

.center {
  text-align: center!important
}

.left {
  text-align: left!important
}

.right {
  text-align: right!important
}

.top0 {
  margin-top: 0!important
}

.top5 {
  margin-top: 5px!important
}

.top10 {
  margin-top: 10px!important
}

.top15 {
  margin-top: 15px!important
}

.top20 {
  margin-top: 20px!important
}

.top25 {
  margin-top: 25px!important
}

.top30 {
  margin-top: 30px!important
}

.top35 {
  margin-top: 35px!important
}

.top40 {
  margin-top: 40px!important
}

.btm0 {
  margin-bottom: 0!important
}

.btm5 {
  margin-bottom: 5px!important
}

.btm10 {
  margin-bottom: 10px!important
}

.btm15 {
  margin-bottom: 15px!important
}

.btm20 {
  margin-bottom: 20px!important
}

.btm25 {
  margin-bottom: 25px!important
}

.btm30 {
  margin-bottom: 30px!important
}

.btm35 {
  margin-bottom: 35px!important
}

.btm40 {
  margin-bottom: 40px!important
}

.btm45 {
  margin-bottom: 45px!important
}

.btm50 {
  margin-bottom: 50px!important
}

.btm55 {
  margin-bottom: 55px!important
}

.btm60 {
  margin-bottom: 60px!important
}

.btm65 {
  margin-bottom: 65px!important
}

.btm70 {
  margin-bottom: 70px!important
}

.btm75 {
  margin-bottom: 75px!important
}

.btm80 {
  margin-bottom: 80px!important
}

.btm85 {
  margin-bottom: 85px!important
}

.btm90 {
  margin-bottom: 90px!important
}

.pT0 {
  padding-top: 0!important
}

.pT5 {
  padding-top: 5px!important
}

.pT10 {
  padding-top: 10px!important
}

.pT15 {
  padding-top: 15px!important
}

.pT20 {
  padding-top: 20px!important
}

.pT25 {
  padding-top: 25px!important
}

.pT30 {
  padding-top: 30px!important
}

.pT35 {
  padding-top: 35px!important
}

.pT40 {
  padding-top: 40px!important
}

.pT45 {
  padding-top: 45px!important
}

.pB0 {
  padding-bottom: 0!important
}

.pB5 {
  padding-bottom: 5px!important
}

.pB10 {
  padding-bottom: 10px!important
}

.pB15 {
  padding-bottom: 15px!important
}

.pB20 {
  padding-bottom: 20px!important
}

.lm5 {
  margin-left: 5px!important
}

.lm10 {
  margin-left: 10px!important
}

.lm15 {
  margin-left: 15px!important
}

.lm20 {
  margin-left: 20px!important
}

.lm50 {
  margin-left: 50px!important
}

.lm60 {
  margin-left: 60px!important
}

.lm70 {
  margin-left: 70px!important
}

.rm5 {
  margin-right: 5px!important
}

.rm10 {
  margin-right: 10px!important
}

.rm15 {
  margin-right: 15px!important
}

.rm20 {
  margin-right: 20px!important
}

.vAT {
  vertical-align: top!important
}

.vAM {
  vertical-align: middle!important
}

.vAB {
  vertical-align: bottom!important
}

.bold {
  font-weight: 700
}

.normal {
  font-weight: 400
}

.size10 {
  font-size: 1rem!important
}

.size11 {
  font-size: 1.1rem!important
}

.size12 {
  font-size: 1.2rem!important
}

.size13 {
  font-size: 1.3rem!important
}

.size14 {
  font-size: 1.4rem!important
}

.size15 {
  font-size: 1.5rem!important
}

.size16 {
  font-size: 1.6rem!important
}

.size17 {
  font-size: 1.7rem!important
}

.size18 {
  font-size: 1.8rem!important
}

.size19 {
  font-size: 1.9rem!important
}

.size20 {
  font-size: 2rem!important
}

.size21 {
  font-size: 2.1rem!important
}

.size22 {
  font-size: 2.2rem!important
}

.size23 {
  font-size: 2.3rem!important
}

.size24 {
  font-size: 2.4rem!important
}

.fltImgL {
  float: left;
  margin: 0 25px 20px 0
}

.fltImgR {
  float: right;
  margin: 0 0 20px 25px
}

.fltL {
  float: left
}

.fltR {
  float: right
}

.objectFitCover {
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;"
}

.cf {
  zoom: 1
}

.cf:after {
  clear: both
}

.cf_ {
  letter-spacing: -1em
}

.cf_ div, .cf_ li, .cf_ p {
  letter-spacing: normal
}

.clear, br.clear {
  display: inline!important;
  display: none
}

@media screen and (-webkit-min-device-pixel-ratio:0) {
  br.clear {
    display: block!important;
    content: " "
  }
}

@media (max-width:1024px) {
  section {
    padding: 30px 0
  }
  .scInr, .scInrS, .scInrW {
    float: none;
    margin: 0 3%;
    width: auto
  }
  .fltL, .fltR {
    float: none
  }
  .fltImgL, .fltImgR {
    float: none;
    margin: 0;
    text-align: center
  }
  .fltImgL img, .fltImgR img {
    max-width: 100%;
    margin-bottom: 5px
  }
}

#news .secTitleBox {
  margin-bottom: 60px
}

#news #main .newsTitle {
  background-color: rgba(255, 255, 255, .7);
  padding: 20px 10px;
  margin-bottom: 40px;
  -webkit-box-shadow: 0 0 10px -6px #7d7d7d;
  box-shadow: 0 0 10px -6px #7d7d7d
}

@media (max-width:1024px) {
  #news #main .newsTitle {
    padding-bottom: 0
  }
}

#news #main .newsTitle li {
  float: left;
  text-align: center;
  width: 200px;
  margin: 0 10px
}

#news #main .newsTitle li a {
  font-size: 15px;
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  border-radius: 25px;
  background-color: #d5e1e6;
  display: block;
  padding: 8px 0
}

#news #main .newsTitle li.active a {
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%);
  color: #fff
}

@media (max-width:1024px) {
  #news #main .newsTitle li {
    width: calc(50% - 20px);
    margin-bottom: 20px
  }
}

#news #main .newsList {
  background-color: rgba(255, 255, 255, .7);
  -webkit-box-shadow: 0 0 10px -6px #7d7d7d;
  box-shadow: 0 0 10px -6px #7d7d7d;
  padding: 60px
}

@media (max-width:768px) {
  #news #main .newsList {
    padding: 30px
  }
}

@media (max-width:480px) {
  #news #main .newsList {
    padding: 10px
  }
}

#news #main .newsList li {
  padding: 2em 0;
  border-bottom: 1px solid #d1dde2
}

#news #main .newsList li dl {
  display: table;
  table-layout: fixed;
  width: 100%;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#news #main .newsList li dl:hover {
  -webkit-transform: translateX(1em);
  transform: translateX(1em)
}

#news #main .newsList li dl dt {
  display: table-cell;
  vertical-align: middle;
  margin-right: 2em;
  font-size: .9em;
  width: 110px
}

#news #main .newsList li dl dt time {
  font-size: 16px;
  display: inline-block;
  vertical-align: middle;
  font-family: Heebo, sans-serif;
  color: #666
}

#news #main .newsList li dl dd {
  font-size: 15px;
  display: table-cell;
  vertical-align: middle;
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap
}

#news #main .detail {
  background-color: rgba(255, 255, 255, .7);
  -webkit-box-shadow: 0 0 10px -6px #7d7d7d;
  box-shadow: 0 0 10px -6px #7d7d7d;
  padding: 60px
}

@media (max-width:768px) {
  #news #main .newsList li dl, #news #main .newsList li dl dt {
    display: block
  }
  #news #main .newsList li dl dd {
    display: block;
    margin-top: 1em
  }
  #news #main .detail {
    padding: 30px
  }
}

@media (max-width:480px) {
  #news #main .detail {
    padding: 30px 10px
  }
}

#news #main .detail .detailTitleBox {
  margin-bottom: 30px
}

#news #main .detail .detailTitleBox h2.detailTitle {
  font-size: 30px;
  margin-bottom: 10px;
  font-weight: 400
}

@media (max-width:768px) {
  #news #main .detail .detailTitleBox h2.detailTitle {
    font-size: 24px;
    margin-bottom: 20px
  }
}

#news #main .detail .detailTitleBox time {
  font-size: 30px;
  display: block;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 0
}

@media (max-width:768px) {
  #news #main .detail .detailTitleBox time {
    font-size: 20px
  }
}

#news #main .detail .detailTitleBox span {
  font-size: 22px;
  display: block;
  margin-bottom: 15px;
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, メイリオ, verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}

@media (max-width:768px) {
  #news #main .detail .detailTitleBox span {
    font-size: 20px
  }
}

#news #main .detail .contactBox {
  border: 1px solid #d1dde2;
  background-color: #fff;
  padding: 30px;
  margin-bottom: 60px
}

@media (max-width:480px) {
  #news #main .detail .contactBox {
    padding: 10px
  }
}

#news #main .detail .contactBox .contactTitle {
  display: inline-block;
  background-color: #dbe8ee;
  font-size: 16px;
  padding: 8px;
  margin-bottom: 20px
}

#news #main .detail .contactBox .department {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 5px
}

#news #main .detail .contactBox .tel {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 5px;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#news #main .detail .contactBox .mail {
  display: block;
  color: #0068b7;
  font-size: 16px;
  font-weight: 600;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#top #sec04 .btnLink li a i, #top #sec05 .bannerBox li img {
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#news #main .detail .contactBox .mail i {
  font-size: 16px;
  padding-right: 5px
}

#top #topMv .mvInr {
  background-image: url(../cmn_img/top/mv.png);
  background-size: cover;
  background-attachment: fixed;
  position: relative;
  width: 100%
}

#top #topMv .mvInr .bkslider li {
  width: 100%;
  max-width: 100%
}

#top #topMv .mvInr .bkslider li img {
  max-width: 100%;
  width: 100%
}

#top #topMv .mvInr .newsBox {
  display: block;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, .8)
}

@media (max-width:768px) {
  #top #topMv .mvInr .newsBox {
    position: static;
    width: 100%;
    display: block;
    background-color: #fff
  }
}

#top #topMv .mvInr .newsBox .title {
  display: inline-block;
  text-align: center;
  line-height: 1.3
}

#top #topMv .mvInr .newsBox .title a {
  display: block;
  background: #0068b7;
  background: linear-gradient(60deg, #0068b7 0, #3ad0dd 100%);
  font-size: 15px;
  color: #fff;
  padding: 30px
}

@media (max-width:768px) {
  #top #topMv .mvInr .newsBox .title {
    display: block;
    width: 100%;
    margin: 0 auto
  }
  #top #topMv .mvInr .newsBox .title a {
    font-size: 14px;
    padding: 20px 10px
  }
}

#top #topMv .mvInr .newsBox .txtBox {
  display: inline-block;
  margin-left: 20px
}

#top #topMv .mvInr .newsBox .txtBox a {
  color: #000
}

#top #topMv .mvInr .newsBox .txtBox a time {
  font-size: 15px;
  font-family: Heebo, sans-serif
}

#top #topMv .mvInr .newsBox .txtBox a .txt {
  margin-top: 5px;
  font-size: 15px;
  height: 25px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1
}

@media (min-width:767px) {
  #top #topMv .mvInr .newsBox .title a:hover {
    opacity: .8
  }
  #top #topMv .mvInr .newsBox .txtBox a:hover {
    color: #0068b7
  }
}

@media (max-width:768px) {
  #top #topMv .mvInr .newsBox .txtBox {
    display: none
  }
}

#top #topMv.on .mvInr .ttlBox {
  opacity: 1!important;
  -webkit-filter: blur(0)!important;
  filter: blur(0)!important
}

#initiatives .initiativesTitle li:hover a, #top #sec04 .btnLink li a:hover, #top #sec05 .bannerBox li:hover img {
  opacity: .8
}

#top #sec01 {
  background-color: #fff;
  position: relative;
  z-index: 0
}

@media (max-width:1024px) {
  #news #main .newsList li dl dd, #news #main .newsList li dl dt {
    vertical-align: top
  }
  #top #topMv .mvInr {
    background-attachment: initial
  }
  #top #sec01 {
    padding: 60px 0
  }
}

#top #sec01 .sec01Inr {
  position: absolute;
  width: 80%;
  height: 100%;
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#f5f9fc), to(#fdf3f6));
  background: linear-gradient(90deg, #f5f9fc 0, #fdf3f6 100%);
  top: 0;
  right: 0;
  z-index: -1
}

#initiatives .initiativesList li .txt, #top #sec03 .initiativesList li .txt {
  height: 75px;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden
}

#top #sec01 .secTitleBox {
  display: block;
  text-align: right;
  margin-bottom: 30px
}

#top #sec01 .secTitleBox .subTitle {
  display: inline-block;
  vertical-align: middle;
  font-size: 16px;
  padding-right: 30px
}

#top #sec01 .secTitleBox .subTitleSp {
  display: none;
  vertical-align: middle;
  font-size: 16px
}

@media (max-width:1024px) {
  #top #sec01 .secTitleBox .subTitle {
    display: none
  }
  #top #sec01 .secTitleBox .subTitleSp {
    display: block
  }
  #top #sec01 .secTitleBox .head01Inr {
    margin-bottom: 20px
  }
}

#top #sec01 .secTitleBox .head01Inr {
  display: inline-block;
  vertical-align: middle
}

#top #sec01 .brandList li {
  width: 31.33333%;
  float: left;
  margin-right: 3%;
  background-color: #fff;
  padding: 40px 30px
}

@media (max-width:1024px) {
  #top #sec01 .brandList li {
    padding: 20px 10px
  }
}

@media (max-width:768px) {
  #top #sec01 .secTitleBox .subTitleSp {
    font-size: 14px
  }
  #top #sec01 .brandList li {
    width: 100%;
    float: none;
    padding: 20px 40px;
    margin-bottom: 30px
  }
}

@media (max-width:480px) {
  #top #sec01 .brandList li {
    padding: 10px;
    margin-bottom: 20px
  }
}

#top #sec01 .brandList li:last-child {
  margin-right: 0
}

#top #sec01 .brandList li .logo {
  width: 100%;
  margin-bottom: 30px;
  text-align: center
}

#top #sec01 .brandList li .logo img {
  max-width: 100%
}

@media (max-width:768px) {
  #top #sec01 .brandList li .logo {
    margin-bottom: 10px
  }
}

#top #sec01 .brandList li .titleBox {
  text-align: center;
  padding: 10px 20px;
  font-size: 22px;
  color: #fff;
  margin-bottom: 15px
}

@media (max-width:1180px) {
  #top #sec01 .brandList li .titleBox {
    font-size: 18px
  }
}

@media (max-width:1024px) {
  #top #sec01 .brandList li .titleBox {
    font-size: 15px;
    padding: 10px 5px
  }
}

#top #sec01 .brandList li .titleBox.c01 {
  background-color: #0068b7
}

#top #sec01 .brandList li .titleBox.c02 {
  background-color: #e95283
}

#top #sec01 .brandList li .titleBox.c03 {
  background-color: #094
}

#top #sec01 .brandList li .txt {
  font-size: 16px;
  margin-bottom: 30px
}

#top #sec02 {
  background-image: url(../cmn_img/top/mv.png);
  background-size: cover;
  background-attachment: fixed;
  position: relative;
  width: 100%
}

#top #sec02 .txtBox {
  color: #fff;
  text-align: center;
  position: relative
}

#top #sec02 .txtBox .bkImg {
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  top: 40%
}

#top #sec02 .txtBox .bkImg img {
  max-width: 100%
}

#top #sec02 .txtBox .titleEn {
  font-size: 40px;
  font-style: italic;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 20px
}

@media (max-width:768px) {
  #top #sec02 .txtBox .bkImg img {
    width: 320px
  }
  #top #sec02 .txtBox .titleEn {
    font-size: 28px
  }
}

#top #sec02 .txtBox .titleJa {
  font-size: 73px;
  line-height: 1;
  margin-bottom: 30px
}

#top #sec02 .txtBox .txt {
  line-height: 2;
  margin-bottom: 30px
}

@media (max-width:1024px) {
  #top #sec02 .txtBox .bscBtn01 {
    width: 320px;
    margin: 0 auto
  }
  #top #sec03 .secTitleBox .subTitle {
    bottom: 0
  }
}

#top #sec03 {
  padding: 80px
}

@media (max-width:768px) {
  #top #sec02 .txtBox .titleJa {
    font-size: 58px
  }
  #top #sec03 {
    padding: 60px
  }
}

@media (max-width:480px) {
  #top #sec02 .txtBox .titleJa {
    font-size: 42px
  }
  #top #sec03 {
    padding: 60px 3%
  }
}

#top #sec03 .secTitleBox {
  display: block;
  margin-bottom: 60px;
  position: relative
}

#top #sec03 .secTitleBox .head01Inr, #top #sec03 .secTitleBox .subTitle {
  display: inline-block;
  vertical-align: middle
}

#top #sec03 .secTitleBox .subTitle {
  padding-left: 60px;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 0
}

#top #sec03 .secTitleBox .subTitle img {
  max-width: 500px
}

@media (max-width:1440px) {
  #top #sec03 .secTitleBox .subTitle img {
    max-width: 480px
  }
}

@media (max-width:1260px) {
  #top #sec03 .secTitleBox .subTitle img {
    max-width: 320px
  }
}

#top #sec03 .secTitleBox .head01Inr .head01::before {
  top: -35px
}

#top #sec03 .initiativesList {
  margin-bottom: 50px
}

#top #sec03 .initiativesList .slide-arrow {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 60px;
  z-index: 1
}

#top #sec03 .initiativesList .slide-arrow.prev-arrow {
  left: -80px
}

#top #sec03 .initiativesList .slide-arrow.next-arrow {
  right: -80px
}

@media (max-width:768px) {
  #top #sec03 .secTitleBox .subTitle {
    bottom: 100%
  }
  #top #sec03 .secTitleBox .subTitle img {
    max-width: 300px
  }
  #top #sec03 .initiativesList .slide-arrow {
    width: 50px
  }
  #top #sec03 .initiativesList .slide-arrow.prev-arrow {
    left: -60px
  }
  #top #sec03 .initiativesList .slide-arrow.next-arrow {
    right: -60px
  }
}

@media (max-width:480px) {
  #top #sec03 .secTitleBox .subTitle img {
    max-width: 280px
  }
  #top #sec03 .initiativesList .slide-arrow {
    width: 30px
  }
  #top #sec03 .initiativesList .slide-arrow.prev-arrow {
    left: -10px
  }
  #top #sec03 .initiativesList .slide-arrow.next-arrow {
    right: -10px
  }
}

#top #sec03 .initiativesList li {
  margin-right: 20px;
  background-color: #fff;
  padding: 20px
}

#top #sec03 .initiativesList li:last-child {
  margin-right: 0
}

@media (max-width:768px) {
  #top #sec03 .initiativesList li {
    margin-right: 0
  }
}

#top #sec03 .initiativesList li .imgBox {
  background-position: center center;
  background-size: cover;
  margin-bottom: 10px
}

#top #sec03 .initiativesList li .imgBox img {
  width: 100%
}

#top #sec03 .initiativesList li .titleBox {
  margin-bottom: 10px
}

#top #sec03 .initiativesList li .titleBox .cat {
  padding: 3px 5px;
  color: #fff;
  font-size: 15px
}

#top #sec03 .initiativesList li .titleBox .cat.cat01 {
  background-color: #0068b7
}

#top #sec03 .initiativesList li .titleBox .cat.cat02 {
  background-color: #009dda
}

#top #sec03 .initiativesList li .titleBox .cat.cat03 {
  background-color: #e95283
}

#top #sec03 .initiativesList li .titleBox .cat.cat04 {
  background-color: #094;
}

#top #sec03 .initiativesList li .titleBox time {
  font-size: 14px;
  padding-left: 10px;
  color: #888;
  font-family: Heebo, sans-serif
}

#top #sec03 .initiativesList li .txt {
  font-size: 16px;
  margin-bottom: 30px;
  width: 100%;
  display: -webkit-box
}

#top #sec03 .initiativesList li .sdgs li {
  float: none;
  display: inline-block;
  vertical-align: bottom;
  padding: 0 10px 0 0;
  width: 70px;
  margin: 0
}

#top #sec03 .initiativesList li .sdgs li.large {
  width: 80px
}

#top #sec03 .initiativesList li .sdgs li img {
  max-width: 100%
}

#top #sec04 {
  background-image: url(../cmn_img/top/sec04bkg.jpg);
  background-position: center;
  background-size: cover;
  padding: 60px 0;
  line-height: 0;
  position: relative
}

#top #sec04 .imgBox {
  text-align: center;
  margin-bottom: 30px
}

#top #sec04 .imgBox img {
  max-width: 80%;
  margin: 0 auto
}

@media (max-width:768px) {
  #top #sec04 .imgBox img {
    max-width: 100%
  }
}

#top #sec04 .btnLink {
  max-width: 820px;
  margin: 0 auto;
  width: 100%
}

@media (max-width:768px) {
  #top #sec04 .btnLink {
    max-width: 100%;
    width: 100%;
    text-align: center
  }
}

#top #sec04 .btnLink li {
  display: inline-block;
  width: 31.33333%;
  margin-right: 3%;
  text-align: center
}

#top #sec04 .btnLink li:nth-child(3) {
  margin-right: 0
}

@media (max-width:768px) {
  #top #sec04 .btnLink li {
    width: 48.5%;
    margin-bottom: 20px
  }
  #top #sec04 .btnLink li:nth-child(2) {
    margin-right: 0
  }
  #top #sec04 .btnLink li:nth-child(3) {
    width: 60%
  }
}

#top #sec04 .btnLink li a {
  width: 100%;
  box-sizing: border-box;
  display: inline-block;
  vertical-align: top;
  line-height: 140%;
  position: relative;
  font-size: 15px;
  letter-spacing: 0;
  padding: 15px 0;
  color: #fff;
  border-radius: 50px;
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%)
}

#top #sec04 .btnLink li a i {
  font-size: 1em;
  font-weight: 600;
  right: 3%;
  top: 38%;
  position: absolute;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  left: 30px;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

@media (max-width:480px) {
  #top #sec04 .btnLink li a {
    font-size: 12px
  }
}

#top #sec04 img {
  width: 100%;
  max-width: 100%
}

#top #sec05 {
  background: #cfe8f8;
  background: -webkit-gradient(linear, left top, left bottom, from(#cfe8f8), to(#fef2c4));
  background: linear-gradient(180deg, #cfe8f8 0, #fef2c4 100%)
}

#top #sec05 .bannerBox {
  width: 100%;
  max-width: 100%;
  margin: 0 auto
}

#top #sec05 .bannerBox + .bannerBox{
    margin-top: 30px;
}
@media(max-width:768px){
    #top #sec05 .bannerBox + .bannerBox{
        margin-top: 0;
    }

}

#top #sec05 .bannerBox li {
  float: left;
  width: calc(33.33333% - 20px);
  margin-right: 30px
}

@media (max-width:768px) {
  #top #sec04 .btnLink li a i {
    left: 20px
  }
  #top #sec05 .bannerBox li {
    float: none;
    width: 100%;
    margin-bottom: 20px
  }
}

#top #sec05 .bannerBox li img {
  width: 100%;
  max-width: 100%;
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#top #sec05 .bannerBox li:last-child {
  margin-right: 0
}

#initiatives .secTitleBox {
  display: block;
  margin-bottom: 30px
}

#initiatives .secTitleBox .subTitle {
  display: inline-block;
  vertical-align: middle;
  font-size: 16px;
  padding-left: 50px
}

@media (max-width:1024px) {
  #initiatives .secTitleBox .subTitle {
    padding-left: 0;
    display: block;
    text-align: left
  }
}

#initiatives .secTitleBox .head01Inr .head01 {
  vertical-align: middle
}

@media (max-width:768px) {
  #initiatives .secTitleBox .subTitle {
    font-size: 15px
  }
  #initiatives .secTitleBox .head01Inr .head01::before {
    top: -40px
  }
}

@media (max-width:480px) {
  #initiatives .secTitleBox .head01Inr .head01::before {
    font-size: 14px;
    top: -40px
  }
}

#initiatives .initiativesTitle {
  background-color: rgba(255, 255, 255, .7);
  padding: 20px 10px;
  margin-bottom: 40px;
  -webkit-box-shadow: 0 0 10px -6px #7d7d7d;
  box-shadow: 0 0 10px -6px #7d7d7d
}

@media (max-width:1024px) {
  #initiatives .initiativesTitle {
    padding-bottom: 0
  }
}

#initiatives .initiativesTitle li {
  float: left;
  text-align: center;
  width: 200px;
  margin: 0 5px
}

#initiatives .initiativesTitle li a {
  background-color: #d5e1e6;
  padding: 8px 0;
  border-radius: 25px;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  font-size: 15px;
  display: block
}

#initiatives .initiativesTitle li.active a {
  background: #0068b7;
  background: -webkit-gradient(linear, left top, right top, from(#0068b7), to(#3ad0dd));
  background: linear-gradient(90deg, #0068b7 0, #3ad0dd 100%);
  color: #fff
}

@media (max-width:1150px) {
  #initiatives .initiativesTitle li {
    font-size: 14px;
    width: 180px
  }
}

@media (max-width:1024px) {
  #initiatives .initiativesTitle li {
    width: calc(50% - 10px);
    margin-bottom: 20px
  }
}

@media (max-width:480px) {
  #initiatives .initiativesTitle li {
    width: 100%;
    margin-bottom: 20px
  }
}

#initiatives .initiativesList {
  margin-bottom: 50px
}

#initiatives .initiativesList li {
  float: left;
  width: calc(33.33333% - 13.33px);
  margin-right: 20px;
  background-color: #fff;
  padding: 20px;
  margin-bottom: 20px
}

#initiatives .initiativesList li:nth-child(3n) {
  margin-right: 0
}

@media (max-width:1024px) {
  #initiatives .initiativesList li {
    width: calc(50% - 10px)
  }
  #initiatives .initiativesList li:nth-child(3n) {
    margin-right: 20px
  }
  #initiatives .initiativesList li:nth-child(2n) {
    margin-right: 0
  }
}

@media (max-width:768px) {
  #initiatives .initiativesList li {
    width: 100%;
    float: none;
    margin-right: 0
  }
  #initiatives .initiativesList li:nth-child(2n), #initiatives .initiativesList li:nth-child(3n) {
    margin-right: 0
  }
}

#initiatives .initiativesList li .imgBox {
  background-position: center center;
  background-size: cover;
  margin-bottom: 10px
}

#initiatives .initiativesList li .imgBox img {
  width: 100%
}

#initiatives .initiativesList li .titleBox {
  margin-bottom: 10px
}

#initiatives .initiativesList li .titleBox .cat {
  padding: 3px 5px;
  color: #fff;
  font-size: 15px
}

#initiatives .initiativesList li .titleBox .cat.cat01 {
  background-color: #0068b7
}

#initiatives .initiativesList li .titleBox .cat.cat02 {
  background-color: #e95283
}

#initiatives .initiativesList li .titleBox .cat.cat03 {
  background-color: #009dda
}

#initiatives .initiativesList li .titleBox .cat.cat04 {
  background-color: #094
}

#initiatives .initiativesList li .titleBox time {
  font-size: 14px;
  padding-left: 10px;
  color: #888;
  font-family: Heebo, sans-serif
}

#initiatives .initiativesList li .txt {
  font-size: 16px;
  margin-bottom: 30px;
  font-weight: 600;
  width: 100%;
  display: -webkit-box
}

#initiatives .initiativesList li .sdgs li {
  float: none;
  display: inline-block;
  vertical-align: bottom;
  padding: 0 10px 0 0;
  width: 70px;
  margin: 0
}

#initiatives .initiativesList li .sdgs li.large {
  width: 80px
}

#initiatives .initiativesList li .sdgs li img {
  max-width: 100%
}

#initiatives .detail {
  background-color: rgba(255, 255, 255, .7);
  -webkit-box-shadow: 0 0 10px -6px #7d7d7d;
  box-shadow: 0 0 10px -6px #7d7d7d;
  padding: 60px
}

@media (max-width:768px) {
  #initiatives .detail {
    padding: 30px
  }
}

@media (max-width:480px) {
  #initiatives .detail {
    padding: 30px 10px
  }
}

#initiatives .detail .detailTitleBox {
  margin-bottom: 30px
}

#initiatives .detail .detailTitleBox .cat {
  padding: 3px 8px;
  color: #fff;
  font-size: 20px
}

#initiatives .detail .detailTitleBox .cat.cat01 {
  background-color: #0068b7
}

#initiatives .detail .detailTitleBox .cat.cat02 {
  background-color: #009dda
}

#initiatives .detail .detailTitleBox .cat.cat03 {
  background-color: #e95283
}

#initiatives .detail .detailTitleBox .cat.cat04 {
  background-color: #094
}

#initiatives .detail .detailTitleBox time {
  font-size: 20px;
  display: block;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 15px
}

#initiatives .detail .detailTitleBox .detailTitle {
  font-size: 30px;
  margin-bottom: 30px;
  font-weight: 600
}

#initiatives .detail .detailTitleBox .tagList li {
  display: inline-block;
  background-color: #dedede;
  padding: 1px 12px;
  border-radius: 25px;
  font-size: 18px;
  margin-bottom: 10px
}

@media (max-width:768px) {
  #initiatives .detail .detailTitleBox .tagList li {
    font-size: 14px
  }
}

#initiatives .detail .detailTitleBox .tagList li.tagImg {
  background-color: transparent
}

#initiatives .detail .detailTitleBox .tagList li.tagImg img {
  width: 100%;
  max-width: 22px
}

#initiatives .detail .sdgsBox {
  display: table;
  width: 100%;
  margin-bottom: 50px
}

@media (max-width:480px) {
  #initiatives .detail .sdgsBox {
    display: block
  }
}

#initiatives .detail .sdgsBox .txtBox {
  display: table-cell;
  table-layout: fixed;
  vertical-align: middle;
  width: 20%;
  background-color: #009dda;
  text-align: center;
  color: #fff;
  font-size: 20px
}

@media (max-width:768px) {
  #initiatives .detail .sdgsBox .txtBox {
    width: 30%;
    font-size: 16px
  }
}

@media (max-width:480px) {
  #initiatives .detail .sdgsBox .txtBox {
    display: block;
    width: 100%;
    padding: 10px 0
  }
}

#initiatives .detail .sdgsBox .sdgsImg {
  display: table-cell;
  table-layout: fixed;
  vertical-align: middle;
  width: 80%;
  padding: 30px;
  background-color: #dbe8ee
}

@media (max-width:768px) {
  #initiatives .detail .sdgsBox .sdgsImg {
    width: 70%
  }
}

@media (max-width:480px) {
  #initiatives .detail .sdgsBox .sdgsImg {
    display: block;
    width: 100%
  }
}

#initiatives .detail .sdgsBox .sdgsImg .sdgs li {
  display: inline-block;
  vertical-align: bottom;
  padding: 0 10px 0 0;
  width: 100px;
  margin: 0
}

@media (max-width:768px) {
  #initiatives .detail .sdgsBox .sdgsImg .sdgs li {
    width: 60px
  }
}

@media (max-width:480px) {
  #initiatives .detail .sdgsBox .sdgsImg .sdgs li {
    width: 80px
  }
}

#initiatives .detail .sdgsBox .sdgsImg .sdgs li.large {
  width: 120px
}

@media (max-width:768px) {
  #initiatives .detail .sdgsBox .sdgsImg .sdgs li.large {
    width: 80px
  }
}

@media (max-width:480px) {
  #initiatives .detail .sdgsBox .sdgsImg .sdgs li.large {
    width: 100px
  }
}

#initiatives .detail .sdgsBox .sdgsImg .sdgs li img {
  max-width: 100%
}

#initiatives .detail .linkBox, #initiatives .detail .profileBox {
  border: 1px solid #d1dde2;
  background-color: #fff;
  padding: 30px;
  margin-bottom: 50px
}

#initiatives .detail .linkBox .title, #initiatives .detail .profileBox .title {
  background-color: #009dda;
  color: #fff;
  display: inline-block;
  font-size: 16px;
  padding: 5px 10px;
  margin-bottom: 20px
}

#initiatives .detail .linkBox li, #initiatives .detail .profileBox li {
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid #9a9a9a;
  text-indent: 0;
  padding-left: 0
}

#initiatives .detail .linkBox li::before, #initiatives .detail .profileBox li::before {
  content: none
}

#initiatives .detail .linkBox li .name, #initiatives .detail .profileBox li .name {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 10px
}

#initiatives .detail .linkBox li .txt, #initiatives .detail .profileBox li .txt {
  font-size: 13px
}

#initiatives .detail .linkBox li i, #initiatives .detail .profileBox li i {
  color: #0068b7;
  padding-right: 10px
}

#initiatives .detail .linkBox li:last-child, #initiatives .detail .profileBox li:last-child {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0
}

#initiatives .detail .linkBox.linkBox li, #initiatives .detail .profileBox.linkBox li {
  font-weight: 600
}

#initiatives .detail .relationBox .title {
  background-color: #009dda;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  font-size: 18px;
  margin-bottom: 30px
}

#company .companyBox {
  text-align: center;
  background-image: url(../cmn_img/company/company_bkg.png);
  background-position: center;
  background-size: cover;
  margin-bottom: 60px
}

#company .companyBox .companyImg img {
  width: 180px;
  margin-right: 40px;
  margin-bottom: 20px
}

@media (max-width:768px) {
  #company .companyBox .companyImg img {
    width: 150px
  }
}

@media (max-width:480px) {
  #company .companyBox .companyImg img {
    margin-right: 30px;
    width: 100px
  }
}

#company .companyBox .companyTitle {
  margin-bottom: 80px
}

#company .companyBox .companyTitle img {
  width: 300px
}

@media (max-width:768px) {
  #company .companyBox .companyTitle {
    margin-bottom: 40px
  }
  #company .companyBox .companyTitle img {
    width: 250px
  }
}

@media (max-width:480px) {
  #company .companyBox .companyTitle img {
    width: 180px
  }
}

#company .companyBox .companyTxt {
  font-size: 18px;
  display: inline-block;
  margin-bottom: 10px;
  background-color: rgba(255, 255, 255, .8);
  padding: 0 8px
}

#company .companyBox .companyTxt.mb50 {
  margin-bottom: 50px
}

@media (max-width:768px) {
  #company .companyBox .companyTxt {
    font-size: 15px
  }
  #company .companyBox .companyTxt.mb50 {
    margin-bottom: 30px
  }
}

#company .Box01 .ceoBox {
  width: 80%;
  margin: 0 auto 60px;
  position: relative
}

@media (max-width:768px) {
  #company .Box01 .ceoBox {
    width: 100%
  }
}

#company .Box01 .ceoBox .imgBox {
  width: 60%;
  float: right
}

@media (max-width:768px) {
  #company .Box01 .ceoBox .imgBox {
    float: none;
    width: 100%;
    padding-top: 80px;
    margin-bottom: 20px
  }
}

#company .Box01 .ceoBox .imgBox img {
  max-width: 100%
}

#company .Box01 .ceoBox .imgBox .nameBoxInr {
  width: 100%;
  position: relative
}

#company .Box01 .ceoBox .imgBox .nameBoxInr .nameBox {
  position: absolute;
  bottom: 0;
  left: 0;
  display: inline-block;
  background-color: #000;
  color: #fff;
  padding: 10px 20px;
  border-bottom: 3px solid #009dda
}

#company .Box01 .ceoBox .imgBox .nameBoxInr .nameBox .position {
  font-size: 16px;
  padding-right: 20px
}

@media (max-width:768px) {
  #company .Box01 .ceoBox .imgBox .nameBoxInr .nameBox .position {
    font-size: 14px;
    padding-right: 10px
  }
}

#company .Box01 .ceoBox .imgBox .nameBoxInr .nameBox .name {
  font-size: 28px
}

#company .Box01 .ceoBox .titleBox {
  position: absolute;
  top: 20%;
  left: 0;
  display: block;
  line-height: 1.6;
  color: #000;
  text-align: left
}

@media (max-width:768px) {
  #company .Box01 .ceoBox .imgBox .nameBoxInr .nameBox .name {
    font-size: 20px
  }
  #company .Box01 .ceoBox .titleBox {
    top: 0
  }
}

#company .Box01 .ceoBox .titleBox .title {
  font-family: Roboto, sans-serif;
  font-size: 60px;
  letter-spacing: -3px;
  margin-bottom: 20px
}

@media (max-width:768px) {
  #company .Box01 .ceoBox .titleBox .title {
    font-size: 40px;
    line-height: 2;
    margin-bottom: 0
  }
}

@media (max-width:480px) {
  #company .Box01 .ceoBox .titleBox {
    line-height: 2;
    padding: 20px 3%
  }
  #company .Box01 .ceoBox .titleBox .title {
    font-size: 30px;
    letter-spacing: 0
  }
}

#company .Box01 .ceoBox .titleBox .title::before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  display: block;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 3px;
  margin-bottom: 10px
}

@media (max-width:480px) {
  #company .Box01 .ceoBox .titleBox .title::before {
    font-size: 13px;
    margin-bottom: 0
  }
}

#company .Box01 .ceoBox .titleBox .bscBtn01 {
  display: inline-block
}

#company .Box01 .linkBox {
  width: 80%;
  margin: 0 auto
}

@media (max-width:768px) {
  #company .Box01 .linkBox {
    width: 100%
  }
}

#company .Box01 .linkBox li {
  float: left;
  width: 48%;
  margin-right: 2%
}

@media (max-width:768px) {
  #company .Box01 .linkBox li {
    float: none;
    width: 100%;
    margin-right: 0;
    margin-bottom: 10px
  }
}

@media (min-width:767px) {
  #company .Box01 .linkBox li a:hover .imgBox img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
  }
  #company .Box01 .linkBox li a:hover .imgBox .txtBox {
    letter-spacing: 3px
  }
}

#company .Box01 .linkBox li .imgBox {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  position: relative;
  line-height: 0
}

#company .Box01 .linkBox li .imgBox img {
  width: 100%;
  max-width: 100%;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#company .Box01 .linkBox li .imgBox .txtBox {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  text-align: center;
  color: #fff;
  line-height: normal;
  width: 100%
}

#company .Box01 .linkBox li .imgBox .txtBox .txtEn {
  font-family: Roboto, sans-serif;
  font-size: 14px
}

#company .Box01 .linkBox li .imgBox .txtBox .txtJa {
  font-size: 20px
}

#company .Box01 .linkBox li:nth-child(3) {
  margin-right: 0
}

#company .Box02 .subBox {
  text-align: center;
  margin-bottom: 0
}

#company .Box02 .subBox .brandsTxt {
  font-size: 18px;
  margin-bottom: 30px
}

#company .Box02 .subBox .imgBox img {
  max-width: 100%;
  width: 50%
}

@media (max-width:1024px) {
  #company .Box01 .ceoBox .titleBox .bscBtn01 a {
    padding: 20px 80px
  }
  #company .Box02 .subBox .imgBox img {
    width: 80%
  }
  #company .Box02 .subBox .scroll {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch
  }
  #company .Box02 .subBox .scroll::after {
    content: "※フリックで横スクロールができます。";
    display: block;
    font-size: 1em;
    margin: 1em 1em 2em
  }
  #company .Box02 .subBox .scrollInr {
    display: inline-block;
    white-space: nowrap
  }
}

@media (max-width:768px) {
  #company .Box02 .subBox .imgBox img {
    width: 100%
  }
}

#company .Box02 .subBox .numberList li {
  display: inline-block;
  vertical-align: top;
  color: #009dda;
  margin-bottom: 20px
}

#company .Box02 .subBox .numberList li .title {
  font-weight: 600;
  display: inline-block;
  font-size: 14px;
  border-bottom: 2px solid #009dda;
  margin-bottom: 20px
}

#company .Box02 .subBox .numberList li .icon {
  margin-bottom: 30px
}

#company .Box02 .subBox .numberList li .icon img {
  max-width: 50%
}

#company .Box02 .subBox .numberList li .txt {
  font-size: 48px;
  font-family: Oswald, sans-serif;
  letter-spacing: -3px;
  line-height: 1
}

#company .Box02 .subBox .numberList li .txt span {
  font-size: 18px
}

#company .Box02 .subBox .numberList li:nth-child(6) .icon {
  margin-bottom: 15px
}

#company .Box02 .subBox .numberList li:nth-child(7) {
  padding: 0 20px
}

#company .Box02 .subBox .numberList li:nth-child(7) .icon {
  margin-bottom: 10px
}

#company .secTitleBox, #history .secTitleBox, #message .secTitleBox, #profile .secTitleBox {
  display: block;
  margin-bottom: 30px
}

#company .mainBox, #history .mainBox, #message .mainBox, #profile .mainBox {
  background-color: rgba(255, 255, 255, .9);
  opacity: .9;
  padding: 50px 50px 60px;
  margin-bottom: 40px
}

@media (max-width:1024px) {
  #company .mainBox, #history .mainBox, #message .mainBox, #profile .mainBox {
    padding: 40px 20px
  }
}

#company .subBox, #history .subBox, #message .subBox, #profile .subBox {
  margin-bottom: 100px
}

#company .subBox .titleBox, #history .subBox .titleBox, #message .subBox .titleBox, #profile .subBox .titleBox {
  margin-bottom: 50px
}

#company .linkBox li, #history .linkBox li, #message .linkBox li, #profile .linkBox li {
  float: left;
  width: 32%;
  margin-right: 2%
}

@media (min-width:767px) {
  #company .linkBox li a:hover .imgBox img, #history .linkBox li a:hover .imgBox img, #message .linkBox li a:hover .imgBox img, #profile .linkBox li a:hover .imgBox img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
  }
  #company .linkBox li a:hover .imgBox .txtBox, #history .linkBox li a:hover .imgBox .txtBox, #message .linkBox li a:hover .imgBox .txtBox, #profile .linkBox li a:hover .imgBox .txtBox {
    letter-spacing: 3px
  }
}

#company .linkBox li .imgBox, #history .linkBox li .imgBox, #message .linkBox li .imgBox, #profile .linkBox li .imgBox {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  position: relative;
  line-height: 0
}

#company .linkBox li .imgBox img, #history .linkBox li .imgBox img, #message .linkBox li .imgBox img, #profile .linkBox li .imgBox img {
  width: 100%;
  max-width: 100%;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#company .linkBox li .imgBox .txtBox, #history .linkBox li .imgBox .txtBox, #message .linkBox li .imgBox .txtBox, #profile .linkBox li .imgBox .txtBox {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  text-align: center;
  color: #fff;
  line-height: normal;
  width: 100%
}

#company .linkBox li .imgBox .txtBox .txtEn, #history .linkBox li .imgBox .txtBox .txtEn, #message .linkBox li .imgBox .txtBox .txtEn, #profile .linkBox li .imgBox .txtBox .txtEn {
  font-family: Roboto, sans-serif;
  font-size: 14px
}

#company .linkBox li .imgBox .txtBox .txtJa, #history .linkBox li .imgBox .txtBox .txtJa, #message .linkBox li .imgBox .txtBox .txtJa, #profile .linkBox li .imgBox .txtBox .txtJa {
  font-size: 20px
}

#company .linkBox li:nth-child(3), #history .linkBox li:nth-child(3), #message .linkBox li:nth-child(3), #profile .linkBox li:nth-child(3) {
  margin-right: 0
}

#message .messageImgBox {
  position: relative;
  width: 100%;
  line-height: 0
}

#message .messageImgBox img {
  max-width: 100%
}

#message .messageImgBox .titleBox {
  line-height: 1.6;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 10%;
  color: #000
}

#message .messageImgBox .titleBox .title {
  font-family: Roboto, sans-serif;
  font-size: 60px;
  letter-spacing: -3px
}

@media (max-width:768px) {
  #company .linkBox li, #history .linkBox li, #message .linkBox li, #profile .linkBox li {
    float: none;
    width: 100%;
    margin-right: 0;
    margin-bottom: 10px
  }
  #message .messageImgBox .titleBox .title {
    font-size: 40px;
    line-height: 2
  }
}

@media (max-width:480px) {
  #company .mainBox, #history .mainBox, #message .mainBox, #profile .mainBox {
    padding: 10px 3%
  }
  #message .messageImgBox .titleBox {
    position: static;
    -webkit-transform: translateY(0);
    transform: translateY(0);
    background-color: #fff;
    opacity: .9;
    line-height: 2;
    padding: 20px 3%
  }
  #message .messageImgBox .titleBox .title {
    font-size: 30px;
    letter-spacing: 0
  }
}

#message .messageImgBox .titleBox .title::before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  display: block;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 3px;
  margin-bottom: 10px
}

@media (max-width:480px) {
  #message .messageImgBox .titleBox .title::before {
    font-size: 13px;
    margin-bottom: 0
  }
}

#message .messageImgBox .titleBox .subTitle {
  font-size: 26px;
  margin-bottom: 30px
}

@media (max-width:768px) {
  #message .messageImgBox .titleBox .subTitle {
    font-size: 20px
  }
}

@media (max-width:480px) {
  #message .messageImgBox .titleBox .subTitle {
    font-size: 18px;
    margin-bottom: 10px
  }
}

#message .messageImgBox .titleBox .name {
  font-size: 16px;
  font-weight: 600
}

#message .messageTxtBox {
  background-color: #fff;
  opacity: .9;
  padding: 50px 50px 60px;
  margin-bottom: 40px
}

@media (max-width:480px) {
  #message .messageImgBox .titleBox .name {
    font-size: 13px
  }
  #message .messageTxtBox {
    padding: 10px 3%
  }
}

#message .messageTxtBox .txt {
  font-size: 18px;
  line-height: 2;
  margin-bottom: 20px
}

@media (max-width:1024px) {
  #message .messageTxtBox .txt {
    font-size: 16px
  }
}

@media (max-width:480px) {
  #message .messageTxtBox .txt {
    font-size: 13px
  }
}

#message .messageTxtBox .txtR {
  text-align: right;
  font-size: 16px
}

#profile .subBox .imgBox {
  text-align: center;
  margin-bottom: 60px
}

#profile .subBox .imgBox img {
  max-width: 100%
}

#profile .subBox .tableBox {
  border-top: 1px solid #d1dde2
}

#profile .subBox .tableBox.fL {
  float: left;
  width: 49%
}

@media (max-width:768px) {
  #profile .subBox .tableBox.fL {
    float: none;
    width: 100%
  }
}

#profile .subBox .tableBox.fR {
  float: right;
  width: 49%
}

#profile .subBox .tableBox table {
  width: 100%
}

#profile .subBox .tableBox table tr {
  border-bottom: 1px solid #d1dde2
}

#profile .subBox .tableBox table td, #profile .subBox .tableBox table th {
  vertical-align: top;
  padding: 20px 0;
  text-align: left;
  font-size: 16px
}

@media (max-width:768px) {
  #profile .subBox .tableBox.fR {
    float: none;
    width: 100%;
    border-top: none
  }
  #profile .subBox .tableBox table td, #profile .subBox .tableBox table th {
    display: block;
    width: 100%;
    padding: 10px 0;
    text-align: center
  }
}

#profile .subBox .tableBox table td .mapLink, #profile .subBox .tableBox table th .mapLink {
  padding-top: 10px
}

#profile .subBox .tableBox table td .mapLink a, #profile .subBox .tableBox table th .mapLink a {
  color: #0068b7;
  font-family: Heebo, sans-serif;
  font-weight: 600
}

#profile .subBox .tableBox table th {
  width: 150px
}

@media (max-width:1024px) {
  #profile .subBox .tableBox table th {
    width: 120px
  }
}

@media (max-width:768px) {
  #profile .subBox .tableBox table th {
    width: 100%
  }
}

#history .historyBox {
  position: relative;
  padding-bottom: 30px
}

#history .historyBox .line {
  display: block;
  position: absolute;
  left: 288px;
  height: 100%;
  width: 2px;
  background-color: #d1dde2;
  z-index: -1;
  margin: auto;
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-transition: 2s;
  transition: 2s;
  -webkit-transform: scaleY(0);
  transform: scaleY(0)
}

#history .historyBox .line.on {
  -webkit-transform: scaleY(1);
  transform: scaleY(1)
}

@media (max-width:1160px) {
  #history .historyBox .line {
    left: 208px
  }
}

@media (max-width:768px) {
  #history .historyBox .line {
    left: 95px
  }
}

@media (max-width:480px) {
  #history .historyBox .line {
    display: none;
    left: 75px
  }
}

#history .historyBox .age {
  display: inline-block;
  vertical-align: top;
  line-height: 1;
  font-size: 34px;
  width: 200px
}

@media (max-width:1160px) {
  #history .historyBox .age {
    width: 120px
  }
}

@media (max-width:768px) {
  #history .historyBox .age {
    font-size: 28px;
    width: 100%;
    margin-bottom: 20px
  }
}

#history .historyBox .age span {
  background-color: #009dda;
  color: #fff;
  padding: 3px
}

#history .historyBox .year {
  display: inline-block;
  vertical-align: top;
  width: 200px;
  font-size: 20px
}

@media (max-width:1160px) {
  #history .historyBox .year {
    width: 150px
  }
}

#history .historyBox .year .yearTxt {
  display: inline-block;
  vertical-align: middle;
  padding-right: 30px
}

#history .historyBox .year .circle {
  width: 15px;
  height: 15px;
  border-radius: 50px;
  display: inline-block;
  background-color: #009dda;
  vertical-align: middle
}

@media (max-width:480px) {
  #history .historyBox .year .circle {
    display: none
  }
}

#history .historyBox .txtBox {
  display: inline-block;
  width: calc(100% - 400px);
  font-size: 16px;
  padding-top: 5px
}

@media (max-width:1160px) {
  #history .historyBox .txtBox {
    width: calc(100% - 270px)
  }
}

#history .historyBox .txtBox .imgBox {
  padding-top: 10px
}

#history .historyBox .txtBox .imgBox.half img {
  max-width: 150px
}

@media (max-width:1024px) {
  #history .historyBox .txtBox .imgBox.half {
    max-width: 100%
  }
  #history .historyBox .txtBox .imgBox.half img {
    max-width: 40%
  }
}

#history .historyBox .txtBox .imgBox img {
  max-width: 150px
}

@media (max-width:768px) {
  #history .historyBox .txtBox {
    width: calc(100% - 150px)
  }
  #history .historyBox .txtBox .imgBox img {
    max-width: 200px
  }
}

#privacy-policy .secTitleBox, #sitemap .secTitleBox, #term-of-use .secTitleBox {
  display: block;
  margin-bottom: 30px
}

#privacy-policy .mainBox, #sitemap .mainBox, #term-of-use .mainBox {
  background-color: #fff;
  opacity: .9;
  padding: 50px 50px 60px;
  margin-bottom: 40px
}

@media (max-width:1024px) {
  #privacy-policy .mainBox, #sitemap .mainBox, #term-of-use .mainBox {
    padding: 40px 20px
  }
}

#privacy-policy .subBox, #sitemap .subBox, #term-of-use .subBox {
  margin-bottom: 100px
}

#privacy-policy .box, #privacy-policy .subBox .titleBox, #sitemap .subBox .titleBox, #term-of-use .box, #term-of-use .subBox .titleBox {
  margin-bottom: 50px
}

#privacy-policy .box a, #term-of-use .box a {
  text-decoration: underline
}

#privacy-policy .box .txt01, #term-of-use .box .txt01 {
  font-size: 14px;
  line-height: 2
}

#privacy-policy .box .txt01.mb20, #term-of-use .box .txt01.mb20 {
  margin-bottom: 20px
}

@media (max-width:480px) {
  #history .historyBox .txtBox {
    width: 100%;
    font-size: 14px
  }
  #privacy-policy .mainBox, #sitemap .mainBox, #term-of-use .mainBox {
    padding: 10px 3%
  }
  #privacy-policy .box .txt01, #term-of-use .box .txt01 {
    font-size: 13px
  }
}

#privacy-policy .box .txt02, #term-of-use .box .txt02 {
  font-size: 13px;
  color: #111;
  line-height: 1.5
}

#privacy-policy .colorBox, #term-of-use .colorBox {
  background-color: #efefef;
  width: 100%;
  max-width: 680px;
  margin: 15px auto;
  padding: 30px
}

@media (max-width:480px) {
  #privacy-policy .box .txt02, #term-of-use .box .txt02 {
    font-size: 12px
  }
  #privacy-policy .colorBox, #term-of-use .colorBox {
    padding: 10px
  }
}

#privacy-policy .colorBox .title, #term-of-use .colorBox .title {
  display: inline-block;
  font-size: 15px;
  font-weight: 600;
  border-bottom: 1px solid #000;
  padding-bottom: 8px;
  margin-bottom: 10px
}

#privacy-policy .list .txt, #term-of-use .list .txt {
  margin-bottom: 10px
}

#privacy-policy .list ul, #term-of-use .list ul {
  padding-left: 1em
}

#privacy-policy .list li, #term-of-use .list li {
  line-height: 2.2;
  padding-left: 1em;
  text-indent: -1em
}

#sitemap .sMapList h2 a, #sitemap .sMapList h2.linkNone {
  padding: 1.2em 1em;
  background-color: #0068b7;
  margin-top: 2em;
  text-decoration: none;
  color: #fff
}

#sitemap .sMapList h2 a {
  display: block;
  font-size: 16px
}

#sitemap .sMapList h2 a:hover {
  opacity: .8
}

#sitemap .sMapList h2 a i {
  font-size: .8em;
  display: inline-block;
  vertical-align: middle;
  margin-right: .5em
}

#sitemap .sMapList h2.linkNone {
  display: block
}

#sitemap .sMapList ul {
  overflow: hidden;
  margin-top: 1em;
  margin-bottom: 0
}

#sitemap .sMapList ul+h3 {
  margin-top: 2em
}

#sitemap .sMapList ul li {
  float: left;
  width: 48%;
  border-bottom: 1px solid #ccc
}

#sitemap .sMapList ul li:nth-child(2n) {
  float: right
}

#sitemap .sMapList ul li+li+li {
  margin-top: 1.5em
}

#sitemap .sMapList ul li a {
  display: block;
  padding: .7em 0 .7em 1em;
  text-decoration: none;
  position: relative;
  line-height: 1.3;
  font-size: 16px;
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, メイリオ, verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}

#sitemap .sMapList ul li a::before {
  content: "-";
  display: inline-block;
  margin-right: .5em;
  font-weight: 600;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  left: 0
}

#sitemap .sMapList ul li a:hover {
  -webkit-transform: translateX(.5em);
  transform: translateX(.5em)
}

#sustainability {
  padding: 120px 0 0
}

#sustainability .sustainabilityBox {
  background-image: url(../cmn_img/sustainability/bkg.png);
  background-size: cover;
  background-attachment: fixed;
  position: relative;
  width: 100%;
  padding: 80px 0;
  color: #fff;
  text-align: center
}

#sustainability .sustainabilityBox .bkImg {
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  position: fixed;
  top: 50%
}

#sustainability .sustainabilityBox .bkImg img {
  max-width: 100%
}

#sustainability .sustainabilityBox .titleBox {
  position: relative
}

#sustainability .sustainabilityBox .titleBox .titleEn {
  font-size: 40px;
  font-style: italic;
  font-family: "Josefin Sans", sans-serif;
  margin-bottom: 20px
}

@media (max-width:768px) {
  #sitemap .sMapList ul li {
    float: none;
    width: 100%
  }
  #sitemap .sMapList ul li:nth-child(2n) {
    float: none
  }
  #sitemap .sMapList ul li+li {
    margin-top: 1em
  }
  #sustainability .sustainabilityBox {
    background-attachment: scroll;
    background-position: center center;
    padding: 0 10px
  }
  #sustainability .sustainabilityBox .bkImg img {
    width: 320px
  }
  #sustainability .sustainabilityBox .titleBox .titleEn {
    font-size: 28px
  }
}

#sustainability .sustainabilityBox .titleBox .titleJa {
  font-size: 73px;
  line-height: 1;
  margin-bottom: 30px
}

@media (max-width:768px) {
  #sustainability .sustainabilityBox .titleBox .titleJa {
    font-size: 58px
  }
}

@media (max-width:480px) {
  #sustainability .sustainabilityBox .titleBox .titleJa {
    font-size: 38px
  }
}

#sustainability .sustainabilityBox .txt {
  font-size: 22px;
  line-height: 2
}

@media (max-width:768px) {
  #sustainability .sustainabilityBox .txt {
    font-size: 16px
  }
}

@media (max-width:480px) {
  #sustainability .sustainabilityBox .txt {
    font-size: 14px
  }
}

#sustainability .sustainabilityBox .txt.mb30 {
  margin-bottom: 30px
}

#sustainability .sustainabilityBox .txt.mb50 {
  margin-bottom: 50px
}

#sustainability .sustainabilityBox .txt.f50 {
  font-size: 50px;
  line-height: 1.2;
  font-weight: 600
}

@media (max-width:768px) {
  #sustainability .sustainabilityBox .txt.f50 {
    font-size: 32px
  }
}

@media (max-width:480px) {
  #sustainability .sustainabilityBox .txt.f50 {
    font-size: 24px
  }
}

#sustainability .bkgColorBox {
  background-color: #fff;
  padding: 80px 0
}

#sustainability .linkBox {
  width: 50%;
  margin: 0 auto
}

@media (max-width:768px) {
  #sustainability .linkBox {
    width: 100%
  }
}

#sustainability .linkBox li {
  float: left;
  width: 48%;
  margin-right: 2%
}

@media (max-width:768px) {
  #sustainability .linkBox li {
    float: none;
    width: 100%;
    margin-right: 0;
    margin-bottom: 10px
  }
}

@media (min-width:767px) {
  #sustainability .linkBox li a:hover .imgBox img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
  }
  #sustainability .linkBox li a:hover .imgBox .txtBox {
    letter-spacing: 3px
  }
}

#sustainability .linkBox li .imgBox {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  position: relative;
  line-height: 0
}

#sustainability .linkBox li .imgBox img {
  width: 100%;
  max-width: 100%;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#sustainability .linkBox li .imgBox .txtBox {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955);
  text-align: center;
  color: #fff;
  line-height: normal;
  width: 100%
}

#sustainability .linkBox li .imgBox .txtBox .txtEn {
  font-family: Roboto, sans-serif;
  font-size: 14px
}

#sustainability .linkBox li .imgBox .txtBox .txtJa {
  font-size: 20px
}

#sustainability .linkBox li:nth-child(3) {
  margin-right: 0
}

#sustainability .ceoBox {
  background-color: #ecf2f2;
  position: relative;
  overflow: hidden;
  width: 100%;
  line-height: 0
}

@media (max-width:1024px) {
  #sustainability .ceoBox {
    padding: 60px 0 0
  }
}

#sustainability .ceoBox .bkgImg {
  height: 100%;
  background-image: url(../cmn_img/sustainability/bkg02.png);
  background-size: cover;
  background-position: center;
  position: absolute;
  opacity: .8;
  width: 100%
}

#sustainability .ceoBox .secTitleBox {
  display: inline-block;
  vertical-align: middle;
  width: 50%;
  line-height: normal;
  padding: 40px 0
}

#sustainability .ceoBox .secTitleBox .head01Inr {
  margin-bottom: 20px
}

#sustainability .ceoBox .secTitleBox .txt {
  font-size: 15px
}

#sustainability .ceoBox .secTitleBox .txt.tR {
  text-align: right;
  font-size: 16px;
  margin-top: 10px
}

#recruit .oneImgBox, #recruit .oneImgBox .imgBox, #sdgs .subBox .contentsBox .imgBox.half, #sdgs .subBox .contentsBox .markList, #sdgs .subBox .contentsBox.box01 {
  text-align: center
}

@media (max-width:1024px) {
  #sustainability .ceoBox .secTitleBox {
    display: block;
    width: 100%
  }
}

#sustainability .ceoBox .imgBox {
  display: inline-block;
  vertical-align: middle;
  width: 50%
}

#sustainability .ceoBox .imgBox img {
  width: 100%;
  max-width: 100%
}

#sdgs .secTitleBox {
  display: block;
  margin-bottom: 30px
}

#sdgs .mainBox {
  background-color: rgba(255, 255, 255, .9);
  opacity: .9;
  padding: 50px 50px 60px;
  margin-bottom: 40px
}

@media (max-width:1024px) {
  #sustainability .ceoBox .imgBox {
    display: block;
    width: 100%
  }
  #sdgs .mainBox {
    padding: 40px 20px
  }
}

@media (max-width:480px) {
  #sustainability .ceoBox .secTitleBox .head01Inr .head01 {
    font-size: 44px
  }
  #sdgs .mainBox {
    padding: 10px 3%
  }
}

#sdgs .subBox .titleBox {
  margin-bottom: 50px
}

#sdgs .subBox .contentsBox {
  background-color: #fff;
  border: 1px solid #d1dde2;
  border-radius: 5px;
  padding: 40px 30px;
  margin-bottom: 50px
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox {
    padding: 20px 10px;
    margin-bottom: 50px
  }
}

#sdgs .subBox .contentsBox.last {
  margin-bottom: 0
}

#sdgs .subBox .contentsBox .title01 {
  font-size: 26px;
  font-weight: 600;
  margin-bottom: 20px
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .title01 {
    font-size: 20px
  }
}

#sdgs .subBox .contentsBox .title02 {
  font-size: 26px;
  font-weight: 600;
  margin-bottom: 10px;
  padding-left: 30px;
  text-indent: -30px
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .title02 {
    font-size: 18px
  }
}

#sdgs .subBox .contentsBox .title02 span {
  margin-right: 10px;
  vertical-align: middle;
  display: inline-block;
  width: 20px;
  height: 3px;
  background-color: #009dda
}

#sdgs .subBox .contentsBox .txt {
  line-height: 1.8;
  font-size: 16px
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .txt {
    font-size: 13px
  }
}

#sdgs .subBox .contentsBox .txt.mb50 {
  margin-bottom: 50px
}

#sdgs .subBox .contentsBox .imgBox.half img {
  max-width: 50%;
  text-align: center;
  margin: 0 auto
}

#sdgs .subBox .contentsBox .imgBox img {
  max-width: 100%;
  width: 100%
}

#sdgs .subBox .contentsBox .txtBox .txt {
  font-size: 16px
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .txtBox .txt {
    font-size: 13px
  }
}

#sdgs .subBox .contentsBox .txtBox .txt.indent {
  padding-left: 1em
}

#sdgs .subBox .contentsBox .txtBox .list li {
  font-size: 16px;
  text-indent: -1em;
  padding-left: 1em
}

#sdgs .subBox .contentsBox .bscBtn01 {
  margin-top: 20px
}

#sdgs .subBox .contentsBox .bscBtn01.mb30 {
  margin-bottom: 30px
}

#sdgs .subBox .contentsBox .bscBtn01 a {
  padding: 10px 80px
}

#sdgs .subBox .contentsBox .markList {
  margin-bottom: 30px
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .txtBox .list li {
    font-size: 13px
  }
  #sdgs .subBox .contentsBox .markList {
    margin-bottom: 10px
  }
}

#sdgs .subBox .contentsBox .markList li {
  display: inline-block;
  padding: 0 5px
}

#sdgs .subBox .contentsBox .markList li img {
  max-width: 80px;
  width: 100%
}

#sdgs .subBox .contentsBox .floatBox.border {
  border-bottom: 1px solid #d1dde2;
  padding-bottom: 30px;
  margin-bottom: 30px
}

#sdgs .subBox .contentsBox .floatBox .fL {
  float: left;
  width: 70%
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .floatBox .fL {
    float: none;
    width: 100%;
    margin-bottom: 20px
  }
}

#sdgs .subBox .contentsBox .floatBox .fR {
  float: right;
  width: 25%
}

@media (max-width:768px) {
  #sdgs .subBox .contentsBox .floatBox .fR {
    float: none;
    width: 100%
  }
}

#history p {
  font-size: 16px
}

#recruit section {
  padding: 60px 0 0
}

#recruit .secTitleBox {
  display: block;
  margin-bottom: 30px
}

#recruit .oneImgBox {
  background-image: url(../cmn_img/top/sec04bkg.jpg);
  background-position: center;
  background-size: cover;
  padding: 60px 0
}

#recruit .oneImgBox .imgBox img {
  width: 100%;
  max-width: 80%
}

#recruit .linkBox {
  margin: 60px 0 0
}

#recruit .linkBox li {
  background-color: rgba(255, 255, 255, .8);
  padding: 30px 0;
  margin-bottom: 30px
}

#recruit .linkBox li a {
  display: block;
  margin: 0 auto;
  max-width: 1240px;
  width: 97%
}

#recruit .linkBox li a:hover .imgBox img {
  opacity: .8
}

#recruit .linkBox li a:hover .txtBox .txt {
  color: #0068b7
}

#recruit .linkBox li a .imgBox {
  display: inline-block;
  vertical-align: middle;
  width: 50%
}

@media (max-width:768px) {
  #recruit .linkBox li a .imgBox {
    display: block;
    width: 100%;
    margin-bottom: 20px
  }
}

#recruit .linkBox li a .imgBox img {
  max-width: 100%;
  width: 100%;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

#recruit .linkBox li a .txtBox {
  display: inline-block;
  vertical-align: middle;
  width: 50%;
  padding-left: 30px
}

#recruit .linkBox li a .txtBox .txt {
  font-size: 26px;
  -webkit-transition: all .3s cubic-bezier(.455, .03, .515, .955);
  transition: all .3s cubic-bezier(.455, .03, .515, .955)
}

@media (max-width:768px) {
  #recruit .linkBox li a .txtBox {
    display: block;
    width: 100%
  }
  #recruit .linkBox li a .txtBox .txt {
    font-size: 20px
  }
}

@media (max-width:480px) {
  #recruit .linkBox li a .txtBox .txt {
    font-size: 18px
  }
}
.top-brandmoview{
  max-width:800px;
  width:100%;
  margin:4.8em auto 0.8em;
}
@media (max-width:768px) {
  .top-brandmoview{
    margin:2.4em auto 0.4em;
  }
}
.top-brandmoview-title{
  font-size: 1.8rem;
  margin-top:.8em;
  text-align: center;
}
.top-brandmoview-block{
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0px;
  overflow: hidden; 
}
.top-brandmoview-block-elment{
  position:absolute;
  top:0;left:0;
  width:100%;
  height:100%
}
/*# sourceMappingURL=main.css.map */