@charset "utf-8";


/*	Reset【normalize.css】必要な箇所だけ書く
------------------------------------------------------------ */
h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li { margin: 0; padding: 0; font-weight: normal }
ul, ol { list-style: none; }



/*	Common
------------------------------------------------------------ */
body {
font-family: 'Alike' , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
	line-height: 1.4;
	font-size: 16px;
	color: #333;
	-webkit-text-size-adjust: 100%;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

table {
	box-sizing: border-box;
	width:100%;
}

table th, 
table td {
	border: 1px solid #ccc;
	padding: .6rem 1rem;
	vertical-align: top;
	text-align: left;
	font-weight: normal;
}

table th { background: #eee; }
table td { background: #fff; }


/* ---------- photo pc/sp switch ---------- */
.switch {
	visibility: hidden;
}


/* ---------- link ---------- */
a {
	display: block;
	text-decoration: none;
	color: #333;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	transition: 0.7s;
}

/*
a:hover {
	opacity: .8;
}
*/

/* ---------- button ---------- 
.btn-main a {
	box-sizing: border-box;
	margin: 2rem auto 0;
	width: 40%;
	border: 1px solid #aaa;
	padding: 1rem;
	font-size: 22px;
	text-align: center;

	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	transition: 0.7s;
}

.btn-main a:hover {
	background-color: #333;
	color: #fff;
}
*/



/*	Wrapper
------------------------------------------------------------ */
#primary.bg_program {
	background: url(../img/program/primary_program_pc.jpg) center no-repeat;
	background-size: cover;
}
#primary.bg_report {
	background: url(../img/report/primary_report_pc.jpg) center no-repeat;
	background-size: cover;
}
#primary.bg_greeting {
	background: url(../img/greeting/primary_greeting_pc.jpg) center no-repeat;
	background-size: cover;
}
#primary.bg_support {
	background: url(../img/support/primary_support_pc.jpg) center no-repeat;
	background-size: cover;
}
#primary.bg_news {
	background: url(../img/news/primary_news_pc.jpg) center no-repeat;
	background-size: cover;
}

/* --- SP ---------- */
@media screen and (max-width: 740px) {
	
	#primary {
		margin-top: 50px;
		width: auto;
		height: 150px;
	}

	.prim-ttl {
		padding: 3.5rem 0 0 1rem;
		font-size: 18px;
		color: #fff;
		text-shadow: 1px 1px 3px rgba(0, 0, 0, .5);
	}

	.secondary {
		margin: 0 .5rem;
		padding: 1rem 0 2rem;
	}

	.second-wrap {
		padding: 0 .8rem 1rem;
	}
	
	.secondary h2 {
		font-size: 16px;
		font-weight: bold;
	}

	h3 {
		margin: 0 0 1rem 0;
		padding: .5rem .7rem;
		background: #333;
		border-left: 7px solid #000;
		font-size: 20px;
		color: #fff;
	}

}

/* --- PC ---------- */
@media screen and (min-width: 741px) {

	#primary {
		margin: 0 auto;
		width: 100%;
		height: 350px;
		
		position: fixed;
		top: 0;
		left: 0;
		z-index: -1;
	}

	.prim-ttl {
		box-sizing: border-box;
		margin: 0 auto;
		width: 980px;
		padding: 11rem 0 0;
		font-size: 35px;
		color: #fff;
		text-align: center;
		text-shadow: 1px 1px 3px rgba(0, 0, 0, .5);
	}

	#scd-wrapper {
		width: 100%;
		background: url(../img/bg.jpg) repeat;
	}

	.secondary {
		box-sizing: border-box;
		margin: 0 auto;
		width: 980px;
		padding: 2rem 0 2rem;
		background: rgba(255, 255, 255, .5);
		
		margin-top: 350px;
		z-index: 9999;
	}

	.second-wrap {
		margin-bottom: 3.5rem;
		padding: 0 2rem;
	}
	
	.secondary h2 {
		font-size: 18px;
		font-weight: bold;
	}

	.secondary h3 {
		position: relative;
		box-sizing: border-box;
		margin: 0  0 1.5rem -1rem;
		padding: .75rem 1.5rem;
		width: 103.2%;
		background: #333;
		color: #fff;
		-moz-box-shadow: 0px 2px 5px rgba(0, 0, 0, .3);
		-webkit-box-shadow: 0px 2px 5px rgba(0, 0, 0, .3);
		box-shadow: 0px 2px 5px rgba(0, 0, 0, .3);
	}

	.secondary h3::before,
	.secondary h3::after {
		content: '';
		position: absolute;
		top: 100%;
		border-style: solid;
		border-color: transparent;
	}

	.secondary h3::before {
		left: 0;
		border-width: 0 15px 15px 0;
		border-right-color: #666;
	}

	.secondary h3::after {
		right: 0;
		border-style: solid;
		border-width: 15px 15px 0 0;
		border-top-color: #666;
	}

}



/* Breakpoint
/* ===================================================================
	
	SP	～740px
	PC	741px～
	
=================================================================== */



/*	header
------------------------------------------------------------ */
#header {
	position: relative;
	width: 100%;
}

/* --- SP ---------- */
@media screen and (max-width: 740px) {

	#header .logo-pc,
	/*
	#header .logo-ap,
	*/
	#header .sp-gnavi-none {
		display: none;
	}

	#header {
		position: fixed;
		top: 0;
		background: #000;
		width: 100%;
		height: 50px !important;
		z-index: 1000;
	}

	#header::after {
		content: "";
		clear: both;
		display: block;
	}

	#header .logo-sp { 
		float: left;
		margin-top: -2px;
		max-width: 50px;
		height: auto;
	}

	#header .menu-btn {
		float: right;
		border-left: 1px solid #666;
	}

	#header .menu-btn a {
		box-sizing: border-box;
		height: 50px;
		padding: .7rem 1rem 0;
		color: #fff;
	}

	.g-navi {
		display: none;
		
		position: fixed;
		top: 50px;
		background: #000;
		width: 100%;
		text-align: left;
		font-size: 16px;
		z-index: 100;
	}

	.g-navi li {
		padding: .8rem 1rem ;
		border-top: 1px solid #333;
	}

	.g-navi li a {
		color: #fff;
	}

	#navi-wrap .logo-ap {
		float: right;
		background: #fff;
		width: 50px;
		height: 50px;
	}

}

/* --- PC ---------- */
@media screen and (min-width: 741px) {

	#header .logo-sp,
	#header .menu-btn,
	#header .navi-sp,
	#header .sp-gnavi-none {
		display: none;
	}

	#header {
		position: fixed;
		top: 0;
		width: 100%;
		background: rgba(0, 0, 0, .8);
		z-index: 1000;
	}
	
	#navi-wrap {
		margin: 0 auto;
		width: 1050px;
	}

	#navi-wrap::after {
		content: "";
		clear: both;
		display: block;
	}

	#navi-wrap .logo-pc {
		float: left;
		width: 70px;
		height: auto;
	}

	#navi-wrap .lang-jp {
		float: right;
		border-left: 1px solid #666;
		text-align: center;
	}

	#navi-wrap .logo-ap {
		float: right;
		margin-top: -.4rem;
		background: #fff;
	}

	#navi-wrap .lang-jp a {
		width: 40px;
	}

	#navi-wrap .g-navi {
		float: right;
	}
	
	#navi-wrap .g-navi li {
		display: inline-block;
	}

	#navi-wrap .g-navi li a {
		padding: 1.3rem 1rem;
	}

	#navi-wrap a {
		color: #fff;
	}

	#navi-wrap a:hover {
		color: #666;
	}

}



/*	footer
------------------------------------------------------------ */
#footer {
	position: relative;
	background: #000;
	color: #fff;
}

#footer dl a {
	display: inline;
	color: #fff;
	text-decoration: underline;
}

/* --- SP ---------- */
@media screen and (max-width: 740px) {

	.footer-wrap {
		padding: 1.5rem 1rem;
		text-align: center;
	}
	
	#footer dl {
		margin-bottom: 1rem;
		border-bottom: 1px solid #666;
		padding-bottom: 1rem
	}

	#footer dl dt {
		display: none;
	}
	
}

/* --- PC ---------- */
@media screen and (min-width: 741px) {
	
	.footer-wrap::after {
		content: "";
		clear: both;
		display: block;
	}

	.footer-wrap {
		width: 980px;
		margin: 0 auto;
		padding: 4rem 0;
	}

	.footer-wrap > * {
		float: left;
		width: 50%;
	}

	#footer dl {
		display: table;
		text-align: left;
	}

	#footer dl > * {
		display: table-cell;
		vertical-align: top;
	}

	.footer-wrap p {
		text-align: right;
	}

