@charset "UTF-8";

/* ===============================================
 * CSSリセット
 * =============================================== */

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
}

body {
	line-height: 1
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block
}

ul {
	list-style: none
}

blockquote,
q {
	quotes: none
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: none
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent
}

del {
	text-decoration: line-through
}

abbr[title],
dfn[title] {
	border-bottom: 1px dotted;
	cursor: help
}

table {
	border-collapse: collapse;
	border-spacing: 0
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0
}

input,
select {
	vertical-align: middle
}


/* ================================================
 * 一般・共通設定 
 * ================================================ */


/* コンテンツ幅1280px */

html {
	min-height: 100%;
	position: relative;
}

body {
	margin-bottom: 7em;
	font-size: 0.9em;
	color: #333;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	line-height: 1.6;
	background: #fefefe;
/*	background-position: 0 0 10px 10px;*/
	background-size: 20px 20px;
}

.inner {
	position: relative;
	max-width: 1280px;
	width: 100%;
	margin: 0 auto;
}

header {
	box-sizing: border-box;
	position: relative;
	background: #fff;
}

nav {
	width: 100%;
	background: #fff;
	box-shadow: 0 1px 2px #d0d8dc;
}

nav:after {
	content: '';
	display: block;
	clear: both;
}

#contents {
	overflow: hidden;
	max-width: 1240px;
	width: calc(100% - 40px);
	margin: 10px auto;
	padding: 10px;
	background: #fff;
}

#main {
	box-sizing: border-box;
	overflow: hidden;
	float: none;
	width: 100%;
	margin-bottom: 1em;
}

a {
	color: #000;
}

a:hover {
	color: #d90030;
	text-decoration: none;
	transition: all .3s ease;
	-webkit-transition: all .3s ease;
}

img a:hover {
	background: #fff!important;
	opacity: 0.7;
}


/* ===============================================
 * 見出し
 * =============================================== */

h2 {
	clear: both;
	font-size: 1.8em;
	font-weight: bold;
	position: relative;
	margin-bottom: 5px;
	padding-bottom: 0.4em;
}


/*疑似要素*/

h2:before {
	font-family: FontAwesome;
	content: "\f14a";
	position: absolute;
	/*左端からのアイコンまでの距離*/
	left: .4em;
	line-height: 1.3em
}

.bg1,
.bg2,
.bg3 {
	background: #ccc;
	border-top: #ccc solid 1px;
	border-right: #999 solid 1px;
	border-bottom: #999 solid 1px;
	border-left: #ccc solid 1px;
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.5) inset;
	background-image: -webkit-gradient(linear, left top, left bottom, from( rgba(160, 160, 160, 1.0)), color-stop(0.25, rgba(255, 255, 255, 1.0)), color-stop(0.30, rgba(250, 250, 250, 1.0)), color-stop(0.36, rgba(255, 255, 255, 1.0)), color-stop(0.50, rgba(250, 250, 250, 1.0)), color-stop(0.80, rgba(155, 155, 155, 1.0)), to( rgba(150, 150, 150, 1.0)));
	background-image: -webkit-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	background-image: -moz-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	background-image: -o-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	background-image: linear-gradient(to bottom, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
}

h3 {
	clear: both;
	position: relative;
	margin-top: 10px;
	margin-bottom: 5px;
	padding: 10px 10px 10px 30px;
	font-size: 1.6em!important;
	font-weight: bold;
	color: #333;
	background: #ccc;
	border-top: #ccc solid 1px;
	border-right: #999 solid 1px;
	border-bottom: #999 solid 1px;
	border-left: #ccc solid 1px;
	text-shadow: 1px 1px 0 rgba(255, 255, 255, 1);
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.5) inset;
	background-image: -webkit-gradient(linear, left top, left bottom, from( rgba(160, 160, 160, 1.0)), color-stop(0.25, rgba(255, 255, 255, 1.0)), color-stop(0.30, rgba(250, 250, 250, 1.0)), color-stop(0.36, rgba(255, 255, 255, 1.0)), color-stop(0.50, rgba(250, 250, 250, 1.0)), color-stop(0.80, rgba(155, 155, 155, 1.0)), to( rgba(150, 150, 150, 1.0)));
	background-image: -webkit-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	background-image: -moz-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	background-image: -o-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	background-image: linear-gradient(to bottom, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
}

h3:before {
	content: " ";
	position: absolute;
	top: 0;
	left: 15px;
	width: 0;
	height: 100%;
	border-left: #ccc solid 1px;
}

h3:after {
	content: " ";
	position: absolute;
	top: 0;
	left: 16px;
	width: 0;
	height: 100%;
	border-right: #eee solid 1px;
}

@media (max-width: 768px) {
	h3 {
		clear: both;
		position: relative;
		margin-top: 5px;
		margin-bottom: 3px;
		padding: 5px 5px 5px 10px;
		font-size: 1.6em!important;
		font-weight: bold;
		color: #333;
		background: #ccc;
		border-top: #ccc solid 1px;
		border-right: #999 solid 1px;
		border-bottom: #999 solid 1px;
		border-left: #ccc solid 1px;
		text-shadow: 1px 1px 0 rgba(255, 255, 255, 1);
		box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.5) inset;
		background-image: -webkit-gradient(linear, left top, left bottom, from( rgba(160, 160, 160, 1.0)), color-stop(0.25, rgba(255, 255, 255, 1.0)), color-stop(0.30, rgba(250, 250, 250, 1.0)), color-stop(0.36, rgba(255, 255, 255, 1.0)), color-stop(0.50, rgba(250, 250, 250, 1.0)), color-stop(0.80, rgba(155, 155, 155, 1.0)), to( rgba(150, 150, 150, 1.0)));
		background-image: -webkit-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
		background-image: -moz-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
		background-image: -o-linear-gradient(top, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
		background-image: linear-gradient(to bottom, rgba(160, 160, 160, 1.0), rgba(255, 255, 255, 1.0) 25%, rgba(250, 250, 250, 1.0) 30%, rgba(255, 255, 255, 1.0) 36%, rgba(250, 250, 250, 1.0) 50%, rgba(155, 155, 155, 1.0) 80%, rgba(150, 150, 150, 1.0));
	}
	h3:before {
		content: " ";
		position: absolute;
		top: 0;
		left: 5px;
		width: 0;
		height: 100%;
		border-left: #ccc solid 1px;
	}
	h3:after {
		content: " ";
		position: absolute;
		top: 0;
		left: 6px;
		width: 0;
		height: 100%;
		border-right: #eee solid 1px;
	}
}

h4 {
	margin-bottom: 0.25em;
	font-size: 1.2em;
	font-weight: bold;
	color: #096ca1;
	border-bottom: 3px solid #76c0fe;
}

h5 {
	position: relative;
	margin-bottom: 0.25em;
	padding-left: 10px;
	color: #76c0fe;
	font-size: 1em;
	font-weight: bold;
}

h5:before {
	content: "";
	margin-top: -7px;
	position: absolute;
	top: 50%;
	left: 0;
	width: 5px;
	height: 14px;
	background: #76c0fe;
}

h6 {
	margin-bottom: 0.25em;
	color: #096ca1;
	font-size: 0.87em;
	font-weight: bold;
}

p {
	margin-left: 1em;
	margin-right: 1em;
}

img {
	vertical-align: bottom;
}

em {
	font-weight: bold;
}

strong {
	font-weight: bold;
}

pre {
	margin: 1em 0;
	padding: 1em;
}

blockquote {
	margin-bottom: 1em;
	padding: 1em;
	border: 1px dotted #ddd;
	border-left: 5px solid #ddd;
}

ul,
ol,
dl {
	margin: 0 0 1em 0;
}

ul li {
	list-style: disc;
}

ol li {
	list-style: decimal;
}

li {
	margin-left: 2em;
}

dt {
	margin-bottom: 0.5em;
}

dd {
	margin-bottom: 1em;
}

.ttl_01 {
	font-size: 1.2em;
	font-weight: bold;
}


/* ===============================================
 * フォーム
 * =============================================== */

table {
	width: 100%;
	margin-bottom: 1em;
	border-collapse: collapse;
	border: 1px solid #ddd;
	background: #fff;
}

th {
	word-break: normal;
	padding: 10px;
	text-align: left;
	border: 1px solid #ddd;
	background: #eee;
	font-weight: bold;
}

td {
	padding: 10px;
	text-align: left;
	border: 1px solid #ddd;
}


/* スマホ用 */

@media (max-width: 768px) {
	table {
		width: 100%;
	}
	table th,
	table td {
		display: block;
		width: 100%;
		padding: 10px;
	}
	table.formTable th {
		width: 100%;
	}
	input[type="text"] {
		margin-top: 2px;
		margin-bottom: 2px;
	}
}

.equal_table {}

.equal_table table {
	table-layout: fixed;
	max-width: calc( 100% - 20px);
	width: auto;
	margin-left: 10px;
}

.equal_table th {
	font-weight: 900;
	font-size: 1.2em;
}

.equal_table td {
	font-size: 1.2em;
	min-width: 5.5em;
}

@media (max-width: 768px) {
	.equal_table table {
		width: 100%;
	}
	.equal_table table th {
		width: auto;
	}
	.equal_table table td {
		width: auto;
		padding: 3px 10px;
	}
}

input[type="text"],
input[type="tel"],
input[type="email"],
input[type="url"],
textarea {
	margin: 2px;
	padding: 0.4em;
	outline: none;
	border: 1px solid #aaa;
	background: #eee;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	font-size: 16px;
}

input[type="text"]:focus,
texture:focus,
textarea:focus {
	box-shadow: 0 0 7px #3498db;
	border: 1px solid #3498db;
}

select {
	font-size: 1.1em;
	padding: 0.4em;
	border: 1px solid #DDD;
}

input[type=checkbox],
input[type=radio] {
	width: 20px;
	height: 20px;
	vertical-align: middle;
}


/* 幅指定 */

.w10 {
	width: 10%;
}

.w15 {
	width: 15%;
}

.w20 {
	width: 20%;
}

.w100 {
	width: 100%;
}

.r_w30 {
	width: 30%;
}

.r_w50 {
	width: 50%;
}

.r_w70 {
	width: 70%;
}

.r_w100 {
	width: 90%;
}

@media screen and (max-width:767px) {
	.r_w30,
	.r_w50,
	.r_w70,
	.r_w100 {
		width: 90%;
	}
}

.img_w100 {
	width: calc(100% - 15px);
	border: 5px solid #fff;
	border-radius: 4px;
	box-shadow: 1px 1px 5px rgb(20 20 20 / 20%);
	margin-bottom: 10px;
	margin-left: 2px;
	margin-right: 2px;
}


/* ボタン（送信する・リセットなど） */

button {
	padding: 10px;
	background-image: -moz-linear-gradient( top, #49a9d4 0%, #49a9d4 49%, #419cd8 50%, #419cd8);
	background-image: -webkit-gradient( linear, left top, left bottom, from(#49a9d4), color-stop(0.49, #49a9d4), color-stop(0.50, #419cde8), to(#419cd8))
}

button:hover {
	/* 透明度を20%に指定 */
	opacity: 0.8;
}

a.button_back {
	display: block;
	margin-left: auto;
	margin-right: auto;
	width: 250px;
	font-size: 1.2em;
	font-weight: bold;
	background: #9a0000;
	height: 50px;
	line-height: 50px;
	border: 5px solid #9a0000;
	color: #fff;
}

a.button_back:hover {
	/* 透明度を20%に指定 */
	opacity: 0.8;
}

.submitbtn a {
	color: #fff;
}

.submitbtn {
	position: relative;
	border: 1px solid #ccc;
	border-radius: 5px;
	background: #9a0000;
	color: #fff;
	padding: 10px 50px;
	font-size: 1.1em;
	font-weight: bold;
}

.submitbtn:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 10px;
	width: 6px;
	height: 6px;
	margin: -4px 0 0 0;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.mfp_buttons {
	text-align: center;
}

:valid+.icon-validation::before {
	content: " \f14a";
	font-family: FontAwesome;
	font-size: 1em;
	color: green;
	margin-right: 10px;
	margin-top: -10px;
}


/* 必須アイコン */

.req:before {
	content: "必須";
	background: #f00;
	color: #fff;
	border: solid 1px #f00;
	/* 罫線 */
	margin-right: 5px;
	padding-left: 5px;
	padding-right: 5px;
	border-radius: 10px;
	/* 角丸 */
}


/* 任意アイコン */

.any:before {
	content: "任意";
	background: #444c9c;
	color: #fff;
	border: solid 1px #444c9c;
	/* 罫線 */
	margin-right: 5px;
	padding-left: 5px;
	padding-right: 5px;
	border-radius: 10px;
	/* 角丸 */
}


/* ===============================================
 * PC用とSP用で画像/コンテンツ切り替え
 * =============================================== */

@media screen and (max-width:767px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
}

@media print,
screen and (min-width:768px) {
	.pc {
		/*display: block !important;*/
	}
	.sp {
		display: none !important;
	}
}

@media screen and (min-width: 768px) {
	.br-sp {
		display: none;
	}
}


/* ===============================================
 * ヘッダー 
 * =============================================== */

.summary {
	position: absolute;
	top: 0;
	right: 20px;
	margin: 0;
}

@media screen and (max-width:767px) {
	h1 {
		height: 75px;
	}
	h1 img {
		margin-left: 0px;
		text-align: left;
		max-width: 485px;
		width: calc(100% - 60px);
		max-height: 70px;
	}
}


/* ===============================================
 * ユニバーサルメニュー（文字サイズ・背景色変更）
 * =============================================== */

.module {
	font-size: 1.3em;
	margin-top: 20px;
	margin-left: 10px;
	line-height: 24px;
	display: inline-block;
	/*for modern*/
	/zoom: 1;
	/*for ie5～7*/
	padding: 0;
}

.module ul li {
	list-style-type: none;
	display: inline-block;
	margin-left: 2px;
}

.module2 {
	font-size: 1.3em;
	margin-left: 20px;
	line-height: 24px;
	display: inline-block;
	/*for modern*/
	/zoom: 1;
	/*for ie5～7*/
	padding: 0;
}

.module2 ul li {
	list-style-type: none;
	display: inline-block;
	margin-left: 2px;
}

#font_size li img {
	height: 24px;
}


/* 1080～768px */

@media screen and (max-width:1080px) {
	.module {
		font-size: 1em;
		margin-top: 15px;
		margin-left: 30px;
		line-height: 20px;
		display: block;
		/*for modern*/
		/zoom: 1;
		/*for ie5～7*/
		padding: 0;
	}
	.module ul li {
		list-style-type: none;
		display: inline-block;
		margin-left: 2px;
	}
	.module2 {
		font-size: 1em;
		margin-top: 2px;
		margin-left: 60px;
		line-height: 20px;
		display: block;
		/*for modern*/
		/zoom: 1;
		/*for ie5～7*/
		padding: 0;
	}
	.module2 ul li {
		list-style-type: none;
		display: inline-block;
		margin-left: 2px;
	}
	#font_size li img {
		height: 20px;
	}
}


/* ～768px */

@media screen and (max-width:768px) {
	.module {
		font-size: 1.1em;
		margin-top: 5px;
		margin-left: 30px;
		line-height: 24px;
		display: inline-block;
		/*for modern*/
		/zoom: 1;
		/*for ie5～7*/
		padding: 0;
	}
	.module ul li {
		list-style-type: none;
		display: inline-block;
		margin-left: 2px;
	}
	.module2 {
		font-size: 1.1em;
		margin-top: 5px;
		margin-left: 60px;
		line-height: 24px;
		display: inline-block;
		/*for modern*/
		/zoom: 1;
		/*for ie5～7*/
		padding: 0;
	}
	.module2 ul li {
		list-style-type: none;
		display: inline-block;
		margin-left: 2px;
	}
	#font_size li img {
		height: 24px;
	}
}

@media print {
	.module,
	.module2 {
		display: none;
	}
}


/* ===============================================
 * グローバルナビゲーション
 * =============================================== */

@media print,
screen and (min-width:768px) {
	nav {
		background: -moz-linear-gradient(top, #9a0000, #d82b2b);
		background: -webkit-linear-gradient(top, #9a0000, #d82b2b);
		background: linear-gradient(to bottom, #9a0000, #d82b2b);
		border-bottom: 3px double #ccc;
		height: 50px;
		font-size: 1em;
		z-index: 993;
	}
	/* 1段目 */
	nav ul {
		text-align: center;
		margin: 0;
		padding: 0;
		position: relative;
	}
	nav ul li {
		width: 17%;
		float: left;
		margin: 0;
		padding: 0;
		text-align: center;
		list-style: none;
		border-right: 1px solid #ccc;
		position: relative;
	}
	nav ul li:last-child {
		width: 14%;
		border-right: 0px;
	}
	nav ul li a {
		display: block;
		margin: 0;
		padding: 0;
		background: -moz-linear-gradient(top, #9a0000, #d82b2b);
		background: -webkit-linear-gradient(top, #9a0000, #d82b2b);
		background: linear-gradient(to bottom, #9a0000, #d82b2b);
		color: #eee;
		font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
		font-size: 1.4em;
		font-weight: bold;
		line-height: 50px;
		text-decoration: none;
		/* ここで動く速度とか設定 */
		transition: all .3s ease;
		-webkit-transition: all 1s ease;
	}
	nav ul>li:hover>a {
		display: block;
		background: #aaa;
		color: #fff;
	}
	nav ul .subnav>a:after {
		position: absolute;
		content: "";
		top: 20px;
		width: 0;
		height: 0;
		margin-left: 10px;
		border: 5px solid transparent;
		border-top-color: #fff;
	}
	nav ul .subnav .subnav>a:after {
		content: "";
		border: none;
	}
	/* 2段目 */
	nav ul li ul {
		list-style: none;
		position: absolute;
		z-index: 993;
		top: 100%;
		left: 0;
		width: 100%;
		margin: 0;
		padding: 0;
	}
	nav ul li ul li {
		overflow: hidden;
		width: 150%;
		height: 0;
		color: #fff;
		transition: .2s;
	}
	nav ul li ul li:first-child {
		width: 150%;
	}
	nav ul li ul li a {
		padding: 13px 15px;
		text-align: left;
		background: #7c0c0c;
		font-weight: normal;
	}
	nav ul li:hover>ul>li {
		overflow: visible;
		height: 40px;
		border-bottom: 1px solid #8c0e0e;
	}
	nav ul li:hover ul li:last-child {
		border-bottom: none;
	}
	nav ul li:last-child ul {
		left: -50%;
	}
	nav ul li ul li ul:before {
		position: absolute;
		content: "";
		top: 13px;
		left: -20px;
		width: 0;
		height: 0;
		border: 5px solid transparent;
		border-left-color: #fff;
	}
	nav ul li:last-child ul li ul:before {
		position: absolute;
		content: "";
		top: 13px;
		left: 200%;
		margin-left: -20px;
		border: 5px solid transparent;
		border-right-color: #fff;
	}
	/* 3段目 */
	nav ul li ul li ul {
		top: 0;
		left: 100%;
	}
	nav ul li ul li ul li {
		width: 100%;
	}
	nav ul li ul li ul li:first-child {
		width: 100%;
	}
	nav ul li ul li:hover ul li {
		border-bottom: 1px solid #6d0c0c;
	}
	nav ul li:last-child ul li ul {
		left: -100%;
	}
	nav ul li ul li ul li a {
		background: #590000;
	}
	nav ul li ul li ul li a:hover {
		background: #420404;
	}
	.gnav {
		display: block !important;
	}
	#spMenu {
		display: none;
	}
	.fixed {
		position: fixed;
		top: 0;
		left: 0;
	}
}


/* ===============================================
 * トピックパス（パンくずリスト） 
 * =============================================== */

#topicpath {
	height: 30px;
	margin-bottom: 20px;
	padding: 10px 5px 5px 2px;
	background: #fff;
}

.breadcrumb {
	line-height: 30px;
	padding: 1px;
	width: 100%;
}

ol.breadcrumb {
	list-style-type: none;
}

ol.breadcrumb li {
	float: left;
	display: block;
}

ol.breadcrumb li a {
	display: block;
	background: #9a0000;
	height: 30px;
	position: relative;
	text-decoration: none;
	color: #fff;
	transition: all 1s ease;
	-webkit-transition: all 1s ease;
}

ol.breadcrumb li a:before {
	content: "";
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: 0;
	left: -30px;
	border: 15px solid transparent;
	background: #9a0000;
	border-left-color: transparent;
	transition: all 1s ease;
	-webkit-transition: all 1s ease;
}

ol.breadcrumb li a:after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: 0;
	right: -30px;
	border: 15px solid transparent;
	border-left-color: #9a0000;
	transition: all 1s ease;
	-webkit-transition: all 1s ease;
}

ol.breadcrumb li:first-child a {
	margin-left: -30px;
	padding-left: 15px;
}

ol.breadcrumb li:first-child a:before {
	display: none;
}

ol.breadcrumb li a:hover {
	background: #888;
	color: #fff;
	text-decoration: none;
}

ol.breadcrumb a:hover:before {
	background: #888;
	border-left-color: transparent;
}

ol.breadcrumb li a:hover:after {
	border-left-color: #888;
}

.banner li {
	font-size: 1.6em!important;
	/*font-weight:bold;*/
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

p {
	font-size: 1.4em;
	padding: 5px;
}

.size-25 {
	padding-left: 15px;
	padding-right: 15px;
	font-size: 125%;
}

p .hidari {
	float: left;
	margin-right: 2em;
	margin-bottom: 1em;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

p .migi,
p .migi2 {
	float: right;
	margin-left: 2em;
	margin-bottom: 1em;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

@media screen and (max-width:768px) {
	p .migi {
		display: none;
	}
	p .migi2 {
		max-width: 100%;
		float: none;
		display: block;
		margin: auto;
	}
	p .sp_on {
		width: 100%;
	}
	p .sp_img {
		display: block;
		margin: auto;
		max-width: 100%;
		width: auto;
	}
}

@media screen and (min-width:769px) {
	p .sp_on,
	p .sp_img {
		display: none;
	}
}

.narabi {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	max-width: 380px;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}


/* ===============================================
 * 2列
 * =============================================== */

.narabi-2 {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	width: 48%;
	height: auto;
	border: 10px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

@media (max-width: 767px) {
	.narabi-2 {
		width: 100%!important;
		height: auto;
	}
}


/* ===============================================
 * 3列
 * =============================================== */

.narabi-3 {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	width: 370px;
	height: auto;
	/*height: 278px;*/
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

.narabi-3_2 {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	width: 750px;
	height: 278px;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

@media screen and (max-width:1280px) {
	.narabi-3 {
		width: 31%;
		height: auto;
	}
	.narabi-3_2 {
		width: 63%!important;
		height: auto!important;
	}
}


/* ===============================================
 * 4列
 * =============================================== */

.narabi-4 {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	width: 25%;
	height: auto;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

.narabi-4_2 {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	width: 47%;
	height: auto;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

@media screen and (max-width:1090px) {
	.narabi-4 {
		width: 32%;
		height: auto;
	}
	.narabi-4_2 {
		width: 60%!important;
		height: auto!important;
	}
}


/* ===============================================
 * バナー広告
 * =============================================== */

.narabi-4col {
	text-align: center;
	margin-left: 1em;
	margin-right: -.7em;
	margin-bottom: 1em;
	width: 23%;
	border: 5px solid #fff;
	border-radius: 4px;
	/* ドロップシャドウ 【横位置 縦位置 ぼかし幅 色】の順に記述 */
	box-shadow: 1px 1px 5px rgba(20, 20, 20, 0.2);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

.clear {
	clear: both;
}

a:hover img {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
}

.list_normal {
	margin-left: -1em;
	font-size: 0.9em;
}

.bold {
	font-weight: bold;
}


/* 字下げ */

li.indent {
	list-style: none;
	padding-left: 1em;
	text-indent: -1em;
}


/* ===============================================
 * 和歌山智翔会を応援していただいている会社・団体
 * =============================================== */

.ouen_word {
	display: flex;
	justify-content: center;
	margin: 0;
	padding: 0;
}

.ouen_word li {
	display: inline;
	margin: 3px;
}

.ouen_word img {
	width: 100%;
}

@media screen and (max-width:768px) {
	.ouen_word {
		margin: 0;
		padding: 0;
		flex-wrap: wrap;
		flex-direction: row;
		justify-content: center;
	}
	.ouen_word li {
		display: inline-block;
		margin: 2px;
		width: calc( 50% - 10px);
	}
}

@media screen and (max-width:400px) {
	.ouen_word li {
		width: 100%;
	}
}


/* ===============================================
 * フッター
 * =============================================== */

footer {
	clear: both;
	width: 100%;
	margin: 0 auto;
	bottom: 0;
	background: #9a0000;
	height: 7em;
	position: absolute;
}

.footer-contents {
	/*overflow:hidden;*/
	max-width: 1240px;
	width: calc(100% - 40px);
	height: 7em;
	margin: 0 auto;
	padding: 0;
	background: #9a0000;
}

.copyright {
	clear: both;
	width: 100%;
	margin-top: 5px;
	padding: 10px;
	text-align: center;
	color: #fff;
	background: #9a0000;
	font-size: 1.4em;
}

.policy {
	float: right;
	color: #fff;
	margin-top: 10px;
	font-size: 1.4em;
}

@media screen and (max-width:850px) {
	body {
		margin-bottom: 12em;
	}
	footer {
		height: 12em;
	}
	.footer-contents {
		height: 12em;
	}
}

@media screen and (max-width:768px) {
	.policy {
		position: relative;
		bottom: 0;
		right: 0;
	}
}

.policy a {
	color: #fff;
}

.policy a:hover {
	background-color: #888;
	color: #fff;
}

h1 a:hover {
	background: #fff;
	opacity: 0.8;
}


/* ===============================================
 * タブレット・スマートフォン向けデザイン
 * =============================================== */

@media screen and (max-width:980px) {
	.narabi-4col {
		width: 45%;
	}
	nav ul li a {
		font-size: 1.1em;
	}
}

@media screen and (max-width:880px) {
	.narabi-4col {
		width: 45%;
	}
}

@media screen and (max-width:767px) {
	body {
		font-size: 0.7em;
	}
	.inner {
		min-width: 320px;
		width: 100%;
	}
	#contents {
		box-sizing: border-box;
		min-width: 320px;
		width: 100%;
		padding: 0 10px;
	}
	header {
		z-index: 992;
		box-sizing: border-box;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		padding: 5px 10px;
	}
	.summary {
		position: relative;
		top: auto;
		right: auto;
		margin-top: 2px;
	}
	#main {
		float: none;
		width: 100%;
	}
	footer {
		width: 100%;
	}
	nav {
		background: #9a0000;
	}
	nav ul {
		margin: 0;
		padding: 0;
	}
	nav .inner>ul {
		z-index: 992;
		overflow: auto;
		position: fixed;
		top: 70px;
		right: 0;
		width: 100%;
		height: 88%;
		height: -webkit-calc(100% - 63px);
		height: calc(100% - 63px);
	}
	nav li {
		position: relative;
		width: 100%;
		float: none;
		margin: 0;
		text-align: left;
		list-style: none;
		border-bottom: 1px solid #eee;
		background: #9a0000;
	}
	nav li:first-child {
		border-top: 0;
	}
	nav li:last-child {
		border-bottom: 0;
	}
	nav li a {
		display: block;
		padding: 10px 30px;
		font-size: 1.6em!important;
		font-weight: bold;
		color: #fff;
		text-decoration: none;
		background: #9a0000;
	}
	nav li a:hover {
		color: #fff;
		background: #888;
	}
	nav ul ul {
		display: none;
		position: relative;
	}
	nav li li a {
		box-sizing: border-box;
		width: 100%;
		padding: 10px 30px 10px 50px;
		text-align: left;
	}
	nav li li li a {
		padding: 10px 30px 10px 70px;
	}
	.gnav li a:after {
		content: attr(data-label);
	}
	.gnav li img {
		display: none;
	}
	.subnav>a:before {
		display: block;
		content: "";
		position: absolute;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		top: 20px;
		right: 30px;
		width: 10px;
		height: 10px;
		margin-top: -5px;
		background: #f1f1f1;
	}
	.subnav>a:after {
		display: block;
		content: "";
		position: absolute;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		top: 20px;
		right: 30px;
		width: 10px;
		height: 10px;
		margin-top: -10px;
		background: #17184b;
	}
	.subnav a:hover:after {
		background: #710000;
	}
	.active>a:before {
		margin-top: 0;
	}
	.active>a:after {
		margin-top: 5px;
	}
	.gnav {
		display: none;
	}
	#spMenu {
		display: block;
		z-index: 992;
		position: fixed;
		top: 10px;
		right: 10px;
	}
	#spMenu:hover {
		cursor: pointer;
	}
	#navBtn {
		display: inline-block;
		position: relative;
		width: 50px;
		height: 50px;
		border-radius: 5%;
		background: #9a0000;
	}
	#navBtnIcon {
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		width: 40px;
		height: 8px;
		margin: -4px 0 0 -20px;
		background: #f1f1f1;
		transition: .2s;
	}
	#navBtnIcon:before,
	#navBtnIcon:after {
		display: block;
		content: '';
		position: absolute;
		top: 50%;
		left: 0;
		width: 40px;
		height: 8px;
		background: #f1f1f1;
		transition: 0.3s;
	}
	#navBtnIcon:before {
		margin-top: -20px;
	}
	#navBtnIcon:after {
		margin-top: 12px;
	}
	#navBtn .close {
		background: transparent;
	}
	#navBtn .close:before,
	#navBtn .close:after {
		margin-top: -5px;
	}
	#navBtn .close:before {
		transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
	}
	#navBtn .close:after {
		transform: rotate(-135deg);
		-webkit-transform: rotate(-135deg);
	}
	.center_top {
		text-align: center;
	}
	.img_responsive {
		width: 100%;
	}
	.hidari {
		width: 100%;
	}
	.narabi-4col {
		width: 100%;
	}
	p .narabi,
	p .narabi-3,
	p .narabi-3_2 {
		float: left;
		margin-left: 0em;
		margin-bottom: 1em;
		width: 100% !important;
		height: 100% !important;
	}
}


/* 背景画像固定 */

.banner {
	clear: both;
	background-color: #fff;
	background-image: url(parallax.jpg);
	background-color: rgba(255, 255, 255, 0.7);
	background-blend-mode: lighten;
	min-height: 380px;
	background-attachment: fixed;
	background-size: cover;
	background-repeat: no-repeat;
	margin-bottom: -10px;
}

.parallax {
	padding-left: 50px;
	padding-top: 20px;
	letter-spacing: 2px;
	margin-top: 0px;
}

.parallax_description {
	clear: both;
	padding-top: 10px;
	padding-left: 20px;
	padding-right: 20px;
}

.parallax_w100 {
	max-width: 100%;
	padding-top: 10px;
	padding-left: 20px;
	padding-right: 20px;
}


/* 登録ボタン */

.footer_banner {
	background-color: #b3b3b3;
	padding-top: 10px;
	padding-bottom: 10px;
	margin-bottom: 0px;
	background: #aaa;
	background-repeat: repeat;
}

.button {
	width: 70%;
	margin-top: 10px;
	font-size: 2em;
	background: -moz-linear-gradient(top, #9a0000, #d82b2b);
	background: -webkit-linear-gradient(top, #9a0000, #d82b2b);
	background: linear-gradient(to bottom, #9a0000, #d82b2b);
	margin-right: auto;
	margin-bottom: auto;
	margin-left: auto;
	padding: 20px 10px;
	text-align: center;
	vertical-align: middle;
	border-radius: 0px;
	text-transform: uppercase;
	font-weight: bold;
	letter-spacing: 2px;
	color: #fff;
	border: 3px solid #fff;
	transition: all 0.3s linear;
}

.button a {
	display: block;
	color: inherit;
	text-decoration: none;
}

.button:hover {
	background: #888;
	cursor: pointer;
}

.hidden {
	display: none;
}


/* SP用　320px */

@media (max-width: 320px) {
	.banner {
		background-color: #fff;
		background-image: none;
	}
}


/* 321pxから767px */

@media (max-width: 767px) {
	h2 {}
	h2:before {
		/*疑似要素*/
		font-family: FontAwesome;
		content: "\f14a";
		position: absolute;
		left: 2em;
		/*左端からのアイコンまでの距離*/
	}
	.parallax {
		width: 90%;
		margin-left: -2em;
		padding-left: 3.5em;
		margin-right: 2em;
		padding-right: 4em;
		font-size: 1.6em !important
	}
	.parallax_description {
		padding: 0;
		margin: 10px 0 0 0;
		float: none;
		width: 100%;
		text-align: center;
	}
	.parallax_description {
		text-align: left;
	}
	.banner {
		padding-left: 5px;
		padding-right: 5px;
	}
	.footer_column {
		width: 100%;
	}
}


/* 768pxから1096px */

@media (min-width: 768px) and (max-width: 1096px) {
	.banner {
		margin-top: 0px;
		padding-top: 0px;
	}
}


/* ===============================================
 * ページトップへの戻り
 * =============================================== */

#page-top {
	position: fixed;
	bottom: 0.5em;
	right: 15px;
}

#page-top img {
	background: #9a0000;
	border: solid 3px #fff;
}

#page-top img:hover {
	background: #333;
}


/* ===============================================
 * リンクアイコン（FontAwesome使用）
 * =============================================== */

.banner a[target="_blank"]:after {
	margin: 0 3px;
	font-family: FontAwesome;
	vertical-align: middle;
	content: '\f08e';
}

.btn_right {
	display: block;
	float: right;
	margin: -10px 5px 5px;
	padding: 5px 10px;
	background: #aaa;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	color: #000;
	font-size: 20px;
	font-weight: normal;
	text-decoration: none;
	border: 2px solid #fff;
}

.btn_right:hover {
	background: #888;
	color: #fff;
}


/* スマホ用 */

@media (max-width: 768px) {
	.btn_right {
		margin: -12px 0px 3px 3px;
		border: 1px solid #fff;
		font-size: 16px;
	}
}


/* 広告用ボタン */

.btn_koukoku {
	display: block;
	float: right;
	margin: 10px 5px 5px;
	padding: 10px;
	background: #ccc;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	color: #000;
	font-size: 20px;
	font-weight: bold;
	text-decoration: none;
	border: 2px solid #fff;
}


/* スマホ用 */

@media (max-width: 768px) {
	.btn_koukoku {
		margin: -12px 0px 3px 3px;
		border: 1px solid #fff;
		font-size: 16px;
	}
}


/* ===============================================
 * スマホでのみ改行
 * =============================================== */

@media screen and (min-width: 900px) {
	.br-sp {
		display: none;
	}
}

@media screen and (min-width: 801px) {
	.sp_mini {
		font-size: 18px!important;
	}
}

@media screen and (max-width: 800px) {
	.sp_mini {
		font-size: 14px!important;
	}
}



#p230718{
	display:block;
	margin-top:2em;
	height:2em;

}