/* --------------------------------------------- */
/* ▼モバイルファースト (全環境に共通のデザイン) */
/* --------------------------------------------- */
/* company */
.company_bg {
  width: 90%;
  margin: -1em auto 0;
}
.company_img {}
.company_img div {
  width: 120px;
  margin: 0 auto 15px;
}
.comp_list {
  margin: 1em auto 3em;
}
.comp_list li {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  justify-content: space-between;
  padding: 15px 0;
  border-bottom: 1px solid #0A3B94;
  text-align: left;
  position: relative;
}
.comp_list li dt {
  width: 25%;
  font-weight: bold;
  color: #0A3B94;
}
.comp_list li dd {
  width: 75%;
}
.comp_list li dd span {
  display: inline-block;
  background: #0A3B94;
  color: #fff;
  padding: 2px 10px;
  margin: 0 auto 5px;
}
.comp_list li dd span.mgnt {
  margin: 10px auto 5px;
}
/* message */
.message_wrap {
  text-align: left;
  margin: 1em auto 2em;
}
.message_ttl {
  width: 80%;
  font-weight: bold;
  margin: 0 auto 1em;
}
.message_ttl span {
  display: block;
  color: #0A3B94;
  letter-spacing: 2px;
  font-size: 2.5rem;
}
.message_img {
  width: 90%;
  margin: 0 0 0 auto;
}
.message_wrap ul {
  width: 80%;
  margin: auto;
}
.message_wrap ul li {
  margin: 1.5em auto 0;
}
.message_wrap ul li div {
  color: #0A3B94;
  letter-spacing: 2px;
  font-weight: bold;
  font-size: 1.7rem;
  position: relative;
  padding: 0 0 5px 25px;
}
.message_wrap ul li div::before {
  position: absolute;
  top: 48%;
  left: 0;
  width: 20px;
  height: 1px;
  content: '';
  background: #0A3B94;
}
.message_wrap ul li p {
  line-height: 1.8;
}
/* history */
.history_bg {
  width: 90%;
  margin: 1em auto 2em;
}
.history_ttl {
  text-align: left;
  color: #0A3B94;
  font-weight: bold;
  letter-spacing: 2px;
  font-size: 1.8rem;
  position: relative;
  padding: 0 0 0 40px;
}
.history_ttl::before {
  position: absolute;
  content: '';
  top: 0px;
  left: 0px;
  display: block;
  width: 30px; /*幅*/
  height: 30px;
  background-image: url("/img/company/logo_mark.webp");
  background-size: contain;
  background-repeat: no-repeat; /*画像を繰り返さない*/
}
/*タイムライン全体の設定*/
.timeline {
  margin: 2em auto 0;
  padding: 0 0 0 80px;
  text-align: left;
}
.timeline li {
  /*線の起点とするためrelativeを設定*/
  position: relative;
  list-style: none;
  padding: 0 0 20px 0;
}
.timeline dl {
  margin: 0px 0 20px 2em;
  position: relative;
}
.timeline dt {
  color: #0A3B94;
  position: absolute;
  top: 0px;
  left: -100px;
  font-weight: bold;
  text-align: right;
  font-size: 1.2rem;
}
.timeline dt span {
  display: block;
  font-family: effra, sans-serif;
  font-weight: 700;
  font-size: 2.3rem;
  line-height: 1;
}
.timeline dd {}
.timeline dd div {
  display: inline-block;
  padding: 2px 15px;
  background: #0A944A;
  color: #fff;
  border-radius: 20px;
  margin: 0 auto 5px;
}
.timeline dd img {
  width: 70%;
  margin: 5px auto 5px 0;
  display: block;
}
.timeline dd p {
  font-size: 1.2rem;
}
.timeline dd p span {
  display: block;
  color: #0A3B94;
  font-weight: bold;
  font-size: 1.6rem;
}
/*絶対配置で線を設定*/
.border-line {
  /*線の位置*/
  position: absolute;
  left: 4.5px;
  top: 5px;
  width: 1px; /*線の太さ*/
  height: 0; /*はじめは高さを0に*/
  background: #0A3B94;
}
/*タイムラインの見出し横の丸の位置と形状*/
.timeline li::after {
  content: '';
  position: absolute;
  top: 5px;
  left: 0;
  width: 10px;
  height: 10px;
  background: #0A3B94;
  border-radius: 50%;
}
/* philosophy */
.philosophy_bg {
  margin: 2em auto 0;
}
.philosophy {}
.philosophy li {
  padding: 4em 0 0;
  position: relative;
  text-align: left;
}
.philosophy li:nth-of-type(even) {
  padding: 4em 0 4em;
}
.philosophy li::before {
  position: absolute;
  bottom: -4em;
  left: 0;
  width: 60%;
  height: 80%;
  content: '';
  z-index: -1;
  background: #F4F4F4;
  clip-path: polygon(0 0, 70% 0, 100% 100%, 30% 100%);
}
.philosophy li:nth-of-type(even)::before {
  left: inherit;
  right: 0;
  clip-path: polygon(30% 0, 100% 0, 70% 100%, 0 100%);
}
.philosophy li h2 {
  position: absolute;
  top: 0px;
  left: 5%;
  color: #0A3B94;
  font-size: 1.5rem;
  letter-spacing: 2px;
}
.philosophy li h2 span {
  display: block;
  font-family: effra, sans-serif;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 3px;
  font-size: 3rem;
}
.philosophy li img {
  width: 85%;
  height: 170px;
  object-fit: cover;
  margin: 0 0 0 15%;
  object-position: center left;
}
.philosophy li:nth-of-type(even) h2 {
  left: inherit;
  right: 5%;
  text-align: right;
}
.philosophy li:nth-of-type(even) img {
  margin: 0 15% 0 0;
  object-position: center right;
}
.philosophy li p {
  width: 75%;
  margin: 1em auto 0;
  line-height: 1.8;
}
.philosophy li p span {
  display: block;
  color: #0A3B94;
  font-size: 1.8rem;
  letter-spacing: 2px;
  margin: 0 auto 0.3em;
  font-weight: bold;
  line-height: 1.6;
}
.values_top {
  position: relative;
}
.values_top::before {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 100%;
  background: #0A3B94;
  mix-blend-mode: multiply;
  opacity: 0.5;
}
.values_top > img {
  height: 250px;
  object-fit: cover;
}
.values_top p {
  width: 250px;
  position: absolute;
  bottom: -2px;
  left: 5%;
}
.values_bg {
  padding: 3em 0;
  position: relative;
  text-align: left;
}
.values_bg h2 {
  width: 80%;
  margin: auto;
  color: #0A3B94;
  font-size: 1.5rem;
  letter-spacing: 2px;
}
.values_bg h2 span {
  display: block;
  font-family: effra, sans-serif;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 3px;
  font-size: 3rem;
}
.values {
  width: 80%;
  margin: 1em auto 0;
}
.values img {
  display: block;
  margin: auto;
  max-width: 250px;
}
.values ul {}
.values ul li {
  margin: 1em auto 0;
}
.values ul li div {
  position: relative;
  margin: 0 auto 0.3em;
  color: #0A3B94;
  font-weight: bold;
  font-size: 1.6rem;
  letter-spacing: 2px;
}
.values ul li div::before {
  content: 'ー';
  padding: 0 3px 0 0;
  font-weight: 300;
}
.mission_wrap {
  position: relative;
}
.mission_wrap::after {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 100%;
  clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
  z-index: -2;
  background: #0A3B94;
}
.mission_bg {
  position: relative;
  padding: 5em 0;
  background: #F4F4F4;
  clip-path: polygon(0 0, 100% 5%, 100% 100%, 0 95%);
  z-index: 1;
}
.h2_ttl {
  font-size: 1.8rem;
  letter-spacing: 2px;
  color: #0A3B94;
}
.h2_ttl span {
  display: block;
  font-family: effra, sans-serif;
  font-weight: 700;
  letter-spacing: 3px;
  font-size: 2.8rem;
  line-height: 1.2;
}
.mission {
  width: 80%;
  margin: auto;
}
.mission li {
  margin: 1em auto 0;
  text-align: left;
  background: #fff;
  padding: 20px;
}
.mission li div {
  color: #0A3B94;
  font-weight: bold;
  font-size: 1.6rem;
  letter-spacing: 2px;
  margin: 0 auto 0.3em;
}
.message_bg {
  padding: 2em 0 3em;
}
.message {
  margin: 1em auto 0;
  text-align: left;
}
.message img {
  width: 90%;
  margin: auto;
  display: block;
}
.message p {
  margin: 1em auto 0;
  width: 80%;
  line-height: 1.8;
}
.message div {
  font-weight: bold;
  font-size: 1.4rem;
  margin: 1em auto 0;
  width: 80%;
}
/* ------------------------------------ */
/* ▼PC用デザイン */
/* ------------------------------------ */
@media all and (min-width: 768px) {
  /* company */
  .company_bg {
    max-width: 1000px;
    margin: -2em auto 0;
  }
  .company_img div {
    width: 180px;
    margin: 0 auto 20px;
  }
  .comp_list {
    margin: 2em auto 5em;
  }
  .comp_list li {
    padding: 20px 0;
  }
  /* message */
  .message_wrap {
    margin: 1em auto 5em;
    position: relative;
    overflow: hidden;
  }
  .message_wrap::after {
    position: absolute;
    content: '';
    top: 300px;
    left: -280px;
    display: block;
    width: 650px; /*幅*/
    height: 850px;
    background-image: url("/img/company/bg.webp");
    background-size: contain;
    background-repeat: no-repeat; /*画像を繰り返さない*/
    z-index: -1;
  }
  .message_ttl {
    width: 70%;
    margin: 0 auto 1em;
    font-size: 1.8rem;
  }
  .message_ttl span {
    line-height: 1.6;
    letter-spacing: 3px;
    font-size: 4.5rem;
  }
  .message_img {
    width: 85%;
    margin: 0 0 0 auto;
  }
  .message_wrap ul {
    width: 70%;
    margin: auto;
  }
  .message_wrap ul li {
    margin: 3em auto 0;
  }
  .message_wrap ul li div {
    font-size: 2.2rem;
    padding: 0 0 5px 38px;
  }
  .message_wrap ul li div::before {
    top: 48%;
    width: 30px;
  }
  .message_wrap ul li p {
    line-height: 2;
  }
  /* history */
  .history_bg {
    max-width: 900px;
    margin: 1em auto 2em;
  }
  .history_ttl {
    letter-spacing: 2px;
    font-size: 2.5rem;
    padding: 0 0 0 60px;
  }
  .history_ttl::before {
    width: 45px;
    height: 45px;
  }
  /*タイムライン全体の設定*/
  .timeline {
    margin: 2em auto 3em;
    padding: 0 0 0 140px;
  }
  .timeline li {
    padding: 0 0 40px 0;
  }
  .timeline dl {
    margin: 0px 0 20px 3em;
    position: relative;
  }
  .timeline dt {
    left: -180px;
    font-size: 1.4rem;
  }
  .timeline dt span {
    font-size: 4.5rem;
  }
  .timeline dd {}
  .timeline dd div {
    padding: 2px 25px;
  }
  .timeline dd img {
    max-width: 200px;
    margin: 8px auto 8px 0;
  }
  .timeline dd p {
    font-size: 1.4rem;
  }
  .timeline dd p span {
    font-size: 2rem;
  }
  /*絶対配置で線を設定*/
  .border-line {
    left: 7px;
    top: 10px
  }
  /*タイムラインの見出し横の丸の位置と形状*/
  .timeline li::after {
    top: 10px;
    width: 15px;
    height: 15px;
  }
  /* philosophy */
  .philosophy_bg {
    margin: 2em auto 0;
  }
  .philosophy {}
  .philosophy li {
    padding: 0em 0 6em;
  }
  .philosophy li:nth-of-type(even) {
    padding: 0em 0 6em;
  }
  .philosophy li::before {
    bottom: -6em;
    left: -30px;
    width: 60%;
    height: 80%;
    clip-path: polygon(0 0, 50% 0, 100% 100%, 50% 100%);
  }
  .philosophy li:nth-of-type(even)::before {
    left: inherit;
    right: -30px;
    clip-path: polygon(50% 0, 100% 0, 50% 100%, 0 100%);
  }
  .philosophy li h2 {
    top: 80px;
    left: 10%;
    font-size: 2.5rem;
  }
  .philosophy li h2 span {
    letter-spacing: 4px;
    font-size: 5.8rem;
    line-height: 1;
  }
  .philosophy li img {
    width: 80%;
    height: 450px;
    margin: 0 0 0 20%;
  }
  .philosophy li:nth-of-type(even) h2 {
    right: 10%;
  }
  .philosophy li:nth-of-type(even) img {
    margin: 0 20% 0 0;
  }
  .philosophy li p {
    width: 50%;
    margin: 1.5em auto 0;
    font-size: 1.7rem;
    line-height: 2.3;
    letter-spacing: 2px;
    padding: 0 10% 0 0;
  }
  .philosophy li p span {
    font-size: 3rem;
  }
  .values_top > img {
    height: 500px;
  }
  .values_top p {
    width: 580px;
  }
  .values_bg {
    padding: 5em 0 5em;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin: 0em auto 0em;
    justify-content: center;
  }
  .values_bg::before {
    position: absolute;
    top: 0;
    left: -8%;
    content: '';
    width: 50%;
    height: 100%;
    background: url("/img/philosophy/bg.webp") center right/ cover;
    z-index: -1;
  }
  .values_bg h2 {
    width: auto;
    margin: 5em 130px 0 0;
    font-size: 2.5rem;
  }
  .values_bg h2 span {
    letter-spacing: 4px;
    font-size: 5.8rem;
    line-height: 1;
  }
  .values {
    width: 50%;
    max-width: 400px;
    margin: 0;
  }
  .values img {
    max-width: 100%;
  }
  .values ul {
    margin: 2em auto 0;
  }
  .values ul li {
    margin: 1em auto 0;
  }
  .values ul li div {
    font-size: 2rem;
    letter-spacing: 4px;
  }
  .values ul li p {
    letter-spacing: 2px;
    font-size: 1.6rem;
  }
  .mission_wrap {
    margin: -2em auto 0;
  }
  .mission_wrap::after {
    clip-path: polygon(0 20%, 100% 0, 100% 80%, 0 100%);
  }
  .mission_bg {
    padding: 13em 0;
    clip-path: polygon(0 0, 100% 20%, 100% 100%, 0 80%);
  }
  .mission_bg .h2_ttl {
    margin: -1em auto 0;
  }
  .h2_ttl {
    font-size: 2.5rem;
  }
  .h2_ttl span {
    letter-spacing: 4px;
    font-size: 5.8rem;
    line-height: 1;
  }
  .mission {
    width: 90%;
    max-width: 1000px;
    margin: auto;
  }
  .mission li {
    margin: 1em auto 0;
    padding: 30px 50px;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: center;
    align-items: center;
  }
  .mission li div {
    width: 320px;
    font-size: 2rem;
    letter-spacing: 3px;
    margin: 0;
  }
  .mission li p {
    width: calc(100% - 320px);
    letter-spacing: 3px;
    font-size: 1.6rem;
  }
  .message_bg {
    padding: 0em 0 5em;
  }
  .message {
    margin: 1em auto 0;
    max-width: 900px;
  }
  .message img {
    width: 100%;
  }
  .message p {
    margin: 2em auto 0;
    width: 100%;
    line-height: 2.3;
    letter-spacing: 2px;
    font-size: 1.6rem;
  }
  .message div {
    font-size: 1.7rem;
    margin: 1.5em auto 0;
    width: 100%;
  }
}