/*--------------------------------
reset
--------------------------------*/
html,body,div,p,img,iframe,a,span,blockquote,q,address,cite,
pre,code,em,small,strong,b,i,
header,article,section,nav,figure,figcaption,hgroup,menu,aside,footer,time,
h1,h2,h3,h4,h5,h6,
ul,ol,li,dl,dt,dd,
table,tbody,thead,tfoot,th,tr,td,
form,fieldset,legend,label,select,input,textarea,button{
	margin: 0;
	padding: 0;
	border: 0;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	vertical-align: baseline;
}
header,article,section,nav,figure,figcaption,hgroup,menu,aside,footer,small{
	display: block;
}
ul, li, summary{
    list-style-type: none;
}
summary::-webkit-details-marker {
  display:none;
}

h1,h2,h3,h4,h5,h6{
	font-weight: 200;
}
body{
	line-height: 1;
}
a{
	text-decoration: none;
}
img{
	vertical-align: middle;
}
table{
	border-collapse: collapse;
	border-spacing: 0;
}
select,option,input,textarea,button{
	font: inherit;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
	border-radius: 0;
}
blockquote::before,blockquote::after,q::before,q::after{
	content: '';
	content: none;
}
[type=submit],[type=button],[type=reset],[type=file],button{
	cursor: pointer;
}
:focus{
	outline: none;
}

/*--------------------------------
global element
--------------------------------*/
html{
	width: 100%;
	height: 100%;
}
body{
	width: 100%;
	height: 100%;
	background: url(../images/bg-img.webp) repeat-Y center 0,#000;
	font-size: 24px;
	color: #fff;
	-webkit-text-size-adjust: 100%;
	font-family: "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    background-size: 100% auto;
}
a,button{
	transition: .3s;
}
a:hover,button:hover{
	opacity:.6;
}
.wrap {
    width: 768px;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 0 5%;
    position: relative;
    overflow: hidden;
    background: #2f0a29;
}
.content-img{
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}
.none{
    display: none;
}
.txt-none{
    text-indent: 120%;
    overflow: hidden;
    white-space: nowrap;
}
.img100{
    width: 100%;
    height: auto;
    display: block;
}

/*--------------------------------
Header
--------------------------------*/
.top{
	position: relative;
}
.sub-top{
	position: relative;
	text-align: center;
}
.sub-top .logo{
	padding: 0;
	height: 120px;
}
.logo-link{
	height: 120px;
	display: block;
}
/*--------------------------------
Contents
--------------------------------*/
.content{
	padding: 0;
}
.heading{
	margin: -12% 0 -8%;
	position: relative;
}
.heading .heading-txt{
	font-size: 1.4em;
	font-weight: bold;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
    font-family: '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
}
.heading-inner{
	padding: 2% 0;
	border-bottom: 1px solid #fff;
}
.general .heading{
	margin: 0 0 4%;
}
.general .heading-txt{
	position: relative;
}
.general-item{
	padding: 0 0 8%;
}
.general .general-item{
	padding: 0 8% 8%;
}
.sub-head,.general-item h3{
	margin: 0 0 4%;
	padding: 4% 0 2%;
	color: #d6b51c;
	font-size: 1.1em;
	font-weight: bold;
	border-bottom: 4px solid #d6b51c;
}
.general-item h4{
	margin: 0 0 4%;
	padding: 2% 0;
	color: #ccc;
	font-size: 1.1em;
}
.general-txt{
	padding: 0 0 4%;
	font-size: 1em;
	line-height: 1.8;
}
.general .general-txt, .general .general-item p{
	font-size: .9em;
	line-height: 1.8;
}
.hl-txt{
	color: #ffcc00;
}
.wrap .lpprtitle{
	margin: 10px;
}
.section01,.section02,.section03,.section04{
    padding: 0 20px;
}
.arrow {
    height: 0;
    padding: 30% 0 0px;
    background: url(../images/arrow.webp) no-repeat center center;
    background-size: 60% auto;
}
.photo-frame{
    margin: 0 0 5%;
    display: flex;
}
.photo-frame figure{
    height: 0;
	padding: 25% 0 0;
    margin: 0 5% ;
    position: relative;
    z-index: 1;
    flex: 0 0 40%;
    order: 1;
}

.photo-frame figure img{
	display: block;
	width: 100%;
	height: auto;
	position: absolute;
	top: 0;
	left: 0;
}
.photo-frame figure::before{
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 10%;
    left: 10%;
    background: url(../images/photo-back.webp) no-repeat 0 0;
    background-size: contain;
    transform: rotate(3deg);
    z-index: -1;
}
.photo-frame:nth-of-type(2n) figure::before{
    left: auto;
    right: 10%;
    transform: rotate(-3deg);
}
.photo-frame .caption{
    transition: all .3s .3s;
    opacity: 0;
    flex: 1 1 auto;
    order: 2;
}
.photo-frame:nth-of-type(2n) .caption{
    order: 0;
}
.caption01{
    background: url(../images/caption01.webp) no-repeat center center;
    background-size: 95% auto;
    transform: translateX(20px);
}
.caption02{
    background: url(../images/caption02.webp) no-repeat center center;
    background-size: 95% auto;
    transform: translateX(-20px);
}
.caption03{
    background: url(../images/caption03.webp) no-repeat center center;
    background-size: 95% auto;
    transform: translateX(20px);
}
.caption04{
    background: url(../images/caption04.webp) no-repeat center center;
    background-size: 85% auto;
    transform: translateX(-20px);
}
.text03 {
    height: 0;
    padding: 20% 0 0;
    background: url(../images/caution.webp) no-repeat center center;
    background-size: 95% auto;
}
.text04 {
    height: 0;
    padding: 45% 0 0;
    background: url(../images/cont2_midasi.webp) no-repeat center center;
    background-size: 95% auto;
}
.text05 {
    height: 0;
    padding: 60% 0 0;
    background: url(../images/check.webp) no-repeat center center;
    background-size: 95% auto;
}
.text_pink{
    text-align: center;
    background: #000;
    padding: 40px 10px;
    margin: 30px 0 0; 
    font-weight: bold;
    color: #ff0d57;
    font-size: 1.3em;
    font-family: sans-serif;
}
.section03 {
    max-width: 100%;
    height: 0;
    padding: 144% 0 0;
    margin: 0 auto;
    background: url(../images/queen-img.webp) no-repeat center 0;
    background-size: contain;
    position: relative;
}
.q-caption{
    position: absolute;
    transition: all .3s .3s;
    opacity: 0;
    transform: translateY(10px);
}
.q01{
	width: 44%;
    height: 0;
	padding: 60% 0 0;
    top: -1%;
    right: 1%;
    background: url(../images/q-caption01.webp) no-repeat 0 0;
    background-size: contain;
}
.q02{
    width: 40%;
    height: 0;
    padding: 46% 0 0;
    top: 19%;
    left: 2%;
    background: url(../images/q-caption02.webp) no-repeat 0 0;
    background-size: contain;
}
.q03{
    width: 40%;
    height: 0;
    top: 41%;
    right: 1%;
    padding: 50% 0 0;
    background: url(../images/q-caption03.webp) no-repeat 0 0;
    background-size: contain;
}
.q04{
	width: 55%;
    height: 0;
    bottom: -5%;
    left: 2%;
	padding: 50% 0 0;
    background: url(../images/q-caption04.webp) no-repeat 0 0;
    background-size: contain;
}
.text07 {
    height: 0;
    padding: 40% 0 0;
    background: url(../images/text.webp) no-repeat center bottom;
    background-size: 90% auto;
}
.exp-box {
    max-width: 100%;
    margin: 5% auto;
    padding: 5%;
    background: url(../images/exp-bg.webp) repeat 0 0;
}
.prof{
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}
.user_img{
    width: 40%;
    margin-right: 30px;
}
.user_prof{
    font-family: '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
    font-weight: bold;
    font-size: 1.2em;
}
.exp-text{
    line-height: 1.4;
}
.btn_brfore_txt{
    width: 85%;
    margin: auto;
}
.gif_img{
    padding-bottom: 5%;
}
.text10 {
    height: 0;
    padding: 40% 0 0;
    background: url(../images/last_txt.webp) no-repeat center center;
    background-size: 100% auto;
}
.bottom-question {
    margin: 0 0 5%;
    font-size: 1.2em;
    font-family: '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
    font-weight: bold;
    text-align: center;
}
.yes-btn {
    width: 90%;
    max-width: 100%;
    height: 0;
    padding: 13% 0 0;
    display: block;
    margin: 0 auto 5%;
    background: url(../images/btn-yes.webp) no-repeat center 0;
    background-size: contain;
}
.exit-btn {
    width: 90%;
    max-width: 100%;
    height: 0;
    padding: 10% 0 0;
    display: block;
    margin: 30px auto 50px;
    background: url(../images/btn-no.webp) no-repeat center 0;
    background-size: contain;
}
/*--------------------------------
Button
-------------------------------*/
.btn-row{
	padding: 4% 12% 8%;
	position: relative;
	text-align: center; 
}
.reg-btn{
	margin: 0 auto;
	display: block;
}
.btn_area{
    width: 85%;
    margin: 15px auto;
    position: relative;
    background: url(https://spsm.sumsmsp.info/tb9/css/../images/btn_back.webp);
    background-size: 100%;
    background-repeat: no-repeat;
    padding: 20px;
}
.top_btn{
    margin: 15px auto 0;
}
.btn02{
    margin: 60px auto 0;
}
.btn03{
    margin: 50px auto;
}
.btn_left{
    position: absolute;
    top: -10%;
    left: -5%;
    width: 23%;
}
.btn_right{
    position: absolute;
    top: 0;
    right: -5%;
    width: 11%;
}
.btn_txt{
    width: 60%;
    margin: auto;
    z-index: 2;
    position: relative;
    top: 15%;
}
.dorodoro{
    position: absolute;
    top: 0;
    right: 0;
    left: 35%;
}
.doro_ani{
    width: 90%;
    transform-origin: center top;
    animation: pull 5s infinite;
}
@keyframes pull {
  0%   { transform: scaleY(1.0); }
  50%  { transform: scaleY(1.5); }
  100% { transform: scaleY(1.0); }
}
/*--------------------------------
Footer
--------------------------------*/
.footer{
	padding: 4% 4% 0;
	text-align: center;
	background: #111;
	color: #fff;
}
.gnav-list{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.gnav-item{
	width: 33%;
	text-align: center;
}
.nav-link{
	padding: 4% 0;
	color: #fff;
	display: block;
	font-size: .9em;
	text-decoration: underline;
}
.copy{
	padding: 4% 0;
	font-size: .9em;
	line-height: 1.2;
}


/*--------------------------------
POPUP
--------------------------------*/
.popup{
	padding: 16px 16px 76px 16px;
	background: #f0f0f0;
}
.popup .primary-heading{
	padding: 0 8px;
	line-height: 44px;
	font-size: 1.2em;
	background: #fc4683;
	color: #fff;
	border-radius: 4px 4px 0 0;
}
.popup-content{
	padding: 16px;
	background: #fff;
	border-radius: 0 0 4px 4px;
}
.popup-content h3{
	padding: 0 0 8px;
	font-size: 1em;
	color: #fc4683;
}
.popup-content p{
	padding: 0 0 16px;
	font-size: .9em;
	line-height: 1.2;
	color: #333;
}
.close-btn{
	position: fixed;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 2;
}
.close{
	line-height: 60px;
	background: rgba(0,0,0,.75);
	color: #fff;
	text-align: center;
	display: block;
	position: relative;
}
.close::before,.close::after{
	margin: auto 0;
	width: 2px;
	height: 32px;
	content: "";
	background: #fff;
	position: absolute;
	top: 0;
	left: 44px;
	bottom: 0;
	transform-origin: center;
}
.close::before{
	transform: rotate(45deg);
}
.close::after{
	transform: rotate(-45deg);
}
/*--------------------------------
Animation
--------------------------------*/
@keyframes fade-in{
0% {opacity: 0;filter: blur(4px);}
100% {opacity: 1;filter: blur(0);}
}
@keyframes slide-in{
0% {opacity: 0;filter: blur(4px);transform: translate3d(50px,0,0);}
100% {opacity: 1;filter: blur(0);transform: translate3d(0,0,0);}
}
@keyframes slide-down{
0% {opacity: 0;filter: blur(4px);transform: translate3d(0,-50px,0);}
100% {opacity: 1;filter: blur(0);transform: translate3d(0,0,0);}
}
@media screen and (max-width:767px) {
	/*--------------------------------
	global element
	--------------------------------*/
	body{
		font-size: 16px;
	}
	/*--------------------------------
	Header
	--------------------------------*/
	.sub-top .logo{
		height: 80px;
	}
	.logo-link{
		height: 80px;
	}
	/*--------------------------------
	Contents
	--------------------------------*/
	.general-item{
		padding: 0 0 4%;
	}
    .text_pink{
        font-size: 1.1em;
        line-height: 1.4;
        padding: 20px 10px;
    }
	/*--------------------------------
	Button
	--------------------------------*/
	.btn-row{
		padding: 0 8% 4%;
	}
    .btn_area{
        background-size: cover;
        padding: 10px;
    }
    .btn02 {
    margin: 40px auto 0;
    }
    .btn03 {
    margin: 35px auto;
}
	/*--------------------------------
	Footer
	--------------------------------*/
	.footer{
		padding: 4% 0;
	}
	.gnav-item{
		width: 100%;
		border-bottom: 1px solid rgba(0,0,0,.1);
	}
	.nav-link{
		padding: 4% 0;
	}
	.copy{
		padding: 4% 0;
		font-size: .8em;
	}
}
@media screen and (max-width:320px) {
	/*--------------------------------
	global element
	--------------------------------*/
	body{
		font-size: 13px;
	}
}