@charset "utf-8";

/*
	File Name   : layout.css
	Description : 各ブロックのレイアウト
*/


/* Container
----------------------------------------------------------- */
#container {
	text-align: left;
	font-size: 100%;
}

/* For modern browsers */
#container:before,
#container:after {
    content:"";
    display:table;
}
 
#containerf:after {
    clear:both;
}
 
/* For IE 6/7 (trigger hasLayout) */
#container {
    zoom:1;
}


/* Header
----------------------------------------------------------- */
#header {
	position: relative;
	width: 1120px;
	height: 123px;
	padding: 27px 0 0 0;
	margin: 0 auto 40px auto;
	font-size: 140%;
}

#header h1 {
	font-weight: normal;
	font-size: 85%;
	margin-bottom: 15px;
}

#header #logo {
	position: absolute;
	top: 56px;
}

#hNav {
	position: absolute;
	top: 45px;
	right: 0;
}

#hNav li {
	padding: 0 12px;
	float: left;
	border-left: 1px dashed #cccccc;
	height: 37px;
}

#hNav li a {
	height: 37px;
	display: table-cell;
    layout-grid-line: 37px;
	vertical-align: middle;
}

#hNav li:first-child {
	border-left: none;
}

#hNav li img {
	vertical-align: top;
}

#hNav .headerSns {
	padding: 0 8px;
}


#fb_area,
#tw_area,
#hb_area,
#line_area,
#rss_area {
	position: relative;
	padding: 0;
	margin: 5px 3px 0 3px;
	float: left;
}

#fb_area{
	background: url(/img/common/hnav_fb_on.png) 0 0 no-repeat;
}

#tw_area {
	background: url(/img/common/hnav_tw_on.png) 0 0 no-repeat;
}

#hb_area {
	background: url(/img/common/hnav_hb_on.png) 0 0 no-repeat;
}

#line_area {
	background: url(/img/common/hnav_line_on.png) 0 0 no-repeat;
}

#rss_area {
	background: url(/img/common/hnav_rss_on.png) 0 0 no-repeat;
}


#hNav li #tw_area a {
	display: inline-block;
	padding-top: 10px;
	height: auto;
}

#hNav li #tw_area a img {
	vertical-align: top;
}


#hNav li #line_area a {
	vertical-align: top;
}


#hNav li #hb_area a {
	vertical-align: top;
}

#fb_area:hover img.snsBtn,
#fb_area.current img.snsBtn,
#tw_area:hover img.snsBtn,
#tw_area.current img.snsBtn,
#hb_area:hover img.snsBtn,
#hb_area.current img.snsBtn,
#line_area:hover img.snsBtn,
#line_area.current img.snsBtn,
#rss_area:hover img.snsBtn,
#rss_area.current img.snsBtn {
	visibility: hidden;
}


/*========= sns popup ========*/
.header_popup {
	width: 312px;
	padding: 24px 4px 4px;
	text-align: center;
	position: absolute;
	top: 30px;
	left: -147px;
	z-index: 600; 
	display: none;
}

.header_popup .inner {
	background-color: #fff;
	padding: 25px 10px 20px 10px;
	position: relative;
	line-height: 1.6;
}

.header_popup .inner p {
	margin-bottom: 10px;
	padding-bottom: 15px;
	border-bottom: 1px solid #cccccc;
}
.header_popup .inner a{
	text-align: center !important;
	display:block !important;
}

.header_popup .inner .headerPopupClose {
	position: absolute;
	right: 5px;
	top: 5px;
	cursor: pointer;
}


#fb_area .header_popup {
	background: url(/img/common/hnav_fb_bg.png) 0 0 no-repeat;
}
#tw_area .header_popup {
	background: url(/img/common/hnav_tw_bg.png) 0 0 no-repeat;
}
#rss_area .header_popup {
	background: url(/img/common/hnav_rss_bg.png) 0 0 no-repeat;
}


.header_popup .inner .fb-like-box {
	padding: 0;
	margin: 0;
	background-color: #fff;
	display: block !important;
}



/*==== sphNav =====*/

#sphNav {
	display: none;
}

#gNav {
	position: absolute;
	top: 113px;
	right: 0;
	height: 40px;
}

#gNav li {
	float: left;
	width: 98px;
	height: 40px;
	position: relative;
}

#gNav li:first-child a span {
	border-left: 1px solid #cccccc;
}

#gNav li a {
	height: 40px;
	display: block;
	text-decoration: none;
}

#gNav li a span {
	border: 1px solid #cccccc;
	border-left: none;
	display: block;
	height: 38px;
	line-height: 38px;
	text-align: center;
	text-decoration: none;
}

#gNav li#nav01 a span,
#gNav li#nav07 a span {
	background: none;
}

#gNav li a:hover span,
#gNav li.current a span,
#all #gNav li#nav01 a span,
#travel #gNav li#nav02 a span,
#case #gNav li#nav03 a span,
#planning #gNav li#nav04 a span,
#introduction #gNav li#nav05 a span,
#theory #gNav li#nav06 a span,
#another #gNav li#nav07 a span {
	border: 1px solid #333333;
	text-align: center;
	background-color: #333333;
	color: #fff;
}

#gNav li#nav01 a:hover span,
#gNav li#nav01.current a span,
#gNav li#nav07 a:hover span,
#gNav li#nav07.current a span {
	background: #333333;
}

#gNav li a:hover,
#gNav li.current a {
}

#gNav li#nav01 a:hover {
	background: none;
}

#gNav li ul:before {
	content: " ";
	position: absolute;
    top: -14px;
	background: url(/img/common/nav_bg.png) 40px 4px no-repeat;
	height: 14px;
	width: 100%;
	display: block;
}

#gNav li ul {
	display: none;
	position: absolute;
	top: 52px;
	left: -1px;
	width: auto;
	background: #f4f4f4;
	border: solid 2px #cccccc;
	z-index: 500;
	width: 140px;
}

#gNav li li:first-child {
	border: none;
}

#gNav li li:first-child a span {
	border-left: none;
}

#gNav li li {
	float: none;
	height: auto;
	width: 100%;
	border-top: 1px dashed #cccccc;
}

#gNav li li a {
	height: auto;
	text-decoration: none;
	display: block;
	padding: 10px 5px 10px 10px;
	text-decoration: none;
}

#gNav li li a:hover:after {
	content: url(/img/common/icon_bread.png);
	float: right;
}

#gNav li li a span {
	padding-right: 15px;
	display: block;
	height: auto;
	line-height: 1.5;
	text-align: left !important;
	border: none !important;
}

#gNav li li a:hover {
	color: #000 !important;
	background: #ffff00;
}

#gNav li.current li a,
#travel #gNav li#nav02 li a,
#case #gNav li#nav03 li a,
#planning #gNav li#nav04 li a,
#introduction #gNav li#nav05 li a,
#theory #gNav li#nav06 li a {
	background: #f4f4f4;
}

#gNav li.current li a:hover,
#travel #gNav li#nav02 li a:hover,
#case #gNav li#nav03 li a:hover,
#planning #gNav li#nav04 li a:hover,
#introduction #gNav li#nav05 li a:hover,
#theory #gNav li#nav06 li a:hover {
	background: #ffff00;
}

.spgNav,
.spgNavClose,
.spgNavSearch {
	display: none;
}


/* Main
----------------------------------------------------------- */
#main {
	width: 1120px;
	margin: 0 auto;
	padding: 0 0 80px 0;
	position: relative;
}

#main #contentsWrap {
	background: url(/img/common/line_contents.png) 770px 0 repeat-y;
}

#contents {
	line-height: 1.6;
	font-size: 160%;
	width: 730px;
	padding: 0 40px 0 0;
/*	border-right: 1px dashed #cccccc;*/
	float: left;
}

.subContents h2,
.subContents h3,
.subContents p,
.subContents div,
.subContents ul {
	margin-bottom: 40px;
}

.subContents p.text {
	margin-bottom: 60px;
}

#pageTop {
	position: fixed;
	bottom: 30px;
	right: 40px;
	display: none;
}

#pageTop img {
    filter: alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5; 
}

#pageTop a:hover img {
    filter: alpha(opacity=100);
    -moz-opacity: 1.0;
    opacity: 1.0;
}

#spPageTop {
	display: none;
}


/* Side
----------------------------------------------------------- */
#sidebar {
	width: 310px;
	float: right;
	font-size: 140%;
	line-height: 1.6;
}

#sidebar .s_ttl {
	margin-bottom: 10px;
}

#sidebar .s_ttl img {
	width: 124px;
	height: auto;
}


#sidebar #sideRanking .s_ttl img {
	width: 220px;
	height: auto;
}
#sidebar #sideRanking_month .s_ttl img {
	width: 240px;
	height: auto;
}



#sidebar p {
	margin-bottom: 15px;
}

.sideBnr {
	background-color: #fff;
}

/*#sidebar .sideBnr01 {
	padding: 4px;
	margin-bottom: 15px;
	background-color: #f4f4f4;
	border: 1px solid #cccccc;
}

#sidebar .sideBnr02 {
	padding: 5px;
	margin-bottom: 15px;
	background: url(/img/common/bnr_bg.png) 0 0 repeat;
}*/

#sideCategory {
	margin-bottom: 50px;
}

#sideCategory ul {
	overflow: hidden;
	margin-left: -2px;
}

#sideCategory li {
	margin: 0 0 2px 2px;
	float: left;
}

#sideCategory li a {
	width: 132px;
	padding: 10px;
	display: block;
	border: 1px solid #eeeeee;
	text-decoration: none;
	color: #000;
	background: #f4f4f4 url(/img/common/side_cate_icon_.png) 100% 15px no-repeat;
}

#sideCategory li a:hover {
	background: #ffff00 url(/img/common/side_cate_icon_.png) 100% 15px no-repeat;
	border: 1px solid #eeee11;
}

#sideSearchBox {
	width: 310px;
	height: 30px;
	margin-bottom: 50px;
	position: relative;
	border-bottom: 2px solid #000;
	padding-bottom: 4px;
}

#sideSearchBox input[type="text"] {
	width: 240px;
	border: none;
	height: 30px;
	line-height: 30px;
	color: #666666;
    /* 20160822 */
    font-size: 16px;
}

#sideSearchBox .searchBtn {
	float: right;
	width: 63px;
	height: 32px;
}

.searchBtn input[type="submit"] {
	position: absolute;
	top: 0;
	right: 0;
	width: 63px;
	height: 32px;
	margin-bottom: 0;
    border: 0px;
    background: url(/img/common/search_btn.png) 0 0 no-repeat;
	cursor: pointer;
	text-indent: -9999px;
}

.searchBtn input[type="submit"]:hover {
    background: url(/img/common/search_btn_on.png) 0 0 no-repeat;
}

#sideSns {
	margin-bottom: 40px;
	padding-top: 30px;
}

#sideSns li {
	margin-bottom: 10px;
}

#sideTag {
	margin-bottom: 40px;
}

#sideTag a {
	border: 2px solid #cccccc;
	display: inline-block;
	margin: 0 10px 10px 0;
	padding: 5px;
	line-height: 1;
	border-radius: 3px;
	color: #000;
	text-decoration: none;
}

#sideTag a:hover {
	background-color: #eeeeee;
}

#sideRanking,
#sideRanking_month {
	margin-bottom: 30px;
}

#sideRanking div.inner,
#sideRanking_month div.inner {
	background-color: #f4f4f4;
	padding: 20px 25px 25px;
}

#sideRanking p,
#sideRanking_month p {
	margin-bottom: 0;
}

#sideRanking p img,
#sideRanking_month p img {
	width: 260px;
	height: auto;
}

#sideRanking ul,
#sideRanking_month ul {
}

#sideRanking li,
#sideRanking_month li {
	border-bottom: 1px solid #cccccc;
	padding: 20px 0;
	margin-bottom: 20px;
	position: relative;
}

#sideRanking li a,
#sideRanking_month  li a {
	text-decoration: none;
}

#sideRanking li:first-child,
#sideRanking_month li:first-child {
	padding-top: 0;
}

#sideRanking li img,
#sideRanking_month li img {
	width: 260px;
	height: auto;
}

#sideRanking .layerImg,
#sideRanking_month .layerImg {
	display: block;
	width: 260px;
	height: auto;
	position: absolute;
	bottom: 20px;
	left: 0;
}

#sideRanking li.rank01,
#sideRanking_month li.rank01 {
	background: url(/img/common/icon_rank1.png) 0 0 no-repeat;
	padding-top: 30px;
}

#sideRanking li.rank02,
#sideRanking_month li.rank02 {
	background: url(/img/common/icon_rank2.png) 0 0 no-repeat;
	padding-top: 30px;
}

#sideRanking li.rank03,
#sideRanking_month li.rank03 {
	background: url(/img/common/icon_rank3.png) 0 0 no-repeat;
	padding-top: 30px;
}

#sideRanking li.rank04,
#sideRanking_month li.rank04 {
	background: url(/img/common/icon_rank4.png) 0 0 no-repeat;
	padding-top: 30px;
}

#sideRanking li.rank05,
#sideRanking_month li.rank05 {
	background: url(/img/common/icon_rank5.png) 0 0 no-repeat;
	padding-top: 30px;
}

#sideRanking li h3,
#sideRanking_month li h3 {
	margin-bottom: 10px;
}


/* Footer
----------------------------------------------------------- */
#footer {
	clear: both;
	font-size: 140%;
}

#footer .footerwrapper {
	background: url(/img/common/bg_footer.png) 0 0 repeat;
	border-top: 1px solid #cccccc;
	padding-top: 40px;
	width: 100%;
	min-width: 1120px;
}

#footer .inner {
	width: 1120px;
	margin: 0 auto;
}

.footerBtm {
	background-color: #000;
	padding: 15px 0;
	color: #999999;
	text-align: center;
	font-size: 71%;
}

.footerBtm span {
	line-height: 46px;
	height: 46px;
	padding: 10px;
}

.fb-like-box {
	padding: 20px 0 20px 5px;
	margin: 0 auto 40px auto;
	background-color: #fff;
	display: block !important;
}

.fb-like-box iframe {
	margin: 0 auto;
}

#footer a {
	text-decoration: none;
}

#footer .sitemap01 {
	border-top: 1px solid #cccccc;
	border-bottom: 1px solid #cccccc;
	padding: 30px 0 30px 20px;
	overflow: hidden;
	line-height: 1.6;
}

#footer .sitemap01 ul {
	float: left;
	width: 145px;
	margin-right: 10px;
}

#footer .sitemap01 li {
	padding-top: 5px;
}

#footer .sitemap01 li:first-child {
	padding-top: 0;
}

#footer .sitemap01 li a {
	padding-left: 20px;
	background: url(/img/common/icon_05.png) 7px 7px no-repeat;
	display: inline-block;
}

#footer .sitemap01 li:first-child a {
	font-weight: bold;
	padding-left: 20px;
	margin-bottom: 10px;
	background: url(/img/common/icon_ft.png) 0 50% no-repeat;
	background-size: 15px auto;
}

#footer .sitemap02 {
	border-bottom: 1px solid #cccccc;
	padding: 30px 0 30px 20px;
	overflow: hidden;
	line-height: 1.6;
}

#footer .sitemap02 li a {
	padding-left: 20px;
	margin-right: 35px;
	background: url(/img/common/icon_ft.png) 0 50% no-repeat;
	float: left;
	display: inline-block;
}

#footer .snsList {
	text-align: center;
	padding: 20px;
}

#footer .snsList ul {
	overflow: hidden;
}

#footer .snsList li {
	display: inline;
	float: none;
	margin: 0 20px;
}

#footer .snsList li iframe {
	vertical-align: middle;
}

#footer .snsList li .spNone {
	/*
	display: inline-block;
	*/
}

#footer .snsList li img {
	height: 20px;
	width: auto;
}

#facebook #u_0_6 {
	display: none !important;
}



/* main slider
----------------------------------------------------------- */
#main_slider{
	overflow: hidden;
	position: static !important;
	max-height: 0px;
}
	#main_slider.view{
		max-height:inherit;
	}
	#main_slider li{
		width: 100% !important;
	}
		#main_slider li img{
			width: 100%;
			height: auto;
		}

