@charset "utf-8";
/* CSS Document */


/*
===== 1: body and base setting ===========================
*/

body {
	margin: 0px;
	padding: 0px;
	text-align: center;
	-webkit-text-size-adjust: 100%;
}

/* params
--------------------*/
h1, h2, h3, h4, h5, h6,
div, p, pre, ul, ol, dl, dt, dd,
form, blockquote{
	padding: 0;
	margin: 0;
	text-align: left;
	display: block;
}
table {
	margin : 0;
	empty-cells: show;
}
hr {
	display : none;
}
img {
	border: none;
}
li {
	list-style: none;
	margin: 0;
	padding: 0;
}

strong, em{
	font-weight: normal;
	font-style: normal
}
sub{
	vertical-align:-0.3em !important;
	font-size:80% !important;
	line-height:100% !important;
}

sup{
	vertical-align:0.6em !important;
	font-size:80% !important;
	line-height:100% !important;
}

/*
===== 2: link setting ===========================
*/
a:link{
	color: #000000;
	text-decoration:underline;
}
a:visited{
	color: #000000;
	text-decoration:underline;
}
a:hover{
	color: #000000;
	text-decoration: none;
}
a:active{
	color: #000000;
	text-decoration:underline;
}

a:link img,
a:visited img,
a:hover img,
a img
{
	border: none;
	text-decoration: none;
}

/*
===== other ===========================
*/
.end{
	margin: 0;
	padding: 0;
	}

/*
===== clear fix ===========================
*/
.cf:before, .cf:after {
    content: '';
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
    zoom: 1; /* for IE6/7 */
}

.clear{
	clear: both;
	height: 0px;
	line-height: 0%;
	font-size: 0px;
}


/*******
 COMMON
*******/

body{
	text-align: center;
	margin: auto;
	width: 100%;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif ;
	position: relative;
}
img {
	vertical-align:bottom;
}
div.nbo_header{
	width: 100%;
	text-align: center;
	background: url(/atcl/ONB/21/sp/topbar_bg.jpg)no-repeat center -1px;
	border-right: none;
	margin: auto;
	position: relative;
	z-index: 10000;
}
div.nbo_header img{
	max-width: 1000px;
    margin: 0 auto;
}


/*******
 base
*******/

.gnav-201601{
	width: 100% !important;
}
#area{
	width: 100%;
	border-left: none;
	border-right: none;
	border-bottom: none;
}
body.doublePane #wp{
	background: transparent;
	padding: 0;
}
body.doublePane #contents{
	width: 100%;
	float: none;
}
body.doublePane #contents .wrapper{
	width: 1000px;
	margin: 0 auto 50px;
	padding: 40px 0;
	box-shadow: 2px 2px 4px 2px #dddddd;
}
#spheader{
	width: 1000px;
	margin: auto;
}
#spheaderNoImage{
	display: none;
}
#spheader h1 img{
	max-width: 100%;
	height: auto;
}

/*******
 contents
*******/

#contents p{
	margin: 0;
	font-size: 14px;
}
#contents .txt_box{
	width: 800px;
	margin: auto;
	padding: 0;
}
#contents .txt_box .icon{
	color:#000000;
	font-size: 14px;
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px solid #e6e6e6;
}
#contents .ttl_flex{
	display: flex;
	border-bottom: 3px solid #d62030;
	padding-bottom: 10px;
	margin-bottom: 30px;
}
#contents .ttl_flex .img{
	margin:  5px 20px 0 0;
}
#contents .txt_box h2{
	font-size: 25px;
	color: #000000;
	line-height: 1.4em;
	padding-bottom: 15px;
	border-bottom: 2px #e40c29 solid;
}
#contents .txt_box h3{
	font-size: 18px;
	color: #000000;
	line-height: 1.4em;
	padding-bottom: 15px;
	border: none;
	border-bottom: 1px #e40c29 solid;
}
#contents .info_box{
	padding: 10px 0 10px 0;
	border-bottom: 1px solid #e6e6e6;
	margin-bottom: 30px;
}
#contents .info_box .ty1{
	float: left;
	font-size: 12px;
	color: #666666;
}
#contents .info_box .ty2{
	float: right;
	color: #666666;
	font-size: 12px;
	border-left: 1px dotted #666666;
	padding-left: 20px;
}
#contents .txt_box .inner{
	width: 700px;
	margin: auto;
}
#contents .txt_box .inner .text{
	color: #333333;
	font-size: 14px;
	line-height: 2em;
	margin-bottom: 30px;
}
#contents .txt_box .inner .icon2 {
	color: #ffffff;
	background-color: #000000;
	padding: 6px 4px 6px 4px;
	margin-bottom: 20px;
	font-size: 12px;
	line-height: 1em;
	display: inline-block;
}
#contents .bpimage_left{
	margin: 10px 30px 10px 0;
}
#contents .bpimage_right{
	margin: 10px 0 10px 30px;
}
#contents .bpimage_center{
	margin: 40px auto 40px;
}
#contents .bpimage_caption{
	line-height: 1.6em;
}
#contents .splink,
#contents .spcontact{
	width: auto;
	max-width: 700px;
}
#contents .splink .spttl,
#contents .spcontact .spttl{
	background: #000;
}
#contents .splink ul li{
	margin-bottom: 10px;
	padding: 0;
	background: none;
	font-weight: normal;
}
#contents .profile_box{
	width: 560px;
	margin: 40px auto;
	padding: 20px;
	border: solid 1px #ccc;
}
#contents .profile_box .bpimage_center{
	margin: 0 auto 20px;
}
#contents .profile_box a:link,#contents .profile_box a:visited,#contents .profile_box a:active{
	color: #e40c29;
	text-decoration: underline;
}
#contents .profile_box a:hover{
	color: #e40c29;
	text-decoration: none;
}
#contents .profile_box .detail dt{
	float: left;
	font-size: 14px;
	line-height: 2em;
}
#contents .profile_box .detail dd{
	padding-left: 5em;
	font-size: 14px;
	line-height: 2em;
}


/*******
 navi
*******/
.nextPagePreview{
	margin: 0;
	padding: 0;
}
.nextPagePreview span{
	display: none;
}
.nextPagePreview a{
	display: block;
	padding: 20px 160px 20px 40px;
	font-size: 17px;
	line-height: 1em;
	text-align: center;
	transition-duration: 0.3s;
	text-decoration: none;
	max-width: 500px;
	margin: 0 auto 10px;
	border: none;
}
.nextPagePreview a:hover{
	opacity: 0.2;
}
.nextPagePreview a:link, .nextPagePreview a:visited{
	background: url(/atcl/ONB/21/sp/next_banner_icon.png)no-repeat 90% center;
	background-size: 108px 27px;
	background-color: #e40c29;
	color: #ffffff;
}
.nextPagePreview a:hover, .nextPagePreview a:visited:hover{
	background: url(/atcl/ONB/21/sp/next_banner_icon.png)no-repeat 90% center;
	background-size: 108px 27px;
	background-color: #e40c29;
}
#naviBottom{
	margin-bottom: 40px;
	padding: 0;
}
/*#naviBottom .pageNumber{
	width: 200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	padding: 0;
}*/
#naviBottom .pageNumber a{
	width: 40px;
	height: 40px;
	box-sizing: border-box;
	/*display: block;*/
	background-color: #f6f6f6;
    color: #e40c29;
	font-size: 17px;
	text-align: center;
	text-decoration: none;
	padding: 10px 0;
	transition-duration: 0.3s;
	border: none;
	line-height: 1;
}
#naviBottom .pageNumber a:hover{
	opacity: 0.2;
}
#naviBottom .pageNumber a:link, #naviBottom .pageNumber a:visited{
	background: #f6f6f6;
	color: #e40c29;
}
#naviBottom .pageNumber a:hover, #naviBottom .pageNumber a:visited:hover{
	background: #f6f6f6;
	color: #e40c29;
}
#naviBottom .pageNumber a.now{
	background-color: #e40c29;
	color: #ffffff;
}
#naviBottom .pageNumber a.now:hover, #naviBottom .pageNumber a.now:visited:hover{
	background: #e40c29;
	color: #ffffff;
}
#naviBottom .pageNumber a.next, #naviBottom .pageNumber a.prev{
	background-color: #ffffff;
	color: #e40c29;
	width: 100px;
	font-weight: bold;
}
#naviBottom .pageNumber a.next:hover, #naviBottom .pageNumber a.prev:hover{
	background: #ffffff;
}

/* disable */
#contents .nextPagePreview.disable p{
	display: block;
	padding: 20px 160px 20px 40px;
	font-size: 17px;
	line-height: 1em;
	text-align: center;
	max-width: 500px;
	margin: 0 auto 10px;
	border: none;
	color: #ffffff;
	background: url(/atcl/ONB/21/sp/next_banner_icon_gr.png)no-repeat 90% center;
	background-size: 108px 27px;
	background-color: #999999;
}
#naviBottom.disable .pageNumber{
	width: 200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	padding: 0;
}
#naviBottom.disable .pageNumber span{
	display: block;
	width: 40px;
	height: 40px;
	box-sizing: border-box;
	background-color: #f6f6f6;
	font-size: 17px;
	padding: 10px 0;
	border: none;
	line-height: 1;
	margin: 0;
}
#naviBottom.disable .pageNumber span.next{
	width: 100px;
	background-color: #ffffff;
}


/*******
 ttl_block_typ1_grey
*******/

#contents .ttl_block_typ1_grey{
	background: #ffffff;
	border: none;
}
#contents .ttl_block_typ1_grey h2{
	max-width: 700px;
	margin: 0 auto 10px;
	padding: 15px 0 15px 0;
	background: #f2f2f2;
	border-top: none;
	border-bottom: 1px solid #000000;
	color: #000000;
	font-size: 14px;
	text-align: center;
}
#contents .questionnaire_box{
	max-width: 700px;
	margin: 0 auto;
	padding: 0;
	border: none;
}
#contents .questionnaire_box .ttl{
	border-bottom: none;
	font-size: 14px;
}
#contents .questionnaire_box .ttl h3{
	background: none;
	font-size: 14px;
	padding: 0 0 10px 0;
	margin-bottom: 10px;
	border: none;
	border-bottom: 1px dotted #cccccc;
	font-weight: bold;
}
#contents .questionnaire_box .data_box .lst_material{
	padding: 0 0 20px 0;
}
#contents .questionnaire_box .data_box .title{
	border-bottom: 1px dotted #ccc;
	margin: 20px 0 10px 0;
	padding: 5px 0;
	line-height: 1.6em;
	font-weight: bold;
	font-size: 14px;
}
#contents .questionnaire_box .data_box .question_box{
	padding-left: 0;
}
#contents .questionnaire_box .permission .text{
	line-height: 2em;
}
#contents .questionnaire_box .permission .iframe_box{
	width: 80%;
	height: auto;
	margin: 0 auto 20px;
	padding: 0;
	border: 1px solid #dddddd;
}
#contents .questionnaire_box .permission .iframe_box iframe{
	height: auto;
}
#contents .questionnaire_box .data_box{
	line-height: inherit;
}
#contents .questionnaire_box .data_box p{
	font-size: 14px;
}
#contents .questionnaire_box .permission .text_center{
	font-size: 14px;
}
.data_box{
	padding: 0;
}
.data_box .lst_question{
	font-size: 14px;
	color: #333333;
	padding-bottom: 15px;
	border-bottom: 1px dotted #cccccc;
	margin-bottom: 15px;
}
.data_box .lst_question a{
	color: #333333;
	transition-duration: 0.3s;
}
.data_box .lst_question a:hover{
	color: #333333;
	opacity: 0.5;
}
#contents .questionnaire_box .grey_btn .btn_width{
	background: url(/atcl/ONB/21/sp/btn_arrow.png)no-repeat 90% center;
	background-size: 22px 20px;
	border: none;
	width: 400px;
	margin: auto;
	padding: 23px 0 23px 0;
	font-size: 17px;
	color: #ffffff;
	text-align: center;
	transition-duration: 0.3s;
}
.bpimage_caption_right {
	width: 100% !important;
}


/*******
 footer
*******/

#footer{
	width: 100%;
	margin: 0 auto;
	border-top: 2px solid #e6e6e6;
	border-bottom: none;
}
div.localFooter{
	max-width: 1000px;
	padding: 15px 10px 0 10px;
	border: none;
	text-align: left;
	width: auto;
}
div.localFooter ul li.first{
	margin: 0;
}
div.localFooter p{
	padding: 0;
}
.globalFooter .globalCopyright{
	margin: 30px 10px 15px;
}


/*******
 submenu
*******/

#submenu{
	display: none;
}


/*******
 smart
*******/

body.smart{
	min-width: 0px;
}
.smart .pc{
	display: none !important;
}
.smart .local_header{
	background: url(/atcl/ONB/21/sp/sp_logo.jpg) no-repeat center;
	background-size: 106px 30px;
	background-color: #000000;
	height: 30px;
	padding: 10px 0 10px 0;
	position: relative;
	text-align: center;
}
.smart .local_header img{
	display: none;
}
.smart #spheader{
	margin: 0;
	box-shadow: none;
}
.smart #spheader h1{
	display: none;
}
.smart #contents{
	padding: 0;
}
.smart #contents .wrapper {
	margin: 50px auto 0px;
	box-shadow:none;
}
.smart #contents .wrapper .txt_box{
	width: calc(100% - 40px);
}
.smart #contents .wrapper .txt_box h2{
	font-size: 18px;
}
.smart #contents .txt_box .inner{
	width: auto;
}
.smart #contents .profile_box{
	width: 100%;
	box-sizing: border-box;
}
.smart .nextPagePreview a{
	padding-right: 42%;
	padding-left: 20px;
	line-height: 1.4em;
	text-align: left;
	font-size: 15px;
}
.smart #naviBottom{
	padding: 0;
}
.smart #contents .nextPagePreview.disable p{
	padding-right: 42%;
	padding-left: 20px;
	line-height: 1.4em;
	text-align: left;
	font-size: 15px;
}
.smart #contents .questionnaire_box{
	margin: 0 auto 40px;
}
.smart #contents .questionnaire_box .permission .iframe_box{
	width: 100%;
}