html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video, input, select, textarea {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-style: normal;
  font-weight: 400;
  vertical-align: bottom;
  background: transparent
}
article, aside, details, figcaption, figure, footer, header, menu, nav, section {
  display: block
}
html {
  font-size: 62.5%
}
body {
  font-family: sans-serif;
  line-height: 1
}
ul, ol {
  list-style: none
}
blockquote, q {
  quotes: none
}
blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none
}
a {
  margin: 0;
  padding: 0;
  vertical-align: bottom;
  background: transparent;
  outline: none
}
img {
  vertical-align: bottom
}
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none
}
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold
}
del {
  text-decoration: line-through
}
abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help
}
table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%
}
th, td {
  text-align: left;
  vertical-align: top
}
input, select, textarea {
  font-family: inherit
}
input[type="submit"] {
  cursor: pointer
}
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0
}
html {
  overflow: auto
}
body {
  min-width: 320px;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif;
  color: #262626;
  font-size: 1.4rem;
  line-height: 1.8;
  letter-spacing: .05em;
  overflow: hidden;
  -webkit-text-size-adjust: 100%
}
@media (min-width: 768px) {
  body {
    font-size: 1.6rem
  }
}
body.sg {
  height: auto
}
a {
  color: inherit;
  text-decoration: none;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
@media (min-width: 768px) {
  a:hover {
    color: #0b3358
  }
}
span {
  font-weight: inherit
}
strong {
  font-weight: 700
}
img {
  width: 100%;
  height: auto
}
.l-wrapper {
  position: relative
}
.l-contents {
  position: relative;
	background: #E9E9E9;
}
.l-contents-top {
  position: relative;
	background-image: url("../img/bg.png");
	  background-size: cover;
	padding-bottom: 100px;
}
@media (max-width: 768px) {
	.l-contents-top {
  position: relative;
	background-image: url("../img/bg_sp.png");
  background-size: 100vw auto; /* 横幅を100vwにして高さは自動調整 */
  
  background-repeat: no-repeat;
	padding-bottom: 30px;
}
}
.l-container {
  position: relative;
  z-index: 2;
}
.u-media-query {
  display: none;
  font-family: 'sp'
}
@media (min-width: 768px) {
  .u-media-query {
    font-family: 'pc'
  }
}
@media (max-width: 767px) {
  .u-view-pc {
    display: none !important
  }
}
@media (min-width: 768px) {
  .u-view-sp {
    display: none !important
  }
}
.u-alpha {
  display: block;
  text-decoration: none
}
@media (min-width: 768px) {
  .u-alpha {
    -webkit-transition: all .3s ease;
    transition: all .3s ease
  }
  .u-alpha:hover {
    opacity: .7
  }
}
.u-cf:after {
  content: "";
  display: block;
  clear: both
}
@media (min-width: 768px) {
  .u-inner {
    width: 100%;
    max-width: 1100px;
    margin: auto
  }
}
.u-goudy {
  font-family: 'Sorts Mill Goudy', serif
}
.u-serif {
  font-family: 'Noto Serif JP', serif
}
.c-animation01 {
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(50px);
  -ms-transform: translateY(50px);
  transform: translateY(50px);
  -webkit-transition: opacity 1500ms, -webkit-transform 1500ms;
  transition: opacity 1500ms, -webkit-transform 1500ms;
  transition: opacity 1500ms, transform 1500ms;
  transition: opacity 1500ms, transform 1500ms, -webkit-transform 1500ms
}
.c-animation01.is-active {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0)
}
.c-animation01.is-delayed01 {
  -webkit-transition-delay: 200ms;
  transition-delay: 200ms
}
.c-animation01.is-delayed02 {
  -webkit-transition-delay: 400ms;
  transition-delay: 400ms
}
.c-animation01.is-delayed03 {
  -webkit-transition-delay: 600ms;
  transition-delay: 600ms
}
.c-animation01.is-delayed04 {
  -webkit-transition-delay: 800ms;
  transition-delay: 800ms
}
.c-animation01.is-delayed05 {
  -webkit-transition-delay: 1000ms;
  transition-delay: 1000ms
}
.c-animation01.is-delayed06 {
  -webkit-transition-delay: 1200ms;
  transition-delay: 1200ms
}
.c-animation01.is-delayed07 {
  -webkit-transition-delay: 1400ms;
  transition-delay: 1400ms
}
.c-animation01.is-delayed08 {
  -webkit-transition-delay: 1600ms;
  transition-delay: 1600ms
}
.c-animation01.is-delayed09 {
  -webkit-transition-delay: 1800ms;
  transition-delay: 1800ms
}
.c-animation01.is-delayed10 {
  -webkit-transition-delay: 2000ms;
  transition-delay: 2000ms
}
.c-animation01.is-delayed11 {
  -webkit-transition-delay: 2200ms;
  transition-delay: 2200ms
}
.c-animation01.is-delayed12 {
  -webkit-transition-delay: 2400ms;
  transition-delay: 2400ms
}
.c-animation01.is-delayed13 {
  -webkit-transition-delay: 2600ms;
  transition-delay: 2600ms
}
.c-animation01.is-delayed14 {
  -webkit-transition-delay: 2800ms;
  transition-delay: 2800ms
}
.c-animation01.is-delayed15 {
  -webkit-transition-delay: 3000ms;
  transition-delay: 3000ms
}
.c-animation01.is-delayed16 {
  -webkit-transition-delay: 3200ms;
  transition-delay: 3200ms
}
.c-animation01.is-delayed17 {
  -webkit-transition-delay: 3400ms;
  transition-delay: 3400ms
}
.c-animation01.is-delayed18 {
  -webkit-transition-delay: 3600ms;
  transition-delay: 3600ms
}
.c-animation01.is-delayed19 {
  -webkit-transition-delay: 3800ms;
  transition-delay: 3800ms
}
.c-animation01.is-delayed20 {
  -webkit-transition-delay: 4000ms;
  transition-delay: 4000ms
}


.c-cv01 {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 0;
  padding-top: 73.5%
}
.c-cv01:after {
  content: '';
  display: inline-block;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  background: url(../img/home/bg_mv01_pc.jpg);
  background-size: cover
}
.c-cv01__inner {
  box-sizing: border-box;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  padding-top: 17%;
  font-size: 1.3rem
}
.c-cv01__txt {
  margin-bottom: 25px;
  line-height: 1.92;
  color: #fff;
  text-align: center;
}

@media (min-width: 768px) {
  .c-cv01 {
    height: 450px;
    padding-top: 0
  }
  .c-cv01:after {
    background: url(../img/home/bg_mv01_pc.jpg) no-repeat center bottom;
    background-size: cover
  }
  .c-cv01__inner {
    padding-top: 8%;
    font-size: 1.8rem
  }
  .c-cv01__txt {
    margin-bottom: 43px
  }
  .c-cv01-btn {
    width: 41.67%;
    min-width: 640px;
    max-width: 800px;
    margin: auto
  }
  .c-cv01-btn__link {
    width: 100%;
    max-width: 800px;
    height: 120px
  }
  .c-cv01-btn__link .c-cv01-btn__span {
    font-size: 2.5rem
  }
}
.c-form01__head {
  margin-bottom: 35px;
  font-weight: 500;
  font-size: 2.3rem;
  text-align: center
}
.c-form01-table {
  table-layout: fixed;
  margin-bottom: 20px;
  background-color: #fff
}
.c-form01-table caption {
  position: relative;
  padding: 15px 13px 18px;
  line-height: 1;
  font-weight: 500;
  font-size: 1.7rem;
  text-align: left
}
.c-form01-table caption:after {
  content: "";
  display: inline-block;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 4px;
  height: 16px;
  background-color: #0b3358
}
.c-form01-table th, .c-form01-table td {
  box-sizing: border-box;
  display: block;
  width: 100%;
  font-size: 1.4rem
}
.c-form01-table th {
  position: relative;
  padding: 16px 18px 0 18px;
  border-top: 1px solid #e6e6e6;
  font-weight: 500
}
.c-form01-table td {
  padding: 5px 18px 20px 18px
}
.c-form01-table tr:last-child td {
  border-bottom: 1px solid #e6e6e6
}
.c-form01 input, .c-form01 button, .c-form01 textarea, .c-form01 select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  border-radius: 0;
  font-family: inherit
}
.c-form01 input[type="text"], .c-form01 input[type="tel"], .c-form01 input[type="email"], .c-form01 input[type="number"], .c-form01 input[type="date"], .c-form01 textarea, .c-form01 select {
  position: relative;
  box-sizing: border-box;
  background-color: #f0f0f0;
  width: 100%;
  height: 43px;
  padding: 0 15px
}
.c-form01 select::-ms-expand {
  display: none
}
.c-form01 select {
  border: 1px solid #e6e6e6;
  background: #fff url(/img/contact/ico_arw01.png) no-repeat center right 15px;
  background-size: 12px
}
.c-form01 textarea {
  width: 100%;
  height: 200px;
  padding: 10px
}
.c-form01 input[type="checkbox"] {
  width: 15px;
  height: 15px;
  border: 1px solid #e6e6e6
}
.c-form01 ::-webkit-input-placeholder {
  color: rgba(0, 0, 0, 0.6)
}
.c-form01 :-ms-input-placeholder {
  color: rgba(0, 0, 0, 0.6)
}
.c-form01 ::placeholder {
  color: rgba(0, 0, 0, 0.6)
}
.c-form01__ico {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 45px
}
.c-form01__input-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}
.c-form01__input-area.is-paralleled {
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap
}
.c-form01__input-area.is-paralleled input[type="text"] {
  width: 75px;
  margin-right: 10px
}
.c-form01__countries {
  padding-top: 8px
}
.c-form01__countries .mwform-checkbox-field {
  width: 50%;
  margin-bottom: 10px
}
.c-form01__countries .mwform-checkbox-field:nth-last-of-type(2) {
  width: 100%
}
.c-form01__countries .mwform-checkbox-field:last-of-type {
  width: 30%;
  padding-top: 10px
}
.c-form01__countries input[type="text"] {
  width: 70%
}
.c-form01__promo {
  padding-top: 8px
}
.c-form01__promo .mwform-checkbox-field {
  width: 100%;
  margin-bottom: 10px
}
.c-form01__promo .mwform-checkbox-field:last-of-type {
  width: 30%;
  padding-top: 10px
}
.c-form01__promo input[type="text"] {
  width: 70%
}
.c-form01__zip {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 15px
}
.c-form01__zip span {
  display: inline-block;
  width: 25px
}
.c-form01__zip input[type="text"] {
  max-width: 41.5%
}
.c-form01__zip input[type="text"]:nth-of-type(1) {
  margin-right: 2%
}
.c-form01__zip input[type="text"]:nth-of-type(2) {
  margin-left: 2%
}
.c-form01 .mwform-checkbox-field {
  display: block
}
.c-form01 .mwform-checkbox-field label {
  position: relative
}
.c-form01 .mwform-checkbox-field label input[type="checkbox"] {
  display: none
}
.c-form01 .mwform-checkbox-field label input[type="checkbox"] + span {
  display: inline-block;
  position: relative;
  padding-left: 25px
}
.c-form01 .mwform-checkbox-field label input[type="checkbox"] + span:before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  width: 18px;
  height: 18px;
  border: 1px solid #e5e5e5;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.c-form01 .mwform-checkbox-field label input[type="checkbox"] + span + input {
  display: block;
  margin-top: 10px
}
.c-form01 .mwform-checkbox-field label input[type="checkbox"]:checked + span {
  background: url(/img/contact/ico_check01.png) no-repeat left 3px top 9px;
  background-size: 14px
}
.c-form01 .mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0
}
.c-form01-concent {
  box-sizing: border-box;
  margin: 35px 0 0;
  padding: 15px 20px
}
.c-form01-concent__head {
  margin-bottom: 20px;
  font-weight: 500;
  font-size: 2.3rem;
  text-align: center
}
@media (max-width: 320px) {
  .c-form01-concent__head {
    font-size: 2rem
  }
}
.c-form01-concent__txt {
  margin-bottom: 40px;
  line-height: 1.85;
  font-size: 1.3rem
}
.c-form01-concent-box {
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 289px;
  margin: 0 -20px 26px;
  padding: 15px;
  border: 1px solid #e5e5e5
}
.c-form01-concent-box__inner {
  box-sizing: border-box;
  overflow: auto;
  height: 269px;
  padding: 5px 15px 0 0
}
.c-form01-concent-box__head {
  font-weight: 500
}
.c-form01-concent-box__txt {
  line-height: 1.85
}
.c-form01-concent__check {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}
.c-form01 ::-webkit-scrollbar {
  width: 12px
}
.c-form01 ::-webkit-scrollbar-track {
  margin: 10px 0;
  border-radius: 10px;
  background-color: #f0f0f0
}
.c-form01 ::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background-color: #262626
}
.c-form01-btn button {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  width: 200px;
  height: 48px;
  margin: auto;
  line-height: 1.25;
  border: 1px solid #0b3358;
  background-color: #0b3358;
  color: #fff;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.c-form01-btn button:hover {
  background-color: #fff;
  color: #0b3358
}
.c-form01-btn button.is-back {
  margin-top: 10px;
  border: 1px solid #262626;
  background-color: #262626
}
.c-form01-btn button.is-back:hover {
  background-color: #fff;
  color: #262626
}
@media (min-width: 768px) {
  .c-form01__head {
    margin-bottom: 65px;
    font-size: 3.5rem
  }
  .c-form01-table {
    margin-bottom: 45px;
    border-bottom: 0
  }
  .c-form01-table caption {
    padding: 15px 13px 30px 18px;
    font-size: 2.3rem
  }
  .c-form01-table caption:after {
    top: 26px;
    width: 6px;
    height: 20px
  }
  .c-form01-table th, .c-form01-table td {
    box-sizing: border-box;
    display: table-cell;
    border-top: 1px solid #e6e6e6;
    border-bottom: 1px solid #e6e6e6;
    font-size: 1.6rem;
    text-align: left
  }
  .c-form01-table th {
    width: 22%;
    padding: 30px 28px;
    vertical-align: middle
  }
  .c-form01-table th.is-top {
    padding-top: 33px;
    vertical-align: top
  }
  .c-form01-table th.is-top .c-form01__ico {
    top: 36px
  }
  .c-form01-table td {
    width: 78%;
    padding: 30px 0;
    vertical-align: middle
  }
  .c-form01 input[type="text"], .c-form01 input[type="tel"], .c-form01 input[type="email"], .c-form01 input[type="number"], .c-form01 input[type="date"] {
    width: 100%;
    max-width: 680px;
    height: 42px;
    padding: 10px 20px
  }
  .c-form01 textarea {
    box-sizing: border-box;
    width: 100%;
    max-width: 680px;
    height: 280px;
    padding: 13px 18px
  }
  .c-form01 select {
    width: 100%;
    max-width: 680px;
    height: 50px;
    background-size: 17px
  }
  .c-form01__ico {
    position: absolute;
    width: 56px;
    top: 40px;
    right: 0
  }
  .c-form01__input-area {
    margin-left: 17%
  }
  .c-form01__countries {
    padding-top: 0px
  }
  .c-form01__countries .mwform-checkbox-field {
    width: auto;
    min-width: 150px;
    margin-right: 25px
  }
  .c-form01__countries .mwform-checkbox-field:nth-last-of-type(2) {
    width: auto
  }
  .c-form01__countries .mwform-checkbox-field:last-of-type {
    width: 12%;
    min-width: 90px;
    padding-top: 10px;
    margin-right: 10px
  }
  .c-form01__countries input[type="text"] {
    width: 35%;
    height: 26px;
    margin-bottom: 5px
  }
  .c-form01__promo {
    padding-top: 8px
  }
  .c-form01__promo .mwform-checkbox-field {
    width: auto;
    min-width: 228px;
    margin-right: 30px
  }
  .c-form01__promo .mwform-checkbox-field:last-of-type {
    width: 12%;
    min-width: 90px;
    padding-top: 10px;
    margin-right: 10px
  }
  .c-form01__promo input[type="text"] {
    width: 35%;
    height: 26px;
    margin-bottom: 5px
  }
  .c-form01__zip {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 15px
  }
  .c-form01__zip span {
    display: inline-block;
    width: 25px;
    font-size: 2rem
  }
  .c-form01__zip input[type="text"] {
    display: inline-block;
    max-width: 180px
  }
  .c-form01 .mwform-checkbox-field {
    display: block;
    margin-bottom: 20px
  }
  .c-form01 .mwform-checkbox-field label input[type="checkbox"] + span {
    padding-left: 30px
  }
  .c-form01 .mwform-checkbox-field label input[type="checkbox"] + span:before {
    cursor: pointer;
    margin-top: 2px
  }
  .c-form01 .mwform-checkbox-field label input[type="checkbox"]:checked + span {
    background-position: left 3px top 11px
  }
  .c-form01-concent {
    box-sizing: border-box;
    margin: 100px 0 0;
    padding-bottom: 30px
  }
  .c-form01-concent__head {
    margin-bottom: 40px;
    font-size: 3.5rem
  }
  .c-form01-concent__txt {
    margin-bottom: 70px;
    font-size: 1.6rem;
    text-align: center
  }
  .c-form01-concent-box {
    height: 259px;
    margin-bottom: 35px;
    padding: 35px 18px 35px 35px
  }
  .c-form01-concent-box__inner {
    height: 259px;
    padding: 35px 20px 0 0
  }
  .c-form01-concent-box__txt {
    line-height: 2
  }
  .c-form01-concent__check {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
  .c-form01-btn button {
    width: 320px;
    height: 60px;
    font-size: 1.8rem
  }
  .c-form01.is-comfirm .c-form01__ico {
    top: 35px
  }
}
@media (min-width: 768px) and (max-width: 1100px) {
  .c-form01-table th {
    width: 32%
  }
  .c-form01-table td {
    width: 68%
  }
  .c-form01__input-area {
    margin-left: 10%
  }
  .c-form01__countries .mwform-checkbox-field:nth-last-of-type(2) {
    width: 100%
  }
  .c-form01__countries .mwform-checkbox-field:last-of-type {
    width: 20%;
    padding-top: 10px
  }
  .c-form01__countries input[type="text"] {
    width: 60%
  }
  .c-form01__promo {
    padding-top: 8px
  }
  .c-form01__promo .mwform-checkbox-field:nth-last-of-type(2) {
    width: 100%
  }
  .c-form01__promo .mwform-checkbox-field:last-of-type {
    width: 20%;
    padding-top: 10px
  }
  .c-form01__promo input[type="text"] {
    width: 60%
  }
}
.c-head01 {
  position: relative;
  margin-bottom: 13px;
  padding-left: 33px;
  line-height: 1.52;
  font-weight: 500;
  font-size: 1.7rem
}
.c-head01:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 15px;
  top: 9px;
  width: 10px;
  height: 10px;
  background-color: #0b3358
}
.c-head01.is-underlined {
  padding-bottom: 18px;
  border-bottom: 1px solid #e5e5e5;
  font-weight: 400
}
.c-head01.is-left {
  padding-left: 21px
}
.c-head01.is-left:before {
  left: 0
}
@media (min-width: 768px) {
  .c-head01 {
    margin-bottom: 22px;
    padding-left: 23px;
    line-height: 1.8;
    font-size: 2.2rem
  }
  .c-head01:before {
    left: 0;
    top: 17px;
    width: 12px;
    height: 12px
  }
  .c-head01.is-underlined {
    padding-bottom: 25px
  }
}
.c-head02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  margin-bottom: 20px
}
.c-head02.is-soon {
  display: block;
  text-align: center
}
.c-head02__en {
  margin-right: 10px;
  font-size: 2.6rem
}
.c-head02__ja {
  line-height: 1.59;
  font-size: 1.1rem
}
@media (min-width: 768px) {
  .c-head02__en {
    margin-right: 15px;
    font-size: 4.2rem
  }
  .c-head02__ja {
    font-size: 1.6rem
  }
}
.c-link01 {
  padding: 40px 0;
  background-color: #f0f0f0
}
.c-link01__inner {
  padding-left: 30px;
  padding-right: 30px
}
.c-link01-btn {
  width: 100%;
  max-width: 315px;
  margin-bottom: 10px
}
.c-link01-btn__link {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  height: 82px;
  margin: auto;
  border: 1px solid #262626
}
.c-link01-btn__link:after {
  content: '';
  position: absolute;
  z-index: 1;
  left: -40%;
  top: 0;
  -webkit-transform: skew(50deg);
  -ms-transform: skew(50deg);
  transform: skew(50deg);
  -webkit-transition-duration: 0.6s;
  transition-duration: 0.6s;
  -webkit-transform-origin: top left;
  -ms-transform-origin: top left;
  transform-origin: top left;
  width: 0;
  height: 100%;
  background-color: #262626
}
.c-link01-btn__link:hover {
  color: #fff
}
.c-link01-btn__link:hover:after {
  width: 140%;
  height: 100%
}
.c-link01-btn__en, .c-link01-btn__ja {
  position: relative;
  z-index: 2;
  display: block;
  width: 100%;
  text-align: center
}
.c-link01-btn__en {
  margin-top: auto;
  font-size: 2.1rem
}
.c-link01-btn__ja {
  margin-bottom: auto;
  line-height: 1.5;
  -webkit-transform: translateY(-5px);
  -ms-transform: translateY(-5px);
  transform: translateY(-5px);
  font-size: 1rem
}
@media (min-width: 768px) {
  .c-link01 {
    padding: 82px 0 78px
  }
  .c-link01__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    max-width: 1100px;
    margin: auto
  }
  .c-link01__heading {
    width: 100%
  }
  .c-link01-btn {
    width: 352px;
    max-width: 352px;
    margin-bottom: 22px;
    margin-right: 22px
  }
  .c-link01-btn:last-of-type {
    margin-right: 0
  }
  .c-link01-btn__link {
    height: 120px
  }
  .c-link01-btn__en {
    font-size: 3rem
  }
  .c-link01-btn__ja {
    font-size: 1.3rem
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .c-link01__heading {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
  .c-link01-btn:last-of-type {
    margin-right: 22px
  }
}
.c-list01__item {
  position: relative;
  margin-bottom: 8px;
  padding-left: 15px
}
.c-list01__item:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 2px;
  top: 12px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #262626
}
@media (min-width: 768px) {
  .c-list01__item {
    margin-bottom: 10px
  }
}

.c-search01 {
  padding: 0 10.6666%;
  margin-bottom: 20px
}
.c-search01-tag {
  background-color: #f0f0f0;
  margin-top: 36px;
  margin-bottom: 35px;
  padding: 10px 19px
}
.c-search01-tag__head {
  font-size: 1.6rem;
  position: relative
}
.c-search01-tag__head:before {
  content: "";
  display: block;
  background: url(/img/contact/ico_arw01.png) no-repeat center right/contain;
  width: 12px;
  height: 7px;
  position: absolute;
  right: 0;
  top: 10px;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.c-search01-tag__head.is-active:before {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg)
}
.c-search01-tag__content {
  border-top: 1px solid #040404;
  padding: 12px 0 0;
  margin-top: 9px
}
.c-search01-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
.c-search01__btn button {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  width: 155px;
  height: 48px;
  margin: auto;
  line-height: 1.25;
  border: 1px solid #040404;
  background-color: #fff;
  font-size: 1.6rem;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.c-search01__btn button:hover {
  background-color: #040404;
  color: #fff
}
.c-search01 button, .c-search01 input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
  outline: none
}
.c-search01__check {
  display: inline-block;
  margin-bottom: 12px;
  margin-right: 16px
}
.c-search01__check label {
  cursor: pointer;
  display: block;
  box-sizing: border-box
}
.c-search01__check input {
  display: none;
  border: 0
}
.c-search01__check-txt {
  position: relative;
  display: block;
  line-height: 1.4;
  padding-left: 29px;
  font-size: 1.5rem
}
.c-search01__check-txt:before, .c-search01__check-txt:after {
  content: "";
  display: block;
  position: absolute
}
.c-search01__check-txt:before {
  width: 18px;
  height: 18px;
  background: #fff;
  border: 1px solid #e5e5e5;
  top: 3px;
  left: 2px;
  box-sizing: border-box
}
.c-search01__check-txt:after {
  display: none;
  left: 8px;
  top: 6px;
  width: 3px;
  height: 9px;
  -webkit-transform: rotate(40deg);
  -ms-transform: rotate(40deg);
  transform: rotate(40deg);
  border-bottom: 2px solid #0b3358;
  border-right: 2px solid #0b3358
}
.c-search01__check input[type="checkbox"]:checked + .c-search01__check-txt:after {
  display: block
}
.c-search01-select {
  text-align: center
}
.c-search01-select select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  min-width: 200px;
  padding: 12px 20px;
  border: 2px solid #040404;
  border-radius: 0;
  background: #fff url(/img/contact/ico_arw01.png) no-repeat center right 15px;
  background-size: 13px;
  font-family: inherit;
  width: 100%
}
.c-search01-select select::-ms-expand {
  display: none
}
@media (min-width: 768px) {
  .c-search01 {
    padding: 0;
    margin-bottom: 30px
  }
  .c-search01 button {
    width: 180px;
    height: 60px
  }
  .c-search01-list {
    margin-bottom: 20px
  }
  .c-search01__check {
    margin-right: 47px;
    margin-bottom: 28px
  }
  .c-search01__check.is-cat {
    width: 20%;
    margin: 0;
    text-align: center
  }
  .c-search01__check.is-cat input[type="checkbox"]:checked + .c-search01__check-txt {
    color: #fff;
    background-color: #262626
  }
  .c-search01__check.is-cat label {
    height: 100%
  }
  .c-search01__check.is-cat:last-of-type .c-search01__check-txt {
    border-right: 1px solid #262626
  }
  .c-search01__check.is-cat .c-search01__check-txt {
    padding: 21px 6px 20px;
    height: 100%;
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border: 1px solid #262626;
    border-right: none;
    background-color: #fff;
    font-size: 1.3rem
  }
  .c-search01__check.is-cat .c-search01__check-txt:before, .c-search01__check.is-cat .c-search01__check-txt:after {
    content: none
  }
  .c-search01__check-txt {
    padding-left: 32px
  }
  .c-search01__check-txt:before {
    width: 20px;
    height: 20px
  }
  .c-search01__check-txt:after {
    top: 6px;
    left: 10px;
    -webkit-transform: rotate(47deg);
    -ms-transform: rotate(47deg);
    transform: rotate(47deg)
  }
  .c-search01-tag {
    margin-top: 40px;
    margin-bottom: 40px;
    padding: 12px 38px
  }
  .c-search01-tag__head {
    font-size: 1.8rem
  }
  .c-search01-tag__head:before {
    width: 17px;
    height: 9px;
    right: 3px;
    top: 14px
  }
  .c-search01-tag__content {
    padding: 28px 0 0;
    margin-top: 15px
  }
}
.c-service01-intro {
  padding: 55px 0 10px
}
.c-service01-intro__inner {
  padding: 0 10.6666%;
	margin-bottom: 50px;
}
.c-service01-intro__txt {
  line-height: 2.21;
	font-size: 13px;
}
@media (min-width: 768px) {
  .c-service01-intro {
    padding: 80px 0 125px
  }
  .c-service01-intro__inner {
    padding: 0
  }
  .c-service01-intro__txt {
    line-height: 1.82;
    font-size: 14px;
    text-align: center
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .c-service01-intro__inner {
    padding: 0 0px
  }
  .c-service01-intro__txt {
    font-size: 1.5rem
  }
}
.c-service01-detail {
  padding: 40px 0 30px;
  background-color: #f0f0f0
}
.c-service01-detail__head {
  margin-bottom: 18px;
  font-size: 25px;
  text-align: center;
	font-weight: 800;
}
.c-service01-detail-list__item:not(:last-of-type) {
  margin-bottom: 30px
}
.c-service01-detail-list__txt-area {
  margin: 0 4.3333%;
  padding: 20px 20px 20px;
  -webkit-transform: translateY(-30px);
  -ms-transform: translateY(-30px);
  transform: translateY(-30px);
  background-color: #fff
}
.c-service01-detail-list__head {
  position: relative;
  margin-bottom: 13px;
  padding-left: 21px;
  line-height: 1.52;
  font-weight: 500;
  font-size: 16px;
}
.c-service01-detail-list__head:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 0px;
  top: 9px;
  width: 10px;
  height: 10px;
  background-color: #0b3358
}
.c-service01-detail-list__txt {
  line-height: 1.85;
	font-size: 13px;
}
.c-service01-detail.is-white {
  background: 0
}
.c-service01-detail.is-white .c-service01-detail-list__txt-area {
  box-shadow: 3px 15px 30px 0px rgba(0, 0, 0, 0.25)
}
@media (min-width: 768px) {
  .c-service01-detail {
    padding: 90px 0 120px
  }
  .c-service01-detail__inner {
    max-width: 1620px;
    margin: auto
  }
  .c-service01-detail__head {
    margin-bottom: 35px;
    font-size: 3rem
  }
  .c-service01-detail-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end
  }
  .c-service01-detail-list__item:not(:last-of-type) {
    margin-bottom: 130px
  }
  .c-service01-detail-list__item:nth-of-type(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
  }
  .c-service01-detail-list__item:nth-of-type(even) .c-service01-detail-list__img {
    margin: 0 0 0 -104px
  }
  .c-service01-detail-list__item:nth-of-type(even) .c-service01-detail-list__txt-area {
    margin: 0 -20px 0 0;
    z-index: 1;
  }
  .c-service01-detail-list__img {
    width: 57%;
    max-width: 915px;
    margin-right: -104px
  }
  .c-service01-detail-list__txt-area {
    box-sizing: border-box;
    width: 43%;
    max-width: 650px;
    margin: 0 0 0 -20px;
    -webkit-transform: translateY(-50px);
    -ms-transform: translateY(-50px);
    transform: translateY(-50px);
    padding: 48px 80px 55px
  }
  .c-service01-detail-list__head {
    margin-bottom: 10px;
    padding-left: 28px;
    line-height: 1.8;
    font-size: 2.6rem
  }
  .c-service01-detail-list__head:before {
    left: -1px;
    top: 16px;
    width: 16px;
    height: 16px
  }
  .c-service01-detail-list__txt {
    line-height: 2
  }
}
@media (min-width: 1024px) and (max-width: 1440px) {
  .c-service01-detail-list__item {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
  .c-service01-detail-list__txt-area {
    width: 55%;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
    padding: 35px 50px 45px;
    font-size: 1.5rem
  }
  .c-service01-detail-list__head {
    font-size: 2.4rem
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .c-service01-detail-list__item {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
  .c-service01-detail-list__img img {
    min-width: 500px
  }
  .c-service01-detail-list__txt-area {
    width: 60%;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
    padding: 30px 45px 40px;
    font-size: 1.5rem
  }
  .c-service01-detail-list__head {
    font-size: 2.2rem
  }
}
.c-service01-summary {
  padding: 40px 0 30px
}
.c-service01-summary__inner {
  padding: 0 5.3333%
}
.c-service01-summary__head {
  margin-bottom: 18px;
  font-size: 4.5rem;
  text-align: center
}
.c-service01-summary-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
.c-service01-summary-list__item {
  box-sizing: border-box;
  width: 50%;
  margin-bottom: 28px
}
.c-service01-summary-list__img {
  margin-bottom: 8px
}
.c-service01-summary-list__img-on {
  display: none
}
.c-service01-summary-list__head {
  line-height: 1.5;
  font-weight: 500;
  text-align: center
}
.c-service01-summary.is-gray {
  background-color: #f0f0f0
}
@media (max-width: 767px) {
  .c-service01-summary-list__item:nth-of-type(odd) {
    padding: 0 6% 0 8%
  }
  .c-service01-summary-list__item:nth-of-type(even) {
    padding: 0 8% 0 6%
  }
}
@media (min-width: 768px) {
  .c-service01-summary {
    padding: 100px 0 55px
  }
  .c-service01-summary__inner {
    max-width: 990px;
    margin: auto;
    padding: 0
  }
  .c-service01-summary__head {
    margin-bottom: 35px;
    font-size: 7rem
  }
  .c-service01-summary-list {
    max-width: 990px
  }
  .c-service01-summary-list__item {
    box-sizing: inherit;
    width: calc(33.3333% - 90px);
    margin: 0 45px 45px
  }
  .c-service01-summary-list__link:hover .c-service01-summary-list__img-on {
    opacity: 1
  }
  .c-service01-summary-list__img {
    margin-bottom: 35px;
    position: relative
  }
  .c-service01-summary-list__img img {
    -webkit-transition: all .3s ease;
    transition: all .3s ease
  }
  .c-service01-summary-list__img-on {
    display: block;
    opacity: 0;
    position: absolute;
    top: 0;
    left: 0
  }
  .c-service01-summary-list__head {
    font-size: 1.8rem
  }
}
@media (min-width: 768px) and (max-width: 1080px) {
  .c-service01-summary__inner {
    padding: 0 20px
  }
  .c-service01-summary-list__item {
    width: calc(33.3333% - 40px);
    margin: 0 20px 45px
  }
  .c-service01-summary-list__img {
    display: block;
    max-width: 240px;
    margin: 0 auto 35px
  }
}
.c-service01-works {
  margin-bottom: 90px
}
@media (min-width: 768px) {
  .c-service01-works {
    margin-bottom: 80px
  }
}
.c-service01-consult {
  padding: 40px 0 50px;
  background: url(/img/common/bg_consult01_sp.jpg);
  background-size: cover
}
.c-service01-consult__inner {
  padding: 0 10.6666%
}
.c-service01-consult__head {
  margin-bottom: 15px;
  line-height: 1.38;
  font-weight: 500;
  font-size: 1.8rem;
  text-align: center
}
.c-service01-consult__span {
  display: block;
  margin-bottom: 5px;
  font-size: 1.5rem
}
.c-service01-consult__txt {
  line-height: 1.5;
  font-size: 1rem;
  text-align: center
}
@media (min-width: 768px) {
  .c-service01-consult {
    padding: 80px 0 85px;
    background: url(/img/common/bg_consult01_pc.jpg);
    background-size: cover
  }
  .c-service01-consult__head {
    line-height: 1.61;
    font-size: 3.4rem
  }
  .c-service01-consult__span {
    font-size: 2.6rem
  }
  .c-service01-consult__txt {
    line-height: 2;
    font-size: 1.6rem
  }
}
.c-single01 {
  padding: 60px 0 65px
}
.c-single01__inner {
  padding-left: 5.3333%;
  padding-right: 5.3333%
}
.c-single01__heading {
  margin-bottom: 30px;
  padding: 0 18px 20px;
  border-bottom: 1px solid #262626
}
.c-single01__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 5px
}
.c-single01__date {
  display: block;
  margin-right: 15px;
  font-size: 1.5rem;
  color: #999
}
.c-single01-cat__item {
  display: inline-block;
  margin-bottom: 3px;
  padding: 1px 10px;
  line-height: 1.4;
  background-color: #999;
  font-size: 1.3rem;
  color: #fff
}
.c-single01-cat__item:not(:last-of-type) {
  margin-right: 8px
}
.c-single01__head {
  line-height: 1.55;
  font-weight: 500;
  font-size: 2rem
}
.c-single01__eyecatch {
  max-width: 600px;
  margin: auto;
  padding: 0 20px 20px
}
.c-single01-contents {
  overflow: hidden;
  margin-bottom: 50px;
  padding: 0 18px;
  line-height: 1.85;
  border-bottom: 1px solid #e6e6e6
}
.c-single01-contents h1, .c-single01-contents h2, .c-single01-contents h3, .c-single01-contents h4, .c-single01-contents h5, .c-single01-contents h6 {
  clear: both;
  margin-top: 35px
}
.c-single01-contents h2 {
  padding: 7px 15px;
  font-size: 1.8rem;
  background-color: #f2f3f3
}
.c-single01-contents h2 + p {
  margin-top: 10px
}
.c-single01-contents h3 {
  margin-top: 25px;
  font-size: 1.6rem;
  color: #0b3358
}
.c-single01-contents p:not([class]) {
  margin-bottom: 30px
}
.c-single01-contents strong {
  font-weight: 700
}
.c-single01-contents em {
  font-style: italic
}
.c-single01-contents img {
  padding-top: 15px;
  width: auto;
  max-width: 75%
}
.c-single01-contents img.alignright {
  display: inline;
  margin: 0 auto 10px;
  padding: 0 0 15px 15px
}
.c-single01-contents img.alignleft {
  display: inline;
  margin: 0 auto 10px;
  padding: 0 15px 15px 0
}
.c-single01-contents img, .c-single01-contents img.aligncenter {
  display: block;
  margin: 0 auto 10px;
  padding-bottom: 15px
}
.c-single01-contents .alignright {
  float: right
}
.c-single01-contents .alignleft {
  float: left
}
.c-single01-contents .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto
}
.c-single01-contents a {
  text-decoration: underline;
  color: #0b3358
}
.c-single01-contents ol {
  margin-bottom: 20px;
  counter-reset: li;
  list-style: none
}
.c-single01-contents ol li {
  position: relative
}
.c-single01-contents ol li:before {
  font-weight: 700;
  color: #0b3358;
  counter-increment: li;
  content: counter(li) ". "
}
.c-single01-contents ul {
  margin-bottom: 20px
}
.c-single01-contents ul li {
  position: relative;
  padding-left: 20px
}
.c-single01-contents ul li:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  background-color: #0b3358
}
.c-single01-btn__link {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 155px;
  height: 48px;
  margin: auto;
  line-height: 1.25;
  border: 1px solid #262626;
  background-color: #fff
}
.c-single01-btn__link:after {
  content: '';
  position: absolute;
  z-index: 1;
  left: -40%;
  top: 0;
  -webkit-transform: skew(50deg);
  -ms-transform: skew(50deg);
  transform: skew(50deg);
  -webkit-transition-duration: 0.6s;
  transition-duration: 0.6s;
  -webkit-transform-origin: top left;
  -ms-transform-origin: top left;
  transform-origin: top left;
  width: 0;
  height: 100%;
  background-color: #262626
}
.c-single01-btn__link:hover {
  color: #fff
}
.c-single01-btn__link:hover:after {
  width: 140%;
  height: 100%
}
.c-single01-btn__span {
  position: relative;
  z-index: 2
}
@media (min-width: 768px) {
  .c-single01 {
    max-width: 1100px;
    margin: auto;
    padding: 85px 0 80px
  }
  .c-single01__inner {
    margin-bottom: 80px;
    padding-left: 40px;
    padding-right: 40px
  }
  .c-single01__heading {
    margin-bottom: 60px;
    padding: 0 0 30px
  }
  .c-single01__meta {
    margin-bottom: 8px
  }
  .c-single01__head {
    font-size: 2.3rem
  }
  .c-single01__eyecatch {
    margin: 0 auto 30px
  }
  .c-single01-contents {
    margin-bottom: 80px;
    padding: 0 0 20px;
    line-height: 2;
    font-size: 1.5rem
  }
  .c-single01-contents h1, .c-single01-contents h2, .c-single01-contents h3, .c-single01-contents h4, .c-single01-contents h5, .c-single01-contents h6 {
    margin-top: 50px
  }
  .c-single01-contents h2 {
    margin-bottom: 30px;
    padding: 7px 30px;
    font-size: 2.2rem
  }
  .c-single01-contents h3 {
    margin-bottom: 15px;
    font-size: 2rem
  }
  .c-single01-contents p:not([class]) {
    margin-bottom: 35px
  }
  .c-single01-contents img {
    max-width: 640px;
    padding-top: 20px
  }
  .c-single01-contents img.alignright {
    margin: 0 auto 35px;
    padding: 0 0 30px 30px
  }
  .c-single01-contents img.alignleft {
    margin: 0 auto 35px;
    padding: 0 30px 30px 0
  }
  .c-single01-contents img, .c-single01-contents img.aligncenter {
    margin: 0 auto 35px;
    padding-bottom: 30px
  }
  .c-single01-btn__link {
    width: 214px;
    height: 60px;
    font-size: 1.8rem
  }
}
@media (min-width: 1200px) {
  .c-single01__inner {
    padding: 0
  }
}
.c-single02 {
  padding: 60px 0 65px;
  background-color: #fff
}
.c-single02__inner {
  padding-left: 5.3333%;
  padding-right: 5.3333%
}
.c-single02__heading {
  margin-bottom: 30px;
  padding: 11px 0;
  border-bottom: 1px solid #262626;
  position: relative
}
.c-single02__heading-ico {
  width: 45px;
  height: 45px;
  top: 0;
  left: 0;
  position: absolute;
  border-radius: 50%
}
.c-single02__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 11px;
  padding-left: 43px
}
.c-single02__date {
  display: block;
  margin-right: 5px;
  font-size: 1.5rem
}
.c-single02-cat__item {
  display: inline-block;
  margin-bottom: 3px;
  padding: 1px 10px;
  line-height: 1.4;
  font-size: 1.5rem;
  color: #b2b2b2
}
.c-single02-cat__item:not(:last-of-type) {
  margin-right: 8px
}
.c-single02__head {
  line-height: 1.55;
  font-weight: 500;
  font-size: 2rem
}
.c-single02__eyecatch {
  max-width: 600px;
  margin: auto;
  padding: 0 20px
}
.c-single02-contents {
  overflow: hidden;
  margin-bottom: 50px;
  padding: 0 18px;
  line-height: 2.21;
  border-bottom: 1px solid #e5e5e5;
  font-size: 1.4rem
}
.c-single02-contents h1, .c-single02-contents h2, .c-single02-contents h3, .c-single02-contents h4, .c-single02-contents h5, .c-single02-contents h6 {
  clear: both;
  margin-top: 25px
}
.c-single02-contents h2 {
  position: relative;
  padding-left: 23px;
  line-height: 1.52;
  font-weight: 500;
  font-size: 1.9rem
}
.c-single02-contents h2:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 1px;
  top: 6px;
  width: 13px;
  height: 13px;
  background-color: #0b3358
}
.c-single02-contents h2 + p {
  margin-top: 5px
}
.c-single02-contents h3 {
  margin-top: 10px;
  padding-bottom: 5px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 1.7rem
}
.c-single02-contents h3 + p {
  margin-top: 10px
}
.c-single02-contents h4 {
  font-size: 1.5rem
}
.c-single02-contents p:not([class]) {
  margin-bottom: 20px
}
.c-single02-contents strong {
  font-weight: 700
}
.c-single02-contents em {
  font-style: italic
}
.c-single02-contents img {
  padding-top: 15px;
  width: auto;
  max-width: 75%
}
.c-single02-contents img.alignright {
  display: inline;
  margin: 0 auto 10px;
  padding-left: 15px
}
.c-single02-contents img.alignleft {
  display: inline;
  margin: 0 auto 10px;
  padding-right: 15px
}
.c-single02-contents img, .c-single02-contents img.aligncenter {
  display: block;
  margin: 0 auto 10px
}
.c-single02-contents .alignright {
  float: right
}
.c-single02-contents .alignleft {
  float: left
}
.c-single02-contents .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto
}
.c-single02-contents a {
  text-decoration: underline;
  color: #0b3358
}
.c-single02-contents ol {
  margin-bottom: 10px;
  counter-reset: li;
  list-style: none
}
.c-single02-contents ol li {
  position: relative;
  padding-left: 22px
}
.c-single02-contents ol li:before {
  counter-increment: li;
  content: counter(li);
  position: absolute;
  left: 0;
  top: 8px;
  display: inline-block;
  width: 12px;
  height: 12px;
  line-height: 12px;
  background-color: #262626;
  color: #fff;
  font-size: 1.1rem;
  text-align: center
}
.c-single02-contents ul {
  margin-bottom: 10px
}
.c-single02-contents ul li {
  position: relative;
  padding-left: 15px
}
.c-single02-contents ul li:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 2px;
  top: 10px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #262626
}
@media (min-width: 768px) {
  .c-single02 {
    max-width: 1100px;
    margin: auto;
    padding: 76px 0 80px
  }
  .c-single02__inner {
    margin-bottom: 80px;
    padding-left: 40px;
    padding-right: 40px
  }
  .c-single02__heading {
    margin-bottom: 60px;
    padding: 6px 0 28px 100px;
    min-height: 110px;
    box-sizing: border-box
  }
  .c-single02__heading-ico {
    width: 90px;
    height: 90px
  }
  .c-single02__meta {
    margin-bottom: 5px;
    padding-left: 0
  }
  .c-single02__date {
    font-size: 1.3rem
  }
  .c-single02-cat__item {
    font-size: 1.3rem
  }
  .c-single02__head {
    font-size: 3rem;
    line-height: 1.3
  }
  .c-single02__eyecatch {
    margin: 0 auto 30px
  }
  .c-single02-contents {
    margin-bottom: 80px;
    padding: 0 0 20px;
    line-height: 2;
    font-size: 1.6rem
  }
  .c-single02-contents h1, .c-single02-contents h2, .c-single02-contents h3, .c-single02-contents h4, .c-single02-contents h5, .c-single02-contents h6 {
    margin-top: 40px
  }
  .c-single02-contents h2 {
    margin-bottom: 20px;
    padding-left: 38px;
    font-size: 2.7rem
  }
  .c-single02-contents h2:before {
    top: 13px;
    width: 20px;
    height: 20px
  }
  .c-single02-contents h3 {
    margin-bottom: 20px;
    font-size: 2.3rem
  }
  .c-single02-contents h4 {
    font-size: 1.9rem
  }
  .c-single02-contents p:not([class]) {
    margin-bottom: 30px
  }
  .c-single02-contents img {
    max-width: 100%;
    padding-top: 20px
  }
  .c-single02-contents img.alignright {
    margin: 0 auto 35px;
    padding-left: 30px
  }
  .c-single02-contents img.alignleft {
    margin: 0 auto 35px;
    padding-right: 30px
  }
  .c-single02-contents img, .c-single02-contents img.aligncenter {
    margin: 0 auto 35px
  }
  .c-single02-contents ol {
    margin-bottom: 10px;
    counter-reset: li
  }
  .c-single02-contents ol li {
    padding-left: 30px
  }
  .c-single02-contents ol li:before {
    top: 9px;
    left: 2px;
    width: 16px;
    height: 16px;
    line-height: 16px;
    font-size: 1.3rem
  }
  .c-single02-contents ul {
    margin-bottom: 10px
  }
  .c-single02-contents ul li {
    position: relative;
    padding-left: 15px
  }
  .c-single02-contents ul li:before {
    left: 2px;
    top: 14px;
    width: 6px;
    height: 6px
  }
}
@media (min-width: 1200px) {
  .c-single02__inner {
    padding: 0
  }
}
.c-single03 {
  padding: 60px 0 65px;
  background-color: #fff
}
.c-single03__inner {
  padding-left: 5.3333%;
  padding-right: 5.3333%
}
.c-single03__heading {
  margin-bottom: 30px;
  padding: 0 10px 20px;
  border-bottom: 1px solid #262626
}
.c-single03__date {
  display: block;
  margin-right: 5px;
  font-size: 1.5rem
}
.c-single03-cat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 13px
}
.c-single03-cat__item {
  display: inline-block;
  padding: 5px 7px;
  background-color: #262626;
  font-size: 1.1rem;
  color: #fff
}
.c-single03-cat__item:not(:last-of-type) {
  margin-right: 8px
}
.c-single03-tag {
  margin-bottom: 10px;
  font-size: 1.3rem
}
.c-single03-tag__item {
  display: inline-block;
  margin-bottom: 3px;
  margin-right: 3px
}
.c-single03__head {
  line-height: 1.55;
  font-weight: 500;
  font-size: 2rem
}
.c-single03__eyecatch {
  max-width: 600px;
  margin: 0 auto 23px;
  padding: 0 5.3333%
}
.c-single03-txt-area {
  margin-bottom: 30px
}
.c-single03-txt-area__head {
  position: relative;
  margin-bottom: 10px;
  padding-left: 40px;
  line-height: 1.52;
  font-weight: 500;
  font-size: 1.9rem
}
.c-single03-txt-area__head:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background-color: #0b3358;
	border-radius: 50px;
}
.c-single03-txt-area__txt {
  padding: 0 5.3333%;
  line-height: 2
}
.c-single03-contents {
  overflow: hidden;a 
  margin-bottom: 50px;
  padding: 0 18px;
  line-height: 2.21;
  font-size: 1.4rem
}
.c-single03-contents h1, .c-single03-contents h2, .c-single03-contents h3, .c-single03-contents h4, .c-single03-contents h5, .c-single03-contents h6 {
  clear: both;
  margin-top: 25px
}
.c-single03-contents h3 {
  margin-top: 10px;
  padding-bottom: 5px;
  border-bottom: 1px solid #e5e5e5;
  font-weight: 700;
  font-size: 1.7rem
}
.c-single03-contents h3 + p {
  margin-top: 10px
}
.c-single03-contents h4 {
  font-weight: 700;
  font-size: 1.5rem
}
.c-single03-contents p:not([class]) {
  margin-bottom: 20px
}
.c-single03-contents strong {
  font-weight: 700
}
.c-single03-contents em {
  font-style: italic
}
.c-single03-contents img {
  padding-top: 15px;
  width: auto;
  max-width: 75%
}
.c-single03-contents img.alignright {
  display: inline;
  margin: 0 auto 10px;
  padding-left: 15px
}
.c-single03-contents img.alignleft {
  display: inline;
  margin: 0 auto 10px;
  padding-right: 15px
}
.c-single03-contents img, .c-single03-contents img.aligncenter {
  display: block;
  margin: 0 auto 10px
}
.c-single03-contents .alignright {
  float: right
}
.c-single03-contents .alignleft {
  float: left
}
.c-single03-contents .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto
}
.c-single03-contents a {
  text-decoration: underline;
  color: #0793d4
}
.c-single03-contents ol {
  margin-bottom: 20px;
  counter-reset: li;
  list-style: none
}
.c-single03-contents ol li {
  position: relative;
  padding-left: 22px
}
.c-single03-contents ol li:before {
  counter-increment: li;
  content: counter(li);
  position: absolute;
  left: 0;
  top: 8px;
  display: inline-block;
  width: 12px;
  height: 12px;
  line-height: 12px;
  background-color: #262626;
  color: #fff;
  font-size: 1.1rem;
  text-align: center
}
.c-single03-contents ul {
  margin-bottom: 20px
}
.c-single03-contents ul li {
  position: relative;
  padding-left: 15px
}
.c-single03-contents ul li:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 2px;
  top: 10px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #262626
}
.c-single03-img-area {
  padding: 0 5.3333% 35px
}
.c-single03-img-area__item {
  margin-bottom: 10px
}
@media (min-width: 768px) {
  .c-single03 {
    max-width: 1100px;
    margin: auto;
    padding: 85px 0 80px
  }
  .c-single03__inner {
    margin-bottom: 80px;
    padding-left: 40px;
    padding-right: 40px
  }
  .c-single03__heading {
    margin-bottom: 60px;
    padding: 0 0 28px
  }
  .c-single03__date {
    font-size: 1.3rem
  }
  .c-single03-cat__item {
    padding: 6px 10px 7px;
    font-size: 1.3rem
  }
  .c-single03-tag {
    font-size: 1.5rem;
    margin-bottom: 20px
  }
  .c-single03-tag__item {
    margin-bottom: 5px;
    margin-right: 5px
  }
  .c-single03__head {
    font-size: 3rem
  }
  .c-single03__eyecatch {
    margin: 0 auto 50px
  }
  .c-single03-txt-area {
    margin-bottom: 45px
  }
  .c-single03-txt-area__head {
    margin-bottom: 15px;
    padding-left: 38px;
    font-size: 2.7rem
  }
  .c-single03-txt-area__head:before {
    left: 0;
    width: 20px;
    height: 20px
  }
  .c-single03-txt-area__txt {
    padding: 0
  }
  .c-single03-contents {
    margin-bottom: 80px;
    padding: 0 0 20px;
    line-height: 2;
    font-size: 1.6rem
  }
  .c-single03-contents h1, .c-single03-contents h2, .c-single03-contents h3, .c-single03-contents h4, .c-single03-contents h5, .c-single03-contents h6 {
    margin-top: 20px
  }
  .c-single03-contents h3 {
    margin-bottom: 20px;
    font-size: 2.3rem
  }
  .c-single03-contents h4 {
    font-size: 1.9rem
  }
  .c-single03-contents p:not([class]) {
    margin-bottom: 30px
  }
  .c-single03-contents img {
    max-width: 100%;
    padding-top: 20px
  }
  .c-single03-contents img.alignright {
    margin: 0 auto 35px;
    padding-left: 30px
  }
  .c-single03-contents img.alignleft {
    margin: 0 auto 35px;
    padding-right: 30px
  }
  .c-single03-contents img, .c-single03-contents img.aligncenter {
    margin: 0 auto 35px
  }
  .c-single03-contents ol {
    margin-bottom: 10px;
    counter-reset: li
  }
  .c-single03-contents ol li {
    padding-left: 30px
  }
  .c-single03-contents ol li:before {
    top: 9px;
    left: 2px;
    width: 16px;
    height: 16px;
    line-height: 16px;
    font-size: 1.3rem
  }
  .c-single03-contents ul {
    margin-bottom: 10px
  }
  .c-single03-contents ul li {
    position: relative;
    padding-left: 15px
  }
  .c-single03-contents ul li:before {
    left: 2px;
    top: 14px;
    width: 6px;
    height: 6px
  }
  .c-single03-img-area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 0 60px
  }
  .c-single03-img-area__item {
    width: 32.18%;
    margin-bottom: 20px
  }
  .c-single03-img-area__item:nth-of-type(4) {
    margin: 0 1.73%
  }
  .c-single03-img-area__item:first-of-type {
    width: calc(50% - 10px);
    margin-right: 10px
  }
  .c-single03-img-area__item:nth-of-type(2) {
    width: calc(50% - 10px);
    margin-left: 10px
  }
}
@media (min-width: 1200px) {
  .c-single03__inner {
    padding: 0
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .c-single03-img-area__item {
    margin-bottom: 12px
  }
  .c-single03-img-area__item:first-of-type {
    width: calc(50% - 6px);
    margin-right: 6px
  }
  .c-single03-img-area__item:nth-of-type(2) {
    width: calc(50% - 6px);
    margin-left: 6px
  }
}
.c-tab01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
.c-tab01__item {
  margin-right: 5px;
  padding: 5px 10px
}
.c-tab01__item.is-active {
  background: #333;
  color: #fff
}
.c-table01 th, .c-table01 td {
  padding: 10px
}
@media (max-width: 767px) {
  .c-table01 table, .c-table01 thead, .c-table01 tbody, .c-table01 tr, .c-table01 th, .c-table01 td {
    display: block
  }
  .c-table01 th, .c-table01 td {
    border-top: 1px solid #ccc
  }
}
@media (min-width: 768px) {
  .c-table01 th, .c-table01 td {
    border: 1px solid #ccc
  }
  .c-table01 th {
    padding: 10px 15px
  }
  .c-table01 td {
    padding: 10px 15px;
    vertical-align: middle
  }
}
.c-toggle-tit01 {
  position: relative;
  padding: 10px 50px 10px 15px;
  background: #333;
  color: #fff
}
.c-toggle-tit01:before, .c-toggle-tit01:after {
  position: absolute;
  top: 50%;
  right: 15px;
  content: "";
  display: block;
  width: 20px;
  height: 2px;
  margin-top: -1px;
  background: #fff;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.c-toggle-tit01:before {
  -webkit-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  transform: rotate(-90deg)
}
.c-toggle-tit01.is-active:before {
  -webkit-transform: rotate(0);
  -ms-transform: rotate(0);
  transform: rotate(0)
}
.l-breadcrumb .breadcrumb-list {
  padding: 15px 10px 25px
}
.l-breadcrumb .breadcrumb-list__item {
  display: inline-block;
  font-size: 1.3rem;
  color: #999
}
.l-breadcrumb .breadcrumb-list__item + .breadcrumb-list__item {
  padding-left: 10px
}
.l-breadcrumb .breadcrumb-list__item + .breadcrumb-list__item:before {
  content: ">";
  margin-right: 15px
}
.l-breadcrumb .breadcrumb-list__item a {
  color: #262626;
  text-decoration: underline
}
.l-breadcrumb .breadcrumb-list__item a:hover {
  text-decoration: none
}
.l-breadcrumb .breadcrumb-list__link {
  color: #262626
}
.l-footer {
  position: relative;
  z-index: 2;
  padding: 50px 30px 40px;
  background-color: #041C32
}
.l-footer .ft-sitemap {
  padding-bottom: 50px
}
.l-footer .ft-nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
.l-footer .ft-nav-list__item {
  box-sizing: border-box;
  width: 50%;
  line-height: 2.85
}
.l-footer .ft-nav-list__link {
  display: block;
  color: #fff
}
.l-footer .ft-nav-list__link:hover {
  color: #0b3358
}
.l-footer .ft-sub-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
.l-footer .ft-sub-list__item {
  width: 50%;
  line-height: 2.85
}
.l-footer .ft-sub-list__item:nth-of-type(even) .ft-sub-list__link {
  padding-left: 15px;
  padding-right: 15px;
}
.l-footer .ft-sub-list__link {
  display: block;
  color: #999
}
.l-footer .ft-sub-list__link:hover {
  color: #0b3358
}
.l-footer .ft-info__logo {
  width: 80px
}
.l-footer .ft-info__txt {
  padding: 10px 0 20px;
  line-height: 1.81;
  font-size: 1.1rem;
  color: #fff
}
.l-footer .ft-cr {
  font-size: 1.1rem;
  color: #999
}
@media (max-width: 767px) {
  .l-footer .ft-nav-list__item:nth-of-type(even) .ft-nav-list__link {
    padding-left: 30px
  }
}
@media (min-width: 768px) {
  .l-footer {
    padding-bottom: 80px
  }
  .l-footer__inner {
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: 1fr 45px;
    grid-template-rows: 1fr 45px;
    max-width: 1100px;
    margin: auto
  }
  .l-footer .ft-sitemap {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    -ms-grid-column-align: end;
    padding-bottom: 0
  }
  .l-footer .ft-nav-list {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end
  }
  .l-footer .ft-nav-list__item {
    width: auto;
    margin-left: 2em;
    text-align: right
  }
  .l-footer .ft-nav-list__item:first-of-type {
    margin-left: 0
  }
  .l-footer .ft-nav-list__link {
    font-size: 1.5rem
  }
  .l-footer .ft-sub-list {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end
  }
  .l-footer .ft-sub-list__item {
    width: auto
  }
  .l-footer .ft-sub-list__link {
    font-size: 1.5rem
  }
  .l-footer .ft-info {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-row-span: 3;
    grid-column: 1;
    grid-row: 1/3;
    -ms-flex-item-align: end;
    align-self: end;
    -ms-grid-row-align: end
  }
  .l-footer .ft-info__logo {
    width: 80px;
  }
  .l-footer .ft-info__txt {
    padding: 40px 0 0;
    line-height: 1.85;
    font-size: 1.4rem
  }
  .l-footer .ft-cr {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
    grid-column: 2;
    grid-row: 2;
    -ms-flex-item-align: end;
    align-self: end;
    -ms-grid-row-align: end;
    justify-self: end;
    -ms-grid-column-align: end;
    font-size: 1.3rem
  }
}
@media (min-width: 900px) and (max-width: 1080px) {
  .l-footer .ft-nav-list {
    width: 500px
  }
}
@media (min-width: 768px) and (max-width: 899px) {
  .l-footer .ft-nav-list__link {
    font-size: 1.4rem
  }
  .l-footer .ft-sub-list__link {
    font-size: 1.4rem
  }
  .l-footer .ft-info__logo {
    width: 80px;
  }
  .l-footer .ft-info__txt {
    font-size: 1.2rem
  }
}
.ft-pagetop {
  position: absolute;
  z-index: 2;
  right: -33px;
  top: 0;
  width: 108px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-item-align: center;
  align-self: center;
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg)
}
.ft-pagetop__link {
  position: relative;
  display: block;
  line-height: 1;
  font-size: 1.2rem;
  color: #fff
}
.ft-pagetop__link i {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 1px;
  margin: 0 0 6px 10px
}
.ft-pagetop__link i:after {
  content: '';
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #fff;
  -webkit-animation: line-animation 1.8s ease 1s infinite;
  animation: line-animation 1.8s ease 1s infinite
}
@media (min-width: 768px) {
  .ft-pagetop {
    right: -14px;
    top: -88px;
    width: 130px
  }
  .ft-pagetop__link {
    font-size: 1.6rem
  }
  .ft-pagetop__link i {
    width: 80px;
    margin: 0 0 7px 15px
  }
  .ft-pagetop__link:hover {
    color: #fff
  }
}
@-webkit-keyframes line-animation {
  from {
    width: 100%
  }
  to {
    width: 0
  }
}
@keyframes line-animation {
  from {
    width: 100%
  }
  to {
    width: 0
  }
}
.l-header {
  position: absolute;
  top: 0;
  z-index: 1000;
  width: 100%;
  min-width: 320px;
  height: 55px
}
.l-header.is-fixed .nav-btn {
  position: fixed;
  top: 0;
  right: 0
}
.l-header.is-fixed .l-nav.is-open {
  position: fixed;
  top: 0;
  left: 0
}
@media (min-width: 768px) {
  .l-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
    height: 90px
  }
  .l-header.is-fixed {
    position: fixed;
    top: 0;
    left: 0;
    background-color: #041C32
  }
  .l-header.is-fixed .hd-info {
    padding-top: 0
  }
  .l-header.is-fixed .hd-info__logo-anniv {
    display: none
  }
}
@media (min-width: 768px) and (max-width: 1279px) {
  .l-header.is-fixed .hd-info__logo svg {
    width: 150px;
    height: 32px
  }
}
.l-header .hd-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 17px 0 0 16px
}
.l-header .hd-info__logo {
  width: 166px
}
.l-header .hd-info__logo svg {
  width: 100px;
  padding-top: 3px
}
.l-header .hd-info__logo-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 80px;
}
.l-header .hd-info__logo-anniv {
  width: 51px
}
@media (min-width: 768px) {
  .l-header .hd-info {
    padding: 0 0 0 50px
  }
  .l-header .hd-info__logo {
    width: 100%;
    max-width: 352px
  }
  .l-header .hd-info__logo svg {
    width: 200px;
    height: 43px
  }
  .l-header .hd-info__logo-anniv {
    display: inline-block;
    width: 75px;
    margin-left: 40px
  }
}
@media (min-width: 768px) and (max-width: 812px) {
  .l-header .hd-info {
    padding: 0 0 0 10px
  }
  .l-header .hd-info__logo {
    -webkit-transform: translateY(-4px);
    -ms-transform: translateY(-4px);
    transform: translateY(-4px)
  }
  .l-header .hd-info__logo svg {
    width: 100px;
    height: 22px;
    padding-top: 0
  }
  .l-header .hd-info__logo-anniv {
    width: 45px;
    margin-left: 15px
  }
}
@media (min-width: 813px) and (max-width: 1023px) {
  .l-header .hd-info {
    padding: 0 0 0 15px
  }
  .l-header .hd-info__logo svg {
    width: 100px;
    height: 22px;
    padding-top: 0
  }
  .l-header .hd-info__logo-anniv {
    width: 45px;
    margin-left: 15px
  }
}
@media (min-width: 1024px) and (max-width: 1279px) {
  .l-header .hd-info {
    padding: 0 0 0 25px
  }
  .l-header .hd-info__logo svg {
    width: 150px;
    height: 32px
  }
  .l-header .hd-info__logo-anniv {
    width: 55px;
    margin-left: 20px
  }
}
.l-header .nav-btn {
  position: absolute;
  z-index: 2001;
  top: 0;
  right: 0;
  width: 55px;
  height: 55px;
  background: #0b3358;
  cursor: pointer；
}
.l-header .nav-btn__line {
  position: absolute;
  top: 27px;
  right: 20px;
  width: 15px;
  height: 1px;
  background: #fff;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.l-header .nav-btn__line:nth-child(2) {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg)
}
.l-header .nav-btn.is-open .nav-btn__line:nth-child(1) {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.l-header .nav-btn.is-open .nav-btn__line:nth-child(2) {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.l-nav {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2000;
  width: 100%;
  height: 100vh;
  min-width: 320px;
  box-sizing: border-box;
  text-align: center;
  -webkit-overflow-scrolling: touch;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}
@media (max-width: 767px) {
  .l-nav {
    overflow: auto;
    -webkit-transform: translateX(120%);
    -ms-transform: translateX(120%);
    transform: translateX(120%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
	background-color: #041C32;
	  
  }
  .l-nav::-webkit-scrollbar {
    display: none
  }
  .l-nav.is-open {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0)
  }
}
.l-nav .nav-list {
  width: 100%;
  height: 100%
}
.l-nav .nav-list__link {
  line-height: 2.75;
  font-size: 2rem;
  color: #fff
}
.l-nav .nav-list__sub-item {
  display: inline-block;
  margin-top: 18.5%
}
.l-nav .nav-list__sub-item:first-of-type {
  margin-right: 10px
}
.l-nav .nav-list__sub-item:last-of-type {
  margin-left: 10px
}
.l-nav .nav-list__sub-link {
  line-height: 2.4;
  font-size: 1.3rem;
  color: #fff
}
@media (max-width: 667px) and (orientation: landscape) {
  .l-nav .nav-list__link {
    line-height: 2.1;
    font-size: 1.7rem;
  }
  .l-nav .nav-list__sub-item {
    margin-top: 8%
  }
}
@media (min-width: 768px) {
  .l-nav {
    position: static;
    width: auto;
    min-width: auto;
    height: 90px
  }
  .l-nav .nav-list {
    padding: 20px 50px 20px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
  }
  .l-nav .nav-list__item {
    margin-right: 2em
  }
  .l-nav .nav-list__item.is-contact {
    margin-right: 0
  }
  .l-nav .nav-list__item.is-contact .nav-list__link {
    position: relative;
    overflow: hidden;
    width: 150px;
    height: 50px;
    background-color: #0b3358
  }
  .l-nav .nav-list__item.is-contact .nav-list__link:after {
    content: '';
    position: absolute;
    z-index: 1;
    left: -40%;
    top: 0;
    -webkit-transform: skew(50deg);
    -ms-transform: skew(50deg);
    transform: skew(50deg);
    -webkit-transition-duration: 0.6s;
    transition-duration: 0.6s;
    -webkit-transform-origin: top left;
    -ms-transform-origin: top left;
    transform-origin: top left;
    width: 0;
    height: 100%;
    background-color: #fff
  }
  .l-nav .nav-list__item.is-contact .nav-list__link:hover:after {
    width: 140%;
    height: 100%
  }
  .l-nav .nav-list__item.is-contact .nav-list__span {
    position: relative;
    z-index: 2
  }
  .l-nav .nav-list__link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 50px;
    font-size: 1.5rem
  }
  .l-nav .nav-list__link:hover {
    color: #1F5E9B;
  }
  .l-nav .nav-list__ico {
    margin-left: 7px;
    font-size: 1.1rem
  }
}
@media (min-width: 768px) and (max-width: 812px) {
  .l-nav .nav-list {
    padding: 15px 10px 0 0
  }
  .l-nav .nav-list__item {
    margin-right: 1em
  }
  .l-nav .nav-list__item.is-contact .nav-list__link {
    width: 100px;
    font-size: 1.3rem
  }
  .l-nav .nav-list__link {
    font-size: 1.3rem
  }
}
@media (min-width: 813px) and (max-width: 1079px) {
  .l-nav .nav-list {
    padding: 15px 15px 0 0
  }
  .l-nav .nav-list__item {
    margin-right: 1em
  }
  .l-nav .nav-list__item.is-contact .nav-list__link {
    width: 120px;
    font-size: 1.3rem
  }
  .l-nav .nav-list__link {
    font-size: 1.5rem
  }
}
.l-main-img {
  position: relative;
  width: 100%;
  height: 100vh
}
.l-main-img__inner {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 100%
}
.l-main-img-copy {
  position: absolute;
  top: 214px;
  width: 80%;
	margin-left: 10%;
	margin-right: 10%;
}
@media (max-width: 768px) {
.l-main-img-copy {
position: absolute;
  top: 50%; /* 親要素の高さの50%の位置 */
  left: 50%; /* 親要素の幅の50%の位置 */
  transform: translate(-50%, -50%); /* 自分のサイズの50%だけ戻す */
  width: 80%;
  margin-left: 0; /* 不要になるので削除 */
  margin-right: 0; /* 不要になるので削除 */
	}
}
.l-main-img-copy__en, .l-main-img-copy__sub, .l-main-img-copy__main {
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px);
  -webkit-transition: opacity 1200ms, -webkit-transform 1200ms;
  transition: opacity 1200ms, -webkit-transform 1200ms;
  transition: opacity 1200ms, transform 1200ms;
  transition: opacity 1200ms, transform 1200ms, -webkit-transform 1200ms
}
.l-main-img-copy__en.is-active, .l-main-img-copy__sub.is-active, .l-main-img-copy__main.is-active {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0)
}
.l-main-img-copy__en {
  position: relative;
  margin-bottom: 3vh;
  font-size: 3rem;
  color: #fff;
  -webkit-transition-delay: 600ms;
  transition-delay: 600ms
}

.l-main-img-copy__sub {
  width: 100%;
  -webkit-transition-delay: 700ms;
  transition-delay: 700ms
}
.l-main-img-copy__sub.is-second {
  -webkit-transition-delay: 800ms;
  transition-delay: 800ms
}
.l-main-img-copy__main {
  width: 100%;
  -webkit-transition-delay: 900ms;
  transition-delay: 900ms
}
.l-main-img__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 110%;
  height: 100%;
  -webkit-transform: translateX(-5%);
  -ms-transform: translateX(-5%);
  transform: translateX(-5%);
  -webkit-transform-origin: center center;
  -ms-transform-origin: center center;
  transform-origin: center center;
  -webkit-transition: opacity 600ms linear 0s, -webkit-transform 5.5s linear 0s;
  transition: opacity 600ms linear 0s, -webkit-transform 5.5s linear 0s;
  transition: transform 5.5s linear 0s, opacity 600ms linear 0s;
  transition: transform 5.5s linear 0s, opacity 600ms linear 0s, -webkit-transform 5.5s linear 0s;
  opacity: 1
}
.l-main-img__img:before {
  content: '';
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover
}
.l-main-img__img.is-shown {
  opacity: 1;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0)
}
.l-main-img__img.is-first:before {
  background-image: url("../img/bg_mv02_sp.jpg")
}
.l-main-img__img.is-second:before {
  background-image: url(../img/bg_mv02_sp.jpg)
}
.l-main-img__img.is-third:before {
  background-image: url(../img/bg_mv02_sp.jpg)
}
@media (min-width: 768px) {
  .l-main-img {
    width: 100%;
    min-height: 668px;
    max-height: 1080px
  }
  .l-main-img__img {
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
    transform: translateX(0%)
  }
  .l-main-img__img.is-first:before {
    background-image: url(../img/bg_mv02_pc.jpg)
  }
  .l-main-img__img.is-second:before {
    background-image: url(../img/bg_mv02_pc.jpg)
  }
  .l-main-img__img.is-third:before {
    background-image: url(../img/bg_mv02_pc.jpg)
  }
  .l-main-img-copy {
    top: 34.07%;
    left: 0px
  }
  .l-main-img-copy__en {
    margin-bottom: 3.2vh;
    font-size: 5rem
  }
  .l-main-img-copy__en:before {
    left: 0;
    width: 80px
  }
  .l-main-img-copy__sub {
    width: 663px
  }
  .l-main-img-copy__main {
    width: 663px
  }
}
@media (min-width: 1180px) {
  .l-main-img-copy {
    left: 0%
  }
}
@media (max-width: 667px) and (orientation: landscape) {
  .l-main-img-copy {
    top: 80px;
    width: 80%
  }
}
.l-loading {
  content: '';
  position: fixed;
  z-index: 9000;
  width: 100%;
  height: 100vh;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: #000
}
.l-loading__img {
  opacity: 0;
  width: 50%;
  -webkit-transform: translateY(30px);
  -ms-transform: translateY(30px);
  transform: translateY(30px);
  -webkit-animation: fade-up 800ms ease 600ms forwards;
  animation: fade-up 800ms ease 600ms forwards
}
.l-loading__img.is-hidden {
  -webkit-animation: fade-out 400ms linear forwards;
  animation: fade-out 400ms linear forwards
}
.l-loading.is-hidden {
  -webkit-animation: fade-away 600ms ease 600ms forwards;
  animation: fade-away 600ms ease 600ms forwards;
  -webkit-transform-origin: center right;
  -ms-transform-origin: center right;
  transform-origin: center right
}
@media (min-width: 768px) {
  .l-loading__img {
    width: 350px
  }
}
@-webkit-keyframes fade-up {
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
}
@keyframes fade-up {
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
}
@-webkit-keyframes fade-away {
  100% {
    -webkit-transform: scaleX(0);
    transform: scaleX(0)
  }
}
@keyframes fade-away {
  100% {
    -webkit-transform: scaleX(0);
    transform: scaleX(0)
  }
}
@-webkit-keyframes fade-out {
  0% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
}
@keyframes fade-out {
  0% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
  100% {
    opacity: 0;
    -webkit-transform: translateY(0);
    transform: translateY(0)
  }
}
.mv-scroll {
  position: absolute;
  z-index: 5;
  right: -39px;
  bottom: 155px;
  width: 120px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-item-align: center;
  align-self: center;
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg)
}
.mv-scroll__link {
  position: relative;
  display: block;
  line-height: 1;
  font-size: 1.2rem;
  color: #fff
}
.mv-scroll__link i {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 1px;
  margin: 0 0 6px 10px
}
.mv-scroll__link i:after {
  content: '';
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #fff;
  -webkit-animation: line-animation 1.8s ease 1s infinite;
  animation: line-animation 1.8s ease 1s infinite
}
@media (min-width: 768px) {
  .mv-scroll {
    right: -76px;
    bottom: 60px;
    width: 254px
  }
  .mv-scroll__link {
    font-size: 1.6rem
  }
  .mv-scroll__link i {
    width: 180px;
    margin: 0 0 7px 15px
  }
  .mv-scroll__link i:after {
    background-color: #999
  }
  .mv-scroll__link:hover {
    color: #fff
  }
}
@-webkit-keyframes line-animation {
  from {
    width: 100%
  }
  to {
    width: 0
  }
}
@keyframes line-animation {
  from {
    width: 100%
  }
  to {
    width: 0
  }
}
/* =========================
   News バー（共通スタイル）
   ========================= */
.home-mv-news {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 86%;
  height: 80px;
  margin: 0 7% 10px;
  background-color: #1e63a5;
  border-radius: 15px;
}

.home-mv-news__head {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 100%;
  background-color: #0b3358;
  font-size: 1.2rem;
  color: #fff;
  border-radius: 0;
}

.home-mv-news-list {
  display: flex;
  align-items: center;
  height: 100%;
  padding: 0 40px 0 75px;
}

.home-mv-news-list__date {
  font-size: 1.2rem;
  color: #999;
}

.home-mv-news-list__head {
  line-height: 2;
  font-size: 1.2rem;
  color: #fff;
}

/* ---- 進む・戻るボタン（スマホも表示） ---- */
.home-mv-news-btn {
  /* スマホでも表示させる */
  display: block;
  position: absolute;
  top: 8px;
  right: 8px;
  width: 40px;
  height: 40px;
  cursor: pointer;
}

.home-mv-news-btn::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  pointer-events: none;
}

.home-mv-news-btn.is-first::before {
  transform: translate(-6px, -50%) rotate(-45deg);
}

.home-mv-news-btn.is-second {
  top: 40px;
}

.home-mv-news-btn.is-second::before {
  transform: translate(-6px, -50%) rotate(135deg);
}

/* ──────────────────────────────
   スマホ（〜767px）
   ────────────────────────────── */
@media (max-width: 767px) {

  /* まず全件非表示にし、is-shown だけ出す */
  .home-mv-news-list__item {
    display: none;
  }
  .home-mv-news-list__item.is-shown {
    display: block;
  }

  /* 矢印サイズはスマホ向けに維持（上で定義済み） */
}

/* =========================
   768px 以上（PC・タブレット）
   ========================= */
@media (min-width: 768px) {
  .home-mv-news {
    width: 960px;
    height: 120px;
    margin-bottom: -40px;
    z-index: 999;
  }

  .home-mv-news__head {
    width: 120px;
    height: 120px;
    font-size: 2.3rem;
  }

  .home-mv-news-list {
    position: relative;
    padding: 0;
  }

  .home-mv-news-list__item {
    box-sizing: border-box;
    position: absolute;
    z-index: 1;
    opacity: 0;
    top: 0;
    left: 0;
    height: 100%;
    margin: 0 110px 0 160px;
    padding: 28px 0;
    transition: all .5s ease-out;
  }
  .home-mv-news-list__item.is-shown {
    z-index: 2;
    opacity: 1;
  }

  .home-mv-news-list__date {
    margin-bottom: 5px;
    font-size: 1.5rem;
  }
  .home-mv-news-list__head {
    font-size: 1.5rem;
  }

  /* PC 用にボタンサイズを上書き */
  .home-mv-news-btn {
    top: 0;
    right: 0;
    width: 60px;
    height: 60px;
  }
  .home-mv-news-btn::before {
    width: 10px;
    height: 10px;
  }
  .home-mv-news-btn.is-first::before {
    transform: translate(-5px, -50%) rotate(-45deg);
  }
  .home-mv-news-btn.is-second {
    top: 60px;
  }
  .home-mv-news-btn.is-second::before {
    transform: translate(-5px, -50%) rotate(135deg);
  }
}

/* タブレット横持ち向け微調整 */
@media (min-width: 768px) and (max-width: 1080px) {
  .home-mv-news {
    width: 85%;
    margin-bottom: 0;
  }
  .home-mv-news-list__item {
    padding: 14px 0;
  }
}

/* 横向きスマホ (例: iPhone landscape) */
@media (max-width: 667px) and (orientation: landscape) {
  .home-mv-news {
    height: 80px;
  }
  .home-mv-news-list__date,
  .home-mv-news-list__head {
    font-size: 1rem;
  }
}


/* ─── 戻る / 進む ボタン（共通サイズ） ────────────── */
.home-mv-news-btn{position:absolute;right:8px;width:44px;height:32px;cursor:pointer;z-index:3;background:transparent;border:none}
.home-mv-news-btn::before{content:'';position:absolute;top:50%;left:50%;width:10px;height:10px;border-top:2px solid #fff;border-right:2px solid #fff;transform:translate(-50%,-50%) rotate(-45deg)}
.js-news-prev{top:8px}              /* ↑ 戻る（▲向き） */
.js-news-next{top:40px}           /* ↓ 進む（▼向き） */
.js-news-next::before{transform:translate(-50%,-50%) rotate(135deg)}

/* ─── PC だけ大きく ──────────────────────── */
@media (min-width:768px){
  .js-news-prev{top:20px}
  .js-news-next{top:70px}
}

.l-sub-img {
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 269px;
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  color: #fff;
  text-align: center
}
.l-sub-img__sub-head {
  -ms-flex-item-align: end;
  align-self: flex-end;
  width: 100%;
  -webkit-transform: translateY(27px);
  -ms-transform: translateY(27px);
  transform: translateY(27px);
  font-size: 4.5rem
}
.l-sub-img__head {
  -ms-flex-item-align: start;
  align-self: flex-start;
  width: 100%;
  -webkit-transform: translateY(16px);
  -ms-transform: translateY(16px);
  transform: translateY(16px);
  font-size: 1.4rem
}
@media (min-width: 768px) {
  .l-sub-img {
    height: 480px
  }
  .l-sub-img__sub-head {
    -webkit-transform: translateY(38px);
    -ms-transform: translateY(38px);
    transform: translateY(38px);
    font-size: 7rem
  }
  .l-sub-img__head {
    -webkit-transform: translateY(13px);
    -ms-transform: translateY(13px);
    transform: translateY(13px);
    font-size: 2rem
  }
}
.l-anniv-img {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 144%;
  background: url("../img/bg_cv01_sp.jpg") no-repeat top center;
  background-size: cover
}
.l-anniv-img-content {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 100%;
  margin-top: 10px;
  z-index: 3
}
.l-anniv-img-logo {
  width: 60%;
  margin: 0 auto 18px
}
.l-anniv-img__btn {
  max-width: 225px;
  width: 100%;
  margin: auto
}
.l-anniv-img__btn-txt {
  position: relative;
  display: block;
  padding: 24px 52px 20px 0;
  box-sizing: border-box;
  color: #fff;
  font-size: 1.4rem;
  text-transform: uppercase;
  text-align: center;
  cursor: pointer
}
.l-anniv-img__btn-txt:before, .l-anniv-img__btn-txt:after {
  content: '';
  position: absolute
}
.l-anniv-img__btn-txt:before {
  top: 8px;
  right: -5px;
  width: 54px;
  height: 54px;
  border: 1px solid #0b3358;
  border-radius: 50%;
  box-sizing: border-box
}
.l-anniv-img__btn-txt:after {
  top: 27px;
  right: 13px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7.5px 0 7.5px 12.5px;
  border-color: transparent transparent transparent #0b3358
}
@media (min-width: 768px) {
  .l-anniv-img {
    height: 100vh;
    max-height: 1080px;
    padding-top: 0;
    background: #000
  }
  .l-anniv-img-video-wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden
  }
  .l-anniv-img-video-container {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden
  }
  .l-anniv-img-video-container:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    z-index: 1
  }
  .l-anniv-img-video-container iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 128%;
    height: 128%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    pointer-events: none
  }
  .l-anniv-img-content {
    margin-top: 24px
  }
  .l-anniv-img-logo {
    width: 698px;
    margin: 0 auto 48px
  }
  .l-anniv-img__btn {
    max-width: 270px
  }
  .l-anniv-img__btn:hover .l-anniv-img__btn-txt:before {
    background: #0b3358
  }
  .l-anniv-img__btn:hover .l-anniv-img__btn-txt:after {
    border-color: transparent transparent transparent #fff
  }
  .l-anniv-img__btn-txt {
    padding: 18px 80px 16px 0;
    font-size: 1.6rem;
    z-index: 1;
    -webkit-transition: all .3s ease;
    transition: all .3s ease
  }
  .l-anniv-img__btn-txt:before, .l-anniv-img__btn-txt:after {
    -webkit-transition: all .3s ease;
    transition: all .3s ease
  }
  .l-anniv-img__btn-txt:before {
    top: 0;
    right: 15px;
    width: 60px;
    height: 60px
  }
  .l-anniv-img__btn-txt:after {
    top: 22px;
    right: 36px;
    border-width: 8px 0 8px 14px
  }
}
.l-anniv-img-loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 10;
  -webkit-transition: all .7s ease;
  transition: all .7s ease;
  opacity: 1;
  visibility: visible
}
.l-anniv-img-loading.is-hide {
  opacity: 1;
  visibility: hidden
}
.l-anniv-img-loading__img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 60%
}
@media (min-width: 768px) {
  .l-anniv-img-loading__img {
    width: 221px
  }
}
.l-anniv-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 5000;
  display: none
}
.l-anniv-popup-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000
}
.l-anniv-popup-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 55px;
  height: 55px;
  box-sizing: border-box;
  border: 1px solid #0b3358;
  z-index: 4000;
  cursor: pointer
}
.l-anniv-popup-close:before, .l-anniv-popup-close:after {
  content: '';
  position: absolute;
  top: 11px;
  left: 26px;
  width: 1px;
  height: 30px;
  background: #0b3358
}
.l-anniv-popup-close:before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.l-anniv-popup-close:after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.l-anniv-popup-video-container {
  position: relative;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  height: 0;
  padding-bottom: 56.25%;
  z-index: 1;
  overflow: hidden
}
.l-anniv-popup-video-container:before, .l-anniv-popup-video-container:after {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  height: 30%;
  background: #000;
  z-index: 1
}
.l-anniv-popup-video-container:before {
  top: -1px
}
.l-anniv-popup-video-container:after {
  bottom: -1px
}
.l-anniv-popup-video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}
@media (max-width: 375px) {
  .l-anniv-popup-video-container:before {
    height: 26%
  }
  .l-anniv-popup-video-container:after {
    height: 18%
  }
}
@media (max-width: 359px) {
  .l-anniv-popup-video-container:before {
    height: 30%
  }
  .l-anniv-popup-video-container:after {
    height: 21%
  }
}
@media (min-width: 768px) {
  .l-anniv-popup-close {
    top: 20px;
    right: 20px;
    -webkit-transition: all .3s ease;
    transition: all .3s ease
  }
  .l-anniv-popup-close:before, .l-anniv-popup-close:after {
    -webkit-transition: all .3s ease;
    transition: all .3s ease
  }
  .l-anniv-popup-close:hover {
    background: #0b3358
  }
  .l-anniv-popup-close:hover:before, .l-anniv-popup-close:hover:after {
    background: #fff
  }
  .l-anniv-popup-video-container:before, .l-anniv-popup-video-container:after {
    height: 11%
  }
  .l-anniv-popup-video-container iframe {
    pointer-events: none
  }
  .l-anniv-popup-controller {
    position: absolute;
    left: 20px;
    bottom: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: 200
  }
  .l-anniv-popup-pray, .l-anniv-popup-sound {
    box-sizing: border-box;
    cursor: pointer
  }
  .l-anniv-popup-pray {
    width: 35px;
    border: 1px solid #0b3358
  }
  .l-anniv-popup-pray img.is-play {
    display: none
  }
  .l-anniv-popup-pray.is-play img.is-play {
    display: block
  }
  .l-anniv-popup-pray.is-play img.is-stop {
    display: none
  }
  .l-anniv-popup-sound {
    width: 25px;
    margin-left: 20px
  }
  .l-anniv-popup-sound img.is-mute {
    display: none;
    padding-top: 4px
  }
  .l-anniv-popup-sound.is-sound img.is-mute {
    display: block
  }
  .l-anniv-popup-sound.is-sound img.is-sound {
    display: none
  }
}
@font-face {
  font-family: "iconfont";
  src: url("/font/iconfont.eot");
  src: url("/font/iconfont.eot?#iefix") format("eot"), url("/font/iconfont.woff2") format("woff2"), url("/font/iconfont.woff") format("woff"), url("/font/iconfont.ttf") format("truetype"), url("/font/iconfont.svg#iconfont") format("svg")
}
[class*=c-icon]:before {
  font-family: "iconfont";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  speak: none;
  text-decoration: none;
  text-transform: none
}
.c-icon-link01:before {
  content: "\E001"
}
.particle-container {
  position: absolute
}
@-webkit-keyframes particle-animation-1 {
  100% {
    -webkit-transform: translate3d(55vw, 61vh, 4px);
    transform: translate3d(55vw, 61vh, 4px)
  }
}
@keyframes particle-animation-1 {
  100% {
    -webkit-transform: translate3d(55vw, 61vh, 4px);
    transform: translate3d(55vw, 61vh, 4px)
  }
}
.particle:nth-child(1) {
  -webkit-animation: particle-animation-1 60s infinite;
  animation: particle-animation-1 60s infinite;
  opacity: .36;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -.2s;
  animation-delay: -.2s;
  -webkit-transform: translate3d(44vw, 36vh, 18px);
  transform: translate3d(44vw, 36vh, 18px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-2 {
  100% {
    -webkit-transform: translate3d(45vw, 67vh, 74px);
    transform: translate3d(45vw, 67vh, 74px)
  }
}
@keyframes particle-animation-2 {
  100% {
    -webkit-transform: translate3d(45vw, 67vh, 74px);
    transform: translate3d(45vw, 67vh, 74px)
  }
}
.particle:nth-child(2) {
  -webkit-animation: particle-animation-2 60s infinite;
  animation: particle-animation-2 60s infinite;
  opacity: .01;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -.4s;
  animation-delay: -.4s;
  -webkit-transform: translate3d(55vw, 72vh, 49px);
  transform: translate3d(55vw, 72vh, 49px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-3 {
  100% {
    -webkit-transform: translate3d(24vw, 2vh, 52px);
    transform: translate3d(24vw, 2vh, 52px)
  }
}
@keyframes particle-animation-3 {
  100% {
    -webkit-transform: translate3d(24vw, 2vh, 52px);
    transform: translate3d(24vw, 2vh, 52px)
  }
}
.particle:nth-child(3) {
  -webkit-animation: particle-animation-3 60s infinite;
  animation: particle-animation-3 60s infinite;
  opacity: .2;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -.6s;
  animation-delay: -.6s;
  -webkit-transform: translate3d(65vw, 44vh, 78px);
  transform: translate3d(65vw, 44vh, 78px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-4 {
  100% {
    -webkit-transform: translate3d(20vw, 29vh, 83px);
    transform: translate3d(20vw, 29vh, 83px)
  }
}
@keyframes particle-animation-4 {
  100% {
    -webkit-transform: translate3d(20vw, 29vh, 83px);
    transform: translate3d(20vw, 29vh, 83px)
  }
}
.particle:nth-child(4) {
  -webkit-animation: particle-animation-4 60s infinite;
  animation: particle-animation-4 60s infinite;
  opacity: .94;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -.8s;
  animation-delay: -.8s;
  -webkit-transform: translate3d(87vw, 14vh, 30px);
  transform: translate3d(87vw, 14vh, 30px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-5 {
  100% {
    -webkit-transform: translate3d(18vw, 8vh, 73px);
    transform: translate3d(18vw, 8vh, 73px)
  }
}
@keyframes particle-animation-5 {
  100% {
    -webkit-transform: translate3d(18vw, 8vh, 73px);
    transform: translate3d(18vw, 8vh, 73px)
  }
}
.particle:nth-child(5) {
  -webkit-animation: particle-animation-5 60s infinite;
  animation: particle-animation-5 60s infinite;
  opacity: .2;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -1s;
  animation-delay: -1s;
  -webkit-transform: translate3d(59vw, 17vh, 78px);
  transform: translate3d(59vw, 17vh, 78px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-6 {
  100% {
    -webkit-transform: translate3d(72vw, 82vh, 50px);
    transform: translate3d(72vw, 82vh, 50px)
  }
}
@keyframes particle-animation-6 {
  100% {
    -webkit-transform: translate3d(72vw, 82vh, 50px);
    transform: translate3d(72vw, 82vh, 50px)
  }
}
.particle:nth-child(6) {
  -webkit-animation: particle-animation-6 60s infinite;
  animation: particle-animation-6 60s infinite;
  opacity: .9;
  height: 8px;
  width: 8px;
  -webkit-animation-delay: -1.2s;
  animation-delay: -1.2s;
  -webkit-transform: translate3d(58vw, 77vh, 44px);
  transform: translate3d(58vw, 77vh, 44px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-7 {
  100% {
    -webkit-transform: translate3d(39vw, 66vh, 63px);
    transform: translate3d(39vw, 66vh, 63px)
  }
}
@keyframes particle-animation-7 {
  100% {
    -webkit-transform: translate3d(39vw, 66vh, 63px);
    transform: translate3d(39vw, 66vh, 63px)
  }
}
.particle:nth-child(7) {
  -webkit-animation: particle-animation-7 60s infinite;
  animation: particle-animation-7 60s infinite;
  opacity: .82;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -1.4s;
  animation-delay: -1.4s;
  -webkit-transform: translate3d(56vw, 39vh, 62px);
  transform: translate3d(56vw, 39vh, 62px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-8 {
  100% {
    -webkit-transform: translate3d(22vw, 22vh, 54px);
    transform: translate3d(22vw, 22vh, 54px)
  }
}
@keyframes particle-animation-8 {
  100% {
    -webkit-transform: translate3d(22vw, 22vh, 54px);
    transform: translate3d(22vw, 22vh, 54px)
  }
}
.particle:nth-child(8) {
  -webkit-animation: particle-animation-8 60s infinite;
  animation: particle-animation-8 60s infinite;
  opacity: .05;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -1.6s;
  animation-delay: -1.6s;
  -webkit-transform: translate3d(87vw, 88vh, 54px);
  transform: translate3d(87vw, 88vh, 54px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-9 {
  100% {
    -webkit-transform: translate3d(77vw, 68vh, 95px);
    transform: translate3d(77vw, 68vh, 95px)
  }
}
@keyframes particle-animation-9 {
  100% {
    -webkit-transform: translate3d(77vw, 68vh, 95px);
    transform: translate3d(77vw, 68vh, 95px)
  }
}
.particle:nth-child(9) {
  -webkit-animation: particle-animation-9 60s infinite;
  animation: particle-animation-9 60s infinite;
  opacity: .74;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -1.8s;
  animation-delay: -1.8s;
  -webkit-transform: translate3d(90vw, 49vh, 8px);
  transform: translate3d(90vw, 49vh, 8px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-10 {
  100% {
    -webkit-transform: translate3d(84vw, 1vh, 41px);
    transform: translate3d(84vw, 1vh, 41px)
  }
}
@keyframes particle-animation-10 {
  100% {
    -webkit-transform: translate3d(84vw, 1vh, 41px);
    transform: translate3d(84vw, 1vh, 41px)
  }
}
.particle:nth-child(10) {
  -webkit-animation: particle-animation-10 60s infinite;
  animation: particle-animation-10 60s infinite;
  opacity: .21;
  height: 6px;
  width: 6px;
  -webkit-animation-delay: -2s;
  animation-delay: -2s;
  -webkit-transform: translate3d(33vw, 40vh, 63px);
  transform: translate3d(33vw, 40vh, 63px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-11 {
  100% {
    -webkit-transform: translate3d(84vw, 37vh, 38px);
    transform: translate3d(84vw, 37vh, 38px)
  }
}
@keyframes particle-animation-11 {
  100% {
    -webkit-transform: translate3d(84vw, 37vh, 38px);
    transform: translate3d(84vw, 37vh, 38px)
  }
}
.particle:nth-child(11) {
  -webkit-animation: particle-animation-11 60s infinite;
  animation: particle-animation-11 60s infinite;
  opacity: .34;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -2.2s;
  animation-delay: -2.2s;
  -webkit-transform: translate3d(74vw, 15vh, 26px);
  transform: translate3d(74vw, 15vh, 26px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-12 {
  100% {
    -webkit-transform: translate3d(4vw, 20vh, 9px);
    transform: translate3d(4vw, 20vh, 9px)
  }
}
@keyframes particle-animation-12 {
  100% {
    -webkit-transform: translate3d(4vw, 20vh, 9px);
    transform: translate3d(4vw, 20vh, 9px)
  }
}
.particle:nth-child(12) {
  -webkit-animation: particle-animation-12 60s infinite;
  animation: particle-animation-12 60s infinite;
  opacity: .17;
  height: 6px;
  width: 6px;
  -webkit-animation-delay: -2.4s;
  animation-delay: -2.4s;
  -webkit-transform: translate3d(46vw, 50vh, 2px);
  transform: translate3d(46vw, 50vh, 2px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-13 {
  100% {
    -webkit-transform: translate3d(16vw, 42vh, 34px);
    transform: translate3d(16vw, 42vh, 34px)
  }
}
@keyframes particle-animation-13 {
  100% {
    -webkit-transform: translate3d(16vw, 42vh, 34px);
    transform: translate3d(16vw, 42vh, 34px)
  }
}
.particle:nth-child(13) {
  -webkit-animation: particle-animation-13 60s infinite;
  animation: particle-animation-13 60s infinite;
  opacity: .74;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -2.6s;
  animation-delay: -2.6s;
  -webkit-transform: translate3d(16vw, 24vh, 92px);
  transform: translate3d(16vw, 24vh, 92px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-14 {
  100% {
    -webkit-transform: translate3d(22vw, 26vh, 20px);
    transform: translate3d(22vw, 26vh, 20px)
  }
}
@keyframes particle-animation-14 {
  100% {
    -webkit-transform: translate3d(22vw, 26vh, 20px);
    transform: translate3d(22vw, 26vh, 20px)
  }
}
.particle:nth-child(14) {
  -webkit-animation: particle-animation-14 60s infinite;
  animation: particle-animation-14 60s infinite;
  opacity: .07;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -2.8s;
  animation-delay: -2.8s;
  -webkit-transform: translate3d(6vw, 9vh, 9px);
  transform: translate3d(6vw, 9vh, 9px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-15 {
  100% {
    -webkit-transform: translate3d(77vw, 84vh, 16px);
    transform: translate3d(77vw, 84vh, 16px)
  }
}
@keyframes particle-animation-15 {
  100% {
    -webkit-transform: translate3d(77vw, 84vh, 16px);
    transform: translate3d(77vw, 84vh, 16px)
  }
}
.particle:nth-child(15) {
  -webkit-animation: particle-animation-15 60s infinite;
  animation: particle-animation-15 60s infinite;
  opacity: .1;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -3s;
  animation-delay: -3s;
  -webkit-transform: translate3d(64vw, 87vh, 5px);
  transform: translate3d(64vw, 87vh, 5px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-16 {
  100% {
    -webkit-transform: translate3d(48vw, 76vh, 64px);
    transform: translate3d(48vw, 76vh, 64px)
  }
}
@keyframes particle-animation-16 {
  100% {
    -webkit-transform: translate3d(48vw, 76vh, 64px);
    transform: translate3d(48vw, 76vh, 64px)
  }
}
.particle:nth-child(16) {
  -webkit-animation: particle-animation-16 60s infinite;
  animation: particle-animation-16 60s infinite;
  opacity: .17;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -3.2s;
  animation-delay: -3.2s;
  -webkit-transform: translate3d(2vw, 36vh, 82px);
  transform: translate3d(2vw, 36vh, 82px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-17 {
  100% {
    -webkit-transform: translate3d(1vw, 77vh, 48px);
    transform: translate3d(1vw, 77vh, 48px)
  }
}
@keyframes particle-animation-17 {
  100% {
    -webkit-transform: translate3d(1vw, 77vh, 48px);
    transform: translate3d(1vw, 77vh, 48px)
  }
}
.particle:nth-child(17) {
  -webkit-animation: particle-animation-17 60s infinite;
  animation: particle-animation-17 60s infinite;
  opacity: .8;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -3.4s;
  animation-delay: -3.4s;
  -webkit-transform: translate3d(57vw, 42vh, 44px);
  transform: translate3d(57vw, 42vh, 44px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-18 {
  100% {
    -webkit-transform: translate3d(18vw, 21vh, 43px);
    transform: translate3d(18vw, 21vh, 43px)
  }
}
@keyframes particle-animation-18 {
  100% {
    -webkit-transform: translate3d(18vw, 21vh, 43px);
    transform: translate3d(18vw, 21vh, 43px)
  }
}
.particle:nth-child(18) {
  -webkit-animation: particle-animation-18 60s infinite;
  animation: particle-animation-18 60s infinite;
  opacity: .88;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -3.6s;
  animation-delay: -3.6s;
  -webkit-transform: translate3d(56vw, 69vh, 29px);
  transform: translate3d(56vw, 69vh, 29px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-19 {
  100% {
    -webkit-transform: translate3d(47vw, 62vh, 6px);
    transform: translate3d(47vw, 62vh, 6px)
  }
}
@keyframes particle-animation-19 {
  100% {
    -webkit-transform: translate3d(47vw, 62vh, 6px);
    transform: translate3d(47vw, 62vh, 6px)
  }
}
.particle:nth-child(19) {
  -webkit-animation: particle-animation-19 60s infinite;
  animation: particle-animation-19 60s infinite;
  opacity: .74;
  height: 8px;
  width: 8px;
  -webkit-animation-delay: -3.8s;
  animation-delay: -3.8s;
  -webkit-transform: translate3d(71vw, 32vh, 63px);
  transform: translate3d(71vw, 32vh, 63px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-20 {
  100% {
    -webkit-transform: translate3d(10vw, 10vh, 18px);
    transform: translate3d(10vw, 10vh, 18px)
  }
}
@keyframes particle-animation-20 {
  100% {
    -webkit-transform: translate3d(10vw, 10vh, 18px);
    transform: translate3d(10vw, 10vh, 18px)
  }
}
.particle:nth-child(20) {
  -webkit-animation: particle-animation-20 60s infinite;
  animation: particle-animation-20 60s infinite;
  opacity: .78;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -4s;
  animation-delay: -4s;
  -webkit-transform: translate3d(43vw, 52vh, 78px);
  transform: translate3d(43vw, 52vh, 78px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-21 {
  100% {
    -webkit-transform: translate3d(67vw, 26vh, 75px);
    transform: translate3d(67vw, 26vh, 75px)
  }
}
@keyframes particle-animation-21 {
  100% {
    -webkit-transform: translate3d(67vw, 26vh, 75px);
    transform: translate3d(67vw, 26vh, 75px)
  }
}
.particle:nth-child(21) {
  -webkit-animation: particle-animation-21 60s infinite;
  animation: particle-animation-21 60s infinite;
  opacity: .36;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -4.2s;
  animation-delay: -4.2s;
  -webkit-transform: translate3d(73vw, 43vh, 9px);
  transform: translate3d(73vw, 43vh, 9px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-22 {
  100% {
    -webkit-transform: translate3d(53vw, 84vh, 5px);
    transform: translate3d(53vw, 84vh, 5px)
  }
}
@keyframes particle-animation-22 {
  100% {
    -webkit-transform: translate3d(53vw, 84vh, 5px);
    transform: translate3d(53vw, 84vh, 5px)
  }
}
.particle:nth-child(22) {
  -webkit-animation: particle-animation-22 60s infinite;
  animation: particle-animation-22 60s infinite;
  opacity: .42;
  height: 8px;
  width: 8px;
  -webkit-animation-delay: -4.4s;
  animation-delay: -4.4s;
  -webkit-transform: translate3d(26vw, 64vh, 88px);
  transform: translate3d(26vw, 64vh, 88px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-23 {
  100% {
    -webkit-transform: translate3d(52vw, 83vh, 89px);
    transform: translate3d(52vw, 83vh, 89px)
  }
}
@keyframes particle-animation-23 {
  100% {
    -webkit-transform: translate3d(52vw, 83vh, 89px);
    transform: translate3d(52vw, 83vh, 89px)
  }
}
.particle:nth-child(23) {
  -webkit-animation: particle-animation-23 60s infinite;
  animation: particle-animation-23 60s infinite;
  opacity: .37;
  height: 10px;
  width: 10px;
  -webkit-animation-delay: -4.6s;
  animation-delay: -4.6s;
  -webkit-transform: translate3d(80vw, 50vh, 54px);
  transform: translate3d(80vw, 50vh, 54px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-24 {
  100% {
    -webkit-transform: translate3d(41vw, 31vh, 72px);
    transform: translate3d(41vw, 31vh, 72px)
  }
}
@keyframes particle-animation-24 {
  100% {
    -webkit-transform: translate3d(41vw, 31vh, 72px);
    transform: translate3d(41vw, 31vh, 72px)
  }
}
.particle:nth-child(24) {
  -webkit-animation: particle-animation-24 60s infinite;
  animation: particle-animation-24 60s infinite;
  opacity: .18;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -4.8s;
  animation-delay: -4.8s;
  -webkit-transform: translate3d(18vw, 36vh, 41px);
  transform: translate3d(18vw, 36vh, 41px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-25 {
  100% {
    -webkit-transform: translate3d(55vw, 64vh, 72px);
    transform: translate3d(55vw, 64vh, 72px)
  }
}
@keyframes particle-animation-25 {
  100% {
    -webkit-transform: translate3d(55vw, 64vh, 72px);
    transform: translate3d(55vw, 64vh, 72px)
  }
}
.particle:nth-child(25) {
  -webkit-animation: particle-animation-25 60s infinite;
  animation: particle-animation-25 60s infinite;
  opacity: .52;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -5s;
  animation-delay: -5s;
  -webkit-transform: translate3d(65vw, 63vh, 46px);
  transform: translate3d(65vw, 63vh, 46px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-26 {
  100% {
    -webkit-transform: translate3d(15vw, 5vh, 16px);
    transform: translate3d(15vw, 5vh, 16px)
  }
}
@keyframes particle-animation-26 {
  100% {
    -webkit-transform: translate3d(15vw, 5vh, 16px);
    transform: translate3d(15vw, 5vh, 16px)
  }
}
.particle:nth-child(26) {
  -webkit-animation: particle-animation-26 60s infinite;
  animation: particle-animation-26 60s infinite;
  opacity: .04;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -5.2s;
  animation-delay: -5.2s;
  -webkit-transform: translate3d(41vw, 17vh, 22px);
  transform: translate3d(41vw, 17vh, 22px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-27 {
  100% {
    -webkit-transform: translate3d(41vw, 37vh, 56px);
    transform: translate3d(41vw, 37vh, 56px)
  }
}
@keyframes particle-animation-27 {
  100% {
    -webkit-transform: translate3d(41vw, 37vh, 56px);
    transform: translate3d(41vw, 37vh, 56px)
  }
}
.particle:nth-child(27) {
  -webkit-animation: particle-animation-27 60s infinite;
  animation: particle-animation-27 60s infinite;
  opacity: .75;
  height: 8px;
  width: 8px;
  -webkit-animation-delay: -5.4s;
  animation-delay: -5.4s;
  -webkit-transform: translate3d(87vw, 62vh, 71px);
  transform: translate3d(87vw, 62vh, 71px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-28 {
  100% {
    -webkit-transform: translate3d(13vw, 19vh, 58px);
    transform: translate3d(13vw, 19vh, 58px)
  }
}
@keyframes particle-animation-28 {
  100% {
    -webkit-transform: translate3d(13vw, 19vh, 58px);
    transform: translate3d(13vw, 19vh, 58px)
  }
}
.particle:nth-child(28) {
  -webkit-animation: particle-animation-28 60s infinite;
  animation: particle-animation-28 60s infinite;
  opacity: .94;
  height: 9px;
  width: 9px;
  -webkit-animation-delay: -5.6s;
  animation-delay: -5.6s;
  -webkit-transform: translate3d(63vw, 69vh, 24px);
  transform: translate3d(63vw, 69vh, 24px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-29 {
  100% {
    -webkit-transform: translate3d(57vw, 67vh, 36px);
    transform: translate3d(57vw, 67vh, 36px)
  }
}
@keyframes particle-animation-29 {
  100% {
    -webkit-transform: translate3d(57vw, 67vh, 36px);
    transform: translate3d(57vw, 67vh, 36px)
  }
}
.particle:nth-child(29) {
  -webkit-animation: particle-animation-29 60s infinite;
  animation: particle-animation-29 60s infinite;
  opacity: .89;
  height: 8px;
  width: 8px;
  -webkit-animation-delay: -5.8s;
  animation-delay: -5.8s;
  -webkit-transform: translate3d(56vw, 43vh, 54px);
  transform: translate3d(56vw, 43vh, 54px);
  background: #c2c2c2
}
@-webkit-keyframes particle-animation-30 {
  100% {
    -webkit-transform: translate3d(37vw, 64vh, 35px);
    transform: translate3d(37vw, 64vh, 35px)
  }
}
@keyframes particle-animation-30 {
  100% {
    -webkit-transform: translate3d(37vw, 64vh, 35px);
    transform: translate3d(37vw, 64vh, 35px)
  }
}
.particle:nth-child(30) {
  -webkit-animation: particle-animation-30 60s infinite;
  animation: particle-animation-30 60s infinite;
  opacity: .98;
  height: 7px;
  width: 7px;
  -webkit-animation-delay: -6s;
  animation-delay: -6s;
  -webkit-transform: translate3d(8vw, 74vh, 67px);
  transform: translate3d(8vw, 74vh, 67px);
  background: #c2c2c2
}
.js-switch-tab {
  cursor: pointer
}
.js-switch-content {
  display: none
}
.js-switch-content.is-active {
  display: block
}
.js-toggle-trigger {
  cursor: pointer
}
.js-toggle-content {
  display: none
}
.anniversary-message {
  padding: 80px 0 60px;
  text-align: center
}
.anniversary-message__inner {
  padding: 0 10.66%
}
.anniversary-message-heading {
  position: relative;
  margin-bottom: 34px
}
.anniversary-message-heading:after {
  content: '';
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: 0;
  right: -8%;
  width: 111px;
  height: 84px;
  background: url(/img/anniversary/txt_message01_sp.png) no-repeat;
  background-size: 111px
}
.anniversary-message-heading__en {
  margin-bottom: 14px;
  font-size: 2.2rem;
  text-transform: capitalize;
  letter-spacing: 0
}
.anniversary-message-heading__ja {
  line-height: 1.59;
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: .1em
}
.anniversary-message__txt {
  line-height: 2.5;
  font-weight: 500;
  text-align: left
}
@media (max-width: 349px) {
  .anniversary-message-heading__ja {
    font-size: 1.8rem
  }
}
@media (max-width: 374px) {
  .anniversary-message-heading__ja {
    font-size: 2.1rem
  }
}
@media (min-width: 768px) {
  .anniversary-message {
    padding: 165px 0 135px
  }
  .anniversary-message__inner {
    width: 100%;
    max-width: 1100px;
    padding: 0;
    margin: auto
  }
  .anniversary-message-heading {
    margin-bottom: 80px
  }
  .anniversary-message-heading:after {
    top: -26px;
    right: 81px;
    width: 310px;
    height: 230px;
    background: url(/img/anniversary/txt_message01_pc.png) no-repeat;
    background-size: 310px
  }
  .anniversary-message-heading__en {
    margin-bottom: 32px;
    font-size: 3.5rem
  }
  .anniversary-message-heading__ja {
    font-size: 3.5rem
  }
  .anniversary-message__txt {
    font-size: 1.8rem;
    text-align: center
  }
}
.anniversary-history {
  position: relative;
  overflow: hidden;
  padding-bottom: 65px;
  text-align: center
}
.anniversary-history__head {
  margin-bottom: 29px;
  font-size: 4.5rem;
  text-transform: capitalize;
  letter-spacing: 0
}
.anniversary-history__img {
  position: relative;
  z-index: 3
}
.anniversary-history.is-active:before, .anniversary-history.is-active:after {
  content: '';
  display: inline-block;
  position: absolute;
  z-index: -1;
  right: 0;
  width: 100%;
  height: 50%
}
.anniversary-history.is-active:before {
  top: 154px;
  background: url(/img/anniversary/bg_history01_sp.png) no-repeat top right;
  background-size: 100%;
  opacity: 0;
  -webkit-animation: 600ms fade-in 1s ease-out forwards;
  animation: 600ms fade-in 1s ease-out forwards
}
.anniversary-history.is-active:after {
  bottom: 206px;
  background: url(/img/anniversary/bg_history02_sp.png) no-repeat bottom right;
  background-size: 100%
}
@media (min-width: 768px) {
  .anniversary-history {
    padding-bottom: 175px
  }
  .anniversary-history__head {
    font-size: 7rem
  }
  .anniversary-history__img {
    max-width: 1177px;
    margin: auto
  }
  .anniversary-history.is-active:before {
    top: 47px;
    background: url(/img/anniversary/bg_history01_pc.png) no-repeat top right;
    background-size: 100%
  }
  .anniversary-history.is-active:after {
    bottom: 240px;
    background: url(/img/anniversary/bg_history02_pc.png) no-repeat bottom right;
    background-size: 100%
  }
}
@-webkit-keyframes fade-in {
  100% {
    opacity: 1
  }
}
@keyframes fade-in {
  100% {
    opacity: 1
  }
}
.anniversary-service {
  background-color: #f0f0f0
}
.anniversary-service:after {
  z-index: -1
}
@media (min-width: 768px) {
  .anniversary-service {
    padding-top: 105px
  }
}
#company .l-sub-img {
  background-image: url(/img/company/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #company .l-sub-img {
    background-image: url(/img/company/bg_mv01_pc.jpg)
  }
}
.company-link {
  padding: 65px 0 5px
}
.company-link-list__img {
  position: relative;
  z-index: 1
}
.company-link-list__txt-area {
  position: relative;
  z-index: 2;
  margin: -30px 30px 50px;
  padding: 20px 0 35px;
  background-color: #fff;
  text-align: center
}
.company-link-list__sub-head {
  font-size: 1.6rem
}
.company-link-list__head {
  margin-bottom: 8px;
  -webkit-transform: translateY(-5px);
  -ms-transform: translateY(-5px);
  transform: translateY(-5px);
  font-weight: 500;
  font-size: 2.3rem
}
.company-link-list-btn__link.is-soon {
  pointer-events: none
}
@media (min-width: 768px) {
  .company-link {
    padding: 92px 0 130px
  }
  .company-link__inner {
    width: 100%;
    max-width: 1350px;
    margin: auto
  }
  .company-link-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
  }
  .company-link-list__item:nth-of-type(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row
  }
  .company-link-list__img {
    width: 50%
  }
  .company-link-list__txt-area {
    box-sizing: border-box;
    width: 50%;
    margin: 0;
    padding: 10% 0 0;
    background-color: transparent
  }
  .company-link-list__sub-head {
    width: 100%;
    margin-bottom: 5px;
    line-height: 1.7;
    font-size: 1.9rem
  }
  .company-link-list__head {
    width: 100%;
    margin-bottom: 30px;
    line-height: 1.47;
    font-size: 3.4rem
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .company-link-list__txt-area {
    padding-top: 6%
  }
  .company-link-list__sub-head {
    font-size: 1.7rem
  }
  .company-link-list__head {
    margin-bottom: 20px;
    font-size: 3rem
  }
  .company-link-list-btn__link {
    width: 160px;
    height: 50px;
    font-size: 1.7rem
  }
}
@media (min-width: 1025px) and (max-width: 1400px) {
  .company-link-list__txt-area {
    padding-top: 7%
  }
}
.company-bnr {
  padding-bottom: 80px
}
@media (min-width: 768px) {
  .company-bnr {
    padding-bottom: 160px;
    max-width: 1350px;
    margin: auto
  }
}
#consulting .l-sub-img {
  background-image: url("../img/bg_mv02_sp.jpg")
}
#consulting .l-sub-img__sub-head {
  font-size: 2.8rem
}
#consulting .l-sub-img__head {
  margin-top: 10px
}
@media (min-width: 768px) {
  #consulting .l-sub-img {
    background-image: url("../img/bg_mv02_pc.jpg")
  }
  #consulting .l-sub-img__sub-head {
    font-size: 7rem
  }
  #consulting .l-sub-img__head {
    margin-top: 0
  }
}
#contact .l-sub-img, #thanks .l-sub-img, #confirm01 .l-sub-img, #confirm02 .l-sub-img, #confirm03 .l-sub-img, #confirm04 .l-sub-img, #confirm05 .l-sub-img, #confirm06 .l-sub-img, #confirm07 .l-sub-img {
  background-image: url("../img/bg_mv02_sp.jpg")
}
@media (min-width: 768px) {
  #contact .l-sub-img, #thanks .l-sub-img, #confirm01 .l-sub-img, #confirm02 .l-sub-img, #confirm03 .l-sub-img, #confirm04 .l-sub-img, #confirm06 .l-sub-img, #confirm07 .l-sub-img , #confirm05 .l-sub-img  {
    background-image: url("../img/bg_mv02_pc.jpg")
  }
}
.contact-form {
  padding: 55px 0 65px
}
.contact-form__inner {
  padding: 0 5.3333%
}
@media (min-width: 768px) {
  .contact-form {
    padding: 90px 0
  }
  .contact-form__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 30px
  }
}
@media (min-width: 1160px) {
  .contact-form__inner {
    padding: 0
  }
}
.contact-form {
  padding: 50px 0 60px
}
.contact-form__form-area {
  display: none
}
.contact-form__form-area.is-active {
  display: block
}
.contact-message {
  padding: 40px 0 60px
}
.contact-message__inner {
  padding: 0 10.6666%
}
.contact-message__txt {
  margin-bottom: 30px
}
@media (min-width: 768px) {
  .contact-message {
    padding: 80px 0 120px
  }
  .contact-message__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 40px
  }
  .contact-message__txt {
    margin-bottom: 50px
  }
}
@media (min-width: 1180px) {
  .contact-message__inner {
    padding: 0
  }
}

.error-page404 {
  padding: 50px 0
}
.error-page404__head {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}
.error-page404__txt {
  text-align: center;
  padding-bottom: 30px
}
@media (min-width: 768px) {
  .error-page404 {
    padding: 100px 0
  }
  .error-page404__txt {
    padding-bottom: 50px
  }
}
#event .l-sub-img {
  background-image: url(/img/event/bg_mv01_sp.jpg)
}
#event .l-sub-img__sub-head {
  font-size: 2.8rem
}
#event .l-sub-img__head {
  margin-top: 10px
}
@media (min-width: 768px) {
  #event .l-sub-img {
    background-image: url(/img/event/bg_mv01_pc.jpg)
  }
  #event .l-sub-img__sub-head {
    font-size: 7rem
  }
  #event .l-sub-img__head {
    margin-top: 0
  }
}
#history .l-sub-img {
  background-image: url(/img/history/bg_mv01_sp.jpg)
}
@media (max-width: 349px) {
  #history .l-sub-img__sub-head {
    font-size: 3.6rem
  }
}
@media (min-width: 768px) {
  #history .l-sub-img {
    background-image: url(/img/history/bg_mv01_pc.jpg)
  }
}
.history-summary {
  padding: 60px 0 50px
}
@media (min-width: 768px) {
  .history-summary {
    padding: 80px 0 115px
  }
}
.history-detail {
  padding-bottom: 65px
}
@media (min-width: 768px) {
  .history-detail {
    padding-bottom: 160px
  }
}
.history-common__inner {
  padding-left: 5.3333%;
  padding-right: 5.3333%
}
.history-common__head {
  margin-bottom: 40px;
  line-height: 1.56;
  font-weight: 500;
  font-size: 2.3rem;
  text-align: center
}
.history-common-list {
  overflow: hidden;
  border-bottom: 1px solid #e5e5e5;
}
.history-common-list dt, .history-common-list dd {
  border-top: 1px solid #D3CCCC;
	font-size: 14px;
}
.history-common-list dt {
  float: left;
  width: calc(50% - 33px);
  padding: 13px 13px 14px 20px;
  font-weight: 500
}
.history-common-list dd {
  width: calc(50% - 20px);
  margin-left: 50%;
  padding: 13px 20px 14px 0
}
@media (min-width: 768px) {
  .history-common__inner {
    max-width: 1100px;
    margin: auto
  }
  .history-common__head {
    margin-bottom: 72px;
    font-size: 3.5rem
  }
  .history-common-list dt {
    width: calc(34% - 43px);
    padding: 23px 13px 26px 30px
  }
  .history-common-list dd {
    width: calc(66% - 18px);
    margin-left: 34%;
    padding: 23px 13px 26px 5px
  }
}
.home-about {
  padding-top: 65px
}
.home-about__inner {
  padding: 0 0px;
	width: 80%;
	margin-left: auto;
	margin-right: auto;
}
.home-about-heading {
  margin-bottom: 20px
}
.home-about-heading__en {
  margin-bottom: 30px;
  line-height: 1;
  font-size: 2rem
}
.home-about-heading__img {
  width: 224px;
  margin-bottom: 18px
}
.home-about-heading__ja {
  line-height: 2;
  font-size: 2.2rem
}
.home-about__txt {
  line-height: 2;
  font-size: 14px;
}
@media (min-width: 768px) {
  .home-about {
    max-width: 1100px;
    padding-top: 100px;
	  margin-left: auto;
	  margin-right: auto;
  }
  .home-about__inner {
    
    padding-left: 0px;
  }
  .home-about-heading {
    margin-bottom: 40px;
  }
  .home-about-heading__en {
    margin-bottom: 40px;
    font-size: 2.5rem;
  }
  .home-about-heading__img {
    width: 448px;
    margin-bottom: 0px
  }
  .home-about-heading__ja {
    font-size: 3.2rem
  }
  .home-about__txt {
    line-height: 2;
    font-size: 14px;
  }
  .home-about-btn__wrap {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-column: 1;
    grid-row: 2
  }
}
@media (min-width: 768px) and (max-width: 1100px) {
  .home-about-heading__img {
    width: 300px
  }
  .home-about__txt {
    
  }
}
.home-service {
  overflow: hidden;
  position: relative;
  padding: 0px 0 20px
}
.home-service:after {
  content: '';
  display: inline-block;
  position: absolute;
  width: 100%;
  top: 315px;
  left: 0;
  bottom: 405px;
}
.home-service__head {
  margin-bottom: 15px;
  font-size: 4.5rem;
  text-align: center
}
.home-service-list {
  position: relative;
  z-index: 2
}
.home-service-list__item {
  width: calc(100% - 80px);
  margin: 0 auto 45px
}
.home-service-list__item:first-of-type .home-service-list__num {
  right: -30px
}
.home-service-list__item:nth-child(5) .home-service-list__num {
  color: #f0f0f0
}
.home-service-list__item:nth-child(5) .home-service-list__num.is-white {
  color: #fff
}
.home-service-list__img {
  position: relative
}
.home-service-list__img img {
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}
.home-service-list__link {
  display: block;
  cursor: pointer;
  overflow: hidden
}
.home-service-list__num {
  margin-top: 10px;
  right: 0px;
  font-size: 4rem;
  color: #262626
}
.home-service-list__txt {
  position: relative;
  z-index: 2;
  margin-bottom: 30px;
  line-height: 1.85
}
@media (max-width: 767px) {
  .home-service-list__txt {
    padding-top: 20px
  }
}
@media (min-width: 768px) {
  .home-service {
    padding: 5px 0 0
  }
  .home-service:after {
    top: 27%;
    bottom: 32%
  }
  .home-service__head {
    margin-bottom: 35px;
    font-size: 7rem
  }
  .home-service-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    max-width: 1710px;
    margin: auto
  }
  .home-service-list__item {
    width: calc(33.3333% - 5.26%);
    max-width: 40%;
    min-width: 40%;
    margin: 0 0% 0px
  }
  .home-service-list__item:first-of-type .home-service-list__num {
    right: 18px
  }
  .home-service-list__item:nth-child(4) .home-service-list__num {
    color: #f0f0f0
  }
  .home-service-list__item:nth-child(4) .home-service-list__num.is-white {
    color: #fff
  }
  .home-service-list__img {
    position: relative;
  }
  .home-service-list__num {
    bottom: 0px;
    font-size: 4rem;
	text-align: center;
  }
  .home-service-list__txt {
    margin-bottom: 0px;
    line-height: 2;
    min-height: 96px;
    box-sizing: border-box;
	text-align: center;
  }
}
@media (min-width: 1024px) and (max-width: 1366px) {
  .home-service-list__num {
    bottom: 0px;
    font-size: 4rem
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .home-service-list__item {
    width: calc(33.3333% - 20px);
    margin: 0 10px
  }
  .home-service-list__num {
    bottom: 0px;
    font-size: 4rem
  }
}

.home-topics {
  padding: 45px 0 0
}
.home-topics__inner {
  padding: 0 5.3333%
}
.home-topics__head {
  font-size: 4.5rem;
  text-align: center
}
.home-topics-btn {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 1500ms;
  transition: all 1500ms;
  -webkit-transition-delay: 150ms;
  transition-delay: 150ms
}
.home-topics-btn.is-active {
  visibility: visible;
  opacity: 1
}
@media (min-width: 768px) {
  .home-topics {
    position: relative;
    padding: 50px 0 0
  }
  .home-topics__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0
  }
  .home-topics__head {
    margin-bottom: 35px;
    font-size: 7rem
  }
  .home-topics-btn {
    position: absolute;
    top: 80px;
    right: 50px;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px)
  }
  .home-topics-btn.is-active {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0)
  }
}
@media (min-width: 768px) and (max-width: 1100px) {
  .home-topics__inner {
    padding: 0 30px
  }
}


#information .l-sub-img {
  background-image: url(/img/information/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #information .l-sub-img {
    background-image: url(/img/information/bg_mv01_pc.jpg)
  }
}
.info-archive {
  padding: 40px 0 15px
}
.info-archive__inner {
  padding-left: 5.3333%;
  padding-right: 5.3333%
}
.info-archive-pager {
  padding: 50px 0
}
@media (min-width: 768px) {
  .info-archive {
    padding: 50px 0 105px
  }
  .info-archive__inner {
    max-width: 1100px;
    margin: auto;
    padding-left: 40px;
    padding-right: 40px
  }
  .info-archive-pager {
    padding: 55px 0
  }
}
@media (min-width: 1200px) {
  .info-archive__inner {
    padding: 0
  }
}
#marketing .l-sub-img {
  background-image: url("../img/bg_mv02_sp.jpg")
}
@media (max-width: 349px) {
  #marketing .l-sub-img__sub-head {
    font-size: 3.6rem
  }
}
@media (min-width: 768px) {
  #marketing .l-sub-img {
    background-image: url("../img/bg_mv02_pc.jpg")
  }
}
#message .l-sub-img {
  background-image: url("../img/bg_mv02_sp.jpg")
}
@media (min-width: 768px) {
  #message .l-sub-img {
    background-image: url("../img/bg_mv02_pc.jpg")
  }
}
.message-box {
  padding: 60px 0
}
.message-box__inner {
  padding-left: 10.6666%;
  padding-right: 10.6666%
}
.message-box__head {
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 30px;
  line-height: 1.52;
  font-weight: 500;
  font-size: 2.2rem
}
.message-box__head:after {
  content: '';
  display: inline-block;
  position: absolute;
  bottom: 2px;
  left: 0;
  width: 61px;
  height: 2px;
  background-color: #262626
}
.message-box__txt {
  line-height: 2.22;
	font-size: 14px;
}
.message-box__txt + .message-box__txt {
  margin-top: 20px
}
.message-box__txt + .message-box__txt.is-margin-top {
  margin-top: 40px
}
.message-box-sign {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding-top: 18px
}
.message-box-sign__txt {
  padding-right: 20px
}
.message-box-sign__img {
  width: 102px
}
@media (min-width: 768px) and (max-width: 900px) {
  .message-box {
    padding-bottom: 80px
  }
  .message-box__head {
    font-size: 2.6rem
  }
  .message-box__head-area, .message-box__txt-area {
    padding: 0 50px
  }
}
@media (min-width: 901px) {
  .message-box {
    padding: 85px 0 20px
  }
  .message-box__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0
  }
  .message-box__head-area {
    width: 30%
  }
  .message-box__head {
    line-height: 1.52;
    font-size: 3rem
  }
  .message-box__txt-area {
    box-sizing: border-box;
    width: 70%;
    padding-left: 30px
  }
  .message-box__txt {
    line-height: 2.2;
  }
  .message-box-sign {
    padding-top: 50px;
	font-family: 'Noto Serif JP', serif
  }
  .message-box-sign__img {
    width: 136px
  }
}
@media (min-width: 768px) and (max-width: 1200px) {
  .message-box__inner {
    box-sizing: border-box;
    padding-left: 50px;
    padding-right: 50px
  }
}
#office .l-sub-img {
  background-image: url(/img/office/bg_mv01_sp.jpg)
}
@media (max-width: 349px) {
  #office .l-sub-img__sub-head {
    font-size: 3.6rem
  }
}
@media (min-width: 768px) {
  #office .l-sub-img {
    background-image: url(/img/office/bg_mv01_pc.jpg)
  }
}
.office-detail {
  margin-bottom: 65px;
  padding: 80px 0 0
}
.office-detail__inner {
  overflow: hidden;
  padding: 0 10.666%
}
.office-detail-main {
  margin-bottom: 60px
}
.office-detail-main__map {
  position: relative;
  width: 100%;
  height: 0;
  margin-bottom: 25px;
  padding-top: 66%;
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feColorMatrix type="matrix" color-interpolation-filters="sRGB" values="0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0 0 0 1 0" /></filter></svg>#filter');
  filter: grayscale(1)
}
.office-detail-main__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}
.office-detail-main__small {
  font-weight: 500;
  font-size: 1.5rem
}
.office-detail-main__txt {
  margin-bottom: 35px;
  line-height: 1.85
}
.office-detail-sub__item {
  margin-bottom: 55px
}
.office-detail-sub__map {
  position: relative;
  width: 100%;
  height: 0;
  margin-bottom: 25px;
  padding-top: 66%;
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feColorMatrix type="matrix" color-interpolation-filters="sRGB" values="0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0 0 0 1 0" /></filter></svg>#filter');
  filter: grayscale(1)
}
.office-detail-sub__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}
.office-detail-sub__txt {
  line-height: 1.85
}
.office-detail-oversea {
  position: relative;
  padding-bottom: 40px
}
.office-detail-oversea:after {
  content: '';
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: 95px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  width: calc(100% + 80px);
  height: 100%;
  background-color: #f0f0f0
}
.office-detail-oversea__map {
  position: relative;
  width: 100%;
  height: 0;
  margin-bottom: 25px;
  padding-top: 66%;
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feColorMatrix type="matrix" color-interpolation-filters="sRGB" values="0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0 0 0 1 0" /></filter></svg>#filter');
  filter: grayscale(1)
}
.office-detail-oversea__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}
.office-detail-oversea__head:before {
  top: 6px
}
.office-detail-oversea__small {
  font-weight: 500;
  font-size: 1.5rem
}
.office-detail-oversea__txt {
  margin-bottom: 10px;
  line-height: 1.85
}
.office-detail-oversea__ico {
  display: inline-block;
  -webkit-transform: translate(5px, -2px);
  -ms-transform: translate(5px, -2px);
  transform: translate(5px, -2px);
  font-size: 1rem
}
@media (max-width: 359px) {
  .office-detail-main__txt, .office-detail-sub__txt, .office-detail-oversea__txt {
    font-size: 1.3rem
  }
}
@media (min-width: 768px) {
  .office-detail {
    padding: 95px 0
  }
  .office-detail__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0
  }
  .office-detail-main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 65px
  }
  .office-detail-main__map {
    width: calc(50% - 38px);
    margin-right: 38px;
    padding-top: 31%
  }
  .office-detail-main__head {
    margin-bottom: 8px
  }
  .office-detail-main__small {
    font-size: 1.8rem
  }
  .office-detail-main__txt-area {
    box-sizing: border-box;
    width: 50%;
    padding-left: 25px;
    -webkit-transform: translateY(-10px);
    -ms-transform: translateY(-10px);
    transform: translateY(-10px)
  }
  .office-detail-main__txt {
    margin-bottom: 45px;
    line-height: 1.73;
    font-size: 1.5rem
  }
  .office-detail-main__span {
    display: inline-block
  }
  .office-detail-main__span:not(:last-of-type) {
    margin-right: 2em
  }
  .office-detail-sub {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .office-detail-sub__item {
    width: calc(50% - 38px);
    margin-bottom: 115px
  }
  .office-detail-sub__item:nth-of-type(odd) {
    margin-right: 38px
  }
  .office-detail-sub__item:nth-of-type(even) {
    margin-left: 38px
  }
  .office-detail-sub__item:nth-last-of-type(-n+2) {
    margin-bottom: 150px
  }
  .office-detail-sub__map {
    margin-bottom: 35px
  }
  .office-detail-sub__head {
    margin-bottom: 5px
  }
  .office-detail-sub__txt {
    font-size: 1.5rem
  }
  .office-detail-sub__span {
    display: inline-block
  }
  .office-detail-sub__span:not(:last-of-type) {
    margin-right: 2em
  }
  .office-detail-oversea {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .office-detail-oversea:after {
    top: -30px;
    -webkit-transform: translateX(-120px);
    -ms-transform: translateX(-120px);
    transform: translateX(-120px);
    width: 930px;
    height: 400px
  }
  .office-detail-oversea__map {
    width: calc(50% - 38px);
    margin-right: 38px;
    padding-top: 31%
  }
  .office-detail-oversea__head {
    margin-bottom: 18px;
    line-height: 1.52
  }
  .office-detail-oversea__head:before {
    top: 10px
  }
  .office-detail-oversea__small {
    display: block;
    font-size: 1.8rem
  }
  .office-detail-oversea__txt-area {
    box-sizing: border-box;
    width: 50%;
    padding: 60px 0 0 25px
  }
  .office-detail-oversea__txt {
    margin-bottom: 5px;
    line-height: 1.73;
    font-size: 1.5rem
  }
  .office-detail-oversea__span {
    display: inline-block
  }
  .office-detail-oversea__span:not(:last-of-type) {
    margin-right: 2em
  }
  .office-detail-oversea__ico {
    -webkit-transform: translate(6px, -2px);
    -ms-transform: translate(6px, -2px);
    transform: translate(6px, -2px);
    font-size: 1.1rem
  }
}
@media (min-width: 768px) and (max-width: 1100px) {
  .office-detail__inner {
    padding-left: 20px;
    padding-right: 20px
  }
}
@media (min-width: 768px) and (max-width: 1080px) {
  .office-detail-oversea:after {
    top: -40px
  }
  .office-detail-oversea__txt-area {
    padding: 20px 0 0 0
  }
}
#philosophy .l-sub-img {
  background-image: url(/img/philosophy/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #philosophy .l-sub-img {
    background-image: url(/img/philosophy/bg_mv01_pc.jpg)
  }
}
.philosophy-intro {
  padding: 60px 0;
  text-align: center
}
.philosophy-intro__sub {
  margin-bottom: 13px;
  font-size: 1.8rem
}
.philosophy-intro__main {
  line-height: 1.25;
  font-weight: 500;
  font-size: 2.8rem
}
.philosophy-intro__txt {
  margin-top: 15px
}
@media (min-width: 768px) {
  .philosophy-intro {
    padding: 85px 0 155px
  }
  .philosophy-intro__sub {
    margin-bottom: 30px;
    font-size: 2.6rem
  }
  .philosophy-intro__main {
    font-size: 4.5rem
  }
  .philosophy-intro__txt {
    margin-top: 20px
  }
}
.philosophy-vision {
  position: relative;
  padding-top: 60px;
  background-color: #f0f0f0
}
.philosophy-vision:after {
  content: '';
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 60px;
  background-color: #fff
}
.philosophy-vision__inner {
  position: relative;
  z-index: 2
}
.philosophy-vision-heading {
  padding: 0 40px 35px
}
.philosophy-vision-heading__en {
  margin-bottom: 10px;
  font-size: 1.8rem
}
.philosophy-vision-heading__ja {
  line-height: 1.6;
  font-weight: 500;
  font-size: 2.3rem
}
.philosophy-vision__img {
  padding-right: 40px
}
@media (min-width: 768px) {
  .philosophy-vision {
    padding-top: 120px
  }
  .philosophy-vision:after {
    height: 120px
  }
  .philosophy-vision__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
  .philosophy-vision-heading {
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 50%;
    padding-left: 78px
  }
  .philosophy-vision-heading__en {
    -ms-flex-item-align: end;
    align-self: flex-end;
    width: 100%;
    -webkit-transform: translateY(-55px);
    -ms-transform: translateY(-55px);
    transform: translateY(-55px);
    font-size: 2.6rem
  }
  .philosophy-vision-heading__ja {
    -ms-flex-item-align: start;
    align-self: flex-start;
    width: 100%;
    -webkit-transform: translateY(-35px);
    -ms-transform: translateY(-35px);
    transform: translateY(-35px);
    line-height: 1.52;
    font-size: 3.4rem
  }
  .philosophy-vision__img {
    width: 50%;
    padding: 0
  }
  .philosophy-vision__img img {
    max-width: 958px
  }
}
@media (min-width: 1025px) and (max-width: 1440px) {
  .philosophy-vision:after {
    height: 80px
  }
  .philosophy-vision-heading {
    padding-left: 50px
  }
  .philosophy-vision-heading__en {
    font-size: 2.3rem;
    margin-bottom: 0
  }
  .philosophy-vision-heading__ja {
    font-size: 3.2rem
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .philosophy-vision:after {
    height: 50px
  }
  .philosophy-vision-heading {
    padding-left: 30px
  }
  .philosophy-vision-heading__en {
    font-size: 2rem
  }
  .philosophy-vision-heading__ja {
    font-size: 3rem
  }
}
.philosophy-value {
  padding: 60px 0 20px
}
.philosophy-value-heading {
  margin-bottom: 30px;
  text-align: center
}
.philosophy-value-heading__sub {
  margin-bottom: 5px;
  font-size: 1.8rem
}
.philosophy-value-heading__main {
  font-size: 3.6rem
}
.philosophy-value-heading__ja {
  margin-top: -3px;
  line-height: 1.25
}
.philosophy-value__txt {
  padding: 0 20px 15px;
  line-height: 2.21;
  text-align: center
}
.philosophy-value-list {
  padding: 0 40px
}
.philosophy-value-list__item {
  margin-bottom: 40px
}
.philosophy-value-list__img {
  margin-bottom: 15px
}
.philosophy-value-list-heading {
  margin-bottom: 23px;
  padding-bottom: 14px;
  border-bottom: 1px solid #262626;
  text-align: center
}
.philosophy-value-list-heading__main {
  line-height: 1.52;
  font-weight: 500;
  font-size: 1.7rem
}
.philosophy-value-list-heading__sub {
  font-weight: 500;
  font-size: 1.3rem
}
@media (min-width: 768px) {
  .philosophy-value {
    padding: 115px 0 105px
  }
  .philosophy-value__inner {
    max-width: 1100px;
    margin: auto
  }
  .philosophy-value-heading {
    margin-bottom: 40px
  }
  .philosophy-value-heading__sub {
    margin-bottom: 20px;
    font-size: 2.6rem
  }
  .philosophy-value-heading__main {
    font-size: 5rem
  }
  .philosophy-value-heading__ja {
    margin-top: -10px;
    line-height: 2.18
  }
  .philosophy-value__txt {
    padding: 0;
    margin-bottom: 30px;
    line-height: 2.18
  }
  .philosophy-value-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0
  }
  .philosophy-value-list__item {
    width: 332px;
    margin-right: 52px
  }
  .philosophy-value-list__item:last-of-type {
    margin-right: 0
  }
  .philosophy-value-list__img {
    margin-bottom: 18px
  }
  .philosophy-value-list-heading {
    margin-bottom: 33px
  }
  .philosophy-value-list-heading__main {
    font-size: 2.2rem
  }
  .philosophy-value-list-heading__sub {
    font-size: 1.4rem
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .philosophy-value-list__item:nth-of-type(2) {
    margin-right: 0
  }
}
#policy .l-sub-img {
  background-image: url(/img/policy/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #policy .l-sub-img {
    background-image: url(/img/policy/bg_mv01_pc.jpg)
  }
}
.policy-index {
  padding: 60px 0 30px
}
.policy-index__inner {
  padding: 0 10.6666%
}
.policy-index__head {
  -webkit-transform: translateX(-38px);
  -ms-transform: translateX(-38px);
  transform: translateX(-38px)
}
.policy-index__txt {
  margin-bottom: 38px;
  line-height: 1.85
}
.policy-index__indent {
  display: block;
  text-indent: -1em;
  padding-left: 14px
}
.policy-index__span {
  display: block;
  padding-top: 5px;
  line-height: 1.61;
  font-size: 1.3rem
}
@media (min-width: 768px) {
  .policy-index {
    padding: 80px 0 95px
  }
  .policy-index__inner {
    box-sizing: border-box;
    padding: 0 40px
  }
  .policy-index__head {
    margin-bottom: 10px;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none
  }
  .policy-index__txt {
    margin-bottom: 65px;
    line-height: 2
  }
  .policy-index__span {
    padding-top: 8px;
    line-height: 1.5;
    font-size: 1.6rem
  }
}
@media (min-width: 1180px) {
  .policy-index__inner {
    padding: 0
  }
}
.policy-index-iso-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}
@media (max-width: 767px) {
  .policy-index-iso-list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .policy-index-iso-list__item {
    width: 45%
  }
  .policy-index-iso-list__item.is-txt {
    width: 100%;
    margin: 15px 0 20px
  }
}
@media (min-width: 768px) {
  .policy-index-iso-list {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap
  }
  .policy-index-iso-list__item {
    width: 15%
  }
  .policy-index-iso-list__item.is-txt {
    width: 63%;
    margin: 10px 0 0
  }
}
.policy-index-iso__dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 38px
}
.policy-index-iso__dl dt {
  margin-top: 15px;
  width: 40%
}
.policy-index-iso__dl dd {
  margin-top: 15px;
  width: 60%
}
@media (min-width: 768px) {
  .policy-index-iso__dl {
    margin: 20px 0 65px
  }
  .policy-index-iso__dl dt {
    width: 18%
  }
  .policy-index-iso__dl dd {
    width: 82%
  }
}
#service .l-sub-img {
  background-image: url(/img/service/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #service .l-sub-img {
    background-image: url(/img/service/bg_mv01_pc.jpg)
  }
}
.service-categories-list {
  background-color: #fff
}
.service-categories-list__link {
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border: 1px solid #262626;
  padding: 13px 10px;
  font-weight: 500;
  font-size: 1.3rem
}
@media (max-width: 767px) {
  .service-categories {
    padding: 65px 40px 0
  }
  .service-categories-list {
    border-bottom: 1px solid #262626
  }
  .service-categories-list__link {
    border-bottom: none
  }
}
@media (min-width: 768px) {
  .service-categories {
    padding: 95px 0 55px
  }
  .service-categories__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 40px
  }
  .service-categories-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .service-categories-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 20%;
    text-align: center
  }
  .service-categories-list__item:nth-of-type(3n) .service-categories-list__link {
    border-right: 1px solid #262626
  }
  .service-categories-list__item:last-of-type .service-categories-list__link {
    border-right-color: #262626
  }
  .service-categories-list__link {
    width: calc(100% + 1px);
    margin-left: -1px;
    border-right-color: transparent;
    padding: 8px 10px
  }
  .service-categories-list__link:hover {
    background-color: #262626;
    color: #fff
  }
}
@media (min-width: 1180px) {
  .service-categories__inner {
    padding: 0
  }
}
.service-detail {
  padding: 65px 0
}
.service-detail-list__item {
  margin-bottom: 60px;
  padding: 0 40px
}
.service-detail-list__img {
  position: relative;
  margin: 0 -40px 40px
}
.service-detail-list__num {
  position: absolute;
  right: 35px;
  bottom: -30px;
  line-height: 1;
  font-size: 6.5rem;
  color: #89dc1c
}
.service-detail-list-heading {
  margin-bottom: 25px
}
.service-detail-list-heading__head {
  margin-bottom: 10px;
  line-height: 1.6;
  font-weight: 500;
  font-size: 2.3rem
}
.service-detail-list-heading__sub {
  line-height: 1.33;
  font-size: 1.5rem
}
.service-detail-list__txt {
  padding-bottom: 25px;
  line-height: 1.85
}
@media (min-width: 768px) {
  .service-detail {
    padding: 25px 0
  }
  .service-detail-list {
    max-width: 1100px;
    margin: auto
  }
  .service-detail-list__item {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 35% 65%;
    grid-template-columns: 35% 65%;
    margin-bottom: 100px;
    padding: 0
  }
  .service-detail-list__img {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
    grid-column: 1 / 3;
    grid-row: 1;
    margin: 0 0 70px
  }
  .service-detail-list__num {
    font-size: 19rem;
    right: 100px;
    bottom: -80px
  }
  .service-detail-list-heading {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-column: 1;
    grid-row: 2;
    padding-left: 80px
  }
  .service-detail-list-heading__head {
    line-height: 1.47;
    font-size: 3.4rem
  }
  .service-detail-list-heading__sub {
    font-size: 1.9rem
  }
  .service-detail-list__txt {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
    -ms-grid-row-span: 3;
    grid-column: 2;
    grid-row: 2/4;
    padding-right: 80px;
    line-height: 2
  }
  .service-detail-list__btn {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    grid-column: 1;
    grid-row: 3;
    margin: 10px 0 0 80px
  }
}
@media (min-width: 768px) and (max-width: 900px) {
  .service-detail {
    padding-top: 50px
  }
  .service-detail-list__item {
    -ms-grid-columns: 50% 50%;
    grid-template-columns: 50% 50%
  }
}
@media (min-width: 901px) and (max-width: 1024px) {
  .service-detail {
    padding-top: 50px
  }
  .service-detail-list__item {
    -ms-grid-columns: 40% 60%;
    grid-template-columns: 40% 60%
  }
}
#sitemap .l-sub-img {
  background-image: url(/img/sitemap/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #sitemap .l-sub-img {
    background-image: url(/img/sitemap/bg_mv01_pc.jpg)
  }
}
.sitemap-index {
  padding: 60px 0 20px
}
.sitemap-index__inner {
  padding-left: 6.6666%;
  padding-right: 6.6666%
}
.sitemap-index-list__item {
  margin-bottom: 50px
}
.sitemap-index-list__ico {
  display: inline-block;
  margin-left: 9px;
  -webkit-transform: translateY(-1px);
  -ms-transform: translateY(-1px);
  transform: translateY(-1px);
  font-size: 1.1rem
}
.sitemap-index-sub-list {
  padding: 0 30px
}
.sitemap-index-sub-list__item {
  position: relative;
  padding: 0 0 5px 16px
}
.sitemap-index-sub-list__item:before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 0;
  top: 10px;
  width: 5px;
  height: 5px;
  border-top: 1px solid #262626;
  border-right: 1px solid #262626;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.sitemap-index-sub-list__ico {
  display: inline-block;
  margin-left: 9px;
  -webkit-transform: translateY(-1px);
  -ms-transform: translateY(-1px);
  transform: translateY(-1px);
  font-size: 1.1rem
}
@media (min-width: 768px) {
  .sitemap-index {
    padding: 80px 0
  }
  .sitemap-index__inner {
    padding: 0
  }
  .sitemap-index-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .sitemap-index-list__item {
    box-sizing: border-box;
    width: 43.64%
  }
  .sitemap-index-list__item:nth-of-type(odd) {
    margin-right: 6.36%
  }
  .sitemap-index-list__item:nth-of-type(even) {
    margin-left: 6.36%
  }
  .sitemap-index-list__ico {
    -webkit-transform: translateY(-3px);
    -ms-transform: translateY(-3px);
    transform: translateY(-3px);
    font-size: 1.6rem
  }
  .sitemap-index-sub-list {
    padding: 0 30px
  }
  .sitemap-index-sub-list__item {
    position: relative;
    padding: 0 0 12px 16px
  }
  .sitemap-index-sub-list__item:before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    top: 10px;
    width: 5px;
    height: 5px;
    border-top: 1px solid #262626;
    border-right: 1px solid #262626;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg)
  }
  .sitemap-index-sub-list__ico {
    font-size: 1.4rem
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .sitemap-index__inner {
    box-sizing: border-box;
    padding-left: 20px;
    padding-right: 20px
  }
}
#solution .l-sub-img {
  background-image: url(/img/solution/bg_mv01_sp.jpg)
}
@media (max-width: 359px) {
  #solution .l-sub-img__sub-head {
    font-size: 2.3rem
  }
}
@media (min-width: 360px) and (max-width: 767px) {
  #solution .l-sub-img__sub-head {
    font-size: 2.8rem
  }
}
@media (min-width: 768px) and (max-width: 900px) {
  #solution .l-sub-img__sub-head {
    font-size: 6rem
  }
}
@media (min-width: 768px) {
  #solution .l-sub-img {
    background-image: url(/img/solution/bg_mv01_pc.jpg)
  }
}
#topics .l-sub-img {
  background-image: url(/img/topics/bg_mv01_sp.jpg)
}
@media (min-width: 768px) {
  #topics .l-sub-img {
    background-image: url(/img/topics/bg_mv01_pc.jpg)
  }
}
.topics-categories {
  padding: 65px 0 35px
}
.topics-categories-select {
  text-align: center
}
.topics-categories-select select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  min-width: 200px;
  padding: 12px 35px 12px 20px;
  border: 1px solid #b2b2b2;
  border-radius: 0;
  background: #fff url(/img/contact/ico_arw01.png) no-repeat center right 15px;
  background-size: 13px;
  font-family: inherit
}
.topics-categories-select select::-ms-expand {
  display: none
}
@media (min-width: 768px) {
  .topics-categories {
    padding: 95px 0 55px
  }
  .topics-categories__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 40px
  }
  .topics-categories-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
  .topics-categories-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 20%;
    background-color: #fff
  }
  .topics-categories-list__item:nth-of-type(5n) .topics-categories-list__link {
    border-right: 1px solid #262626
  }
  .topics-categories-list__item:nth-of-type(n+6) .topics-categories-list__link {
    border-top-color: transparent
  }
  .topics-categories-list__item:last-of-type .topics-categories-list__link {
    border-right-color: #262626
  }
  .topics-categories-list__link {
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: calc(100% + 1px);
    margin-left: -1px;
    border: 1px solid #262626;
    padding: 18px 6px;
    font-weight: 500;
    font-size: 1.3rem
  }
  .topics-categories-list__link:hover {
    background-color: #262626;
    color: #fff
  }
  .topics-categories-list__link.is-current {
    background-color: #0b3358
  }
}
@media (min-width: 1180px) {
  .topics-categories__inner {
    padding: 0
  }
}
.topics-archive {
  padding-bottom: 60px
}
.topics-archive__inner {
  padding: 0 5.3333%
}
@media (min-width: 768px) {
  .topics-archive {
    padding-bottom: 160px
  }
  .topics-archive__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 40px
  }
  .topics-archive-pager {
    padding-top: 50px
  }
}
@media (min-width: 1180px) {
  .topics-archive__inner {
    padding: 0
  }
}
#tourism .l-sub-img {
  background-image: url("../img/bg_cv01_sp.jpg")
}
#tourism .l-sub-img__sub-head {
  font-size: 2.8rem
}
#tourism .l-sub-img__head {
  margin-top: 10px
}
@media (min-width: 768px) {
  #tourism .l-sub-img {
    background-image: url("../img/bg_mv02_pc.jpg")
  }
  #tourism .l-sub-img__sub-head {
    font-size: 7rem
  }
  #tourism .l-sub-img__head {
    margin-top: 0
  }
}
#works .l-sub-img, #work .l-sub-img {
  background-image: url("../img/bg_mv02_sp.jpg")
}
@media (min-width: 768px) {
  #works .l-sub-img, #work .l-sub-img {
    background-image: url("../img/bg_mv02_pc.jpg")
  }
}
.works-categories {
  padding: 65px 0 35px
}
.works-categories-select {
  text-align: center
}
.works-categories-select select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  min-width: 200px;
  padding: 12px 20px;
  border: 1px solid #b2b2b2;
  border-radius: 0;
  background: #fff url(/img/contact/ico_arw01.png) no-repeat center right 15px;
  background-size: 13px;
  font-family: inherit
}
.works-categories-select select::-ms-expand {
  display: none
}
@media (min-width: 768px) {
  .works-categories {
    padding: 95px 0 55px
  }
  .works-categories__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 40px
  }
  .works-categories-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
  .works-categories-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 20%;
    background-color: #fff;
    text-align: center
  }
  .works-categories-list__item:nth-of-type(3n) .works-categories-list__link {
    border-right: 1px solid #262626
  }
  .works-categories-list__item:last-of-type .works-categories-list__link {
    border-right-color: #262626
  }
  .works-categories-list__link {
    box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: calc(100% + 1px);
    margin-left: -1px;
    border: 1px solid #262626;
    border-right-color: transparent;
    padding: 18px 10px;
    font-weight: 500;
    font-size: 1.3rem
  }
  .works-categories-list__link:hover {
    background-color: #262626;
    color: #fff
  }
}
@media (min-width: 1180px) {
  .works-categories__inner {
    padding: 0
  }
}
.works-archive {
  padding: 25px 0 65px
}
.works-archive__inner {
  padding: 0 10.6666%
}
.works-archive-pager {
  padding-top: 20px
}
@media (min-width: 768px) {
  .works-archive {
    padding: 25px 0 160px
  }
  .works-archive__inner {
    max-width: 1100px;
    margin: auto;
    padding: 0 40px
  }
  .works-archive-pager {
    padding-top: 50px
  }
}
@media (min-width: 1140px) {
  .works-archive__inner {
    padding: 0
  }
}
.works-single {
  padding: 50px 0 65px
}
.works-single-pager {
  padding-top: 50px;
  border-top: 1px solid #e6e6e6
}
@media (min-width: 768px) {
  .works-single {
    padding: 70px 30px 40px
  }
  .works-single-pager {
    padding-top: 80px
  }
}
@media (min-width: 1160px) {
  .works-single {
    padding: 70px 0 40px
  }
}
.about-img {
width: 250px;
	margin-top: 20px;
	margin-bottom: 20px;
}
 .fancy {
 background-color: transparent;
 border: 1px solid #0b3358;
 border-radius: 0;
 box-sizing: border-box;
 color: #fff;
 cursor: pointer;
 display: inline-block;
 letter-spacing: 0.05em;
 margin: 0;
 outline: none;
 overflow: visible;
 padding: 1.25em 2em;
 position: relative;
 text-align: center;
 text-decoration: none;
 text-transform: none;
 transition: all 0.3s ease-in-out;
 user-select: none;
 font-size: 13px;
	 
}

.fancy::before {
 content: " ";
 width: 1.5625rem;
 height: 0.5px;
 background: black;
 top: 50%;
 left: 1.5em;
 position: absolute;
 transform: translateY(-50%);
 transform-origin: center;
 transition: background 0.3s linear, width 0.3s linear;
}

.fancy .text {
 font-size: 1.125em;
 line-height: 1.33333em;
 padding-left: 2em;
 display: block;
 text-align: left;
 transition: all 0.3s ease-in-out;
 text-transform: uppercase;
 text-decoration: none;
 color: black;
}



.fancy .top-key {
 height: 2px;
 width: 1.5625rem;
 top: -2px;
 left: 0.625rem;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, left 0.3s ease-out;
}

.fancy .bottom-key-1 {
 height: 2px;
 width: 1.5625rem;
 right: 1.875rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy .bottom-key-2 {
 height: 2px;
 width: 0.625rem;
 right: 0.625rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy:hover {
 color: white;
	background-color: #0b3358;
}

.fancy:hover::before {
 width: 0.9375rem;
 background: white;
}

.fancy:hover .text {
 color: white;
 padding-left: 1.5em;
}

.fancy:hover .top-key {
 left: -2px;
 width: 0px;
}

.fancy:hover .bottom-key-1,
 .fancy:hover .bottom-key-2 {
 right: 0;
 width: 0;
}

@media (max-width: 768px) {
.fancy {
 background-color: transparent;
 border: 1px solid #0b3358;
 border-radius: 0;
 box-sizing: border-box;
 color: #fff;
 cursor: pointer;
 display: inline-block;
 letter-spacing: 0.05em;
 margin: 0;
 outline: none;
 overflow: visible;
 padding: 1.25em 2em;
 position: relative;
 text-align: center;
 text-decoration: none;
 text-transform: none;
 transition: all 0.3s ease-in-out;
 user-select: none;
 font-size: 13px;
 margin-bottom: 50px;
	margin-top: -50px;
	 
}
.fancy::before {
 content: " ";
 width: 1.5625rem;
 height: 0.5px;
 background: black;
 top: 50%;
 left: 1.5em;
 position: absolute;
 transform: translateY(-50%);
 transform-origin: center;
 transition: background 0.3s linear, width 0.3s linear;
}

.fancy .text {
 font-size: 1.125em;
 line-height: 1.33333em;
 padding-left: 2em;
 display: block;
 text-align: left;
 transition: all 0.3s ease-in-out;
 text-transform: uppercase;
 text-decoration: none;
 color: black;
}
	
}


.fancy2 {
 background-color: transparent;
 border: 1px solid #0b3358;
 border-radius: 0;
 box-sizing: border-box;
 color: #fff;
 cursor: pointer;
 display: inline-block;
 letter-spacing: 0.05em;
 margin: 0;
 outline: none;
 overflow: visible;
 padding: 1.25em 2em;
 position: relative;
 text-align: center;
 text-decoration: none;
 text-transform: none;
 transition: all 0.3s ease-in-out;
 user-select: none;
 font-size: 13px;
}

.fancy2::before {
 content: " ";
 width: 1.5625rem;
 height: 0.5px;
 background: white;
 top: 50%;
 left: 1.5em;
 position: absolute;
 transform: translateY(-50%);
 transform-origin: center;
 transition: background 0.3s linear, width 0.3s linear;
}

.fancy2 .text {
 font-size: 1.125em;
 line-height: 1.33333em;
 padding-left: 2em;
 display: block;
 text-align: left;
 transition: all 0.3s ease-in-out;
 text-transform: uppercase;
 text-decoration: none;
 color: white;
}

.fancy2 .top-key {
 height: 2px;
 width: 1.5625rem;
 top: -2px;
 left: 0.625rem;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, left 0.3s ease-out;
}

.fancy2 .bottom-key-1 {
 height: 2px;
 width: 1.5625rem;
 right: 1.875rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy2 .bottom-key-2 {
 height: 2px;
 width: 0.625rem;
 right: 0.625rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy2:hover {
 color: white;
	background-color: #0b3358;
}

.fancy2:hover::before {
 width: 0.9375rem;
 background: white;
}

.fancy2:hover .text {
 color: white;
 padding-left: 1.5em;
}

.fancy2:hover .top-key {
 left: -2px;
 width: 0px;
}

.fancy2:hover .bottom-key-1,
 .fancy2:hover .bottom-key-2 {
 right: 0;
 width: 0;
}
.fancy3 {
  background-color: transparent;
  border: 1px solid #0b3358;
  border-radius: 0;
  box-sizing: border-box;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  letter-spacing: 0.05em;
  margin: 0;
  outline: none;
  overflow: visible;
  padding: 1.25em 2em;
  position: absolute; /* 変更: 絶対配置 */
  top: 50%; /* 垂直方向中央 */
  left: 50%; /* 水平方向中央 */
  transform: translate(-50%, -50%); /* 50%だけシフトして完全に中央 */
  text-align: center;
  text-decoration: none;
  text-transform: none;
  transition: all 0.3s ease-in-out;
  user-select: none;
  font-size: 13px;
  align-items: center;
}

.fancy3::before {
  content: " ";
  width: 1.5625rem;
  height: 0.5px;
  background: black;
  top: 50%;
  left: 1.5em;
  position: absolute;
  transform: translateY(-50%);
  transform-origin: center;
  transition: background 0.3s linear, width 0.3s linear;
}

.fancy3 .text {
  font-size: 1.125em;
  line-height: 1.33333em;
  padding-left: 2em;
  display: block;
  text-align: left;
  transition: all 0.3s ease-in-out;
  text-transform: uppercase;
  text-decoration: none;
  color: black;
}

.fancy3 .top-key {
  height: 2px;
  width: 1.5625rem;
  top: -2px;
  left: 0.625rem;
  position: absolute;
  background: #e8e8e8;
  transition: width 0.5s ease-out, left 0.3s ease-out;
}

.fancy3 .bottom-key-1 {
  height: 2px;
  width: 1.5625rem;
  right: 1.875rem;
  bottom: -2px;
  position: absolute;
  background: #e8e8e8;
  transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy3 .bottom-key-2 {
  height: 2px;
  width: 0.625rem;
  right: 0.625rem;
  bottom: -2px;
  position: absolute;
  background: #e8e8e8;
  transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy3:hover {
  color: white;
  background-color: #0b3358;
}

.fancy3:hover::before {
  width: 0.9375rem;
  background: white;
}

.fancy3:hover .text {
  color: white;
  padding-left: 1.5em;
}

.fancy3:hover .top-key {
  left: -2px;
  width: 0px;
}

.fancy3:hover .bottom-key-1,
.fancy3:hover .bottom-key-2 {
  right: 0;
  width: 0;
}
.fancy4 {
 background-color: transparent;
 border: 1px solid #0b3358;
 border-radius: 0;
 box-sizing: border-box;
 color: #fff;
 cursor: pointer;
 display: inline-block;
 letter-spacing: 0.05em;
 margin: 0;
 outline: none;
 overflow: visible;
 padding: 1.25em 2em;
 position: relative;
 text-align: center;
 text-decoration: none;
 text-transform: none;
 transition: all 0.3s ease-in-out;
 user-select: none;
 font-size: 13px;
	 
}

.fancy4::before {
 content: " ";
 width: 1.5625rem;
 height: 0.5px;
 background: black;
 top: 50%;
 left: 1.5em;
 position: absolute;
 transform: translateY(-50%);
 transform-origin: center;
 transition: background 0.3s linear, width 0.3s linear;
}

.fancy4 .text {
 font-size: 1.125em;
 line-height: 1.33333em;
 padding-left: 2em;
 display: block;
 text-align: left;
 transition: all 0.3s ease-in-out;
 text-transform: uppercase;
 text-decoration: none;
 color: black;
}

.fancy4 .top-key {
 height: 2px;
 width: 1.5625rem;
 top: -2px;
 left: 0.625rem;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, left 0.3s ease-out;
}

.fancy4 .bottom-key-1 {
 height: 2px;
 width: 1.5625rem;
 right: 1.875rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy4 .bottom-key-2 {
 height: 2px;
 width: 0.625rem;
 right: 0.625rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy4:hover {
 color: white;
	background-color: #0b3358;
}

.fancy4:hover::before {
 width: 0.9375rem;
 background: white;
}

.fancy4:hover .text {
 color: white;
 padding-left: 1.5em;
}

.fancy4:hover .top-key {
 left: -2px;
 width: 0px;
}

.fancy4:hover .bottom-key-1,
 .fancy4:hover .bottom-key-2 {
 right: 0;
 width: 0;
}
.t-img{
	width: 80%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 80px;
}

.fancy-ct {
 background-color: transparent;
 border: 1px solid #0b3358;
 border-radius: 0;
 box-sizing: border-box;
 color: #fff;
 cursor: pointer;
 display: inline-block;
 font-weight: 700;
 letter-spacing: 0.05em;
 margin: 0;
 outline: none;
 overflow: visible;
 padding: 1.25em 2em;
 position: relative;
 text-align: center;
 text-decoration: none;
 text-transform: none;
 transition: all 0.3s ease-in-out;
 user-select: none;
 font-size: 13px;
 width: 140px;
 margin-left: auto;
 margin-right: auto;
 margin-top: 30px;
}

.fancy-ct::before {
 content: " ";
 width: 1.5625rem;
 height: 0.5px;
 background: black;
 top: 50%;
 left: 1.5em;
 position: absolute;
 transform: translateY(-50%);
 transform-origin: center;
 transition: background 0.3s linear, width 0.3s linear;
}

.fancy-ct .text {
 font-size: 1.125em;
 line-height: 1.33333em;
 padding-left: 2em;
 display: block;
 text-align: left;
 transition: all 0.3s ease-in-out;
 text-transform: uppercase;
 text-decoration: none;
 color: black;
}

.fancy-ct .top-key {
 height: 2px;
 width: 1.5625rem;
 top: -2px;
 left: 0.625rem;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, left 0.3s ease-out;
}

.fancy-ct .bottom-key-1 {
 height: 2px;
 width: 1.5625rem;
 right: 1.875rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy-ct .bottom-key-2 {
 height: 2px;
 width: 0.625rem;
 right: 0.625rem;
 bottom: -2px;
 position: absolute;
 background: #e8e8e8;
 transition: width 0.5s ease-out, right 0.3s ease-out;
}

.fancy-ct:hover {
 color: white;
	background-color: #0b3358;
}

.fancy-ct:hover::before {
 width: 0.9375rem;
 background: white;
}

.fancy-ct:hover .text {
 color: white;
 padding-left: 1.5em;
}

.fancy-ct:hover .top-key {
 left: -2px;
 width: 0px;
}

.fancy-ct:hover .bottom-key-1,
 .fancy-ct:hover .bottom-key-2 {
 right: 0;
 width: 0;
}

#amiten {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image:url("../img/dot.png");
  background-size: 2px 2px;
  background-position: -1px -1px;
  opacity: 0.7;
}

address,caption,cite,code,dfn,em,strong,th,var {
  font-style: normal;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption,th {
  text-align: left;
}
q:before,q:after {
  content: '';
}
object,embed {
  vertical-align: top;
}
hr,legend {
  display: none;
}
h1,h2,h3,h4,h5,h6 {
  font-size: 100%;
}
img,abbr,acronym,fieldset {
  border: 0;
}
li {
  list-style-type: none;
}
sup {
  vertical-align: super;
  font-size: 0.5em;
}
img {
  vertical-align: top;
}
i {
  font-style: normal;
}
/*----リセットcss*----/

/*デザインcss↓*/
.box_con08 {
  max-width: 900px;
  margin: 0  auto;
}
@media only screen and (max-width: 768px) {
  .box_con08 {
    width: 95%;
  }
}
.box_con08 form {
  width: 100%;
}
.box_con08 form ul {
  width: 100%;
  background: #eee;
}
.box_con08 form ul li {
  position: relative;
  overflow: hidden;
  margin: .5em 0;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (min-width: 769px) {
  .box_con08 form ul li {
    display: -webkit-flex;
    display: flex;
  }
}
@media print {
  .box_con08 form ul li {
    display: -webkit-flex;
    display: flex;
  }
}
.ie8 .box_con08 form ul li {
  display: -webkit-flex;
  display: flex;
}
.box_con08 form ul li .title {
  position: relative;
  width: 30%;
  font-weight: normal;
  padding: 1em;
  position: relative;
  color: #1c2e53;
}
@media only screen and (min-width: 769px) {
  .box_con08 form ul li .title {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
  }
}
@media print {
  .box_con08 form ul li .title {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
  }
}
.ie8 .box_con08 form ul li .title {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .box_con08 form ul li .title {
    text-align: center;
    width: 100%;
    display: block;
    padding: .8em .2em;
    color: #fff;
    background: #1c2e53;
  }
}
.box_con08 form ul li .title em {
  position: relative;
  z-index: 1;
}
.box_con08 form ul li .title span {
  background: #cd6f55;
  padding: 0 .3em;
  color: #fff;
  margin-left: .5em;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.box_con08 form ul li .box_det {
  width: 70%;
  position: relative;
  padding: 1em;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .box_con08 form ul li .box_det {
    padding: 1.5em .5em;
    display: block;
    width: 100%;
  }
}
.box_con08 form ul li .box_br {
  display: block;
}
.box_con08 form ul li select, .box_con08 form ul li textarea, .box_con08 form ul li .wide {
  width: 100%;
  height: 3em;
  padding: .5em;
  border: none;
  outline: none;
  background: transparent;
  background: #fff;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.box_con08 form ul li textarea {
  height: 10em;
}

/*プライバシーのデザインcss↓*/
.con_pri {
  max-width: 700px;
  margin: 0  auto;
}
@media only screen and (max-width: 768px) {
  .con_pri {
    width: 95%;
  }
}
.con_pri .box_pri {
  height: 300px;
  overflow-y: scroll;
  border: 1px solid #cdcdcd;
  background: #f7f7f7;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin-top: 20px;
  padding: 20px 55px;
}
@media only screen and (max-width: 768px) {
  .con_pri .box_pri {
    margin-top: 4%;
    padding: 3%;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .con_pri .box_pri {
    padding: 4%;
  }
}
.con_pri .box_pri .box_tori {
  text-align: left;
  margin-top: 40px;
}
@media only screen and (max-width: 768px) {
  .con_pri .box_pri .box_tori {
    margin-top: 4%;
  }
}
.con_pri .box_pri .box_tori h4 {
  font-weight: normal;
  margin-bottom: 30px;
  font-size: 150%;
}
@media only screen and (max-width: 768px) {
  .con_pri .box_pri .box_tori h4 {
    margin-bottom: 4%;
  }
}
.con_pri .box_pri .box_tori .txt {
  padding: 0 20px;
}
@media only screen and (max-width: 768px) {
  .con_pri .box_pri .box_tori .txt {
    padding: 0;
  }
}
.con_pri .box_pri .box_num {
  margin-top: 30px;
}
@media only screen and (max-width: 768px) {
  .con_pri .box_pri .box_num {
    margin-top: 5%;
  }
}
.con_pri .box_pri .box_num h4 {
  font-weight: normal;
  font-size: 113%;
}
.con_pri .box_pri .box_num .txt {
  padding: 10px 0 0 20px;
}
@media only screen and (max-width: 768px) {
  .con_pri .box_pri .box_num .txt {
    padding: 3% 0 0 3%;
  }
}

.box_check {
  text-align: center;
  margin: 1em auto;
}
.box_check label {
  display: inline-block;
}
.box_check label span {
  margin-left: .3em;
}

.btn {
  text-align: center;
}
.btn input {
  display: inline-block;
  background: #eee;
  padding: .5em 4em;
  color: #000;
  text-decoration: none;
  cursor: pointer;
  border: none;
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.btn input:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
}


/* .contact-form__inner のスタイル */
.contact-form__inner {
    background-color: #EBEBEB;
    padding: 20px;
    max-width: 80%;
    width: 100%;
    margin: 0 auto;
}

form {
    display: flex;
    flex-direction: column;
}

/* フォームの各フィールドのグループ */
.form-group {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
	
}

label {
    font-size: 16px;
    color: #333;
    margin-right: 10px;  /* ラベルと入力フィールドの間にスペースを確保 */
    width: 120px;  /* ラベルの幅を一定に設定 */
	font-weight: bold;
	
	
}

input, textarea {
    font-size: 16px;
    padding: 12px;
    border: 1px solid #ddd;
    width: 100%;
    box-sizing: border-box;
	background-color: #FFFFFF;
}

input:focus, textarea:focus {
    outline: none;
    border-color: #007BFF;
}

textarea {
    resize: vertical;
    width: 100%;
}

input[required]:valid, textarea[required]:valid {
    border-color: #28a745;
}

input[required]:invalid, textarea[required]:invalid {
    border-color: #dc3545;
}


/* 送信ボタンのスタイル */
button {
    background-color: #007BFF;
    color: white;
    font-size: 16px;
    padding: 12px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    width: 100%;
    box-sizing: border-box;
}

button:hover {
    background-color: #0056b3;
}

/* スマートフォンやタブレット用のレスポンシブデザイン */
@media (max-width: 768px) {
    .contact-form__inner {
        padding: 15px;
    }

    label {
        font-size: 12px;
        width: 100px;
    }

    input, textarea {
        font-size: 14px;
        padding: 10px;
    }

    button {
        font-size: 14px;
        padding: 10px;
    }
.c-cv01__txt {
  padding-bottom: 50px;
  line-height: 1.92;
  color: #fff;
  text-align: center;
}
}

.topbtn {
	margin-top: 60px;
	margin-bottom: 30px;
}
.topbtn2 {
	margin-top: 10px;
	margin-bottom: 30px;
}
@media screen and (min-width: 768px){
.br_sp {display: none; }
}