@charset "UTF-8";
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 {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

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;
}

th {
  text-align: left;
  vertical-align: top;
  font-weight: normal;
}

td {
  text-align: left;
  vertical-align: top;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input, select, textarea, img {
  vertical-align: middle;
}

ul, dl, ol {
  list-style: none;
}

em {
  font-style: normal;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

/* ========================================
■ 必須設定
======================================== */
/* 文字色 */
.font_yellow {
  color: #ffe400;
}

/* 太さ */
.font_medium {
  font-weight: 500 !important;
}
.font_bold {
  font-weight: 700 !important;
}
.font_black {
  font-weight: 900 !important;
}

/* 関数
----------------------------- */
.kenten, .kenten_half {
  /* 圏点 */
  padding: 0.35em 0;
  background-repeat: repeat-x;
  background-size: 1em 0.5em;
  background-position: top left;
  background-image: radial-gradient(0.4rem 0.4rem at center center, #000 50%, transparent 50%);
  font-feature-settings: normal;
}

.kenten_half {
  background-size: 0.65em 0.5em;
}

.is_sp {
  display: block;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .is_sp {
    display: none;
  }
}

.is_pc {
  display: none;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .is_pc {
    display: block;
  }
}

.dib {
  display: inline-block;
}

img.is_sp,
br.is_sp {
  display: inline;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  img.is_sp,
  br.is_sp {
    display: none;
  }
}

img.is_pc,
br.is_pc {
  display: none;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  img.is_pc,
  br.is_pc {
    display: inline-block;
  }
}

/* ========================================
■ General
======================================== */
html {
  font-size: 3.125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  html {
    font-size: 1.0416666667vw;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  line-height: 1.7;
  letter-spacing: 0.05em;
  background: #fff;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

a {
  color: #000;
  text-decoration: underline;
}
a:hover {
  text-decoration: none;
}

img,
video,
object {
  width: 100%;
  height: auto;
  vertical-align: bottom;
  border: none;
}

section {
  position: relative;
}

mark {
  background: none;
  color: inherit;
  font-weight: normal;
  font-style: normal;
}

.global_wrap {
  overflow: hidden;
}

/* アニメーション
----------------------------- */
.sa {
  opacity: 0;
  -webkit-transition: all 1.0s ease;
  -o-transition: all 1.0s ease;
  transition: all 1.0s ease;
}

.sa.show {
  opacity: 1;
  -webkit-transform: none;
  -ms-transform: none;
  transform: none;
  -webkit-transition: all 1.0s ease;
  -o-transition: all 1.0s ease;
  transition: all 1.0s ease;
}

.sa--rl {
  -webkit-transform: translate(78.125vw, 0vw);
  -ms-transform: translate(78.125vw, 0vw);
  transform: translate(78.125vw, 0vw);
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sa--rl {
    -webkit-transform: translate(39.0625vw, 0vw);
    -ms-transform: translate(39.0625vw, 0vw);
    transform: translate(39.0625vw, 0vw);
  }
}

.sa--up {
  -webkit-transform: translate(0vw, 6.5104166667vw);
  -ms-transform: translate(0vw, 6.5104166667vw);
  transform: translate(0vw, 6.5104166667vw);
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sa--up {
    -webkit-transform: translate(0vw, 3.2552083333vw);
    -ms-transform: translate(0vw, 3.2552083333vw);
    transform: translate(0vw, 3.2552083333vw);
  }
}

/* utility class
----------------------------- */
.wrap {
  position: relative;
  margin: 0 auto;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

/* cmn class
----------------------------- */
/*cmn_wrap*/
.cmn_wrap {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .cmn_wrap {
    padding-left: 5.2083333333vw;
    padding-right: 5.5989583333vw;
  }
}
@media screen and (min-width: 769px) {
  .cmn_wrap {
    width: 65.1%;
  }
}
.cmn_wrap:after {
  content: " ";
  display: block;
  clear: both;
}

/*cmn_hl01*/
.cmn_hl01 {
  font-weight: 700;
  font-size: 5.7291666667vw;
  line-height: 1.59;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cmn_hl01 {
    font-size: 2.6041666667vw;
  }
}

/*cmn_btn01*/
.cmn_btn01 {
  /* メディアクエリ用 */
  pointer-events: none;
}
.cmn_btn01 img {
  -webkit-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
  box-shadow: 0.390625vw 0.78125vw 1.3020833333vw rgba(0, 0, 0, 0.3);
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cmn_btn01 img {
    box-shadow: 0.1953125vw 0.390625vw 0.6510416667vw rgba(0, 0, 0, 0.3);
  }
}
@media screen and (min-width: 769px) {
  .cmn_btn01:hover img {
    opacity: 0.7;
  }
}

/*cmn_cta01*/
.cmn_cta01_bg01 {
  background: url(../images/cta01_bg01_sp.jpg) center top no-repeat;
  background-size: cover;
  color: #fff;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cmn_cta01_bg01 {
    background-image: url(../images/cta01_bg01_pc.jpg);
  }
}
.cmn_cta01 .cmn_wrap {
  padding-top: 9.1145833333vw;
  padding-bottom: 11.9791666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cmn_cta01 .cmn_wrap {
    padding-top: 5.0130208333vw;
    padding-bottom: 5.9895833333vw;
  }
}
.cmn_cta01_catch {
  font-weight: 700;
  font-size: 5.7291666667vw;
  margin-bottom: 5.078125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cmn_cta01_catch {
    font-size: 2.6041666667vw;
    margin-bottom: 1.953125vw;
    padding-left: 3.1901041667vw;
  }
}
.cmn_cta01_text01 {
  font-weight: 700;
  font-size: 3.6458333333vw;
  margin-bottom: 7.03125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cmn_cta01_text01 {
    font-size: 1.5625vw;
    margin-bottom: 1.8880208333vw;
    padding-left: 3.1901041667vw;
  }
}
.cmn_cta01_btn01 {
  float: right;
  width: 72.26%;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .cmn_cta01_btn01 {
    margin-right: -5.7291666667vw;
  }
}
@media screen and (min-width: 769px) {
  .cmn_cta01_btn01 {
    width: 42.4%;
  }
}

/* ========================================
■ header
======================================== */
.header {
  padding-top: 3.3854166667vw;
  padding-bottom: 2.8645833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .header {
    padding-top: 1.6927083333vw;
    padding-bottom: 1.3671875vw;
  }
}
.header .logo {
  line-height: 0;
}
.header .logo img {
  width: 29%;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .header .logo img {
    width: 18.128%;
  }
}
.header .cmn_wrap {
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .header .cmn_wrap {
    padding-left: 2.734375vw;
    padding-right: 2.734375vw;
  }
}
@media screen and (min-width: 769px) {
  .header .cmn_wrap {
    width: 77.21%;
  }
}

/* ========================================
■ keyv
======================================== */
.keyv .bg01 {
  background: url(../images/keyv_bg01_sp.jpg) center top no-repeat;
  background-size: 100% auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .bg01 {
    background-image: url(../images/keyv_bg01_pc.jpg);
  }
}
.keyv .bg02 {
  background: url(../images/keyv_bg02_sp.jpg) center top no-repeat;
  background-size: 100% auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .bg02 {
    background-image: url(../images/keyv_bg02_pc.jpg);
  }
}
.keyv .mv {
  color: #fff;
  height: 117.0572916667vw;
  padding-top: 5.7864583333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv {
    height: 50.78125vw;
    padding-top: 10.7421875vw;
  }
}
.keyv .mv .catch01 {
  font-weight: 700;
  font-size: 4.296875vw;
  margin-bottom: 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv .catch01 {
    font-size: 3.4484375vw;
    margin-bottom: 0.9765625vw;
  }
}
.keyv .mv .text01 {
  margin-bottom: 1.953125vw;
  line-height: 1.75;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv .text01 {
    font-size: 1.4322916667vw;
    margin-bottom: 1.3020833333vw;
  }
}
.keyv .mv .text02 {
  margin: 0 -5.5989583333vw 2.6041666667vw -5.2083333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv .text02 {
    margin: 0 -26.8% 1.3020833333vw;
  }
}
.keyv .mv .text02 img {
  width: 90.49%;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv .text02 img {
    width: 71.875%;
  }
}
.keyv .mv .catch02 {
  font-weight: 700;
  margin-bottom: 2.6041666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv .catch02 {
    font-size: 1.4322916667vw;
    margin-bottom: 0.6510416667vw;
  }
}
.keyv .mv .text03 {
  line-height: 1.75;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .mv .text03 {
    font-size: 1.171875vw;
  }
}
.keyv .mv .btn01 {
  float: right;
  width: 72%;
  margin-top: 10.9375vw;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .keyv .mv .btn01 {
    margin-right: -5.5989583333vw;
  }
}
@media screen and (min-width: 769px) {
  .keyv .mv .btn01 {
    width: 42.4%;
    margin-top: 2.34375vw;
  }
}
.keyv .lead {
  position: relative;
  z-index: 1;
}
.keyv .lead .cmn_wrap {
  padding-top: 9.1145833333vw;
  padding-bottom: 11.71875vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .lead .cmn_wrap {
    padding-top: 4.8828125vw;
    padding-bottom: 5.5338541667vw;
  }
}
.keyv .lead .cmn_hl01 {
  margin-bottom: 5.7291666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .lead .cmn_hl01 {
    margin-bottom: 2.2786458333vw;
  }
}
.keyv .lead .lead_text01 {
  width: 70.07%;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .lead .lead_text01 {
    width: 77%;
  }
}
.keyv .lead .lead_text01 p + p {
  margin-top: 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .lead .lead_text01 p + p {
    margin-top: 1.953125vw;
  }
}
.keyv .lead_image01 {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 50.65%;
  z-index: -1;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv .lead_image01 {
    width: 42.51%;
  }
}

/* ========================================
■ sec_case
======================================== */
.sec_case .bg01 {
  background: url(../images/case_bg01_sp.jpg) center top no-repeat;
  background-size: cover;
  color: #fff;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .bg01 {
    background-image: url(../images/case_bg01_pc.jpg);
  }
}
.sec_case .cmn_hl01 {
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .cmn_hl01 {
    line-height: 1.675;
  }
}
.sec_case .cmn_wrap {
  padding-top: 9.765625vw;
  padding-bottom: 11.71875vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .cmn_wrap {
    padding-top: 4.8828125vw;
    padding-bottom: 5.859375vw;
  }
}
.sec_case .case {
  margin-top: 8.3333333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .case {
    margin-top: 4.1015625vw;
  }
}
.sec_case .case_hl01 {
  width: 77.4739583333vw;
  margin-left: -5.859375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .case_hl01 {
    width: 36.4583333333vw;
    margin-left: -2.4088541667vw;
  }
}
.sec_case .case_child {
  border: 0.2604166667vw solid #fff;
  padding-top: 4.5572916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .case_child {
    border-width: 0.1302083333vw;
    padding-top: 2.6041666667vw;
  }
}
.sec_case .case_child + .case_child {
  margin-top: 4.9479166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .case_child + .case_child {
    margin-top: 2.6041666667vw;
  }
}
.sec_case .case_text01 {
  padding: 4.9479166667vw 4.5572916667vw 5.859375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .case_text01 {
    font-size: 1.171875vw;
    padding: 1.3020833333vw 2.8645833333vw 2.2786458333vw;
  }
}
.sec_case .case_text01 p + p {
  margin-top: 3.125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_case .case_text01 p + p {
    margin-top: 1.3020833333vw;
  }
}

/* ========================================
■ sec_done
======================================== */
.sec_done .head {
  background: url(../images/done_bg01_sp.jpg) center top no-repeat;
  background-size: cover;
  position: relative;
  padding: 9.1145833333vw 0 10.546875vw 10.8072916667vw;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .head {
    background-image: url(../images/done_bg01_pc.jpg);
    padding-left: 20.70%;
    padding: 4.5572916667vw 0 5.2083333333vw 20.7%;
  }
}
@media screen and (max-width: 768px) {
  .sec_done .head {
    position: relative;
    z-index: 1;
  }
  .sec_done .head:before {
    content: "";
    display: block;
    background: #041330;
    height: 100%;
    position: absolute;
    top: 0;
    width: 0.390625vw;
    left: 6.1197916667vw;
  }
}
.sec_done .head .cmn_hl01 {
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .head .cmn_hl01 {
    line-height: 1.75;
  }
}
.sec_done .done {
  position: relative;
  z-index: 10;
}
.sec_done .done:before {
  content: "";
  display: block;
  background: #041330;
  height: 100%;
  position: absolute;
  top: 0;
  width: 0.390625vw;
  left: 6.1197916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done:before {
    width: 0.1953125vw;
    left: 17.3%;
  }
}
.sec_done .done_chronology {
  padding-top: 3.90625vw;
  padding-bottom: 5.46875vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology {
    padding-top: 1.8229166667vw;
    padding-bottom: 2.2786458333vw;
  }
}
.sec_done .done_chronology_hl01 {
  position: relative;
  z-index: 30;
  font-weight: 700;
  padding-left: 7.8125vw;
  font-size: 5.2083333333vw;
  margin-bottom: 1.3020833333vw;
  line-height: 1.3;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_hl01 {
    padding-left: 3.4505208333vw;
    font-size: 1.6927083333vw;
    margin-bottom: 1.6927083333vw;
  }
}
.sec_done .done_chronology_hl01:before {
  content: "";
  display: block;
  position: absolute;
  background: #1752a2;
  border-radius: 100%;
  width: 2.9947916667vw;
  height: 2.9947916667vw;
  top: 2.6041666667vw;
  left: -0.2604166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_hl01:before {
    width: 1.4322916667vw;
    height: 1.4322916667vw;
    top: 0.6510416667vw;
    left: -0.7161458333vw;
  }
}
.sec_done .done_chronology_item {
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_item {
    display: table;
    width: 100%;
  }
}
.sec_done .done_chronology_item + .done_chronology_item {
  margin-top: 2.34375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_item + .done_chronology_item {
    margin-top: 1.6927083333vw;
  }
}
.sec_done .done_chronology_year, .sec_done .done_chronology_text01 {
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_done .done_chronology_year, .sec_done .done_chronology_text01 {
    padding-left: 8.203125vw;
  }
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_year, .sec_done .done_chronology_text01 {
    display: table-cell;
  }
}
.sec_done .done_chronology_year {
  position: relative;
  color: #828282;
  font-weight: 700;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_done .done_chronology_year {
    font-size: 3.3854166667vw;
    line-height: 1.4;
  }
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_year {
    padding-left: 3.3203125vw;
    width: 9.4401041667vw;
  }
}
.sec_done .done_chronology_year:before {
  content: "";
  display: block;
  background: #000;
  position: absolute;
  left: 0.9114583333vw;
  width: 4.9479166667vw;
  height: 0.2604166667vw;
  top: 2.34375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_year:before {
    left: 0;
    width: 2.4739583333vw;
    height: 0.1302083333vw;
    top: 0.8463541667vw;
  }
}
.sec_done .done_chronology_text01 {
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_done .done_chronology_text01 {
    line-height: 1.4;
    font-size: 3.3854166667vw;
  }
}
.sec_done .done_chronology_hl02 {
  margin-bottom: 1.953125vw;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_done .done_chronology_hl02 {
    font-size: 3.3854166667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_hl02 {
    margin-bottom: 0.9765625vw;
  }
}
.sec_done .done_chronology_frame {
  margin-top: 3.90625vw;
  padding: 3.90625vw 3.515625vw;
  margin-right: 3.90625vw;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_done .done_chronology_frame {
    font-size: 3.125vw;
    line-height: 1.8;
  }
}
@media screen and (min-width: 769px) {
  .sec_done .done_chronology_frame {
    margin-top: 1.953125vw;
    margin-right: 2.34375vw;
    padding: 0.9765625vw 1.3020833333vw 1.6276041667vw;
  }
}
.sec_done .done_chronology_frame.color01 {
  background: #fff;
}
.sec_done .done_chronology_frame.color02 {
  background: #e7e7e7;
}
.sec_done .done_child.bg01 {
  background: #d5d5d5;
}
.sec_done .done_child.bg01 .done_chronology_text01 {
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_done .done_child.bg01 .done_chronology_text01 {
    font-size: 3.125vw;
  }
}
.sec_done .done_child.bg03 {
  background: url(../images/done_chronology03_bg01_sp.jpg) center center no-repeat;
  background-size: cover;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_child.bg03 {
    background-image: url(../images/done_chronology03_bg01_pc.jpg);
  }
}
.sec_done .done_child.bg05 {
  background: url(../images/done_chronology05_bg01_sp.jpg) center center no-repeat;
  background-size: cover;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_child.bg05 {
    background-image: url(../images/done_chronology05_bg01_pc.jpg);
  }
}
.sec_done .done_child.bg07 {
  background: url(../images/done_chronology07_bg01_sp.jpg) center bottom no-repeat;
  background-size: cover;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_child.bg07 {
    background: #d5d5d5;
  }
}
.sec_done .done_child.bg08 {
  background: url(../images/done_chronology08_bg01_sp.jpg) center top no-repeat;
  background-size: cover;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_child.bg08 {
    background-image: url(../images/done_chronology08_bg01_pc.jpg);
  }
}
.sec_done .done_child.bg09 {
  background: url(../images/done_chronology09_bg01_sp.jpg) center center no-repeat;
  background-size: cover;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_done .done_child.bg09 {
    background-image: url(../images/done_chronology09_bg01_pc.jpg);
  }
}

/* ========================================
■ sec_future
======================================== */
.sec_future .bg01 {
  background: url(../images/future_bg01_sp.jpg) center center no-repeat;
  background-size: cover;
  color: #fff;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_future .bg01 {
    background-image: url(../images/future_bg01_pc.jpg);
  }
}
.sec_future .cmn_wrap {
  padding-top: 9.1145833333vw;
  padding-bottom: 10.4166666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_future .cmn_wrap {
    padding-top: 4.6875vw;
    padding-bottom: 5.0130208333vw;
    width: 58.85%;
  }
}
.sec_future .hl01 {
  font-weight: 700;
  font-size: 5.7291666667vw;
  margin-bottom: 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_future .hl01 {
    font-size: 2.6041666667vw;
    margin-bottom: 2.4739583333vw;
  }
}
.sec_future .text01 {
  font-weight: 700;
  font-size: 3.6458333333vw;
  line-height: 1.75;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_future .text01 {
    margin-right: -5.5989583333vw;
  }
}
@media screen and (min-width: 769px) {
  .sec_future .text01 {
    font-size: 1.5625vw;
  }
}

/* ========================================
■ sec_crew
======================================== */
.sec_crew .head {
  padding: 11.4583333333vw 0 19.6614583333vw 5.2083333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .head {
    padding: 5.2083333333vw 0 5.859375vw 17.38%;
  }
}
.sec_crew .head .hl01 {
  position: relative;
  font-weight: 700;
  line-height: 1.4;
  font-size: 5.7291666667vw;
  padding-left: 7.421875vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .head .hl01 {
    line-height: 1.5;
    font-size: 2.6041666667vw;
    padding-left: 3.4505208333vw;
  }
}
.sec_crew .head .hl01:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background: #1752a2;
  width: 2.0833333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .head .hl01:before {
    width: 1.0416666667vw;
  }
}
.sec_crew .crew_child {
  padding-top: 0.1302083333vw;
  padding-bottom: 11.4583333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .crew_child {
    padding-top: 0.0651041667vw;
    padding-bottom: 6.9010416667vw;
  }
}
.sec_crew .crew_child:nth-child(odd) {
  background: #e4e4e4;
}
.sec_crew .crew_child:nth-child(odd) .crew_profile {
  margin-top: -12.3697916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .crew_child:nth-child(odd) .crew_profile {
    margin-top: -1.8229166667vw;
  }
}
.sec_crew .crew_child:nth-child(even) .crew_profile {
  margin-top: -6.9010416667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .crew_child:nth-child(even) .crew_profile {
    margin-top: -4.1015625vw;
  }
}
.sec_crew .crew_child:nth-child(3) .crew_profile {
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_crew .crew_child:nth-child(3) .crew_profile {
    margin-top: -8.4635416667vw;
  }
}
.sec_crew .crew_child:last-child {
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_crew .crew_child:last-child {
    padding-bottom: 6.5104166667vw;
  }
}
.sec_crew .crew_frame {
  background: #fff;
  padding: 2.6041666667vw 4.5572916667vw 5.2083333333vw;
  margin-bottom: 4.9479166667vw;
  box-shadow: 0.390625vw 0.390625vw 1.171875vw rgba(160, 160, 160, 0.7);
  margin-top: -25.5208333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .crew_frame {
    padding: 1.5625vw 1.953125vw 1.8229166667vw;
    margin-top: -8.0078125vw;
    margin-bottom: 1.953125vw;
    box-shadow: 0.1953125vw 0.1953125vw 0.5859375vw rgba(160, 160, 160, 0.7);
  }
}
.sec_crew .crew_text01 p + p {
  margin-top: 5.1432291667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_crew .crew_text01 p + p {
    margin-top: 1.953125vw;
  }
}

/* ========================================
■ sec_person
======================================== */
.sec_person .bg01 {
  background: url(../images/person_bg01_sp.jpg) center center no-repeat;
  background-size: cover;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_person .bg01 {
    background-image: url(../images/person_bg01_pc.jpg);
  }
}
.sec_person .cmn_wrap {
  padding-top: 9.375vw;
  padding-bottom: 10.4166666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_person .cmn_wrap {
    padding-top: 4.6875vw;
    padding-bottom: 5.6640625vw;
  }
}
.sec_person .hl01 {
  text-align: center;
  font-weight: 700;
  font-size: 5.7291666667vw;
  margin-bottom: 5.078125vw;
  letter-spacing: 0.1em;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_person .hl01 {
    font-size: 2.6041666667vw;
    margin-bottom: 3.1901041667vw;
  }
}
.sec_person .person {
  background: rgba(255, 255, 255, 0.5);
  margin: 0 auto;
  padding: 3.90625vw 5.078125vw 4.5572916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_person .person {
    width: 44.5963541667vw;
    padding: 2.6041666667vw 3.3854166667vw 2.7994791667vw;
  }
}
.sec_person .person_list li {
  position: relative;
  line-height: 2.166;
  padding-left: 4.4270833333vw;
  font-size: 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_person .person_list li {
    line-height: 1.875;
    padding-left: 1.5625vw;
    font-size: 1.5625vw;
  }
}
.sec_person .person_number {
  position: absolute;
  left: 0;
  top: 2.6041666667vw;
  width: 2.8645833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_person .person_number {
    top: 0.9765625vw;
    width: 1.1067708333vw;
  }
}

/* ========================================
■ sec_recruit
======================================== */
.sec_recruit .cmn_wrap {
  padding-top: 18.2291666667vw;
  padding-bottom: 11.71875vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .cmn_wrap {
    padding-top: 9.1145833333vw;
    padding-bottom: 5.9244791667vw;
  }
}
.sec_recruit .lead01 {
  position: relative;
  z-index: 1;
  font-weight: 700;
  margin-bottom: 16.1458333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .lead01 {
    margin-bottom: 4.0364583333vw;
  }
}
.sec_recruit .lead01_text01 {
  font-size: 3.6458333333vw;
  letter-spacing: 0.05em;
  line-height: 1.78;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .lead01_text01 {
    font-size: 1.5625vw;
    padding-left: 3.0598958333vw;
    letter-spacing: 0.1em;
  }
}
.sec_recruit .lead01_btn01 {
  float: right;
  margin-top: 10.2864583333vw;
  width: 72.26%;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_recruit .lead01_btn01 {
    margin-right: -5.7291666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec_recruit .lead01_btn01 {
    margin-top: 1.953125vw;
    width: 42.4%;
  }
}
.sec_recruit .lead01_en {
  position: absolute;
  z-index: -1;
  width: 110%;
  top: -13.4114583333vw;
  left: -5.859375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .lead01_en {
    width: 75.8%;
    top: -6.8359375vw;
    left: -0.6510416667vw;
  }
}
.sec_recruit .recruit {
  border: 0.2604166667vw solid #000;
  margin-top: 4.5572916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .recruit {
    margin-top: 2.6041666667vw;
    border-width: 0.1302083333vw;
  }
}
.sec_recruit .recruit_hl01 {
  font-weight: 700;
  text-align: center;
  font-size: 3.6458333333vw;
  padding: 2.6041666667vw 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .recruit_hl01 {
    font-size: 1.4322916667vw;
    padding: 1.171875vw 1.7578125vw;
  }
}
.sec_recruit .recruit_hl02 {
  font-weight: 700;
  font-size: 3.3854166667vw;
  margin-bottom: 2.6041666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .recruit_hl02 {
    font-size: 1.171875vw;
    margin-bottom: 0.3255208333vw;
  }
}
.sec_recruit .recruit_child {
  border-top: 0.2604166667vw solid #000;
  padding: 3.2552083333vw 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .recruit_child {
    border-width: 0.1302083333vw;
    padding: 1.4973958333vw 1.7578125vw;
  }
}
.sec_recruit .recruit_text01 {
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec_recruit .recruit_text01 {
    line-height: 1.4;
  }
}
.sec_recruit .recruit_text01 p + p {
  margin-top: 4.8177083333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .recruit_text01 p + p {
    margin-top: 2.0833333333vw;
  }
}
.sec_recruit .recruit_text01.lineheight01 {
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_recruit .recruit_text01.lineheight01 {
    line-height: 2.125;
  }
}

/* ========================================
■ sec_company
======================================== */
.sec_company .cmn_wrap {
  padding-top: 9.1145833333vw;
  padding-bottom: 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_company .cmn_wrap {
    padding-top: 4.9479166667vw;
    padding-bottom: 4.5572916667vw;
  }
}
.sec_company .bg01 {
  background: #000;
  color: #fff;
}
.sec_company .hl01 {
  font-weight: 700;
  font-size: 5.7291666667vw;
  margin-bottom: 7.8125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_company .hl01 {
    text-align: center;
    font-size: 2.6041666667vw;
    margin-bottom: 2.9296875vw;
  }
}
.sec_company .company {
  width: 86.13%;
  margin: 0 auto 6.7708333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_company .company {
    width: 39%;
    margin: 0 auto 2.0833333333vw;
  }
}
.sec_company .company table {
  width: 100%;
}
.sec_company .company table th {
  width: 24.74%;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_company .company table th {
    width: 37%;
  }
}
.sec_company .company table th, .sec_company .company table td {
  padding-bottom: 3.6458333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_company .company table th, .sec_company .company table td {
    padding-bottom: 1.7578125vw;
  }
}
.sec_company .link01 {
  text-align: center;
}
.sec_company .link01 a {
  color: #fff;
  text-decoration: none;
  font-size: 2.8645833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec_company .link01 a {
    font-size: 0.9114583333vw;
  }
  .sec_company .link01 a:hover {
    text-decoration: underline;
  }
}

/* ========================================
■ footer
======================================== */
.footer {
  background: #000;
  color: #fff;
  text-align: center;
  letter-spacing: 0.1em;
  font-size: 2.34375vw;
  padding: 0 0 11.71875vw;
  margin-top: -0.1302083333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .footer {
    font-size: 0.9114583333vw;
    padding: 0 0 0.9765625vw;
    margin-top: -0.0651041667vw;
  }
}
