@charset "utf-8";

/* -------------------------------------------------
	box
------------------------------------------------- */

.box1000 {
	width: 96%;
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
}

/* -------------------------------------------------
	h
------------------------------------------------- */

.h-type1 {
	padding: 0.5em 0 0.4em;
	background: #282828;
	color: #fff;
	text-align: center;
	font-size: 25px;
	font-weight: bold;
	position: relative;
}
.h-type1::before {
	width: 152px;
	height: 88px;
	content: "";
	background: url(../img/deco.png) no-repeat 0 0 / contain;
	display: block;
	position: absolute;
	left: 10px;
	top: -20px;
	z-index: 2;
}
.h-type1 span {
	position: relative;
	z-index: 4;
}

/* -------------------------------------------------
	btn
------------------------------------------------- */

.btn-type1 {
	margin: 40px auto 0;
	width: 385px;
	height: 45px;
	border: solid 2px #000;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 16px;
	color: #000;
	position: relative;
}
.btn-type1:hover {
	color: #000;
	background: #eee;
}
.btn-type1::after {
	width: 20px;
	height: 6px;
	border-bottom: solid 1px #444;
	border-right: solid 1px #444;
	box-sizing: border-box;
	transform: skewX(40deg);
	position: absolute;
	right: 18px;
	top: 40%;
	content: "";
	display: block;
}

/* -------------------------------------------------
	mv
------------------------------------------------- */

#mv {
	margin-top: 35px;
}
#mv .back {
	padding: 4px 15px;
	background: #000;
	margin-bottom: 1px;
	text-align: right;
	font-size: 14px;
}
#mv .back a {
	padding-left: 1.9em;
	color: #fff;
	display: inline-block;
	position: relative;
}
#mv .back a::before {
	content: "";
	display: block;
	border-top: solid 4px #fff;
	border-left: solid 4px #fff;
	box-sizing: border-box;
	width: 0.9em;
	height: 0.9em;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%) rotate(-45deg);
}
#mv .desc {
	width: 81%;
	margin: 40px auto 0;
}
#mv .desc1 {
	font-size: 18px;
	color: #ca0915;
	font-weight: bold;
}
#mv .desc2 {
	margin-top: 1.2em;
	font-size: 16px;
}

/* -------------------------------------------------
	plan
------------------------------------------------- */

#plan {
	padding-top: 70px;
}
.plan-inner {
	margin: 0 30px;
}

.plan-lead {
	margin: 32px 0 26px;
	text-align: center;
	font-size: 18px;
}

.plan-table {
	width: 100%;
	box-sizing: border-box;
	border-collapse: collapse;
	table-layout: fixed;
	border-left: solid 1px #b1b1b1;
	border-top: solid 1px #b1b1b1;
}
.plan-table td,
.plan-table th {
	padding: 15px;
	border-right: solid 1px #b1b1b1;
	border-bottom: solid 1px #b1b1b1;
	text-align: center !important;
	vertical-align: top !important;
}
.plan-table th p.bold {
	font-weight: bold;
}
.plan-table tr:first-child th {
	color: #fff;
	background-color: #646464;
	border-bottom: none;
}
.plan-table tr:last-child th {
	color: #fff;
	background-color: #000;
}

.plan-table tr:first-child td {
	border-bottom: none;
}
.plan-table tr:last-child td {
	vertical-align: middle !important;
	text-align: center !important;
	background-color: #e9e9e9;
}

.plan-table.t1 {
	margin-bottom: 20px;
}

.plan-table th {
	width: 21.12%;
}

.plan-table .small {
	font-size: 13px;
	line-height: 1.4em;
}

.plan-desc {
	margin: 50px 0 30px;
	display: flex;
}
.plan-desc .title {
	padding-right: 1em;
	white-space: nowrap;
	font-size: 16px;
	font-weight: bold;
}
.plan-desc ul li {
	font-size: 16px;
}

/* -------------------------------------------------
	chose
------------------------------------------------- */

#chose {
	padding-top: 80px;
}
#chose .chose-inner {
	padding: 0 60px;
}
#chose ul {
	margin-top: 58px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#chose ul li {
	width: calc(420 / 880 * 100%);
}
#chose ul li:nth-child(even) {
	margin-top: 95px;
}
#chose ul li:nth-child(odd):not(:first-child) {
	margin-top: -50px;
}
#chose ul li .text-box {
	margin-bottom: 20px;
	padding-left: 10px;
	border-left: solid 3px #ca0915;
}
#chose ul li .text-box .name {
	padding: 0.2em 0 0.2em;
	font-size: 18px;
	font-weight: bold;
	line-height: 1;
}
#chose ul li .text-box .desc {
	font-size: 16px;
}

/* -------------------------------------------------
	#caution
------------------------------------------------- */

#caution {
	margin-top: 82px;
	margin-bottom: 90px;
	padding: 27px 0;
	background: #EBEBEB;
}
#caution img {
	width: 61px;
}
#caution p {
	font-size: 20px;
	line-height: 1.6;
}

@media print, screen and (min-width:741px) {
	#caution {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#caution p {
		margin-left: 1em;
	}
}