@charset "UTF-8";
@import "/include/css/common.pc.css";

/* ---------------------------------------------------------
	CSS Document main
--------------------------------------------------------- */

#main {
	margin-bottom: 40px;
	background-image: url(../images/visual.png);
}

/* ---------------------------------------------------------
	CSS Document about
--------------------------------------------------------- */

#about {
	margin-bottom: 40px;
	font-size: 18px;
	letter-spacing: 1px;
}

#about h3 {
	margin-bottom: 10px;
	font-weight: bold;
	font-size: 36px;
	letter-spacing: 2px;
	color: #0d1b2a;
}

/* ---------------------------------------------------------
	CSS Document anchor
--------------------------------------------------------- */

#anchor {
	margin-bottom: 100px;
}

#anchor .section {
	margin-bottom: 40px;
	font-size: 0;
}

#anchor .anchor {
	display: inline-block;
	vertical-align: top;
	width: 200px;
	height: 250px;
	padding-top: 15px;
	background: #fff url(../images/arrow.png) no-repeat bottom / 16px auto;
	line-height: 60px;
	position: relative;
	z-index: 0;
	transition: .4s;
	cursor: pointer;
}

#anchor .anchor:nth-of-type(odd) {
	background-color: #e7e7e7;
}

#anchor .anchor:nth-of-type(odd):hover {
	background-color: #ccc;
}

#anchor .anchor:hover {
	background-color: #f0f0f0;
}

#anchor .kana {
	font-size: 27px;
	letter-spacing: 2px;
	line-height: 40px;
	color: #e7e7e7;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

#anchor .anchor:nth-of-type(odd) .kana {
	color: #fff;
}

#anchor .anchor a {
	display: inline-block;
	vertical-align: middle;
	width: 200px;
	margin-bottom: 20px;
	text-decoration: none;
	font-weight: 500;
	font-size: 22px;
	line-height: 1.2;
	color: #0d1b2a;
}

#anchor .small {
	font-size: 17px;
}

#anchor figure {
	width: 120px;
	height: 120px;
	margin: 0 auto;
	border-radius: 100%;
	background: #e7e7e7;
	transform: translateX(-50%);
	position: absolute;
	top: 90px;
	left: 50%;
}

#anchor .anchor:nth-of-type(odd) figure {
	background: #fff;
}

#anchor figure img {
	transform: translateY(-50%) translateX(-50%);
	position: absolute;
	top: 50%;
	left: 50%;
}

/* ---------------------------------------------------------
	CSS Document course
--------------------------------------------------------- */

#course {
	margin-bottom: 100px;
	text-align: left;
}

.target {
	margin-top: -150px;
	padding-top: 150px;
}

#course .clearfix {
	position: relative;
	z-index: 0;
}

#course .clearfix:before {
	content: '';
	width: 50vw;
	height: 100%;
	background: #f17424 url(../images/bg.png) no-repeat bottom;
	position: absolute;
	top: 0;
	z-index: -1;
}

#course .target:nth-of-type(odd) .clearfix:before {
	background-position: right bottom;
	right: 50%;
}

#course .target:nth-of-type(even) .clearfix:before {
	background-position: left bottom;
	left: 50%;
}

#course .course {
	width: 460px;
	padding: 60px 0;
	text-align: left;
}

#course h3 {
	margin-bottom: 15px;
	font-weight: 500;
	font-size: 34px;
	line-height: 1;
	color: #f17424;
}

#course .figure {
	width: 200px;
	height: 100%;
	text-align: center;
	font-size: 0;
	position: absolute;
	top: 0;
}

#course .target:nth-of-type(odd) .figure {
	right: 50%;
}

#course .target:nth-of-type(even) .figure {
	left: 50%;
}

#course .figure:before {
	display: inline-block;
	vertical-align: middle;
	content: '';
	width: 0;
	height: 100%;
	background: #f00;
}

#course .figure .section {
	display: inline-block;
	vertical-align: middle;
}

#course .figure .num {
	display: block;
	margin-bottom: 30px;
	font-weight: bold;
	font-size: 90px;
	line-height: 1;
	color: #fff;
}

#shop dt {
	color: #f17424;
}

#company dd {
	display: table-cell;
	vertical-align: top;
	padding-bottom: 15px;
}

#outline li {
	margin-left: 1.1em;
	list-style: decimal;
}

/* ---------------------------------------------------------
	CSS Document price
--------------------------------------------------------- */

#price {
	margin-bottom: 100px;
	text-align: left;
}

#price h3 {
	margin-bottom: 10px;
	padding: 20px 0;
	border-top: solid 1px #333;
	border-bottom: solid 1px #333;
	font-weight: 500;
	font-size: 24px;
	line-height: 1;
	position: relative;
}

#price h3:after {
	content: '';
	width: 80px;
	height: 1px;
	background: #f17424;
	position: absolute;
	top: -1px;
	left: 0;
}

#price .table {
	display: table;
	width: 100%;
}

#price dl {
	display: table-row;
}

#price dt {
	display: table-cell;
	width: 30%;
	padding: 15px;
	border-bottom: solid 1px #ccc;
}

#price dd {
	display: table-cell;
	padding: 15px;
	border-bottom: solid 1px #ccc;
	text-align: right;
}

#price .right {
	margin-top: 15px;
	text-align: right;
	font-size: 14px;
	color: #888;
}

/* ---------------------------------------------------------
	CSS Document outline
--------------------------------------------------------- */

#outline {
	margin-bottom: 100px;
	text-align: left;
}

#outline h3 {
	margin-bottom: 10px;
	padding: 20px 0;
	border-top: solid 1px #333;
	border-bottom: solid 1px #333;
	font-weight: 500;
	font-size: 24px;
	line-height: 1;
	position: relative;
}

#outline h3:after {
	content: '';
	width: 80px;
	height: 1px;
	background: #f17424;
	position: absolute;
	top: -1px;
	left: 0;
}

#outline .section {
	margin-top: 20px;
	padding-top: 15px;
}

#outline h4 {
	margin-bottom: 10px;
	padding-bottom: 15px;
	border-bottom: solid 1px #ccc;
	font-weight: bold;
	font-size: 18px;
	line-height: 22px;
	color: #f17424;
}

#outline h4 span {
	display: inline-block;
	vertical-align: top;
	height: 23px;
	margin-left: 10px;
	padding: 0 10px;
	border-radius: 5px;
	background: #f17424;
	font-weight: bold;
	font-size: 14px;
	line-height: 22px;
	color: #fff;
}

#outline dl {
	display: table;
	width: 100%;
}

#outline dt {
	display: table-cell;
}

#outline dd {
	display: table-cell;
	text-align: right;
	font-size: 18px;
}
