@charset "Shift_JIS";

/***************************************/
/*	main
=======================================*/

body.siteBody {
	background-color: #ffee9f;
	color: #333;
}

/***************************************/
/*	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;
}

/***************************************/
/*	index
=======================================*/
.bg_head {
	background-color: #FF0000;
	color: #fff;
	font-size: 1.3em;
	font-weight: 400;
	padding: 5px;
	text-align: center;
}

.top_bg {
	position: relative;
	width: 100%;
}

.top_hoko {
	position: absolute;
	bottom: 0%;
	width: 60%;
	left: 20%;
	z-index: 1;
}

.top_tap {
	position: absolute;
	bottom: 0%;
	z-index: 2;
	width: 60%;
	text-align: center;
	left: 20%;
}

.anm_hako {
	animation: zoomIn 2s 1, bounce 2s 2s infinite;
}

.anm_tap {
	animation-name: flash;
	animation-duration: 4s;
	animation-timing-function: ease;
	animation-delay: 3s;
	animation-iteration-count: infinite;
	animation-direction: normal;
}

/* Keyframes */
@keyframes zoomIn {
	from {
		opacity: 0;
		transform: scale3d(.3, .3, .3);
	}

	50% {
		opacity: 1;
	}
}

@keyframes bounce {

	0%,
	100% {
		transform: scale3d(1, 1, 1);
	}

	60% {
		transform: scale3d(0.9, 0.9, 0.9);
	}
}

@keyframes flash {

	0%,
	50%,
	to {
		opacity: 1;
	}

	25%,
	75% {
		opacity: 0;
	}
}


/* --------------------------------------------------
  form
-------------------------------------------------- */
.col {
	flex: 100%;
}

.justify-content-start {
	justify-content: center !important;
	align-items: center;
}

.d-flex {
	display: flex !important;
}

.box_seg {
	margin: 10px 0 30px 0;
}

fieldset legend {
	background-color: #483d8b;
	border: 0 none;
	border-radius: 8px 8px 0 0;
	color: #ffffff;
	display: block;
	padding-bottom: 5px;
	padding-top: 5px;
	text-align: center;
	width: 100%;
}

/* ---���N����--- */
select[name="birth_dt_y"] {
	width: 100%;
	color: #39270e;
	font-size: 1.2rem;
	border: 1px solid #39270e;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	border-radius: 5px;
	padding: 10px 5px;
}

select[name="birth_dt_m"] {
	width: 100%;
	color: #39270e;
	font-size: 1.2rem;
	border: 1px solid #39270e;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	border-radius: 5px;
	padding: 10px 5px;
}

select[name="birth_dt_d"] {
	width: 100%;
	color: #39270e;
	font-size: 1.2rem;
	border: 1px solid #39270e;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	border-radius: 5px;
	padding: 10px 5px;
}

/* ---����--- */
.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: #d3d3d3;
	margin: 0 4%;
	display: block;
}

.cate_radio li:first-child input[type="radio"]:checked+label {
	color: #fff;
	background: #ff69b4;
}

.cate_radio li:last-child input[type="radio"]:checked+label {
	color: #fff;
	background: #00bfff;
}

.cate_radio li input[type="radio"] {
	display: none;
}

/* ---�j�b�N�l�[��--- */
.form-control-lg {
	width: 100% !important;
	min-height: calc(1.5em + 1rem + 1rem);
	padding: .5rem 1rem;
	font-size: 1.25rem;
	border-radius: 8px;
}

.btn_next {
	width: 100%;
	max-width: 480px;
	height: auto;
	aspect-ratio: 480 / 121;
	margin: 0 auto;
	padding: 0;
	display: block;
	background-image: url(../img/button_01.webp);
	background-size: cover;
	background-repeat: no-repeat;
	cursor: pointer;
	border: none;
	text-indent: -9999px;
	overflow: hidden;
	border-radius: 20px;
	box-sizing: border-box;
}


/* --------------------------------------------------
  submit
-------------------------------------------------- */

.box_action {
	padding: 0 5%;
	margin: 0 3%;
	color: #4f392b;
	background: #ffffff;
	border-top: none;
	border-right: #b48922 solid 4px;
	border-bottom: #b48922 solid 4px;
	border-left: #b48922 solid 4px;
}

.tbl_seg {
	width: 90%;
	margin: 0 auto;
}

.tbl_seg th {
	min-width: 80px;
	background-color: #483d8b;
	color: #ffffff;
}

.tbl_seg td {
	background-color: #fffafa;
}

.tbl_seg th,
.tbl_seg td {
	border: 1px solid #483d8b;
	padding: 10px 5px;
	vertical-align: middle;
}

.btn8 {
	width: 86%;
	max-width: 480px;
	height: auto;
	aspect-ratio: 480 / 121;
	margin: 0 auto;
	padding: 0;
	display: block;
	background-image: url(../img/button_02.webp);
	background-size: cover;
	background-repeat: no-repeat;
	cursor: pointer;
	border: none;
	text-indent: -9999px;
	overflow: hidden;
	border-radius: 20px;
	box-sizing: border-box;
}