@font-face {
  font-family: 'Altedin1451';
  src: url('./font/din1451.woff') format('woff'),url('./font/din1451.ttf') format('truetype');
}
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap');

html{
  scroll-behavior: smooth;
}
.site_logo{
  width: 160px;
}
.ff_01{
  font-family: 'Altedin1451', sans-serif;
}
.fc_01{
  color: #ff4d07;
}
.fc_02{
  color: #ff9b14;
}
.number{
  position: absolute;
  display: inline;
  font-family: 'Altedin1451', sans-serif;
  font-size: 2.4em;
  line-height: 1;
  color: #fff;
  padding: 15px 20px;
  border-radius: 0 25px 25px 0;
  background: linear-gradient(90deg,#ff6021,#ff9b14);
}
.arrow_down{
  display: block;
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #ff6021;
}
.to_top{
  position: fixed;
  bottom: 30px;
  right: 60px;
  width: 60px;
  height: 60px;
  opacity: 0;
  transition: 0.3s;
}
.to_top.show{
  opacity: 1;
}
@media (max-width: 768px) {
  .pc{
    display: none !important;
  }
}
@media (min-width: 769px){
  a[href^="tel:"]{
    pointer-events: none;
  }
  .sp{
    display: none !important;
  }
}
@media (max-width: 580px) {
  .site_logo{
    width: 83px;
  }
  .number{
    font-size: 1.8em;
    padding: 10px 15px 10px 10px;
  }
  .to_top{
    width: 35px;
    height: 35px;
    right: 20px;
  }
}


/* ボタン類 */
.btn_01{
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  border-radius: 50vw;
  width: 90%;
  max-width: 360px;
  height: 60px;
  font-size: 1.8em;
  background: linear-gradient(90deg,#ff6021,#ff9b14);
  box-shadow: 1px 1px 7px rgba(0, 0, 0, 0.2);
}
.btn_01::before{
  content: "";
  display: inline-block;
  background-image: url(./img/common/icon_05_l.png);
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: sub;
  width: 30px;
  height: 30px;
  margin-right: 15px;
}
@media (max-width: 580px) {
  .btn_01{
    width: 80%;
    font-size: 1.5em;
    height: 50px;
  }
  .btn_01::before{
    width: 18px;
    height: 18px;
    margin-right: 10px;
  }
}


.btn_02{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  color: #ff4d07;
  background: #fff;
  border: 2px solid #ff4d07;
  border-radius: 50vw;
  width: 90%;
  max-width: 360px;
  height: 60px;
  font-size: 1.8em;
}
.btn_02::after{
  content: "";
  background: url() no-repeat;
  background-size: contain;
  position: absolute;
  width: 10px;
  height: 10px;
  border-top: 2px solid #ff4d07;
  border-right: 2px solid #ff4d07;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  right: 8%;
}
@media (max-width: 580px) {
  .btn_02{
    font-size: 1.5em;
    width: 80%;
    height: 50px;
  }
  .btn_02::after{
    width: 8px;
    height: 8px;
    right: 5%;
  }
}


.btn_03{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  color: #fff;
  background: transparent;
  border: 2px solid #fff;
  border-radius: 50vw;
  width: 100%;
  max-width: 400px;
  height: 80px;
  font-size: 1.8em;
}
.btn_03::before{
  content: "";
  display: inline-block;
  background-image: url(./img/common/icon_05_l.png);
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: sub;
  width: 30px;
  height: 30px;
  margin-right: 15px;
}
.btn_03.btn_rd:hover{
  background: #ff4d07;
  opacity: 1;
}
.btn_03.btn_og:hover{
  background: #ff9b14;
  opacity: 1;
}
@media (max-width: 580px) {
  .btn_03{
    width: 80%;
    font-size: 1.5em;
    height: 50px;
  }
  .btn_03::before{
    width: 18px;
    height: 18px;
    margin-right: 10px;
  }
  .btn_03.btn_rd{
    background: #ff4d07;
  }
  .btn_03.btn_og{
    background: #ff9b14;
  }
}


/* 見出し */
.head_txt_01{
  text-align: center;
  font-size: 42px;
  font-weight: 700;
  margin-bottom: 70px;
}
.head_txt_01 img{
  vertical-align: baseline;
  margin-right: 5px;
}
@media (max-width: 580px) {
  .head_txt_01{
    font-size: 21px;
    margin-bottom: 30px;
  }
  .head_txt_01 img{
    width: 83px;
  }
}

/* ----- about PAGE ----- */
section#problem_area img {
  border-radius: 15px;
}

/* ----- FAQ SECTION ----- */
.faq{
  width: 95%;
  max-width: 1200px;
  margin: 0 auto 70px;
}
.faq > div{
  padding: 30px;
  border-bottom: 1px solid #efefef;
}
.faq > div:nth-of-type(1){
}
.faq > div:last-of-type{
  margin-bottom: 70px;
}
.faq_q{
  display: flex;
  align-items: center;
  cursor: pointer;
  margin-bottom: 20px;
}
.faq_q p{
  position: relative;
  width: 100%;
  font-size: 2em;
  font-weight: 700;
  padding-right: 30px;
}
.icon_q{
  display: block;
  background: url(./img/common/icon_q.png) no-repeat;
  background-size: contain;
  width: 50px;
  height: 50px;
  margin-right: 30px;
}
.icon_a{
  display: block;
  background: url(./img/common/icon_a.png) no-repeat;
  background-size: contain;
  width: 50px;
  height: 50px;
  margin-right: 30px;
}
.faq_q p::after{
  content: "";
  width: 27px;
  height: 27px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  background-size: contain;
  background-repeat: no-repeat;
  transition: 0.3s;
}
.faq_q p::after{
  background-image: url(./img/common/faq_open.png);
}
.faq_q.open p::after{
  background-image: url(./img/common/faq_close.png);
}
.faq_a{
  display: none;
}
.faq_a.open{
  display: block;
}
.faq_a_inner{
  display: flex;
  align-items: center;
}
.faq_a_inner p{
  position: relative;
  width: 100%;
  font-size: 1.8em;
  padding-right: 30px;
}
@media (max-width: 580px){
  .faq{
    margin: 0 auto 30px;
  }
  .faq > div{
    padding: 15px;
  }
  .faq > div:last-of-type{
    margin-bottom: 30px;
  }
  .icon_q{
    width: 25px;
    height: 25px;
    margin-right: 15px;
    flex-shrink: 0;
  }
  .icon_a{
    width: 25px;
    height: 25px;
    margin-right: 15px;
    flex-shrink: 0;
  }
  .faq_q p{
    font-size: 1.5em;
    padding-right: 20px;
  }
  .faq_q p::after{
    width: 15px;
    height: 15px;
  }
  .faq_a_inner{
    align-items: flex-start;
  }
  .faq_a_inner p{
    font-size: 1.2em;
    padding-right: 20px;
  }
}
@media (max-width: 320px){
  .faq .btn_02{
    font-size: 1.3em;
  }
}

