#modal {
  display:none;
  background-color:rgba(0,0,0,0.7);
  height:9999px;
  z-index:9999;
}

/* 画像の高さを調整してモーダル内に収める - 追加スタイル */
#ridatu-simulation-btn {
  max-height: 160px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}

#ridatu-simulation-shiba-btn {
  max-height: 220px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}

/* スマホでの画像高さ調整 - 追加スタイル */
@media only screen and (max-width: 768px) {
  #ridatu-simulation-btn {
    max-height: 120px !important;
  }
  
  #ridatu-simulation-shiba-btn {
    max-height: 170px !important;
  }
}

/* より小さい画面での画像高さ調整 - 追加スタイル */
@media only screen and (max-width: 380px) {
  #ridatu-simulation-btn {
    max-height: 100px !important;
  }
  
  #ridatu-simulation-shiba-btn {
    max-height: 140px !important;
  }
}
.modal {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
}
.modal .box {
  overflow-y: auto;
  position:fixed;
  border:5px solid #158530;
  width:600px;
  margin:auto;
  background-color:rgba(255,255,255,1);
  text-align: center;
  height:85%;
  max-height:750px;
  top:50%;
  left:50%;
  padding:50px 5px 0;
  transform: translate(-50%, -50%);
}

.modal .box p{
  font-size:18px;
}
.modal .box .p1 {
  margin-top:0rem;
}
.modal .box .p2 {
  margin-top:1rem;
}
.modal .box button{
  font-size:22px;
}

#modal .batsu{
    position:absolute;
    top:0;
    right:1%;
    font-size: 35px;
    font-weight: bold;
    color:gray
}
#modal .btn-area {
    display:block;
    margin:0 auto 0;
}
#modal p {
    font-family: "M PLUS 1p";
    font-size:16px;
    font-weight: 700;
    color:#158530;
}
#modal .btn-area .up-area div {
  height:100%;
  margin: 0 auto 10px;
  width: 32.5%;
  text-align: center;
  position: relative;
}
/* クリック */
#modal .btn-area .up-area div.arrow_box {
    position: relative;
    background: #d50b11;
    border: 4px solid #fff;
    width: 280px;
    padding: 10px 20px;
    color: #fff;
    font-size: 16px;
    left: -97%;
    transform: rotate(352deg);
    font-weight: bold;
    top: 35px;
}
#modal .arrow_box:after, .arrow_box:before {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: "";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
}

#modal .arrow_box:after {
    border-color: rgba(213, 11, 17, 0);
    border-top-color: #d50b11;
    border-width: 30px 1px 10px 18px;
    margin-left: -150px;
}
#modal .arrow_box:before {
    border-color: rgba(230, 245, 225, 0);
    border-top-color: #fff;
    border-width: 36px 4px 16px 24px;
    margin-left: -145px;
}

#modal .btn-area .up-area img {
  width:75%;
  max-width:600px;
  margin-top:40px;
}
#modal .btn-area .down-area div {
  display:block;
  text-align:center;
}
#modal .btn-area .down-area div .escape{
  margin: 0px auto;
  background-color: gray;
  padding: 10px 20px;
  width: 260px;
  margin-top:3rem;
}
#modal .btn-area .down-area div #back-top{
  margin-top:2rem;
  margin-bottom:2rem;
}
#modal .btn-area .down-area div .escape p{
  font-size:18px;
  color:#fff;
  font-weight: 700;
}
#modal .btn-area p{
    margin:initial;
    background:initial;
    font-size:16px;
    width: 90%;
    margin:10px 18px;
    text-align: center;
}

#modal .btn-area div.price a ,
#modal .btn-area div.contact a {
  font-size:18px;
  text-decoration: none;
  font-family: "M PLUS 1p";
  font-weight: 700;
}

#modal .btn-area div a {
  padding: 25px 10px;
  display:block;
  /* スペシャルクーポン width:385px; */
  font-size:18px;
  text-decoration: none;
  font-weight: bold;
  padding: 25px 10px;
  margin:auto;
  height:100%;
}

#modal .btn-area div a span {
  transform: scale(0.65, 1);
  -webkit-transform: scale(0.65, 1);
  -o-transform: scale(0.65, 1);
  -moz-transform: scale(0.65, 1);
 }


#modal .btn-area div a span,
#modal .btn-area div a span {
  transform: scale(1, 1);
  -webkit-transform: scale(1, 1);
}

#modal .btn-area div.price a{
  background-color:#00b900;
  color:#fff;
}

#modal .btn-area div.contact a{
  background-color: #158530;
  color:#fff;
}

#modal .btn-area div.price a:after{
  content: '';
  color:#fff;
  background: url(../common_img/simulation-icon.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  top: 50%;
  width: 40px;
  height: 40px;
  left: 11%;
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
}

#modal .btn-area div.contact a:after{
content: '';
color: #fff;
background-color: #158530!important;
background: url(../price/images/document.png);
background-repeat: no-repeat;
background-position: center;
background-size: 100% auto;
position: absolute;
top: 50%;
width: 40px;
height: 32px;
left: 11%;
-ms-transform: translate(0, -50%);
transform: translate(0, -50%);
-webkit-transform: translate(0, -50%);
}

/* common */
br.sp-br {
  display: none;
}

/* スマホレイアウト */
@media (max-width: 767px) {
  br.sp-br {
      display: block;
  }
  .disp-pc {
      display: none;
  }
}

/* ▽ PC-TAB layout ========== */
@media only screen and (max-width: 885px) {
  .modal .box {
    height:70%;
    transform: translate(-50%, -50%);
  }
}
@media print, screen and (min-width: 768px) {
    #modal .btn-area p:before {
      pointer-events:initial;
      position:initial;
      z-index:initial;
      content:initial;
      top:initial;
      left:initial;
      height:initial;
      width:initial;
      opacity:initial;
      background:initial;
      transition-duration:initial;
      transition-property:initial;
    }
 }

@media only screen and (max-width: 768px) {
  .modal .box {
    width:calc(100% - 20px);
    /* スペシャルクーポン　height:78vh;*/
    height:70vh;
    position:fixed;
    margin:auto;
    top:50%;
    left:50%;
    padding:50px 5px 0;
    transform: translate(-50%, -50%);
  }
  #modal p{
    font-size:13px;
	  text-align: center;
  }
  #modal .box button{
    font-size:14px;
  }
  #modal .btn-area .up-area div.arrow_box {
    font-size:14px;
  }
  #modal .btn-area .up-area img {
    width:90%;
  }

  #modal .box .btn-area{
   	margin:0;
  }
  #modal .btn-area .up-area div {
	display:block;
	width:100%;
  }
  #modal .btn-area {
    display: block;
    margin-bottom: 20vw;
  }
  #modal .btn-area .up-area img {
    margin-top:3rem;
  }

  #modal .btn-area .up-area div.arrow_box {
    margin-top:-15px;
    left:-12%;
    width:250px;
    transform: rotate(357deg);
  }
  #modal .arrow_box:after {
      border-width: 22px 4px 5px 18px;
      margin-left: -115px;
  }
  #modal .arrow_box:before {
      border-width: 26px 7px 11px 24px;
      margin-left: -120px;
  }

  #modal .btn-area .up-area div .price a ,
  #modal .btn-area .up-area div .contact a,
  #modal .btn-area .down-area div .escape {
    margin:initial;
    margin:auto;
    font-size:14px;
  }
  #modal .btn-area .up-area div .price,
  #modal .btn-area .up-area div .contact,
  #modal .btn-area .down-area div .escape {
	  margin-top:10px;
  }
  #modal .btn-area .down-area div .escape {
    margin-top:30px;
	  padding:10px 0;
    width:80%;
  }
  #modal .btn-area .down-area div .escape p{
    font-size:14px;
    width:auto;
	  margin:5px 0;
  }
  #modal .btn-area div a {
    padding:25px 0;
    width:100%;
    margin-top:-35px;
  }
  .modal .box .p1 {
    margin-top:0rem;
  }
  @media only screen and (max-width: 380px) {
    #modal p{
      font-size:12px;
	    text-align: center;
    }
    #modal .box button{
      font-size:14px;
    }
    #modal .btn-area .up-area div.arrow_box {
      font-size:14px;
    }
    #modal .btn-area .down-area div .escape {
      padding:5px;
    }
    #modal .btn-area .up-area div.arrow_box {
        left: -7%;
        width: 250px;
        transform: rotate(357deg);
        margin-top:-20px;
    }
    #modal .btn-area .up-area img {
        margin-top: 4rem;
    }
    #modal .btn-area .down-area div .escape p{
      font-size:14px;
      width:auto;
	    margin-top:5px;
      margin-bottom:0;
    }
  }

}
