@charset "UTF-8";

*, *::before, *::after {
  box-sizing: border-box; 
}
html {
	margin: 0;
	padding: 0;
	font-size: 100%;
  overflow-x: hidden;

  scroll-behavior: smooth;
}
body {
	margin: 0;
	padding: 0;
  width: 100%;
  background-color: #67a7df0f;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size:18px;
  line-height: 1.6;
}
a{
  color: #000;
  text-decoration: none;
}
a:hover{
  opacity: 0.7;
  transition: 0.2s;
}
.only-pc{
  display: block;
}
.only-sp{
  display: none;
}
.only-sp-logo {
  display: none;
}
.only-sp-footer {
  display: none;
}
.only-pc-plan {
  display: block;
}
.only-sp-plan {
  display: none;
}
.only-sp1000{
  display: none;
}
.only-sp900{
  display: none !important;
}
.only-sp500 {
  display: none;
}
.inner-wrop{
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}
h2{
  font-size: 40px;
  font-weight: bold;
  color: #0272b0;
  text-align: center;
  margin: 0 auto;
  padding: 100px 0 60px 0;
  position: relative;
  z-index: 2;
}
h3{
  font-size: 28px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  margin: 0;
}
.small {
  font-size: 16px;
}
.regular {
  font-size: 18px;
}
.big {
  font-size: 30px;
  font-weight: bold;
  font-family: 'Trebuchet MS','DIN Alternate','DIN Alternate',sans-serif;
  white-space: nowrap;
}
.big-red {
  font-size: 30px;
  color: #f90404;
  font-weight: bold;
  font-family: 'Trebuchet MS','DIN Alternate','DIN Alternate',sans-serif;
  white-space: nowrap;
}
.red {
  color: #f90404;
  font-weight: bold;
}
.green {
  color: #2c4f54;
}
.inner{
	max-width: 1280px;
  width: 100%;
	margin: 0 auto;
  padding: 10px;
}

/* ここからヘッダー */
.top{
  background-image: url(../img/MV.webp);
  position: relative;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  height: 100vh;
}
.top-list{
  position: fixed;        
  top: 0;
  left: 0;
  width: 100%;            
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 40px;     
  background: rgba(255, 255, 255, 0); 
  transition: background 0.3s ease, box-shadow 0.3s ease; 
  z-index: 1000;          
}

.top-list.is-scrolled {
  background: rgba(255, 255, 255, 0.5);
  box-shadow: 0 2px 10px rgba(0,0,0,0.05); 
}
.top-logo {
  max-width: 175px;
  width: 100%;
}
.top-logo img {
  width: 100%;
}
.top-menulist ul{
  text-decoration: none;
  list-style-type: none;
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0;
}
.btn-contact {
  max-width: 100px;
  margin: 0 15px;
}
.btn-contact img {
  width: 100%;
}

.top-icon{
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 500px;
}
.top-icon img{
  width: 100%;
}
.hero-txt{
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #2ea7b2;
  padding: 20px;
  text-align: center;
  color: #fff;
  font-size: 26px;
  letter-spacing: 2px;
}
.hero-txt span{
  border-bottom: solid 7px #f0e22180;
}

/* ここからトップの注意事項 */
.cyuui p{
  padding: 20px 30px;
}

/* お試しキャンペーン対象ホーム */
.home{
    background-image: linear-gradient(90deg, #6ac5f0, #6794e7);
    padding: 20px 30px 100px 30px;
    position: relative;
}
.home h2{
    color: #fff;
    z-index: 2;
    position: relative;
}
.home-item{
  display: flex;
  justify-content: center;
  z-index: 2;
  position: relative;
  padding-left: 0;
}
.home-item li{
  max-width: 450px !important;
  list-style-type: none;
  background: #fff;
  border-radius: 20px;
  margin: 20px;
}
.home-img img{
  width: 100%;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}
.home-txt{
  padding: 30px;
  text-align: center;
}
.home-txt h3{
  color: #000;
}
.home-txt .home-price > p{
  margin-bottom: 0;
  margin-top: 20px;
}
.home-txt .home-price .price-wrap{
  display: flex;
  justify-content: center;
  align-items: center;
}
.home-txt p{
  margin-top: 10px;
  margin-bottom: 10px;
}
.home-txt .txt-arrow{
  max-width: 35px;
  margin: 10px;
}
.home-txt .txt-arrow img{
  width: 100%;
}
.home-txt .txt-bg{
  font-size: 24px;
  font-weight: bold;
}
.home-txt .empha{
  font-size: 30px;
  color: #c32142;
}
.home-txt .txt-bg span{
  font-size: 20px;
}
.home-contact{
  display: flex;
  justify-content: center;
}
.home-contact a{
  background: #ffc000;
  margin: 10px;
  padding: 15px 30px;
  display: block;
  border-radius: 5px;
}
.home-contact .visit a{
  background: #0272b0;
  color: #fff;
}
.hanabi{
  position: absolute;
  top: 3%;
  left: 0;
  max-width: 400px;
}
.hanabi img{
  width: 100%;
}

/* ここからこんなことでお困りではないですか？ */
.komarigoto-item{
  display: flex;
  margin: 0;
  padding-left: 0;
}
.komarigoto-item li{
  list-style-type: none;
  margin: 20px;
}
.komarigoto-item .komarigoto-item-wrap{
  display: flex;
  background: #237dd3;
  border-radius: 20px;
  max-width: 500px;
  width: 100%;
}
.komarigoto-item .komarigoto-txt{
  padding: 30px;
  color: #fff;
  font-size: 26px;
  font-weight: bold;
}
.komarigoto-item .komarigoto-txt span{
  color: #ffc000;
}
.komarigoto-item .komarigoto-img{
  max-width: 100px;
  display: flex;
  align-items: end;
}
.komarigoto-item .komarigoto-img img{
  width: 100%;
}
.komarigoto-item .komarigoto-item-hukidash{
  max-width: 50px;
  margin-left: 100px;
}
.komarigoto-item .komarigoto-item-hukidash img{
  width: 100%;
}

.komarigoto-solution{
  font-size: 40px;
  font-weight: bold;
  text-align: center;
  margin: 0 auto;
  padding: 60px 0 100px 0;
  position: relative;
  z-index: 2;
}
.komarigoto-solution .komarigoto-orange{
  display: inline-block;
  font-size: 48px;
  color: #db751c; 
  animation: solutionImpactSingle 1.2s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

@keyframes solutionImpactSingle {
  0% {
    transform: scale(0.5);
    opacity: 0;
    background-position: 0% center;
  }
  100% {
    transform: scale(1.15);
    opacity: 1;
    background-position: 100% center;
  }
}

/* 当プランの魅力 */
.miryoku{
  background: #51a7e3;
}
.miryoku h2{
  color: #fff;
  padding-top: 0 !important;
}
.miryoku-item li{
  list-style-type: none;
  background: #fff;
  padding: 30px;
  position: relative;
  border-radius: 20px;
  margin: 20px;
}
.miryoku-item{
  padding-left: 0;
}
.miryoku-item-wrap{
  display: flex;
  margin-top: 70px;
}
.miryoku-item-wrap li{
  width: calc(100% / 2);
}
.miryoku-point{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #dc5504;
  padding: 0 50px;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  border-radius: 10px;
  width: 65%;
  text-align: center
}
.miryoku-txt{
  padding: 30px;
  text-align: center;
}
.miryoku-txt h3{
  color: #dc5504;
  margin: 20px 0 15px;
}
.miryoku-img{
  max-width: 500px;
  margin: 0 auto;
}
.miryoku-img img{
  width: 100%;
}
.miryoku-txt p{
  font-size: 22px;
  text-align: left;
}
.miryoku-txt-wrap{
  display: flex;
  align-items: center;
  margin-top: 0;
}
.miryoku-txt-wrap .miryoku-img{
  padding: 30px;
}
.miryoku-price .miryoku-price-item .price {
  position: relative;
}
.miryoku-price .miryoku-price-item .price::before,
.miryoku-price .miryoku-price-item .price::after {
  position: absolute;
  content: "";
  display: block;
  background-color: #000;
  width: 100%;
  height: 2px;
  left: 0;
}
/* 上側の線 */
.miryoku-price .miryoku-price-item .price::before {
  top: 40%;
}
/* 下側の線 */
.miryoku-price .miryoku-price-item .price::after {
  top: 60%;
}
.point2 .miryoku-point{
  /* background: #0272aa; */
  width: 85%;
}
.point2 h3{
  color: #0272aa;
}
.point3 .miryoku-point{
  /* background: #6fac2c; */
  width: 85%;
}
.point3 h3{
  color: #6fac2c;
  text-align: left;
}
.point-first{
  margin-top: 50px;
}
.point-first h3{
  color: #dc5504;
}
.point-second h3{
  color: #0272aa;
}
.point-third{
  margin-bottom: 60px;
}
.miryoku-item .miryoku-campaign{
  margin-top: 90px;
  margin-bottom: 100px;
  background: #ffffd6;
}
.miryoku-txt .ribbon1 {
  display: inline-block;
  position: relative;
  line-height: 50px;
  text-align: center;
  padding: 10px 30px;
  background: #ffc000;
  color: #000;
  box-sizing: border-box;
  width: 100%;
}
.miryoku-txt .ribbon1:before, .miryoku-txt .ribbon1:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}
.miryoku-txt .ribbon1:before {
  top: 0;
  left: 0;
  border-width: 35px 0px 35px 20px;
  border-color: transparent transparent transparent #ffffd6;
  border-style: solid;
}
.miryoku-txt .ribbon1:after {
  top: 0;
  right: 0;
  border-width: 35px 20px 35px 0px;
  border-color: transparent #ffffd6 transparent transparent;
  border-style: solid;
}
.miryoku-campaign-wrap{
  display: flex;
  align-items: center;
  justify-content: center;
}
.miryoku-campaign-wrap > div{
  margin: 20px;
}
.miryoku-campaign-wrap .miryoku-img{
  max-width: 320px;
}
.miryoku-campaign-wrap .miryoku-price-item{
  width: 100%;
}
.miryoku-campaign-wrap .miryoku-price{
  background: #fff;
  max-width: 600px;
  width: 100%;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
  padding-bottom: 10px;
}
.miryoku-price .miryoku-price-ttl{
  background: #4d4d4d;
  text-align: center;
  color: #fff;
  margin-top: 0;
  font-size: 26px;
}
.miryoku-price .miryoku-price-item{
  display: flex;
  justify-content: center;
}
.miryoku-price .miryoku-price-item p{
  margin: 0;
}
.miryoku-price .miryoku-price-item .price{
  font-size: 50px;
  font-weight: bold;
  position: relative;
}
.miryoku-price .miryoku-price-item .price::before,
.miryoku-price .miryoku-price-item .price::after {
  position: absolute;
  content: "";
  display: block;
  transform: rotate(0);
  background-color: #000;
  width: 100%;
  height: 2px;
  left: 0;
}
.miryoku-price .miryoku-price-item span{
  font-size: 20px;
}
.miryoku-price .miryoku-price-item .term{
  margin-right: 20px;
}
.miryoku-price .miryoku-price-item .yen{
  padding-left: 5px;
}
.miryoku-price .miryoku-price-detail{
  font-size: 18px;
  text-align: center;
}
.miryoku-arrow{
  max-width: 50px;
  margin: 10px auto;
}
.miryoku-arrow img{
  width: 100%;
}
.miryoku-price .campaign_ttl{
  background: #c32142;
}
.miryoku-price .miryoku-price-item .campaign_price{
  font-size: 60px;
  font-weight: bold;
  color: #c32142;
}
.miryoku-price-detail span{
  color: #c32142;
}
.miryoku-campaign-cyuui{
  background: #ffc0002e;
  border-radius: 20px;
  padding: 30px;
  font-size: 20px;
  text-align: left;
  margin-top: 30px;
}
.miryoku-campaign-cyuui a{
  color: #c42143;
}
.price-otoku{
  position: relative;
}
.otoku{
  position: absolute;
  top: -20%;
  right: -10%;
  max-width: 150px;
}
.otoku img{
  width: 100%;
}

/* ここからご利用者の声 */
.voice-top {
  background-image: url(../img/user-bk.webp);
  width: 100%;
  min-height: 100vh;
  position: relative;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center top;
}
.voice-box {
  background-color: #ffffff80;
  max-width: 500px;
  width: 100%;
  position: absolute;
  left: 32%;
  top: 50%;
  border-radius: 30px;
  display: block;
  transform: translate(-50%, -50%);
}
.voice-title {
  text-align: left;
  padding: 3px 40px 0 40px;
  color: #0272b0;
}
.voice-title p {
  font-size: 32px;
}
.voice {
  text-align: left;
  padding: 0 40px 30px 40px;
}

/* ここから対象ホーム */
.planbox{
	padding: 50px 0;
  background-color: #f7e9b8;
}
.plan-box {
  width: 90%;
  max-width: 1100px;
  margin: 60px auto;
  background: #d6d8cd;
  box-shadow: 0px 0px 0px 10px #d6d8cd;
  border: dashed 4px #75818d;
  padding: 0.2em 0.5em;
  color: #0272b0;
  border-radius: 120px;
  z-index: 99;
}
.planbox h2{
	padding-top: 50px;
}
.planbox ul{
  list-style-type: none;
}
.plan-wrap{
	max-width: 1100px;
	width: 100%;
	margin: 30px auto 0;
  padding-left: 0;
}
.plan-wrap li .plan-item{
  width: 100%;
  max-width: 1100px;
	display: flex;
  justify-content: center;
	margin-bottom: 50px;
}
.plan-wrap li .plan-img{
  width: 50%;
	margin: 10px;
	line-height: 0;
}
.plan-wrap li .plan-img img{
	width: 100%;
}
.plan-wrap li .plan-img .cost{
	display: flex;
	align-items: center;
	justify-content: center;
	background: #a1cfdd;
	padding: 10px;
}
.plan-wrap li .plan-img .cost p{
	font-size: 24px;
	margin: 0 10px;
}
.plan-wrap li .plan-img .cost .fst{
	line-height: 1.5;
}
.plan-wrap li .plan-img .cost .sec, .plan-wrap li .plan-img .cost .trd{
	margin-top: 10px;
}

.plan-wrap li .plan-img .cost p .small{
	font-size: 18px;
}
.plan-wrap li .plan-img .cost p .big{
	font-size: 28px;
}
.plan-wrap li .plan-txt{
	max-width: 500px;
	width: 100%;
	margin: 10px;
}
.plan-txt h3{
	font-size: 26px;
  font-weight: bold;
  text-align: left;
  margin-bottom: 20px;
  color: #000;
}
.plan-wrap li {
	font-size: 18px;
  text-align: left;
  line-height: 1.4em;
  list-style-type: none;
}
.plan-wrap li .plan-txt .comment-one{
  background: #333;
  display: inline-block;
  padding: 3px 10px;
  margin: 5px 0;
  color: #fff;
}

.blog-link-container {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 0 5px 0;
  border-top: 3px dotted #333;
}

.plan-wrap li .plan-txt .comment-two { 
  display: inline-block;
  color: #333;
  margin: 0;
  font-size: 18px;
  font-weight: bold;
  margin-top: 10px;
}

.comment-two-btn-wrap {
  margin: 0;
  padding: 0;
}

.comment-two-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 38px;
  border-radius: 50px;
  text-decoration: none;
  background-color: #51a7e3; 
  border: 2px solid #51a7e3;
  color: #fff;              
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  transition: all 0.3s ease;
  margin-top: 10px;
}

.comment-two-btn:hover {
  background-color: #3b8fc7; 
  border-color: #3b8fc7;
  transform: translateY(1px);
}

.plan-wrap li .plan-txt dd{
  margin-left: 0;
}
.plan-wrap li .address dd a{
  color: #365e95;
  border: solid 1px #365e95;
  border-radius: 50px;
  display: inline-block;
  padding: 0 15px;
  margin-left: 10px;
	cursor: pointer;
}
.link-box {
  display: flex;
  justify-content: left;
  padding: 45px 0 0 0;
}
.link-box a{
  padding: 15px 50px;
  display: block;
}
.silver {
  background: #ffc000;
  display: inline-block;
  margin: 5px 0;
  border-radius: 5px;
}
.orange {
  background: #365e95;
  display: inline-block;
  margin: 5px 10px;
  color: #fff !important;
  border-radius: 5px;
}
.orange a {
  color: #fff !important;
}
.plan-sub {
  margin: 70px auto;
}
.cost-two {
  background-color: #a1cfdd;
  text-align: right;
  height: auto;
  display: flex;
  justify-content: flex-end;
  padding: 15px 15px 5px 0;
}
.cost-two a {
  height: 3vh;
  display: block;
  text-decoration: none;
  display: block;
}
.only-470sp{
	display: none;
}
.sp-wave img, .sp-wave-sec img{
  width: 100%;
}
.sp-wave, .sp-wave-sec{
  overflow: hidden;
}

/* ここからフッター */
.footerbox{
	background: #333;
	padding-bottom: 20px;
	position: relative;
}
.footer-wrap{
	display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}
.footer-wrap p{
	color: #fff;
}
.footerbox .footer-link a{
	color: #fff;
  font-size: 14px;
  margin: 0 10px;
  padding-bottom: 6px;
}
.top-box {
  position: absolute;
  top: -40%;
  right: 8%;
  max-width: 80px;
}
.top-box img{
  width: 100%;
}
.bottom-menu {
  position: sticky;
  bottom: 0;
  width: 100%;
  background: #ffffff80;
  text-align: center;
  z-index: 99;
}
.bottom-box ul {
  display: flex;
  justify-content: center;
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  background: #fff;
}
.bottom-box li {
  list-style-type: none;
  width: calc(100% / 3);
}
.bottom-box li a{
  padding: 10px;
  display: block;
  font-size: 24px;
  display: block;
  color: #fff;
}
.bottom-box li a i{
  margin-right: 5px;
}
.li-one-bottom {
  background-color: #03004c;
  border: solid 5px #03004c;
}
.li-one-bottom img {
  width: 100%;
}
.li-two-bottom {
  background-color: #59493f;
  border: solid 5px #59493f;
}
.li-two-bottom img {
  width: 100%;
}
.li-thr-bottom a{
  background-color: #fff;
  border: solid 5px #333;
  color: #000 !important;
}

.li-thr-bottom img {
  width: 100%;
}

.pagetop {
  display: none;
  position: fixed;
  bottom: 80px;
  right: 15px;
}
.pagetop a {
  display: block;
  background-color: #ccc;
  text-align: center;
  color: #222;
  font-size: 30px;
  text-decoration: none;
  padding: 4px 17px;
  filter: alpha(opacity=50);
  -moz-opacity: 0.5;
  opacity: 0.5;
}
.fadein {
   opacity : 0;
  transform : translate(0, 30px);
  transition : all 500ms;
}
.visible {
  opacity: 1;
  transform: translateY(0); 
}

/* お問い合わせ */
.contact{
  background-color: #67a7df0f;
  border-radius: 20px;
  padding: 50px 30px;
  margin-bottom: 100px;
}
.contact-img img{
  width: 100%;
}
.contact-box{
  display: flex;
  justify-content: center;
  align-items: center;
}
.contact-box > div{
  margin: 20px;
  max-width: 380px;
}
.contact-box > div a{
  display: block;
}
.contact-box > div img{
  width: 100%;
}
.contact-img-two{
  background: #2da7b2;
  display: inline-block;
  margin: 5px 0;
  border-radius: 5px;
}
.contact-img-two a{
  padding: 15px 50px;
  display: block;
  color: #fff;
}
.komarigoto-gaiyou-bold {
  font-size: 22px;
  font-weight: bold;
  display: block;
}
.komarigoto-gaiyou {
  text-align: left;
  font-size: 17px;
  max-width: 900px;
  margin: 20px auto 0;
}
.summary-toggle-btn {
  display: none;
}

/* レスポンシブ */
@media screen and (max-width: 1400px){
  h2 {
    padding: 80px 0 60px 0;
  }
  .miryoku h2{
    padding-top: 0 !important;
  }
}

@media screen and (min-width: 1200px) and (max-width: 1300px) {
  .hero-txt {
    font-size: 20px;
    padding: 15px;
  }
  .komarigoto-item .komarigoto-txt {
    font-size: 22px;
  }
  .komarigoto-item .komarigoto-item-wrap {
    height: 200px;
  }
}

@media screen and (max-width: 1199px){
  .only-pc {
    display: none;
  }
  .only-sp-logo {
    display: block;
  }
  .only-pc1000{
    display: none;
  }
  .only-sp1000{
    display: block;
  }
  .top-list-sp {
    display: flex;
    justify-content: space-between;
    background-color: #fff;
    width: 100%;
  }
  h2 {
    padding: 80px 0 30px 0;
    font-size: 32px;
  }
  .miryoku h2{
    padding-top: 0 !important;
  }
  .plan-box {
    max-width: 900px;
    padding: 0;
  }
  .small {
    margin: 0 auto;
    max-width: 900px;
  }
  .plan-wrap li .plan-item {
    max-width: 1080px;
    margin: 0 auto 50px auto;
    align-items: center;
  }
  .plan-wrap li .plan-txt {
    max-width: 455px;
  }
  .plan-wrap li .plan-img {
    width: 45%;
    margin: 10px 0 0 0;
  }
  .plan-txt h3 {
    font-size: 22px;
  }
  .plan-wrap li {
    font-size: 17px;
  }
  .link-box {
    padding: 0;
  }
  .link-box a {
    font-size: 17px;
  }
  .only-sp-footer {
    display: block;
  }
  .footer-wrap-sp {
    width: 100%;
  }
  .footer-link-sp ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .footer-link-sp li {
    border-top: 1px solid #dcdcdc;
  }
  .footer-link-sp li a {
    display: block;
    padding: 18px 30px 16px 20px;
    position: relative;
  }
  .footer-link-sp a:after {
    display: block;
    content: "";
    position: absolute;
    right: 15px;
    top: 50%;
    margin-top: -3px;
    width: 6px;
    height: 10px;
    background-image: url(../img/footer.png);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
  }
  #copyright {
    border-top: 1px solid #dcdcdc;
    text-align: center;
    font-size: 13px;
    background: rgb(51, 51, 51);
    color: #fff;
    margin: 0;
    padding: 10px;
  }
}

@media screen and (max-width: 900px){
  .only-sp900{
    display: block !important;
  }
  .voice-box {
    background-color: #ffffff80;
    margin: 0 auto;
    width: 70%;
    border-radius: 30px;
    display: block;
    max-width: none;
    position: absolute; 
    left: 50%; 
    top: 48.5%; 
    transform: translate(-50%, -50%);
  }
  .plan-wrap {
    padding: 0;
  }
  .plan-box {
    width: 95%;
  }
  .planbox h2 {
    padding-top: 30px;
    font-size: 35px;
  }
  .plan-wrap li .plan-item {
    display: block;
  }
  .plan-wrap li .plan-img {
    width: 90%;
    margin: 0 auto;
  }
  .plan-wrap li .plan-img > .plan-txt{
    width: 100%;
  }
  .plan-wrap li .plan-txt {
    max-width: unset;
    width: 90%;
    margin: 20px auto;
  }
  .plan-txt h3 {
    font-size: 35px;
    margin: 20px 0 40px 0;
  }
  .plan-wrap li {
    font-size: 20px;
  }
  .plan-sub {
    margin-top: 0;
  }
  .link-box {
    width: 100%;
    margin: 30px auto;
    justify-content: center;
    
  }
  .link-box a {
    font-size: 30px;
    padding: 15px 50px 15px 50px;
  }
  .voice-title p {
    font-size: 40px;
    margin: 20px auto;
  }
  .voice p {
    font-size: 21px;
    line-height: 1.9rem;
  }
  .small {
    max-width: 800px;
    width: 80%;
  }
  .plan-wrap li .plan-txt .comment-two {
    font-size: 20px;
  }
  .comment-two-btn {
    font-size: 18px;
  }
}

@media screen and (max-width: 768px){
  .only-pc-plan {
    display: none;
  }
  .only-sp-plan {
    display: block;
  }
  .only-pc{
    display: none;
  }
  .only-sp {
    display: block;
  }
  .top{
    background-image: url(../img/MV-sp.webp);
    position: relative;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
  }
  .top-list {
    padding: 10px 20px !important;
  }
  .top-money-item {
    max-width: 600px;
  }
  .top-money-item p {
    white-space: wrap;
  }
  .voice-top {
    background-image: url(../img/voice-sp.webp);
    position: relative;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
  }
  .voice-box {
    top: 50%;
  }
  .komarigoto-item {
    flex-direction: column;
  }
  .komarigoto-item .komarigoto-item-wrap {
    max-width: unset;
    height: 200px;
  }
  .miryoku-txt {
    padding: 0;
    padding-top: 20px;
  }
  .miryoku h2 {
    padding-bottom: 50px;
  }
  .miryoku-campaign-wrap {
    flex-direction: column;
  }
  .miryoku-campaign-wrap .miryoku-price {
    max-width: unset;
  }
  .otoku {
    top: -50px;
    right: -10px;
  }
  .link-box ul {
    padding: 0;
  }
  .miryoku-point {
    width: 85%;
    padding: 0 30px;
  }
  .hero-txt { 
    font-size: 21px;
    text-align: left;
  }
  .js-summary-content {
    max-height: 120px !important;
    overflow: hidden !important;
    position: relative;
    transition: max-height 0.5s ease-in-out !important;
    z-index: 1;
  }

  .js-summary-content::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(103, 167, 223, 0.06));
    transition: opacity 0.3s ease;
    pointer-events: none !important; 
    z-index: 2;
  }

  .js-summary-content.is-open {
    max-height: 1200px !important;
  }

  .js-summary-content.is-open::after {
    opacity: 0 !important;
  }

  .summary-toggle-btn {
    display: block !important;
    width: 160px;
    margin: 20px auto 0;
    padding: 10px 0;
    background-color: #fff;
    color: #51a7e3;
    border: 2px solid #51a7e3;
    border-radius: 50px;
    font-size: 14px;
    font-weight: bold;
    cursor: pointer;
    text-align: center;
    outline: none;
    position: relative !important;
    z-index: 10 !important; 
  }

  .summary-toggle-btn.is-active {
    background-color: #51a7e3;
    color: #fff;
  }
}

@media screen and (max-width: 650px){
  .money p {
    padding-bottom: 5px;
  }
  .big {
    font-size: 26px;
  }
  .miryoku-point {
    width: 85%;
    padding: 0 30px;
  }
  .small {
    width: 100%;
  }
}

@media screen and (max-width: 550px){
  .big {
    font-size: 24px;
  }
  .big-red {
    font-size: 28px;
  }
}

@media screen and (max-width: 500px){
  .cyuui p {
    padding: 15px;
  }
  .only-sp{
    display: block;
  }
  .only-sp500 { 
    display: block;
  }
  .sp-list-logo {
    max-width: 110px;
    width: 100%;
    margin: 15px 0 10px 20px;
  }
  .sp-list-tel {
    max-width: 170px;
    width: 100%;
    margin: 14px 20px 10px 0;
  }
  .top-icon {
    max-width: 250px;
    width: 100%;
    top: 45%;
  }
  .top-list {
    position: relative !important; 
    top: auto !important;
    left: auto !important;
    width: 100% !important;
    padding: 0 15px !important; 
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    z-index: auto !important;
  }
  .top-logo {
    max-width: 110px; 
  }
  
  .top-menulist {
    position: fixed !important;   
    bottom: 80px;                  
    right: 6px;                   
    z-index: 1001;                 
  }
  .top-menulist ul {
    flex-direction: column !important; 
  }
  .btn-contact {
    max-width: 80px !important;       
    margin: 0 !important;             
  }

  .top-list-sec {
    max-width: 360px;
    width: 90%;
    top: 10%;
  }
  .top-money {
    margin: -300px auto 0;
  } 
  .money-money-top {
    max-width: 467px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    margin: 10px 0;
  }
  .yazirushi {
    max-width: 25px;
    margin: 0.5rem 0.2rem;
  }
  .big {
    font-size: 20px;
  }
  .big-red {
    font-size: 22px;
  }
  .yellow {
    margin-top: 10px;
  }
  .yellow h1 {
    font-size: 20px;
  }
  .top-money-item {
    max-width: 460px;
    margin: 0 auto;
  }
  .yellow-bottom {
    font-size: 15px;
  }
  .top-white {
    margin: 10px 0 10px 0;
  }
  .top-money-item p {
    font-size: 17px;
    white-space: initial;
  }
  .h2-small {
    font-size: 18px;
  }
  .picup-box {
    width: 85%;
  }
  .picup-boxbox {
    margin: 10px auto;
    width: 90%;
  }
  .picup-img-one {
    width: 30%;
  }
  .picup-img-two {
    width: 33%;
  }
  .picup-sub {
    display: block;
    margin: 30px auto 0 auto;
  }
  h2 { 
    font-size: 28px;
    padding: 80px 0 15px 0;
    line-height: 1.5;
  }

  .home {
    padding: 20px 20px 100px 20px !important; 
  }
  .home-contact{
    flex-direction: column;
  }
  .home-txt {
    padding: 20px;
  }

  .miryoku {
    padding: 10px 0 40px 0;
  }
  .miryoku h2 {
    font-size: 26px; 
    padding: 0 0 20px 0;
  }
  .miryoku-item-wrap {
    display: flex;
    flex-direction: column;
    margin-bottom: 0;
    gap: 20px;
  }
  .miryoku-item-wrap li {
    width: 100% !important; 
    margin: 30px 0 0 0 !important; 
  }
  .miryoku-point {
    width: 85%;
    font-size: 18px;
    padding: 0 20px;
  }
  .miryoku-item li {
    padding: 20px 15px;
    margin: 50px 0 0 0;
  }
  .miryoku-item li {
    padding: 20px 15px;
    margin: 50px 0 0 0;
  }
  .miryoku-txt {
    padding: 15px 0 0 0;
  }
  .miryoku-txt h3 {
    font-size: 22px;
    margin: 15px 0 10px 0;
    text-align: center;
  }
  .miryoku-txt p {
    font-size: 17px;
    line-height: 1.5;
  }
  .miryoku-txt-wrap {
    display: flex;
    flex-direction: column !important; 
    text-align: center;
    margin-bottom: 25px;
  }
  .miryoku-txt-wrap:last-child {
    margin-bottom: 0;
  }
  .miryoku-txt-wrap .miryoku-img {
    padding: 10px 0;
    max-width: 100%;
    width: 100%;
    order: 2; 
  }
  .miryoku-txt-wrap .miryoku-txt {
    order: 1; 
  }
  .point3 h3 {
    text-align: center !important; 
  }
  .miryoku-item .miryoku-campaign {
    margin-top: 50px;
    margin-bottom: 20px;
  }
  .miryoku-txt .ribbon1 {
    font-size: 16px; 
    line-height: 1.4;
    padding: 12px 25px;
    width: 100%;
    box-sizing: border-box;
    display: inline-block;
    position: relative;
  }
  .miryoku-txt .ribbon1:before,
  .miryoku-txt .ribbon1:after {
    display: block; 
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    top: 0;
    z-index: 1;
  }
  .miryoku-txt .ribbon1:before {
    left: 0;
    border-width: 25px 0px 25px 15px; 
    border-color: transparent transparent transparent #ffffd6; 
    border-style: solid;
  }
  .miryoku-txt .ribbon1:after {
    right: 0;
    border-width: 25px 15px 25px 0px;
    border-color: transparent #ffffd6 transparent transparent; 
    border-style: solid;
  }
  
  .miryoku-campaign-wrap {
    display: flex;
    flex-direction: column;
    margin-top: 15px;
  }
  .miryoku-campaign-wrap .miryoku-price-item {
    order: 1; 
  }
  .miryoku-campaign-wrap .miryoku-img {
    order: 2; 
    margin: 20px auto 10px auto;
    max-width: 280px;
  }
  .miryoku-campaign-wrap > div {
    margin: 10px 0;
  }
  .miryoku-campaign-wrap .miryoku-price {
    max-width: 100%;
    width: 100%;
  }
  .miryoku-price .miryoku-price-ttl {
    font-size: 18px;
    padding: 5px 0;
  }
  .miryoku-price .miryoku-price-item .price {
    font-size: 32px;
  }
  .miryoku-price .miryoku-price-item .term {
    font-size: 15px;
    margin-right: 10px;
  }
  .miryoku-price .miryoku-price-item span {
    font-size: 16px;
  }
  .miryoku-price .miryoku-price-item .campaign_price {
    font-size: 40px;
  }
  .miryoku-price .miryoku-price-detail {
    font-size: 13px;
    padding: 0 5px;
  }
  .otoku {
    top: -25px;
    right: 5px;
    max-width: 70px;
  }
  .miryoku-campaign-cyuui {
    font-size: 18px;
    padding: 15px;
    margin-top: 20px;
    line-height: 1.5;
  }

  .komarigoto-item {
    flex-direction: column; 
    align-items: center;
    width: 100%;
  }
  .komarigoto-item li {
    width: 100%;
    margin: 0 0 30px 0; 
    list-style-type: none;
  }
  .komarigoto-item .komarigoto-item-wrap {
    max-width: 100%;
    width: 100%;
    height: auto; 
    padding: 15px 20px; 
    align-items: center; 
  }
  .komarigoto-item .komarigoto-txt {
    font-size: 20px; 
    padding: 0;
    line-height: 1.5;
    text-align: left;
    width: 100%; 
  }
  .komarigoto-item .komarigoto-img {
    max-width: 75px; 
    width: 100%;
    align-items: center;
    margin-left: 10px;
  }
  .komarigoto-item .komarigoto-item-hukidash {
    max-width: 35px; 
    margin: -10px auto 0 auto; 
  }
  .komarigoto-solution {
    font-size: 22px; 
    padding: 40px 10px 50px 10px;
  }

  .planbox h2 {
    font-size: 26px;
    padding: 30px 10px 10px 10px;
  }
  .plan-wrap {
    width: 100%;
    padding: 0;
    margin-top: 10px;
  }
  .plan-wrap li .plan-item {
    flex-direction: column; 
    width: 100%;
    padding: 0 10px;
    padding-top: 30px;
    margin-bottom: 40px;
  }
  .plan-wrap li .plan-img {
    width: 100%; 
    margin: 0 0 15px 0;
  }
  .plan-wrap li .plan-txt {
    width: 100%;
    margin: 0;
    padding: 0 5px;
  }
  .plan-wrap li .plan-img .plan-txt h3 {
    font-size: 22px;
    margin: 0 0 15px 0;
    text-align: center;
    color: #0272b0;
  }
  .plan-wrap li .plan-img .cost {
    padding: 12px 10px;
    flex-direction: column; 
    gap: 11px;
    border-radius: 0;
  }
  .plan-wrap li .plan-img .cost p {
    margin: 0;
    text-align: center;
  }
  .plan-wrap li .plan-img .cost p .small {
    font-size: 16px;
  }
  .plan-wrap li .plan-img .cost p .big {
    font-size: 26px;
  }
  .cost-two {
    padding: 20px 10px;
    justify-content: right; 
  }
  .cost-two a {
    height: unset;
    font-size: 15px;
  }
  .plan-wrap li dl {
    margin: 10px 0;
  }
  .plan-wrap li dt {
    font-weight: bold;
    font-size: 18px;
  }
  .plan-wrap li dd {
    font-size: 18px;
    margin-top: 2px;
  }
  .plan-wrap li .address dd a {
    padding: 2px 12px;
    font-size: 18px;
    margin-left: 6px;
  }
  .link-box {
    padding: 15px 0 0 0;
    margin: 15px 0 0 0;
  }
  .link-box ul {
    padding: 0;
  }
  .link-box li {
    width: 100%; 
    text-align: center;
  }
  .link-box a {
    font-size: 20px;
  }
  .orange {
    margin: 0;
  }
  .small {
    width: 100%;
  }
  .planbox .inner p {
    font-size: 18px;
    line-height: 1.5;
    padding: 0;
  }
  .plan-sub {
    margin: 30px auto 0 auto;
  }
  .plan-sub .small p {
    font-size: 18px;
    line-height: 1.6;
    padding: 0;
  }
  .point-first {
    margin-bottom: 0;
  }

  #contact {
    display: block !important; 
    margin: 40px 0;
  }
  .contact {
    padding: 25px 15px;
    margin-bottom: 0;
    border-radius: 15px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
  }
  .contact p {
    font-size: 18px;
    line-height: 1.6;
    margin: 15px 0;
    text-align: left;
  }
  .contact-box {
    flex-direction: column; 
    gap: 15px;
    margin: 0;
  }
  .contact-box > div {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    text-align: center;
  }
  .contact-img-one {
    max-width: 240px !important;
    margin: 0 auto !important;
  }
  .contact-img-two {
    width: 100%;
    border-radius: 6px;
  }
  .contact-img-two a {
    padding: 14px 0 !important;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
  }
  .container {
    height: 0vh;
  }
  .wave {
    height: 70px;
    overflow-x: visible;
  }
  .wave::before {
    top: 55%;
  }
  .wave::after {
    top: 33%;
  }
  .container-sec {
    height: 7vh;
    margin-top: 30px;
  }
  .wave-sec {
    height: 70px;
    overflow-x: visible;
  }
  .wave-sec::before {
    top: 62%;
  }
  .wave-sec::after {
    top: 44%;
  }
  #service {
    margin: 50px 0;
    margin-top: 100px;
  }
  .service-img {
    padding: 0;
  }
  .service-service h2 {
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    font-size: 30px;
  }
  .event-title h3 {
    font-size: 26px;
    padding: 5px;
  }
  .content {
    max-width: 400px;
    margin: 0 auto;
    padding: 10px 0 10px 0;
  }
  .content p {
    font-size: 20px;
    margin: 10px 0 30px 0;
  }
  .user h2 {
    font-size: 28px;
    padding: 0 0 20px 0;
  }
  .user-list {
    font-size: 20px;
    padding: 10px 0;
  }
  .user-box-img {
    max-width: 33px;
    width: 100%;
    margin-top: 15px;
    flex-shrink: 0;
    margin-right: 5px;
  }
  .user-box-item p {
    margin-top: 0;
    margin-bottom: 0;
  }
  .curved {
    height: 7vh;
  }
  .money h2 {
    padding: 0;
    font-size: 28px;
  }
  .money p {
    font-size: 16px;
    padding: 0 5px;
  }
  .small {
    font-size: 15px;
  }
  .money-total {
    width: 90%;
  }
  .money-text {
    padding: 0 0 50px 0;
    width: 90%;
  }
  .money-total {
    padding: 1.5rem 1rem;
  }
  .voice-top {
    position: relative;
  }
  .voice-box {
    width: 90%;
  }
  .voice-title {
    padding: 3px 20px 0 20px;
  }
  .voice-title p {
    font-size: 35px;
    margin: 10px auto;
  }
  .voice p {
    font-size: 16px;
  }
  .voice {
    text-align: left;
    padding: 0 20px 20px 20px;
  }
  .top-box {
    top: -24%;
    right: 10px;
    max-width: 50px;
  }
  .footer-link-sp li a {
    display: block;
    padding: 18px 30px 16px 20px;
    position: relative;
    font-size: 16px;
  }
  .pagetop {
    bottom: 0;
    right: 10px;
  }
  .bottom-box li a {
    margin: 0 auto;
    font-size: 20px;
  }
  .hero-txt span {
    border-bottom: solid 5px #f0e22180;
  } 
  .hero-txt {
    padding: 13px 10px;
    font-size: 17px;
    text-align: left;
  }
  .hanabi {
    top: 0%;
    right: 3px !important;
    left: unset;
    max-width: 150px; 
  }
  .footerbox {
    display: none;
  }
  .komarigoto-solution .komarigoto-orange {
    font-size: 34px; 
  }
  .comment-two-btn {
    margin-top: 5px;
  }
  .komarigoto-gaiyou-bold {
    font-size: 18px;
  }
  .komarigoto-gaiyou {
    font-size: 16px;
  }
  .miryoku-item-wrap .point3{
    margin-top: 70px !important; 
  }
}