@charset "utf-8";

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td,img{
	margin:0;
	padding:0;
}
table {
	border-collapse:collapse;
	border-spacing:0;
}
fieldset,img {
	border:0;
}
address,caption,cite,code,dfn,em,strong,th,var {
	font-style:normal;
	font-weight:normal;
}
ol,ul {
	list-style:none;
}
caption,th {
	text-align:left;
}
h1,h2,h3,h4,h5,h6 {
	font-size:100%;
	font-weight:normal;
}
q:before,q:after {
	content:'';
}
abbr,acronym {
	border:0;
}
 
a{
	text-decoration:none;
}
 
a:hover,a.selected{
	text-decoration:none;
}

/* clear fix */

.clearfix:after {
	content: "";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
 
.clearfix {
	display: inline-table;
	min-height: 1%;
}


/* font */

body{
	font:13px/1.231 Verdana, "メイリオ", Meiryo, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
	line-height:1.38em;
	*font-size:small;
	*font:x-small;
}
 
select,input,button,textarea,button{
	font:99% arial,helvetica,clean,sans-serif;
}
 
table{
	font-size:inherit;
	font:100%;
}
 
pre,code,kbd,samp,tt{
	font-family:monospace;
	*font-size:108%;
	line-height:99%;
}

.ime-off {
	ime-mode: disabled;
}
.ime-on {
	ime-mode: active;
}


.wrap {
	width: 1080px;
	margin: 0 auto;
}

#contents .wrap {
	width: 1020px;
	padding: 0 30px;
}

/* header */

#header {
	margin-bottom: 1px;
}

#header img {
	display: block;
}

/* navi */

#navi ul {
	overflow: hidden;
	background: url("../images/common/navi_bg.png") left top repeat-x;
	padding-left: 32px;
	padding-bottom: 10px;
}

#navi ul li {
	float: left;
	padding: 0 1px;
}

#navi ul li a {
	width: 167px;
	height: 56px;
	overflow: hidden;
	display: block;
}

#navi ul li a:hover img,
#navi ul li.selected a img {
	margin-top: -56px;
}

/* footer */

#footer .wrap > ul {
	text-align: center;
	margin-bottom: 40px;
}

#footer .wrap > ul li {
	display: inline-block;
	border-left: 1px solid #4a167d;
	padding: 0 10px;
}

#footer .wrap > ul li:first-child {
	border-left: none;
}

#footer .wrap > ul li a {
	color: #4a167d;
	text-decoration: underline;
}

#footer .wrap > ul li a:hover {
	text-decoration: none;
	color: #f08200;
}

#footer .wrap > dl {
	background: url("../images/common/contact_bg.jpg") center top no-repeat;
	font-size: 18px;
	line-height: 1.5;
	min-height: 225px;
	padding-left: 32px;
}

#footer .wrap > dl dt {
	border-bottom: 2px solid #caa9ea;
	width: 380px;
	padding: 10px 0;
	margin-bottom: 10px;
}

#footer .wrap > dl dd .tel span {
	color: #4a167d;
	font-weight: bold;
	font-size: 26px;
}

#footer .wrap > dl dd .fax span {
	color: #f08200;
	font-weight: bold;
	font-size: 26px;
}

#footer .wrap > dl dd a {
	color: #000;
	text-decoration: none;
}

#footer .wrap > dl dd a:hover {
	text-decoration: underline;
	color: #f08200;
}

#footer .wrap > div {
	overflow: hidden;
}

#footer .wrap > div p {
	float: left;
	font-size: 11px;
	padding-top: 7px;
	min-height: 25px;
	line-height: 1.5;
}

#footer .wrap > div .privacy-policy {
	width: 328px;
	border-bottom: 6px solid #4a167d;
}

#footer .wrap > div .privacy-policy a {
	background: url("../images/common/privacy_policy_arrow.png") left center no-repeat;
	color: #4a167d;
	text-decoration: underline;
	padding-left: 13px;
}

#footer .wrap > div .privacy-policy a:hover {
	text-decoration: none;
	color: #f08200;
}

#footer .wrap > div .copy {
	width: 732px;
	text-align: right;
	border-bottom: 6px solid #f08200;
	padding-right: 20px;
}

/* to-page-top */
#to-page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
}

#to-page-top a:hover img{
	filter: alpha(opacity=80);
	opacity: 0.8;
}

/* error */
.error-message-top {
	color: #f00;
	font-size: 14px!important;
	font-weight: bold!important;
	background-color: #ffecec;
	text-align: center!important;
	padding: 20px 0px;
	margin: 12px 0!important;
	border-bottom: 3px double #ce0807;
	border-top: 3px double #ce0807;
}

.error-message {
	color: #f00;
	font-weight: bold;
}

th.error {
	background-color: #fcc!important;
}