/* ##############################################################
#
#    base
#    
############################################################## */

/* ##############################################################
#    layout
############################################################## */
#wrapper {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 100%;
    margin: 0;
	padding: 0 0 27px;
	/*background: url(../images/special/inochinomori/mv.jpg) center top repeat;
	background-size: 100%;*/
}

#bg {
	position: fixed;
	z-index: -1;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
#bg video {
	position: absolute;
	left: 0;
	top: 0;
	min-height: 100%;
	min-height: 100vh;
	min-width: 100%;
	min-width: 100vw;
}


/* ##############################################################
#    #header
############################################################## */
#header {
	position: relative;
	width: 100%;
	min-width: 1000px;
	height: 100vh;
	color: #fff;
	/*background: url(../images/special/inochinomori/mv.jpg) center center no-repeat;
	background-size: cover;*/
}
#header .main {
	height: 100%;
}
#header h2 {
	position: absolute;
	left: 14px;
	top: 15px;
	background: #fff;
	padding: 3px;
}
#header h2 img {
	width: auto;
	height: 38px;
}
#header .text {
	position: relative;
    top: calc(50% - 167.5px);
	width: 76.95%;
	margin: 0 auto;
	font-size: 17px;
	font-weight: bold;
}
#header .text h1 {
	margin-bottom: 40px;
	line-height: 97px;
	font-size: 97px;
}
#header .text h1 sub {
	font-size: 0.6em;
	display: inline-block;
	transform: translate(0%, 0.5em);
	text-decoration: none !important;
}
#header .text .subtitle {
	margin-bottom: 20px;
	line-height: 28px;
	font-size: 28px;
}
#header .text .desc {
	line-height: 30px;
}
#header nav {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 82px;
	background-color: rgba(0,0,0,0.4);
}
#header nav .inner {
	width: 76.95%;
	height: 100%;
	margin: 0 auto;
}
#header nav ul {
	display: -webkit-box;
	display: flex;
	-webkit-justify-content: space-between;
	        justify-content: space-between;
	height: 100%;
	font-size: 15px;
	letter-spacing: 0;
}
#header nav ul li {
	vertical-align: top;
}
#header nav ul li a {
	position: relative;
	display: block;
	height: 100%;
	padding-top: 20px;
	text-decoration: none;
	color: #fff;
}
#header nav ul li a:before {
	content: '';
	position: absolute;
	left: 50%;
	margin-left: -8px;
	bottom: 14px;
	display: block;
	width: 16px;
	height: 14px;
	background: url(../images/special/inochinomori/nav_arrow.png) left top no-repeat;
}


/* ##############################################################
#    #content
############################################################## */
#content {
	position: relative;
	z-index: 1;
	min-width: 1000px;
	padding: 155px 0 134px;
}
#content:after {
	content: '';
	position: absolute;
	z-index: -1;
	left: 0;
	top: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,0.8);
}
#content section {
	position: relative;
	width: 78.13%;
	min-width: 985px;
	margin: 0 auto;
	line-height: 35px;
	font-size: 17px;
}
#content section + section {
	margin-top: 123px;
}
#content section .label {
	position: relative;
	margin-bottom: 65px;
	font-size: 16px;
	color: #fff;
}
#content section .label:before {
	content: '';
	position: absolute;
	left: 0;
	top: calc(50% - 1px);
	width: 100%;
	height: 1px;
	background-color: #e72510;
}
#content section .label span {
	position: relative;
	display: inline-block;
	height: 49px;
	padding: 0 18px;
	line-height: 49px;
	background-color: #e72510;
}
#content section h3 {
	margin-bottom: 83px;
	line-height: 60px;
	font-size: 42px;
	font-weight: normal;
}
#content .item {
	position: relative;
	clear: both;
}
#content .item + .item {
	margin-top: 100px;
}
#content .item h4 {
	margin-bottom: 22px;
}
#content > section .item p + p {
	margin-top: 17px;
}
#content > section .item p + h4 {
	margin-top: 22px;
	margin-bottom: 22px;
}
#content .item .col .left {
	float: left;
	/*width: 48.73%;*/
	width: calc(100% - 505px);
}
#content .item .col .right {
	float: right;
	/*width: 48.22%;*/
	width: 480px;
}
#content .item .col.type2 .left {
	width: 71.57%;
}
#content .item .col.type2 .right {
	width: 25.79%;
}
#content .item .col.type3 .left {
	width: 54.92%;
}
#content .item .col.type3 .right {
	width: 41.73%;
}

#toTop {
	position: fixed;
	z-index: 1;
	right: -80px;
	bottom: 94px;
	-webkit-transition: all 0.4s ease;
			transition: all 0.4s ease;
}

#toTop.show {
	right: 0;
}


/* --------------------------------------------------------------
    .other
-------------------------------------------------------------- */
.caption {
	font-size: 12px;
	text-align: center;
}

.movie {
	position: relative;
	margin-top: 36px;
	padding-top: 56.2%;
}
.movie iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.photo {
	display: -webkit-box;
	display: flex;
	-webkit-justify-content: space-between;
	        justify-content: space-between;
	width: 480px;
	margin-top: 36px;
}
.photo li {
	flex-grow: 1;
}
.photo li + li {
	margin-left: 16px;
}

.shadow {
	-webkit-box-shadow: 0 0 9px 0 rgba(0,0,0,0.2);
	   -moz-box-shadow: 0 0 9px 0 rgba(0,0,0,0.2);
	        box-shadow: 0 0 9px 0 rgba(0,0,0,0.2);
}

.box {
	position: relative;
	margin-top: 22px;
	padding: 16px 17px;
	background-color: #fff;
	box-shadow: 
	-webkit-box-shadow: 0 0 9px 0 rgba(0,0,0,0.2);
	   -moz-box-shadow: 0 0 9px 0 rgba(0,0,0,0.2);
	        box-shadow: 0 0 9px 0 rgba(0,0,0,0.2);
}
.box + .box {
	margin-top: 29px;
}
.box.arrow:before {
	content: '';
	position: absolute;
	left: 50%;
	margin-left: -10.5px;
	bottom: -19px;
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 19px 10.5px 0 10.5px;
	border-color: #ffffff transparent transparent transparent;
}
.box.arrow-right:before {
	content: '';
	position: absolute;
	right: -19px;
	top: 50%;
	margin-top: -10.5px;
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10.5px 0 10.5px 19px;
	border-color: transparent transparent transparent #ffffff;
}
.box h5 {
	margin-bottom: 15px;
	line-height: 25px;
	font-size: 25px;
	color: #59bd57;
}
.box h5:before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 9px;
	height: 43px;
	background-color: #59bd57;
}
#content .item .col.type3 .box {
	margin-top: 0;
}

#content .item table th {
	width: 160px;
	padding-bottom: 34px;
	font-weight: normal;
	text-align: left;
}
#content .item table td {
	padding-bottom: 34px;
}
#content .item .banner {
	width: 49.75%;
}

.red {
	color: #e72510;
}




/* ##############################################################
#    #footer
############################################################## */
#footer {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	min-width: 1000px;
	height: 27px;
	background-color: #f8f8f8;
}
#footer nav {
	position: absolute;
	left: 8px;
	top: auto;
}
#footer nav li {
	line-height: 27px;
	font-size: 11px;
}
#footer nav li a {
	color: #000;
	text-decoration: none;
}
#footer .copy {
	position: absolute;
	right: 6px;
	top: 0;
	line-height: 27px;
	font-size: 10px;
}



/* ##############################################################
#
#    responsive
#
############################################################## */

/* --------------------------------------------------------------
    pc
-------------------------------------------------------------- */
@media print, screen and (min-width: 769px) {
}



/* --------------------------------------------------------------
    sp
-------------------------------------------------------------- */
@media screen and (max-width: 768px) {
	
	/* ##############################################################
	#    layout
	############################################################## */
	#wrapper {
		padding: 0 0 78.5px;
	}


	/* ##############################################################
	#    #header
	############################################################## */
	#header {
		min-width: auto;
		height: auto;
		margin-bottom: 40px;
		background: url(../images/special/inochinomori/mv.jpg) center center no-repeat;
		background-size: cover;
	}
	#header .main {
		padding-bottom: 25px;
		text-shadow: 0px 0px 10px #000000;
	}
	#header h2 {
		position: static;
		/*padding: 10px 0 0 3.13%;*/
		display: inline-block;
		padding: 3px;
		margin: 14px 0 0 15px;
	}
	#header h2 img {
		width: auto;
		/*height: 30px*/
		height: 24px;
	}
	#header .text {
		position: static;
		width: 89.69%;
	    margin: 0 auto;
		padding-top: 30px;
		font-size: 12px;
	}
	#header .text h1 {
		margin-bottom: 25px;
		line-height: 48.5px;
		font-size: 48.5px;
	}
	#header .text .subtitle {
        margin-bottom: 10px;
		line-height: 14px;
		font-size: 14px;
	}
	#header .text .desc {
		line-height: 20px;
	}
	#header nav {
		position: static;
		width: 100%;
		height: auto;
		background-color: rgba(4,7,54,0.5);
	}
	#header nav .inner {
		width: 100%;
	}
	#header nav ul {
		display: block;
		font-size: 10px;
	}
	#header nav ul li {
		display: block;
		padding: 0;
		text-align: center;
	}
	#header nav ul li + li {
		border-top: 0.5px solid #949494;
	}	
	#header nav ul li a {
		display: block;
		padding: 7px 0 21px;
	}
	#header nav ul li a:before {
		margin-left: -4px;
		bottom: 6px;
		width: 8px;
		height: 7px;
		background-size: 100%;
	}


	/* ##############################################################
	#    #content
	############################################################## */
	#content {
		min-width: auto;
		padding: 0 0 100px;
	}
	#content section {
		width: 93.75%;
		min-width: auto;
		line-height: 17.5px;
		font-size: 11px;
	}
	#content section + section {
		margin-top: 80px;
	}
	#content section .label {
		margin-bottom: 22px;
		font-size: 12px;
	}
	#content section .label span {
		height: 34px;
		padding: 0 12px;
		line-height: 34px;
	}
	#content section h3 {
		margin-bottom: 24px;
		line-height: 26px;
		font-size: 18px;
	}
	#content .item + .item {
		margin-top: 30px;
	}
	#content .item h4 {
		margin-bottom: 12px;
		line-height: 17.5px;
		font-size: 13px;
	}
	#content > section .item p + p {
		margin-top: 12px;
	}
	#content > section .item p + h4 {
		margin-top: 12px;
		margin-bottom: 12px;
	}
	#content .item .col .left,
	#content .item .col .right,
	#content .item .col.type2 .left,
	#content .item .col.type2 .right,
	#content .item .col.type3 .left,
	#content .item .col.type3 .right {
		float: none;
		width: 100%;
	}
	#content .item .col .right {
		margin-top: 24px;
	}

	#toTop {
		right: -40px;
		bottom: 78.5px;
		width: 40px;
	}


	/* --------------------------------------------------------------
		.other
	-------------------------------------------------------------- */
	.caption {
		font-size: 12px;
		text-align: center;
	}

	.movie {
		margin-top: 24px;
	}
	
	.photo {
		width: 100%;
	}
	
	.box {
		margin-top: 22px;
		padding: 16px 17px;
	}
	.box.arrow-right:before {
		content: '';
		position: absolute;
		right: auto;
		top: auto;
		left: 50%;
		margin-left: -10.5px;
		bottom: -19px;
		display: block;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 19px 10.5px 0 10.5px;
		border-color: #ffffff transparent transparent transparent;
	}
	.box h5 {
		margin-bottom: 20px;
		line-height: 15px;
		font-size: 15px;
	}
	.box h5:before {
		width: 4.5px;
		height: 34px;
	}

	#content .item table th {
		width: 100px;
		padding-bottom: 24px;
	}
	#content .item table td {
		padding-bottom: 24px;
	}
	#content .item .banner {
		width: 100%;
	}




	/* ##############################################################
	#    #footer
	############################################################## */
	#footer {
		min-width: auto;
		/*height: 78.5px;*/
		padding: 25px 0;
	}
	#footer nav {
		position: static;
		padding: 25px 0;
		text-align: center;
	}
	#footer nav li {
		line-height: 9px;
		font-size: 9px;
	}
	#footer .copy {
		position: static;
		line-height: 8px;
		font-size: 8px;
		text-align: center;
	}
	
}










