@charset "utf-8";

/* title
========================================================================== */

#title {
	margin: 0 0 120px 226px;
	padding: 215px 40px 0;
}

div.object {
	height: 400px;
	margin: 0 0 90px 226px !important;
	background: url(../img/common/title.png) no-repeat center bottom;
	background-size: 92px;
}

#title h1 {
	font-size: 286%; /* 40px */
	font-weight: 700;
	line-height: 1;
	position: relative;
}
#title h1:before {
	width: 60px;
	height: 2px;
	margin-left: -30px;
	background: #000;
	content: "";
	position: absolute;
	top: -40px;
	left: 50%;
	display: block;
}

#title h2 {
	margin-top: 100px;
	font-size: 214%; /* 30px */
	font-weight: 700;
}

#title p {
	margin-top: 25px;
	line-height: 1.8;
}

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#title {
		margin: 0 0 70px 0;
		padding: 75px 25px 0;
	}

	div.object {
		height: auto;
		margin: 0 0 70px 0 !important;
		background: none;
	}

	#title h1 {
		font-size: 154%; /* 20px */
	}
	#title h1:before {
		width: 30px;
		height: 1px;
		margin-left: -15px;
		top: -20px;
	}

	#title h2 {
		margin-top: 50px;
		font-size: 124%; /* 16px */
	}

	#title p {
		margin-top: 30px;
		background: url(../img/common/title.png) no-repeat center center;
		background-size: 70px;
		text-align: left;
	}
}



/* title (compact)
========================================================================== */

#title_compact {
	height: 92px;
	margin: 0 0 80px 226px;
	background: #b2b0b0;
	position: relative;
	top: 80px;
}

#title_compact h1 {
	color: #fff;
	font-size: 186%; /* 26px */
	font-weight: 700;
	line-height: 92px;
}

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#title_compact {
		height: 46px;
		margin: 0 0 0 0;
		padding: 0 25px 0;
		top: auto;
	}

	#title_compact h1 {
		font-size: 100%; /* 13px */
		line-height: 46px;
	}
}



/* title (news)
========================================================================== */

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#title.title_news {
		height: 46px;
		margin: 0;
		padding: 0 25px 0;
		background: #b2b0b0;
		top: auto;
	}

	#title.title_news h1 {
		color: #fff;
		font-size: 100%; /* 13px */
		font-weight: 700;
		line-height: 46px;
	}
}



/* contents
========================================================================== */

/* layout
-------------------------------------------------------------------------- */

#contents {
	margin: 0 0 0 226px;
	padding-bottom: 145px;
	text-align: left;
	zoom: 1;
}
#contents:after {
	content:"";
	display: block;
	clear: both;
}


#main {
	width: 912px;
	margin: 0 auto;
}

#main > *:last-child,
#main > *:last-child > *:last-child,
#main > *:last-child > *:last-child > *:last-child,
#main > *:last-child > *:last-child > *:last-child > *:last-child {
	margin-bottom: 0 !important;
}

/* pc (small) */
@media only screen and (min-width: 1024px) and (max-width: 1199px) {
	#main {
		width: 720px;
	}
}

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#contents {
		margin: 0;
		padding-bottom: 50px;
	}

	#main {
		width: auto;
		padding: 0 25px;
	}
}


/* link
-------------------------------------------------------------------------- */

#main a.external {
	padding-right: 18px;
	background: url(../img/common/icon/external.svg) no-repeat center right;
	background-size: 14px;
}

#main a.file {
	padding-right: 16px;
	background: url(../img/common/icon/file.svg) no-repeat center right;
	background-size: 11px;
}


/* body copy
-------------------------------------------------------------------------- */

#main p {
	margin-bottom: 1em;
	line-height: 1.8;
}

#main p.preparation {
	padding: 200px 0;
	text-align: center;
}


/* list (ul)
-------------------------------------------------------------------------- */

#main ul {
	margin-bottom: 1em;
}

#main ul li {
	margin: 0 0 .5em 1.5em;
	list-style: disc;
}

#main ul li ul {
	margin: .5em 0;
}

#main ul li ul li {
	list-style: circle;
}

#main ul li ol {
	margin: .5em 0;
	padding-left: 0;
}
#main ul li ol li {
	list-style: decimal;
}


/* list (link)
-------------------------------------------------------------------------- */

#main ul.list_link li {
	margin: 0 0 .5em 1.25em;
	list-style: none;
	position: relative;
}

#main ul.list_link li:before {
	width: 1.25em;
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 100%; /* 14px */
	display: inline-block;
	position: absolute;
	top: 0;
	left: -1.25em;
}


/* list (ol)
-------------------------------------------------------------------------- */

#main ol {
	margin-bottom: 1em;
	padding-left: 1.5em;
}

#main ol li {
	margin-bottom: .5em;
}

#main ol li ul {
	margin: .5em 0;
}
#main ol li ol {
	margin: .5em 0;
	padding-left: 1.5em;
}


/* list (dl)
-------------------------------------------------------------------------- */

#main dl {
	margin-bottom: 1em;
}

#main dl dt {
	margin-bottom: .5em;
	font-weight: bold;
}
#main dl dd {
	margin-bottom: 1em;
}
#main dl dd:last-child {
	margin-bottom: 0;
}


/* list (table)
-------------------------------------------------------------------------- */

#main dl.list_table dt {
	margin-bottom: 0;
	padding: .75em 0;
	float: left;
	clear: both;
}

#main dl.list_table dd {
	margin-bottom: 0;
	padding: .75em 0 .75em 6em;
	border-top: 1px dotted #ccc;
}
#main dl.list_table dd:last-child {
	border-bottom: 1px dotted #ccc;
}

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#main dl.list_table dt {
		padding: .75em 0 0;
		border-top: 1px dotted #ccc;
		float: none;
	}

	#main dl.list_table dd {
		padding: .75em 0;
		border-top: none;
	}
	#main dl.list_table dd + dd {
		padding: 0 0 .75em;
	}
}


/* table
-------------------------------------------------------------------------- */

#main table {
	width: 100%;
	margin-bottom: 1em;
}

#main table th,
#main table td {
	padding: .75em;
	border: 1px solid #ccc;
	vertical-align: middle;
}

#main table th {
	background: #edefec;
	font-weight: bold;
}

#main table td *:last-child {
	margin-bottom: 0;
}

#main p.table_scroll {
	display: none;
}

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#main div.table {
	    width: auto;
	    margin-bottom: .5em;
	    padding: 15px;
	    overflow-x: scroll;
	    overflow-y: hidden;
	    -webkit-overflow-scrolling: touch;
	    -ms-overflow-style: -ms-autohiding-scrollbar;
	    border: 1px solid #eee;
	}

	#main div.table table {
		margin-bottom: 0;
	}
	#main div.table table th,
	#main div.table table td {
		white-space: nowrap;
	}

	#main p.table_scroll {
		font-size: 86%; /* 12px */
		text-align: right;
		display: inherit;
	}
	#main p.table_scroll:before {
		width: 1em;
		margin-right: .25em;
		content: "\f0a6";
		font-family: "Font Awesome 5 Free";
		font-weight: 400;
		display: inline-block;
	}
}


/* note
-------------------------------------------------------------------------- */

#main p.note {
	margin: 0 0 .5em 1em;
	font-size: 86%; /* 12px */
	line-height: 1.5;
	text-indent: -1em;
}

#main dl.note {
	font-size: 86%; /* 12px */
	line-height: 1.5;
}
#main dl.note dt {
	margin-bottom: 0;
	font-weight: normal;
	float: left;
}
#main dl.note dd {
	margin-bottom: 0;
	padding-left: 2.5em;
}


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

#main div.border,
#main div.fill,
#main div.fill_alert {
	margin: 2em 0;
	padding: 1em;
}
#main div.border *:last-child,
#main div.fill *:last-child,
#main div.fill_alert *:last-child {
	margin-bottom: 0;
}

#main div.border {
	border: 1px solid #ccc;
}

#main div.fill {
	background: #f1f1f1;
}

#main div.fill_alert {
	background: #f9e5e5;
}


/* line
-------------------------------------------------------------------------- */

#main hr.line {
	margin-bottom: 1em;
	border: 0;
	border-top: 1px solid #ccc;
	visibility: visible;
}

#main hr.dot {
	margin-bottom: 1em;
	border: 0;
	border-top: 1px dotted #ccc;
	visibility: visible;
}


/* button
-------------------------------------------------------------------------- */

#main div.btn a {
	width: 228px;
	height: 50px;
	margin-bottom: 20px;
	border: 2px solid #787575;
	border-radius: 7px;
	color: #787575;
	font-size: 115%; /* 16px */
	font-weight: 500;
	line-height: 50px;
	text-align: center;
	display: inline-block;
}
#main div.btn a:hover {
	text-decoration: none;
}

#main div.btn a:last-child {
	margin-bottom: 0;
}

/* phones & tablet */
@media only screen and (max-width: 1023px) {
	#main div.btn {
		text-align: center;
	}

	#main div.btn a {
		width: 193px;
		height: 40px;
		font-size: 115%; /* 16px */
		line-height: 40px;
		display: inline-block;
	}
}


/* pagination
-------------------------------------------------------------------------- */

#main nav.pagination {
	margin-top: 50px;
	text-align: center;
}

#main nav.pagination ul li {
	margin: 0 15px;
	font-size: 143%; /* 20px */
	line-height: 1;
	list-style: none;
	display: inline-block;
}

#main nav.pagination ul li a {
	padding: .25em 0;
	color: #203880;
	display: block;
}
#main nav.pagination ul li a:hover,
#main nav.pagination ul li a.current {
	border-bottom: 2px solid #203880;
	text-decoration: none;
}

#main nav.pagination ul li img {
	width: 8px;
	height: 10px;
}