@charset "UTF-8";
/* CSS Document */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

body {
	padding:0;
	margin:0;
}

a{
	color:black;
}

.st_wrap {
	clear: both;
	width:100%;
	padding: 0% 0 20px;
	margin:0 auto;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	color: #000000;	
	background-color:#e8e8e3; 
    font-size: 16px;
}

.st_wrap a{
    text-decoration: none;
}

.st_wrap h1 {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 20px;
	font-weight: 500;
	text-align: center;
	margin: 7% auto 0%;
    line-height: 1.0em;
	letter-spacing: 0.05em;
    color: #000;
}

.st_wrap h1 span {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 50%;
}

.st_wrap strong {
    font-size: 140%;
}

.st_wrap h2 {
	font-size: 25px;
	font-weight: 600;
	text-align: center;
	margin: 8% auto 4%;
    line-height: 1.0em;
	letter-spacing: 0em;
    color: #000;
}

.st_wrap h3 {
	font-size: 22px;
	font-weight: bold;
	text-align: center;
	margin: 6% auto 2%;
}
.st_wrap p {
    text-align: left;
    font-size: 14px;
	font-weight: 500;
    line-height: 1.5em;
    margin: 2% auto 0;
}


.st_wrap img {
	width: 100%;
	vertical-align: bottom;
}
.red {
	color: red;
    font-weight: bold;
    font-size: 110%;
}

.linethroug {
    text-decoration: line-through;
}

#Main {
    width: 100%;
	margin: 0% auto 0%;
	position: relative;
}

#main_ {
	width: 100%;
	margin:4% auto 0%;
	position:relative;
}
.ttl{
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}
.ttl_txt{
	width: 45%;
	position: absolute;
	top:28%;
	left:27.5%;
}
.wrap_content {
	width: 98%;
	max-width: 1200px;
	margin: 10% auto 0;
	padding: 2%;
	position: relative;
}


.sp {
	display:none;
}

.Lead {
	font-weight:normal;
	text-align:center;
	font-size:14px;
	margin:1% auto 0%;
	line-height:1.8em;
	color: #000000;
}

.link_box {
	width: 90%;
	max-width: 700px;
	margin: 3% auto;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
}

.link_line {
	width: 90%;
	max-width: 650px;
	margin: 3% auto;
	border: solid 2px #000;
	box-sizing: border-box;
}



.Sml {
	font-size: 90%;
	text-align: center;
	line-height: 1.8em;
	margin: 1% auto;
	font-weight: normal;
}

small {
	font-size: 80%;
}


.clear {
	clear:both;
}

#ターゲット要素 {
    padding-top: 110px;
    margin-top: -50px;
}
.mt3{
	margin-top: 20%;
}
.mt5{
	margin-top: 23%;
}
.mt10{
	margin-top: 80%;
}
.mt12{
	margin-top: 77%;
}
.ml10{
	margin-left: -25%;
}
.mr10{
	margin-left: 25%;
}


/*thumb*/
	
.thum_box {
	width: 100%;
	max-width: 700px;
	margin: 0% auto 3%;
    padding: 0;
    display: flex; 
	flex-wrap: wrap;
	justify-content: space-between;
}

.thumb {
	width: 45%;
	margin: 0 auto 2%;
	text-align:center;
    position: relative;
    padding: 0.5em 0.5em;
    margin: 1em 0;
    font-weight: bold;
}

.thumb img {
    width: 100%;
}

.sub{
	width: 100%;
	max-width: 500px;
	margin: 5% auto 2%;
}
.point{
	width: 100%;
	max-width: 450px;
	margin: 2% auto 2%;
}
.t_P {
  font-family: Montserrat, sans-serif;
	font-size: 18px;
	text-align:center;
	font-weight: 600;
	margin: 1% auto -2%;
	line-height: 1.9;
}
.kakomi{
	border:solid 2px black;
	border-radius: 30px;
	padding: 5px 10px;
	background-color: white;
}
.t_T {
  font-family: Montserrat, sans-serif;
	font-size: 16px;
	text-align:center;
	font-weight: 600;
	margin: 5% auto 0%;
	line-height: 2.1;
}
.price{
	font-weight:normal;
	font-size:100%;
	text-align: left;
	margin: 0 auto;
	width: 100%;
	font-weight: 600;
}
.tax{
	font-size:70%;
	margin-left: 1%;
}
.Red{
	color:#db454e;
	font-weight:bold;
	letter-spacing: 0.06em;
	font-size:120%;
	text-decoration: underline;
}



.cap {
	text-align: left;
}

.cap span {
	font-size: 18px;
	text-align: left;
	margin: 2% 0;
	padding: 3px;
	background-color: #97d2f4;
}

.Btn_s {
    width: 160px;
    margin: 2% auto;
}

/* General button style (reset) */
.Btn {
	border: none;
	font-family: inherit;
	font-size: 1.2rem;
	color: inherit;
	background: none;
	cursor: pointer;
	padding: 3px;
	display: inline-block;
	margin: 0% auto;
    line-height: 1.2em;
	font-weight: 700;
	outline: none;
	position: relative;
	text-align: center;
	
}


/* Button 1 */
.Btn-1 {
    display: block;
	font-size: 18px;
	letter-spacing: 0.035em;
	font-weight: 500;
    width: 47%;
	margin: 1% auto;
	padding: 2% 0;
	color: #000;
    border-radius: 3px;
}

.btn_code {
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-align: center;
	margin: 15px auto;
	padding:1.5% 0 2%;
	border:3px solid #000;
	background-color: #000;
	width:80%;
}

.btn_code a{
	text-decoration: none;
	display: block;
	color:#fff;
	border:3px solid #000;	
}

.col01 {
	background-color: #878787;
}

.col02 {
	background-color: #28552E;
}

.col03 {
	background-color: #95C7E0;
}

.col04 {
	background-color: #EFAC3E;
}

.Btn-2 {
	font-size: 26px;
	font-weight: 700;
	text-align: center;
	line-height: 1.8em;
	margin: 0 auto;
	width: 100%;
}


.Btn-2.line_bottom  {
	border-bottom: solid 2px #000;
	box-sizing: border-box;
} 


.txt01 {
	color: #878787;
}

.txt02 {
	color: #28552E;
}

.txt03 {
	color: #95C7E0;
}

.txt04 {
	color: #EFAC3E;
}



.Btn-3 {
	width: 80%;
	max-width: 400px;
	font-size: 18px;
	font-weight: 500;
	text-align: center;
	line-height: 1.5em;
	margin: 4% auto 4%;
	padding: 15px 0;
	background-color: #000;
}

.triangle-button{
    border-radius: 4px;
    color: #fff;
    display: block;
    position: relative;
    text-align: center;
    text-decoration: none;
}

.triangle-button::after{
    content: '';
    display: inline-block;
    border-style: solid;
    border-width: 8px 0 8px 8px;
    border-color: transparent transparent transparent #fff;
    width: 0;
    height: 0;
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
}

/*マーカーアニメーション*/
 
.marker-animation.active{
    background-position: -100% .5em;
}
 
.marker-animation {
    background-image: -webkit-linear-gradient(left, transparent 50%, rgb(191,191,191) 50%);
    background-image: -moz-linear-gradient(left, transparent 50%, rgb(191,191,191) 50%);
    background-image: -ms-linear-gradient(left, transparent 50%, rgb(191,191,191) 50%);
    background-image: -o-linear-gradient(left, transparent 50%, rgb(191,191,191) 50%);
    background-image: linear-gradient(left, transparent 50%, rgb(191,191,191) 50%);
    background-repeat: repeat-x;
    background-size: 200% .8em;
    background-position: 0 .5em;
    transition: all 1s ease;
    font-weight: bold;
}

.catch {
  display: flex;
  align-items: center; /* 垂直中心 */
  justify-content: center; /* 水平中心 */
}
.catch:before, .catch:after {
  border-top: 3px solid;
  content: "";
  width: 1em; /* 線の長さ */
}
.catch:before {
  margin-right: 1em; /* 文字の右隣 */
}
.catch:after {
  margin-left: 1em; /* 文字の左隣 */
}


.point_video {
	display: block;
    width: 90%;
	margin: 5% auto;
}

.point_video iframe {
    width: 100%;
}

.img-box {
    position: relative;
    width: 100%;
    aspect-ratio: 6 / 7;
    overflow: hidden;
}

.img1 {
    width: 100%;
    height: auto;
    position: absolute;
    top: 0;
    background: center center no-repeat;
    animation: anime 6s 0s infinite;
    z-index: 0;
    opacity: 0;
}
.img1:nth-of-type(2) {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}

@keyframes anime {
    0% {
        opacity: 1;
    }
    50% {
        opacity: 1;
    }
    60% {
        opacity: 0;
        z-index: 10;
    }
    100% {
        opacity: 0;
    }
}


@media only screen and (max-width: 750px) {
	
	.pc {
		display:none;
	}
	.sp {
		display:block;
	}
	.Lead {
		font-size:12px;
		margin: 3% auto 8%;
	}
	#main_ {
	width: 100%;
	margin:0% auto 0%;
	padding: 10% 0;
}
	.st_wrap {
		width: 100%;
		margin: 0 auto 1%;
	}

	
	.st_wrap h1 {
		font-size: 15px;
		line-height: 1.8;
		margin: 14% auto -2%;
	}	
    
	.st_wrap h2 {
		font-size: 16px;
        padding: 8% auto 4%;
	}
	
	.st_wrap h3 {
		font-size: 15px;
		margin: 8% auto 2%;
	}	

    .st_wrap p {
        font-size: .7rem;
        margin: 3% auto 0;
    }
	
	.st_wrap p br {
		display: none;
		padding-right: 10px;
	}
	
.mt3{
	margin-top: 33%;
}
.mt5{
	margin-top: 37%;
}
.mt10{
	margin-top: 80%;
}
.mt12{
	margin-top: 75%;
}
.ml10{
	margin-left: -11%;
}
.mr10{
	margin-left: 11%;
}
    .n_icon0{
	position: absolute;
	width: 40%;
	top:-3%;
	left:0%;
}	
    .n_icon{
	position: absolute;
	width: 40%;
	top:-4%;
	left:0%;
}
.sub{
	width: 85%;
	margin: 10% auto 2%;
}
.point{
	width: 72%;
	margin: 5% auto 2%;
}	
    .t_P {
        font-size: 12px;
        margin: 4% auto;
    }
.kakomi{
	border:solid 2px black;
	border-radius: 30px;
	padding: 5px 10px;
}	
       .t_T {
        font-size: 13px;
        margin: 6% auto 0;
    } 
	.link_box {
		width: 100%;
	}
	
	.link_line {
		margin: 5% auto;
	}

	.Sml {
		font-size: 11px;
		line-height: 1.8em;
		margin: 2% 0;
	}
	
.wrap_content {
	width: 100%;
	margin: 15% auto 0;
}	
.ttl{
	width: 100%;
	margin: 0 auto -4%;
}	
.ttl_txt{
	width: 66%;
	position: absolute;
	top:17%;
	left:16%;
}	
	.thum_box {
		width: 96%;
		margin: 0% auto 8%;
		flex-wrap: wrap;
		justify-content: center;
		gap: 3%;
	}
	
	.thumb {
		width: 45.5%;
		margin: 3% auto;
    padding: 0.5em 0.3em;
    margin: 0.5em 0 0;
    font-weight: bold;	
	}
	

	
	.info_box {
		width: 95%;
		font-size: 12px;
		line-height: 1.6em;
		text-align: center;
		padding: 6% 3%;
		margin: 15% auto 5%;
	}
	
	

	

	.catch:before, .catch:after {
    	border-top: 2px solid;
	}
	
	
/* Button 1 */
.Btn-1 {
	font-size: 12px;
    line-height: 1.6em;
	margin: 1% auto 2%;
}
	
.Btn-2 {
        font-size: 15px;
    } 
.Btn-3 {
       width: 60%;
        font-size: 13px;
    } 	
.btn_code {
	font-size: 12px;
	text-align: center;
	margin: 10px auto;
	padding:3% 0;
	width:90%;
}
	
	
	.triangle-button::after {
   	 	border-width: 5px 0 5px 5px;
	}
	
}

