@charset "utf-8";
/* =============================================
	土木施工管理技士 試験情報
============================================= */
/*****
Reset
*****/
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, a,
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{
	box-sizing: border-box;
}

header div,
header a,
header span,
header img{
 box-sizing: content-box;
}

sup{
	vertical-align: top;
	position: static;
	font-size: 0.65em;
}

header li{
 font-size: 1.3rem;
}

/* 画像ボケ軽減 */
img{
	max-width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}

/*****
common
*****/
.small_header_list{}
.small_header_list li{
	margin-left: 10px;
	display: inline-block;
}

.font_red{
	color: #e04536;
}
.font_engin{
 color: #b28247;
}

.bg_red{
	background-color: #e04536;
}
.bg_engin{
	background-color: #b28247;
}
.bg_white{
	background-color: #fff;
}
.bg_eee{
	background-color: #eee;
}

.border_engin{
	border: solid 2px #b28247;
}
.border_ccc{
	border: solid 2px #ccc;
}

.font_green{
	color: #18A1A4;
}
.font_green02{
	color: #bfcd38;
}
.font_green03{
	color: #9dd3cd;
}
.bg_green{
	background-color: #18A1A4;
}
.bg_green02{
	background-color: #bfcd38;
}
.bg_green03{
	background-color: #9dd3cd;
}
.border_green{
	border: solid 2px #18A1A4;
}
.border_green02{
	border: solid 2px #bfcd38;
}
.border_green03{
	border: solid 2px #9dd3cd;
}

.text_indent1,
.li_indent1 li{
	text-indent: -1em;
	padding-left: 1em;
}
.text_indent2,
.li_indent2 li{
	text-indent: -2em;
	padding-left: 2em;
}
.text_indent3,
.li_indent3 li{
	text-indent: -3em;
	padding-left: 3em;
}

.mgn_t05{
	margin-top: 0.5em;
}
.mgn_t1{
	margin-top: 1em;
}
.mgn_t2{
	margin-top: 2em;
}
.mgn_t3{
	margin-top: 3em;
}
.mgn_b05{
	margin-bottom: 0.5em;
}
.mgn_b1{
	margin-bottom: 1em;
}
.mgn_b2{
	margin-bottom: 2em;
}
.mgn_b3{
	margin-bottom: 3em;
}
.mgn_r1{
 margin-right: 1em;
}
.mgn_l1{
 margin-left: 1em;
}

.font_size_s{
	font-size: 0.8em;
}
.font_size_l{
 font-size: 1.25em;
}

.rotate90{
	display: inline-block;
	margin-right: 0.5em;
	transform: rotateZ(-90deg);
}

.p_line p{
	padding-bottom: 0.5em;
}
.p_line p:last-of-type{
	padding-bottom: 0;
}

.underline_red{
	border-bottom: solid 2px #e04536;
}

.text_through{
	text-decoration: line-through;
}

/***リンクボタン***/
.btn_normal{
	display: block;
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
	width: 100%;
	max-width: 420px;
	margin: 1em auto;
	border: solid 2px #fff;
	border-radius: 0.25em;
	position: relative;
	z-index: 1;
	box-shadow: 0 0 2px 0 rgba(0,0,0,0.3);
}
.btn_normal::before{
	content: '';
	display: block;
	width: 0%;
	height: 100%;
	border-radius: 0.25em;
	background-color: rgba(0,0,0,0.5);
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	opacity: 0;
	transition: width 0.5s, opacity 0.5s;
}
.btn_normal:hover::before{
	width: 100%;
	opacity: 1;
}
.btn_normal a{
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	height: 100%;
	padding: 0.5em 2.5em 0.5em 1em;
	border-radius: 0.25em;
	background-image: url("/nikken/guidance/img/icon_arrow.png");
	background-repeat: no-repeat;
	background-size: 1em auto;
	background-position: right 1em center;
}

.btn_anchor{
	display: inline-block;
	color: #18A1A4;
	padding: 0.5em;
	border: solid 1px #18A1A4;
}

.outer_link{
	margin: 1em 0;
}
.outer_link a{
	display: inline-block;
	color: #1e83c5;
	padding: 0.5em 1em;
	border: solid 1px #1e83c5;
}

/*---------------------------------------------
	page_header
---------------------------------------------*/
#header_wrap{
 background-image: url("../img/header_bg.jpg");
 background-repeat: no-repeat;
 background-position: center center;
 background-size: cover;
}

.page_header{
	width: 94%;
	max-width: 1200px;
 margin: 0 auto;
	position: relative;
}
.page_header img{
	max-width: 100%;
	height: auto;
}
.page_header h1{
	font-size: 4.2rem;
	text-align: center;
}
.page_header h1 .h1_inner{
	display: inline-block;
	margin: 2em auto;
	padding: 1em;
	background-color: rgba(255,255,255,0.65);
}

.page_header .header_icon01{
	width: 16.5%;
	max-width: 194px;
	position: absolute;
	top: 2em;
	left: 0;
}
.page_header .header_icon02{
	width: 22.5%;
	max-width: 270px;
	position: absolute;
	bottom: 0;
	right: 0;
}

/*****
ページナビ
*****/
/***ナビ固定用のCSS***/
.fixed_nav{
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}
.on_anchor{}
/***end ナビ固定用のCSS***/

#page_nav{
 width: 100%;
 padding: 1em 0 0 0;
 border-top: solid 1px #ccc;
 border-bottom: solid 1px #ccc;
 background-color: #fff;
}
#page_nav ul{
 display: flex;
 justify-content: center;
	flex-wrap: wrap;
 width: 94%;
 max-width: 970px;
 margin: 0 auto;
}
#page_nav ul li{
 font-weight: bold;
 width: 23%;
	margin: 0 1% 1em 1%;
}
#page_nav ul li a{
 display: block;
 color: #333;
 padding: 0.5em 0.5em 0.5em 3em;
 border-bottom: solid 4px #b28247;
 background-repeat: no-repeat;
 background-position: left 0.5em center;
 background-size: 2em auto;
 transition: background 0.5s, color 0.5s;
}

#page_nav ul li a.a_kouza_area{
 background-image: url("../img/nav_icon_kouza.png");
}
#page_nav ul li a.a_newtest_area{
 background-image: url("../img/nav_icon_newtest.png");
}
#page_nav ul li a.a_bunseki_area{
 background-image: url("../img/nav_icon_bunseki.png");
}
#page_nav ul li a.a_advice_area{
 background-image: url("../img/nav_icon_advice.png");
}

#page_nav ul li a:hover,
#page_nav ul li.on_anchor a{
 text-decoration: none;
 color: #fff;
 background-color: #b28247;
}
#page_nav ul li a.a_kouza_area:hover,
#page_nav ul li.on_anchor a.a_kouza_area{
 background-image: url("../img/nav_icon_kouza_o.png");
}
#page_nav ul li a.a_newtest_area:hover,
#page_nav ul li.on_anchor a.a_newtest_area{
 background-image: url("../img/nav_icon_newtest_o.png");
}
#page_nav ul li a.a_bunseki_area:hover,
#page_nav ul li.on_anchor a.a_bunseki_area{
 background-image: url("../img/nav_icon_bunseki_o.png");
}
#page_nav ul li a.a_advice_area:hover,
#page_nav ul li.on_anchor a.a_advice_area{
 background-image: url("../img/nav_icon_advice_o.png");
}

/***スマホ用開閉ナビ***/
#nav_sp{
	display: none;
}
.nav_check{}
.nav_check .nav_sp_label{}


/*---------------------------------------------
	section
---------------------------------------------*/
.section_wrap{
	width: 100%;
	margin: 0 auto;
	padding: 4em 0;
}
.section_wrap:first-of-type{
	margin-top: 4em;
}
.normal_section{
 font-size: 1.6rem;
	width: 970px;
	margin: 0 auto;
	background-color: #fff;
}
.normal_section li{
 font-size: 1.6rem;
}

.ttl_type01{
	text-align: center;
 font-size: 3rem;
 margin-bottom: 1em;
 padding: 0.5em;
 border: solid 1px #808080;
 border-radius: 0.25em;
}

.ttl_type02{
	font-size: 2.4rem;
	text-align: center;
	color: #b28247;
	margin: 2em 0 1em 0;
	border-bottom: solid 2px #b28247;
}


/*****
新試験制度
*****/
#newtest_area{}

.newtest_section{
	margin-top: 2em;
	padding-bottom: 2em;
	border-bottom: dashed 1px #ccc;
}

.ttl_new{
	font-size: 1.8rem;
	font-weight: bold;
	color: #b28247;
}

.kijun_box{
	display: flex;
	align-items: center;
}
.kijun_wrap{
	text-align: center;
	margin: 0 1em;
	padding: 1em;
	border: solid 2px #b28247;
}

/***表組***/
.tbl_scroll{}

.tbl_newtest{
	font-size: 1.4rem;
	width: 100%;
	border-top: solid 1px #858585;
	border-left: solid 1px #858585;
}

.tbl_newtest tr{
	border-bottom: solid 1px #858585;
}
.tbl_newtest tr:nth-of-type(odd){
	background-color: #eee;
}

.tbl_newtest th,
.tbl_newtest td{
	padding: 0.5em;
	border-right: solid 1px #858585;
}

.tbl_newtest th{
	background-color: #ccc;
}

.tbl_newtest td{
	vertical-align: middle;
}


/*****
試験傾向分析
*****/
#bunseki_area{}

.graph_atent_area{
	text-align: center;
}
.graph_atent{
	display: inline-block;
	padding: 1em;
	border: solid 2px #ccc;
}
.graph_atent li{
	text-align: left;
}

.g_color01{
	color: #af8046;
}
.g_color02{
	color: #d3a32e;
}
.g_color03{
	color: #e97c30;
}

.graph_set{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 2em auto;
}

.graph_set .graph_area{
	/*width: 465px;*/
	width: 480px;
	margin: 0.5em 0;
	padding: 1em;
	border: solid 1px #b28247;
}
.graph_area .ttl_graph{
	font-size: 1.8rem;
	font-weight: bold;
	color: #b28247;
	text-align: center;
}
.graph_area p{
	padding-top: 0.5em;
	padding-bottom: 0.5em;
}
.graph_area img{
	max-width: 100%;
	height: auto;
}


/*****
学習アドバイス
*****/
#advice_area{}

.advice_wrap{
	/*display: flex;
	align-items: center;*/
	margin: 2em auto 4em auto;
}

.advice_detail{
	padding: 1em;
}
.advice_detail .ttl_detail{
	display: inline-block;
	font-size: 1.2em;
	color: #fff;
	margin: -1em auto 1em -1.5em;
	padding: 0.25em 0.5em;
	background-color: #b28247;
}
/*.advice_detail .icon_detail{
	display: inline-block;
	font-size: 0.85em;
	font-weight: bold;
	color: #fff;
	text-align: center;
	margin: 0.5em 1em;
	padding: 0.5em 1em;
	border-radius: 0.25em;
}*/

.advice_arrow{
	font-size: 6rem;
	line-height: 1;
	color: #e04536;
	text-align: center;
	margin: 0.2em auto;
}

.advice_text{
	font-size: 2.4rem;
	text-align: center;
}
.advice_text b{
	display: inline-block;
	text-align: left;
}

.ttl_attent{
	font-size: 1.15em;
	color: #fff;
	padding: 0.5em 1em;
	background-color: #9CD6F6;
	border: solid 1px #9CD6F6;
}
.advice_attent{
	padding: 1em;
	border: solid 1px #9CD6F6;
}
.advice_attent .point_wrap{
	display: flex;
}
.point_wrap .icon_point{
	flex-shrink: 0;
	margin: 0 1em 0.5em 0;
}
.point_wrap .illust_alpaca{
	width: 120px;
}

.advice_border{
	margin: 1em 0;
	padding: 1em;
	border: solid 2px #ccc;
}

.advice_flex{
	display: flex;
	justify-content: space-between;
}
.large_book{
	font-size: 1.2rem;
	flex-shrink: 0;
	width: 240px;
	margin: 0 0 0 2em;
}
.icon_large{
	display: block;
	border: solid 1px #ccc;
	position: relative;
}
.icon_large .icon_large_mark{
	position: absolute;
	bottom: 0.5em;
	right: 0.5em;
}


/*****
講座紹介
*****/
.anc_course{
	text-align: center;
}
.anc_course li{
	display: inline-block;
	margin: 1em;
}
.anc_course li a{
	display: block;
	color: #fff;
	padding: 0.5em 1em;
	border-radius: 0.25em;
	background-color: #b28247;
}

.course_info_cont{
	font-size: 1.3rem;
}

.course_list_table{
	margin: 0;
	border-top: solid 2px #fff46a;
}

/***タブ***/
.course_tab{
	display: flex;
}
.course_tab li{
	font-size: 1.8rem;
	font-weight: bold;
	margin-right: 1em;
}
.course_tab li a{
	display: block;
	color: #333;
	padding: 0.5em 1em;
	background-color: #ccc;
	border-radius: 0.5em 0.5em 0 0;
}
.course_tab li a:hover{
	text-decoration: none;
}
.course_tab li a.show_box{
	cursor: default;
	background-color: #fff46a;
}


/*** 拡大表示 ***/
#overlay{
	width: 100%;
	background-color: rgba(0,0,0,0.75);
	position: fixed;
	/*position: absolute;*/
	top: 0;
	left: 0;
	z-index: 10000;
}
#overlay::after{
	content: '×';
	display: block;
	font-size: 4vh;
	text-align: center;
	line-height: 1;
	color: #fff;
	padding: 0 0.25em;
	border: solid 1px #fff;
	position: absolute;
	top: 1em;
	right: 2%;
	cursor: pointer;
}

#overlay #view_container{
	width: 100%;
	max-width: 970px;
	margin: 0 auto;
}

#overlay #view_container #view_img{
	text-align: center;
	width: 94%;
 max-width: 940px;
	max-height: 80vh;
 margin: 0 auto;
	overflow-y: scroll;
}

#overlay #view_container #view_img img{
	max-width: 100%;
	height: auto;
}

#overlay #view_container #nav_area{
	display: none;
	/*display: flex;
	justify-content: space-between;
	margin-top: 0.25em;*/
}
/*
#overlay #view_container #nav_area #prev_btn{
	display: inline-block;
	padding: 0.5em 1em;
	background-color: #fff;
	cursor: pointer;
}

#overlay #view_container #nav_area #next_btn{
	display: inline-block;
	padding: 0.5em 1em;
	background-color: #fff;
	cursor: pointer;
}*/
/*** 拡大表示 ここまで ***/


/* ===========================================
	MediaQueries
=========================================== */
/* PC----------------------------- */
@media (min-width: 768px){
	/*---------------------------------------------
		section
	---------------------------------------------*/
	/*** 非表示 ***/
	.sp_only{
  display: none;
 }
	
	.flex_between_pc{
		display: flex;
		justify-content: space-between;
  flex-wrap: wrap;
	}
	.self_center_pc{
		align-self: center;
	}
	
	.btn_area_flex{
		display: flex;
		justify-content: space-around;
	}
	
	/*---------------------------------------------
	page_header
	---------------------------------------------*/
	/*****
	ページナビ
	*****/
	/***スマホ用開閉ナビ***/
	
	#nav_sp{}
	.nav_check{
		display: none;
	}
	.nav_check .nav_sp_label{}
	
}

/* スマホ----------------------------- */
@media screen and (max-width: 767px){
 /*** 非表示 ***/
 .pc_only{
  display: none;
 }
 
	/*****
	common
	*****/
	.small_header_menu{
		margin: 5px -5px 0;
		padding: 0 5px;
		border-top: 1px solid #dddddd;
		padding-top: 5px;
		width: 100%;
	}
	
	.small_header_list{ text-align: right; }
	.small_header_list li{ font-size: 1.2rem; }
	
	.simple_btn a{
		width: 95%;
		min-width: 0;
	}
	
	.btn_normal{
		font-size: 1.6rem;
	}
	
	/*---------------------------------------------
	page_header
	---------------------------------------------*/
	#header_wrap{
		background-size: auto 100%;
	}
	
	.page_header h1{
		font-size: 1.8rem;
	}
	.page_header .header_icon01{
		width: 15%;
		top: 1em;
	}
	.page_header .header_icon02{
		width: 24%;
	}
	
	/*****
	ページナビ
	*****/
	#page_nav{
		padding: 0.5em 0;
		background-color: transparent;
	}
	#page_nav.fixed_nav{
		border: none;
	}
	#page_nav ul{
  display: block;
		overflow: hidden;
		height: 0;
		max-height: 0;
		padding: 0 0.5em;
		background-color: #fff;
		transition: 0.5s;
 }
 #page_nav ul li{
  width: 100%;
		margin: 0 auto 1em auto;
 }
	
	/***スマホ用開閉ナビ***/
	#nav_sp{}
	.nav_check{
		margin-left: 0.5em;
	}
	.nav_check .nav_sp_label{
		display: block;
		width: 4em;
		height: 4em;
		padding: 0.5em;
		border: solid 2px #b28247;
		border-radius: 0.25em;
		background-color: #fff;
		position: relative;
	}
	.nav_check .nav_sp_label::before,
	.nav_check .nav_sp_label::after{
		content: '';
		display: block;
		width: 100%;
		height: 0.5em;
		background-color: #b28247;
	}
	.nav_check .nav_sp_label span{
		display: block;
		width: 100%;
		height: 0.5em;
		margin: 0.5em 0;
		background-color: #b28247;
	}
	
	#nav_sp:checked{}
	#nav_sp:checked + .nav_check .nav_sp_label span{
		display: none;
	}
	#nav_sp:checked + .nav_check .nav_sp_label::before{
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) rotateZ(45deg);
		transform-origin: center center;
	}
	#nav_sp:checked + .nav_check .nav_sp_label::after{
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) rotateZ(-45deg);
		transform-origin: center center;
	}
	
	#nav_sp:checked ~ ul{
		height: auto;
		max-height: 100vh;
	}
	
	
	/*---------------------------------------------
	section
	---------------------------------------------*/
	.section_wrap{
		padding: 2em 0;
	}
	.section_wrap:first-of-type{
		margin-top: 2em;
	}
	.normal_section{
		font-size: 1.4rem;
		width: 94%;
	}
 .normal_section li{
  font-size: 1.4rem;
 }
	
	.ttl_type01{
		font-size: 1.8rem;
	}
	.ttl_type02{
		font-size: 1.8rem;
	}
	
	
	/*****
	新試験制度
	*****/
	.kijun_box{
		display: block;
	}
	
	.kijun_wrap{
		margin: 1em auto;
	}
	
	/***表組***/
	.tbl_scroll{
		width: 100%;
		overflow-x: scroll;
		padding: 0.5em;
		border: solid 1px #ccc;
	}
	.tbl_scroll::before,
	.tbl_scroll::after{
		content: '←表をスクロール→';
		display: block;
		font-size: 0.85em;
		margin: 0.5em 0;
	}
	
	.tbl_newtest{}
	.tbl_newtest th,
	.tbl_newtest td{
		white-space: nowrap;
	}
	
	/*****
	試験傾向分析
	*****/
	.graph_set{
		display: block;
	}
	
	.graph_set .graph_area{
		width: 100%;
	}
 
	/*****
	学習アドバイス
	*****/
	.advice_text{
		font-size: 1.8rem;
	}
	
	.advice_attent .point_wrap{
		display: block;
	}
	.point_wrap .icon_point{
		max-width: 30px;
	}
	.point_wrap .illust_alpaca{
		width: 20%;
	}
	
	.advice_flex{
		display: block;
	}
	
	.large_book{
		width: 80%;
		max-width: 240px;
		margin: 1em auto 0 auto;
	}
 
	/*****
	講座紹介
	*****/
	/***タブ***/
	.course_tab{
		flex-wrap: wrap;
	}
	.course_tab li{
		font-size: 1.4rem;
	}
	
}


/* print----------------------------- */
@media print{
	#footer,.page_top{ display: none; }
	body{ min-height: 0; }
}