/***************************************/
/*	index
=======================================*/
body.siteBody {
	background: #ffed9c;
	color: #1a1a1a;
}

.top_area {
	position: relative;
	width: 100%;
}

.logp_text {
	position: absolute;
	width: 100%;
	z-index: 2;
	top: 0;
	left: 0;
}

.light_anm {
	position: absolute;
	width: 100%;
	z-index: 1;
	top: 0;
	left: 0;
}

.light_anm img {
	top: 0;
	left: 0;
	position: absolute;
}

.light_front_anm {
	position: absolute;
	width: 100%;
	z-index: 3;
	top: 0;
	left: 0;
}

.light_front_anm img {
	top: 0;
	left: 0;
	position: absolute;
}

.bg_icon {
	width: 100%;
	margin: 0 auto;
	text-align: center;
}

.bg_icon td {
	margin: 0 2px 10px;
}

.icon_area {
	position: relative;
}

.icon_effect {
	position: absolute;
	top: 0;
	left: 0%;
	width: 100%;
	z-index: 1;
}

.icon_anm {
	-webkit-animation-name: light;
	-webkit-animation-duration: 2s;
	-webkit-animation-timing-function: linear;
	-webkit-animation-iteration-count: infinite;
	-webkit-animation-delay: 0s;
	-webkit-animation-fill-mode: forwards;
	-moz-animation-name: light;
	-moz-animation-duration: 2s;
	-moz-animation-timing-function: linear;
	-moz-animation-iteration-count: infinite;
	-moz-animation-delay: 0s;
	-moz-animation-fill-mode: forwards;
}

@-webkit-keyframes light {
	0% {
		opacity: 0;
	}

	25% {
		opacity: 1;
	}

	50% {
		opacity: 1;
	}

	75% {
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}

@-moz-keyframes light {
	0% {
		opacity: 0;
	}

	25% {
		opacity: 1;
	}

	50% {
		opacity: 1;
	}

	75% {
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}

.index_btm_area {
	position: relative;
	width: 100%;
}

.index_btm_btn {
	position: absolute;
	width: 94%;
	bottom: 5%;
	left: 3%;
}

.btn_index1 {
	position: relative;
	width: 100%;
	z-index: 1;
}

.btn_index2 {
	position: absolute;
	top: 0;
	left: 0%;
	width: 100%;
	z-index: 2;
}

.btn_rink_anm {
	-webkit-animation-name: light2;
	-webkit-animation-duration: 2s;
	-webkit-animation-timing-function: linear;
	-webkit-animation-iteration-count: infinite;
	-webkit-animation-delay: 0s;
	-webkit-animation-fill-mode: forwards;
	-moz-animation-name: light2;
	-moz-animation-duration: 2s;
	-moz-animation-timing-function: linear;
	-moz-animation-iteration-count: infinite;
	-moz-animation-delay: 0s;
	-moz-animation-fill-mode: forwards;
}

@-webkit-keyframes light2 {
	0% {
		opacity: 0;
	}

	25% {
		opacity: 1;
	}

	50% {
		opacity: 1;
	}

	75% {
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}

@-moz-keyframes light2 {
	0% {
		opacity: 0;
	}

	25% {
		opacity: 1;
	}

	50% {
		opacity: 1;
	}

	75% {
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}

/***************************************/
/*	form
=======================================*/

.box_form {
	background: #FFFFFF;
	border: #ffbc97 solid 3px;
	border-radius: 5px;
	color: #885023;
	padding: 10px 5px;
	margin: 10px 15px;
}

.box_form_inner {
	padding: 10px;
}

.btn_formnext {
	width: 70%;
	margin: 0 auto;
	padding: 15px 0;
	border: none;
	display: block;
	color: #ffffff !important;
	background-color: #fa5858;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	border-radius: 8px;
	text-decoration: none;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	-ms-box-sizing: content-box;
	box-sizing: content-box;
}

.col {
	flex: 100%;
}

.justify-content-start {
	justify-content: center !important;
	align-items: center;
}

.d-flex {
	display: flex !important;
}

.box_seg {
	padding: 5px;
	text-align: center;
}

.reg_cate {
	margin: 10px 0 20px;
}

/* ---生年月日--- */
select[name="birth_dt_y"] {
	width: 100%;
	color: #666666;
	font-size: 1.2rem;
	border: 2px solid #d2d2d2;
	background: #fff url(../img/tutorial_icon_down.webp) no-repeat 97% 50%;
	background-size: 15px;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	border-radius: 5px;
	padding: 10px 30px 10px 5px;
	appearance: none;
}

select[name="birth_dt_m"] {
	width: 100%;
	color: #666666;
	font-size: 1.2rem;
	border: 2px solid #d2d2d2;
	background: #fff url(../img/tutorial_icon_down.webp) no-repeat 97% 50%;
	background-size: 15px;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	border-radius: 5px;
	padding: 10px 30px 10px 5px;
	appearance: none;
}

select[name="birth_dt_d"] {
	width: 100%;
	color: #666666;
	font-size: 1.2rem;
	border: 2px solid #d2d2d2;
	background: #fff url(../img/tutorial_icon_down.webp) no-repeat 97% 50%;
	background-size: 15px;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	border-radius: 5px;
	padding: 10px 30px 10px 5px;
	appearance: none;
}

/* ---性別--- */
.cate_radio,
.cate_select {
	width: 100%;
	table-layout: fixed;
	display: table;
}

.cate_radio li,
.cate_select li {
	display: table-cell;
}

.cate_radio li label {
	text-align: center;
	border-radius: 8px;
	height: 50px;
	line-height: 50px;
	font-size: 20px;
	background: #d2d2d2;
	color: #434343;
	margin: 0 4%;
	display: block;
}

.cate_radio li:first-child input[type="radio"]:checked+label {
	color: #fff;
	background: #ff6a98;
}

.cate_radio li:last-child input[type="radio"]:checked+label {
	color: #fff;
	background: #52b0ff;
}

.cate_radio li input[type="radio"] {
	display: none;
}

/* ---ニックネーム--- */
.box_seg input[type="text"] {
	width: 100%;
	height: 40px;
	border-radius: 10px;
	color: #313131;
	padding: 3px 10px;
	border: solid 2px #d2d2d2;
	font-size: 1.1rem;
}

/***************************************/
/*	submit
=======================================*/
.submit_text_box {
	padding: 10px 20px;
}

.box_submit {
	background: #ffffff;
	border: #ffbc97 solid 3px;
	border-radius: 10px;
	padding: 10px 5px;
	margin: 10px 15px;
	color: #6f480b;
}

.tbl_seg {
	width: 100%;
	margin: 0 auto;
	font-size: 1.4rem;
}

.tbl_seg th {
	min-width: 120px;
	text-align: right;
}

.tbl_seg th span {
	background: linear-gradient(transparent 70%, #fffb8d 70%);
}

.tbl_seg td {
	text-align: left;
}

.tbl_seg th,
.tbl_seg td {
	padding: 10px 5px;
	vertical-align: middle;
}

.back_text {
	font-size: 1.0rem;
	text-align: center;
}

.btn_submit {
	width: 280px;
	padding: 10px 0px;
	margin: 10px auto 20px;
	border: none;
	display: block;
	color: #ffffff !important;
	background-color: #fa5858;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	border-radius: 10px;
	text-decoration: none;
	box-sizing: content-box;
	letter-spacing: 3px;
}

.btn_anm {
	-webkit-animation-name: btn_anm;
	animation-name: btn_anm;
	-webkit-animation-duration: 2.0s;
	animation-duration: 2.0s;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-direction: normal;
	animation-direction: normal;
}

@-webkit-keyframes btn_anm {
	0% {
		transform: scale3d(1, 1, 1);
	}

	50% {
		transform: scale3d(1.1, 1.1, 1.1);
	}

	100% {
		transform: scale3d(1, 1, 1);
	}
}

@keyframes btn_anm {
	0% {
		transform: scale3d(1, 1, 1);
	}

	50% {
		transform: scale3d(1.1, 1.1, 1.1);
	}

	100% {
		transform: scale3d(1, 1, 1);
	}
}

/***************************************/
/*	footer
=======================================*/
nav {
	margin: 0 8px;
}

ul.f_nav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	margin: 10px auto 0;
}

ul.f_nav li {
	width: 50%;
	margin-bottom: 8px;
	box-sizing: border-box;
	padding: 0 5px;
}

ul.f_nav li>a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 50px;
	text-align: center;
	box-sizing: border-box;
	color: #39270e;
	background: rgba(255, 255, 255, 1.0);
	font-size: 0.8rem;
	line-height: 1.2rem;
	padding: 0 1em;
	border: 2px solid #f6c517;
	border-radius: 5px;
}

ul.f_nav li>a {
	border-width: 1px;
	text-decoration: none;
}

.footerBox {
	position: relative;
	bottom: 0;
	width: 100%;
	height: 40px;
	display: table;
	font-size: 0;
}

.footerBox li {
	display: table-cell;
	vertical-align: middle;
}

.copyRight {
	font-size: 0.8rem;
	width: 100%;
	text-align: center;
	line-height: 1.2em;
}