*{
  margin: 0;
}
html{
  scroll-behavior: smooth;
  font-size: 15px;
}
@media (min-width:768px) and (max-width:1499px) {
  html{
    font-size: 1vw;
  }
}
@media (max-width:767px) {
  html{
    font-size: 2vw;
  }
}
a{
  transition: 300ms;
}
a:hover{
  opacity: 0.7;
}
.sans{
  font-family: 'Noto Sans JP', sans-serif;
}
.serif{
  font-family: 'Noto Serif JP', serif;
}
section{
  position: relative;
}
.container{
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}
.inner{
  width: 70%;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.orange_h2 {
  font-size: 3.4rem;
  line-height: 1.2;
  font-weight: normal;
  color: #F7931E;
  text-align: center;
  padding-top: 1.5em;
  padding-bottom: 2.7em;
}
.orange_h2::after {
  content: "～";
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: 8.7rem;
  font-size: 70%;
}
.blue_h3 {
  font-size: 2.7rem;
  line-height: 1.2;
  font-weight: normal;
  color: #29ABE2;
  padding-top: 2.5em;
  padding-bottom: 2em;
}
.blue_h3 span {
  font-size: 140%;
  font-weight: bold;
  position: relative;
  margin-right: 0.6em;
}
.blue_h3 span::after {
  content: "～";
  font-weight: normal;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: 4rem;
  font-size: 60%;
}
.text{
  font-size: 1.65rem;
  line-height: 1.8;
}
.graph_title{
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
  padding-bottom: 1.5em;
}
.graph_caution{
  font-size: 0.7rem;
  line-height: 1.2;
  padding-top: 4rem;
  display: inline-block;
  width: 45%;
  margin-left: 55%;
}



.top_bg_img{
  display: block;
  width: 100%;
}
#top_wrapper h1{
  font-size: 3.4rem;
  line-height: 1.2;
  letter-spacing: 0.1em;
  font-weight: normal;
  color: white;
  text-shadow: 0.1em 0.1em 0.1em #222;
  position: absolute;
  width: 70%;
  left: 15%;
  top: 12%
}
#top_wrapper h5{
  font-size: 1.9rem;
  line-height: 1.2;
  letter-spacing: 0.1em;
  font-weight: normal;
  color: white;
  text-shadow: 0.1em 0.1em 0.1em #222;
  position: absolute;
  width: 70%;
  left: 15%;
  top: 30%;
}
#top_wrapper p{
  font-size: 1.74rem;
  line-height: 1.7;
  font-weight: 100;
  color: white;
  text-shadow: 0.1em 0.1em 0.1em #222;
  position: absolute;
  width: 70%;
  left: 15%;
  top: 43%;
}



.side_bg_l_area{
  position: absolute;
  width: 4%;
  left: 0;
  bottom: 0;
  top: 30rem;
  background-image: url('imgs/side_bg_l.png');
  background-size: contain;
  background-repeat: repeat-y;
}
.side_bg_r_area{
  position: absolute;
  width: 4%;
  right: 0;
  bottom: 0;
  top: 30rem;
  background-image: url('imgs/side_bg_r.png');
  background-size: contain;
  background-repeat: repeat-y;
}



#profile_wrapper {
  padding-bottom: 5rem;
}
.profile_geo_img{
  position: absolute;
  width: 100%;
  left: 0;
  top: 13rem;
}
.profile_img{
  display: inline-block;
  vertical-align: bottom;
  width: 45%;
  margin-right: 5%;
}
.profile_right{
  display: inline-block;
  vertical-align: bottom;
  width: 50%;
}
.profile_right h5{
  font-size: 2.1rem;
  line-height: 1.7;
  font-weight: normal;
  padding-bottom: 0.8em;
}
.profile_right p{
  font-size: 1.65rem;
  line-height: 1.6;
}



.contents_geo_img{
  position: absolute;
  width: 18.55%;
  left: 10%;
  top: 12rem;
}
.contents_geo2_img{
  position: absolute;
  width: 18.55%;
  left: 80%;
  top: 38rem;
}
.contents {
  width: 52%;
  margin-left: 24%;
}
.contents a{
  font-size: 1.8rem;
  line-height: 2.1;
  display: inline-block;
  color: black;
  text-decoration: none;
}



.c01_geo_img{
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 17rem;
}
.c01_img{
  display: block;
  width: 50%;
  margin: 0 auto;
  padding-top: 3rem;
  padding-bottom: 6rem;
}
.c02_geo_img{
  position: absolute;
  width: 15.75%;
  right: 3%;
  bottom: -11rem;
}
.c06_geo_img{
  position: absolute;
  width: 100%;
  left: 1%;
  top: 1rem;
}
.circle_graph_area{
  padding-top: 8rem;
}
.circle_graph{
  display: inline-block;
  vertical-align: top;
  width: 80%;
  text-align: center;
}
.circle_graph_img{
  display: inline-block;
  width: 90%;
}
.c04_geo01_img{
  position: absolute;
  width: 88.35%;
  right: 0;
  top: 56.4rem;
}
.c04_geo02_img{
  position: absolute;
  width: 28.1%;
  left: 0;
  bottom: 30rem;
}
.c04_geo03_img{
  position: absolute;
  width: 18.6%;
  right: 1%;
  bottom: -7rem;
}
.c04_01_img{
  display: block;
  width: 56.3%;
  margin: 0 auto;
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.c04_02_img{
  display: inline-block;
  vertical-align: top;
  width: 48.6%;
  margin-right: 2.8%;
  padding-top: 14rem;
}
.c04_03_img{
  display: inline-block;
  vertical-align: top;
  width: 48.6%;
  padding-top: 8rem;
}
.c05_geo_img{
  position: absolute;
  width: 20.5%;
  left: 0;
  top: 40rem;
}
.line_graph_area{
  padding-top: 5rem;
  padding-bottom: 6rem;
}
.line_graph_img{
  display: block;
  width: 80%;
  margin: 0 auto;
}
.btn_area{
  text-align: center;
  padding-top: 6rem;
  padding-bottom: 5rem;
}
.btn{
  display: inline-block;
  width: 64.3%;
}
.btn img{
  display: block;
  width: 100%;
}
#bottom_wrapper {
  padding-bottom: 6rem;
}
.bottom_geo_img{
  position: absolute;
  width: 36.7%;
  right: 0;
  top: -1rem;
}
#bottom_wrapper .orange_h2 {
  padding-bottom: 1.7em;
}
.btn1_area{
  position: absolute;
  left: 30rem;  
  }


.btn1{
  display: inline-block;
  width: 90%;
}
.btn1 img{
  display: block;
  width: 100%;
}
.c02_img{
  display: block;
  width: 40%;
  margin: 0 auto;
  padding-top: 3rem;
  padding-bottom: 6rem;
}
.c03_img{
  display: block;
  width: 100%;
  margin: 0 auto;
  padding-top: 3rem;
  padding-bottom: 6rem;
}
.c04_img{
  display: block;
  width: 90%;
  margin: 0 auto;
  padding-top: 3rem;
  padding-bottom: 6rem;
}
.c05_img{
  display: block;
  width: 40%;
  margin: 0 auto;
  padding-top: 3rem;
  padding-bottom: 6rem;
}


.sp_only{
  display: none !important;
}
@media (max-width:767px) {
  .sp_only{
    display: block !important;
  }
  .inner {
    width: 80%;
  }
  .orange_h2 {
    padding-bottom: 1.5em;
  }
  .blue_h3 {
    text-indent: -2.5em;
    padding-left: 2.5em;
    padding-bottom: 1.5em;
  }
  .blue_h3 span::after {
    text-indent: 0;
  }
  .graph_caution {
    width: 70%;
    margin-left: 30%;
  }
  .top_bg_img {
    width: 320%;
    margin-left: -33vw;
  }
  #top_wrapper h1 {
    width: 80%;
    left: 10%;
    top: 8%;
  }
  #top_wrapper h5 {
    width: 80%;
    left: 10%;
    top: 28%;
  }
  #top_wrapper p {
    width: 80%;
    left: 10%;
    top: 41%;
  }
  .profile_geo_img {
   top: 1rem;
  }
  .profile_img {
    position: absolute;
    width: 90%;
    left: 5%;
    top:34%;
  }
  .profile_right{
    width: 100%;
  }
  .profile_right h5 {
    padding-bottom: 17em;
  }
  .contents {
    width: 90%;
    margin-left: 5%;
  }
  .contents_geo_img {
    top: 7rem;
  }
  .contents_geo2_img {
    top: 30rem;
  }
  .c01_img {
    width: 70%;
  }
  .c01_geo_img {
    bottom: -1rem;
  }
  

  .c02_geo_img {
    width:90%;
    bottom: -3rem;
  }
  .c06_geo_img {
    top: 1rem;
  }
  .circle_graph_img {
    width: 85%;
  }
  .c04_geo01_img {
    width: 95%;
    top: 75rem;
  }
  .c04_geo02_img {
    bottom: 21rem;
  }
  .c04_geo03_img {
    bottom: -3rem;
  }
  .c04_01_img {
    width: 80%;
  }
  .c04_02_img{
    padding-top: 10rem;
  }
  .c04_03_img{
    padding-top: 5rem;
  }
  .c05_geo_img {
    top: 56rem;
  }
  .line_graph_img {
    width: 80%;
  }
  .btn {
    width: 90%;
  }
  .bottom_geo_img {
    top: 6rem;
  }
  .btn1 {
    width: 85%;
  }
  .btn1_area{
    position: absolute;
    left: 10rem;  
    }
}
