@charset "utf-8";

/**
 *  common: コンテンツ共通
 */

/*--------------------------------------------------------------------------
	utility
---------------------------------------------------------------------------*/
.hidden{ visibility: hidden; height: 0; padding: 0; line-height: 0;}

.txt-left  { text-align: left;}
.txt-center{ text-align: center;}
.txt-right { text-align: right;}

.left { float: left;}
.right{ float: right;}
.clear{ float: none; clear: both;}

.meiryo{ font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;}
.jp    { font-family: "ヒラギノ角ゴ Pro W3", Osaka, "ＭＳ Ｐゴシック", sans-serif;}
.times { font-family: "Times New Roman", Times, serif;}
.verdana{ font-family: Verdana, sans-serif;}

@media all and (orientation:portrait){
.landscape{ display: none !important;}
}
@media all and (orientation:landscape){
.portrait{ display: none !important;}
}

/* adjust margin */
.mb-type { margin-bottom: 25px;}
.mb-type2{ margin-bottom: 20px !important;}
.mb-type3{ margin-bottom: 15px !important;;}
.mb-type4{ margin-bottom: 10px;}

.em{ font-weight: bold;}

/* clearfix */
.clearfix:before,
.clearfix:after,
.cf:before,
.cf:after{
	content:"";
	display:table;
}
.clearfix:after,
.cf:after{
	clear:both;
}
.clearfix,
.cf{
	zoom:1;
}

/*-----------------------------------------------------
	list-type
-------------------------------------------------------*/
ul.list-type li{
	padding: 0 0 0 1.2em;
	background: url(/shared/images/ico_circle01.png) no-repeat 0 .6em;
}


/*-----------------------------------------------------
	arrow
-------------------------------------------------------*/
.arrow01{
	padding:0 0 0 15px;
	background:url(/shared/images/ico_arrow01.gif) no-repeat 0 .4em;
}
.arrow02{
	padding:0 0 0 10px;
	background:url(/shared/images/ico_arrow02.gif) no-repeat 0 .5em;
}


/*-----------------------------------------------------
	ico
-------------------------------------------------------*/
img.externalIcon{
	margin:-1px 0 0 5px;
	vertical-align:middle;
}


/*-----------------------------------------------------
	frame
-------------------------------------------------------*/
.section-frame{
	width:728px;
	background:url(/shared/images/bg_frame_repeat.gif) repeat-y 0 0;
}
div.section-frame-outline{
	width:100%;
	background:url(/shared/images/bg_frame_top.gif) no-repeat 0 0;
}
div.section-frame-inline{
	zoom:1;
	margin-bottom: 30px;
	padding:30px 22px 30px 20px;
	background:url(/shared/images/bg_frame_bottom.gif) no-repeat 0 100%;
}


/*-----------------------------------------------------
	box
-------------------------------------------------------*/
/* img-box
---------------------*/
div.img-box-cmn{
	width:100%;
	overflow:hidden;
}
div.img-box-cmn p.img{
	float:left;
	margin:0 10px 0 0;
}
div.img-box-cmn div.txt{
	overflow:hidden;
	zoom:1;
}

/* contact-box
---------------------*/
.contact-box{
	border: 5px solid #ff991e;
	background: #fff;
}
.contact-box p.ttl{
	padding: 15px 0 15px 20px;
	background: #ffe1bc;
}
.contact-box .inner{
	padding: 25px 30px;
}
.contact-box dt{
	padding-bottom: 10px;
}
.contact-box dl.right{
	width: 292px;
	padding-left: 40px;
	background: url(/shared/images/contact_box_border.png) repeat-y;
}


/*-----------------------------------------------------
	title
-------------------------------------------------------*/
/* lead-page */
div.lead-page{
	margin:0 0 20px;
}
div.lead-page h1{
	margin:0 0 15px;
}
div.lead-page p{
	margin:0 3px;
}
/* ttl-box01 */
div.ttl-box01{
	padding-bottom: 15px;
}
div.ttl-box01 h2{
	float: left;
}
div.ttl-box01 p{
	float: right;
}

/* .title-box
---------------------*/
.title-box{
	position: relative;
	margin-bottom: 18px;
}
.title-box p{
	position: absolute;
	top: 15px;
	right: 20px;
}
.title-box p a{
	padding-left: 10px;
	background: url(/shared/images/ico_arrow05.png) no-repeat 0 50%;
	color: #fff;
	text-decoration: underline;
}
.title-box p a:hover{
	text-decoration: none;
}

/*-----------------------------------------------------
	title-type
-------------------------------------------------------*/
.title-type{ zoom:1; background: #498DE5; color: #fff; font-size: 117%; font-weight: bold;}
.title-type-outline{ zoom:1; background: url(/shared/images/bg_title_top.gif) no-repeat 0 0;}
.title-type-inline{ width: 650px; padding: 7px 18px 6px; background: url(/shared/images/bg_title_bottom.gif) no-repeat 0 100%;}


/*-----------------------------------------------------
	txt
-------------------------------------------------------*/
.coution{
	color: #fd0101;
	font-size: 93%;
}

/* fontS : 10px
---------------------*/
.fontS{
	font-size: 84%;
}

/* fontM : 14px
---------------------*/
.fontM{
	font-size: 116%;
}

/* color
---------------------*/
.blue{ color: #26477F;}
.red { color: #fd2223;}


/*-----------------------------------------------------
	link
-------------------------------------------------------*/
/* .pagetop
---------------------*/
p.pagetop{
	clear: both;
	margin: -15px 5px 20px;
	text-align: right;
}
#Main p.pagetop a{
	padding-left: 12px;
	background: url(/shared/images/ico_arrow06.png) no-repeat 0 50%;
	color: #202020;
	text-decoration: underline;
}
#Main p.pagetop a:hover{
	color: #1557be;
	text-decoration: none;
}


/*-----------------------------------------------------
	table
-------------------------------------------------------*/
/* .table-type01
---------------------*/
.table-type01{
	width: 100%;
	margin-bottom: 20px;
}
.table-type01,
.table-type01 th,
.table-type01 td{
	border: 1px solid #9cbcef;
	text-align: center;
	vertical-align: middle;
	line-height: 1.5;
}
.table-type01 thead th{
	font-weight: bold;
	background: #deeaf7;
}
.table-type01 thead th a{
	color: #212121;
	text-decoration: underline;
}
.table-type01 thead th a:hover{
	text-decoration: none;
}
.table-type01 th{
	font-weight: normal;
}
.table-type01 th,
.table-type01 td{
	padding: 8px 5px;
}
.table-type01 img{
	vertical-align: middle;
}
.table-type01 tbody tr.even th,
.table-type01 tbody tr.even td{
	background: #fffbe5;
}
/* .table-type02
---------------------*/
.table-type02 th,
.table-type02 td{
	border: 1px solid #C5C5C5;
}
.table-type02 th{
	width: 150px;
	padding: 15px 18px 0;
	background: #FFFADF;
	font-weight: bold;
	text-align: left;
}
.table-type02 td{
	padding: 15px 20px;
}
/* .table-type03 [form]
---------------------*/
.table-type03{
	width: 100%;
}
.table-type03 th,
.table-type03 td{
	vertical-align: top;
	border: 1px solid #d9d8d3;
	border-top: 1px dashed #d9d8d3;
	border-bottom: 1px dashed #d9d8d3;
}
.table-type03 th{
	width: 9em;
	padding: 18px 18px 15px 18px;
	border-right: none;
	background: #fffadf;
	font-weight: bold;
	text-align: left;
}
.table-type03 .first th,
.table-type03 .first td{
	border-top: 1px solid #d9d8d3;
}
.table-type03 .last th,
.table-type03 .last td{
	border-bottom: 1px solid #d9d8d3;
}
.table-type03 td{
	padding: 15px 18px;
	border-left: none;
}
.table-type03 td span.txt{
	padding: 3px 8px;
}
.table-type03 td span.txt.pl-none{
	padding-left: 0;
}
/* required */
.table-type03 th span.position{
	position: relative;
	display: block;
	width: 9em;
	padding-right: 60px;
}
.table-type03 th img{
	position: absolute;
	top: 0;
	right: 0;
}


/*-----------------------------------------------------
	form
-------------------------------------------------------*/
/* common */
form ul.input-list li{
	padding: 3px 0;
}
form p.btn-type01{
	padding-top: 20px;
	text-align: center;
}

/* input parts
---------------------*/
input[type="checkbox"],
input[type="radio"]{
	vertical-align:top;
}

input[type="text"],
textarea{
	box-sizing: border-box;
	width: 100%;
	padding: 3px;
	border-radius: 3px;
	border: 1px solid #d9d9d9;
}
input[type="text"].size5{ width: 5em;}
input[type="text"].size25{ width: 25em;}

input[type=text]:focus,
textarea:focus{
	outline-color: #a3c4f1;
	background: #f0f5fd;
}
