/****************************/
.index_mv {
  transition: .3s;
  background-color: #0075B6;
  border-radius: 0 0 300px 0;
  padding: 110px 0 0;
  width: 100%;
  max-height: 950px; }
  .index_mv p {
    background: url("../images/index/mv.png") center center no-repeat;
    background-size: contain;
    aspect-ratio: 1920/950;
    margin: 0 auto;
    width: 100%;
    max-width: 1920px;
    height: auto;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap; }

@media (min-width: 1920px) {
  .index_mv {
    min-height: 950px;
    padding: 0 0 0; } }
/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .index_mv {
    border-radius: 0 0 200px 0;
    padding: 80px 0 0; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .index_mv {
    border-radius: 0 0 100px 0;
    padding: 50px 20px 0;
    width: 100%;
    max-height: inherit; }
    .index_mv p {
      background: url("../images/index/mv_sp.png") center center no-repeat;
      background-size: contain;
      aspect-ratio: 768/1366; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .index_mv {
    border-radius: 0 0 100px 0;
    padding: 10px 0 0; } }
/*max-width:480px*/
/****************************/
.index_news {
  padding: 80px 0 120px; }
  .index_news .box {
    max-width: 1280px;
    width: calc(100% - 100px);
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start; }
  .index_news h2 {
    width: fit-content;
    color: #0075B6;
    font: 8rem/1em "Outfit", sans-serif;
    font-weight: 100; }
    .index_news h2 span {
      display: block;
      font: 1.9rem/1em "Noto Sans", sans-serif;
      font-weight: 500;
      letter-spacing: 0.06em;
      padding: 0 0 0 20px;
      border-left: 4px solid #0075B6;
      margin: 15px 0 0 10px;
      width: fit-content; }
  .index_news .item {
    max-width: 880px;
    width: calc(100% - 280px); }
  .index_news ul {
    margin: 0 0 50px; }
  .index_news li {
    margin: 0 0 10px;
    border-bottom: 1px solid #BCCDDF; }
    .index_news li a {
      transition: .3s;
      padding: 12px 45px 13px 0;
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
      align-items: flex-start;
      position: relative; }
      .index_news li a:before {
        position: absolute;
        content: "";
        right: 15px;
        top: 20px;
        width: 10px;
        height: 10px;
        border-top: 1px solid #5C6776;
        border-right: 1px solid #5C6776;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
    .index_news li p {
      width: calc(100% - 110px);
      font: 1.7rem/1.6em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }
    .index_news li time {
      width: 110px;
      font: 1.6rem/1.6em "Roboto", sans-serif;
      font-weight: 500; }
  .index_news .btn {
    display: block;
    margin: 0 0 0 auto;
    width: calc(100% - 20px);
    max-width: 340px;
    height: 65px;
    color: #fff;
    font: 1.7rem/65px "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-align: center;
    position: relative;
    z-index: 5; }
    .index_news .btn span {
      position: relative;
      display: block;
      width: 100%;
      padding: 0 20px 0 0; }
      .index_news .btn span:before {
        position: absolute;
        content: "";
        right: 25px;
        top: 28px;
        width: 10px;
        height: 10px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
    .index_news .btn:before {
      transition: .3s;
      border-radius: 50px;
      position: absolute;
      width: 100%;
      height: 100%;
      content: "";
      display: block;
      left: 0;
      top: 0;
      z-index: -1;
      background: linear-gradient(#59C2E1, #009BD3); }
    .index_news .btn:after {
      opacity: 0;
      transition: .3s;
      border-radius: 50px;
      position: absolute;
      width: 100%;
      height: 100%;
      content: "";
      display: block;
      left: 0;
      top: 0;
      z-index: -1;
      background: #0075B6; }

@media (hover: hover) {
  .index_news li a:hover {
    color: #99C5DD; }
  .index_news .btn:hover:before {
    opacity: 0; }
  .index_news .btn:hover:after {
    opacity: 1; } }
/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .index_news .box {
    max-width: 1280px;
    margin: 0 auto;
    display: block; }
  .index_news h2 {
    margin: 0 0 50px; }
  .index_news .item {
    max-width: 1024px;
    width: 100%; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .index_news .box {
    width: calc(100% - 60px);
    max-width: 1280px;
    margin: 0 auto;
    display: block; }
  .index_news h2 {
    margin: 0 0 40px;
    font: 7rem/1em "Outfit", sans-serif;
    font-weight: 100; }
    .index_news h2 span {
      font: 1.8rem/1em "Noto Sans", sans-serif;
      font-weight: 500; }
  .index_news li a {
    padding: 12px 0 13px 0;
    display: block; }
    .index_news li a:before {
      display: none; }
  .index_news li p {
    width: 100%;
    font: 1.6rem/1.6em "Noto Sans", sans-serif;
    font-weight: 400;
    letter-spacing: 0.05em;
    padding: 0 45px 0 0;
    position: relative; }
    .index_news li p:before {
      position: absolute;
      content: "";
      right: 15px;
      top: 8px;
      width: 10px;
      height: 10px;
      border-top: 1px solid #5C6776;
      border-right: 1px solid #5C6776;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg); }
  .index_news li time {
    width: 100%;
    margin: 0 0 5px;
    font: 1.5rem/1.6em "Roboto", sans-serif;
    font-weight: 500; }
  .index_news .btn {
    width: calc(100% - 20px);
    max-width: 300px;
    padding: 0 15px 0 0;
    font: 1.6rem/65px "Noto Sans", sans-serif;
    font-weight: 500; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .index_news {
    padding: 60px 0 20px; }
    .index_news .box {
      width: calc(100% - 60px); }
    .index_news h2 {
      margin: 0 0 18px;
      font: 5rem/1em "Outfit", sans-serif;
      font-weight: 100; }
    .index_news ul {
      margin: 0 0 25px; }
    .index_news li a {
      padding: 12px 0 13px 0;
      display: block; }
      .index_news li a:before {
        display: none; }
    .index_news li p {
      width: 100%;
      font: 1.5rem/1.7em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em;
      padding: 0 30px 0 0;
      position: relative; }
      .index_news li p:before {
        right: 10px;
        top: 7px;
        width: 8px;
        height: 8px; }
    .index_news li time {
      font: 1.4rem/1.6em "Roboto", sans-serif;
      font-weight: 500; }
    .index_news .btn {
      max-width: 220px;
      height: 50px;
      font: 1.5rem/48px "Noto Sans", sans-serif;
      font-weight: 500; }
      .index_news .btn span {
        padding: 0 15px 0 0; }
        .index_news .btn span:before {
          position: absolute;
          content: "";
          right: 10px;
          top: 20px;
          width: 8px;
          height: 8px; } }
/*max-width:480px*/
/****************************/
.about_mv {
  transition: .3s;
  background-color: #0075B6;
  border-radius: 0 0 300px 0;
  padding: 200px 0 75px;
  width: 100%;
  margin: 0 auto 100px; }
  .about_mv .box {
    width: calc(100% - 100px);
    max-width: 1430px;
    margin: 0 auto; }
  .about_mv h2 {
    width: fit-content;
    color: #fff;
    font: 10rem/1em "Outfit", sans-serif;
    font-weight: 100;
    margin: 0 0 30px; }
    .about_mv h2 span {
      margin: 10px 0 0;
      display: block;
      font: 4.5rem/1em "Outfit", sans-serif;
      font-weight: 100;
      width: fit-content; }
  .about_mv p {
    font: 2rem/1.3em "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: #fff;
    padding: 0 0 0 25px;
    margin: 0 0 80px;
    position: relative; }
    .about_mv p:before {
      position: absolute;
      content: "";
      width: 1px;
      height: 100%;
      left: 0;
      top: 1px;
      border-left: 4px solid #59C2E1; }
    .about_mv p br {
      display: none; }
  .about_mv .item {
    background: url("../images/about/mv.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 1120/461;
    width: 100%;
    max-width: 1120px;
    height: auto;
    margin: 0 auto; }

@media (max-width: 1024px) {
  .about_mv {
    border-radius: 0 0 200px 0;
    padding: 180px 0 75px; }
    .about_mv .box {
      width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .about_mv {
    border-radius: 0 0 100px 0;
    margin: 0 auto 50px;
    width: 100%;
    padding: 150px 0 75px; }
    .about_mv .box {
      width: calc(100% - 60px);
      max-width: 480px; }
    .about_mv h2 {
      font: 7rem/1em "Outfit", sans-serif;
      font-weight: 100;
      margin: 0 0 30px; }
      .about_mv h2 span {
        font: 3.5rem/1em "Outfit", sans-serif;
        font-weight: 100; }
    .about_mv .item {
      background: url("../images/about/mv_sp.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 306/855;
      width: 100%;
      max-width: 480px;
      height: auto;
      margin: 0 auto; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .about_mv {
    padding: 120px 0 35px; }
    .about_mv .box {
      max-width: 305px; }
    .about_mv h2 {
      font: 5.6rem/1em "Outfit", sans-serif;
      font-weight: 100; }
      .about_mv h2 span {
        margin: 10px 0 0;
        font: 2rem/1em "Outfit", sans-serif;
        font-weight: 100; }
    .about_mv p {
      font: 1.8rem/1.8em "Noto Sans", sans-serif;
      font-weight: 500;
      letter-spacing: 0.01em;
      color: #fff;
      margin: 0 0 40px; }
      .about_mv p br {
        display: block; }
      .about_mv p:before {
        position: absolute;
        content: "";
        width: 1px;
        height: 90%;
        left: 0;
        top: 5%;
        border-left: 4px solid #59C2E1; } }
/*max-width:480px*/
/****************************/
.about_01,
.about_02 {
  max-width: 1120px;
  width: calc(100% - 100px);
  height: auto;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap; }

.about_01 {
  background: url("../images/about/about-01.svg") center center no-repeat;
  background-size: contain;
  aspect-ratio: 1120/363;
  margin: 0 auto 100px; }

.about_02 {
  background: url("../images/about/about-02.svg") center center no-repeat;
  background-size: contain;
  aspect-ratio: 1120/569;
  margin: 0 auto 100px; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .about_01,
  .about_02 {
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .about_01,
  .about_02 {
    width: calc(100% - 60px);
    max-width: 480px; }

  .about_01 {
    background: url("../images/about/about-01_sp.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 315/607;
    margin: 0 auto 50px; }

  .about_02 {
    background: url("../images/about/about-02_sp.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 316/904;
    margin: 0 auto 50px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .about_01,
  .about_02 {
    width: calc(100% - 60px);
    max-width: 315px; }

  .about_02 {
    margin: 0 auto 20px; } }
/*max-width:480px*/
/****************************/
.career_mv,
.curriculum_mv,
.fee_mv,
.contact_mv,
.news_mv {
  transition: .3s;
  background-color: #0075B6;
  border-radius: 0 0 150px 150px;
  width: 100%;
  margin: 0 auto 100px;
  min-height: 435px;
  overflow: hidden;
  position: relative; }
  .career_mv:before,
  .curriculum_mv:before,
  .fee_mv:before,
  .contact_mv:before,
  .news_mv:before {
    position: absolute;
    content: "";
    aspect-ratio: 800/396;
    width: 100%;
    max-width: 800px;
    height: auto;
    top: 50%;
    right: 60px;
    transform: translate(0%, -50%);
    background-size: contain;
    background-repeat: no-repeat; }
  .career_mv .box,
  .curriculum_mv .box,
  .fee_mv .box,
  .contact_mv .box,
  .news_mv .box {
    position: relative;
    z-index: 10;
    padding: 190px 0 0;
    width: calc(100% - 100px);
    max-width: 1280px;
    margin: 0 auto; }
  .career_mv h2,
  .curriculum_mv h2,
  .fee_mv h2,
  .contact_mv h2,
  .news_mv h2 {
    width: fit-content;
    color: #fff;
    font: 10rem/1em "Outfit", sans-serif;
    font-weight: 100;
    margin: 0 0 15px; }
    .career_mv h2 span,
    .curriculum_mv h2 span,
    .fee_mv h2 span,
    .contact_mv h2 span,
    .news_mv h2 span {
      font: 8rem/1em "Outfit", sans-serif;
      font-weight: 100; }
    .career_mv h2 small,
    .curriculum_mv h2 small,
    .fee_mv h2 small,
    .contact_mv h2 small,
    .news_mv h2 small {
      font: 4.5rem/1em "Outfit", sans-serif;
      font-weight: 100;
      padding: 0 20px 0 0; }
  .career_mv p,
  .curriculum_mv p,
  .fee_mv p,
  .contact_mv p,
  .news_mv p {
    font: 2rem/1.3em "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: #fff;
    border-left: 4px solid #59C2E1;
    padding: 0 0 0 25px; }

.career_mv:before {
  background: url("../images/career/mv.svg") center center no-repeat;
  background-size: contain; }

.curriculum_mv:before {
  background: url("../images/curriculum/mv.svg") center center no-repeat;
  background-size: contain; }

.fee_mv:before {
  background: url("../images/fee/mv.svg") center center no-repeat;
  background-size: contain; }

.contact_mv:before {
  background: url("../images/contact/mv.svg") center center no-repeat;
  background-size: contain; }

.news_mv:before {
  background: url("../images/news/mv.svg") center center no-repeat;
  background-size: contain; }

@media (max-width: 1280px) {
  .career_mv:before,
  .curriculum_mv:before,
  .fee_mv:before,
  .contact_mv:before,
  .news_mv:before {
    max-width: 640px;
    right: 0; } }
@media (max-width: 1024px) {
  .career_mv,
  .curriculum_mv,
  .fee_mv,
  .contact_mv,
  .news_mv {
    border-radius: 0 0 100px 100px; }
    .career_mv:before,
    .curriculum_mv:before,
    .fee_mv:before,
    .contact_mv:before,
    .news_mv:before {
      display: none; }
    .career_mv .box,
    .curriculum_mv .box,
    .fee_mv .box,
    .contact_mv .box,
    .news_mv .box {
      width: calc(100% - 80px); }

  .fee_mv h2 small {
    display: block;
    padding: 0; }
  .fee_mv .box {
    padding: 150px 0 0; } }
@media (max-width: 768px) {
  .career_mv,
  .curriculum_mv,
  .fee_mv,
  .contact_mv,
  .news_mv {
    border-radius: 0 0 50px 50px;
    min-height: 300px;
    margin: 0 auto 50px; }
    .career_mv .box,
    .curriculum_mv .box,
    .fee_mv .box,
    .contact_mv .box,
    .news_mv .box {
      padding: 120px 0 0;
      width: calc(100% - 60px);
      max-width: 480px; }
    .career_mv h2,
    .curriculum_mv h2,
    .fee_mv h2,
    .contact_mv h2,
    .news_mv h2 {
      font-size: 7rem; }

  .fee_mv h2 small {
    font: 3.5rem/1em "Outfit", sans-serif;
    font-weight: 100; }
  .fee_mv h2 span {
    font-size: 5.5rem; }
  .fee_mv .box {
    padding: 110px 0 0; } }
@media (max-width: 480px) {
  .career_mv,
  .curriculum_mv,
  .fee_mv,
  .contact_mv,
  .news_mv {
    border-radius: 0 0 40px 40px;
    min-height: 250px; }
    .career_mv .box,
    .curriculum_mv .box,
    .fee_mv .box,
    .contact_mv .box,
    .news_mv .box {
      padding: 110px 0 0;
      max-width: 305px; }
    .career_mv h2,
    .curriculum_mv h2,
    .fee_mv h2,
    .contact_mv h2,
    .news_mv h2 {
      font-size: 5.6rem; }
      .career_mv h2 span,
      .curriculum_mv h2 span,
      .fee_mv h2 span,
      .contact_mv h2 span,
      .news_mv h2 span {
        margin: 10px 0 0;
        font-size: 2.0rem; }
    .career_mv p,
    .curriculum_mv p,
    .fee_mv p,
    .contact_mv p,
    .news_mv p {
      font-size: 1.8rem;
      margin: 0 0 40px; } }
/****************************/
.curriculum_01,
.curriculum_02 {
  max-width: 1120px;
  width: calc(100% - 100px);
  height: auto;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap; }

.curriculum_01 {
  background: url("../images/curriculum/curriculum-01.svg") center center no-repeat;
  background-size: contain;
  aspect-ratio: 1120/489;
  margin: 0 auto 100px; }

.curriculum_02 {
  background: url("../images/curriculum/curriculum-02.svg") center center no-repeat;
  background-size: contain;
  aspect-ratio: 1122/992;
  margin: 0 auto 100px; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .curriculum_01,
  .curriculum_02 {
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .curriculum_01,
  .curriculum_02 {
    width: calc(100% - 60px);
    max-width: 480px; }

  .curriculum_01 {
    background: url("../images/curriculum/curriculum_sp-01.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 315/604;
    margin: 0 auto 100px; }

  .curriculum_02 {
    background: url("../images/curriculum/curriculum_sp-02.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 317/2001;
    margin: 0 auto 100px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .curriculum_01,
  .curriculum_02 {
    width: calc(100% - 60px);
    max-width: 315px; }

  .curriculum_01 {
    margin: 0 auto 50px; }

  .curriculum_02 {
    margin: 0 auto 20px; } }
/*max-width:480px*/
/****************************/
.career_01 {
  max-width: 1120px;
  width: calc(100% - 100px);
  height: auto;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
  background: url("../images/career/career.svg") center center no-repeat;
  background-size: contain;
  aspect-ratio: 1120/676;
  margin: 0 auto 100px; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .career_01 {
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .career_01 {
    width: calc(100% - 60px);
    max-width: 480px;
    background: url("../images/career/career-sp.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 315/1224;
    margin: 0 auto 100px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .career_01 {
    width: calc(100% - 60px);
    max-width: 315px;
    margin: 0 auto 20px; } }
/*max-width:480px*/
/****************************/
.fee_01 {
  max-width: 1120px;
  width: calc(100% - 100px);
  margin: 0 auto 100px; }
  .fee_01 p {
    background: url("../images/fee/fee-01.svg") center center no-repeat;
    background-size: contain;
    aspect-ratio: 730/255;
    height: auto;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    max-width: 730px;
    width: 100%; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .fee_01 {
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .fee_01 {
    width: calc(100% - 60px);
    max-width: 480px; }
    .fee_01 p {
      background: url("../images/fee/fee-01-sp.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 315/572; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .fee_01 {
    width: calc(100% - 60px);
    max-width: 315px;
    margin: 0 auto 20px; } }
/*max-width:480px*/
/****************************/
.contact_box {
  max-width: 1120px;
  width: calc(100% - 100px);
  margin: 0 auto 100px;
  color: #222222; }
  .contact_box p {
    font: 1.9rem/1.8em "Noto Sans", sans-serif;
    font-weight: 400;
    letter-spacing: 0.05em;
    margin: 0 0 30px;
    padding: 0 0 15px;
    border-bottom: #BCCDDF 1px solid; }
    .contact_box p br.two {
      display: none; }
  .contact_box dt {
    font: 2.4rem/1.8em "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.05em;
    margin: 0 0 15px; }
  .contact_box dd {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center; }
    .contact_box dd span {
      margin: 0 15px 0 0;
      display: block;
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap;
      background: url("../images/common/icon_mail_03.svg") center center no-repeat;
      background-size: contain;
      width: 26px;
      height: 20px; }
    .contact_box dd a {
      display: block;
      max-width: fit-content;
      width: calc(100% - 46px); }
      .contact_box dd a img {
        max-width: 100%; }

/*min-width:1920px*/
/*max-width:1280px*/
@media (max-width: 1024px) {
  .contact_box {
    max-width: 1120px;
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .contact_box {
    max-width: 480px;
    width: calc(100% - 60px); }
    .contact_box p {
      font: 1.8rem/1.8em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }
    .contact_box dt {
      font: 2.3rem/1.8em "Noto Sans", sans-serif;
      font-weight: 500; }
    .contact_box dd {
      width: 100%;
      display: block; }
      .contact_box dd span {
        font: 2.2rem/1em "Noto Sans", sans-serif;
        font-weight: 500;
        margin: 0 0 20px;
        padding: 0 0 0 30px;
        display: block;
        overflow: inherit;
        text-indent: inherit;
        white-space: inherit;
        background: url("../images/common/icon_mail_03.svg") top 5px left no-repeat;
        background-size: 20px 15px;
        width: 100%;
        height: auto; }
      .contact_box dd a {
        width: 100%; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .contact_box {
    max-width: 315px;
    width: calc(100% - 60px);
    margin: 0 auto 50px; }
    .contact_box p {
      font: 1.6rem/1.8em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }
      .contact_box p br.one {
        display: none; }
      .contact_box p br.two {
        display: block; }
    .contact_box dt {
      font: 1.9rem/1.8em "Noto Sans", sans-serif;
      font-weight: 500; }
    .contact_box dd {
      width: 100%;
      display: block; }
      .contact_box dd span {
        font: 1.8rem/1em "Noto Sans", sans-serif;
        font-weight: 500;
        margin: 0 0 15px;
        padding: 0 0 3px 30px;
        display: block;
        overflow: inherit;
        text-indent: inherit;
        white-space: inherit;
        background: url("../images/common/icon_mail_03.svg") top 3px left no-repeat;
        background-size: 20px 15px;
        width: 100%;
        height: auto; } }
/*max-width:480px*/
/****************************/
.news_box {
  max-width: 1120px;
  width: calc(100% - 100px);
  margin: 0 auto 100px; }
  .news_box ul {
    margin: 0 0 50px; }
  .news_box li {
    margin: 0 0 10px;
    border-bottom: 1px solid #BCCDDF; }
    .news_box li a {
      padding: 12px 45px 13px 0;
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
      align-items: flex-start;
      position: relative;
      color: #222222;
      transition: .3s; }
      .news_box li a:before {
        position: absolute;
        content: "";
        right: 15px;
        top: 20px;
        width: 10px;
        height: 10px;
        border-top: 1px solid #5C6776;
        border-right: 1px solid #5C6776;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
    .news_box li p {
      width: calc(100% - 110px);
      font: 1.7rem/1.6em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em; }
    .news_box li time {
      width: 110px;
      font: 1.6rem/1.6em "Roboto", sans-serif;
      font-weight: 500; }

@media (hover: hover) {
  .news_box li a:hover {
    color: #99C5DD; } }
@media (max-width: 1024px) {
  .news_box {
    max-width: 1120px;
    width: calc(100% - 80px);
    margin: 0 auto 100px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .news_box {
    max-width: 1120px;
    width: calc(100% - 60px);
    margin: 0 auto 100px; }
    .news_box ul {
      margin: 0 0 50px; }
    .news_box li a {
      padding: 12px 0 13px 0;
      display: block; }
      .news_box li a:before {
        display: none; }
    .news_box li p {
      width: 100%;
      font: 1.6rem/1.6em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em;
      padding: 0 45px 0 0;
      position: relative; }
      .news_box li p:before {
        position: absolute;
        content: "";
        right: 15px;
        top: 8px;
        width: 10px;
        height: 10px;
        border-top: 1px solid #5C6776;
        border-right: 1px solid #5C6776;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
    .news_box li time {
      width: 100%;
      margin: 0 0 5px;
      font: 1.5rem/1.6em "Roboto", sans-serif;
      font-weight: 500; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .news_box {
    max-width: 315px;
    width: calc(100% - 60px);
    margin: 0 auto 30px; }
    .news_box ul {
      margin: 0 0 25px; }
    .news_box li a {
      padding: 12px 0 13px 0;
      display: block; }
      .news_box li a:before {
        display: none; }
    .news_box li p {
      width: 100%;
      font: 1.5rem/1.7em "Noto Sans", sans-serif;
      font-weight: 400;
      letter-spacing: 0.05em;
      padding: 0 30px 0 0;
      position: relative; }
      .news_box li p:before {
        right: 10px;
        top: 7px;
        width: 8px;
        height: 8px; }
    .news_box li time {
      font: 1.4rem/1.6em "Roboto", sans-serif;
      font-weight: 500; } }
/*max-width:480px*/
/***************************************/
.pagination {
  max-width: 315px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: center;
  align-items: center; }
  .pagination a, .pagination span {
    color: #222222;
    font: 1.6rem/30px "Noto Sans", sans-serif;
    font-weight: 400;
    display: block;
    text-align: center;
    margin: 3px;
    width: 30px;
    height: 30px; }
  .pagination a:hover {
    opacity: 0.5; }
  .pagination span {
    text-decoration: underline; }

@media (max-width: 480px) {
  .pagination {
    max-width: 300px; } }
/*max-width:480px*/
/***************************************/
.news_single {
  max-width: 1120px;
  width: calc(100% - 100px);
  margin: 0 auto 100px; }
  .news_single .head {
    margin-bottom: 40px; }
  .news_single .ttl {
    font: 2.2rem/1.8em "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.05em; }
  .news_single time {
    font: 1.6rem/1em "Roboto", sans-serif;
    display: block;
    border-bottom: 1px solid #BCCDDF;
    padding: 0 0 15px;
    margin: 0 0 20px; }
  .news_single .btn {
    display: block;
    margin: 0 auto;
    width: calc(100% - 20px);
    max-width: 340px;
    height: 65px;
    color: #fff;
    padding: 0 20px 0 0;
    font: 1.7rem/65px "Noto Sans", sans-serif;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-align: center;
    background: linear-gradient(#59C2E1, #009BD3);
    position: relative;
    border-radius: 50px;
    z-index: 5; }
    .news_single .btn span {
      position: relative;
      display: block;
      width: 100%;
      padding: 0 20px 0 0; }
      .news_single .btn span:before {
        position: absolute;
        content: "";
        right: 25px;
        top: 28px;
        width: 10px;
        height: 10px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
    .news_single .btn:before {
      transition: .3s;
      border-radius: 50px;
      position: absolute;
      width: 100%;
      height: 100%;
      content: "";
      display: block;
      left: 0;
      top: 0;
      z-index: -1;
      background: linear-gradient(#59C2E1, #009BD3); }
    .news_single .btn:after {
      opacity: 0;
      transition: .3s;
      border-radius: 50px;
      position: absolute;
      width: 100%;
      height: 100%;
      content: "";
      display: block;
      left: 0;
      top: 0;
      z-index: -1;
      background: #0075B6; }

.news_content {
  font: 1.7rem/2.2em "Noto Sans", sans-serif;
  font-weight: 400;
  font-weight: 0.04em;
  width: 100%;
  margin: 0 auto 80px; }
  .news_content p {
    margin: 0 0 30px; }

@media (hover: hover) {
  .news_single .btn:hover:before {
    opacity: 0; }
  .news_single .btn:hover:after {
    opacity: 1; } }
@media (max-width: 1024px) {
  .news_single {
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .news_single {
    max-width: 1120px;
    width: calc(100% - 60px);
    margin: 0 auto 100px; }
    .news_single .head {
      margin-bottom: 40px; }
    .news_single .ttl {
      font: 2rem/1.8em "Noto Sans", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em; }
    .news_single time {
      font: 1.5rem/1em "Roboto", sans-serif;
      display: block;
      border-bottom: 1px solid #BCCDDF;
      padding: 0 0 15px;
      margin: 0 0 20px; }
    .news_single .btn {
      max-width: 300px; }

  .news_content {
    font: 1.6rem/2.2em "Noto Sans", sans-serif;
    font-weight: 400;
    font-weight: 0.04em;
    width: 100%;
    margin: 0 auto 50px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .news_single {
    max-width: 315px;
    width: calc(100% - 30px);
    margin: 0 auto 20px; }
    .news_single .head {
      margin-bottom: 30px; }
    .news_single .ttl {
      font: 1.8rem/1.8em "Noto Sans", sans-serif;
      font-weight: 500;
      letter-spacing: 0.05em; }
    .news_single time {
      font: 1.4rem/1em "Roboto", sans-serif;
      display: block;
      border-bottom: 1px solid #BCCDDF;
      padding: 0 0 15px;
      margin: 0 0 10px; }
    .news_single .btn {
      max-width: 220px;
      height: 50px;
      font: 1.5rem/48px "Noto Sans", sans-serif;
      font-weight: 500; }
      .news_single .btn span {
        padding: 0 15px 0 0; }
        .news_single .btn span:before {
          position: absolute;
          content: "";
          right: 10px;
          top: 20px;
          width: 8px;
          height: 8px; }

  .news_content {
    font: 1.5rem/2.2em "Noto Sans", sans-serif;
    font-weight: 400;
    font-weight: 0.04em;
    width: 100%;
    margin: 0 auto 50px; } }
/*max-width:480px*/
