﻿@charset "utf-8";

/* Column */

.col_1,
.col_2,
.col_3,
.col_4,
.col_5,
.col_6{}

.col_1-2{},
.col_1-3{}

.col_2-1{},
.col_2-3{}

.col_3-1{},
.col_3-2{}

.col_child{
	float:left;
	box-sizing:border-box;
	padding-left:1%;
	padding-right:1%;
}
.col_child:first-child,
.col_child:first-child:last-child{
	padding-left:0;
	padding-right:2%;
}
.col_child:last-child{
	padding-left:2%;
	padding-right:0;
}
.col_2 .col_child{ width:50%;}
.col_3 .col_child{ width:33.3%;}
.col_4 .col_child{ width:25%;}
.col_5 .col_child{ width:20%;}
.col_6 .col_child{ width:16.6%;}

.col_1-2 .col_child:nth-child(1){ width:33.3%;}
.col_1-2 .col_child:nth-child(2){ width:66.6%;}

.col_2-1 .col_child:nth-child(1){ width:66.6%;}
.col_2-1 .col_child:nth-child(2){ width:33.3%;}

.col_1-3 .col_child:nth-child(1){ width:25%;}
.col_1-3 .col_child:nth-child(2){ width:75%;}

.col_3-1 .col_child:nth-child(1){ width:75%;}
.col_3-1 .col_child:nth-child(2){ width:25%;}

.col_2-3 .col_child:nth-child(1){ width:40%;}
.col_2-3 .col_child:nth-child(2){ width:60%;}

.col_3-2 .col_child:nth-child(1){ width:60%;}
.col_3-2 .col_child:nth-child(2){ width:40%;}


@media screen and (max-width:768px) {
	.col_1 > .col_child,
	.col_2 > .col_child,
	.col_3 > .col_child,
	.col_4 > .col_child,
	.col_5 > .col_child,
	.col_6 > .col_child,
	.fix.col_1-2 > .col_child,
	.fix.col_1-3 > .col_child,
	.fix.col_2-1 > .col_child,
	.fix.col_2-3 > .col_child,
	.fix.col_3-1 > .col_child,
	.fix.col_3-2 > .col_child{width: 100%;padding-left:0;padding-right:0;}
	.col_4 .col_child,
	.col_5 .col_child{ 
		width:50%;
	}
	.col_4 .col_child:nth-child(odd),
	.col_5 .col_child:nth-child(odd){ 
		padding-right:1%;
	}	
	.col_4 .col_child:nth-child(even),
	.col_5 .col_child:nth-child(even){ 
		padding-left:1%;
	}	

}

/* head,text */


.h_style01{
	font-size:200%;
	padding:25px 0;
	font-weight:bold;
	color:#004499;
    text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
	line-height:1;
	text-align:center;
	background:#ffe100;
	margin:0 40px 40px;
	position:relative;
}
.h_style01 span{
	display:inline-block;
}
.h_style01 i{
	font-style:normal;
	font-size:50%;
	margin-left:1em;
	vertical-align:middle;
	display:inline-block;
}

.h_style01:before,
.h_style01:after{
	position:absolute;
	content:"";
	display:block;
	width: 0;
	height: 0;
	top:7px;
	bottom:0;
	border-style: solid;
	border-width: 42px 0 42px 32px;
	border-color:#f0d000 #f0d000 #f0d000 transparent;
}
.h_style01:before{
	left:0;
	transform:translateX(-100%);
}
.h_style01:after{
	right:0;
	transform:translateX(100%);
	border-width: 42px 32px 42px 0;
	border-color:#f0d000 transparent #f0d000 #f0d000 ;	
}


.h_style02{
	text-align:center;
	margin-bottom:30px;
}
.h_style02 span{
	background:#003cb4;
	display:block;
	padding:10px 10px;
	font-size:150%;
	color:#fff;
	font-weight:bold;
	border-radius:30px;
}
.sec03 .h_style02 span{
	background:#ee9900;
}

.h_style03{
	display:block;
	text-align:left;
	font-weight:bold;
	color:#334466;
	font-size:112.75%;
	padding:10px;
	margin-bottom:20px;
	background:rgba(255,255,255,0.3);
	border-bottom:solid 2px #666;
}
.h_style03 span{
	display:inline-block;
	font-style:normal;
	vertical-align:middle;
	margin-left:1em;
}
.h_style03 i{
	font-size:75%;
	display:inline-block;
	font-style:normal;
	vertical-align:middle;
}
.h_style04{
	font-size:20px;
	font-weight:bold;
	color:#1F1F1F;
	padding:5px 20px;
	border-left:#1F1F1F solid 4px;
	margin-bottom:20px;
}
.h_style05{
	font-size:18px;
	font-weight:bold;
	margin-bottom:10px;
}
p.text,
.texts > p{
	font-size:16px;
	line-height:1.6;
	margin:0;
	text-align:left;
}
.sub_lead{
	margin-bottom:40px;
	text-align:left;
}
.sub_lead span{
	background:#fff;
	padding:20px;
	border-radius:10px;
	font-size:112.75%;
	text-align:left;
	position:relative;
	color:#223344;
	display:inline-block;
}
.sub_lead span:after{
	content:"";
	position:absolute;
	display:block;
	width: 0;
	height: 0;
	box-sizing:border-box;
	bottom:-25px;
	left:30px;
    width: 10px;
    height: 10px;
    border: 10px solid transparent;
    border-top: 20px solid #fff;
}
.sub_lead span ul{
	font-size:75%;
	margin-top:10px;
}
.sitewrap .box{
	border:solid 1px #999;
	background:rgba(255,255,255,0.3);
	padding:20px;
}
.sub_tables{
	display:table;
	width:100%;
	margin-bottom:20px;
}
.sub_tables dt{
	display:table-cell;
	vertical-align:top;
	width:7em;
	text-align:left;
	position:relative;
}
.sub_tables dt:after{
	content:"\FF1A";
	display:inline-block;
	position:absolute;
	right:0;
}
.sub_tables dd{
	display:table-cell;
	text-align:left;
	vertical-align:top;
	position:relative;
}
.sub_tables + .sub_tables{
	margin-top:10px;
	padding-top:10px;
	border-top:dotted 1px #666;
}
@media screen and (max-width: 768px) {
	.h_style01{
		font-size:150%;
		padding:15px 5px;
		line-height:1.2;
		margin:0 20px 30px;
		display:flex;
		flex-direction:column;
		align-items:center;
		justify-content:center;
		min-height:64px;
	}
	.h_style01:before{
		border-width: 40px 0 40px 18px;
	}

	.h_style01:after{
		border-width: 40px 18px 40px 0;
	}
	.h_style02{
		margin-bottom:20px;
	}
	.h_style02 span{
		font-size:125%;
	}
	p.text,
	.texts > p{
		font-size:14px;
	}
	.f_small{
		font-size:12px;	
	}
}
@media screen and (max-width: 600px) {
	.h_style01{
		font-size: 5.5vw;
		display:flex;
		flex-direction:column;
		align-items:center;
		justify-content:center;
		min-height:65px;
	}
	.h_style01 i{
		margin:5px 0 0;
	}
}

/* Link */

.text_link a,
a.text_link{
	text-decoration:underline;
}
.text_link a:hover,
a.text_link:hover{
	text-decoration:none;
}
.block_link a,
a.block_link{
	display:block;
	transition: opacity 1s, background 1s, color 1s, border 1s;
}
.block_link a:hover,
a.block_link:hover{
	opacity: 0.7;
	text-decoration:none;
	transition: opacity 0.7s;
}

a:hover img.opacity{
	opacity: 0.7;
	text-decoration:none;
	transition: opacity 0.7s;
}
.common_btn{
	text-align:center;
	margin:20px auto 30px;
}
.common_btn a{
	display:block;
	max-width:390px;
	border:solid 2px #535353;
	border-radius:10px;
	color:#535353;
	font-size:22px;
	font-weight:bold;
	padding:25px 0;
	position:relative;
	text-decoration:none;
	margin:0 auto;
	background:#eee;
}
.common_btn a:before,
.common_btn a:after{
	content: "";
	width: 0px;
	height: 0;
	border: 8px solid transparent;
	border-left: 8px solid #000000;
	display: inline-block;
	position: absolute;
	border-radius: 4px;
	right: 20px;
	top: 50%;
	margin-top:-8px;
}
.common_btn a:after{
	border: 8px solid transparent;
	border-left: 8px solid #eee;
	right: 23px;
}
a.arrow_link,
.arrow_link a{
	position: relative;
	padding-left:14px;
}
a.arrow_link:before,
.arrow_link a:before{
    content: "";
    position: absolute;
    left: -1px;
    margin-top:-3px;
    top: 50%;
    width: 6px;
    height: 6px;
    border-top: 2px solid #666;
    border-right: 2px solid #666;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.ico_blank{position:relative;padding-right: 20px;}
.ico_blank:before, .ico_blank:after{
	content: "";
	width: 11px;
	height: 11px;
	display: inline-block;
	position: absolute;
	border: 1px solid #333;
	background:#fff;
	right: 0;
	top: 2px;
	z-index:10;
}
.ico_blank:after{
	right: 3px;
	top: 5px;
	z-index:9;
}
img.icon{
	vertical-align:middle;
	margin-right:5px;
}
/* image */
.scale { }
.scale_m { 
	max-width:100%;
	width:auto;
	height:auto;
}
.scale_all{	
	width:100%;
	height:auto;
}
@media screen and (max-width: 768px) {
	.scale {
		width:100%;
		height:auto;
	}
}

/* table,list */

.table_style {
	border:#ddd solid 1px;
	border-bottom:none
}
.table_style dl{
	position:relative;
	border-bottom:#ddd solid 1px;
	width:100%;
}
.table_style dt{
	position:absolute;
	top:0;
	left:0;
	background:#EEEEEE;
	width:250px;
	padding:16px 20px;
	box-sizing:border-box;
}
.table_style dd{
	padding:16px 20px;
	padding-left:270px;
	box-sizing:border-box;
}
.txt_indent {
	padding-left:1em;
	text-indent:-1em;
}
.list_style ul li{
	margin-left:1em;
	margin-bottom:5px;
	text-indent: -1em;
}
.list_style ul li:before{
	content:"\30FB";
	margin-right:5px;
	color:#005BAC;
	font-weight:bold;
	
}
.list_style ul li.inlist ul{
	margin-top:5px;
}
.list_style ul li.inlist li{
	margin-left:3em;
	padding-left:0;
	text-indent:-3em;
}
.ol_style ol li{
	margin-left:-1em;
	padding-left:1em;
	margin-bottom:5px;
	text-indent: -1em;
	list-style-position:inside;
}

.dl_style dl{
	margin:0;
	padding:15px;
	background:#f6f6f6;
}
.dl_style dl dt{
	font-weight:bold;
	margin-bottom:10px;
	padding-bottom:10px;
	border-bottom: dotted 1px #999;
}
.table_wrap {
	margin:10px 0;
}
.table_wrap.over {
	padding-bottom:10px;
	overflow-x:auto;
	overflow-y:hidden;
}
.table_wrap table{
	width:100%;
	box-sizing:border-box;
	font-size:88%;
}
.table_wrap table th,
.table_wrap table td{
	box-sizing:border-box;
	padding:10px 5px;
	background:#fff;
	border:solid 1px #ddd;
}
.table_wrap table td{
	font-weight:normal;
}
.table_wrap table tr:nth-child(2n-1) td{
	background:#f0f0ff;
}
.table_wrap table tr td:empty,
.table_wrap table tr td.null{
	background:#ccc;
}
.table_wrap table th{
	text-align:center;
	background:#5b9bd5;
	color:#fff;
	font-weight:bold;
}
.sec03 .table_wrap table th{
	background:#ffbb00;
}

.table_wrap table th span{
	display:inline-block;
	text-align:left;
}

.table_caption{
	text-align:left;
	font-size:75%;
	font-weight:normal;
	margin-bottom:20px;
}
.table_caption p{
	display:inline-block;
	margin-right:1em;
}
.table_wrap::-webkit-scrollbar {
	height: 8px;
	width:8px;
}

.table_wrap::-webkit-scrollbar-track {
	border-radius: 8px;
	background: #c1c1c1;
}

.table_wrap::-webkit-scrollbar-thumb {
	border-radius: 8px;
	background: #666;
}

.sec04 .table_wrap td{
	padding:10px;
	box-sizing:border-box;
	width:50%;
	vertical-align: top;
	text-align:center;
}
.sec04 .accordion .table_wrap th{
	background:#ffee99;
	color:#000;
}
.sec04 .accordion .table_wrap td{
	background:#fff9dd;
}
.sec04 .accordion .table_wrap td b{
	color:#ff0000;
	font-weight:normal;
}

.sec04 .table_wrap.wauto td:nth-child(1){
	text-align:left;
}
.sec04 .table_wrap.wauto td{
	width:auto;
	vertical-align: middle;
}

.sec04 .table_wrap .wrap{
	position:relative;
	overflow:hidden;
	z-index:2;
}
.sec04 .table_wrap .wrap span{
	padding:10px;
	display:flex;
	justify-content:center;
	align-items:center;
	height:40px;
	border:solid 3px #008C23;
	border-right:none;
	margin-right:34px;
	background:#ddffcc;
	font-weight:bold;
}
.sec04 .table_wrap .wrap.height span{
	height:60px;
}
.sec04 .table_wrap .reverse td{
	vertical-align:middle;
}
.sec04 .table_wrap .park_start td:nth-child(1) .wrap,
.sec04 .table_wrap td:nth-child(2) .wrap{
	margin-top:15px;
}
.sec04 .table_wrap td:nth-child(2) .wrap span{
	border:solid 3px #aa66aa;
	border-left:none;
	background:#eeccee;
	margin:0 0 0 34px;
}
.sec04 .table_wrap .park_start td:nth-child(2) .wrap,
.sec04 .table_wrap .reverse td:nth-child(2) .wrap{
	margin-top:0;
}
.sec04 .table_wrap .reverse td .wrap + .wrap{
	margin-top:15px;
}

.sec04 .table_wrap .wrap span:before{
	content:"";
	display:block;
	position:absolute;
	top:0;
	bottom:0;
	margin:auto;
	right:10px;
	width:48px;
	height:48px;
	box-sizing:border-box;
	background:#ddffcc;
	border-left:solid 3px #008C23;
	border-top:solid 3px #008C23;
	transform:rotate(135deg);
	z-index:-1;
}
.sec04 .table_wrap td:nth-child(2) .wrap.height span{
	margin-left:43px;
}
.sec04 .table_wrap td:nth-child(2) .wrap.height span:before{
	width:62px;
	height:62px;
	left:12px;
}
.sec04 .table_wrap td:nth-child(2) .wrap span:before{
	background:#eeccee;
	border-left:solid 3px #aa66aa;
	border-top:solid 3px #aa66aa;
	transform:rotate(-45deg);
	right:auto;
	left:10px;
}
.sec04 .table_wrap .bdr{
	font-weight:bold;
	background:#ffee99;
	padding:10px;
	border:solid 3px #ffaa00;	
}
.sec04 .box + .h_style02{
	margin-top:30px;
}
.sec04 .accordion dl{
	background:#ffcccc;
	border:#ee4433 solid 3px;
}
.sec04 .accordion dt{
	font-size:112.75%;
	padding:15px;
	cursor:pointer;
	position:relative;
}
.sec04 .accordion dt:after{
    content: "";
    display: inline-block;
    vertical-align: middle;
    margin: auto;
    position: absolute;
    right: 20px;
    width: 0;
    height: 0;
    top:0;
    bottom:0;
    border-style: solid;
    border-width: 14px 10px 0 10px;
    border-color: #ee4433 transparent transparent transparent;
}
.sec04 .accordion dt.opened:after{
	transform:scale(-1);
}
.sec04 .accordion dd{
	border-top:dotted 2px #ee4433;
	padding:15px;
	text-align:left;
}
.sec04 .accordion dd .flex{
	display:flex;
	align-items:flex-start;
	justify-content:space-between;
}
.sec04 .accordion dd .flex > .plan_box{
	width:48%;
}

.sec04 .accordion dd .ttl{
	margin-bottom:10px;
}
.sec04 .accordion dd ul,
.sec04 .accordion dd .txt{
	font-weight:normal;
	font-size:87.5%;
}
.sec04 .accordion dd ul li + li{
	margin-top:5px;
}
.sec05 .sitewrap .box{
	text-align:left;
	background: #fff;
}
.sec05 .sitewrap .policy_list{
	margin:40px 0 0;
	display:flex;
	flex-wrap:wrap;
}
.sec05 .sitewrap .policy_list li{
	width:48%;
	margin-right:4%;
	margin-bottom:10px;
	padding-bottom:5px;
	border-bottom:dotted 1px #aaa;
}
.sec05 .sitewrap .policy_list li:nth-child(2n){
	margin-right:0;
}
.sec05 .sitewrap .t_right a{
	color:#ff3300;
}
.sec05 .sitewrap .t_right p{
	text-align:right;
}
@media only screen and (max-width: 768px) {
	.table_style dl,
	.table_style dt,
	.table_style dd{
		display:block;
	}
	.table_style dt{
		border-bottom:#ddd solid 1px;
		width:100%;
		padding:10px;
		position:static;
		top:auto;
		left:auto;
	}
	.table_style dd{
		padding:15px 10px;
	}
	.dl_style dl{
		font-size:14px;
		margin:0;
	}
	.table_wrap table{
		font-size:12px;
	}
	.table_wrap table th,
	.table_wrap table td{
		padding:10px;
	}
}

}
.topics_list{ border-top:#DDDDDD solid 1px;}
.topics_list li{
	border-bottom:#DDDDDD solid 1px;
}
.topics_list li a{
	display:block;
	padding:20px;
}
.topics_list li a:hover{
	text-decoration:none;
}
.topics_list time,
.topics_list h2,
.topics_list p{ display:inline-block;}
.topics_list a:hover h2{ 
	color:#fff;
	background:#E60012;
	border-color:#ddd;
	transition: background-color 0.5s, color 0.5s;
}
.topics_list a:hover time,
.topics_list a:hover p{ text-decoration:underline;}

.topics_list time{ margin-right:20px;}
.topics_list h2{
	padding:5px 20px;
	width: 5em;
	text-align:center;
	border:solid 1px #666666;
	margin-right:20px;
	transition: background-color 1s, color 1s;
}


/*  GoogleMAP・動画埋め込み  */
.map_wrap iframe{
	width:100%;
}
#campus_map{
	height:390px;
	margin-bottom:20px;
}
.movie_wrap{
	position:relative;
	width:100%;
	padding-bottom:56.25%;
}
.movie_wrap iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
}
.movie_wrap2{
	width: 100%;
	height:  0;
	padding-bottom:  590px;
	overflow:hidden;
	position:  relative;
}
.movie_wrap2 iframe,
.movie_wrap2 video{
	min-width: 100%;
	min-height: 590px;
	height:  auto;
	position:  absolute;
	top: 0;
	bottom: 0;
	left:0;
	right:0;
	margin:  auto;
}
@media only screen and (max-width: 768px) {
	#campus_map {
	    margin: 0 15px;
	    box-sizing: border-box;
	    width: auto;
	    height: 320px;
	}
}

/*  パンくずリスト  */
#pan ul{ margin:10px 0 40px;}
#pan li{ 
	display:inline;
	vertical-align:middle;
}
#pan li span,
#pan li img{ 
	vertical-align:middle;
}
#pan ul li{
	padding: 0 0 0 10px;
	display:inline-block;
}
#pan ul li:before{
	content: "\003E";
	display:inline-block;
	margin-right:10px;
}
#pan ul li:first-child:before{
	content: "";
	display:none;
	margin-right:0;
}
@media only screen and (max-width: 768px) {
	#pan ul{ margin:15px 0 25px; font-size:12px}
}

/*  ページャー  */
.pager_style{
	text-align:center;
	padding:30px 0 0 0;
}
.pager_style li{
	width:40px;
	border:1px solid #BBBBBB;
	background:#fff;
	display:inline-block;
	margin:0 0 10px 0;
}
.pager_style li:hover{
	background:#024384;
}
.pager_style li.on{
	background:#024384;
}
.pager_style li a{
	font-size:16px;
	text-decoration:none;
	display:block;
	padding:8px 0;
}
.pager_style li.on a{
	color:#fff;
}
.pager_style li a:hover{
	color:#fff;
}
.pager_style li.prev{
	margin:0 10px 0 0;
}
.pager_style li.next{
	margin:0 0 0 10px;
}
@media screen and (max-width: 768px) {
	.pager_style li{
		width: 30px;
	}
	.pager_style li a{
		font-size:12px;
		padding:6px 0;
	}
	.pager_style li.prev,
	.pager_style li.next{
		margin:0;
	}
}

.pc_center { }
.pc_right { }
.sp_center { }
.sp_right { }


@media screen and (min-width:769px) {
	.pc_center { text-align:center !important;}
	.sp_center { text-align:left;}
	.pc_right { text-align:right !important;}
	.mb50_h{ margin-bottom:50px !important;}
	.mb60_h{ margin-bottom:60px !important;}
	.mb80_h{ margin-bottom:80px !important;}
}
@media screen and (max-width:768px) {
	.pc_center,
	.pc_righ { text-align:left;}
	.sp_center { text-align:center !important;}
	.sp_right { text-align:right !important;}
	.mb50_h{ margin-bottom:25px !important;}
	.mb60_h{ margin-bottom:30px !important;}
	.mb80_h{ margin-bottom:40px !important;}
}

.fixed_bg{
	width:100%;
	height:750px;
	background: url(../img/bg_01.jpg) no-repeat;
	background-attachment: fixed;
	background-position: 0 0;
	background-size: cover;
	overflow: hidden;
}
.fixed_bg.bg02{
	background-image: url(../img/bg_02.jpg);
}
_::-webkit-full-page-media, _:future, :root .fixed_bg {
		height:50vw;
		background-attachment:unset;
		background-position:0% 0%;
		background-size: 100%;
}
@media screen and (max-width:1024px) {
	.fixed_bg {
			height:50vw;
			background-attachment:unset;
			background-position:0% 0%;
			background-size: 100%;
	}
}