.web_font1 {
  font-family: 'Oswald', sans-serif;
  font-weight: 400; }

.web_font2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  letter-spacing: 0.15em; }

.web_font3 {
  font-family: 'Roboto', sans-serif; }

.border {
  border-bottom: 1px dashed #cdcdd2; }

.border2 {
  border-bottom: 1px dashed #03071f; }

.border3 {
  border-bottom: 1px solid #cdcdd2; }

.border4 {
  border-bottom: 1px solid #03071f; }

.border5 {
  border-bottom: 2px solid #03071f; }

.bg_dot {
  background: url("../common/images/bg_dot.png") left top repeat;
  background-size: 10px 10px; }

@media screen and (min-width: 1px) {
  .bg_dot {
    background: url("../common/images/bg_dot.png") left top repeat;
    background-size: 5px 5px; } }
/*------------------------------------------------------------
Reason_ttl_area
------------------------------------------------------------*/
#Reason_ttl_area {
  position: relative;
  height: 100%; }
  #Reason_ttl_area .ttl_area {
    position: relative;
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    z-index: 20;
    text-align: center;
    flex-wrap: wrap; }
    #Reason_ttl_area .ttl_area > div {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      margin-bottom: 120px; }
    #Reason_ttl_area .ttl_area h1 {
      width: 245px;
      width: 15.3%;
      margin-bottom: 40px; }
    #Reason_ttl_area .ttl_area .txt {
      width: 100%;
      font-size: 1.6rem;
      font-size: 1%;
      font-weight: bold;
      line-height: 2.25; }
  #Reason_ttl_area .img_area {
    position: absolute;
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 10; }

@media screen and (min-width: 1px) {
  #Reason_ttl_area {
    align-items: flex-start; }
    #Reason_ttl_area .ttl_area {
      align-items: flex-start; }
      #Reason_ttl_area .ttl_area > div {
        margin-bottom: 0; }
      #Reason_ttl_area .ttl_area h1 {
        width: 178px;
        width: 47.3%;
        margin-bottom: 0;
        margin-top: 32px; }
      #Reason_ttl_area .ttl_area .txt {
        display: none; } }
/*------------------------------------------------------------
Contents_area
------------------------------------------------------------*/
#Contents_area {
  margin-top: -100px; }
  #Contents_area section {
    position: relative;
    margin-bottom: 100px; }
    #Contents_area section:before {
      display: block;
      content: '';
      width: 100%;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      z-index: 30;
      opacity: .7; }
    #Contents_area section:after {
      display: block;
      content: '';
      width: 100%;
      height: 100%;
      background: #FFF;
      position: absolute;
      top: 0;
      left: 0;
      z-index: 29; }
    #Contents_area section .section_in {
      position: relative;
      z-index: 40;
      padding: 0 70px 70px; }
    #Contents_area section h2 {
      width: 82px;
      margin: 0 auto 30px;
      position: relative;
      top: -10px; }
    #Contents_area section .ttl {
      text-align: center;
      margin-bottom: 50px; }
      #Contents_area section .ttl img {
        height: 80px;
        width: auto; }
    #Contents_area section .wrap {
      display: flex;
      align-items: center;
      justify-content: space-between; }
      #Contents_area section .wrap > dt {
        margin-left: 40px;
        width: calc( 50% - 100px); }
        #Contents_area section .wrap > dt > img {
          width: 100%;
          height: auto; }
      #Contents_area section .wrap > dd {
        width: 50%;
        width: calc( 50% - 20px); }
    #Contents_area section .btn span {
      color: #FFF;
      width: 100;
      height: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative; }
      #Contents_area section .btn span:before {
        display: block;
        content: '';
        width: 10px;
        height: 14px;
        background: url("../common/images/btn_arrow_w.png") left top no-repeat;
        background-size: 10px 14px;
        position: absolute;
        top: 50%;
        right: 20px;
        margin-top: -7px; }
    #Contents_area section#reason01:before {
      background: #ffbbc4; }
    #Contents_area section#reason01 .section_in {
      padding: 0 70px 40px; }
    #Contents_area section#reason01 .wrap {
      margin-bottom: 40px;
      padding-bottom: 60px;
      border-bottom: 2px solid #03071f; }
      #Contents_area section#reason01 .wrap > dd {
        line-height: 2.2;
        font-size: 1.6rem; }
    #Contents_area section#reason02:before {
      background: #ddcbfe; }
    #Contents_area section#reason02 .wrap {
      align-items: flex-start; }
      #Contents_area section#reason02 .wrap h3 {
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.08em; }
      #Contents_area section#reason02 .wrap .top_txt {
        margin-top: 30px;
        font-size: 1.6rem;
        margin-bottom: 45px; }
    #Contents_area section#reason02 .acc_area {
      border-bottom: 2px solid #03071f; }
    #Contents_area section#reason02 .acc_btn {
      border-top: 2px solid #03071f;
      display: flex;
      padding: 25px 0;
      line-height: 1;
      align-items: center;
      font-size: 1.6rem;
      font-weight: bold; }
      #Contents_area section#reason02 .acc_btn .box_icon {
        background: #03071f;
        margin-right: 15px; }
    #Contents_area section#reason02 .acc_box dl {
      border-top: 2px solid #03071f;
      padding: 35px 0; }
      #Contents_area section#reason02 .acc_box dl dt {
        width: 100%;
        text-align: center; }
        #Contents_area section#reason02 .acc_box dl dt img {
          width: 350px;
          height: auto;
          margin: 0 auto 30px; }
      #Contents_area section#reason02 .acc_box dl dd {
        width: 100%;
        line-height: 1.5;
        letter-spacing: 0; }
    #Contents_area section#reason03:before {
      background: #b1fffc; }
    #Contents_area section#reason03 .ttl {
      margin-bottom: 50px; }
      #Contents_area section#reason03 .ttl img {
        height: 40px;
        width: auto; }
    #Contents_area section#reason03 .wrap {
      align-items: flex-start; }
      #Contents_area section#reason03 .wrap .nav {
        margin-bottom: 30px;
        display: flex; }
        #Contents_area section#reason03 .wrap .nav li {
          border-bottom: 3px solid #03071f;
          border-bottom: 3px solid #aad6d5;
          width: 50%;
          text-align: center;
          padding-bottom: 10px;
          font-size: 1.6rem;
          color: #aad6d5;
          cursor: pointer; }
          #Contents_area section#reason03 .wrap .nav li.on {
            color: #03071f;
            border-bottom: 3px solid #03071f;
            animation: view .3s ease-in-out both; }
      #Contents_area section#reason03 .wrap .content {
        line-height: 2;
        font-size: 1.5rem;
        margin: 0 30px; }
        #Contents_area section#reason03 .wrap .content li {
          display: none; }
          #Contents_area section#reason03 .wrap .content li.on {
            display: block;
            color: #03071f;
            animation: view .3s ease-in-out both; }
        #Contents_area section#reason03 .wrap .content h3 {
          font-weight: bold;
          margin-bottom: 10px; }
        #Contents_area section#reason03 .wrap .content .txt {
          margin-bottom: 30px; }
    #Contents_area section#reason04:before {
      background: #b1ffed; }
    #Contents_area section#reason04 .wrap > dd .txt {
      line-height: 2.2;
      font-size: 1.6rem;
      margin-bottom: 40px; }
    #Contents_area section#reason05:before {
      background: #fdf68e; }
    #Contents_area section#reason05 .wrap {
      margin-bottom: 50px; }
      #Contents_area section#reason05 .wrap > dd .txt {
        line-height: 2.2;
        font-size: 1.6rem;
        margin-bottom: 40px; }
    #Contents_area section#reason05 .acc_btn {
      display: none; }

@keyframes view {
  0% {
    display: none;
    opacity: 0; }
  100% {
    display: block;
    opacity: 1; } }
@media screen and (min-width: 1px) {
  #Contents_area {
    margin-top: -70px; }
    #Contents_area section {
      margin-bottom: 50px; }
      #Contents_area section .section_in {
        padding: 0 20px 35px; }
      #Contents_area section h2 {
        width: 71px;
        margin: 0 auto 17px;
        top: -10px; }
      #Contents_area section .ttl {
        margin: 0 auto 35px;
        display: flex;
        justify-content: center; }
        #Contents_area section .ttl img {
          width: auto;
          height: 55px; }
      #Contents_area section .wrap {
        display: block; }
        #Contents_area section .wrap > dt {
          margin-left: 0;
          width: 57.3%;
          margin: 0 auto; }
          #Contents_area section .wrap > dt > img {
            width: 100%;
            height: auto; }
        #Contents_area section .wrap > dd {
          width: 100%; }
      #Contents_area section .btn span {
        width: 100;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center; }
        #Contents_area section .btn span:before {
          width: 9px;
          height: 12px;
          background: url("../common/images/btn_arrow_w.png") left top no-repeat;
          background-size: 9px 12px;
          right: 15px;
          margin-top: -6px; }
      #Contents_area section#reason01 .section_in {
        padding: 0 20px 25px; }
      #Contents_area section#reason01 .wrap {
        margin-bottom: 25px;
        padding-bottom: 35px; }
        #Contents_area section#reason01 .wrap > dt {
          width: 86%;
          margin-bottom: 40px; }
        #Contents_area section#reason01 .wrap > dd {
          text-align: center;
          line-height: 1.7;
          font-size: 1.3rem; }
      #Contents_area section#reason02 .section_in {
        padding: 0 20px 35px; }
      #Contents_area section#reason02 .wrap h3 {
        font-size: 1.8rem;
        letter-spacing: 0.08em; }
      #Contents_area section#reason02 .wrap .top_txt {
        margin-top: 35px;
        line-height: 1.7;
        font-size: 1.3rem;
        margin-bottom: 30px; }
      #Contents_area section#reason02 .acc_btn {
        flex-wrap: wrap;
        padding: 12px 0;
        font-size: 1.3rem; }
        #Contents_area section#reason02 .acc_btn .box_icon {
          margin-right: 0;
          margin-bottom: 7px; }
        #Contents_area section#reason02 .acc_btn .txt {
          width: 100%; }
      #Contents_area section#reason02 .acc_box dl {
        padding: 25px 0; }
        #Contents_area section#reason02 .acc_box dl dt {
          width: 100%; }
          #Contents_area section#reason02 .acc_box dl dt img {
            width: 100%;
            height: auto;
            margin: 0 auto 20px; }
        #Contents_area section#reason02 .acc_box dl dd {
          width: 100%;
          line-height: 1.7;
          letter-spacing: 0; }
      #Contents_area section#reason03 .section_in {
        padding: 0 20px 20px; }
      #Contents_area section#reason03 .ttl {
        margin-bottom: 35px; }
        #Contents_area section#reason03 .ttl img {
          height: 30px;
          width: auto; }
      #Contents_area section#reason03 .wrap {
        align-items: flex-start; }
        #Contents_area section#reason03 .wrap .nav {
          margin-top: 30px;
          margin-bottom: 30px;
          display: flex; }
          #Contents_area section#reason03 .wrap .nav li {
            padding-bottom: 10px;
            font-size: 1.3rem; }
        #Contents_area section#reason03 .wrap .content {
          line-height: 2;
          font-size: 1.3rem;
          line-height: 1.7;
          margin: 0; }
          #Contents_area section#reason03 .wrap .content h3 {
            font-weight: bold;
            margin-bottom: 15px;
            text-align: center;
            font-size: 1.4rem; }
          #Contents_area section#reason03 .wrap .content .txt {
            margin: 0 10px 30px; }
      #Contents_area section#reason04 .section_in {
        padding: 0 20px 20px; }
      #Contents_area section#reason04 .wrap > dd .txt {
        line-height: 1.7;
        font-size: 1.3rem;
        margin: 25px 10px 30px 10px; }
      #Contents_area section#reason05 .section_in {
        padding: 0 20px 30px; }
      #Contents_area section#reason05 .wrap {
        margin-bottom: 0; }
        #Contents_area section#reason05 .wrap > dd .txt {
          line-height: 1.7;
          font-size: 1.3rem;
          margin: 25px 10px 30px 10px; }
      #Contents_area section#reason05 .acc_btn {
        display: block;
        padding: 15px 0;
        text-align: center;
        border-bottom: 2px solid #03071f;
        border-top: 2px solid #03071f; }
      #Contents_area section#reason05 .acc_box .btn {
        margin: 20px auto 0; } }
/*------------------------------------------------------------
Modal_area
------------------------------------------------------------*/
#Modal_area .wrap {
  display: block;
  justify-content: space-between; }
  #Modal_area .wrap .img_area {
    width: 100%; }
  #Modal_area .wrap .txt_area {
    width: 100%;
    padding: 50px; }
    #Modal_area .wrap .txt_area .txt {
      margin-bottom: 30px; }

@media screen and (min-width: 1px) {
  #Modal_area .wrap .txt_area {
    padding: 30px 20px; }
    #Modal_area .wrap .txt_area .txt {
      margin-bottom: 20px; } }
