*{
  margin:0;
  padding:0;
  box-sizing: border-box;
}

body{
  width:100%;
  background:#fafafa;
}

.wrapper {
  margin:0 auto;
  width: 100%;
  max-width: 600px;
  box-shadow:0 0 5px #eee;
  position: relative;
}

img {
  width:100%;
  vertical-align: middle;
}

.fv, .cta1, .cta2, .cta3, .cta4, .cta5, .cta6, .footer{
  position:relative;
}

.fv{
      /*margin-bottom: 21%;*/
}

.button{
  position: absolute;
}

.fv .button{
width: 100%;
bottom: -15%;
right: 0;
}

.cta1 .button{
  width:80%;
  bottom:0;
  right:10%;
}

.cta2 .button{
  width:80%;
  bottom:2.2%;
  right:10%;
}

.cta3 .button{
  width:80%;
  bottom:0;
  right:10%;
}

.cta4 .button{
  width:80%;
  bottom:3%;
  right:10%;
}

.cta5 .button{
  width:80%;
  bottom:1%;
  right:10%;
}

.cta6 .button{
  width:80%;
  bottom:-7%;
  right:10%;
  z-index:1;
}

.footer .button {
  width: 90%;
  bottom: 10%;
  right: 5%;
}

.banner {
  width: 82%;
  position: absolute;
  bottom: 19%;
  left: 9%;
}

.fixed_button { 
  position: relative;
  position: fixed;
  bottom: 10px;
  right: 10px;
  width: 170px;
  }

.round_btn {
    display: block;
    position: absolute;
    position: relative;
    right: 190px;
    bottom: 15px;
    width: 20px;
    height: 20px;
    border-radius: 50%;  /* 丸みの度合い */
    background: rgb(255, 53, 53); /* ボタンの背景色 */
  }
   
.round_btn::before, .round_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 3px;
    height: 16px;
    background: #fff; /* バツ印の色 */
  }
   
.round_btn::before {
    transform: translate(-50%,-50%) rotate(45deg);
  }
   
.round_btn::after {
    transform: translate(-50%,-50%) rotate(-45deg);
  }

.round_btn:hover { /* マウスオーバー時のスタイル */
    transform: rotate(360deg);
}

#close {
  display: none;
}

#close:checked + .fixed_button {
  display: none;
}

a{
  transition : .7s;
}
a:hover{
  opacity: .7;
transition : .7s;
}
.button{
  transition : .7s;
}
.button:hover{
  opacity: .7;
transition : .7s;
}

.cta-frame{
      position: relative;
    z-index: 2;
}
.button-link{
      bottom: 9%;
    position: absolute;
    z-index: 99;
    width: 75%;
    right: 0;
    left: 0;
    margin: 0 auto;
}

.footer-frame .button-link{
bottom: 27%;
}




.cvarea{
  padding: 40px 0;
  background: #fdf5f2;
}
@media screen and (max-width: 767px) {
.cvarea{
  padding: calc(40/750 * 100vw) 0;
}
}
.firstview-button{
  display: block;
  margin: 0 auto;
  width: 80%;
  height: 110px;
  background: #1e9b61;
  border-radius: 10px;
  position: relative;
  box-shadow: 0px 8px 0px 0px #0d7042;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
.firstview-button{
  height: calc(134/750 * 100vw);
  box-shadow: 0px calc(12/750 * 100vw) 0px 0px #0d7042;
}
}
.firstview-button:hover,
.firstview-button:active{
  box-shadow: none;
  margin-top: 8px;
  margin-bottom: -8px;
}
@media screen and (max-width: 767px) {
.firstview-button:hover,
.firstview-button:active{
  margin-top: calc(12/750 * 100vw);
  margin-bottom: calc(-10/750 * 100vw);
}
}
.firstview-button img{
  width: 96%;
  position: absolute;
  bottom: 1%;
    left: 1%;
}

.cv-button{
    display: block;
  margin: 0 auto;
  width: 80%;
  height: 110px;
  background: #1e9b61;
  border-radius: 10px;
  position: relative;
    box-shadow: 0px 8px 0px 0px #0d7042;
  transition: 0.2s;
}
.cv-button:hover,
.cv-button:active{
  box-shadow: none;
  margin-top: 8px;
  margin-bottom: -8px;
}

@media screen and (max-width: 767px) {
.cv-button{
  height: calc(134/750 * 100vw);
  box-shadow: 0px calc(12/750 * 100vw) 0px 0px #0d7042;
}
}
@media screen and (max-width: 767px) {
.cv-button:hover,
.cv-button:active{
  margin-top: calc(12/750 * 100vw);
  margin-bottom: calc(-10/750 * 100vw);
}
}

.cv-button img{
  width: 82%;
  position: absolute;
  top: 50%;
  transform: translate(0%, -50%);
    right: 4%;
}

.cta1{
  padding-bottom: 40px;
  background: #fff;
}

.button-link{
  position: absolute;
    width: 75%;
}

.floating{
  position: fixed;
  bottom: 0;
left: 50%;
transform: translate(-50%, 0%);
  width: 600px;
  background: rgba(255,255,255,0.8);
  padding: 20px 0;
  text-align: center;
  z-index: 100;
}

@media screen and (max-width: 767px) {
  .floating{
    width: 100%;
      padding: calc(24/750 * 100vw) 0;
  }
}

.footer-bottom{
  margin-bottom: 140px;
}

@media screen and (max-width: 767px) {
.footer-bottom{
  margin-bottom:24%;
  }
}