@charset "UTF-8";

body{
  font-size: 1.1vw;
}
p{
  letter-spacing: 0.12em;
  line-height: 2.13;
}
  .section-hero .content {
    position: relative;
  }
    
  @media only screen and (max-width: 767px) {
    .section-hero .content {
        margin-top: 16vw;
    }
  }
  
  .section .section-content {
    /* display: flex; */
    padding: 4.5vw 3vw 2vw 0;
    max-width: 75vw;
    margin: 0 auto;
  }

  .section-hero .imgarea {
    position: relative;
    border-radius: 0 0 0 1.2em;
    overflow: hidden;
  }
  .section-hero .imgarea .img img {
    width: 100%;
    object-fit: cover;
    font-family: 'object-fit: cover;';
    object-position: 50% 20%;
  } 
  @media only screen and (max-width: 767px) {
    .section-hero .imgarea .img{
        width: 97vw;
        margin: 0 0 0 auto;
    }
  }

.section-hero .txt {
    position: relative;
    width: 75vw;
    margin: 3.5vw auto 0;
}
/* .section-hero .txt .local {
    background: #349436;
    color: #fff;
    padding: 0.1vw 1.2vw 0.3vw;
    border-radius: 2vw;
    font-size: 0.97vw;
    letter-spacing: 0.02em;
    font-weight: 700;
    margin: -1vw 0.5vw 1.5vw;
    display: block;
    width: fit-content;
} */
  
.section-hero .txt .main-title {
    font-size: 6.4vw;
    font-weight: 800;
    letter-spacing: 0.01em;
    line-height: 1.06;
    margin: 0 auto;
    color: #349436;
}
.section-hero .txt .main-title-sub {
    font-size: 1.6vw;
    font-weight: 800;
    letter-spacing: 0.1em;
    margin: 0;
    color: #349436;
}

section .img img {
  width: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
  object-position: 50% 20%;
} 
@media only screen and (max-width: 767px) {
  section .img {
      width: 90vw;
      margin: 0 auto;
  }

}


.section .headline__title {
  line-height: 1.2;
}

.section .headline__title {
  display: block;
  color: #349436;
  /* font-family: "Inter", sans-serif; */
  font-size: 2.2vw;
  font-weight: 800;
  /* padding-bottom: 1vw; */
  padding: 5.3vw 0 4.5vw;
  text-align: center;
}
  

  /* .section .section-content .headline{
    width: 110vw;
  } */
  /* .section .section-content .headline__title{
    font-size: 1.1vw;
    padding: 0.4vw 0 3.2vw;
  } */
  /* .section .headline__title span { */
    /* padding-bottom: 0.7vw; */
    /* font-weight: 700; */
  /* } */
  @media only screen and (max-width: 767px) {
    .section-hero .txt { width: 97vw; }
    .section-hero .txt .local {
        font-size: 3vw;
        padding: 0.3vw 2.7vw 1vw;
        border-radius: 4vw;
        margin: -3vw 2.5vw 1.5vw;
    }
    .section-hero .txt .main-title {
        font-size: 13vw;
        width: 93vw;
    }
    .section-hero .txt .main-title-sub {
        font-size: 4.3vw;
        margin: 0 2.2vw;
    }

  }
  .section .content {
    width: 61vw;
    margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .section .content {
    width: 90vw;
  }
}
  
  @media only screen and (max-width: 767px) {
    body{ font-size: 3.2vw; }
    p{ line-height: 2.0;}
   
    .section .section-content{ 
      max-width: 90vw;
      flex-wrap: wrap;
      padding : 15vw 0 0; 
    }
    .section .section-content .headline{
      width: 100%;
      padding: 0;
      position: relative;
      margin-bottom: 1.5vw;
    }
    .section .section-content .headline__title{
      font-size: 5.2vw;
      padding: 9vw 0 4vw;
      line-height: 1.4;
    }
    .section .headline__title span.en{
      font-size: 10vw;
      padding-bottom: 2vw;
      }
  
    .section-overview .section-content .txt-lt{
      width: 100%;
      padding-left: 5vw;
    }
    .section-overview .section-content.flex > .flex-box.text-box {
      width: 95%;
    }
    .section-overview .section-content.flex .text-content{
      padding: 29vw 0 23vw;
      width: 92vw;
      margin: 12vw -5vw 0 8vw;
    }
  }

  .section-attempt .section-content {
    padding: 2.5vw 3vw 2.5vw 0;
    text-align: center;
  }
  .section-attempt .headline__title {
    padding: 0 0 2.1vw;
    font-size: 2.4vw;
  }
  .section-attempt .section-content.flex {
    padding: 1vw 3vw 0 0;
    gap: 2.7vw;
    margin-bottom: 2.1vw;
    align-items: flex-start;
  }
  .section-attempt .section-content .img {
    padding: 0.5vw 0 2.6vw;
  }
  .section-content.flex h3 {
    font-size: 1.5vw;
    font-weight: 800;
    letter-spacing: 0.3em;
  }
  .section-content.flex .txt {
    padding: 1.4vw 3vw;
    text-align: left;
    line-height: 1.9;
  }
  .section-content.annotation {
    text-align: left;
    font-size: 91%;
    font-weight: 400;
    line-height: 1.7;
  }
  .section-content.annotation > div {
    padding: 1vw 2.8vw;
  }
  .section-content.annotation li {
    text-indent: -1vw;
    padding-left: 1vw;
  }
  .section-content.annotation a{
    text-decoration: underline;
    color: #1f7afa;
    text-underline-offset: 0.2em;
  }

  @media only screen and (min-width: 768px) {
    .section-attempt .section-content.flex >div {
    width: 50%;
  }
}
  @media only screen and (max-width: 767px) {
    .section-content.flex h3 {
      font-size: 4.2vw;
      letter-spacing: 0.1em;
  }
  .section-content.flex .txt {
    padding: 6.4vw 3vw 11vw;
  }
    .section-attempt .section-content .headline__title {
      font-size: 5.8vw;
    }
    .section-attempt .section-content{
      padding-bottom: 10vw;
    }
    .section-attempt .section-content .img {
      padding-bottom: 6.6vw;
    }

  }