@charset "utf-8";
/* CSS Document */

/* -------------------------------------------------- */
/* BASE --------------------------------------------- */
/* -------------------------------------------------- */
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, form, input, p, blockquote, th, td { margin:0; padding:0; }
body { color:#333; letter-spacing: .02em; font-stretch: ultra-expanded; font: 62.5%/1.4 Avenir , "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "メイリオ" , Meiryo, "Meiryo UI"  , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif; margin: 0 auto; -webkit-text-size-adjust: 100%; }


/* linkTextColor */
a:link {color:#1841ce; text-decoration: none;}
a:visited {color: #572769; text-decoration: none;}
a:active {color: #438f8d; text-decoration: underline;}
a:hover {color: #0e4497; text-decoration: underline;}
a:not[class~=button]:link {color:#1841ce;text-decoration: none;}
a:not[class~=button]:visited {color: #572769;}
a:not[class~=button]:active {color: #438f8d;}
a:not[class~=button]:hover {color: #0e4497;text-decoration: underline;}


img { max-width: 100%; width: auto\9; /* ie8 */ height: auto; border:0; vertical-align: top; }
.a-img a:hover img{ opacity:0.6; filter: alpha(opacity=60); }

ul, ol { list-style: none; }

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

/* pc-nonpc_switch  */
.pc { display:block; }/*pcのみ表示*/
.tablet { display:none; }/* tabletのみ表示*/
.nonpc { display: none; }/*pc非表示、tablet,smartphoneで表示*/
.nonpc-inline { display: none; }/*pc非表示、tablet,smartphoneで表示*/
.pc-tablet { display: block; }/* PC,tabletで表示 */
.pc-tablet-inline { display: inline; }/* PC,tabletで表示 */
.nonpc-small { display: none; }/* smartphoneのみ表示*/
.nonpc-small-inline { display: none; }/* smartphoneのみ表示*/
@media screen and (max-width: 768px) {
.pc { display:none; }/*pcのみ表示*/
.tablet { display:block; }/* tabletのみ表示*/
.nonpc { display:block; }/*pc非表示、tablet,smartphoneで表示*/
.nonpc-inline { display: inline; }/*pc非表示、tablet,smartphoneで表示*/
}
@media screen and (max-width: 480px) {
.tablet { display:none; }/* tabletのみ表示*/
.pc-tablet { display: none; }/* PC,tabletで表示 */
.pc-tablet-inline { display: none; }/* PC,tabletで表示 */
.nonpc-small { display: block; }/* smartphoneのみ表示*/
.nonpc-small-inline { display: inline; }/* smartphoneのみ表示*/
}

/* 全体を含むボックス：100%とする */
#page { width: 100%; }




/* -------------------------------------------------- */
/* HEADER_AREA -------------------------------------- */
/* -------------------------------------------------- */
#header-box { width: 980px; margin: 0 auto;}
#top { font-size:12px; margin: 0; font-weight: normal; line-height: 1.2; padding: 10px 0 20px 0;}
#head {  }
#header-logo { float: left; }
#header-rightBox{ float: right; margin-top: -6px; font-size: 1.2em; }
@media screen and (max-width: 768px) {
#header-box { width: 96%; }
#top { padding: 10px 1em;}
}
@media screen and (max-width: 680px) {
#header-logo { width: 28%; }
#header-rightBox{ width: 66%; }
#header-rightBox .float-l{ width: 42%; max-width: 169px; }
#header-rightBox .float-r{ width: 50%; }
}
@media screen and (max-width: 480px) {
#header-box { width: 300px; }
#head { width: 100%; }
#header-logo { width: 300px; float: none; margin: 0 0 10px 0; text-align: center; }
#header-rightBox{ width: 300px; float: none; text-align: center; }
#header-rightBox .float-l{ float: none; }
}


/* HEADER_AREA - GlobalNavi ---------------- */
#gnavi-box { width: 980px; clear: both; margin: 0 auto; }
#gnavi ul { width: 100%; overflow: hidden; }
#gnavi li { float: left; text-align: center; }
@media screen and (max-width: 768px) {
#gnavi-box { width: 100%; }
#gnavi li { width: 20%; }
}

#gnavi-ul li { height: 38px; background: url(../images/cmn/gnavi_bg.gif) no-repeat right 4px; }
#gnavi-ul li:last-child { background: none; }
#gnavi-ul li a { display: block; padding: 4px 31px 16px; }
#gnavi-ul li a:hover { background: url(../images/cmn/gnavi_bg_over.gif) repeat-x bottom; }

@media screen and (max-width: 580px) {
#gnavi-ul li a{ padding-right: 6%; padding-left: 6%;}
}
@media screen and (max-width: 480px) {
#gnavi-box { width: 100%;}
#gnavi { width: 300px; }
#gnavi ul { border-top: 1px solid #ccc; border-left: 1px solid #ccc; }
#gnavi li { width: 49.6%; border-right: 1px solid #ccc; border-bottom: 1px solid #ccc; }
#gnavi-ul li { background: none; }
#gnavi-ul li a { padding: 14px 28px 10px; }
}




/* -------------------------------------------------- */
/* CONTENTS_AREA ------------------------------------ */
/* -------------------------------------------------- */
/* contents = main + side */

#contents-area { clear: both; margin: 0 auto; width: 980px; background: #FFF; }
#contents-area-box { overflow: hidden; margin: 0 auto; padding: 20px 20px 0 0; width: auto; }
#main { float: right; overflow: hidden; width: 660px; font-size: 1.4em; }
#main p { margin-bottom: 1em; line-height: 1.6; }
@media screen and (max-width: 768px) {
#contents-area { width: 100%; }
#contents-area-box { background: none; border: none; padding:0; }
#main { float: none; padding: 20px 0 0 0; margin: 0 auto; }
}
@media screen and (max-width: 650px) {
#contents-area-box { margin: 0 auto; width: 96%; }
#main { margin: 15px auto 30px 0; padding: 0; width: 100%; }
}
@media screen and (max-width: 480px) {
#contents-area { width: 100%; }
#contents-area-box { margin: 0 auto; padding:0; width: 300px; }
#main { margin: 15px auto 30px 0; padding: 0; width: 100%; }
}

/* CONTENTS_AREA - MAIN ---------------- */
#breadcrumb{ list-style: none; margin: 0 0 10px; padding: 0; border: 1px solid #CCC; height: 26px; line-height: 26px; border-radius: 4px; background: #ECEAE3;}
#breadcrumb li{	padding: 0 6px 0 4px;	float: left; font-size: .91em; color: #757264; }
#breadcrumb li img{ vertical-align: bottom; }
#breadcrumb li a{ display: block; padding: 0 12px 0 0; background: #FFFAF7 url(../images/cmn/crumbs.gif) no-repeat right; color:#757264; }
#breadcrumb li a:hover, #breadcrumb li a:focus{ color: #777; }
@media screen and (max-width: 480px) {
#breadcrumb li{ padding-left: .2em; font-size: .9em; letter-spacing: -1px; }
#breadcrumb li a{ padding-right: 8px; }
}

#page-ttl{ background: url(../images/ttl/ttl_bg.gif) no-repeat left 4px; padding: 2px 0 2px 10px; margin-bottom: 1em; }

.h2-txt { color: #FFF; font-size: 19px; background: #1D1D1D url(../images/cmn/h2_bg.gif) no-repeat 4px 4px; margin-bottom: 10px; padding: 2px 4px 2px 14px; }
.h2-txt a { color: #FFF; }
.h3-txt { padding: 0 0 1px 20px; margin: 0 0 10px 0; background: url(../images/cmn/h3_bg.gif) no-repeat left 2px;}
.h4-txt { color: #5A4F25; padding: 0; margin: 0 0 4px 0; }

@media screen and (max-width: 480px) {
.h2-txt { padding: 6px .1em 1px 16px; font-size: 1.2em; min-height: 28px; }
}

/* ボタンアクション */
.btn-action{ margin: 60px 0; overflow: hidden; width: 658px; height: 238px; border: 1px solid #867637; background: #F5F4F0; page-break-inside: avoid; }
.btn-action-sub{ background: url(../images/cmn/btn_action_bg.gif) no-repeat; overflow: hidden; width: 654px; height: 234px; border: 1px solid #CCC; margin: 1px; }
.btn-action-inner{ float: right; margin: 14px 10px 14px 0; width: 254px; height: 204px; }
.btn-action-inner .tr{ float: right; padding-right: 4px; width: 146px; height: 80px; }
.btn-action-inner a:hover img{ opacity:0.6; filter: alpha(opacity=60); }

@media screen and (max-width: 680px) {
.btn-action{ width: 98%; height: auto; }
.btn-action-sub{ width: 99%; height: auto; margin: .4%; background-size: 94%; }
}
@media screen and (max-width: 600px) {
.btn-action-sub{ background-size: 90%; }
.btn-action-inner{ width: 38%; height: auto; }
}
@media screen and (max-width: 480px) { .btn-action{ display: none; } }


/* ページトップ */
#page-top { float: none; position: fixed; bottom: 50px; right: 30px;text-align:right; padding: 0 0 10px 0; font-size: 110%; font-family: Helvetica, Arial; }
#page-top a { background: rgba(90,79,37,.6); text-decoration: none; color: #fff; width: 100px; padding: 12px 6px; text-align: center; display: block; border-radius: 5px; }
#page-top a:hover { text-decoration: none; background:  rgba( 90, 79, 37, .2); }
@media screen and (max-width: 768px) { #page-top { bottom: 0px; right: 10px; } }



/* -------------------------------------------------- */
/* SIDE_AREA ---------------------------------------- */
/* -------------------------------------------------- */

#sidebar { float: left; width: 300px; font-size: 1.4em;}
#sidebox { width: 270px; margin: 0; }
@media screen and (max-width: 768px) { #sidebar { float: none; width: 100%; } #sidebox { width: 630px; margin: 20px auto; } }
@media screen and (max-width: 650px) { #sidebox { width: 96%; } }
@media screen and (max-width: 480px) { #sidebar { width: 100%; } #sidebox { margin: 0 auto; } }

@media screen and (max-width: 768px) { 
.side-left{ float: left; margin: 0 20px 0 0; }
.side-right{ float: right; margin: 0 0 0 20px; }
}
@media screen and (max-width: 650px) { 
.side-left, .side-right{ width: 48%; }
.side-left{ margin-right: 5px; }
.side-right{ margin-left: 5px; }
}
@media screen and (max-width: 480px) {
.side-left, .side-right{ margin: 0 auto; float: none; width: 240px; }
}


.side-bnr-ul{ margin: 30px 0;}
.side-bnr-ul li{ margin-bottom: 7px; }


.side-menu-ul { margin-top: 20px; }
.side-menu-ul li { padding-bottom: 6px; }
.side-menu-ul li a  { display: block; padding: 0 0 4px 12px;}
.side-menu-ul li a:link { background:url(../images/cmn/side_menu_bg.gif) no-repeat left 4px;color: #333;text-decoration: none;}
/*
.side-menu-ul li a:visited  { background: url(../images/cmn/side_menu_bg.gif) no-repeat;color: #572769;text-decoration: none;}
.side-menu-ul li a:active { background: url(../images/cmn/side_menu_bg.gif) no-repeat;text-decoration: none;}
*/
.side-menu-ul li a:hover { background: url(../images/cmn/side_menu_bg_up.gif) no-repeat left 4px;color: #0e4497;text-decoration: underline;	}
@media screen and (max-width: 480px) {
.side-menu-ul li a  { width: 230px;}	
}

#side-cntct-box{ border: 1px solid #CCC; padding: 5px 10px; width: 250px; text-align: center; }
@media screen and (max-width: 650px) { 
#side-cntct-box{ width: 92%; }
}

#feed{ border: 1px solid #DDD; }
.side-topics{ width: 268px; margin-bottom: 40px; }
.side-topics ul { padding-top: 20px; list-style: disc; margin-left: 24px; }
.side-topics li { margin: 0 0 15px; padding:0;}
#rss{}
@media screen and (max-width: 600px) { 
.side-topics{ width: 100%; }
}



/* ---------------------------------------------------- */
/* FOOTER_AREA ---------------------------------------- */
/* ---------------------------------------------------- */

#footer { width: 100%; margin-top: 40px; clear: both; border-top: 1px solid #DDD; }
#footer-area { width: 980px; margin: 0 auto; font-size: 1.4em; overflow: hidden; }
@media screen and (max-width: 768px) { #footer { float: none; width: 100%; } #footer-area { width: 90%; } }


#footer-menu { padding-bottom: 15px; margin: 0 auto; text-align: center; }
@media screen and (max-width: 768px) { #footer-menu { width: 98%; } }
@media screen and (max-width: 480px) { #footer-menu { width: 100%;} }


#footer-address{ width: 300px; float: left; margin: 20px 0 0 0; text-align: left; }
@media screen and (max-width: 768px) { #footer-address { width: 30%; margin: 30px 0 0 0; } }
@media screen and (max-width: 480px) { #footer-address { float: none; width: 300px; margin: 30px auto; text-align: center; } }


#footer-link { padding: 20px 0 20px 0; float: right; width: 680px; }
#footer-link ul { text-align: left; overflow: hidden; }
#footer-link li { display: inline-block; margin: 4px 0; padding: 0 4px 0 2px; border-right: 1px solid #999; }
#footer-link a{ color: #333; text-decoration: none; }
#footer-link a:hover{ text-decoration: underline; }
@media screen and (max-width: 768px) { #footer-link { width: 64%; } }
@media screen and (max-width: 480px) { #footer-link { width: 100%; padding-top: 0; } }


#footer-copyright { padding: 6px 0; background-color: #000; text-align: center; color: #FFF; font-size: 1.1em; }
#footer-copyright a { color: #FFF; text-decoration: none; }
@media screen and (max-width: 480px) { #footer-copyright { height: auto; } }


/* ---------------------------------------------------- */
/* PRINT ---------------------------------------- */
/* ---------------------------------------------------- */
@media print {
body { background: #FFF; }
#contents-area-box { overflow: visible; }
#page-top { display: none; }
}
