/* CSS Document */
.mt80_40{
	margin-top: clamp(40px, 4vw, 80px)!important;
}
.mt50_30{
	margin-top: clamp(30px, 4vw, 50px)!important;
}
.mt30_15{
    margin-top: clamp(15px, 4vw, 30px)!important;
}
.mt15_8{
    margin-top: clamp(8px, 4vw, 15px)!important;
}

.mb50_30{
	margin-bottom: clamp(30px, 4vw, 50px) !important;
}
.mb30_15{
	margin-bottom: clamp(15px, 4vw, 30px)!important;
}
.mb15_8{
	margin-bottom: clamp(8px, 4vw, 15px)!important;
}

a:hover{
   opacity: 0.6;
}
a{
	transition: all 0.3s ease;
}
h1,h2,h3{
font-family: dnp-shuei-mgothic-std,"Zen Maru Gothic", sans-serif;
        color: #555;

}
h2{
    font-size: 2rem;
    line-height: 1.1;
}


h2 span{
 font-size: 7vw;
}



h1 span,h2 span,h3 span{
	font-family: oskar, sans-serif;
}
.text_box{
	   text-align: left;
}
.main_h2{
	text-align: center;
}
.main_h2 span{

	font-weight: 300;
	    color: #b8ded8;
	display: flex;
	flex-direction: column;
}
.ttl_en{
font-family: oskar, sans-serif;	

}
.back_or{
	background-color:#f8f7f2;
}
.link_btn{
    background-color: #ffffff;
    border-radius: 100px;
    width: 270px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: solid 2px #e6c08f;
	color: #e6c08f;
	    padding: 7px;
	margin:20px auto;
}

@media screen and (max-width: 600px) {
    h2{
		font-size: 1.7rem;	
	}
	h2 span{
     font-size: 14vw;
        margin-top: 20px;
	}
}

.mv_back {
  position: relative;

    z-index: 0;

}

.mv_back:after {
content: "";
    position: absolute;
       width: 100%;
    height: 100vh;
    border-radius: 530px 0 0 40px;
    background:#f8f7f2;
  top: 13vw;
    left: 0;
    z-index: -2;
}
.inner{
	
}
.mv{
background: url(../img/mv.png) no-repeat center/contain;
width: 96vw; /* 幅を指定 */
    aspect-ratio: 1580 / 1012;
margin: 0 auto;
    max-width: 1600px;
    z-index: -1;
    position: relative;
	    margin-top: 50px;
}
.mv_text_box{
    display: flex;
    max-width: 40vw;
    margin: 0 auto;
	flex-direction: row-reverse;
}
.mv_text{
    writing-mode: vertical-rl;
    text-orientation: upright;
    background-color: #fff;
    color: #929292;
    font-size: clamp(2rem, 3vw, 4.3rem);
    font-family: "Zen Maru Gothic", sans-serif;
    margin-bottom: 0 !important;
    margin-block-start: 0px;
    border-radius: 70px;
    letter-spacing: 0.25vw;
    padding: 20px 4px 0px;
    margin-top: 20px;
    font-weight: 500;
}
.mv_text span{
	color:#e4ad8c;
	}
@media screen and (max-width: 770px) {
.mv_text {
        font-size: clamp(1rem, 5vw, 6rem);
	}
	.mv_text_box{
	    max-width: 50vw;	
	}
.mv{
background: url(../img/sp_mv.png) no-repeat center/cover;
width: 96vw; /* 幅を指定 */
aspect-ratio: 1722 / 1530; /* SP用アスペクト比 */
        margin-top: 70px;
}
}
  
/*news*/
.top-news-inner{
	max-width: 1300px;
	margin: 0 auto;
}
.news_box{
	    display: flex;
    justify-content: center;
	    gap: 50px;
    align-items: center;
	border:solid 2px #c3c3c3;
	background-color: #fff;
	     border-radius: 18vw;
    margin-top: -20%;
	    width: 95%;
    margin: 0 auto;
	    position: relative;
       top: -180px;
    margin-bottom: -150px;
	 padding: 20px;
	    max-width: 1300px;

}
.top-news-cont{
max-height: 400px;
    width: 100%;
    padding: 20px;
}
.scroll-inner{
    overflow-y: auto; /* 垂直方向にスクロールを許可 */
    padding-right: 10px; /* スクロールバーのスペース確保 */
	    height: 350px;
}
/* スクロールバーのスタイル（オプション） */
.scroll-inner::-webkit-scrollbar {
    width: 8px; /* スクロールバーの幅 */
}

.scroll-inner::-webkit-scrollbar-thumb {
    background-color: #c3c3c3; /* スクロールバーの色 */
    border-radius: 4px; /* スクロールバーの角を丸く */
	 height: 30px; /* スクロールバーの長さを調整 */
}

.scroll-inner::-webkit-scrollbar-track {
    background-color: #f8f7f2; /* スクロールバーの背景色 */
}

	.article-cont-ttl{
	font-weight: 600;
	color: #555;    
	}
.news_ttl{
    font-size: 3.5rem;
        font-weight: 300;
	color: #87cec2;         
}

.top-news-cont__article{
	display: flex;
    gap: 20px;
	    padding: 20px 0px;
}

.article-date{
	font-size: 2rem;
	color: #98917b;
	font-family: dnp-shuei-mgothic-std, sans-serif;
	    text-wrap-mode: nowrap;
}
.news_backinner{
    background-color: #f8f7f2;
	
}
.article-cont{
     max-width: 700px;
}
@media screen and (max-width: 1000px) {
	.news_box{
	flex-direction: column;
    justify-content: flex-start;
    gap: 0px;
		    top:0px;
    margin-bottom:0px;
	margin-top: 40px;
	}
	.news_box p{
		margin-bottom: 0;
	}
	.top-news-cont__article {
    display: flex;
    gap: 0px;
    flex-direction: column;
}
}
@media screen and (max-width: 770px) {
	.news_box {
    margin-top:8%;
}
	.top-news-cont__article{
		margin: 0 auto;	
	}
}
@media screen and (max-width: 600px) {
.top-news-cont {
    padding: 0px;
}	
}
/*how to use*/

.video-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 800px; /* 最大750px */
    margin: 50px auto;
}

.video-wrapper iframe {
    width: 95%;
    aspect-ratio: 16 / 9; /* 16:9の比率を維持 */
}




.con_inner{
	width: 96%;
	max-width: 1500px;
	margin: 0 auto;
}
.last_contact{
    padding-bottom: clamp(40px, 4vw, 80px);
}

.con_box{
	background-color: #fff;
	    border: solid 2px #c3c3c3;
	border-radius: 15rem;
	margin-top: clamp(40px, 4vw, 80px);
	margin-bottom: clamp(40px, 4vw, 80px);
	    position: relative;
    z-index: 2;	
}

.how_to h2{
	text-align: center;
	    display: flex;
    flex-direction: column;
}
.how_to h2 span{
	    font-size: 6vw;
    font-weight: 300;
    -webkit-text-stroke: 3px #b8ded8;
    text-stroke: 3px #b8ded8;
    color: rgba(0, 0, 0, 0);
}
.move_btn_wrap {
    z-index: 1;
    position: relative;
	 display: inline-block; /* ホバー判定領域をボタン全体に広げる */
	    width: 100%;
}

.move_btn{
    position: relative; /* 親要素内でのスタッキングコンテキストを確立 */
    background-color: #a5d5cd;
    width: 90%;
	max-width: 1200px;
    margin: 0 auto;
    display: flex;
    height: 90px;
    justify-content: center;
    align-items: center;
    gap: 30px;
    border-radius: 20px;
    border: solid 3px #c3c3c3;
    font-size: 2rem;
    color: #fff;
    overflow: hidden; /* 子要素が親要素の範囲外に出ないようにする */
    z-index: 0; /* 親要素よりも子要素を背面に配置 */	
	   transition: transform 0.3s ease; /* スムーズな動き */
}
.move_btn_wrap span {
    position: relative;
    z-index: 1; /* 子要素の z-index を親より低く設定 */
}

.move_btn_wrap span:after {
    content: "";
    position: absolute;
        left: 50%;
    transform: translateX(-50%);
    bottom: -8px;
    border:solid 1px #c0c0c0;
    background-color: #ffffff;
    height: 100%;
    width: 90%;
	max-width: 1200px;
    border-radius: 20px;
    z-index: -1; /* 疑似要素を親要素の背面に配置 */
    pointer-events: none; /* ホバーやクリックを無効化 */
}
.move_btn:hover {
    transform: translateY(8px); /* ホバー時の動き */

}

.card-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 50px 10px;
    max-width: 1350px;
    margin: 0 auto;
    width: 98%;
}

.card{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;	
	    width: 30%;
}

.card-image img {
  border-radius: 20px; /* 画像の角を丸く */
border:solid 2px #c3c3c3;
}

.btn-circle-right{
width: 100%;	
}
/* ボタンのスタイル */
.btn a {
    position: relative;
    display: block;
    padding: 8px 0;
    background-color: #ffffff;
    border-radius: 60px;
    color: #555;
    text-decoration: none;
    text-align: center;
	    border: 2px solid #ccc;
transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease; /* アニメーション */
}
.btn a:hover {
background-color: #eef5f4;
    border-color: #e2e2e2;
}



/* アイコンのスタイル */
.btn-circle-right a::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  width: 22px;
  height: 22px;
  margin: auto;
  border-radius: 20px;
  background-color: #dad695;
transition: right 0.3s ease; /* アニメーション追加 */
}
.btn-circle-right a::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 0;
  height: 0;
  margin: auto;
  border-top: 4px solid transparent;
  border-right: 0 solid transparent;
  border-left: 7px solid #fff;
  border-bottom: 4px solid transparent;
  box-sizing: border-box;
    transition: right 0.3s ease; /* アニメーション追加 */
}
.btn-circle-right a:hover::before {
    right: 10px; /* ホバー時に左へ動く */
}

.btn-circle-right a:hover::after {
    right: 15px; /* ホバー時に左へ動く */
}

@media screen and (max-width: 770px) {
.card {
    width: 48%;
}
}
@media screen and (max-width: 600px) {
	.how_to h2 span {
    font-size: 12vw;
	-webkit-text-stroke: 2px #b8ded8;
}
	.card-image{
		width: 100%;
	}
	.move_btn{
	    font-size: 1.6rem;	
	}
	.btn a{
	font-size: 1.5rem;
	        text-align: start;
        padding-left: 10px;
	}
	.btn-circle-right a::before{
	width: 19px;
    height: 19px;
	}
	.btn-circle-right a::after{
	right: 26px;
    border-top: 3.5px solid transparent;
    border-left: 5px solid #fff;
    border-bottom: 3.5px solid transparent;	
	}
}

/*insta*/

.insta h2{
	
	    display: flex;
    flex-direction: column;
	    text-align: center;
}

.insta h2 span{
color: #b8ded8;
    font-weight: 300;
margin-top: clamp(15px, 4vw, 30px);
}

.insta_con {
    margin: 0 auto;
	    max-width: 1300px;
    width: 96%;
	    margin-top: clamp(30px, 4vw, 50px);
	
}
.insta_con{
    padding-bottom: 30px;	
}
.back_w{
	position: relative;
	background-color:#f8f7f2;
	 height: auto;
}

.back_w:after{
    content: "";
    position: absolute;
    width: 100%;
    height: 100%; 
    border-radius: 60% 60% 0px 0px;
    background:#fff;
    top: 0%;
    left: 0;
    z-index: 0;
}
.insta_box{
	position: relative;
	z-index: 2;
}
@media screen and (max-width: 770px) {
.insta_box:before{
    position: absolute;
    content: "";
    background-color: #ffffff;
    width: 100vw;
    height: 90%;
/*     bottom: -50px; */
    z-index: -1;
}
	.back_w:after {
    height: 30%;
		border-radius: 60% 60% 0px 0px;
	}
}

/*abut*/
.about h2{
	text-align: left;
	margin-bottom: clamp(15px, 4vw, 30px);
}

.con_wrap{
	display: flex;
	    justify-content: center;
    gap: 70px;
	    height: 650px;
    align-items: center;
	    width: 93%;
    margin: 0 auto;
}
.about .text_box{
        max-width: 460px;
    width: 45vw;
}
.con_wrap img{
    max-width: 600px;
    width: 45vw;
}
.subttl{
font-size: 2.2rem;
    color:#b4a060;	
	    font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;
margin-bottom: clamp(8px, 4vw, 15px);
	display: inline-block;
}
.about .con_inner{
    padding: 50px 0px 0px;
} 
.about_pic{
	position: relative;
}

.about_btn{
    position: absolute;
width: 12vw;
    height: 12vw;
	    min-height: 150px;
    min-width: 150px;
    bottom: 0;
    background-color: #f4c4a0;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 0 0 10px #ffe9d6;
    flex-direction: column;
    text-align: center;
	font-weight: 500;
	font-size: clamp(1.5rem, 1.5vw, 2rem);
}
.about_btn:after{
    position: absolute;
    content: "";
    left: 0%;
    bottom: -50px;
	min-width: 119px;
    min-height: 95px;
    width: 9vw;
    height: calc(9vw*(147 / 184));
    background: url(../img/aboutbtnpic.png) center / cover no-repeat;
}

.about_btn p{
margin-bottom: 0;
		color: #fff;
    font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;
	    line-height: 1.4;
}
.about_btn span{
    margin-top: 8px;
    display: block;
	font-size: 90%;
}
.arrow{
    position: relative;
    width: 30px;
    height: 2px;
    background-color: white;
    left: 50%;
    transform: translateX(-50%);
    bottom: -15px;

}
.arrow::after {
  content: "";
  position: absolute;
  right: 0;
  width: 16px; /* 矢印の斜め線の長さ */
  height: 2px; /* 斜め線の太さ */
  background-color: white; /* 線の色 */
  transform: rotate(45deg); /* 線を斜めに */
  transform-origin: right center; /* 回転の基準を右端に */
}
@media screen and (max-width: 770px) {
.con_wrap {
    flex-direction: column;
	    gap: 0px;
	/* padding: 100vw 0px;	*/
	height: 100%;
	}
.con_wrap img {
    max-width: 650px;
    width: 80vw;
}
	.about .text_box {
    max-width: 650px;
    width: 90vw;
}

.about_btn{
    width: 26vw;
    height: 26vw;
    min-height: 130px;
    min-width: 130px;
bottom: 50px;
	}
.about_btn:after {
    min-width: 93px;
    min-height: 75px;
}
}
@media screen and (max-width: 1000px) {
	.con_box {
    border-radius: 8rem;
}
}
@media screen and (max-width: 600px) {
.subttl {
	font-size: 1.7rem;
	}
.con_wrap{
        min-height: calc(100% + 10%);
	        height: auto;
	}
.con_box {
    border-radius: 5rem;
}
	.about .con_box {
		padding-bottom:20px;
	}
}

/*POINT*/
.re{
    flex-direction: row-reverse;	
}
.point{
	    text-align: center;
}
.point .about_pic img{
	    max-width: 520px;
	
}
.point .about_pic:after{
position: absolute;
    content: "";
    left: 0%;
    bottom: 10px;
    min-width: 140px;
    min-height: 115px;
    width: 11vw;
    height: calc(9vw*(347 / 288));
    background: url(../img/point_back.png) center / cover no-repeat;
}
.re .about_pic:after{
	  left: auto; /* 左方向の位置を無効化 */
  right: 0%; /* 右方向に配置 */
  bottom: 10px; /* 必要に応じて調整 */
  transform: scaleX(-1); /* 画像を水平反転 */
}
.subttl{
/* 	color:#7f7f7f; */
	     line-height: 1.5;
	    font-weight: 500;
}

.subttl span{
	color:#8cbeb6;
}
.num_box{
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;	
}
.num_box{
    color: #d7caa0;
    font-family: oskar, sans-serif;
    font-size: 3rem;
    font-weight: 100;
	    line-height: 0.8;
	margin-bottom: clamp(8px, 4vw, 15px);
}
.num_box span{
	font-size: 9rem;
    font-weight: 400;
    color:#b8ded8;
}
.text_box p{
max-width: 580px;	
}
.point .con_wrap{
        height: auto;
	    min-height: 520px;
}
@media screen and (max-width: 770px) {
       .re{
		   flex-direction: column;	
}
.point .con_wrap{
        height: auto;
	    min-height: calc(100% + 5%);
}
}
@media screen and (max-width: 600px) {
.num_box {
	font-size: 2.5rem;
	}	
.num_box span {
	font-size: 7rem;
	}
}
/*contact*/
.contact h2 span{
	color: #fff;
	position: relative;
    padding: 0 20px; /* 文字の両側の余白を調整 */
}
.contact h2 span::before,
.contact h2 span::after {
    content: '';
    position: absolute;
    top: 50%;
   width: 15vw;
    height: 3px;/* 線の太さ */
    background-color: #fff;/* 線の色 */
    transform: translateY(-50%);
}

.contact h2 span::before {
      left: 10%;
}

.contact h2 span::after {
	right: 10%;
}
.contact .con_box{
	background-color:#dcf2ef;
}

.contactbtn div{
	position: relative;
}

.contactbtn {
border-radius: 10px;
    padding: 20px 10px 5px;
    position: relative;
    border: solid 1px #a7a7a7;
    display: flex;
    flex-direction: column;
    min-width: 260px;
    gap: 10px;
    align-items: center;
    justify-content: center;
    background: linear-gradient(to bottom, #e4eeec 10%, #ffffff 10%);
	 transition: background-color 1.2s ease, background-image 1.2s ease; /* アニメーション時間を1.2秒に変更 */
}


.buy{
background: linear-gradient(to bottom, #f2ebe5 10%, #ffffff 10%);	
}
.contactbtn_box{
	    display: flex;
    justify-content: center;
    gap: 20px;

}

	
.contactbtn div {
    text-align: center;
    z-index: 1; /* テキストが疑似要素の上に表示されるように */
}
.contactbtn div p{
	    font-size: 1.7rem;
	font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;	
}
.contactbtn::before,
.contactbtn::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 30px;
    height: 40px;
    background-size: contain;
    background-repeat: no-repeat;
}

.contactbtn::before {
    left: 10px; /* ボタンの左側に配置 */
    background-image: url('../img/right_btn_blue.png'); /* 左アイコンの画像 */
}

.contactbtn::after {
    right: 10px; /* ボタンの右側に配置 */
    background-image: url('../img/right_btn_blue.png'); /* 右アイコンの画像 */
}
.buy:before {
    left: 10px; /* ボタンの左側に配置 */
    background-image: url('../img/right_btn_red.png'); /* 左アイコンの画像 */	
}
.buy:after {
    right: 10px; /* ボタンの右側に配置 */
    background-image: url('../img/right_btn_red.png'); /* 右アイコンの画像 */
}
.mail_box{
    background-color:#9bd0c8;
    color: #fff;
	    width: 90%;
    text-align: center;
    max-width: 700px;
    border-radius: 2.5rem;
    margin: 0 auto;
	    padding: 50px;
		font-size: 110%;
	font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;
	box-shadow: 0 0 0 15px #c6e5e0;
}
.mail_box p{
color: #fff;
	font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;	
}
.mail_btn{
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #d0cb7b;
    color: #fff;
    font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;
    font-size: 100%;
    width: fit-content;
    padding: 12px 20px;
    max-width: 300px;
    border-radius: 50px;
    margin: 0 auto;
    gap: 10px;
    font-weight: 600;
    margin-top: 10px;
}
.mail_btn img{
    width: 27px;	
}
@media screen and (max-width: 600px) {
	.contactbtn div p{
    font-size: 1.6rem;		
	}
.contactbtn_box{
    flex-direction: column;
	        align-items: center;
	}
.mail_box {
    width: 90%;
   padding: 30px 0px;
    font-size: 100%;
    font-family: dnp-shuei-mgothic-std, "Zen Maru Gothic", sans-serif;
    box-shadow: 0 0 0 10px #c6e5e0;
}
	.mail_btn{
		    font-size: 100%;
		        max-width: 280px;
	}
.contactbtn {
    min-width: auto;
    max-width: 280px;
	        width: 90%;
}
.contact h2 span::before, .contact h2 span::after {
    top: 55%;
    width: 9vw;
    height: 2px;
}	
	}

/*pic up*/
.picup img {
    border-radius: 20px;
    border:none;
}
/*product*/

.product .btn a{
    width: auto;
	    border: none;
   text-align: center;
	    padding: 0;
}
.product .btn a:hover{
	background-color:#fff;
}
.product .btn-circle-right a::before{
	content: none;
}
.product .btn-circle-right a::after{
	content: none;
}

/* コンテンツ */
/* .specific-card クラスを追加して限定 */
.specific-card .card-wrapper {
  position: relative;
  display: inline-block;
  border-radius: 20px; /* 外枠の角丸 */
  overflow: hidden; /* 画像が枠外に出ないように */
  width: 100%; /* 必要に応じて幅調整 */
}

.specific-card .card-image {
  width: 100%;
  border-radius: 20px; /* 画像の角丸 */
}

.specific-card .card-title {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: rgb(0 0 0 / 41%);
    color: #ffffff;
    border-radius: 20px;
    height: 90%;
    width: 90%;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;

}
/* voice*/
.image-container {
    text-align: center;
    margin-top: 50px;
    max-width: 500px;
    margin: 10px auto;
	    width: 90%;
}

